PCI: pciehp: cleanup flow in pciehp_configure_device
authorYinghai Lu <yinghai@kernel.org>
Fri, 22 Jan 2010 09:02:26 +0000 (01:02 -0800)
committerJesse Barnes <jbarnes@virtuousgeek.org>
Tue, 23 Feb 2010 00:17:24 +0000 (16:17 -0800)
Move bus_size_bridges and assign resources out of pciehp_add_bridge()
and do them all together, one time, including slot bridge, to avoid to
calling assign resources several times when there are several bridges
under the slot bridge.  Using pci_assign_unassigned_bridge_resources.

Signed-off-by: Yinghai Lu <yinghai@kernel.org>
Reviewed-by: Alex Chiang <achiang@hp.com>
Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
drivers/pci/hotplug/pciehp_pci.c

index 21733108addefe3aefc208dd646ae91340903883..0a16444c14c9d46d80ad391d5759cc27e0ab19f9 100644 (file)
@@ -53,17 +53,15 @@ static int __ref pciehp_add_bridge(struct pci_dev *dev)
                busnr = pci_scan_bridge(parent, dev, busnr, pass);
        if (!dev->subordinate)
                return -1;
-       pci_bus_size_bridges(dev->subordinate);
-       pci_bus_assign_resources(parent);
-       pci_enable_bridges(parent);
-       pci_bus_add_devices(parent);
+
        return 0;
 }
 
 int pciehp_configure_device(struct slot *p_slot)
 {
        struct pci_dev *dev;
-       struct pci_bus *parent = p_slot->ctrl->pcie->port->subordinate;
+       struct pci_dev *bridge = p_slot->ctrl->pcie->port;
+       struct pci_bus *parent = bridge->subordinate;
        int num, fn;
        struct controller *ctrl = p_slot->ctrl;
 
@@ -96,12 +94,25 @@ int pciehp_configure_device(struct slot *p_slot)
                                (dev->hdr_type == PCI_HEADER_TYPE_CARDBUS)) {
                        pciehp_add_bridge(dev);
                }
+               pci_dev_put(dev);
+       }
+
+       pci_assign_unassigned_bridge_resources(bridge);
+
+       for (fn = 0; fn < 8; fn++) {
+               dev = pci_get_slot(parent, PCI_DEVFN(0, fn));
+               if (!dev)
+                       continue;
+               if ((dev->class >> 16) == PCI_BASE_CLASS_DISPLAY) {
+                       pci_dev_put(dev);
+                       continue;
+               }
                pci_configure_slot(dev);
                pci_dev_put(dev);
        }
 
-       pci_bus_assign_resources(parent);
        pci_bus_add_devices(parent);
+
        return 0;
 }