cregit-Linux how code gets into the kernel

Release 4.12 include/linux/user_namespace.h

Directory: include/linux
#ifndef _LINUX_USER_NAMESPACE_H

#define _LINUX_USER_NAMESPACE_H

#include <linux/kref.h>
#include <linux/nsproxy.h>
#include <linux/ns_common.h>
#include <linux/sched.h>
#include <linux/workqueue.h>
#include <linux/rwsem.h>
#include <linux/sysctl.h>
#include <linux/err.h>


#define UID_GID_MAP_MAX_EXTENTS 5


struct uid_gid_map {	/* 64 bytes -- 1 cache line */
	
u32 nr_extents;
	
struct uid_gid_extent {
		
u32 first;
		
u32 lower_first;
		
u32 count;
	
} extent[UID_GID_MAP_MAX_EXTENTS];
};


#define USERNS_SETGROUPS_ALLOWED 1UL


#define USERNS_INIT_FLAGS USERNS_SETGROUPS_ALLOWED

struct ucounts;


enum ucount_type {
	
UCOUNT_USER_NAMESPACES,
	
UCOUNT_PID_NAMESPACES,
	
UCOUNT_UTS_NAMESPACES,
	
UCOUNT_IPC_NAMESPACES,
	
UCOUNT_NET_NAMESPACES,
	
UCOUNT_MNT_NAMESPACES,
	
UCOUNT_CGROUP_NAMESPACES,
#ifdef CONFIG_INOTIFY_USER
	
UCOUNT_INOTIFY_INSTANCES,
	
UCOUNT_INOTIFY_WATCHES,
#endif
	
UCOUNT_COUNTS,
};


struct user_namespace {
	
struct uid_gid_map	uid_map;
	
struct uid_gid_map	gid_map;
	
struct uid_gid_map	projid_map;
	
atomic_t		count;
	
struct user_namespace	*parent;
	
int			level;
	
kuid_t			owner;
	
kgid_t			group;
	
struct ns_common	ns;
	
unsigned long		flags;

	/* Register of per-UID persistent keyrings for this namespace */
#ifdef CONFIG_PERSISTENT_KEYRINGS
	
struct key		*persistent_keyring_register;
	
struct rw_semaphore	persistent_keyring_register_sem;
#endif
	
struct work_struct	work;
#ifdef CONFIG_SYSCTL
	
struct ctl_table_set	set;
	
struct ctl_table_header *sysctls;
#endif
	
struct ucounts		*ucounts;
	
int ucount_max[UCOUNT_COUNTS];
};


struct ucounts {
	
struct hlist_node node;
	
struct user_namespace *ns;
	
kuid_t uid;
	
int count;
	
atomic_t ucount[UCOUNT_COUNTS];
};

extern struct user_namespace init_user_ns;

bool setup_userns_sysctls(struct user_namespace *ns);
void retire_userns_sysctls(struct user_namespace *ns);
struct ucounts *inc_ucount(struct user_namespace *ns, kuid_t uid, enum ucount_type type);
void dec_ucount(struct ucounts *ucounts, enum ucount_type type);

#ifdef CONFIG_USER_NS


static inline struct user_namespace *get_user_ns(struct user_namespace *ns) { if (ns) atomic_inc(&ns->count); return ns; }

Contributors

PersonTokensPropCommitsCommitProp
Cédric Le Goater2793.10%150.00%
Eric W. Biedermann26.90%150.00%
Total29100.00%2100.00%

extern int create_user_ns(struct cred *new); extern int unshare_userns(unsigned long unshare_flags, struct cred **new_cred); extern void __put_user_ns(struct user_namespace *ns);
static inline void put_user_ns(struct user_namespace *ns) { if (ns && atomic_dec_and_test(&ns->count)) __put_user_ns(ns); }

Contributors

PersonTokensPropCommitsCommitProp
Cédric Le Goater2172.41%133.33%
Eric W. Biedermann827.59%266.67%
Total29100.00%3100.00%

struct seq_operations; extern const struct seq_operations proc_uid_seq_operations; extern const struct seq_operations proc_gid_seq_operations; extern const struct seq_operations proc_projid_seq_operations; extern ssize_t proc_uid_map_write(struct file *, const char __user *, size_t, loff_t *); extern ssize_t proc_gid_map_write(struct file *, const char __user *, size_t, loff_t *); extern ssize_t proc_projid_map_write(struct file *, const char __user *, size_t, loff_t *); extern ssize_t proc_setgroups_write(struct file *, const char __user *, size_t, loff_t *); extern int proc_setgroups_show(struct seq_file *m, void *v); extern bool userns_may_setgroups(const struct user_namespace *ns); extern bool current_in_userns(const struct user_namespace *target_ns); struct ns_common *ns_get_owner(struct ns_common *ns); #else
static inline struct user_namespace *get_user_ns(struct user_namespace *ns) { return &init_user_ns; }

Contributors

PersonTokensPropCommitsCommitProp
Cédric Le Goater18100.00%1100.00%
Total18100.00%1100.00%


static inline int create_user_ns(struct cred *new) { return -EINVAL; }

Contributors

PersonTokensPropCommitsCommitProp
Cédric Le Goater956.25%133.33%
Serge E. Hallyn743.75%266.67%
Total16100.00%3100.00%


static inline int unshare_userns(unsigned long unshare_flags, struct cred **new_cred) { if (unshare_flags & CLONE_NEWUSER) return -EINVAL; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Eric W. Biedermann30100.00%1100.00%
Total30100.00%1100.00%


static inline void put_user_ns(struct user_namespace *ns) { }

Contributors

PersonTokensPropCommitsCommitProp
Cédric Le Goater11100.00%1100.00%
Total11100.00%1100.00%


static inline bool userns_may_setgroups(const struct user_namespace *ns) { return true; }

Contributors

PersonTokensPropCommitsCommitProp
Eric W. Biedermann16100.00%1100.00%
Total16100.00%1100.00%


static inline bool current_in_userns(const struct user_namespace *target_ns) { return true; }

Contributors

PersonTokensPropCommitsCommitProp
Seth Forshee16100.00%1100.00%
Total16100.00%1100.00%


static inline struct ns_common *ns_get_owner(struct ns_common *ns) { return ERR_PTR(-EPERM); }

Contributors

PersonTokensPropCommitsCommitProp
Andrey Vagin21100.00%1100.00%
Total21100.00%1100.00%

#endif #endif /* _LINUX_USER_H */

Overall Contributors

PersonTokensPropCommitsCommitProp
Eric W. Biedermann38960.59%2261.11%
Cédric Le Goater13420.87%12.78%
Andrey Vagin324.98%12.78%
Seth Forshee274.21%12.78%
David Howells162.49%25.56%
Serge E. Hallyn142.18%25.56%
Nikolay Borisov91.40%12.78%
Ingo Molnar91.40%38.33%
Al Viro60.93%12.78%
Oleg Nesterov30.47%12.78%
Fabian Frederick30.47%12.78%
Total642100.00%36100.00%
Directory: include/linux
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.