]> git.baikalelectronics.ru Git - kernel.git/commit
nvme-tcp: fix timeout handler
authorSagi Grimberg <sagi@grimberg.me>
Tue, 28 Jul 2020 20:16:36 +0000 (13:16 -0700)
committerSagi Grimberg <sagi@grimberg.me>
Fri, 28 Aug 2020 23:43:57 +0000 (16:43 -0700)
commit9ae9fc54c4a1c3aefbbe0da2f30e6deceb7edf2e
tree820efeab6fc2f40485df94c0bf5082a8e010aa35
parentb3f2230a86b995d0330729df7fd981a45516a722
nvme-tcp: fix timeout handler

When a request times out in a LIVE state, we simply trigger error
recovery and let the error recovery handle the request cancellation,
however when a request times out in a non LIVE state, we make sure to
complete it immediately as it might block controller setup or teardown
and prevent forward progress.

However tearing down the entire set of I/O and admin queues causes
freeze/unfreeze imbalance (q->mq_freeze_depth) because and is really
an overkill to what we actually need, which is to just fence controller
teardown that may be running, stop the queue, and cancel the request if
it is not already completed.

Now that we have the controller teardown_lock, we can safely serialize
request cancellation. This addresses a hang caused by calling extra
queue freeze on controller namespaces, causing unfreeze to not complete
correctly.

Signed-off-by: Sagi Grimberg <sagi@grimberg.me>
drivers/nvme/host/tcp.c