Commit 64cdb418 authored by Rafael J. Wysocki's avatar Rafael J. Wysocki Committed by Bjorn Helgaas

MPT / PCI: Use pci_stop_and_remove_bus_device_locked()

Race conditions are theoretically possible between the MPT PCI device
removal and the generic PCI bus rescan and device removal that can be
triggered via sysfs.

To avoid those race conditions make the MPT PCI code use
pci_stop_and_remove_bus_device_locked().
Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
Signed-off-by: default avatarBjorn Helgaas <bhelgaas@google.com>
parent 8b9ec1da
...@@ -346,7 +346,7 @@ static int mpt_remove_dead_ioc_func(void *arg) ...@@ -346,7 +346,7 @@ static int mpt_remove_dead_ioc_func(void *arg)
if ((pdev == NULL)) if ((pdev == NULL))
return -1; return -1;
pci_stop_and_remove_bus_device(pdev); pci_stop_and_remove_bus_device_locked(pdev);
return 0; return 0;
} }
......
...@@ -128,7 +128,7 @@ static int mpt2sas_remove_dead_ioc_func(void *arg) ...@@ -128,7 +128,7 @@ static int mpt2sas_remove_dead_ioc_func(void *arg)
pdev = ioc->pdev; pdev = ioc->pdev;
if ((pdev == NULL)) if ((pdev == NULL))
return -1; return -1;
pci_stop_and_remove_bus_device(pdev); pci_stop_and_remove_bus_device_locked(pdev);
return 0; return 0;
} }
......
...@@ -131,7 +131,7 @@ static int mpt3sas_remove_dead_ioc_func(void *arg) ...@@ -131,7 +131,7 @@ static int mpt3sas_remove_dead_ioc_func(void *arg)
pdev = ioc->pdev; pdev = ioc->pdev;
if ((pdev == NULL)) if ((pdev == NULL))
return -1; return -1;
pci_stop_and_remove_bus_device(pdev); pci_stop_and_remove_bus_device_locked(pdev);
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment