]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
nvme: remove dead controllers from a work item
authorChristoph Hellwig <hch@lst.de>
Thu, 26 Nov 2015 11:35:49 +0000 (12:35 +0100)
committerChuck Anderson <chuck.anderson@oracle.com>
Thu, 1 Jun 2017 20:41:16 +0000 (13:41 -0700)
Compared to the kthread this gives us multiple call prevention for free.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Keith Busch <keith.busch@intel.com>
Signed-off-by: Jens Axboe <axboe@fb.com>
(cherry picked from commit 5c8809e650772be87ba04595a8ccf278bab7b543)

Orabug: 25130845

Signed-off-by: Ashok Vairavan <ashok.vairavan@oracle.com>
Reviewed-by: Martin K. Petersen <martin.petersen@oracle.com>
drivers/nvme/host/pci.c

index 781d8ec2cd1b1a2f64dae76e72a779af184b4ab7..21c1c460c46fa677cc1225e2ba39c9126611bdc1 100644 (file)
@@ -1922,19 +1922,26 @@ static void nvme_reset_work(struct work_struct *work)
        return;
 
  out:
-       nvme_remove_dead_ctrl(dev, result);
+       nvme_remove_dead_ctrl(dev);
 }
 
-static int nvme_remove_dead_ctrl(void *arg)
+static void nvme_remove_dead_ctrl_work(struct work_struct *work)
 {
-       struct nvme_dev *dev = (struct nvme_dev *)arg;
+       struct nvme_dev *dev = container_of(work, struct nvme_dev, remove_work);
        struct pci_dev *pdev = to_pci_dev(dev->dev);
 
        nvme_kill_queues(&dev->ctrl);
        if (pci_get_drvdata(pdev))
                pci_stop_and_remove_bus_device_locked(pdev);
        nvme_put_ctrl(&dev->ctrl);
-       return 0;
+}
+
+static void nvme_remove_dead_ctrl(struct nvme_dev *dev)
+{
+       dev_warn(dev->dev, "Removing after probe failure\n");
+       kref_get(&dev->ctrl.kref);
+       if (!schedule_work(&dev->remove_work))
+               nvme_put_ctrl(&dev->ctrl);
 }
 
 static int nvme_reset(struct nvme_dev *dev)