proc: Usable inode numbers for the namespace file descriptors.
authorEric W. Biederman <ebiederm@xmission.com>
Wed, 15 Jun 2011 17:21:48 +0000 (10:21 -0700)
committerEric W. Biederman <ebiederm@xmission.com>
Tue, 20 Nov 2012 12:19:49 +0000 (04:19 -0800)
commit98f842e675f96ffac96e6c50315790912b2812be
treeed4dee9a6e54e3443e9f3f1614c8a2fcf9b31e0a
parentbf056bfa80596a5d14b26b17276a56a0dcb080e5
proc: Usable inode numbers for the namespace file descriptors.

Assign a unique proc inode to each namespace, and use that
inode number to ensure we only allocate at most one proc
inode for every namespace in proc.

A single proc inode per namespace allows userspace to test
to see if two processes are in the same namespace.

This has been a long requested feature and only blocked because
a naive implementation would put the id in a global space and
would ultimately require having a namespace for the names of
namespaces, making migration and certain virtualization tricks
impossible.

We still don't have per superblock inode numbers for proc, which
appears necessary for application unaware checkpoint/restart and
migrations (if the application is using namespace file descriptors)
but that is now allowd by the design if it becomes important.

I have preallocated the ipc and uts initial proc inode numbers so
their structures can be statically initialized.

Signed-off-by: Eric W. Biederman <ebiederm@xmission.com>
18 files changed:
fs/mount.h
fs/namespace.c
fs/proc/namespaces.c
include/linux/ipc_namespace.h
include/linux/pid_namespace.h
include/linux/proc_fs.h
include/linux/user_namespace.h
include/linux/utsname.h
include/net/net_namespace.h
init/version.c
ipc/msgutil.c
ipc/namespace.c
kernel/pid.c
kernel/pid_namespace.c
kernel/user.c
kernel/user_namespace.c
kernel/utsname.c
net/core/net_namespace.c