2005-04-16 16:20:36 -06: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-07 15:15:49 -07:00
|
|
|
wait_queue_head_t poll;
|
|
|
|
int event;
|
2005-04-16 16:20:36 -06:00
|
|
|
};
|
|
|
|
|
|
|
|
extern int copy_namespace(int, struct task_struct *);
|
|
|
|
extern void __put_namespace(struct namespace *namespace);
|
2006-02-07 13:59:00 -07:00
|
|
|
extern struct namespace *dup_namespace(struct task_struct *, struct fs_struct *);
|
2005-04-16 16:20:36 -06:00
|
|
|
|
|
|
|
static inline void put_namespace(struct namespace *namespace)
|
|
|
|
{
|
2005-07-07 18:57:24 -06:00
|
|
|
if (atomic_dec_and_lock(&namespace->count, &vfsmount_lock))
|
|
|
|
/* releases vfsmount_lock */
|
2005-04-16 16:20:36 -06: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
|