nsproxy.h 1.35 KB
Newer Older
1
2
3
4
5
6
#ifndef _LINUX_NSPROXY_H
#define _LINUX_NSPROXY_H

#include <linux/spinlock.h>
#include <linux/sched.h>

7
struct mnt_namespace;
8
struct uts_namespace;
Kirill Korotaev's avatar
Kirill Korotaev committed
9
struct ipc_namespace;
Cedric Le Goater's avatar
Cedric Le Goater committed
10
struct pid_namespace;
11

12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
/*
 * A structure to contain pointers to all per-process
 * namespaces - fs (mount), uts, network, sysvipc, etc.
 *
 * 'count' is the number of tasks holding a reference.
 * The count for each namespace, then, will be the number
 * of nsproxies pointing to it, not the number of tasks.
 *
 * The nsproxy is shared by tasks which share all namespaces.
 * As soon as a single namespace is cloned or unshared, the
 * nsproxy is copied.
 */
struct nsproxy {
	atomic_t count;
	spinlock_t nslock;
27
	unsigned long id;
28
	struct uts_namespace *uts_ns;
Kirill Korotaev's avatar
Kirill Korotaev committed
29
	struct ipc_namespace *ipc_ns;
30
	struct mnt_namespace *mnt_ns;
Cedric Le Goater's avatar
Cedric Le Goater committed
31
	struct pid_namespace *pid_ns;
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
};
extern struct nsproxy init_nsproxy;

struct nsproxy *dup_namespaces(struct nsproxy *orig);
int copy_namespaces(int flags, struct task_struct *tsk);
void get_task_namespaces(struct task_struct *tsk);
void free_nsproxy(struct nsproxy *ns);

static inline void put_nsproxy(struct nsproxy *ns)
{
	if (atomic_dec_and_test(&ns->count)) {
		free_nsproxy(ns);
	}
}

static inline void exit_task_namespaces(struct task_struct *p)
{
	struct nsproxy *ns = p->nsproxy;
	if (ns) {
51
		task_lock(p);
52
		p->nsproxy = NULL;
53
54
		task_unlock(p);
		put_nsproxy(ns);
55
56
57
	}
}
#endif