From mboxrd@z Thu Jan 1 00:00:00 1970 From: John Johansen Subject: Re: [git pull] apparmor fix for __d_path() misuse Date: Tue, 06 Dec 2011 14:19:08 -0800 Message-ID: <4EDE94DC.8010106@canonical.com> References: <20111206154854.GH2203@ZenIV.linux.org.uk> <20111206205346.GK2203@ZenIV.linux.org.uk> Mime-Version: 1.0 Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 7bit Cc: Al Viro , linux-kernel@vger.kernel.org, linux-fsdevel@vger.kernel.org To: Linus Torvalds Return-path: In-Reply-To: Sender: linux-kernel-owner@vger.kernel.org List-Id: linux-fsdevel.vger.kernel.org On 12/06/2011 01:07 PM, Linus Torvalds wrote: > On Tue, Dec 6, 2011 at 12:53 PM, Al Viro wrote: >> >> The trouble is, might very well stop *NOT* at the global root. Consider >> a race with umount -l; we have no way to tell "it had been outside of >> chroot jail" from "it had walked up to the place where ->mnt_parent had >> been already reset, sorry, no idea what it was". > > Sure, but you made that case return NULL already as part of the "no > bastard" case, didn't you? > > That part of the patch looked fine. > > It was just the extra convolutions around 'bastard' that seemed to be > over-designed, and made for just a single use that seems very > peripheral anyway. > it is, and the plan is to not need the bastard even. What apparmor should be doing is lazy labeling the live objects, and anything that is disconnected is evaluated based on the previous labeling. This will also remove its use of passing root = { NULL, NULL } to __d_path. > Apart from AppArmor, afaik nobody even really cared where they ended > up, and even AppArmor really didn't want to know - it just had this > totally crazy special case about "/sys". > right it only cared about where it endup in the cases of reaching the fs->root or own_mnt. The sys case really is just broken, I started looking at it when Al poked me and said wtf, and have been looking at ways to remove it. Right now we could drop the bastard parameter and passing root = { NULL, NULL } __d_path and only break in the case of some chroot situations, which is not the standard use case anyways. We are willing to drop support for this, and it can be picked backup when the labeling patch is done.