Message ID | 20220316024606.689731-3-imagedong@tencent.com (mailing list archive) |
---|---|
State | Superseded |
Delegated to: | Netdev Maintainers |
Headers | show |
Series | net: icmp: add skb drop reasons to icmp | expand |
Context | Check | Description |
---|---|---|
netdev/tree_selection | success | Clearly marked for net-next |
netdev/fixes_present | success | Fixes tag not required for -next series |
netdev/subject_prefix | success | Link |
netdev/cover_letter | success | Series has a cover letter |
netdev/patch_count | success | Link |
netdev/header_inline | success | No static functions without inline keyword in header files |
netdev/build_32bit | success | Errors and warnings before: 2 this patch: 2 |
netdev/cc_maintainers | success | CCed 5 of 5 maintainers |
netdev/build_clang | success | Errors and warnings before: 18 this patch: 18 |
netdev/module_param | success | Was 0 now: 0 |
netdev/verify_signedoff | success | Signed-off-by tag matches author and committer |
netdev/verify_fixes | success | No Fixes tag |
netdev/build_allmodconfig_warn | success | Errors and warnings before: 7 this patch: 7 |
netdev/checkpatch | warning | CHECK: Alignment should match open parenthesis |
netdev/kdoc | success | Errors and warnings before: 0 this patch: 0 |
netdev/source_inline | success | Was 0 now: 0 |
On Wed, Mar 16, 2022 at 10:47 AM <menglong8.dong@gmail.com> wrote: > > From: Menglong Dong <imagedong@tencent.com> > > In order to avoid to change the return value of ping_queue_rcv_skb(), > introduce the function __ping_queue_rcv_skb(), which is able to report > the reasons of skb drop as its return value, as Paolo suggested. > > Meanwhile, make ping_queue_rcv_skb() a simple call to > __ping_queue_rcv_skb(). > > The kfree_skb() and sock_queue_rcv_skb() used in ping_queue_rcv_skb() > are replaced with kfree_skb_reason() and sock_queue_rcv_skb_reason() > now. > > Reviewed-by: Hao Peng <flyingpeng@tencent.com> > Reviewed-by: Biao Jiang <benbjiang@tencent.com> > Signed-off-by: Menglong Dong <imagedong@tencent.com> > --- > v2: > - introduce __ping_queue_rcv_skb() instead of change the return value > of ping_queue_rcv_skb() > --- > net/ipv4/ping.c | 18 +++++++++++++----- > 1 file changed, 13 insertions(+), 5 deletions(-) > > diff --git a/net/ipv4/ping.c b/net/ipv4/ping.c > index 3ee947557b88..138eeed7727b 100644 > --- a/net/ipv4/ping.c > +++ b/net/ipv4/ping.c > @@ -934,16 +934,24 @@ int ping_recvmsg(struct sock *sk, struct msghdr *msg, size_t len, int noblock, > } > EXPORT_SYMBOL_GPL(ping_recvmsg); > > -int ping_queue_rcv_skb(struct sock *sk, struct sk_buff *skb) > +static enum skb_drop_reason __ping_queue_rcv_skb(struct sock *sk, > + struct sk_buff *skb) Oops, there is an alignment problem here...I'll send a new version. > { > + enum skb_drop_reason reason; > + > pr_debug("ping_queue_rcv_skb(sk=%p,sk->num=%d,skb=%p)\n", > inet_sk(sk), inet_sk(sk)->inet_num, skb); > - if (sock_queue_rcv_skb(sk, skb) < 0) { > - kfree_skb(skb); > + if (sock_queue_rcv_skb_reason(sk, skb, &reason) < 0) { > + kfree_skb_reason(skb, reason); > pr_debug("ping_queue_rcv_skb -> failed\n"); > - return -1; > + return reason; > } > - return 0; > + return SKB_NOT_DROPPED_YET; > +} > + > +int ping_queue_rcv_skb(struct sock *sk, struct sk_buff *skb) > +{ > + return __ping_queue_rcv_skb(sk, skb) ?: -1; > } > EXPORT_SYMBOL_GPL(ping_queue_rcv_skb); > > -- > 2.35.1 >
diff --git a/net/ipv4/ping.c b/net/ipv4/ping.c index 3ee947557b88..138eeed7727b 100644 --- a/net/ipv4/ping.c +++ b/net/ipv4/ping.c @@ -934,16 +934,24 @@ int ping_recvmsg(struct sock *sk, struct msghdr *msg, size_t len, int noblock, } EXPORT_SYMBOL_GPL(ping_recvmsg); -int ping_queue_rcv_skb(struct sock *sk, struct sk_buff *skb) +static enum skb_drop_reason __ping_queue_rcv_skb(struct sock *sk, + struct sk_buff *skb) { + enum skb_drop_reason reason; + pr_debug("ping_queue_rcv_skb(sk=%p,sk->num=%d,skb=%p)\n", inet_sk(sk), inet_sk(sk)->inet_num, skb); - if (sock_queue_rcv_skb(sk, skb) < 0) { - kfree_skb(skb); + if (sock_queue_rcv_skb_reason(sk, skb, &reason) < 0) { + kfree_skb_reason(skb, reason); pr_debug("ping_queue_rcv_skb -> failed\n"); - return -1; + return reason; } - return 0; + return SKB_NOT_DROPPED_YET; +} + +int ping_queue_rcv_skb(struct sock *sk, struct sk_buff *skb) +{ + return __ping_queue_rcv_skb(sk, skb) ?: -1; } EXPORT_SYMBOL_GPL(ping_queue_rcv_skb);