diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2019-07-19 10:42:02 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2019-07-19 10:42:02 -0700 | 
| commit | 933a90bf4f3505f8ec83bda21a3c7d70d7c2b426 (patch) | |
| tree | ca81c209000a15670e3582760ad9bae1a9cde215 /fs/proc/root.c | |
| parent | 5f4fc6d440d77a2cf74fe4ea56955674ac7e35e7 (diff) | |
| parent | 037f11b4752f717201143a1dc5d6acf3cb71ddfa (diff) | |
Merge branch 'work.mount0' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs
Pull vfs mount updates from Al Viro:
 "The first part of mount updates.
  Convert filesystems to use the new mount API"
* 'work.mount0' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs: (63 commits)
  mnt_init(): call shmem_init() unconditionally
  constify ksys_mount() string arguments
  don't bother with registering rootfs
  init_rootfs(): don't bother with init_ramfs_fs()
  vfs: Convert smackfs to use the new mount API
  vfs: Convert selinuxfs to use the new mount API
  vfs: Convert securityfs to use the new mount API
  vfs: Convert apparmorfs to use the new mount API
  vfs: Convert openpromfs to use the new mount API
  vfs: Convert xenfs to use the new mount API
  vfs: Convert gadgetfs to use the new mount API
  vfs: Convert oprofilefs to use the new mount API
  vfs: Convert ibmasmfs to use the new mount API
  vfs: Convert qib_fs/ipathfs to use the new mount API
  vfs: Convert efivarfs to use the new mount API
  vfs: Convert configfs to use the new mount API
  vfs: Convert binfmt_misc to use the new mount API
  convenience helper: get_tree_single()
  convenience helper get_tree_nodev()
  vfs: Kill sget_userns()
  ...
Diffstat (limited to 'fs/proc/root.c')
| -rw-r--r-- | fs/proc/root.c | 7 | 
1 files changed, 3 insertions, 4 deletions
| diff --git a/fs/proc/root.c b/fs/proc/root.c index 522199e9525e..33f72d1b92cc 100644 --- a/fs/proc/root.c +++ b/fs/proc/root.c @@ -157,8 +157,6 @@ static int proc_get_tree(struct fs_context *fc)  {  	struct proc_fs_context *ctx = fc->fs_private; -	put_user_ns(fc->user_ns); -	fc->user_ns = get_user_ns(ctx->pid_ns->user_ns);  	fc->s_fs_info = ctx->pid_ns;  	return vfs_get_super(fc, vfs_get_keyed_super, proc_fill_super);  } @@ -167,8 +165,7 @@ static void proc_fs_context_free(struct fs_context *fc)  {  	struct proc_fs_context *ctx = fc->fs_private; -	if (ctx->pid_ns) -		put_pid_ns(ctx->pid_ns); +	put_pid_ns(ctx->pid_ns);  	kfree(ctx);  } @@ -188,6 +185,8 @@ static int proc_init_fs_context(struct fs_context *fc)  		return -ENOMEM;  	ctx->pid_ns = get_pid_ns(task_active_pid_ns(current)); +	put_user_ns(fc->user_ns); +	fc->user_ns = get_user_ns(ctx->pid_ns->user_ns);  	fc->fs_private = ctx;  	fc->ops = &proc_fs_context_ops;  	return 0; | 
