ipv6: call consume_skb() in frag/reassembly
Some kfree_skb() calls should be replaced by consume_skb() to avoid drop_monitor/dropwatch false positives. Signed-off-by: Eric Dumazet <edumazet@google.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
081579840b
commit
808db80a7e
2 changed files with 3 additions and 3 deletions
|
@ -210,7 +210,7 @@ int ip6_xmit(struct sock *sk, struct sk_buff *skb, struct flowi6 *fl6,
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return -ENOBUFS;
|
return -ENOBUFS;
|
||||||
}
|
}
|
||||||
kfree_skb(skb);
|
consume_skb(skb);
|
||||||
skb = skb2;
|
skb = skb2;
|
||||||
skb_set_owner_w(skb, sk);
|
skb_set_owner_w(skb, sk);
|
||||||
}
|
}
|
||||||
|
@ -889,7 +889,7 @@ int ip6_fragment(struct sk_buff *skb, int (*output)(struct sk_buff *))
|
||||||
}
|
}
|
||||||
IP6_INC_STATS(net, ip6_dst_idev(skb_dst(skb)),
|
IP6_INC_STATS(net, ip6_dst_idev(skb_dst(skb)),
|
||||||
IPSTATS_MIB_FRAGOKS);
|
IPSTATS_MIB_FRAGOKS);
|
||||||
kfree_skb(skb);
|
consume_skb(skb);
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
fail:
|
fail:
|
||||||
|
|
|
@ -433,7 +433,7 @@ static int ip6_frag_reasm(struct frag_queue *fq, struct sk_buff *prev,
|
||||||
skb_morph(head, fq->q.fragments);
|
skb_morph(head, fq->q.fragments);
|
||||||
head->next = fq->q.fragments->next;
|
head->next = fq->q.fragments->next;
|
||||||
|
|
||||||
kfree_skb(fq->q.fragments);
|
consume_skb(fq->q.fragments);
|
||||||
fq->q.fragments = head;
|
fq->q.fragments = head;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue