summaryrefslogtreecommitdiffstats
path: root/drivers/nvme
diff options
context:
space:
mode:
authorSagi Grimberg <sagi@grimberg.me>2020-02-26 01:43:24 +0100
committerKeith Busch <kbusch@kernel.org>2020-03-25 20:51:45 +0100
commit761ad26c45b0260a8516bc1fc9d25bb66ca4e25c (patch)
tree0ba14692fcb25e42e2499481e8072606fb58a7f1 /drivers/nvme
parentnvme-tcp: move send failure to nvme_tcp_try_send (diff)
downloadlinux-761ad26c45b0260a8516bc1fc9d25bb66ca4e25c.tar.xz
linux-761ad26c45b0260a8516bc1fc9d25bb66ca4e25c.zip
nvme-tcp: break from io_work loop if recv failed
If we failed to receive data from the socket, don't try to further process it, we will for sure be handling a queue error at this point. While no issue was seen with the current behavior thus far, its safer to cease socket processing if we detected an error. Signed-off-by: Sagi Grimberg <sagi@grimberg.me> Signed-off-by: Keith Busch <kbusch@kernel.org>
Diffstat (limited to 'drivers/nvme')
-rw-r--r--drivers/nvme/host/tcp.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/nvme/host/tcp.c b/drivers/nvme/host/tcp.c
index 221a5a59aa06..4b20301e517c 100644
--- a/drivers/nvme/host/tcp.c
+++ b/drivers/nvme/host/tcp.c
@@ -1074,6 +1074,8 @@ static void nvme_tcp_io_work(struct work_struct *w)
result = nvme_tcp_try_recv(queue);
if (result > 0)
pending = true;
+ else if (unlikely(result < 0))
+ break;
if (!pending)
return;