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 | |
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')
-rw-r--r-- | include/linux/init_task.h | 7 | ||||
-rw-r--r-- | include/linux/nsproxy.h | 45 | ||||
-rw-r--r-- | include/linux/sched.h | 2 |
3 files changed, 54 insertions, 0 deletions
diff --git a/include/linux/init_task.h b/include/linux/init_task.h index 60aac2cea0cf..8f8bb422a5c7 100644 --- a/include/linux/init_task.h +++ b/include/linux/init_task.h | |||
@@ -68,6 +68,12 @@ | |||
68 | .session = 1, \ | 68 | .session = 1, \ |
69 | } | 69 | } |
70 | 70 | ||
71 | extern struct nsproxy init_nsproxy; | ||
72 | #define INIT_NSPROXY(nsproxy) { \ | ||
73 | .count = ATOMIC_INIT(1), \ | ||
74 | .nslock = SPIN_LOCK_UNLOCKED, \ | ||
75 | } | ||
76 | |||
71 | #define INIT_SIGHAND(sighand) { \ | 77 | #define INIT_SIGHAND(sighand) { \ |
72 | .count = ATOMIC_INIT(1), \ | 78 | .count = ATOMIC_INIT(1), \ |
73 | .action = { { { .sa_handler = NULL, } }, }, \ | 79 | .action = { { { .sa_handler = NULL, } }, }, \ |
@@ -117,6 +123,7 @@ extern struct group_info init_groups; | |||
117 | .files = &init_files, \ | 123 | .files = &init_files, \ |
118 | .signal = &init_signals, \ | 124 | .signal = &init_signals, \ |
119 | .sighand = &init_sighand, \ | 125 | .sighand = &init_sighand, \ |
126 | .nsproxy = &init_nsproxy, \ | ||
120 | .pending = { \ | 127 | .pending = { \ |
121 | .list = LIST_HEAD_INIT(tsk.pending.list), \ | 128 | .list = LIST_HEAD_INIT(tsk.pending.list), \ |
122 | .signal = {{0}}}, \ | 129 | .signal = {{0}}}, \ |
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 | ||
diff --git a/include/linux/sched.h b/include/linux/sched.h index a7fff3304bd6..4fa631fa55e3 100644 --- a/include/linux/sched.h +++ b/include/linux/sched.h | |||
@@ -239,6 +239,7 @@ extern signed long schedule_timeout_uninterruptible(signed long timeout); | |||
239 | asmlinkage void schedule(void); | 239 | asmlinkage void schedule(void); |
240 | 240 | ||
241 | struct namespace; | 241 | struct namespace; |
242 | struct nsproxy; | ||
242 | 243 | ||
243 | /* Maximum number of active map areas.. This is a random (large) number */ | 244 | /* Maximum number of active map areas.. This is a random (large) number */ |
244 | #define DEFAULT_MAX_MAP_COUNT 65536 | 245 | #define DEFAULT_MAX_MAP_COUNT 65536 |
@@ -898,6 +899,7 @@ struct task_struct { | |||
898 | struct files_struct *files; | 899 | struct files_struct *files; |
899 | /* namespace */ | 900 | /* namespace */ |
900 | struct namespace *namespace; | 901 | struct namespace *namespace; |
902 | struct nsproxy *nsproxy; | ||
901 | /* signal handlers */ | 903 | /* signal handlers */ |
902 | struct signal_struct *signal; | 904 | struct signal_struct *signal; |
903 | struct sighand_struct *sighand; | 905 | struct sighand_struct *sighand; |