bpf: Support for per connection SYN/SYN-ACK RTOs
authorLawrence Brakmo <brakmo@fb.com>
Sat, 1 Jul 2017 03:02:42 +0000 (20:02 -0700)
committerDavid S. Miller <davem@davemloft.net>
Sat, 1 Jul 2017 23:15:13 +0000 (16:15 -0700)
This patch adds support for setting a per connection SYN and
SYN_ACK RTOs from within a BPF_SOCK_OPS program. For example,
to set small RTOs when it is known both hosts are within a
datacenter.

Signed-off-by: Lawrence Brakmo <brakmo@fb.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
include/net/tcp.h
include/uapi/linux/bpf.h
net/ipv4/tcp_input.c
net/ipv4/tcp_output.c

index e58500825006799e450f5ff4ee82a9ce15ac03ff..564af2dee2366c666723fff125a06ace1f174d5b 100644 (file)
@@ -2057,4 +2057,15 @@ static inline int tcp_call_bpf(struct sock *sk, int op)
 }
 #endif
 
+static inline u32 tcp_timeout_init(struct sock *sk)
+{
+       int timeout;
+
+       timeout = tcp_call_bpf(sk, BPF_SOCK_OPS_TIMEOUT_INIT);
+
+       if (timeout <= 0)
+               timeout = TCP_TIMEOUT_INIT;
+       return timeout;
+}
+
 #endif /* _TCP_H */
index 01cd485ccd4f1874c411328bd68b92c2f9839915..00702b2944478f428b4c28929515c0004422e9cb 100644 (file)
@@ -748,6 +748,9 @@ struct bpf_sock_ops {
  */
 enum {
        BPF_SOCK_OPS_VOID,
+       BPF_SOCK_OPS_TIMEOUT_INIT,      /* Should return SYN-RTO value to use or
+                                        * -1 if default value should be used
+                                        */
 };
 
 #endif /* _UAPI__LINUX_BPF_H__ */
index 2ab7e2fa9bb9727a6d22552f851d6254ea074481..bcc96654cd7e3038677382986380b70a96bf4917 100644 (file)
@@ -6406,7 +6406,8 @@ int tcp_conn_request(struct request_sock_ops *rsk_ops,
        } else {
                tcp_rsk(req)->tfo_listener = false;
                if (!want_cookie)
-                       inet_csk_reqsk_queue_hash_add(sk, req, TCP_TIMEOUT_INIT);
+                       inet_csk_reqsk_queue_hash_add(sk, req,
+                               tcp_timeout_init((struct sock *)req));
                af_ops->send_synack(sk, dst, &fl, req, &foc,
                                    !want_cookie ? TCP_SYNACK_NORMAL :
                                                   TCP_SYNACK_COOKIE);
index 1d79137f37955ae3b3a881ce16387d34e8a1e096..47fe0759a8771fd85479ddd43a2093771cf02261 100644 (file)
@@ -3326,7 +3326,7 @@ static void tcp_connect_init(struct sock *sk)
        tp->rcv_wup = tp->rcv_nxt;
        tp->copied_seq = tp->rcv_nxt;
 
-       inet_csk(sk)->icsk_rto = TCP_TIMEOUT_INIT;
+       inet_csk(sk)->icsk_rto = tcp_timeout_init(sk);
        inet_csk(sk)->icsk_retransmits = 0;
        tcp_clear_retrans(tp);
 }