coallocate socket_wq with socket itself
authorAl Viro <viro@zeniv.linux.org.uk>
Fri, 5 Jul 2019 19:14:16 +0000 (20:14 +0100)
committerDavid S. Miller <davem@davemloft.net>
Tue, 9 Jul 2019 02:25:19 +0000 (19:25 -0700)
commit333f7909a8573145811c4ab7d8c9092301707721
tree313fbf52f203f67375d0d378198a70a4de732a93
parent6d7855c54e1e269275d7c504f8f62a0b7a5b3f18
coallocate socket_wq with socket itself

socket->wq is assign-once, set when we are initializing both
struct socket it's in and struct socket_wq it points to.  As the
matter of fact, the only reason for separate allocation was the
ability to RCU-delay freeing of socket_wq.  RCU-delaying the
freeing of socket itself gets rid of that need, so we can just
fold struct socket_wq into the end of struct socket and simplify
the life both for sock_alloc_inode() (one allocation instead of
two) and for tun/tap oddballs, where we used to embed struct socket
and struct socket_wq into the same structure (now - embedding just
the struct socket).

Note that reference to struct socket_wq in struct sock does remain
a reference - that's unchanged.

Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/tap.c
drivers/net/tun.c
include/linux/if_tap.h
include/linux/net.h
include/net/sock.h
net/core/sock.c
net/socket.c