Commit 30ef0e40 authored by Chengguang Xu's avatar Chengguang Xu Committed by Jan Kara

ext2: don't set *count in the case of failure in ext2_try_to_allocate()

Currently we set *count to num(value 0) in the failure
of block allocation in ext2_try_to_allocate(). Without
reservation, we reuse *count(value 0) to retry block
allocation and wrong *count will cause only allocating
maximum 1 block even though having sufficent free blocks
in that block group. Finally, it probably cause significant
fragmentation.

Link: https://lore.kernel.org/r/20191026090721.23794-1-cgxu519@mykernel.netSigned-off-by: default avatarChengguang Xu <cgxu519@mykernel.net>
Signed-off-by: default avatarJan Kara <jack@suse.cz>
parent 60e4cf67
...@@ -736,7 +736,6 @@ ext2_try_to_allocate(struct super_block *sb, int group, ...@@ -736,7 +736,6 @@ ext2_try_to_allocate(struct super_block *sb, int group,
*count = num; *count = num;
return grp_goal - num; return grp_goal - num;
fail_access: fail_access:
*count = num;
return -1; return -1;
} }
......
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