btrfs: fix the length of reserved qgroup to free
authorHaisu Wang <haisuwang@tencent.com>
Fri, 25 Oct 2024 06:54:40 +0000 (14:54 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 25 Apr 2025 08:45:58 +0000 (10:45 +0200)
commit 2b084d8205949dd804e279df8e68531da78be1e8 upstream.

The dealloc flag may be cleared and the extent won't reach the disk in
cow_file_range when errors path. The reserved qgroup space is freed in
commit 30479f31d44d ("btrfs: fix qgroup reserve leaks in
cow_file_range"). However, the length of untouched region to free needs
to be adjusted with the correct remaining region size.

Fixes: 30479f31d44d ("btrfs: fix qgroup reserve leaks in cow_file_range")
CC: stable@vger.kernel.org # 6.11+
Reviewed-by: Qu Wenruo <wqu@suse.com>
Reviewed-by: Boris Burkov <boris@bur.io>
Signed-off-by: Haisu Wang <haisuwang@tencent.com>
Reviewed-by: David Sterba <dsterba@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
fs/btrfs/inode.c

index fc127182067bcddbb36a4fad5d2e6773a130b92b..11c4d69177f0caa96bd7d63aa13f4d4d618260db 100644 (file)
@@ -1560,7 +1560,7 @@ out_unlock:
                clear_bits |= EXTENT_CLEAR_DATA_RESV;
                extent_clear_unlock_delalloc(inode, start, end, locked_page,
                                             clear_bits, page_ops);
-               btrfs_qgroup_free_data(inode, NULL, start, cur_alloc_size, NULL);
+               btrfs_qgroup_free_data(inode, NULL, start, end - start + 1, NULL);
        }
        return ret;
 }