Commit 001869c3 authored by Linus Torvalds's avatar Linus Torvalds Committed by Greg Kroah-Hartman

dcache: add missing lockdep annotation

commit 9f12600f 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 046b961b ("shrink_dentry_list(): take parent's
->d_lock earlier").
Reported-and-tested-by: default avatarJosh Boyer <jwboyer@fedoraproject.org>
Cc: Al Viro <viro@zeniv.linux.org.uk>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent b004c3a7
...@@ -551,7 +551,7 @@ static inline struct dentry *lock_parent(struct dentry *dentry) ...@@ -551,7 +551,7 @@ static inline struct dentry *lock_parent(struct dentry *dentry)
} }
rcu_read_unlock(); rcu_read_unlock();
if (parent != dentry) if (parent != dentry)
spin_lock(&dentry->d_lock); spin_lock_nested(&dentry->d_lock, DENTRY_D_LOCK_NESTED);
else else
parent = NULL; parent = NULL;
return parent; return parent;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment