2005-04-17 06:20:36 +08:00
|
|
|
#ifndef _NAMESPACE_H_
|
|
|
|
#define _NAMESPACE_H_
|
|
|
|
#ifdef __KERNEL__
|
|
|
|
|
|
|
|
#include <linux/mount.h>
|
|
|
|
#include <linux/sched.h>
|
|
|
|
|
|
|
|
struct namespace {
|
|
|
|
atomic_t count;
|
|
|
|
struct vfsmount * root;
|
|
|
|
struct list_head list;
|
2005-11-08 06:15:49 +08:00
|
|
|
wait_queue_head_t poll;
|
|
|
|
int event;
|
2005-04-17 06:20:36 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
extern int copy_namespace(int, struct task_struct *);
|
|
|
|
extern void __put_namespace(struct namespace *namespace);
|
2006-02-08 04:59:00 +08:00
|
|
|
extern struct namespace *dup_namespace(struct task_struct *, struct fs_struct *);
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
static inline void put_namespace(struct namespace *namespace)
|
|
|
|
{
|
2005-07-08 08:57:24 +08:00
|
|
|
if (atomic_dec_and_lock(&namespace->count, &vfsmount_lock))
|
|
|
|
/* releases vfsmount_lock */
|
2005-04-17 06:20:36 +08:00
|
|
|
__put_namespace(namespace);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void exit_namespace(struct task_struct *p)
|
|
|
|
{
|
|
|
|
struct namespace *namespace = p->namespace;
|
|
|
|
if (namespace) {
|
|
|
|
task_lock(p);
|
|
|
|
p->namespace = NULL;
|
|
|
|
task_unlock(p);
|
|
|
|
put_namespace(namespace);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void get_namespace(struct namespace *namespace)
|
|
|
|
{
|
|
|
|
atomic_inc(&namespace->count);
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
#endif
|