diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2013-09-07 14:35:32 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2013-09-07 14:35:32 -0700 | 
| commit | c7c4591db64dbd1e504bc4e2806d7ef290a3c81b (patch) | |
| tree | a2fb124f9760eec668d20541383e762822d7cc7b /fs/proc/root.c | |
| parent | 11c7b03d42a847db90862d0f9d8be6ce9b2f0553 (diff) | |
| parent | c7b96acf1456ef127fef461fcfedb54b81fecfbb (diff) | |
Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/ebiederm/user-namespace
Pull namespace changes from Eric Biederman:
 "This is an assorted mishmash of small cleanups, enhancements and bug
  fixes.
  The major theme is user namespace mount restrictions.  nsown_capable
  is killed as it encourages not thinking about details that need to be
  considered.  A very hard to hit pid namespace exiting bug was finally
  tracked and fixed.  A couple of cleanups to the basic namespace
  infrastructure.
  Finally there is an enhancement that makes per user namespace
  capabilities usable as capabilities, and an enhancement that allows
  the per userns root to nice other processes in the user namespace"
* 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/ebiederm/user-namespace:
  userns:  Kill nsown_capable it makes the wrong thing easy
  capabilities: allow nice if we are privileged
  pidns: Don't have unshare(CLONE_NEWPID) imply CLONE_THREAD
  userns: Allow PR_CAPBSET_DROP in a user namespace.
  namespaces: Simplify copy_namespaces so it is clear what is going on.
  pidns: Fix hang in zap_pid_ns_processes by sending a potentially extra wakeup
  sysfs: Restrict mounting sysfs
  userns: Better restrictions on when proc and sysfs can be mounted
  vfs: Don't copy mount bind mounts of /proc/<pid>/ns/mnt between namespaces
  kernel/nsproxy.c: Improving a snippet of code.
  proc: Restrict mounting the proc filesystem
  vfs: Lock in place mounts from more privileged users
Diffstat (limited to 'fs/proc/root.c')
| -rw-r--r-- | fs/proc/root.c | 6 | 
1 files changed, 5 insertions, 1 deletions
| diff --git a/fs/proc/root.c b/fs/proc/root.c index e0a790da726d..87dbcbef7fe4 100644 --- a/fs/proc/root.c +++ b/fs/proc/root.c @@ -110,7 +110,11 @@ static struct dentry *proc_mount(struct file_system_type *fs_type,  		ns = task_active_pid_ns(current);  		options = data; -		if (!current_user_ns()->may_mount_proc) +		if (!capable(CAP_SYS_ADMIN) && !fs_fully_visible(fs_type)) +			return ERR_PTR(-EPERM); + +		/* Does the mounter have privilege over the pid namespace? */ +		if (!ns_capable(ns->user_ns, CAP_SYS_ADMIN))  			return ERR_PTR(-EPERM);  	} | 
