Re: [PATCH 1/6] Add a dentry op to handle automounting rather thanabusing follow_link() [ver #2]

From: Ian Kent
Date: Mon Jul 26 2010 - 11:23:11 EST


On Mon, 2010-07-26 at 15:19 +0100, David Howells wrote:
> Ian Kent <raven@xxxxxxxxxx> wrote:
>
> > > (4) Stops pathwalk at the automount point and returns that point in the fs
> > > tree if it decides not to automount rather than reporting ELOOP (see its
> > > use of EXDEV for this).
>
> Does it make autofs easier if d_op->d_automount() is allowed to return -EXDEV
> to request this? Then you can return it in Oz mode to allow the daemon to
> see/use the underlying mountpoint without recursing back into d_automount().

Yes, it's really useful.

>
> Ideally, the daemon would use AT_NO_AUTOMOUNT, but there's no way to pass that
> to sys_mount() or sys_umount().

The use of EXDEV, and if we had a way of saying we want a negative
dentry to trigger a mount, allows this mechanism to work for autofs
without any user space changes for direct and indirect mounts, at least
to match the current function.

Having said that though I've only just begun to test the various cases.

I know this was originally meant to deal with just the follow_link abuse
but the approach as it is appears to be able to resolve a long standing
deadlock bug autofs has with indirect mounts and affords a huge amount
of simplification to the autofs module code. I really hope we can work
out a suitable way to change the implementation to allow for negative
dentrys to trigger mounts. Of course it's quite possible I'll hit a snag
during testing but I hope not as I've spent a lot of time on alternate
approaches in the last few years.

Ian

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