Browse Source

netns 1/2: don't get/put old netns on CLONE_NEWNET

copy_net_ns() doesn't copy anything, it creates fresh netns, so
get/put of old netns isn't needed.

Signed-off-by: Alexey Dobriyan <adobriyan@gmail.com>
Acked-by: Serge Hallyn <serue@us.ibm.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Alexey Dobriyan 16 years ago
parent
commit
4a84822c60
1 changed files with 1 additions and 4 deletions
  1. 1 4
      net/core/net_namespace.c

+ 1 - 4
net/core/net_namespace.c

@@ -120,10 +120,8 @@ struct net *copy_net_ns(unsigned long flags, struct net *old_net)
 	struct net *new_net = NULL;
 	struct net *new_net = NULL;
 	int err;
 	int err;
 
 
-	get_net(old_net);
-
 	if (!(flags & CLONE_NEWNET))
 	if (!(flags & CLONE_NEWNET))
-		return old_net;
+		return get_net(old_net);
 
 
 	err = -ENOMEM;
 	err = -ENOMEM;
 	new_net = net_alloc();
 	new_net = net_alloc();
@@ -142,7 +140,6 @@ struct net *copy_net_ns(unsigned long flags, struct net *old_net)
 	if (err)
 	if (err)
 		goto out_free;
 		goto out_free;
 out:
 out:
-	put_net(old_net);
 	return new_net;
 	return new_net;
 
 
 out_free:
 out_free: