On Sat, Mar 09, 2019 at 09:00:58AM -0800, Linus Torvalds wrote: > On Wed, Mar 6, 2019 at 11:14 AM Aleksa Sarai <cyphar@xxxxxxxxxx> wrote: > > > > This is a refresh of Al's AT_NO_JUMPS patchset[1] (which was a variation > > on David Drysdale's O_BENEATH patchset[2], which in turn was based on > > the Capsicum project[3]). Input from Linus and Andy in the AT_NO_JUMPS > > thread[4] determined most of the API changes made in this refresh. > > So I still think this is likely a good idea... BUT. > > The absolutely huge BUT here is "are user space people actually > interested in using it, or do they already have other solutions to > this anyway?" > > The intent is obviously to make it easy and cheap to to the simple > pathname lookup in a controlled manner, and then let user space fall > back to "let's check things much more carefully" for paths that look > iffy. > > But maybe the people who care already have their own solutions, and/or > need something more anyway (ie samba looking up all names in user > space first _anyway_ due to ICASE issues or whatever)? > > So this is easy and straightforward to do in the kernel, and it > _feels_ like something that can be useful, and I'm not all that > concerned about the maintenance overhead either because of the trivial > semantics. > > But I'd still like to actually have some user space person say "yeah, > we'd actually use this" since quite often non-portable solutions don't So if I may put my user space hat on. I maintain a container runtime LXC and Aleksa maintains runC another container runtime. We both have (horrible) code in our respective projects that tries to ensure that a given path doesn't escape a given dirfd. Symlink resolution, and then using crazy things such as mounting through /proc/<pid>/fd/<nr> etc. pp. It works and we have been living with this state for a long time. But we would both definitely use this feature. We've been discussing this and had this on our wishlist for quite a long time and it would be good to have this patchset. Aside from that I want to point out that it is non-trivial to do this in user space. The original code for restricted path resolution in our codebase was done and is maintained by people like Serge and myself who are involved in kernel development and it honestly required some pretty intricate knowledge. I think having this feature work out of the box in the kernel is a great win for quite a lot projects. Definitely for LXC and runC. Christian