udp: drop head states only when all skb references are gone
After commit0ddf3fb2c4
("udp: preserve skb->dst if required for IP options processing") we clear the skb head state as soon as the skb carrying them is first processed. Since the same skb can be processed several times when MSG_PEEK is used, we can end up lacking the required head states, and eventually oopsing. Fix this clearing the skb head state only when processing the last skb reference. Reported-by: Eric Dumazet <edumazet@google.com> Fixes:0ddf3fb2c4
("udp: preserve skb->dst if required for IP options processing") Signed-off-by: Paolo Abeni <pabeni@redhat.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:

committed by
David S. Miller

parent
5c25f30c93
commit
ca2c1418ef
@@ -710,14 +710,11 @@ EXPORT_SYMBOL(consume_skb);
|
||||
* consume_stateless_skb - free an skbuff, assuming it is stateless
|
||||
* @skb: buffer to free
|
||||
*
|
||||
* Works like consume_skb(), but this variant assumes that all the head
|
||||
* states have been already dropped.
|
||||
* Alike consume_skb(), but this variant assumes that this is the last
|
||||
* skb reference and all the head states have been already dropped
|
||||
*/
|
||||
void consume_stateless_skb(struct sk_buff *skb)
|
||||
void __consume_stateless_skb(struct sk_buff *skb)
|
||||
{
|
||||
if (!skb_unref(skb))
|
||||
return;
|
||||
|
||||
trace_consume_skb(skb);
|
||||
skb_release_data(skb);
|
||||
kfree_skbmem(skb);
|
||||
|
Reference in New Issue
Block a user