diff options
author | Sagi Grimberg <sagi@grimberg.me> | 2022-06-26 11:24:51 +0200 |
---|---|---|
committer | Christoph Hellwig <hch@lst.de> | 2022-06-29 16:13:45 +0200 |
commit | 41d07df7de841bfbc32725ce21d933ad358f2844 (patch) | |
tree | 888073d35f1f919901025c01dde71a9fd99e371d /drivers | |
parent | nvmet-tcp: fix regression in data_digest calculation (diff) | |
download | linux-41d07df7de841bfbc32725ce21d933ad358f2844.tar.xz linux-41d07df7de841bfbc32725ce21d933ad358f2844.zip |
nvme-tcp: always fail a request when sending it failed
queue stoppage and inflight requests cancellation is fully fenced from
io_work and thus failing a request from this context. Hence we don't
need to try to guess from the socket retcode if this failure is because
the queue is about to be torn down or not.
We are perfectly safe to just fail it, the request will not be cancelled
later on.
This solves possible very long shutdown delays when the users issues a
'nvme disconnect-all'
Reported-by: Daniel Wagner <dwagner@suse.de>
Signed-off-by: Sagi Grimberg <sagi@grimberg.me>
Signed-off-by: Christoph Hellwig <hch@lst.de>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/nvme/host/tcp.c | 3 |
1 files changed, 1 insertions, 2 deletions
diff --git a/drivers/nvme/host/tcp.c b/drivers/nvme/host/tcp.c index bb67538d241b..009c2cf3f106 100644 --- a/drivers/nvme/host/tcp.c +++ b/drivers/nvme/host/tcp.c @@ -1180,8 +1180,7 @@ done: } else if (ret < 0) { dev_err(queue->ctrl->ctrl.device, "failed to send request %d\n", ret); - if (ret != -EPIPE && ret != -ECONNRESET) - nvme_tcp_fail_request(queue->request); + nvme_tcp_fail_request(queue->request); nvme_tcp_done_send_req(queue); } return ret; |