diff options
-rw-r--r-- | arch/powerpc/kernel/pci_dn.c | 5 | ||||
-rw-r--r-- | arch/powerpc/platforms/iseries/pci.c | 12 | ||||
-rw-r--r-- | include/asm-powerpc/pci-bridge.h | 1 |
3 files changed, 7 insertions, 11 deletions
diff --git a/arch/powerpc/kernel/pci_dn.c b/arch/powerpc/kernel/pci_dn.c index 85d4d8924b5c..1c67de52e3ce 100644 --- a/arch/powerpc/kernel/pci_dn.c +++ b/arch/powerpc/kernel/pci_dn.c | |||
@@ -56,11 +56,6 @@ static void * __devinit update_dn_pci_info(struct device_node *dn, void *data) | |||
56 | pdn->busno = (regs[0] >> 16) & 0xff; | 56 | pdn->busno = (regs[0] >> 16) & 0xff; |
57 | pdn->devfn = (regs[0] >> 8) & 0xff; | 57 | pdn->devfn = (regs[0] >> 8) & 0xff; |
58 | } | 58 | } |
59 | if (firmware_has_feature(FW_FEATURE_ISERIES)) { | ||
60 | const u32 *busp = of_get_property(dn, "linux,subbus", NULL); | ||
61 | if (busp) | ||
62 | pdn->bussubno = *busp; | ||
63 | } | ||
64 | 59 | ||
65 | pdn->pci_ext_config_space = (type && *type == 1); | 60 | pdn->pci_ext_config_space = (type && *type == 1); |
66 | return NULL; | 61 | return NULL; |
diff --git a/arch/powerpc/platforms/iseries/pci.c b/arch/powerpc/platforms/iseries/pci.c index 931941036b91..cc562e4c2f32 100644 --- a/arch/powerpc/platforms/iseries/pci.c +++ b/arch/powerpc/platforms/iseries/pci.c | |||
@@ -29,6 +29,7 @@ | |||
29 | #include <linux/init.h> | 29 | #include <linux/init.h> |
30 | #include <linux/module.h> | 30 | #include <linux/module.h> |
31 | #include <linux/pci.h> | 31 | #include <linux/pci.h> |
32 | #include <linux/of.h> | ||
32 | 33 | ||
33 | #include <asm/types.h> | 34 | #include <asm/types.h> |
34 | #include <asm/io.h> | 35 | #include <asm/io.h> |
@@ -70,7 +71,7 @@ static long current_iomm_table_entry; | |||
70 | * Lookup Tables. | 71 | * Lookup Tables. |
71 | */ | 72 | */ |
72 | static struct device_node *iomm_table[IOMM_TABLE_MAX_ENTRIES]; | 73 | static struct device_node *iomm_table[IOMM_TABLE_MAX_ENTRIES]; |
73 | static u8 iobar_table[IOMM_TABLE_MAX_ENTRIES]; | 74 | static u64 ds_addr_table[IOMM_TABLE_MAX_ENTRIES]; |
74 | 75 | ||
75 | static DEFINE_SPINLOCK(iomm_table_lock); | 76 | static DEFINE_SPINLOCK(iomm_table_lock); |
76 | 77 | ||
@@ -80,8 +81,9 @@ static DEFINE_SPINLOCK(iomm_table_lock); | |||
80 | static inline u64 iseries_ds_addr(struct device_node *node) | 81 | static inline u64 iseries_ds_addr(struct device_node *node) |
81 | { | 82 | { |
82 | struct pci_dn *pdn = PCI_DN(node); | 83 | struct pci_dn *pdn = PCI_DN(node); |
84 | const u32 *sbp = of_get_property(node, "linux,subbus", NULL); | ||
83 | 85 | ||
84 | return ((u64)pdn->busno << 48) + ((u64)pdn->bussubno << 40) | 86 | return ((u64)pdn->busno << 48) + ((u64)(sbp ? *sbp : 0) << 40) |
85 | + ((u64)0x10 << 32); | 87 | + ((u64)0x10 << 32); |
86 | } | 88 | } |
87 | 89 | ||
@@ -333,7 +335,8 @@ static void __init iomm_table_allocate_entry(struct pci_dev *dev, int bar_num) | |||
333 | */ | 335 | */ |
334 | while (bar_size > 0 ) { | 336 | while (bar_size > 0 ) { |
335 | iomm_table[current_iomm_table_entry] = dev->sysdata; | 337 | iomm_table[current_iomm_table_entry] = dev->sysdata; |
336 | iobar_table[current_iomm_table_entry] = bar_num; | 338 | ds_addr_table[current_iomm_table_entry] = |
339 | iseries_ds_addr(dev->sysdata) | (bar_num << 24); | ||
337 | bar_size -= IOMM_TABLE_ENTRY_SIZE; | 340 | bar_size -= IOMM_TABLE_ENTRY_SIZE; |
338 | ++current_iomm_table_entry; | 341 | ++current_iomm_table_entry; |
339 | } | 342 | } |
@@ -598,8 +601,7 @@ static inline struct device_node *xlate_iomm_address( | |||
598 | dn = iomm_table[ind]; | 601 | dn = iomm_table[ind]; |
599 | 602 | ||
600 | if (dn != NULL) { | 603 | if (dn != NULL) { |
601 | int barnum = iobar_table[ind]; | 604 | *dsaptr = ds_addr_table[ind]; |
602 | *dsaptr = iseries_ds_addr(dn) | (barnum << 24); | ||
603 | *bar_offset = base_addr % IOMM_TABLE_ENTRY_SIZE; | 605 | *bar_offset = base_addr % IOMM_TABLE_ENTRY_SIZE; |
604 | } else | 606 | } else |
605 | panic("PCI: Invalid PCI IO address detected!\n"); | 607 | panic("PCI: Invalid PCI IO address detected!\n"); |
diff --git a/include/asm-powerpc/pci-bridge.h b/include/asm-powerpc/pci-bridge.h index 29324047779d..a6ea49eb680b 100644 --- a/include/asm-powerpc/pci-bridge.h +++ b/include/asm-powerpc/pci-bridge.h | |||
@@ -165,7 +165,6 @@ struct iommu_table; | |||
165 | 165 | ||
166 | struct pci_dn { | 166 | struct pci_dn { |
167 | int busno; /* pci bus number */ | 167 | int busno; /* pci bus number */ |
168 | int bussubno; /* pci subordinate bus number */ | ||
169 | int devfn; /* pci device and function number */ | 168 | int devfn; /* pci device and function number */ |
170 | 169 | ||
171 | struct pci_controller *phb; /* for pci devices */ | 170 | struct pci_controller *phb; /* for pci devices */ |