mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-15 01:24:33 +00:00
9807080e21
Introducing entry_saddr and entry_daddr parameters in this macro for later use can help us record the reverse 4-tuple by analyzing the 4-tuple of the incoming skb when receiving. Signed-off-by: Jason Xing <kernelxing@tencent.com> Reviewed-by: Eric Dumazet <edumazet@google.com> Link: https://lore.kernel.org/r/20240401073605.37335-2-kerneljasonxing@gmail.com Signed-off-by: Jakub Kicinski <kuba@kernel.org>
53 lines
1.3 KiB
C
53 lines
1.3 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#undef TRACE_SYSTEM
|
|
#define TRACE_SYSTEM udp
|
|
|
|
#if !defined(_TRACE_UDP_H) || defined(TRACE_HEADER_MULTI_READ)
|
|
#define _TRACE_UDP_H
|
|
|
|
#include <linux/udp.h>
|
|
#include <linux/tracepoint.h>
|
|
#include <trace/events/net_probe_common.h>
|
|
|
|
TRACE_EVENT(udp_fail_queue_rcv_skb,
|
|
|
|
TP_PROTO(int rc, struct sock *sk, struct sk_buff *skb),
|
|
|
|
TP_ARGS(rc, sk, skb),
|
|
|
|
TP_STRUCT__entry(
|
|
__field(int, rc)
|
|
|
|
__field(__u16, sport)
|
|
__field(__u16, dport)
|
|
__field(__u16, family)
|
|
__array(__u8, saddr, sizeof(struct sockaddr_in6))
|
|
__array(__u8, daddr, sizeof(struct sockaddr_in6))
|
|
),
|
|
|
|
TP_fast_assign(
|
|
const struct udphdr *uh = (const struct udphdr *)udp_hdr(skb);
|
|
|
|
__entry->rc = rc;
|
|
|
|
/* for filtering use */
|
|
__entry->sport = ntohs(uh->source);
|
|
__entry->dport = ntohs(uh->dest);
|
|
__entry->family = sk->sk_family;
|
|
|
|
memset(__entry->saddr, 0, sizeof(struct sockaddr_in6));
|
|
memset(__entry->daddr, 0, sizeof(struct sockaddr_in6));
|
|
|
|
TP_STORE_ADDR_PORTS_SKB(skb, uh, __entry->saddr, __entry->daddr);
|
|
),
|
|
|
|
TP_printk("rc=%d family=%s src=%pISpc dest=%pISpc", __entry->rc,
|
|
show_family_name(__entry->family),
|
|
__entry->saddr, __entry->daddr)
|
|
);
|
|
|
|
#endif /* _TRACE_UDP_H */
|
|
|
|
/* This part must be outside protection */
|
|
#include <trace/define_trace.h>
|