diff options
| -rw-r--r-- | fs/ext4/super.c | 2 | ||||
| -rw-r--r-- | fs/super.c | 4 |
2 files changed, 3 insertions, 3 deletions
diff --git a/fs/ext4/super.c b/fs/ext4/super.c index c7b8f8d9b7a8..0d3034c5e8a4 100644 --- a/fs/ext4/super.c +++ b/fs/ext4/super.c | |||
| @@ -576,6 +576,7 @@ static void ext4_put_super(struct super_block *sb) | |||
| 576 | struct ext4_super_block *es = sbi->s_es; | 576 | struct ext4_super_block *es = sbi->s_es; |
| 577 | int i, err; | 577 | int i, err; |
| 578 | 578 | ||
| 579 | lock_super(sb); | ||
| 579 | if (sb->s_dirt) | 580 | if (sb->s_dirt) |
| 580 | ext4_write_super(sb); | 581 | ext4_write_super(sb); |
| 581 | 582 | ||
| @@ -645,7 +646,6 @@ static void ext4_put_super(struct super_block *sb) | |||
| 645 | unlock_super(sb); | 646 | unlock_super(sb); |
| 646 | kobject_put(&sbi->s_kobj); | 647 | kobject_put(&sbi->s_kobj); |
| 647 | wait_for_completion(&sbi->s_kobj_unregister); | 648 | wait_for_completion(&sbi->s_kobj_unregister); |
| 648 | lock_super(sb); | ||
| 649 | lock_kernel(); | 649 | lock_kernel(); |
| 650 | kfree(sbi->s_blockgroup_lock); | 650 | kfree(sbi->s_blockgroup_lock); |
| 651 | kfree(sbi); | 651 | kfree(sbi); |
diff --git a/fs/super.c b/fs/super.c index 49f670cb9a83..54fd331f0cab 100644 --- a/fs/super.c +++ b/fs/super.c | |||
| @@ -304,7 +304,7 @@ void generic_shutdown_super(struct super_block *sb) | |||
| 304 | if (sb->s_root) { | 304 | if (sb->s_root) { |
| 305 | shrink_dcache_for_umount(sb); | 305 | shrink_dcache_for_umount(sb); |
| 306 | sync_filesystem(sb); | 306 | sync_filesystem(sb); |
| 307 | lock_super(sb); | 307 | get_fs_excl(); |
| 308 | sb->s_flags &= ~MS_ACTIVE; | 308 | sb->s_flags &= ~MS_ACTIVE; |
| 309 | 309 | ||
| 310 | /* bad name - it should be evict_inodes() */ | 310 | /* bad name - it should be evict_inodes() */ |
| @@ -322,7 +322,7 @@ void generic_shutdown_super(struct super_block *sb) | |||
| 322 | } | 322 | } |
| 323 | 323 | ||
| 324 | unlock_kernel(); | 324 | unlock_kernel(); |
| 325 | unlock_super(sb); | 325 | put_fs_excl(); |
| 326 | } | 326 | } |
| 327 | spin_lock(&sb_lock); | 327 | spin_lock(&sb_lock); |
| 328 | /* should be initialized for __put_super_and_need_restart() */ | 328 | /* should be initialized for __put_super_and_need_restart() */ |
