|
@@ -1212,6 +1212,38 @@ struct pci_bus * __devinit pci_scan_bus_parented(struct device *parent,
|
|
EXPORT_SYMBOL(pci_scan_bus_parented);
|
|
EXPORT_SYMBOL(pci_scan_bus_parented);
|
|
|
|
|
|
#ifdef CONFIG_HOTPLUG
|
|
#ifdef CONFIG_HOTPLUG
|
|
|
|
+/**
|
|
|
|
+ * pci_rescan_bus - scan a PCI bus for devices.
|
|
|
|
+ * @bus: PCI bus to scan
|
|
|
|
+ *
|
|
|
|
+ * Scan a PCI bus and child buses for new devices, adds them,
|
|
|
|
+ * and enables them.
|
|
|
|
+ *
|
|
|
|
+ * Returns the max number of subordinate bus discovered.
|
|
|
|
+ */
|
|
|
|
+unsigned int __devinit pci_rescan_bus(struct pci_bus *bus)
|
|
|
|
+{
|
|
|
|
+ unsigned int max;
|
|
|
|
+ struct pci_dev *dev;
|
|
|
|
+
|
|
|
|
+ max = pci_scan_child_bus(bus);
|
|
|
|
+
|
|
|
|
+ up_read(&pci_bus_sem);
|
|
|
|
+ list_for_each_entry(dev, &bus->devices, bus_list)
|
|
|
|
+ if (dev->hdr_type == PCI_HEADER_TYPE_BRIDGE ||
|
|
|
|
+ dev->hdr_type == PCI_HEADER_TYPE_CARDBUS)
|
|
|
|
+ if (dev->subordinate)
|
|
|
|
+ pci_bus_size_bridges(dev->subordinate);
|
|
|
|
+ down_read(&pci_bus_sem);
|
|
|
|
+
|
|
|
|
+ pci_bus_assign_resources(bus);
|
|
|
|
+ pci_enable_bridges(bus);
|
|
|
|
+ pci_bus_add_devices(bus);
|
|
|
|
+
|
|
|
|
+ return max;
|
|
|
|
+}
|
|
|
|
+EXPORT_SYMBOL_GPL(pci_rescan_bus);
|
|
|
|
+
|
|
EXPORT_SYMBOL(pci_add_new_bus);
|
|
EXPORT_SYMBOL(pci_add_new_bus);
|
|
EXPORT_SYMBOL(pci_scan_slot);
|
|
EXPORT_SYMBOL(pci_scan_slot);
|
|
EXPORT_SYMBOL(pci_scan_bridge);
|
|
EXPORT_SYMBOL(pci_scan_bridge);
|