aboutsummaryrefslogtreecommitdiffstats
path: root/net/ipv4/tcp_input.c
diff options
context:
space:
mode:
authorYafang Shao <laoar.shao@gmail.com>2018-04-22 09:50:04 -0400
committerDavid S. Miller <davem@davemloft.net>2018-04-23 11:56:44 -0400
commitc6849a3ac17e336811f1d5bba991d2a9bdc47af1 (patch)
treeb7348427ce20d56554deaabba280b190f46d9cb1 /net/ipv4/tcp_input.c
parentec8c360a6ecdea595aff957c6a720e059275f1f4 (diff)
net: init sk_cookie for inet socket
With sk_cookie we can identify a socket, that is very helpful for traceing and statistic, i.e. tcp tracepiont and ebpf. So we'd better init it by default for inet socket. When using it, we just need call atomic64_read(&sk->sk_cookie). Signed-off-by: Yafang Shao <laoar.shao@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv4/tcp_input.c')
-rw-r--r--net/ipv4/tcp_input.c8
1 files changed, 7 insertions, 1 deletions
diff --git a/net/ipv4/tcp_input.c b/net/ipv4/tcp_input.c
index 5a17cfc75326..17b78582ba63 100644
--- a/net/ipv4/tcp_input.c
+++ b/net/ipv4/tcp_input.c
@@ -78,6 +78,7 @@
78#include <linux/errqueue.h> 78#include <linux/errqueue.h>
79#include <trace/events/tcp.h> 79#include <trace/events/tcp.h>
80#include <linux/static_key.h> 80#include <linux/static_key.h>
81#include <linux/sock_diag.h>
81 82
82int sysctl_tcp_max_orphans __read_mostly = NR_FILE; 83int sysctl_tcp_max_orphans __read_mostly = NR_FILE;
83 84
@@ -6190,10 +6191,15 @@ struct request_sock *inet_reqsk_alloc(const struct request_sock_ops *ops,
6190#if IS_ENABLED(CONFIG_IPV6) 6191#if IS_ENABLED(CONFIG_IPV6)
6191 ireq->pktopts = NULL; 6192 ireq->pktopts = NULL;
6192#endif 6193#endif
6193 atomic64_set(&ireq->ir_cookie, 0);
6194 ireq->ireq_state = TCP_NEW_SYN_RECV; 6194 ireq->ireq_state = TCP_NEW_SYN_RECV;
6195 write_pnet(&ireq->ireq_net, sock_net(sk_listener)); 6195 write_pnet(&ireq->ireq_net, sock_net(sk_listener));
6196 ireq->ireq_family = sk_listener->sk_family; 6196 ireq->ireq_family = sk_listener->sk_family;
6197
6198 BUILD_BUG_ON(offsetof(struct inet_request_sock, ir_cookie) !=
6199 offsetof(struct sock, sk_cookie));
6200 BUILD_BUG_ON(offsetof(struct inet_request_sock, ireq_net) !=
6201 offsetof(struct sock, sk_net));
6202 sock_init_cookie((struct sock *)ireq);
6197 } 6203 }
6198 6204
6199 return req; 6205 return req;