aboutsummaryrefslogtreecommitdiffstats
path: root/arch/powerpc
diff options
context:
space:
mode:
authorStephen Rothwell <sfr@canb.auug.org.au>2006-05-19 02:48:47 -0400
committerPaul Mackerras <paulus@samba.org>2006-05-24 02:08:56 -0400
commit96ff6afaf1c2fdd118139095dea66c0910379780 (patch)
tree5364530523d40789b549edc66e02e47b04932c9a /arch/powerpc
parent0d177df15d12926dc2ef7c814f317f02de52ce17 (diff)
[PATCH] powerpc: remove iSeries_Global_Device_List
We can now scan the list of device nodes instead. This also allows us to remove the Device_list member of struct pci_dn. Signed-off-by: Stephen Rothwell <sfr@canb.auug.org.au> Signed-off-by: Paul Mackerras <paulus@samba.org>
Diffstat (limited to 'arch/powerpc')
-rw-r--r--arch/powerpc/platforms/iseries/iommu.c15
-rw-r--r--arch/powerpc/platforms/iseries/pci.c14
2 files changed, 15 insertions, 14 deletions
diff --git a/arch/powerpc/platforms/iseries/iommu.c b/arch/powerpc/platforms/iseries/iommu.c
index 3ac22065c424..75a5a1e8abb8 100644
--- a/arch/powerpc/platforms/iseries/iommu.c
+++ b/arch/powerpc/platforms/iseries/iommu.c
@@ -32,13 +32,11 @@
32#include <asm/tce.h> 32#include <asm/tce.h>
33#include <asm/machdep.h> 33#include <asm/machdep.h>
34#include <asm/abs_addr.h> 34#include <asm/abs_addr.h>
35#include <asm/prom.h>
35#include <asm/pci-bridge.h> 36#include <asm/pci-bridge.h>
36#include <asm/iseries/hv_call_xm.h> 37#include <asm/iseries/hv_call_xm.h>
37#include <asm/iseries/iommu.h> 38#include <asm/iseries/iommu.h>
38 39
39extern struct list_head iSeries_Global_Device_List;
40
41
42static void tce_build_iSeries(struct iommu_table *tbl, long index, long npages, 40static void tce_build_iSeries(struct iommu_table *tbl, long index, long npages,
43 unsigned long uaddr, enum dma_data_direction direction) 41 unsigned long uaddr, enum dma_data_direction direction)
44{ 42{
@@ -140,10 +138,15 @@ void iommu_table_getparms_iSeries(unsigned long busno,
140 */ 138 */
141static struct iommu_table *iommu_table_find(struct iommu_table * tbl) 139static struct iommu_table *iommu_table_find(struct iommu_table * tbl)
142{ 140{
143 struct pci_dn *pdn; 141 struct device_node *node;
142
143 for (node = NULL; (node = of_find_all_nodes(node)); ) {
144 struct pci_dn *pdn = PCI_DN(node);
145 struct iommu_table *it;
144 146
145 list_for_each_entry(pdn, &iSeries_Global_Device_List, Device_List) { 147 if (pdn == NULL)
146 struct iommu_table *it = pdn->iommu_table; 148 continue;
149 it = pdn->iommu_table;
147 if ((it != NULL) && 150 if ((it != NULL) &&
148 (it->it_type == TCE_PCI) && 151 (it->it_type == TCE_PCI) &&
149 (it->it_offset == tbl->it_offset) && 152 (it->it_offset == tbl->it_offset) &&
diff --git a/arch/powerpc/platforms/iseries/pci.c b/arch/powerpc/platforms/iseries/pci.c
index 9d571e749098..5bc08d4eef49 100644
--- a/arch/powerpc/platforms/iseries/pci.c
+++ b/arch/powerpc/platforms/iseries/pci.c
@@ -50,8 +50,6 @@
50 */ 50 */
51static struct device_node *find_Device_Node(int bus, int devfn); 51static struct device_node *find_Device_Node(int bus, int devfn);
52 52
53LIST_HEAD(iSeries_Global_Device_List);
54
55static int Pci_Retry_Max = 3; /* Only retry 3 times */ 53static int Pci_Retry_Max = 3; /* Only retry 3 times */
56static int Pci_Error_Flag = 1; /* Set Retry Error on. */ 54static int Pci_Error_Flag = 1; /* Set Retry Error on. */
57 55
@@ -245,8 +243,6 @@ void iSeries_pcibios_init(void)
245 pdn->bussubno = *busp; 243 pdn->bussubno = *busp;
246 pdn->Irq = irq; 244 pdn->Irq = irq;
247 pdn->LogicalSlot = *lsn; 245 pdn->LogicalSlot = *lsn;
248 list_add_tail(&pdn->Device_List,
249 &iSeries_Global_Device_List);
250 } 246 }
251 } 247 }
252} 248}
@@ -338,11 +334,13 @@ EXPORT_SYMBOL(iSeries_memcpy_fromio);
338 */ 334 */
339static struct device_node *find_Device_Node(int bus, int devfn) 335static struct device_node *find_Device_Node(int bus, int devfn)
340{ 336{
341 struct pci_dn *pdn; 337 struct device_node *node;
338
339 for (node = NULL; (node = of_find_all_nodes(node)); ) {
340 struct pci_dn *pdn = PCI_DN(node);
342 341
343 list_for_each_entry(pdn, &iSeries_Global_Device_List, Device_List) { 342 if (pdn && (bus == pdn->busno) && (devfn == pdn->devfn))
344 if ((bus == pdn->busno) && (devfn == pdn->devfn)) 343 return node;
345 return pdn->node;
346 } 344 }
347 return NULL; 345 return NULL;
348} 346}