]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
btrfs: fix memory leaks when rejecting a non SINGLE data profile without an RST
authorMiquel Sabaté Solà <mssola@mssola.com>
Wed, 8 Oct 2025 12:18:59 +0000 (14:18 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 23 Oct 2025 14:20:20 +0000 (16:20 +0200)
commit fec9b9d3ced39f16be8d7afdf81f4dd2653da319 upstream.

At the end of btrfs_load_block_group_zone_info() the first thing we do
is to ensure that if the mapping type is not a SINGLE one and there is
no RAID stripe tree, then we return early with an error.

Doing that, though, prevents the code from running the last calls from
this function which are about freeing memory allocated during its
run. Hence, in this case, instead of returning early, we set the ret
value and fall through the rest of the cleanup code.

Fixes: 5906333cc4af ("btrfs: zoned: don't skip block group profile checks on conventional zones")
CC: stable@vger.kernel.org # 6.8+
Reviewed-by: Johannes Thumshirn <johannes.thumshirn@wdc.com>
Signed-off-by: Miquel Sabaté Solà <mssola@mssola.com>
Signed-off-by: David Sterba <dsterba@suse.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
fs/btrfs/zoned.c

index 8e8edfe0c6190e175b42e4ade13d9e8c52f092a3..4966b4f5a7d245478272d9bef92ec20e9902c7a2 100644 (file)
@@ -1664,7 +1664,7 @@ out:
            !fs_info->stripe_root) {
                btrfs_err(fs_info, "zoned: data %s needs raid-stripe-tree",
                          btrfs_bg_type_to_raid_name(map->type));
-               return -EINVAL;
+               ret = -EINVAL;
        }
 
        if (cache->alloc_offset > cache->zone_capacity) {