blob: 830bbcd449d6c97c9e09a51bce33fabcd163d087 [file] [log] [blame]
Kirill Korotaev6b3286e2006-12-08 02:37:56 -08001#ifndef _NAMESPACE_H_
2#define _NAMESPACE_H_
3#ifdef __KERNEL__
4
5#include <linux/mount.h>
6#include <linux/sched.h>
7#include <linux/nsproxy.h>
Miklos Szeredia1a2c402008-03-27 13:06:24 +01008#include <linux/seq_file.h>
Kirill Korotaev6b3286e2006-12-08 02:37:56 -08009
10struct mnt_namespace {
11 atomic_t count;
12 struct vfsmount * root;
13 struct list_head list;
14 wait_queue_head_t poll;
15 int event;
16};
17
Miklos Szeredia1a2c402008-03-27 13:06:24 +010018struct proc_mounts {
19 struct seq_file m; /* must be the first element */
20 struct mnt_namespace *ns;
21 struct path root;
22 int event;
23};
24
Eric W. Biederman213dd262007-07-15 23:41:15 -070025extern struct mnt_namespace *copy_mnt_ns(unsigned long, struct mnt_namespace *,
Kirill Korotaev6b3286e2006-12-08 02:37:56 -080026 struct fs_struct *);
Badari Pulavartye3222c42007-05-08 00:25:21 -070027extern void __put_mnt_ns(struct mnt_namespace *ns);
Kirill Korotaev6b3286e2006-12-08 02:37:56 -080028
29static inline void put_mnt_ns(struct mnt_namespace *ns)
30{
31 if (atomic_dec_and_lock(&ns->count, &vfsmount_lock))
32 /* releases vfsmount_lock */
33 __put_mnt_ns(ns);
34}
35
36static inline void exit_mnt_ns(struct task_struct *p)
37{
38 struct mnt_namespace *ns = p->nsproxy->mnt_ns;
39 if (ns)
40 put_mnt_ns(ns);
41}
42
43static inline void get_mnt_ns(struct mnt_namespace *ns)
44{
45 atomic_inc(&ns->count);
46}
47
Miklos Szeredia1a2c402008-03-27 13:06:24 +010048extern const struct seq_operations mounts_op;
Ram Pai2d4d4862008-03-27 13:06:25 +010049extern const struct seq_operations mountinfo_op;
Miklos Szeredia1a2c402008-03-27 13:06:24 +010050extern const struct seq_operations mountstats_op;
51
Kirill Korotaev6b3286e2006-12-08 02:37:56 -080052#endif
53#endif