|
@@ -1859,6 +1859,9 @@ static void nvme_reset_work(struct work_struct *work)
|
|
|
if (dev->ctrl.ctrl_config & NVME_CC_ENABLE)
|
|
|
nvme_dev_disable(dev, false);
|
|
|
|
|
|
+ if (test_bit(NVME_CTRL_REMOVING, &dev->flags))
|
|
|
+ goto out;
|
|
|
+
|
|
|
set_bit(NVME_CTRL_RESETTING, &dev->flags);
|
|
|
|
|
|
result = nvme_pci_enable(dev);
|
|
@@ -2078,11 +2081,10 @@ static void nvme_remove(struct pci_dev *pdev)
|
|
|
{
|
|
|
struct nvme_dev *dev = pci_get_drvdata(pdev);
|
|
|
|
|
|
- del_timer_sync(&dev->watchdog_timer);
|
|
|
-
|
|
|
set_bit(NVME_CTRL_REMOVING, &dev->flags);
|
|
|
pci_set_drvdata(pdev, NULL);
|
|
|
flush_work(&dev->async_work);
|
|
|
+ flush_work(&dev->reset_work);
|
|
|
flush_work(&dev->scan_work);
|
|
|
nvme_remove_namespaces(&dev->ctrl);
|
|
|
nvme_uninit_ctrl(&dev->ctrl);
|