diff options
Diffstat (limited to 'include/linux/user_namespace.h')
| -rw-r--r-- | include/linux/user_namespace.h | 20 | 
1 files changed, 15 insertions, 5 deletions
diff --git a/include/linux/user_namespace.h b/include/linux/user_namespace.h index 95142cae446..4ce00932493 100644 --- a/include/linux/user_namespace.h +++ b/include/linux/user_namespace.h @@ -21,10 +21,11 @@ struct user_namespace {  	struct uid_gid_map	uid_map;  	struct uid_gid_map	gid_map;  	struct uid_gid_map	projid_map; -	struct kref		kref; +	atomic_t		count;  	struct user_namespace	*parent;  	kuid_t			owner;  	kgid_t			group; +	unsigned int		proc_inum;  };  extern struct user_namespace init_user_ns; @@ -34,17 +35,18 @@ extern struct user_namespace init_user_ns;  static inline struct user_namespace *get_user_ns(struct user_namespace *ns)  {  	if (ns) -		kref_get(&ns->kref); +		atomic_inc(&ns->count);  	return ns;  }  extern int create_user_ns(struct cred *new); -extern void free_user_ns(struct kref *kref); +extern int unshare_userns(unsigned long unshare_flags, struct cred **new_cred); +extern void free_user_ns(struct user_namespace *ns);  static inline void put_user_ns(struct user_namespace *ns)  { -	if (ns) -		kref_put(&ns->kref, free_user_ns); +	if (ns && atomic_dec_and_test(&ns->count)) +		free_user_ns(ns);  }  struct seq_operations; @@ -66,6 +68,14 @@ static inline int create_user_ns(struct cred *new)  	return -EINVAL;  } +static inline int unshare_userns(unsigned long unshare_flags, +				 struct cred **new_cred) +{ +	if (unshare_flags & CLONE_NEWUSER) +		return -EINVAL; +	return 0; +} +  static inline void put_user_ns(struct user_namespace *ns)  {  }  |