tcp: add tcp_sock_set_syncnt
authorChristoph Hellwig <hch@lst.de>
Thu, 28 May 2020 05:12:21 +0000 (07:12 +0200)
committerDavid S. Miller <davem@davemloft.net>
Thu, 28 May 2020 18:11:45 +0000 (11:11 -0700)
Add a helper to directly set the TCP_SYNCNT sockopt from kernel space
without going through a fake uaccess.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Acked-by: Sagi Grimberg <sagi@grimberg.me>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/nvme/host/tcp.c
include/linux/tcp.h
net/ipv4/tcp.c

index 4e4a750ecdb9709b3a79dcf3392f9676a1c0eefc..2872584f52f6375726f2a077069e292f666449db 100644 (file)
@@ -1336,14 +1336,7 @@ static int nvme_tcp_alloc_queue(struct nvme_ctrl *nctrl,
        }
 
        /* Single syn retry */
-       opt = 1;
-       ret = kernel_setsockopt(queue->sock, IPPROTO_TCP, TCP_SYNCNT,
-                       (char *)&opt, sizeof(opt));
-       if (ret) {
-               dev_err(nctrl->device,
-                       "failed to set TCP_SYNCNT sock opt %d\n", ret);
-               goto err_sock;
-       }
+       tcp_sock_set_syncnt(queue->sock->sk, 1);
 
        /* Set TCP no delay */
        tcp_sock_set_nodelay(queue->sock->sk);
index 2eaf8320b9db05ac9ffe89f644f2021562882cd6..6aa4ae5ebf3d5f62548ea565c546c95e5328428f 100644 (file)
@@ -500,5 +500,6 @@ int tcp_skb_shift(struct sk_buff *to, struct sk_buff *from, int pcount,
 void tcp_sock_set_cork(struct sock *sk, bool on);
 void tcp_sock_set_nodelay(struct sock *sk);
 void tcp_sock_set_quickack(struct sock *sk, int val);
+int tcp_sock_set_syncnt(struct sock *sk, int val);
 
 #endif /* _LINUX_TCP_H */
index 27b5e7a4e2ef9451cefde43038a444f08bce22b3..d2c67ae1da07acdb2fe02d1dca554ac0403a9656 100644 (file)
@@ -2881,6 +2881,18 @@ void tcp_sock_set_quickack(struct sock *sk, int val)
 }
 EXPORT_SYMBOL(tcp_sock_set_quickack);
 
+int tcp_sock_set_syncnt(struct sock *sk, int val)
+{
+       if (val < 1 || val > MAX_TCP_SYNCNT)
+               return -EINVAL;
+
+       lock_sock(sk);
+       inet_csk(sk)->icsk_syn_retries = val;
+       release_sock(sk);
+       return 0;
+}
+EXPORT_SYMBOL(tcp_sock_set_syncnt);
+
 /*
  *     Socket option code for TCP.
  */