From: Al Viro Date: Fri, 30 May 2014 15:39:02 +0000 (-0400) Subject: dcache.c: call ->d_prune() regardless of d_unhashed() X-Git-Tag: firefly_0821_release~176^2~3067^2~42 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=2926620145095ffb0350b2312ac9d0af8537796f;p=firefly-linux-kernel-4.4.55.git dcache.c: call ->d_prune() regardless of d_unhashed() the only in-tree instance checks d_unhashed() anyway, out-of-tree code can preserve the current behaviour by adding such check if they want it and we get an ability to use it in cases where we *want* to be notified of killing being inevitable before ->d_lock is dropped, whether it's unhashed or not. In particular, autofs would benefit from that. Signed-off-by: Al Viro --- diff --git a/fs/dcache.c b/fs/dcache.c index d8a77b1c3d52..21eee4c08e76 100644 --- a/fs/dcache.c +++ b/fs/dcache.c @@ -482,7 +482,7 @@ static void __dentry_kill(struct dentry *dentry) * inform the fs via d_prune that this dentry is about to be * unhashed and destroyed. */ - if ((dentry->d_flags & DCACHE_OP_PRUNE) && !d_unhashed(dentry)) + if (dentry->d_flags & DCACHE_OP_PRUNE) dentry->d_op->d_prune(dentry); if (dentry->d_flags & DCACHE_LRU_LIST) {