Factor out release_block_group() from find_free_extent(). This function is called when it gives up an allocation from a block group. Allocator hook functions like release_block_group_clustered() should reset their information for an allocation in the next block group. Signed-off-by: Naohiro Aota <naohiro.aota@xxxxxxx> --- fs/btrfs/extent-tree.c | 31 ++++++++++++++++++++++++++----- 1 file changed, 26 insertions(+), 5 deletions(-) diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c index 0e1fe83e5d79..9f01c2bf7e11 100644 --- a/fs/btrfs/extent-tree.c +++ b/fs/btrfs/extent-tree.c @@ -3712,6 +3712,31 @@ static int do_allocation(struct btrfs_block_group *block_group, } } +static void release_block_group_clustered(struct find_free_extent_ctl *ffe_ctl) +{ + struct clustered_alloc_info *clustered = ffe_ctl->alloc_info; + + clustered->retry_clustered = false; + clustered->retry_unclustered = false; +} + +static void release_block_group(struct btrfs_block_group *block_group, + struct find_free_extent_ctl *ffe_ctl, + int delalloc) +{ + switch (ffe_ctl->policy) { + case BTRFS_EXTENT_ALLOC_CLUSTERED: + release_block_group_clustered(ffe_ctl); + break; + default: + BUG(); + } + + BUG_ON(btrfs_bg_flags_to_raid_index(block_group->flags) != + ffe_ctl->index); + btrfs_release_block_group(block_group, delalloc); +} + /* * Return >0 means caller needs to re-search for free extent * Return 0 means we have the needed free extent. @@ -4094,11 +4119,7 @@ static noinline int find_free_extent(struct btrfs_fs_info *fs_info, btrfs_release_block_group(block_group, delalloc); break; loop: - clustered->retry_clustered = false; - clustered->retry_unclustered = false; - BUG_ON(btrfs_bg_flags_to_raid_index(block_group->flags) != - ffe_ctl.index); - btrfs_release_block_group(block_group, delalloc); + release_block_group(block_group, &ffe_ctl, delalloc); cond_resched(); } up_read(&space_info->groups_sem); -- 2.25.0