lists.openwall.net | lists / announce owl-users owl-dev john-users john-dev passwdqc-users yescrypt popa3d-users / oss-security kernel-hardening musl sabotage tlsify passwords / crypt-dev xvendor / Bugtraq Full-Disclosure linux-kernel linux-netdev linux-ext4 linux-hardening PHC | |
Open Source and information security mailing list archives
| ||
|
Date: Fri, 4 Mar 2022 01:47:05 +0800 From: menglong8.dong@...il.com To: dsahern@...nel.org, kuba@...nel.org Cc: rostedt@...dmis.org, mingo@...hat.com, davem@...emloft.net, ast@...nel.org, daniel@...earbox.net, hawk@...nel.org, john.fastabend@...il.com, imagedong@...cent.com, edumazet@...gle.com, talalahmad@...gle.com, keescook@...omium.org, ilias.apalodimas@...aro.org, alobakin@...me, flyingpeng@...cent.com, mengensun@...cent.com, atenart@...nel.org, bigeasy@...utronix.de, memxor@...il.com, arnd@...db.de, pabeni@...hat.com, willemb@...gle.com, vvs@...tuozzo.com, cong.wang@...edance.com, linux-kernel@...r.kernel.org, netdev@...r.kernel.org, bpf@...r.kernel.org Subject: [PATCH net-next 5/7] net: dev: use kfree_skb_reason() for do_xdp_generic() From: Menglong Dong <imagedong@...cent.com> Replace kfree_skb() used in do_xdp_generic() with kfree_skb_reason(). The drop reason SKB_DROP_REASON_XDP is introduced for this case. Signed-off-by: Menglong Dong <imagedong@...cent.com> --- include/linux/skbuff.h | 1 + include/trace/events/skb.h | 1 + net/core/dev.c | 2 +- 3 files changed, 3 insertions(+), 1 deletion(-) diff --git a/include/linux/skbuff.h b/include/linux/skbuff.h index d2cf87ff84c2..23bbfcd6668b 100644 --- a/include/linux/skbuff.h +++ b/include/linux/skbuff.h @@ -408,6 +408,7 @@ enum skb_drop_reason { * full (see netdev_max_backlog in * net.rst) or RPS flow limit */ + SKB_DROP_REASON_XDP, /* dropped by XDP in input path */ SKB_DROP_REASON_MAX, }; diff --git a/include/trace/events/skb.h b/include/trace/events/skb.h index 29c360b5e114..c117430375c0 100644 --- a/include/trace/events/skb.h +++ b/include/trace/events/skb.h @@ -48,6 +48,7 @@ EM(SKB_DROP_REASON_QDISC_EGRESS, QDISC_EGRESS) \ EM(SKB_DROP_REASON_QDISC_DROP, QDISC_DROP) \ EM(SKB_DROP_REASON_CPU_BACKLOG, CPU_BACKLOG) \ + EM(SKB_DROP_REASON_XDP, XDP) \ EMe(SKB_DROP_REASON_MAX, MAX) #undef EM diff --git a/net/core/dev.c b/net/core/dev.c index 373fa7a33ffa..ae85e024c7b7 100644 --- a/net/core/dev.c +++ b/net/core/dev.c @@ -4797,7 +4797,7 @@ int do_xdp_generic(struct bpf_prog *xdp_prog, struct sk_buff *skb) } return XDP_PASS; out_redir: - kfree_skb(skb); + kfree_skb_reason(skb, SKB_DROP_REASON_XDP); return XDP_DROP; } EXPORT_SYMBOL_GPL(do_xdp_generic); -- 2.35.1
Powered by blists - more mailing lists