From mboxrd@z Thu Jan 1 00:00:00 1970 From: Al Viro Subject: Re: [PATCH 4/4] Allow unprivileged chroot when safe Date: Mon, 16 Jan 2012 20:26:04 +0000 Message-ID: <20120116202604.GO23916@ZenIV.linux.org.uk> References: <20120116200618.GN23916@ZenIV.linux.org.uk> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Cc: Casey Schaufler , Linus Torvalds , Jamie Lokier , Will Drewry , linux-kernel@vger.kernel.org, keescook@chromium.org, john.johansen@canonical.com, serge.hallyn@canonical.com, coreyb@linux.vnet.ibm.com, pmoore@redhat.com, eparis@redhat.com, djm@mindrot.org, segoon@openwall.com, rostedt@goodmis.org, jmorris@namei.org, scarybeasts@gmail.com, avi@redhat.com, penberg@cs.helsinki.fi, mingo@elte.hu, akpm@linux-foundation.org, khilman@ti.com, borislav.petkov@amd.com, amwang@redhat.com, oleg@redhat.com, ak@linux.intel.com, eric.dumazet@gmail.com, gregkh@suse.de, dhowells@redhat.com, daniel.lezcano@free.fr, linux-fsdevel@vger.kernel.org, linux-security-module@vger.kernel.org, olofj@chromium.org, mhalcrow@google.com, dlaor@redhat.com, corbet@lwn.net, alan@lxorguk.ukuu.org.uk To: Andy Lutomirski Return-path: Content-Disposition: inline In-Reply-To: Sender: linux-security-module-owner@vger.kernel.org List-Id: linux-fsdevel.vger.kernel.org On Mon, Jan 16, 2012 at 12:15:09PM -0800, Andy Lutomirski wrote: > The first approach I tried was (from memory -- may not compile at all > on any version) fs->root.mnt != fs->root.mnt->mnt_parent. That didn't > work. The issue is that on dracut-based distros, AFAICT, the root (in > the sense of the root of the tree of struct vfsmounts) is rootfs. The > apparent root (the filesystem containing /, /usr, etc) is mounted on > top of (rootfs)/. Dracut then does something with the effect of > chroot("/"). So you end up with the vfsmount that contains "/" not > being the actual root vfsmount. But there's nothing hidden by the > chroot -- even if fs->root.mnt pointed at rootfs, "/" would still > follow the mountpoint into the actual filesystem. That has nothing whatsoever to do with dracut. _Everything_ ends up that way; IOW, everything including init(8) runs chrooted into the final userland root. On any normal distro. Your test is complete BS - e.g. mount /dev/crap /mnt/blah mount /dev/garbage /mnt/blah chroot /mnt/blah will *NOT* be chrooted per your definition.