Commit 56d4b4e4 authored by Menglong Dong's avatar Menglong Dong Committed by David S. Miller

net: neigh: add skb drop reasons to arp_error_report()

When neighbour become invalid or destroyed, neigh_invalidate() will be
called. neigh->ops->error_report() will be called if the neighbour's
state is NUD_FAILED, and seems here is the only use of error_report().
So we can tell that the reason of skb drops in arp_error_report() is
SKB_DROP_REASON_NEIGH_FAILED.

Replace kfree_skb() used in arp_error_report() with kfree_skb_reason().
Reviewed-by: default avatarMengen Sun <mengensun@tencent.com>
Reviewed-by: default avatarHao Peng <flyingpeng@tencent.com>
Signed-off-by: default avatarMenglong Dong <imagedong@tencent.com>
Reviewed-by: default avatarDavid Ahern <dsahern@kernel.org>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent a5736edd
...@@ -293,7 +293,7 @@ static int arp_constructor(struct neighbour *neigh) ...@@ -293,7 +293,7 @@ static int arp_constructor(struct neighbour *neigh)
static void arp_error_report(struct neighbour *neigh, struct sk_buff *skb) static void arp_error_report(struct neighbour *neigh, struct sk_buff *skb)
{ {
dst_link_failure(skb); dst_link_failure(skb);
kfree_skb(skb); kfree_skb_reason(skb, SKB_DROP_REASON_NEIGH_FAILED);
} }
/* Create and send an arp packet. */ /* Create and send an arp packet. */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment