[PATCH 2/16 v6] PCI: define PCI resource names in an 'enum'

Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
From: Yu Zhao
Date: Wednesday, October 22, 2008 - 1:40 am

This patch moves all definitions of the PCI resource names to an 'enum',
and also replaces some hard-coded resource variables with symbol
names. This change eases introduction of device specific resources.

Cc: Alex Chiang <achiang@hp.com>
Cc: Grant Grundler <grundler@parisc-linux.org>
Cc: Greg KH <greg@kroah.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: Jesse Barnes <jbarnes@virtuousgeek.org>
Cc: Matthew Wilcox <matthew@wil.cx>
Cc: Randy Dunlap <randy.dunlap@oracle.com>
Cc: Roland Dreier <rdreier@cisco.com>
Signed-off-by: Yu Zhao <yu.zhao@intel.com>

---
 drivers/pci/pci-sysfs.c |    4 +++-
 drivers/pci/pci.c       |   19 ++-----------------
 drivers/pci/probe.c     |    2 +-
 drivers/pci/proc.c      |    7 ++++---
 include/linux/pci.h     |   37 ++++++++++++++++++++++++-------------
 5 files changed, 34 insertions(+), 35 deletions(-)

diff --git a/drivers/pci/pci-sysfs.c b/drivers/pci/pci-sysfs.c
index 110022d..5c456ab 100644
--- a/drivers/pci/pci-sysfs.c
+++ b/drivers/pci/pci-sysfs.c
@@ -101,11 +101,13 @@ resource_show(struct device * dev, struct device_attribute *attr, char * buf)
 	struct pci_dev * pci_dev = to_pci_dev(dev);
 	char * str = buf;
 	int i;
-	int max = 7;
+	int max;
 	resource_size_t start, end;
 
 	if (pci_dev->subordinate)
 		max = DEVICE_COUNT_RESOURCE;
