NVMe: Fix check_flush_dependency warning
authorKeith Busch <keith.busch@intel.com>
Wed, 27 Apr 2016 21:51:18 +0000 (15:51 -0600)
committerJens Axboe <axboe@fb.com>
Mon, 2 May 2016 15:03:06 +0000 (09:03 -0600)
If the controller fails and is degraded after a reset, we need to kill
off all requests queues before removing the inaccessble namespaces. This
will prevent del_gendisk from syncing dirty data, which we can't due
from a WQ_MEM_RECLAIM work queue.

Signed-off-by: Keith Busch <keith.busch@intel.com>
Reviewed-by: Sagi Grimberg <sagi@grimberg.me>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Jens Axboe <axboe@fb.com>
drivers/nvme/host/pci.c

index ff3c8d7ca8827e305cdc74ef721045f6a212e3f8..cc46fdf17b1670fd752329d85ed2d7c24fb497f2 100644 (file)
@@ -1887,6 +1887,7 @@ static void nvme_reset_work(struct work_struct *work)
         */
        if (dev->online_queues < 2) {
                dev_warn(dev->ctrl.device, "IO queues not created\n");
+               nvme_kill_queues(&dev->ctrl);
                nvme_remove_namespaces(&dev->ctrl);
        } else {
                nvme_start_queues(&dev->ctrl);