diff options
author | Al Viro <viro@zeniv.linux.org.uk> | 2009-05-05 22:10:44 -0400 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2009-06-11 21:36:07 -0400 |
commit | a9e220f8322e2b0e0b8903fe00265461cffad3f0 (patch) | |
tree | b3be7d58b8eb9fd810636223f0458191ec1b9d75 /fs/ext4/super.c | |
parent | 62c6943b4b1e818aea60c11c5a68a50785b83119 (diff) |
No need to do lock_super() for exclusion in generic_shutdown_super()
We can't run into contention on it. All other callers of lock_super()
either hold s_umount (and we have it exclusive) or hold an active
reference to superblock in question, which prevents the call of
generic_shutdown_super() while the reference is held. So we can
replace lock_super(s) with get_fs_excl() in generic_shutdown_super()
(and corresponding change for unlock_super(), of course).
Since ext4 expects s_lock held for its put_super, take lock_super()
into it. The rest of filesystems do not care at all.
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'fs/ext4/super.c')
-rw-r--r-- | fs/ext4/super.c | 2 |
1 files changed, 1 insertions, 1 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); |