From: Zhang Shengju Date: Wed, 7 Dec 2016 06:52:53 +0000 (+0800) Subject: icmp: correct return value of icmp_rcv() X-Git-Tag: v4.10-rc1~202^2~52 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=f91c58d68b8638530e0eb2fec76c5b9e429ca39a;p=users%2Fhch%2Fdma-mapping.git icmp: correct return value of icmp_rcv() Currently, icmp_rcv() always return zero on a packet delivery upcall. To make its behavior more compliant with the way this API should be used, this patch changes this to let it return NET_RX_SUCCESS when the packet is proper handled, and NET_RX_DROP otherwise. Signed-off-by: Zhang Shengju Signed-off-by: David S. Miller --- diff --git a/net/ipv4/icmp.c b/net/ipv4/icmp.c index 691146abde2d..f79d7a8ab1c6 100644 --- a/net/ipv4/icmp.c +++ b/net/ipv4/icmp.c @@ -1047,12 +1047,12 @@ int icmp_rcv(struct sk_buff *skb) if (success) { consume_skb(skb); - return 0; + return NET_RX_SUCCESS; } drop: kfree_skb(skb); - return 0; + return NET_RX_DROP; csum_error: __ICMP_INC_STATS(net, ICMP_MIB_CSUMERRORS); error: