diff options
author | Keith Busch <keith.busch@intel.com> | 2019-05-14 23:46:09 +0300 |
---|---|---|
committer | Keith Busch <keith.busch@intel.com> | 2019-05-17 20:04:34 +0300 |
commit | d6135c3a1ec0cddda7b8b8e1b5b4abeeafd98289 (patch) | |
tree | ae1291f1b36c6bac60a3b241769c68be8859b5e4 /drivers/nvme/host/pci.c | |
parent | 2036f7263d70e67d70a67899a468588cb7356bc9 (diff) | |
download | linux-d6135c3a1ec0cddda7b8b8e1b5b4abeeafd98289.tar.xz |
nvme-pci: Sync queues on reset
A controller with multiple namespaces may have multiple request_queues with
their own timeout work. If a controller fails with IO outstanding to
diffent namespaces, each request queue may attempt to handle it, so
ensure there is no previously scheduled timeout work executing prior to
starting controller initialization by synchronizing with each queue.
Reviewed-by: Minwoo Im <minwoo.im.dev@gmail.com>
Reviewed-by: Ming Lei <ming.lei@redhat.com>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Keith Busch <keith.busch@intel.com>
Diffstat (limited to 'drivers/nvme/host/pci.c')
-rw-r--r-- | drivers/nvme/host/pci.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/drivers/nvme/host/pci.c b/drivers/nvme/host/pci.c index 8df176ffcbc1..599065ed6a32 100644 --- a/drivers/nvme/host/pci.c +++ b/drivers/nvme/host/pci.c @@ -2492,6 +2492,7 @@ static void nvme_reset_work(struct work_struct *work) */ if (dev->ctrl.ctrl_config & NVME_CC_ENABLE) nvme_dev_disable(dev, false); + nvme_sync_queues(&dev->ctrl); mutex_lock(&dev->shutdown_lock); result = nvme_pci_enable(dev); |