On Tue, 2008-06-03 at 11:52 +0100, Al Viro wrote: > On Tue, Jun 03, 2008 at 12:45:33PM +0200, Miklos Szeredi wrote: > > > I think it must be autofs4 doing something weird. Like this in > > autofs4_lookup_unhashed(): > > > > /* > > * Make the rehashed dentry negative so the VFS > > * behaves as it should. > > */ > > if (inode) { > > dentry->d_inode = NULL; > > Lovely. If we ever step into that with somebody else (no matter who) > holding a reference to that dentry, we are certainly well and truly > buggered. It's not just mount(2) - everything in the tree assumes that > holding a reference to positive dentry guarantees that it remains > positive. The intent here is that, the dentry above is unhashed at this point, and if hasn't been reclaimed by the VFS, it is made negative and replaces the unhashed negative dentry passed to ->lookup(). The reference count is incremented to account for the reference held by the path walk. What am I doing wrong here? Ian -- To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html