On Sat, Sep 28, 2013 at 11:06 PM, Al Viro <viro@xxxxxxxxxxxxxxxxxx> wrote: > > Sigh... Looks like there's a lot of fun in shrink_dcache_for_umount() - > at the very least, it needs to bump ->d_seq on everything, because with > that change we *can* walk into a filesystem in the middle of that. > We obviously don't want to slap rcu_barrier() into the final mntput() - I have to say, that when I was working with the dcache lockref code, I absolutely _detested_ the magical shrink_dcache_for_umount() code that violated all the locking rules. So I actually wouldn't mind at all if that was all forced to follow all the same rules that the live filesystem code is forced to follow. Yes, yes, it's going to slow things down, but it's not like umount() is _that_ performance critical. And I think the whole "let's ignore locking rules" actually comes from back when we had one global dcache_lock: we used to have batching in order to not hold the dcache_lock over long periods, and then it got converted to the per-dentry locking, and then that got removed entirely with the whole RCU lookup etc. So I would be *entirely* ok with having shrink_dcache_for_umount_subtree() take the d_lock on the dentry as it shrinks it etc etc. Linus -- 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