[POWERPC] pci_controller->arch_data really is a struct device_node *
authorStephen Rothwell <sfr@canb.auug.org.au>
Mon, 10 Dec 2007 03:33:21 +0000 (14:33 +1100)
committerPaul Mackerras <paulus@samba.org>
Tue, 11 Dec 2007 02:42:37 +0000 (13:42 +1100)
Signed-off-by: Stephen Rothwell <sfr@canb.auug.org.au>
Signed-off-by: Paul Mackerras <paulus@samba.org>
18 files changed:
arch/powerpc/kernel/isa-bridge.c
arch/powerpc/kernel/pci-common.c
arch/powerpc/kernel/pci_32.c
arch/powerpc/kernel/pci_64.c
arch/powerpc/kernel/pci_dn.c
arch/powerpc/kernel/prom_parse.c
arch/powerpc/kernel/rtas_pci.c
arch/powerpc/platforms/82xx/pq2.c
arch/powerpc/platforms/85xx/mpc85xx_ds.c
arch/powerpc/platforms/86xx/mpc8610_hpcd.c
arch/powerpc/platforms/86xx/mpc86xx_hpcn.c
arch/powerpc/platforms/cell/io-workarounds.c
arch/powerpc/platforms/celleb/io-workarounds.c
arch/powerpc/platforms/celleb/pci.c
arch/powerpc/platforms/maple/pci.c
arch/powerpc/platforms/powermac/pci.c
arch/powerpc/platforms/pseries/iommu.c
include/asm-powerpc/pci-bridge.h

