Skip to content

Commit 7841f03

Browse files
atenartsmb49
authored andcommitted
gro: fix ownership transfer
BugLink: https://bugs.launchpad.net/bugs/2065435 commit ed4ccce upstream. If packets are GROed with fraglist they might be segmented later on and continue their journey in the stack. In skb_segment_list those skbs can be reused as-is. This is an issue as their destructor was removed in skb_gro_receive_list but not the reference to their socket, and then they can't be orphaned. Fix this by also removing the reference to the socket. For example this could be observed, kernel BUG at include/linux/skbuff.h:3131! (skb_orphan) RIP: 0010:ip6_rcv_core+0x11bc/0x19a0 Call Trace: ipv6_list_rcv+0x250/0x3f0 __netif_receive_skb_list_core+0x49d/0x8f0 netif_receive_skb_list_internal+0x634/0xd40 napi_complete_done+0x1d2/0x7d0 gro_cell_poll+0x118/0x1f0 A similar construction is found in skb_gro_receive, apply the same change there. Fixes: 5e10da5 ("skbuff: allow 'slow_gro' for skb carring sock reference") Signed-off-by: Antoine Tenart <[email protected]> Reviewed-by: Willem de Bruijn <[email protected]> Signed-off-by: David S. Miller <[email protected]> Signed-off-by: Greg Kroah-Hartman <[email protected]> Signed-off-by: Manuel Diewald <[email protected]> Signed-off-by: Roxana Nicolescu <[email protected]>
1 parent 6543b7f commit 7841f03

File tree

1 file changed

+4
-2
lines changed

1 file changed

+4
-2
lines changed

net/core/skbuff.c

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -3976,8 +3976,9 @@ int skb_gro_receive_list(struct sk_buff *p, struct sk_buff *skb)
39763976
NAPI_GRO_CB(p)->count++;
39773977
p->data_len += skb->len;
39783978

3979-
/* sk owenrship - if any - completely transferred to the aggregated packet */
3979+
/* sk ownership - if any - completely transferred to the aggregated packet */
39803980
skb->destructor = NULL;
3981+
skb->sk = NULL;
39813982
p->truesize += skb->truesize;
39823983
p->len += skb->len;
39833984

@@ -4425,8 +4426,9 @@ int skb_gro_receive(struct sk_buff *p, struct sk_buff *skb)
44254426
}
44264427

44274428
merge:
4428-
/* sk owenrship - if any - completely transferred to the aggregated packet */
4429+
/* sk ownership - if any - completely transferred to the aggregated packet */
44294430
skb->destructor = NULL;
4431+
skb->sk = NULL;
44304432
delta_truesize = skb->truesize;
44314433
if (offset > headlen) {
44324434
unsigned int eat = offset - headlen;

0 commit comments

Comments
 (0)