diff options
author | Ruozhu Li <liruozhu@huawei.com> | 2022-06-23 09:45:39 +0300 |
---|---|---|
committer | Christoph Hellwig <hch@lst.de> | 2022-06-29 17:13:45 +0300 |
commit | f7f70f4aa09dc43d7455c060143e86a017c30548 (patch) | |
tree | a10f57cdb8adf918a3bf54b1b5a8af4ff24c8928 /drivers/usb/cdns3/cdns3-ti.c | |
parent | 1629de0e0373e04d68e88e6d9d3071fbf70b7ea8 (diff) | |
download | linux-f7f70f4aa09dc43d7455c060143e86a017c30548.tar.xz |
nvme: fix regression when disconnect a recovering ctrl
We encountered a problem that the disconnect command hangs.
After analyzing the log and stack, we found that the triggering
process is as follows:
CPU0 CPU1
nvme_rdma_error_recovery_work
nvme_rdma_teardown_io_queues
nvme_do_delete_ctrl nvme_stop_queues
nvme_remove_namespaces
--clear ctrl->namespaces
nvme_start_queues
--no ns in ctrl->namespaces
nvme_ns_remove return(because ctrl is deleting)
blk_freeze_queue
blk_mq_freeze_queue_wait
--wait for ns to unquiesce to clean infligt IO, hang forever
This problem was not found in older kernels because we will flush
err work in nvme_stop_ctrl before nvme_remove_namespaces.It does not
seem to be modified for functional reasons, the patch can be revert
to solve the problem.
Revert commit 794a4cb3d2f7 ("nvme: remove the .stop_ctrl callout")
Signed-off-by: Ruozhu Li <liruozhu@huawei.com>
Reviewed-by: Sagi Grimberg <sagi@grimberg.me>
Signed-off-by: Christoph Hellwig <hch@lst.de>
Diffstat (limited to 'drivers/usb/cdns3/cdns3-ti.c')
0 files changed, 0 insertions, 0 deletions