Commit 92911a55 authored by Christoph Hellwig's avatar Christoph Hellwig Committed by Jens Axboe

nvme: tighten up state check for namespace scanning

We only should be scanning namespaces if the controller is live.  Currently
we call the function just before setting it live, so fix the code up to
move the call to nvme_queue_scan to just below the state change.
Signed-off-by: default avatarChristoph Hellwig <hch@lst.de>
Reviewed-by: default avatarSagi Grimberg <sagi@grimberg.me>
Acked-by Jon Derrick: <jonathan.derrick@intel.com>
Signed-off-by: default avatarJens Axboe <axboe@fb.com>
parent bb8d261e
...@@ -272,7 +272,7 @@ static void nvme_queue_scan(struct nvme_dev *dev) ...@@ -272,7 +272,7 @@ static void nvme_queue_scan(struct nvme_dev *dev)
* Do not queue new scan work when a controller is reset during * Do not queue new scan work when a controller is reset during
* removal. * removal.
*/ */
if (dev->ctrl.state != NVME_CTRL_DELETING) if (dev->ctrl.state == NVME_CTRL_LIVE)
queue_work(nvme_workq, &dev->scan_work); queue_work(nvme_workq, &dev->scan_work);
} }
...@@ -1659,7 +1659,6 @@ static int nvme_dev_add(struct nvme_dev *dev) ...@@ -1659,7 +1659,6 @@ static int nvme_dev_add(struct nvme_dev *dev)
nvme_free_queues(dev, dev->online_queues); nvme_free_queues(dev, dev->online_queues);
} }
nvme_queue_scan(dev);
return 0; return 0;
} }
...@@ -1893,6 +1892,9 @@ static void nvme_reset_work(struct work_struct *work) ...@@ -1893,6 +1892,9 @@ static void nvme_reset_work(struct work_struct *work)
dev_warn(dev->ctrl.device, "failed to mark controller live\n"); dev_warn(dev->ctrl.device, "failed to mark controller live\n");
goto out; goto out;
} }
if (dev->online_queues > 1)
nvme_queue_scan(dev);
return; return;
out: out:
......
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