mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-14 09:25:12 +00:00
PCI: pciehp: cleanup flow in pciehp_configure_device
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>
This commit is contained in:
parent
6841ec681a
commit
9789ac979b
@ -53,17 +53,15 @@ static int __ref pciehp_add_bridge(struct pci_dev *dev)
|
|||||||
busnr = pci_scan_bridge(parent, dev, busnr, pass);
|
busnr = pci_scan_bridge(parent, dev, busnr, pass);
|
||||||
if (!dev->subordinate)
|
if (!dev->subordinate)
|
||||||
return -1;
|
return -1;
|
||||||
pci_bus_size_bridges(dev->subordinate);
|
|
||||||
pci_bus_assign_resources(parent);
|
|
||||||
pci_enable_bridges(parent);
|
|
||||||
pci_bus_add_devices(parent);
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int pciehp_configure_device(struct slot *p_slot)
|
int pciehp_configure_device(struct slot *p_slot)
|
||||||
{
|
{
|
||||||
struct pci_dev *dev;
|
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;
|
int num, fn;
|
||||||
struct controller *ctrl = p_slot->ctrl;
|
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)) {
|
(dev->hdr_type == PCI_HEADER_TYPE_CARDBUS)) {
|
||||||
pciehp_add_bridge(dev);
|
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_configure_slot(dev);
|
||||||
pci_dev_put(dev);
|
pci_dev_put(dev);
|
||||||
}
|
}
|
||||||
|
|
||||||
pci_bus_assign_resources(parent);
|
|
||||||
pci_bus_add_devices(parent);
|
pci_bus_add_devices(parent);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user