From: Sagi Grimberg Date: Wed, 26 Feb 2020 00:43:24 +0000 (-0800) Subject: nvme-tcp: break from io_work loop if recv failed X-Git-Url: http://git.maquefel.me/?a=commitdiff_plain;h=761ad26c45b0260a8516bc1fc9d25bb66ca4e25c;p=linux.git 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 Signed-off-by: Keith Busch --- diff --git a/drivers/nvme/host/tcp.c b/drivers/nvme/host/tcp.c index 221a5a59aa062..4b20301e517ca 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;