Commit a860c2f9 authored by Vasily Averin's avatar Vasily Averin Committed by Kleber Sacilotto de Souza

ext4: avoid potential extra brelse in setup_new_flex_group_blocks()

BugLink: https://bugs.launchpad.net/bugs/1810947

commit 9e402893 upstream.

Currently bh is set to NULL only during first iteration of for cycle,
then this pointer is not cleared after end of using.
Therefore rollback after errors can lead to extra brelse(bh) call,
decrements bh counter and later trigger an unexpected warning in __brelse()

Patch moves brelse() calls in body of cycle to exclude requirement of
brelse() call in rollback.

Fixes: 33afdcc5 ("ext4: add a function which sets up group blocks ...")
Signed-off-by: default avatarVasily Averin <vvs@virtuozzo.com>
Signed-off-by: default avatarTheodore Ts'o <tytso@mit.edu>
Cc: stable@kernel.org # 3.3+
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarJuerg Haefliger <juergh@canonical.com>
Signed-off-by: default avatarKleber Sacilotto de Souza <kleber.souza@canonical.com>
parent 01d5070f
...@@ -590,7 +590,6 @@ static int setup_new_flex_group_blocks(struct super_block *sb, ...@@ -590,7 +590,6 @@ static int setup_new_flex_group_blocks(struct super_block *sb,
bh = bclean(handle, sb, block); bh = bclean(handle, sb, block);
if (IS_ERR(bh)) { if (IS_ERR(bh)) {
err = PTR_ERR(bh); err = PTR_ERR(bh);
bh = NULL;
goto out; goto out;
} }
overhead = ext4_group_overhead_blocks(sb, group); overhead = ext4_group_overhead_blocks(sb, group);
...@@ -602,9 +601,9 @@ static int setup_new_flex_group_blocks(struct super_block *sb, ...@@ -602,9 +601,9 @@ static int setup_new_flex_group_blocks(struct super_block *sb,
ext4_mark_bitmap_end(group_data[i].blocks_count, ext4_mark_bitmap_end(group_data[i].blocks_count,
sb->s_blocksize * 8, bh->b_data); sb->s_blocksize * 8, bh->b_data);
err = ext4_handle_dirty_metadata(handle, NULL, bh); err = ext4_handle_dirty_metadata(handle, NULL, bh);
brelse(bh);
if (err) if (err)
goto out; goto out;
brelse(bh);
handle_ib: handle_ib:
if (bg_flags[i] & EXT4_BG_INODE_UNINIT) if (bg_flags[i] & EXT4_BG_INODE_UNINIT)
...@@ -619,18 +618,16 @@ static int setup_new_flex_group_blocks(struct super_block *sb, ...@@ -619,18 +618,16 @@ static int setup_new_flex_group_blocks(struct super_block *sb,
bh = bclean(handle, sb, block); bh = bclean(handle, sb, block);
if (IS_ERR(bh)) { if (IS_ERR(bh)) {
err = PTR_ERR(bh); err = PTR_ERR(bh);
bh = NULL;
goto out; goto out;
} }
ext4_mark_bitmap_end(EXT4_INODES_PER_GROUP(sb), ext4_mark_bitmap_end(EXT4_INODES_PER_GROUP(sb),
sb->s_blocksize * 8, bh->b_data); sb->s_blocksize * 8, bh->b_data);
err = ext4_handle_dirty_metadata(handle, NULL, bh); err = ext4_handle_dirty_metadata(handle, NULL, bh);
brelse(bh);
if (err) if (err)
goto out; goto out;
brelse(bh);
} }
bh = NULL;
/* Mark group tables in block bitmap */ /* Mark group tables in block bitmap */
for (j = 0; j < GROUP_TABLE_COUNT; j++) { for (j = 0; j < GROUP_TABLE_COUNT; j++) {
...@@ -661,7 +658,6 @@ static int setup_new_flex_group_blocks(struct super_block *sb, ...@@ -661,7 +658,6 @@ static int setup_new_flex_group_blocks(struct super_block *sb,
} }
out: out:
brelse(bh);
err2 = ext4_journal_stop(handle); err2 = ext4_journal_stop(handle);
if (err2 && !err) if (err2 && !err)
err = err2; err = err2;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment