net: udp: add IP/port data to the tracepoint udp/udp_fail_queue_rcv_skb
authorBalazs Scheidler <bazsi77@gmail.com>
Tue, 26 Mar 2024 18:05:47 +0000 (19:05 +0100)
committerJakub Kicinski <kuba@kernel.org>
Fri, 29 Mar 2024 19:18:24 +0000 (12:18 -0700)
The udp_fail_queue_rcv_skb() tracepoint lacks any details on the source
and destination IP/port whereas this information can be critical in case
of UDP/syslog.

Signed-off-by: Balazs Scheidler <balazs.scheidler@axoflow.com>
Reviewed-by: Jason Xing <kerneljasonxing@gmail.com>
Link: https://lore.kernel.org/r/0c8b3e33dbf679e190be6f4c6736603a76988a20.1711475011.git.balazs.scheidler@axoflow.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
include/trace/events/udp.h
net/ipv4/udp.c
net/ipv6/udp.c

index 336fe272889f59c5fe59cda70f0b5a1bff526c97..62bebe2a6ecebd95ec9eac4961ae3816d33b102f 100644 (file)
@@ -7,24 +7,43 @@
 
 #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),
+       TP_PROTO(int rc, struct sock *sk, struct sk_buff *skb),
 
-       TP_ARGS(rc, sk),
+       TP_ARGS(rc, sk, skb),
 
        TP_STRUCT__entry(
                __field(int, rc)
-               __field(__u16, lport)
+
+               __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;
-               __entry->lport = inet_sk(sk)->inet_num;
+
+               /* 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(__entry, skb, uh);
        ),
 
-       TP_printk("rc=%d port=%hu", __entry->rc, __entry->lport)
+       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 */
index 661d0e0d273f616ad82746b69b2c76d056633017..531882f321f2de375daa1715bbe16da075595893 100644 (file)
@@ -2049,8 +2049,8 @@ static int __udp_queue_rcv_skb(struct sock *sk, struct sk_buff *skb)
                        drop_reason = SKB_DROP_REASON_PROTO_MEM;
                }
                UDP_INC_STATS(sock_net(sk), UDP_MIB_INERRORS, is_udplite);
+               trace_udp_fail_queue_rcv_skb(rc, sk, skb);
                kfree_skb_reason(skb, drop_reason);
-               trace_udp_fail_queue_rcv_skb(rc, sk);
                return -1;
        }
 
index 7c1e6469d091d2252efa5b5ba7270586cef89c29..2e4dc5e6137bd0f468ab99a5132c214ee3d9050c 100644 (file)
@@ -34,6 +34,7 @@
 #include <linux/slab.h>
 #include <linux/uaccess.h>
 #include <linux/indirect_call_wrapper.h>
+#include <trace/events/udp.h>
 
 #include <net/addrconf.h>
 #include <net/ndisc.h>
@@ -658,8 +659,8 @@ static int __udpv6_queue_rcv_skb(struct sock *sk, struct sk_buff *skb)
                        drop_reason = SKB_DROP_REASON_PROTO_MEM;
                }
                UDP6_INC_STATS(sock_net(sk), UDP_MIB_INERRORS, is_udplite);
+               trace_udp_fail_queue_rcv_skb(rc, sk, skb);
                kfree_skb_reason(skb, drop_reason);
-               trace_udp_fail_queue_rcv_skb(rc, sk);
                return -1;
        }