diff options
author | Patrick McHardy | 2005-08-17 06:03:41 +0200 |
---|---|---|
committer | David S. Miller | 2005-08-17 06:03:41 +0200 |
commit | fad87acaea7b0965fe91f0351fdd688fc9761cbe (patch) | |
tree | c14fefeeb50683accf0a34e4785155f0edad030d /net/ipv6 | |
parent | [TCP]: Fix bug #5070: kernel BUG at net/ipv4/tcp_output.c:864 (diff) | |
download | kernel-qcow2-linux-fad87acaea7b0965fe91f0351fdd688fc9761cbe.tar.gz kernel-qcow2-linux-fad87acaea7b0965fe91f0351fdd688fc9761cbe.tar.xz kernel-qcow2-linux-fad87acaea7b0965fe91f0351fdd688fc9761cbe.zip |
[IPV6]: Fix SKB leak in ip6_input_finish()
Changing it to how ip_input handles should fix it.
Signed-off-by: Patrick McHardy <kaber@trash.net>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv6')
-rw-r--r-- | net/ipv6/ip6_input.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/net/ipv6/ip6_input.c b/net/ipv6/ip6_input.c index 866f10726c58..10fbb50daea4 100644 --- a/net/ipv6/ip6_input.c +++ b/net/ipv6/ip6_input.c @@ -198,12 +198,13 @@ resubmit: if (!raw_sk) { if (xfrm6_policy_check(NULL, XFRM_POLICY_IN, skb)) { IP6_INC_STATS_BH(IPSTATS_MIB_INUNKNOWNPROTOS); - icmpv6_param_prob(skb, ICMPV6_UNK_NEXTHDR, nhoff); + icmpv6_send(skb, ICMPV6_PARAMPROB, + ICMPV6_UNK_NEXTHDR, nhoff, + skb->dev); } - } else { + } else IP6_INC_STATS_BH(IPSTATS_MIB_INDELIVERS); - kfree_skb(skb); - } + kfree_skb(skb); } rcu_read_unlock(); return 0; |