diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2011-05-25 18:10:16 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2011-05-25 18:10:16 -0700 | 
| commit | 14d74e0cab7a7779a7ff0c3863c04c8a8e507106 (patch) | |
| tree | 5e27d7495f8f7ce178b637d588ec42bd7b4173d8 /kernel/utsname.c | |
| parent | 49a78d085fa6b44d6ed791923c7172a6433589c2 (diff) | |
| parent | 956c920786694f51601a0ef7ee12956fd6aa216e (diff) | |
| download | olio-linux-3.10-14d74e0cab7a7779a7ff0c3863c04c8a8e507106.tar.xz olio-linux-3.10-14d74e0cab7a7779a7ff0c3863c04c8a8e507106.zip  | |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/ebiederm/linux-2.6-nsfd
* git://git.kernel.org/pub/scm/linux/kernel/git/ebiederm/linux-2.6-nsfd:
  net: fix get_net_ns_by_fd for !CONFIG_NET_NS
  ns proc: Return -ENOENT for a nonexistent /proc/self/ns/ entry.
  ns: Declare sys_setns in syscalls.h
  net: Allow setting the network namespace by fd
  ns proc: Add support for the ipc namespace
  ns proc: Add support for the uts namespace
  ns proc: Add support for the network namespace.
  ns: Introduce the setns syscall
  ns: proc files for namespace naming policy.
Diffstat (limited to 'kernel/utsname.c')
| -rw-r--r-- | kernel/utsname.c | 39 | 
1 files changed, 39 insertions, 0 deletions
diff --git a/kernel/utsname.c b/kernel/utsname.c index 44646179eab..bff131b9510 100644 --- a/kernel/utsname.c +++ b/kernel/utsname.c @@ -15,6 +15,7 @@  #include <linux/err.h>  #include <linux/slab.h>  #include <linux/user_namespace.h> +#include <linux/proc_fs.h>  static struct uts_namespace *create_uts_ns(void)  { @@ -79,3 +80,41 @@ void free_uts_ns(struct kref *kref)  	put_user_ns(ns->user_ns);  	kfree(ns);  } + +static void *utsns_get(struct task_struct *task) +{ +	struct uts_namespace *ns = NULL; +	struct nsproxy *nsproxy; + +	rcu_read_lock(); +	nsproxy = task_nsproxy(task); +	if (nsproxy) { +		ns = nsproxy->uts_ns; +		get_uts_ns(ns); +	} +	rcu_read_unlock(); + +	return ns; +} + +static void utsns_put(void *ns) +{ +	put_uts_ns(ns); +} + +static int utsns_install(struct nsproxy *nsproxy, void *ns) +{ +	get_uts_ns(ns); +	put_uts_ns(nsproxy->uts_ns); +	nsproxy->uts_ns = ns; +	return 0; +} + +const struct proc_ns_operations utsns_operations = { +	.name		= "uts", +	.type		= CLONE_NEWUTS, +	.get		= utsns_get, +	.put		= utsns_put, +	.install	= utsns_install, +}; +  |