-----BEGIN PGP SIGNED MESSAGE----- Hash: SHA1 Ian Kent wrote: > On Thu, 2007-04-12 at 02:00 +0800, Ian Kent wrote: >> On Thu, 2007-04-12 at 01:49 +0800, Ian Kent wrote: >>> On Wed, 2007-04-11 at 11:05 -0400, Jeff Mahoney wrote: >>>> Commit f50b6f8691cae2e0064c499dd3ef3f31142987f0 introduced a >>>> race in autofs4 between autofs_lookup_unhashed() and >>>> autofs_dentry_release(). >>>> >>>> autofs_dentry_release() ends up clearing the ->dentry and ->inode >>>> members of autofs_info before removing it from the rehash list. The >>>> list is protected by the rehash lock in both functions, but >>>> since autofs_dentry_release() starts tearing the autofs_info struct >>>> down before removing it from the list, autofs_lookup_unhashed() can >>>> get a autofs_info with a NULL dentry. >>>> >>>> This patch moves the clearing of ->dentry and ->inode after the removal >>>> from the rehash list. >>> Oh .. excellent, I had a bug report but I just couldn't see it for >>> looking. >> Maybe I've been a bit hasty with the celebration. >> It looks like I've got a bigger locking problem here. >> If autofs4_dentry_release waits on the rehash lock and >> autofs4_lookup_unhashed reclaims it then the info struct and the dentry >> go away unconditionally as the release is called just prior to freeing >> the dentry memory, right?. > > No I'm wrong, dentry_iput holds the dcache locks till it sets d_inode to > NULL, the point of the d_inode check in autofs4_lookup_unhashed. > > My day is still made. >
Ok, that was quick. I thought it was ok, but was about to dig back in to make sure. :) - -Jeff - -- Jeff Mahoney SUSE Labs -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.5 (GNU/Linux) Comment: Using GnuPG with SUSE - http://enigmail.mozdev.org iD8DBQFGHSVMLPWxlyuTD7IRArOcAKCGwXJaqObc3ee3W810zv5CU2h/MgCfbLUd 4dR++d9OFimkdWGYcmJvWlE= =+Tlm -----END PGP SIGNATURE----- - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/

