diff options
author | Neil Horman <nhorman@tuxdriver.com> | 2013-03-01 07:44:08 +0000 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2013-03-01 15:56:29 -0500 |
commit | d8c6f4b9b7848bca8babfc0ae43a50c8ab22fbb9 (patch) | |
tree | c354b5edc7c4c335bea3d9dcf4e977646ed012a0 /net/ipv4 | |
parent | 9e0aab86496295efdf6c2f57eaac3497e1c721a2 (diff) | |
download | op-kernel-dev-d8c6f4b9b7848bca8babfc0ae43a50c8ab22fbb9.zip op-kernel-dev-d8c6f4b9b7848bca8babfc0ae43a50c8ab22fbb9.tar.gz |
ipv[4|6]: correct dropwatch false positive in local_deliver_finish
I had a report recently of a user trying to use dropwatch to localise some frame
loss, and they were getting false positives. Turned out they were using a user
space SCTP stack that used raw sockets to grab frames. When we don't have a
registered protocol for a given packet, we record it as a drop, even if a raw
socket receieves the frame. We should only record the drop in the event a raw
socket doesnt exist to receive the frames
Tested by the reported successfully
Signed-off-by: Neil Horman <nhorman@tuxdriver.com>
Reported-by: William Reich <reich@ulticom.com>
Tested-by: William Reich <reich@ulticom.com>
CC: "David S. Miller" <davem@davemloft.net>
CC: William Reich <reich@ulticom.com>
CC: eric.dumazet@gmail.com
Acked-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv4')
-rw-r--r-- | net/ipv4/ip_input.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/net/ipv4/ip_input.c b/net/ipv4/ip_input.c index 87abd3e..2bdf802 100644 --- a/net/ipv4/ip_input.c +++ b/net/ipv4/ip_input.c @@ -228,9 +228,11 @@ static int ip_local_deliver_finish(struct sk_buff *skb) icmp_send(skb, ICMP_DEST_UNREACH, ICMP_PROT_UNREACH, 0); } - } else + kfree_skb(skb); + } else { IP_INC_STATS_BH(net, IPSTATS_MIB_INDELIVERS); - kfree_skb(skb); + consume_skb(skb); + } } } out: |