index 965bfcc9ad2d6e5a8887933876b3ac8db7bd59c3..ee172aa42aa7713abba98220903b826ab5d8cadf 100644 (file)
@@ -145,7 +145,7 @@ void __init isa_bridge_find_early(struct pci_controller *hose)
        for_each_node_by_type(np, "isa") {
                /* Look for our hose being a parent */
                for (parent = of_get_parent(np); parent;) {
-                       if (parent == hose->arch_data) {
+                       if (parent == hose->dn) {
                                of_node_put(parent);
                                break;
                        }
index 5a9d4c7bfec50302d4526bad481c49c75e660a6f..2f3f30efffed67e266663337e165f3d3e111dfc6 100644 (file)
@@ -62,7 +62,7 @@ struct pci_controller *pcibios_alloc_controller(struct device_node *dev)
        phb->global_number = global_phb_number++;
        list_add_tail(&phb->list_node, &hose_list);
        spin_unlock(&hose_spinlock);
-       phb->arch_data = dev;
+       phb->dn = dev;
        phb->is_dynamic = mem_init_done;
 #ifdef CONFIG_PPC64
        if (dev) {
@@ -137,7 +137,7 @@ struct pci_controller* pci_find_hose_for_OF_device(struct device_node* node)
        while(node) {
                struct pci_controller *hose, *tmp;
                list_for_each_entry_safe(hose, tmp, &hose_list, list_node)
-                       if (hose->arch_data == node)
+                       if (hose->dn == node)
                                return hose;
                node = node->parent;
        }
index 0e2bee46304c51fc109d0e2b899a6ce6a559f841..096c97e03aa655d1e723cc579da9252929e7cad6 100644 (file)
@@ -662,8 +662,8 @@ pcibios_make_OF_bus_map(void)
 
        /* For each hose, we begin searching bridges */
        list_for_each_entry_safe(hose, tmp, &hose_list, list_node) {
-               struct device_node* node;       
-               node = (struct device_node *)hose->arch_data;
+               struct device_node* node = hose->dn;
+
                if (!node)
                        continue;
                make_one_node_map(node, hose->first_busno);
@@ -742,7 +742,7 @@ static struct device_node *scan_OF_for_pci_bus(struct pci_bus *bus)
                struct pci_controller *hose = pci_bus_to_host(bus);
                if (hose == NULL)
                        return NULL;
-               return of_node_get(hose->arch_data);
+               return of_node_get(hose->dn);
        }
 
        /* not a root bus, we need to get our parent */
@@ -812,9 +812,9 @@ pci_device_from_OF_node(struct device_node* node, u8* bus, u8* devfn)
                return -ENODEV;
        /* Make sure it's really a PCI device */
        hose = pci_find_hose_for_OF_device(node);
-       if (!hose || !hose->arch_data)
+       if (!hose || !hose->dn)
                return -ENODEV;
-       if (!scan_OF_pci_childs(((struct device_node*)hose->arch_data)->child,
+       if (!scan_OF_pci_childs(hose->dn->child,
                        find_OF_pci_device_filter, (void *)node))
                return -ENODEV;
        reg = of_get_property(node, "reg", NULL);
index 002cd4cac0f380551cb7cf6ce37a7c5f8f4491f1..6b9a8564e73513d14ec41c8c6dd8d5e7ef653155 100644 (file)
@@ -458,7 +458,7 @@ EXPORT_SYMBOL(of_scan_pci_bridge);
 void __devinit scan_phb(struct pci_controller *hose)
 {
        struct pci_bus *bus;
-       struct device_node *node = hose->arch_data;
+       struct device_node *node = hose->dn;
        int i, mode;
        struct resource *res;
 
@@ -705,8 +705,7 @@ int pcibios_unmap_io_space(struct pci_bus *bus)
        if (hose->io_base_alloc == 0)
                return 0;
 
-       DBG("IO unmapping for PHB %s\n",
-           ((struct device_node *)hose->arch_data)->full_name);
+       DBG("IO unmapping for PHB %s\n", hose->dn->full_name);
        DBG("  alloc=0x%p\n", hose->io_base_alloc);
 
        /* This is a PHB, we fully unmap the IO area */
@@ -765,8 +764,7 @@ int __devinit pcibios_map_io_space(struct pci_bus *bus)
        hose->io_base_virt = (void __iomem *)(area->addr +
                                              hose->io_base_phys - phys_page);
 
-       DBG("IO mapping for PHB %s\n",
-           ((struct device_node *)hose->arch_data)->full_name);
+       DBG("IO mapping for PHB %s\n", hose->dn->full_name);
        DBG("  phys=0x%016lx, virt=0x%p (alloc=0x%p)\n",
            hose->io_base_phys, hose->io_base_virt, hose->io_base_alloc);
        DBG("  size=0x%016lx (alloc=0x%016lx)\n",
index b4839038613d2232c8a2c7cc2ba9a56c95795969..85d4d8924b5ca1628cde9eee99088f53b5885098 100644 (file)
@@ -133,7 +133,7 @@ void *traverse_pci_devices(struct device_node *start, traverse_func pre,
  */
 void __devinit pci_devs_phb_init_dynamic(struct pci_controller *phb)
 {
-       struct device_node * dn = (struct device_node *) phb->arch_data;
+       struct device_node *dn = phb->dn;
        struct pci_dn *pdn;
 
        /* PHB nodes themselves must not match */
index b5c96af955c639ce43ea1532423bebebf0a6b177..6bdfaf3f99eaa0151d80ccee0e8704e0f5e1f8c5 100644 (file)
@@ -273,7 +273,7 @@ int of_irq_map_pci(struct pci_dev *pdev, struct of_irq *out_irq)
 #else
                        struct pci_controller *host;
                        host = pci_bus_to_host(pdev->bus);
-                       ppnode = host ? host->arch_data : NULL;
+                       ppnode = host ? host->dn : NULL;
 #endif
                        /* No node for host bridge ? give up */
                        if (ppnode == NULL)
index 21f14e57d1f3d848d9d7d375abf96c2a83ae1b27..3650eb50c27d2c910fd072e875244bc43ef83469 100644 (file)
@@ -260,7 +260,7 @@ static int phb_set_bus_ranges(struct device_node *dev,
 
 int __devinit rtas_setup_phb(struct pci_controller *phb)
 {
-       struct device_node *dev = phb->arch_data;
+       struct device_node *dev = phb->dn;
 
        if (is_python(dev))
                python_countermeasures(dev);
index a497cbaa1ac5ad7ba76db0d2a0890fe47b2171d9..11d1db8bb09154b3742226aef0d3b4094d6f11df 100644 (file)
@@ -59,7 +59,7 @@ static void __init pq2_pci_add_bridge(struct device_node *np)
        if (!hose)
                return;
 
-       hose->arch_data = np;
+       hose->dn = np;
 
        setup_indirect_pci(hose, r.start + 0x100, r.start + 0x104, 0);
        pci_process_bridge_OF_ranges(hose, np, 1);
index 59c121a97ac7c60a0069e4b0dc91ee46c245814f..bdb3d0b38cd2789b1cde4d63f7ffcad2a9af6336 100644 (file)
@@ -123,7 +123,7 @@ static int mpc85xx_exclude_device(struct pci_controller *hose,
        struct device_node* node;
        struct resource rsrc;
 
-       node = (struct device_node *)hose->arch_data;
+       node = hose->dn;
        of_address_to_resource(node, 0, &rsrc);
 
        if ((rsrc.start & 0xfffff) == primary_phb_addr) {
index 6390895e5e9258ae03c07512180c1a94f3dc3224..c6d2f48f8f3d2ef44f1bf1c95e2014074ba58cad 100644 (file)
@@ -124,7 +124,7 @@ static void __devinit quirk_uli5229(struct pci_dev *dev)
 static void __devinit final_uli5288(struct pci_dev *dev)
 {
        struct pci_controller *hose = pci_bus_to_host(dev->bus);
-       struct device_node *hosenode = hose ? hose->arch_data : NULL;
+       struct device_node *hosenode = hose ? hose->dn : NULL;
        struct of_irq oirq;
        int virq, pin = 2;
        u32 laddr[3];
index 32a531aebcb78458ca1998387c29ad9441337213..14f4e527e7ac0245224819e578ae73506a6ad530 100644 (file)
@@ -116,7 +116,7 @@ static int mpc86xx_exclude_device(struct pci_controller *hose,
        struct device_node* node;       
        struct resource rsrc;
 
-       node = (struct device_node *)hose->arch_data;
+       node = hose->dn;
        of_address_to_resource(node, 0, &rsrc);
 
        if ((rsrc.start & 0xfffff) == 0x8000) {
index 9d7c2ef940a818fff1406e7b6523174499451da9..b86076e3c09e402a6e74b880a8d23a8160143b33 100644 (file)
@@ -238,7 +238,7 @@ static void __init spider_pci_setup_chip(struct spider_pci_bus *bus)
 static void __init spider_pci_add_one(struct pci_controller *phb)
 {
        struct spider_pci_bus *bus = &spider_pci_busses[spider_pci_count];
-       struct device_node *np = phb->arch_data;
+       struct device_node *np = phb->dn;
        struct resource rsrc;
        void __iomem *regs;
 
@@ -317,7 +317,7 @@ static int __init spider_pci_workaround_init(void)
         * update this code to cope with dynamically added busses
         */
        list_for_each_entry(phb, &hose_list, list_node) {
-               struct device_node *np = phb->arch_data;
+               struct device_node *np = phb->dn;
                const char *model = of_get_property(np, "model", NULL);
 
                /* If no model property or name isn't exactly "pci", skip */
index 32b9cecfda1566a28204b85b808911d456038279..b939c0e98af8eaf018acb3afce1621f32a87172d 100644 (file)
@@ -222,7 +222,7 @@ void __init celleb_pci_add_one(struct pci_controller *phb,
                               void (*dummy_read)(struct pci_controller *))
 {
        struct celleb_pci_bus *bus = &celleb_pci_busses[celleb_pci_count];
-       struct device_node *np = phb->arch_data;
+       struct device_node *np = phb->dn;
 
        if (celleb_pci_count >= MAX_CELLEB_PCI_BUS) {
                printk(KERN_ERR "Too many pci bridges, workarounds"
@@ -262,7 +262,7 @@ int __init celleb_pci_workaround_init(void)
        }
 
        list_for_each_entry(phb, &hose_list, list_node) {
-               node = phb->arch_data;
+               node = phb->dn;
                match = of_match_node(celleb_pci_workaround_match, node);
 
                if (match) {
index 13ec4a606b9611d6715c39990eeda0a47ffe67c7..5d399e038c2326954002f956e89199d97f333f10 100644 (file)
@@ -480,7 +480,7 @@ static struct of_device_id celleb_phb_match[] __initdata = {
 
 int __init celleb_setup_phb(struct pci_controller *phb)
 {
-       struct device_node *dev = phb->arch_data;
+       struct device_node *dev = phb->dn;
        const struct of_device_id *match;
        int (*setup_func)(struct device_node *, struct pci_controller *);
 
index 771ed0cf29a5d8c0c5f8d7858ddf223913d19f5a..3ffa0ac170eeefc84ff28bba853b485156ebc66e 100644 (file)
@@ -558,7 +558,7 @@ void __init maple_pci_init(void)
         * safe assumptions hopefully.
         */
        if (u3_agp) {
-               struct device_node *np = u3_agp->arch_data;
+               struct device_node *np = u3_agp->dn;
                PCI_DN(np)->busno = 0xf0;
                for (np = np->child; np; np = np->sibling)
                        PCI_DN(np)->busno = 0xf0;
index ec49099830d55b0fe5c256180b3ac8b3c7f4eafb..778c249d88156221bb52c3a4f72e93d5d6a547ca 100644 (file)
@@ -319,7 +319,7 @@ static int u3_ht_skip_device(struct pci_controller *hose,
        if (bus->self)
                busdn = pci_device_to_OF_node(bus->self);
        else
-               busdn = hose->arch_data;
+               busdn = hose->dn;
        for (dn = busdn->child; dn; dn = dn->sibling)
                if (PCI_DN(dn) && PCI_DN(dn)->devfn == devfn)
                        break;
@@ -778,7 +778,7 @@ static void __init setup_u4_pcie(struct pci_controller* hose)
 
 static void __init setup_u3_ht(struct pci_controller* hose)
 {
-       struct device_node *np = (struct device_node *)hose->arch_data;
+       struct device_node *np = hose->dn;
        struct pci_controller *other = NULL;
        int i, cur;
 
@@ -1032,7 +1032,7 @@ void __init pmac_pci_init(void)
         * future though
         */
        if (u3_agp) {
-               struct device_node *np = u3_agp->arch_data;
+               struct device_node *np = u3_agp->dn;
                PCI_DN(np)->busno = 0xf0;
                for (np = np->child; np; np = np->sibling)
                        PCI_DN(np)->busno = 0xf0;
index ebb9313b6e91727f3620c0b4ef518db64498cb81..a65c763082010c8c1ff7d6fd0a8b458974fef085 100644 (file)
@@ -251,7 +251,7 @@ static void iommu_table_setparms(struct pci_controller *phb,
        const unsigned long *basep;
        const u32 *sizep;
 
-       node = (struct device_node *)phb->arch_data;
+       node = phb->dn;
 
        basep = of_get_property(node, "linux,tce-base", NULL);
        sizep = of_get_property(node, "linux,tce-size", NULL);
index f67d262d9ec635d70bbb59668c82b0c8eda7dfab..f139f2a44b19b0d7cf7bfa9033315ea1261b251f 100644 (file)
@@ -11,6 +11,8 @@
 #include <linux/list.h>
 #include <linux/ioport.h>
 
+struct device_node;
+
 /*
  * Structure of a PCI controller (host bridge)
  */
@@ -20,7 +22,7 @@ struct pci_controller {
 #ifdef CONFIG_PPC64
        int node;
 #endif
-       void *arch_data;
+       struct device_node *dn;
        struct list_head list_node;
        struct device *parent;
 
@@ -132,7 +134,6 @@ extern void __init update_bridge_resource(struct pci_dev *dev,
  * by device_node->data.
  */
 struct iommu_table;
-struct device_node;
 
 struct pci_dn {
        int     busno;                  /* pci bus number */