nvme-tcp: improve icreq/icresp logging
authorHannes Reinecke <hare@suse.de>
Thu, 24 Aug 2023 14:39:17 +0000 (16:39 +0200)
committerKeith Busch <kbusch@kernel.org>
Wed, 11 Oct 2023 17:11:55 +0000 (10:11 -0700)
When icreq/icresp fails we should be printing out a warning to
inform the user that the connection could not be established;
without it there won't be anything in the kernel message log,
just an error code returned to nvme-cli.

Signed-off-by: Hannes Reinecke <hare@suse.de>
Reviewed-by: Sagi Grimberg <sagi@grimberg.me>
Signed-off-by: Keith Busch <kbusch@kernel.org>
drivers/nvme/host/tcp.c

index 69975b655179c01c1b100806e816d1f2df5460c6..4656ad20e157ee1e38fc3aab937f93a8f4bd4edd 100644 (file)
@@ -1403,8 +1403,11 @@ static int nvme_tcp_init_connection(struct nvme_tcp_queue *queue)
        iov.iov_base = icreq;
        iov.iov_len = sizeof(*icreq);
        ret = kernel_sendmsg(queue->sock, &msg, &iov, 1, iov.iov_len);
-       if (ret < 0)
+       if (ret < 0) {
+               pr_warn("queue %d: failed to send icreq, error %d\n",
+                       nvme_tcp_queue_id(queue), ret);
                goto free_icresp;
+       }
 
        memset(&msg, 0, sizeof(msg));
        iov.iov_base = icresp;
@@ -1415,8 +1418,11 @@ static int nvme_tcp_init_connection(struct nvme_tcp_queue *queue)
        }
        ret = kernel_recvmsg(queue->sock, &msg, &iov, 1,
                        iov.iov_len, msg.msg_flags);
-       if (ret < 0)
+       if (ret < 0) {
+               pr_warn("queue %d: failed to receive icresp, error %d\n",
+                       nvme_tcp_queue_id(queue), ret);
                goto free_icresp;
+       }
        if (queue->ctrl->ctrl.opts->tls) {
                ctype = tls_get_record_type(queue->sock->sk,
                                            (struct cmsghdr *)cbuf);