mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-04 04:06:26 +00:00
ext4: use best found when complex scan of group finishs
If any bex which meets bex->fe_len >= gex->fe_len is found, then it will always be used when complex scan of group that bex belongs to finishs. So there will not be any lock-unlock period. Signed-off-by: Kemeng Shi <shikemeng@huaweicloud.com> Reviewed-by: Ojaswin Mujoo <ojaswin@linux.ibm.com> Link: https://lore.kernel.org/r/20230303172120.3800725-15-shikemeng@huaweicloud.com Signed-off-by: Theodore Ts'o <tytso@mit.edu>
This commit is contained in:
parent
32c0869370
commit
78dc9f844f
@ -2019,8 +2019,6 @@ static void ext4_mb_check_limits(struct ext4_allocation_context *ac,
|
|||||||
struct ext4_sb_info *sbi = EXT4_SB(ac->ac_sb);
|
struct ext4_sb_info *sbi = EXT4_SB(ac->ac_sb);
|
||||||
struct ext4_free_extent *bex = &ac->ac_b_ex;
|
struct ext4_free_extent *bex = &ac->ac_b_ex;
|
||||||
struct ext4_free_extent *gex = &ac->ac_g_ex;
|
struct ext4_free_extent *gex = &ac->ac_g_ex;
|
||||||
struct ext4_free_extent ex;
|
|
||||||
int max;
|
|
||||||
|
|
||||||
if (ac->ac_status == AC_STATUS_FOUND)
|
if (ac->ac_status == AC_STATUS_FOUND)
|
||||||
return;
|
return;
|
||||||
@ -2039,16 +2037,8 @@ static void ext4_mb_check_limits(struct ext4_allocation_context *ac,
|
|||||||
if (bex->fe_len < gex->fe_len)
|
if (bex->fe_len < gex->fe_len)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (finish_group && bex->fe_group == e4b->bd_group) {
|
if (finish_group)
|
||||||
/* recheck chunk's availability - we don't know
|
ext4_mb_use_best_found(ac, e4b);
|
||||||
* when it was found (within this lock-unlock
|
|
||||||
* period or not) */
|
|
||||||
max = mb_find_extent(e4b, bex->fe_start, gex->fe_len, &ex);
|
|
||||||
if (max >= gex->fe_len) {
|
|
||||||
ext4_mb_use_best_found(ac, e4b);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
Loading…
Reference in New Issue
Block a user