linux-fsdevel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] vfs: Correctly set the dir i_mutex lockdep class
@ 2011-11-10  6:45 Tyler Hicks
  2011-11-10 14:33 ` Jan Kara
  2011-12-12 16:02 ` [PATCH][RESEND] " Tyler Hicks
  0 siblings, 2 replies; 6+ messages in thread
From: Tyler Hicks @ 2011-11-10  6:45 UTC (permalink / raw)
  To: Alexander Viro
  Cc: John Johansen, Jan Kara, Josh Boyer, Peter Zijlstra, Ingo Molnar,
	linux-fsdevel

9a7aa12f3911853a introduced additional logic around setting the i_mutex
lockdep class for directory inodes. The idea was that some filesystems
may want their own special lockdep class for different directory
inodes and calling unlock_new_inode() should not clobber one of
those special classes.

I believe that the added conditional, around the *negated* return value
of lockdep_match_class(), caused directory inodes to be placed in the
wrong lockdep class.

inode_init_always() sets the i_mutex lockdep class with i_mutex_key for
all inodes. If the filesystem did not change the class during inode
initialization, then the conditional mentioned above was false and the
directory inode was incorrectly left in the non-directory lockdep class.
If the filesystem did set a special lockdep class, then the conditional
mentioned above was true and that class was clobbered with
i_mutex_dir_key.

This patch removes the negation from the conditional so that the i_mutex
lockdep class is properly set for directory inodes. Special classes are
preserved and directory inodes with unmodified classes are set with
i_mutex_dir_key.

Signed-off-by: Tyler Hicks <tyhicks@canonical.com>
---
 fs/inode.c |    3 +--
 1 files changed, 1 insertions(+), 2 deletions(-)

diff --git a/fs/inode.c b/fs/inode.c
index ee4e66b..9d01a0d 100644
--- a/fs/inode.c
+++ b/fs/inode.c
@@ -855,8 +855,7 @@ void lockdep_annotate_inode_mutex_key(struct inode *inode)
 		struct file_system_type *type = inode->i_sb->s_type;
 
 		/* Set new key only if filesystem hasn't already changed it */
-		if (!lockdep_match_class(&inode->i_mutex,
-		    &type->i_mutex_key)) {
+		if (lockdep_match_class(&inode->i_mutex, &type->i_mutex_key)) {
 			/*
 			 * ensure nobody is actually holding i_mutex
 			 */
-- 
1.7.5.4


^ permalink raw reply related	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2012-01-20 18:40 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2011-11-10  6:45 [PATCH] vfs: Correctly set the dir i_mutex lockdep class Tyler Hicks
2011-11-10 14:33 ` Jan Kara
2011-11-10 15:28   ` Tyler Hicks
2011-11-17  8:35     ` Joel Becker
2011-12-12 16:02 ` [PATCH][RESEND] " Tyler Hicks
2012-01-20 18:39   ` [PATCH][BUGFIX][RESEND] " Tyler Hicks

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).