diff options
author | 2024-06-17 11:09:09 -0700 | |
---|---|---|
committer | 2024-06-19 12:44:22 +0100 | |
commit | ba8de796baf4bdc03530774fb284fe3c97875566 (patch) | |
tree | da51334e1119d058073e89bf562d7b2fc1940683 /net/ipv6/udp.c | |
parent | net: add rx_sk to trace_kfree_skb (diff) | |
download | wireguard-linux-ba8de796baf4bdc03530774fb284fe3c97875566.tar.xz wireguard-linux-ba8de796baf4bdc03530774fb284fe3c97875566.zip |
net: introduce sk_skb_reason_drop function
Long used destructors kfree_skb and kfree_skb_reason do not pass
receiving socket to packet drop tracepoints trace_kfree_skb.
This makes it hard to track packet drops of a certain netns (container)
or a socket (user application).
The naming of these destructors are also not consistent with most sk/skb
operating functions, i.e. functions named "sk_xxx" or "skb_xxx".
Introduce a new functions sk_skb_reason_drop as drop-in replacement for
kfree_skb_reason on local receiving path. Callers can now pass receiving
sockets to the tracepoints.
kfree_skb and kfree_skb_reason are still usable but they are now just
inline helpers that call sk_skb_reason_drop.
Note it is not feasible to do the same to consume_skb. Packets not
dropped can flow through multiple receive handlers, and have multiple
receiving sockets. Leave it untouched for now.
Suggested-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: Yan Zhai <yan@cloudflare.com>
Acked-by: Jesper Dangaard Brouer <hawk@kernel.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv6/udp.c')
0 files changed, 0 insertions, 0 deletions