diff options
author | Jan Blunck <jblunck@infradead.org> | 2010-02-24 07:25:35 -0500 |
---|---|---|
committer | Arnd Bergmann <arnd@arndb.de> | 2010-10-04 15:10:44 -0400 |
commit | 3e44f9f1dc19e2b8d4f7ca3b3c63e976b22ad372 (patch) | |
tree | 85e61adb1cb41d726cd8bb2300777c91676c1702 /fs | |
parent | 6841c05021236b8d394cc6c41aa6ae17623aef13 (diff) |
BKL: Remove BKL from ext2 filesystem
The BKL is still used in ext2_put_super(), ext2_fill_super(), ext2_sync_fs()
ext2_remount() and ext2_write_inode(). From these calls ext2_put_super(),
ext2_fill_super() and ext2_remount() are protected against each other by
the struct super_block s_umount rw semaphore. The call in ext2_write_inode()
could only protect the modification of the ext2_sb_info through
ext2_update_dynamic_rev() against concurrent ext2_sync_fs() or ext2_remount().
ext2_fill_super() and ext2_put_super() can be left out because you need a
valid filesystem reference in all three cases, which you do not have when
you are one of these functions.
If the BKL is only protecting the modification of the ext2_sb_info it can
safely be removed since this is protected by the struct ext2_sb_info s_lock.
Signed-off-by: Jan Blunck <jblunck@infradead.org>
Cc: Jan Kara <jack@suse.cz>
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Diffstat (limited to 'fs')
-rw-r--r-- | fs/ext2/super.c | 4 |
1 files changed, 0 insertions, 4 deletions
diff --git a/fs/ext2/super.c b/fs/ext2/super.c index f98c390caf1d..85df87d0f7b7 100644 --- a/fs/ext2/super.c +++ b/fs/ext2/super.c | |||
@@ -747,8 +747,6 @@ static int ext2_fill_super(struct super_block *sb, void *data, int silent) | |||
747 | __le32 features; | 747 | __le32 features; |
748 | int err; | 748 | int err; |
749 | 749 | ||
750 | lock_kernel(); | ||
751 | |||
752 | err = -ENOMEM; | 750 | err = -ENOMEM; |
753 | sbi = kzalloc(sizeof(*sbi), GFP_KERNEL); | 751 | sbi = kzalloc(sizeof(*sbi), GFP_KERNEL); |
754 | if (!sbi) | 752 | if (!sbi) |
@@ -1086,7 +1084,6 @@ static int ext2_fill_super(struct super_block *sb, void *data, int silent) | |||
1086 | if (ext2_setup_super (sb, es, sb->s_flags & MS_RDONLY)) | 1084 | if (ext2_setup_super (sb, es, sb->s_flags & MS_RDONLY)) |
1087 | sb->s_flags |= MS_RDONLY; | 1085 | sb->s_flags |= MS_RDONLY; |
1088 | ext2_write_super(sb); | 1086 | ext2_write_super(sb); |
1089 | unlock_kernel(); | ||
1090 | return 0; | 1087 | return 0; |
1091 | 1088 | ||
1092 | cantfind_ext2: | 1089 | cantfind_ext2: |
@@ -1112,7 +1109,6 @@ failed_sbi: | |||
1112 | kfree(sbi->s_blockgroup_lock); | 1109 | kfree(sbi->s_blockgroup_lock); |
1113 | kfree(sbi); | 1110 | kfree(sbi); |
1114 | failed_unlock: | 1111 | failed_unlock: |
1115 | unlock_kernel(); | ||
1116 | return ret; | 1112 | return ret; |
1117 | } | 1113 | } |
1118 | 1114 | ||