]> git.baikalelectronics.ru Git - kernel.git/commit
tcp: add a tracepoint for tcp retransmission
authorCong Wang <xiyou.wangcong@gmail.com>
Fri, 13 Oct 2017 20:03:16 +0000 (13:03 -0700)
committerDavid S. Miller <davem@davemloft.net>
Sun, 15 Oct 2017 01:45:15 +0000 (18:45 -0700)
commit6044cf4f44ef1f916c9bae291ee0b10a4d96e160
tree5eb147e546eac44c5dd83b7e5dd1c6263c7678eb
parentc03baec3714751ede912953c531c93ac26db7905
tcp: add a tracepoint for tcp retransmission

We need a real-time notification for tcp retransmission
for monitoring.

Of course we could use ftrace to dynamically instrument this
kernel function too, however we can't retrieve the connection
information at the same time, for example perf-tools [1] reads
/proc/net/tcp for socket details, which is slow when we have
a lots of connections.

Therefore, this patch adds a tracepoint for __tcp_retransmit_skb()
and exposes src/dst IP addresses and ports of the connection.
This also makes it easier to integrate into perf.

Note, I expose both IPv4 and IPv6 addresses at the same time:
for a IPv4 socket, v4 mapped address is used as IPv6 addresses,
for a IPv6 socket, LOOPBACK4_IPV6 is already filled by kernel.
Also, add sk and skb pointers as they are useful for BPF.

1. https://github.com/brendangregg/perf-tools/blob/master/net/tcpretrans

Cc: Eric Dumazet <edumazet@google.com>
Cc: Alexei Starovoitov <alexei.starovoitov@gmail.com>
Cc: Hannes Frederic Sowa <hannes@stressinduktion.org>
Cc: Brendan Gregg <brendan.d.gregg@gmail.com>
Cc: Neal Cardwell <ncardwell@google.com>
Signed-off-by: Cong Wang <xiyou.wangcong@gmail.com>
Acked-by: Alexei Starovoitov <ast@kernel.org>
Acked-by: Brendan Gregg <bgregg@netflix.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
include/trace/events/tcp.h [new file with mode: 0644]
net/core/net-traces.c
net/ipv4/tcp_output.c