diff options
author | Serge E. Hallyn <serue@us.ibm.com> | 2006-10-02 05:18:06 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-10-02 10:57:20 -0400 |
commit | ab516013ad9ca47f1d3a936fa81303bfbf734d52 (patch) | |
tree | 643ea9c4c3d28958cb42dd87b1856f74edd22b11 /include/linux/nsproxy.h | |
parent | b1ba4ddde0cf67991d89f039365eaaeda61aa027 (diff) |
[PATCH] namespaces: add nsproxy
This patch adds a nsproxy structure to the task struct. Later patches will
move the fs namespace pointer into this structure, and introduce a new utsname
namespace into the nsproxy.
The vserver and openvz functionality, then, would be implemented in large part
by virtualizing/isolating more and more resources into namespaces, each
contained in the nsproxy.
[akpm@osdl.org: build fix]
Signed-off-by: Serge Hallyn <serue@us.ibm.com>
Cc: Kirill Korotaev <dev@openvz.org>
Cc: "Eric W. Biederman" <ebiederm@xmission.com>
Cc: Herbert Poetzl <herbert@13thfloor.at>
Cc: Andrey Savochkin <saw@sw.ru>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'include/linux/nsproxy.h')
-rw-r--r-- | include/linux/nsproxy.h | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/include/linux/nsproxy.h b/include/linux/nsproxy.h new file mode 100644 index 000000000000..7bdebfaab6a5 --- /dev/null +++ b/include/linux/nsproxy.h | |||
@@ -0,0 +1,45 @@ | |||
1 | #ifndef _LINUX_NSPROXY_H | ||
2 | #define _LINUX_NSPROXY_H | ||
3 | |||
4 | #include <linux/spinlock.h> | ||
5 | #include <linux/sched.h> | ||
6 | |||
7 | /* | ||
8 | * A structure to contain pointers to all per-process | ||
9 | * namespaces - fs (mount), uts, network, sysvipc, etc. | ||
10 | * | ||
11 | * 'count' is the number of tasks holding a reference. | ||
12 | * The count for each namespace, then, will be the number | ||
13 | * of nsproxies pointing to it, not the number of tasks. | ||
14 | * | ||
15 | * The nsproxy is shared by tasks which share all namespaces. | ||
16 | * As soon as a single namespace is cloned or unshared, the | ||
17 | * nsproxy is copied. | ||
18 | */ | ||
19 | struct nsproxy { | ||
20 | atomic_t count; | ||
21 | spinlock_t nslock; | ||
22 | }; | ||
23 | extern struct nsproxy init_nsproxy; | ||
24 | |||
25 | struct nsproxy *dup_namespaces(struct nsproxy *orig); | ||
26 | int copy_namespaces(int flags, struct task_struct *tsk); | ||
27 | void get_task_namespaces(struct task_struct *tsk); | ||
28 | void free_nsproxy(struct nsproxy *ns); | ||
29 | |||
30 | static inline void put_nsproxy(struct nsproxy *ns) | ||
31 | { | ||
32 | if (atomic_dec_and_test(&ns->count)) { | ||
33 | free_nsproxy(ns); | ||
34 | } | ||
35 | } | ||
36 | |||
37 | static inline void exit_task_namespaces(struct task_struct *p) | ||
38 | { | ||
39 | struct nsproxy *ns = p->nsproxy; | ||
40 | if (ns) { | ||
41 | put_nsproxy(ns); | ||
42 | p->nsproxy = NULL; | ||
43 | } | ||
44 | } | ||
45 | #endif | ||