PCI: Move pci_proc_attach_device() to pci_bus_add_device()
authorYinghai Lu <yinghai@kernel.org>
Sat, 30 Nov 2013 22:40:28 +0000 (14:40 -0800)
committerBjorn Helgaas <bhelgaas@google.com>
Wed, 18 Dec 2013 20:53:38 +0000 (13:53 -0700)
4f535093cf8f ("PCI: Put pci_dev in device tree as early as possible")
moved pci_proc_attach_device() from pci_bus_add_device() to
pci_device_add().

This moves it back to pci_bus_add_device(), essentially reverting that
part of 4f535093cf8f.  This makes it symmetric with pci_stop_dev(),
where we call pci_proc_detach_device() and pci_remove_sysfs_dev_files()
and set dev->is_added = 0.

[bhelgaas: changelog, create sysfs then attach proc for symmetry]
Signed-off-by: Yinghai Lu <yinghai@kernel.org>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
drivers/pci/bus.c
drivers/pci/probe.c

index fc1b740137430b703a348b03d1c9420d19d21d7a..a037d81f21edb8c8f9c2b45bffcb6c45f5187537 100644 (file)
@@ -176,6 +176,7 @@ int pci_bus_add_device(struct pci_dev *dev)
         */
        pci_fixup_device(pci_fixup_final, dev);
        pci_create_sysfs_dev_files(dev);
+       pci_proc_attach_device(dev);
 
        dev->match_driver = true;
        retval = device_attach(&dev->dev);
index 38e403dddf6e0e07166585e226d47f2793bd86f8..173a9cf4593e51a01561c596a596afeb631eb4b6 100644 (file)
@@ -1381,8 +1381,6 @@ void pci_device_add(struct pci_dev *dev, struct pci_bus *bus)
        dev->match_driver = false;
        ret = device_add(&dev->dev);
        WARN_ON(ret < 0);
-
-       pci_proc_attach_device(dev);
 }
 
 struct pci_dev *__ref pci_scan_single_device(struct pci_bus *bus, int devfn)