Re: [PATCH] private mounts

From: Ram
Date: Thu Apr 28 2005 - 14:43:01 EST


On Thu, 2005-04-28 at 12:20, Jamie Lokier wrote:
> Eric Van Hensbergen wrote:
> > > It's called /proc/NNN/root.
> > >
> > > So no new system calls are needed. A daemon to hand out per-user
> > > namespaces (or any other policy) can be written using existing
> > > kernels, and those namespaces can be joined using chroot.
> > >
> > > That's the theory anyway. It's always possible I misread the code (as
> > > I don't use namespaces and don't have tools handy to try them).
> > >
> >
> > Should have checked myself before posting my previous reply -- but
> > this doesn't seem to work. /proc/NNN/root is represented as a
> > symlink, but when you CLONE_NS and then try to look at another one of
> > your process' /proc/NNN/root the link doesn't seem to have a target
> > and you get permission denied on all accesses.
>
> I've looked at the code. Look in fs/proc/base.c (Linux 2.6.10),
> proc_root_link().
>
> I don't see anything there to prevent you from traversing to the
> mounts in the other namespace.
>
> So why is it failing? Any idea?

Since you are traversing a symlink, you will be traversing the symlink
in the context of traversing process's namespace.

If process 'x' is traversing /proc/y/root , the lookup for the root
dentry will happen in the context of process x's namespace, and not
process y's namespace. Hence process 'x' wont really get into
the namespace of the process y.

RP

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/