ext4: use best found when complex scan of group finishs
authorKemeng Shi <shikemeng@huaweicloud.com>
Fri, 3 Mar 2023 17:21:14 +0000 (01:21 +0800)
committerTheodore Ts'o <tytso@mit.edu>
Thu, 6 Apr 2023 05:13:11 +0000 (01:13 -0400)
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>
fs/ext4/mballoc.c

index eeafa1bba8246509539553bc5337b45abe743c39..a12c33bc27566317aea4ce21f8928c6f970cce2a 100644 (file)
@@ -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_free_extent *bex = &ac->ac_b_ex;
        struct ext4_free_extent *gex = &ac->ac_g_ex;
-       struct ext4_free_extent ex;
-       int max;
 
        if (ac->ac_status == AC_STATUS_FOUND)
                return;
@@ -2039,16 +2037,8 @@ static void ext4_mb_check_limits(struct ext4_allocation_context *ac,
        if (bex->fe_len < gex->fe_len)
                return;
 
-       if (finish_group && bex->fe_group == e4b->bd_group) {
-               /* recheck chunk's availability - we don't know
-                * 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;
-               }
-       }
+       if (finish_group)
+               ext4_mb_use_best_found(ac, e4b);
 }
 
 /*