Re: [PATCH] Fix d_path for lazy unmounts

From: Linus Torvalds
Date: Wed Feb 14 2007 - 10:38:41 EST




On Wed, 14 Feb 2007, Andreas Gruenbacher wrote:
>
> Mountpoints are reported relative to the chroot if they are reachable from the
> chroot, and relative to the namespace they are defined in otherwise. This is
> big nonsense, but it's unclear to me how to best fix it:

Well, it's also what a traditional "pwd" implementation would do, so it's
not "nonsense" in that sense.

> - don't report unreachable mount points,
> - somehow indicate which mountpoints are reachable and which are not,
> like by prepending a question flag?

We could prepend another '/' (so that you'd have a path that starts with
"//"). That's still a legal path, but it's also somethign that even POSIX
says is valid to mean something else (eg "//ftp/.." or "//socket/.." to
escape into another namespace).

But the fact is, some things just want a path. And it's generally *better*
to get them a

- path that looks ok and starts from '/' than it is to give them
something that looks strange and doesn't start from root (because the
latter gives many many more possible attack vectors: if somebody
actually looks up the path, a bad user can much more easily fake a
relative path than fake an absolute one).

- the path we've historically always given them.

> What's the point in reporting the rootfs at all -- it's never reachable to an
> ordinary process?

All the paths are generally useful for USER INFORMATION. That's the
primary use of paths for anything but "getcwd()". And the primary use for
"getcwd()" is to do the same thing that any traditional cwd implementation
has done, except faster (and _possibly_ better, but compatibility is more
important than extensions - so the "better" is mainly an issue about
non-readable or non-executable path component that we can show, and
about being able to tell _how_ you got to a point that has multiple ways
of getting there).

Linus
-
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/