aboutsummaryrefslogtreecommitdiffstats
path: root/fs/ext2
diff options
context:
space:
mode:
Diffstat (limited to 'fs/ext2')
-rw-r--r--fs/ext2/super.c10
1 files changed, 8 insertions, 2 deletions
diff --git a/fs/ext2/super.c b/fs/ext2/super.c
index 1ec602673ea8..f98c390caf1d 100644
--- a/fs/ext2/super.c
+++ b/fs/ext2/super.c
@@ -747,15 +747,18 @@ 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 sbi = kzalloc(sizeof(*sbi), GFP_KERNEL); 753 sbi = kzalloc(sizeof(*sbi), GFP_KERNEL);
751 if (!sbi) 754 if (!sbi)
752 return -ENOMEM; 755 goto failed_unlock;
753 756
754 sbi->s_blockgroup_lock = 757 sbi->s_blockgroup_lock =
755 kzalloc(sizeof(struct blockgroup_lock), GFP_KERNEL); 758 kzalloc(sizeof(struct blockgroup_lock), GFP_KERNEL);
756 if (!sbi->s_blockgroup_lock) { 759 if (!sbi->s_blockgroup_lock) {
757 kfree(sbi); 760 kfree(sbi);
758 return -ENOMEM; 761 goto failed_unlock;
759 } 762 }
760 sb->s_fs_info = sbi; 763 sb->s_fs_info = sbi;
761 sbi->s_sb_block = sb_block; 764 sbi->s_sb_block = sb_block;
@@ -1083,6 +1086,7 @@ static int ext2_fill_super(struct super_block *sb, void *data, int silent)
1083 if (ext2_setup_super (sb, es, sb->s_flags & MS_RDONLY)) 1086 if (ext2_setup_super (sb, es, sb->s_flags & MS_RDONLY))
1084 sb->s_flags |= MS_RDONLY; 1087 sb->s_flags |= MS_RDONLY;
1085 ext2_write_super(sb); 1088 ext2_write_super(sb);
1089 unlock_kernel();
1086 return 0; 1090 return 0;
1087 1091
1088cantfind_ext2: 1092cantfind_ext2:
@@ -1107,6 +1111,8 @@ failed_sbi:
1107 sb->s_fs_info = NULL; 1111 sb->s_fs_info = NULL;
1108 kfree(sbi->s_blockgroup_lock); 1112 kfree(sbi->s_blockgroup_lock);
1109 kfree(sbi); 1113 kfree(sbi);
1114failed_unlock:
1115 unlock_kernel();
1110 return ret; 1116 return ret;
1111} 1117}
1112 1118