summaryrefslogtreecommitdiff
path: root/fs
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2014-05-31 09:13:21 -0700
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2016-03-03 15:06:46 -0800
commit001869c34bdefa35f021f2633ed37122cfd3aa2d (patch)
treed6b9cb0ace986259bd755c1b857b2db005118019 /fs
parentb004c3a7f5ee27001a39892874c733d23b7ecbc6 (diff)
downloadlwn-001869c34bdefa35f021f2633ed37122cfd3aa2d.tar.gz
lwn-001869c34bdefa35f021f2633ed37122cfd3aa2d.zip
dcache: add missing lockdep annotation
commit 9f12600fe425bc28f0ccba034a77783c09c15af4 upstream. lock_parent() very much on purpose does nested locking of dentries, and is careful to maintain the right order (lock parent first). But because it didn't annotate the nested locking order, lockdep thought it might be a deadlock on d_lock, and complained. Add the proper annotation for the inner locking of the child dentry to make lockdep happy. Introduced by commit 046b961b45f9 ("shrink_dentry_list(): take parent's ->d_lock earlier"). Reported-and-tested-by: Josh Boyer <jwboyer@fedoraproject.org> Cc: Al Viro <viro@zeniv.linux.org.uk> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'fs')
-rw-r--r--fs/dcache.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/dcache.c b/fs/dcache.c
index 7374c578154d..40d474129c1c 100644
--- a/fs/dcache.c
+++ b/fs/dcache.c
@@ -551,7 +551,7 @@ again:
}
rcu_read_unlock();
if (parent != dentry)
- spin_lock(&dentry->d_lock);
+ spin_lock_nested(&dentry->d_lock, DENTRY_D_LOCK_NESTED);
else
parent = NULL;
return parent;