diff options
author | Lukas Wunner <[email protected]> | 2016-05-02 13:48:25 -0500 |
---|---|---|
committer | Bjorn Helgaas <[email protected]> | 2016-05-02 13:48:25 -0500 |
commit | 1e398eae8407abdc02cde8a449b14d17ed193d56 (patch) | |
tree | 58726e551ae0412004dbaeff0ac85eeb06b3e8da /tools/perf/scripts/python/export-to-postgresql.py | |
parent | 67e658794ca191b3221b143f2a1c10d002c40bc8 (diff) |
PCI: Fix BUG on device attach failure
Previously when pci_bus_add_device() called device_attach() and it returned
a negative value, we emitted a WARN but carried on.
Commit ab1a187bba5c ("PCI: Check device_attach() return value always"),
introduced in Linux 4.6-rc1, changed this to unwind all steps preceding
device_attach() and to not set dev->is_added = 1.
The latter leads to a BUG if pci_bus_add_device() was called from
pci_bus_add_devices(). Fix by not recursing to a child bus if
device_attach() failed for the bridge leading to it.
This can be triggered by plugging in a PCI device (e.g. Thunderbolt) while
the system is asleep. The system locks up when woken because
device_attach() returns -EPROBE_DEFER.
Fixes: ab1a187bba5c ("PCI: Check device_attach() return value always")
Signed-off-by: Lukas Wunner <[email protected]>
Signed-off-by: Bjorn Helgaas <[email protected]>
Acked-by: Rafael J. Wysocki <[email protected]>
Diffstat (limited to 'tools/perf/scripts/python/export-to-postgresql.py')
0 files changed, 0 insertions, 0 deletions