2017-10-13 13:03:16 -07:00
# undef TRACE_SYSTEM
# define TRACE_SYSTEM tcp
# if !defined(_TRACE_TCP_H) || defined(TRACE_HEADER_MULTI_READ)
# define _TRACE_TCP_H
# include <linux/ipv6.h>
# include <linux/tcp.h>
# include <linux/tracepoint.h>
# include <net/ipv6.h>
2017-10-23 09:20:22 -07:00
/*
* tcp event with arguments sk and skb
*
* Note : this class requires a valid sk pointer ; while skb pointer could
* be NULL .
*/
DECLARE_EVENT_CLASS ( tcp_event_sk_skb ,
2017-10-13 13:03:16 -07:00
2017-10-23 09:20:23 -07:00
TP_PROTO ( const struct sock * sk , const struct sk_buff * skb ) ,
2017-10-13 13:03:16 -07:00
TP_ARGS ( sk , skb ) ,
TP_STRUCT__entry (
2017-10-23 09:20:23 -07:00
__field ( const void * , skbaddr )
__field ( const void * , skaddr )
2017-10-13 13:03:16 -07:00
__field ( __u16 , sport )
__field ( __u16 , dport )
__array ( __u8 , saddr , 4 )
__array ( __u8 , daddr , 4 )
__array ( __u8 , saddr_v6 , 16 )
__array ( __u8 , daddr_v6 , 16 )
) ,
TP_fast_assign (
struct inet_sock * inet = inet_sk ( sk ) ;
struct in6_addr * pin6 ;
__be32 * p32 ;
__entry - > skbaddr = skb ;
__entry - > skaddr = sk ;
__entry - > sport = ntohs ( inet - > inet_sport ) ;
__entry - > dport = ntohs ( inet - > inet_dport ) ;
p32 = ( __be32 * ) __entry - > saddr ;
* p32 = inet - > inet_saddr ;
p32 = ( __be32 * ) __entry - > daddr ;
* p32 = inet - > inet_daddr ;
2017-10-18 08:17:29 -07:00
# if IS_ENABLED(CONFIG_IPV6)
if ( sk - > sk_family = = AF_INET6 ) {
2017-10-13 13:03:16 -07:00
pin6 = ( struct in6_addr * ) __entry - > saddr_v6 ;
2017-10-16 15:32:07 -07:00
* pin6 = sk - > sk_v6_rcv_saddr ;
2017-10-13 13:03:16 -07:00
pin6 = ( struct in6_addr * ) __entry - > daddr_v6 ;
2017-10-16 15:32:07 -07:00
* pin6 = sk - > sk_v6_daddr ;
2017-10-18 08:17:29 -07:00
} else
# endif
{
2017-10-13 13:03:16 -07:00
pin6 = ( struct in6_addr * ) __entry - > saddr_v6 ;
ipv6_addr_set_v4mapped ( inet - > inet_saddr , pin6 ) ;
pin6 = ( struct in6_addr * ) __entry - > daddr_v6 ;
ipv6_addr_set_v4mapped ( inet - > inet_daddr , pin6 ) ;
}
) ,
2017-10-16 14:24:02 -07:00
TP_printk ( " sport=%hu dport=%hu saddr=%pI4 daddr=%pI4 saddrv6=%pI6c daddrv6=%pI6c " ,
2017-10-13 13:03:16 -07:00
__entry - > sport , __entry - > dport , __entry - > saddr , __entry - > daddr ,
__entry - > saddr_v6 , __entry - > daddr_v6 )
) ;
2017-10-23 09:20:22 -07:00
DEFINE_EVENT ( tcp_event_sk_skb , tcp_retransmit_skb ,
2017-10-23 09:20:23 -07:00
TP_PROTO ( const struct sock * sk , const struct sk_buff * skb ) ,
2017-10-23 09:20:22 -07:00
TP_ARGS ( sk , skb )
) ;
2017-10-23 09:20:24 -07:00
/*
* skb of trace_tcp_send_reset is the skb that caused RST . In case of
* active reset , skb should be NULL
*/
DEFINE_EVENT ( tcp_event_sk_skb , tcp_send_reset ,
TP_PROTO ( const struct sock * sk , const struct sk_buff * skb ) ,
TP_ARGS ( sk , skb )
) ;
2017-10-13 13:03:16 -07:00
# endif /* _TRACE_TCP_H */
/* This part must be outside protection */
# include <trace/define_trace.h>