diff options
author | Pavel Emelyanov <xemul@openvz.org> | 2007-11-01 00:31:26 -0700 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2007-11-01 00:31:26 -0700 |
commit | 1e2e6b89f1d3152da0606d23e65e8760bf62a4c3 (patch) | |
tree | 75cbf6c0a5b2a0e708261d3799c7797a371f8a1d /net/core | |
parent | f1a6c4da14c365d3ee0b5de43a93f7470982637c (diff) | |
download | linux-stable-1e2e6b89f1d3152da0606d23e65e8760bf62a4c3.tar.gz linux-stable-1e2e6b89f1d3152da0606d23e65e8760bf62a4c3.tar.bz2 linux-stable-1e2e6b89f1d3152da0606d23e65e8760bf62a4c3.zip |
[NET]: Move the get_net() from sock_copy()
The sock_copy() is supposed to just clone the socket. In a perfect
world it has to be just memcpy, but we have to handle the security
mark correctly. All the extra setup must be performed in sk_clone()
call, so move the get_net() into more proper place.
Signed-off-by: Pavel Emelyanov <xemul@openvz.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/core')
-rw-r--r-- | net/core/sock.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/net/core/sock.c b/net/core/sock.c index fdacf9c8f1cb..9c2dbfaca60d 100644 --- a/net/core/sock.c +++ b/net/core/sock.c @@ -864,7 +864,6 @@ static void sock_copy(struct sock *nsk, const struct sock *osk) #endif memcpy(nsk, osk, osk->sk_prot->obj_size); - get_net(nsk->sk_net); #ifdef CONFIG_SECURITY_NETWORK nsk->sk_security = sptr; security_sk_clone(osk, nsk); @@ -958,6 +957,7 @@ struct sock *sk_clone(const struct sock *sk, const gfp_t priority) sock_copy(newsk, sk); /* SANITY */ + get_net(newsk->sk_net); sk_node_init(&newsk->sk_node); sock_lock_init(newsk); bh_lock_sock(newsk); |