+	else
+		max = PCI_BRIDGE_RESOURCES;
 
 	for (i = 0; i < max; i++) {
 		struct resource *res =  &pci_dev->resource[i];
diff --git a/drivers/pci/pci.c b/drivers/pci/pci.c
index ae62f01..40284dc 100644
--- a/drivers/pci/pci.c
+++ b/drivers/pci/pci.c
@@ -359,24 +359,9 @@ pci_find_parent_resource(const struct pci_dev *dev, struct resource *res)
 static void
 pci_restore_bars(struct pci_dev *dev)
 {
-	int i, numres;
-
-	switch (dev->hdr_type) {
-	case PCI_HEADER_TYPE_NORMAL:
-		numres = 6;
-		break;
-	case PCI_HEADER_TYPE_BRIDGE:
-		numres = 2;
-		break;
-	case PCI_HEADER_TYPE_CARDBUS:
-		numres = 1;
-		break;
-	default:
-		/* Should never get here, but just in case... */
-		return;
-	}
+	int i;
 
-	for (i = 0; i < numres; i++)
+	for (i = 0; i < PCI_BRIDGE_RESOURCES; i++)
 		pci_update_resource(dev, i);
 }
 
diff --git a/drivers/pci/probe.c b/drivers/pci/probe.c
index aaaf0a1..a52784c 100644
--- a/drivers/pci/probe.c
+++ b/drivers/pci/probe.c
@@ -426,7 +426,7 @@ static struct pci_bus *pci_alloc_child_bus(struct pci_bus *parent,
 	child->subordinate = 0xff;
 
 	/* Set up default resource pointers and names.. */
-	for (i = 0; i < 4; i++) {
+	for (i = 0; i < PCI_BRIDGE_RES_NUM; i++) {
 		child->resource[i] = &bridge->resource[PCI_BRIDGE_RESOURCES+i];
 		child->resource[i]->name = child->name;
 	}
diff --git a/drivers/pci/proc.c b/drivers/pci/proc.c
index e1098c3..f6f2a59 100644
--- a/drivers/pci/proc.c
+++ b/drivers/pci/proc.c
@@ -352,15 +352,16 @@ static int show_device(struct seq_file *m, void *v)
 			dev->vendor,
 			dev->device,
 			dev->irq);
-	/* Here should be 7 and not PCI_NUM_RESOURCES as we need to preserve compatibility */
-	for (i=0; i<7; i++) {
+
+	/* only print standard and ROM resources to preserve compatibility */
+	for (i = 0; i <= PCI_ROM_RESOURCE; i++) {
 		resource_size_t start, end;
 		pci_resource_to_user(dev, i, &dev->resource[i], &start, &end);
 		seq_printf(m, "\t%16llx",
 			(unsigned long long)(start |
 			(dev->resource[i].flags & PCI_REGION_FLAG_MASK)));
 	}
-	for (i=0; i<7; i++) {
+	for (i = 0; i <= PCI_ROM_RESOURCE; i++) {
 		resource_size_t start, end;
 		pci_resource_to_user(dev, i, &dev->resource[i], &start, &end);
 		seq_printf(m, "\t%16llx",
diff --git a/include/linux/pci.h b/include/linux/pci.h
index 43e1fc1..2ada2b6 100644
--- a/include/linux/pci.h
+++ b/include/linux/pci.h
@@ -76,7 +76,30 @@ enum pci_mmap_state {
 #define PCI_DMA_FROMDEVICE	2
 #define PCI_DMA_NONE		3
 
-#define DEVICE_COUNT_RESOURCE	12
+/*
+ *  For PCI devices, the region numbers are assigned this way:
+ */
+enum {
+	/* #0-5: standard PCI regions */
+	PCI_STD_RESOURCES,
+	PCI_STD_RESOURCES_END = 5,
+
+	/* #6: expansion ROM */
+	PCI_ROM_RESOURCE,
+
+	/* address space assigned to buses behind the bridge */
+#ifndef PCI_BRIDGE_RES_NUM
+#define PCI_BRIDGE_RES_NUM 4
+#endif
+	PCI_BRIDGE_RESOURCES,
+	PCI_BRIDGE_RES_END = PCI_BRIDGE_RESOURCES + PCI_BRIDGE_RES_NUM - 1,
+
+	/* total resources associated with a PCI device */
+	PCI_NUM_RESOURCES,
+
+	/* preserve this for compatibility */
+	DEVICE_COUNT_RESOURCE
+};
 
 typedef int __bitwise pci_power_t;
 
@@ -262,18 +285,6 @@ static inline void pci_add_saved_cap(struct pci_dev *pci_dev,
 	hlist_add_head(&new_cap->next, &pci_dev->saved_cap_space);
 }
 
-/*
- *  For PCI devices, the region numbers are assigned this way:
- *
- *	0-5	standard PCI regions
- *	6	expansion ROM
- *	7-10	bridges: address space assigned to buses behind the bridge
- */
-
-#define PCI_ROM_RESOURCE	6
-#define PCI_BRIDGE_RESOURCES	7
-#define PCI_NUM_RESOURCES	11
-
 #ifndef PCI_BUS_NUM_RESOURCES
 #define PCI_BUS_NUM_RESOURCES	16
 #endif
-- 
1.5.6.4

--
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
[PATCH 0/16 v6] PCI: Linux kernel SR-IOV support, Yu Zhao, (Wed Oct 22, 1:38 am)
[PATCH 2/16 v6] PCI: define PCI resource names in an 'enum', Yu Zhao, (Wed Oct 22, 1:40 am)
[PATCH 3/16 v6] PCI: export __pci_read_base, Yu Zhao, (Wed Oct 22, 1:41 am)
git repository for SR-IOV development?, H L, (Thu Nov 6, 9:51 am)
Re: git repository for SR-IOV development?, Greg KH, (Thu Nov 6, 9:59 am)
RE: [PATCH 0/16 v6] PCI: Linux kernel SR-IOV support, Fischer, Anna, (Thu Nov 6, 10:38 am)
Re: [PATCH 0/16 v6] PCI: Linux kernel SR-IOV support, Matthew Wilcox, (Thu Nov 6, 10:47 am)
Re: [PATCH 0/16 v6] PCI: Linux kernel SR-IOV support, Matthew Wilcox, (Thu Nov 6, 11:36 am)
Re: git repository for SR-IOV development?, H L, (Thu Nov 6, 12:58 pm)
RE: [PATCH 0/16 v6] PCI: Linux kernel SR-IOV support, Fischer, Anna, (Thu Nov 6, 1:04 pm)
RE: [PATCH 0/16 v6] PCI: Linux kernel SR-IOV support, Fischer, Anna, (Thu Nov 6, 2:35 pm)
Re: [PATCH 0/16 v6] PCI: Linux kernel SR-IOV support, Simon Horman, (Thu Nov 6, 3:24 pm)
Re: [PATCH 0/16 v6] PCI: Linux kernel SR-IOV support, Anthony Liguori, (Thu Nov 6, 3:38 pm)
Re: [PATCH 0/16 v6] PCI: Linux kernel SR-IOV support, Anthony Liguori, (Thu Nov 6, 3:40 pm)
Re: git repository for SR-IOV development?, Simon Horman, (Thu Nov 6, 3:56 pm)
Re: [PATCH 0/16 v6] PCI: Linux kernel SR-IOV support, Matthew Wilcox, (Thu Nov 6, 3:58 pm)
Re: [PATCH 0/16 v6] PCI: Linux kernel SR-IOV support, Chris Wright, (Thu Nov 6, 4:54 pm)
RE: [PATCH 0/16 v6] PCI: Linux kernel SR-IOV support, Dong, Eddie, (Thu Nov 6, 6:52 pm)
Re: git repository for SR-IOV development?, Greg KH, (Thu Nov 6, 6:58 pm)
RE: [PATCH 0/16 v6] PCI: Linux kernel SR-IOV support, Nakajima, Jun, (Thu Nov 6, 7:08 pm)
RE: [PATCH 0/16 v6] PCI: Linux kernel SR-IOV support, Leonid Grossman, (Fri Nov 7, 12:29 am)
Re: git repository for SR-IOV development?, Yu Zhao, (Fri Nov 7, 6:09 am)
RE: [PATCH 0/16 v6] PCI: Linux kernel SR-IOV support, Fischer, Anna, (Sat Nov 8, 4:09 am)
RE: [PATCH 0/16 v6] PCI: Linux kernel SR-IOV support, Leonid Grossman, (Sat Nov 8, 8:37 am)
Re: [PATCH 0/16 v6] PCI: Linux kernel SR-IOV support, Muli Ben-Yehuda, (Sat Nov 8, 11:41 pm)
Re: [PATCH 0/16 v6] PCI: Linux kernel SR-IOV support, Avi Kivity, (Sun Nov 9, 12:37 pm)
Re: [PATCH 0/16 v6] PCI: Linux kernel SR-IOV support, Avi Kivity, (Tue Nov 11, 2:00 am)