take the targets of /proc/*/ns/* symlinks to separate fs
authorAl Viro <viro@zeniv.linux.org.uk>
Sat, 1 Nov 2014 14:57:28 +0000 (10:57 -0400)
committerAl Viro <viro@zeniv.linux.org.uk>
Thu, 11 Dec 2014 02:30:20 +0000 (21:30 -0500)
commite149ed2b805fefdccf7ccdfc19eca22fdd4514ac
tree8c9cd88deff8c7309ca2acb8d4cb475aaca47b14
parentf77c80142e1afe6d5c16975ca5d7d1fc324b16f9
take the targets of /proc/*/ns/* symlinks to separate fs

New pseudo-filesystem: nsfs.  Targets of /proc/*/ns/* live there now.
It's not mountable (not even registered, so it's not in /proc/filesystems,
etc.).  Files on it *are* bindable - we explicitly permit that in do_loopback().

This stuff lives in fs/nsfs.c now; proc_ns_fget() moved there as well.
get_proc_ns() is a macro now (it's simply returning ->i_private; would
have been an inline, if not for header ordering headache).
proc_ns_inode() is an ex-parrot.  The interface used in procfs is
ns_get_path(path, task, ops) and ns_get_name(buf, size, task, ops).

Dentries and inodes are never hashed; a non-counting reference to dentry
is stashed in ns_common (removed by ->d_prune()) and reused by ns_get_path()
if present.  See ns_get_path()/ns_prune_dentry/nsfs_evict() for details
of that mechanism.

As the result, proc_ns_follow_link() has stopped poking in nd->path.mnt;
it does nd_jump_link() on a consistent <vfsmount,dentry> pair it gets
from ns_get_path().

Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
fs/Makefile
fs/internal.h
fs/namespace.c
fs/nsfs.c [new file with mode: 0644]
fs/proc/inode.c
fs/proc/namespaces.c
include/linux/ns_common.h
include/linux/proc_ns.h
include/uapi/linux/magic.h
init/main.c