[NET]: Make the sk_clone() lighter
authorPavel Emelyanov <xemul@openvz.org>
Thu, 1 Nov 2007 07:37:32 +0000 (00:37 -0700)
committerDavid S. Miller <davem@davemloft.net>
Thu, 1 Nov 2007 07:37:32 +0000 (00:37 -0700)
The sk_prot_alloc() already performs all the stuff needed by the
sk_clone(). Besides, the sk_prot_alloc() requires almost twice
less arguments than the sk_alloc() does, so call the sk_prot_alloc()
saving the stack a bit.

Signed-off-by: Pavel Emelyanov <xemul@openvz.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/core/sock.c

index 2b744c2bf46622c3ad6d3f2b83952d0a3c179aa2..4f4708a6ff8fb1aa5c9cc8b6ba2e638ebb944191 100644 (file)
@@ -976,8 +976,9 @@ void sk_free(struct sock *sk)
 
 struct sock *sk_clone(const struct sock *sk, const gfp_t priority)
 {
-       struct sock *newsk = sk_alloc(sk->sk_net, sk->sk_family, priority, sk->sk_prot, 0);
+       struct sock *newsk;
 
+       newsk = sk_prot_alloc(sk->sk_prot, priority, sk->sk_family);
        if (newsk != NULL) {
                struct sk_filter *filter;