net: make skb_set_owner_w() more robust
authorEric Dumazet <edumazet@google.com>
Sun, 1 Nov 2015 23:36:55 +0000 (15:36 -0800)
committerDavid S. Miller <davem@davemloft.net>
Mon, 2 Nov 2015 21:28:49 +0000 (16:28 -0500)
commit9e17f8a475fca81950fdddc08df428ed66cf441f
tree417a79910266f08806f78be2dd970102afa3356f
parenteca1e006cf6f6f66a1a90c055a8a6d393475c3f9
net: make skb_set_owner_w() more robust

skb_set_owner_w() is called from various places that assume
skb->sk always point to a full blown socket (as it changes
sk->sk_wmem_alloc)

We'd like to attach skb to request sockets, and in the future
to timewait sockets as well. For these kind of pseudo sockets,
we need to take a traditional refcount and use sock_edemux()
as the destructor.

It is now time to un-inline skb_set_owner_w(), being too big.

Fixes: ca6fb0651883 ("tcp: attach SYNACK messages to request sockets instead of listener")
Signed-off-by: Eric Dumazet <edumazet@google.com>
Bisected-by: Haiyang Zhang <haiyangz@microsoft.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
include/net/sock.h
net/core/sock.c
net/ipv4/tcp_output.c