The patch titled namespaces: utsname: implement utsname namespaces has been added to the -mm tree. Its filename is namespaces-utsname-implement-utsname-namespaces.patch See http://www.zip.com.au/~akpm/linux/patches/stuff/added-to-mm.txt to find out what to do about this ------------------------------------------------------ Subject: namespaces: utsname: implement utsname namespaces From: "Serge E. Hallyn" <serue@xxxxxxxxxx> This patch defines the uts namespace and some manipulators. Adds the uts namespace to task_struct, and initializes a system-wide init namespace. It leaves a #define for system_utsname so sysctl will compile. This define will be removed in a separate patch. Signed-off-by: Serge Hallyn <serue@xxxxxxxxxx> Cc: Kirill Korotaev <dev@xxxxxxxxxx> Cc: "Eric W. Biederman" <ebiederm@xxxxxxxxxxxx> Cc: Herbert Poetzl <herbert@xxxxxxxxxxxx> Cc: Andrey Savochkin <saw@xxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxx> --- include/linux/init_task.h | 2 + include/linux/nsproxy.h | 2 + include/linux/sched.h | 1 include/linux/utsname.h | 52 +++++++++++++++++++++++++++++++++--- init/Kconfig | 8 +++++ init/version.c | 22 +++++++++------ kernel/Makefile | 1 kernel/nsproxy.c | 14 +++++++++ kernel/utsname.c | 43 +++++++++++++++++++++++++++++ 9 files changed, 133 insertions(+), 12 deletions(-) diff -puN include/linux/init_task.h~namespaces-utsname-implement-utsname-namespaces include/linux/init_task.h --- 25/include/linux/init_task.h~namespaces-utsname-implement-utsname-namespaces Fri May 19 11:40:12 2006 +++ 25-akpm/include/linux/init_task.h Fri May 19 11:40:12 2006 @@ -3,6 +3,7 @@ #include <linux/file.h> #include <linux/rcupdate.h> +#include <linux/utsname.h> #define INIT_FDTABLE \ { \ @@ -70,6 +71,7 @@ extern struct nsproxy init_nsproxy; #define INIT_NSPROXY(nsproxy) { \ .count = ATOMIC_INIT(1), \ .nslock = SPIN_LOCK_UNLOCKED, \ + .uts_ns = &init_uts_ns, \ .namespace = NULL, \ } diff -puN include/linux/nsproxy.h~namespaces-utsname-implement-utsname-namespaces include/linux/nsproxy.h --- 25/include/linux/nsproxy.h~namespaces-utsname-implement-utsname-namespaces Fri May 19 11:40:12 2006 +++ 25-akpm/include/linux/nsproxy.h Fri May 19 11:40:12 2006 @@ -5,6 +5,7 @@ #include <linux/sched.h> struct namespace; +struct uts_namespace; /* * A structure to contain pointers to all per-process @@ -21,6 +22,7 @@ struct namespace; struct nsproxy { atomic_t count; spinlock_t nslock; + struct uts_namespace *uts_ns; struct namespace *namespace; }; extern struct nsproxy init_nsproxy; diff -puN include/linux/sched.h~namespaces-utsname-implement-utsname-namespaces include/linux/sched.h --- 25/include/linux/sched.h~namespaces-utsname-implement-utsname-namespaces Fri May 19 11:40:12 2006 +++ 25-akpm/include/linux/sched.h Fri May 19 11:40:12 2006 @@ -749,6 +749,7 @@ static inline void prefetch_stack(struct struct audit_context; /* See audit.c */ struct mempolicy; struct pipe_inode_info; +struct uts_namespace; enum sleep_type { SLEEP_NORMAL, diff -puN include/linux/utsname.h~namespaces-utsname-implement-utsname-namespaces include/linux/utsname.h --- 25/include/linux/utsname.h~namespaces-utsname-implement-utsname-namespaces Fri May 19 11:40:12 2006 +++ 25-akpm/include/linux/utsname.h Fri May 19 11:40:12 2006 @@ -1,6 +1,11 @@ #ifndef _LINUX_UTSNAME_H #define _LINUX_UTSNAME_H +#include <linux/sched.h> +#include <linux/kref.h> +#include <linux/nsproxy.h> +#include <asm/atomic.h> + #define __OLD_UTS_LEN 8 struct oldold_utsname { @@ -30,17 +35,58 @@ struct new_utsname { char domainname[65]; }; -extern struct new_utsname system_utsname; +struct uts_namespace { + struct kref kref; + struct new_utsname name; +}; +extern struct uts_namespace init_uts_ns; + +static inline void get_uts_ns(struct uts_namespace *ns) +{ + kref_get(&ns->kref); +} + +#ifdef CONFIG_UTS_NS +extern int copy_utsname(int flags, struct task_struct *tsk); +extern void free_uts_ns(struct kref *kref); + +static inline void put_uts_ns(struct uts_namespace *ns) +{ + kref_put(&ns->kref, free_uts_ns); +} + +static inline void exit_utsname(struct task_struct *p) +{ + struct uts_namespace *uts_ns = p->nsproxy->uts_ns; + if (uts_ns) { + put_uts_ns(uts_ns); + } +} + +#else +static inline int copy_utsname(int flags, struct task_struct *tsk) +{ + return 0; +} +static inline void put_uts_ns(struct uts_namespace *ns) +{ +} +static inline void exit_utsname(struct task_struct *p) +{ +} +#endif static inline struct new_utsname *utsname(void) { - return &system_utsname; + return ¤t->nsproxy->uts_ns->name; } static inline struct new_utsname *init_utsname(void) { - return &system_utsname; + return &init_uts_ns.name; } +#define system_utsname init_uts_ns.name + extern struct rw_semaphore uts_sem; #endif diff -puN init/Kconfig~namespaces-utsname-implement-utsname-namespaces init/Kconfig --- 25/init/Kconfig~namespaces-utsname-implement-utsname-namespaces Fri May 19 11:40:12 2006 +++ 25-akpm/init/Kconfig Fri May 19 11:40:12 2006 @@ -219,6 +219,14 @@ config SYSCTL building a kernel for install/rescue disks or your system is very limited in memory. +config UTS_NS + bool "UTS Namespaces" + default n + help + Support uts namespaces. This allows containers, i.e. + vservers, to use uts namespaces to provide different + uts info for different servers. If unsure, say N. + config AUDIT bool "Auditing support" depends on NET diff -puN init/version.c~namespaces-utsname-implement-utsname-namespaces init/version.c --- 25/init/version.c~namespaces-utsname-implement-utsname-namespaces Fri May 19 11:40:12 2006 +++ 25-akpm/init/version.c Fri May 19 11:40:12 2006 @@ -11,23 +11,27 @@ #include <linux/uts.h> #include <linux/utsname.h> #include <linux/version.h> +#include <linux/sched.h> #define version(a) Version_ ## a #define version_string(a) version(a) int version_string(LINUX_VERSION_CODE); -struct new_utsname system_utsname = { - .sysname = UTS_SYSNAME, - .nodename = UTS_NODENAME, - .release = UTS_RELEASE, - .version = UTS_VERSION, - .machine = UTS_MACHINE, - .domainname = UTS_DOMAINNAME, +struct uts_namespace init_uts_ns = { + .kref = { + .refcount = ATOMIC_INIT(2), + }, + .name = { + .sysname = UTS_SYSNAME, + .nodename = UTS_NODENAME, + .release = UTS_RELEASE, + .version = UTS_VERSION, + .machine = UTS_MACHINE, + .domainname = UTS_DOMAINNAME, + }, }; -EXPORT_SYMBOL(system_utsname); - const char linux_banner[] = "Linux version " UTS_RELEASE " (" LINUX_COMPILE_BY "@" LINUX_COMPILE_HOST ") (" LINUX_COMPILER ") " UTS_VERSION "\n"; diff -puN kernel/Makefile~namespaces-utsname-implement-utsname-namespaces kernel/Makefile --- 25/kernel/Makefile~namespaces-utsname-implement-utsname-namespaces Fri May 19 11:40:12 2006 +++ 25-akpm/kernel/Makefile Fri May 19 11:40:12 2006 @@ -41,6 +41,7 @@ obj-$(CONFIG_GENERIC_HARDIRQS) += irq/ obj-$(CONFIG_SECCOMP) += seccomp.o obj-$(CONFIG_RCU_TORTURE_TEST) += rcutorture.o obj-$(CONFIG_RELAY) += relay.o +obj-$(CONFIG_UTS_NS) += utsname.o obj-$(CONFIG_TASK_DELAY_ACCT) += delayacct.o obj-$(CONFIG_TASKSTATS) += taskstats.o diff -puN kernel/nsproxy.c~namespaces-utsname-implement-utsname-namespaces kernel/nsproxy.c --- 25/kernel/nsproxy.c~namespaces-utsname-implement-utsname-namespaces Fri May 19 11:40:12 2006 +++ 25-akpm/kernel/nsproxy.c Fri May 19 11:40:12 2006 @@ -14,6 +14,7 @@ #include <linux/version.h> #include <linux/nsproxy.h> #include <linux/namespace.h> +#include <linux/utsname.h> static inline void get_nsproxy(struct nsproxy *ns) { @@ -57,6 +58,8 @@ struct nsproxy *dup_namespaces(struct ns if (ns) { if (ns->namespace) get_namespace(ns->namespace); + if (ns->uts_ns) + get_uts_ns(ns->uts_ns); } return ns; @@ -95,6 +98,15 @@ int copy_namespaces(int flags, struct ta goto out; } + err = copy_utsname(flags, tsk); + if (err) { + if (new_ns->namespace) + put_namespace(new_ns->namespace); + tsk->nsproxy = old_ns; + put_nsproxy(new_ns); + goto out; + } + out: put_nsproxy(old_ns); return err; @@ -104,5 +116,7 @@ void free_nsproxy(struct nsproxy *ns) { if (ns->namespace) put_namespace(ns->namespace); + if (ns->uts_ns) + put_uts_ns(ns->uts_ns); kfree(ns); } diff -puN /dev/null kernel/utsname.c --- /dev/null Thu Apr 11 07:25:15 2002 +++ 25-akpm/kernel/utsname.c Fri May 19 11:40:12 2006 @@ -0,0 +1,43 @@ +/* + * Copyright (C) 2004 IBM Corporation + * + * Author: Serge Hallyn <serue@xxxxxxxxxx> + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation, version 2 of the + * License. + */ + +#include <linux/compile.h> +#include <linux/module.h> +#include <linux/uts.h> +#include <linux/utsname.h> +#include <linux/version.h> + +/* + * Copy task tsk's utsname namespace, or clone it if flags + * specifies CLONE_NEWUTS. In latter case, changes to the + * utsname of this process won't be seen by parent, and vice + * versa. + */ +int copy_utsname(int flags, struct task_struct *tsk) +{ + struct uts_namespace *old_ns = tsk->nsproxy->uts_ns; + int err = 0; + + if (!old_ns) + return 0; + + get_uts_ns(old_ns); + + return err; +} + +void free_uts_ns(struct kref *kref) +{ + struct uts_namespace *ns; + + ns = container_of(kref, struct uts_namespace, kref); + kfree(ns); +} _ Patches currently in -mm which might be from serue@xxxxxxxxxx are origin.patch namespaces-add-nsproxy.patch namespaces-incorporate-fs-namespace-into-nsproxy.patch namespaces-utsname-introduce-temporary-helpers.patch namespaces-utsname-switch-to-using-uts-namespaces.patch namespaces-utsname-use-init_utsname-when-appropriate.patch namespaces-utsname-implement-utsname-namespaces.patch namespaces-utsname-sysctl-hack.patch namespaces-utsname-remove-system_utsname.patch namespaces-utsname-implement-clone_newuts-flag.patch - To unsubscribe from this list: send the line "unsubscribe mm-commits" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html