diff options
| author | Filipe Manana <fdmanana@suse.com> | 2024-09-24 14:39:19 +0100 | 
|---|---|---|
| committer | David Sterba <dsterba@suse.com> | 2024-10-07 23:22:30 +0200 | 
| commit | 6ef8fbce010421bf742b12b8f8f2b2d2ff154845 (patch) | |
| tree | 251d721903f78c5f176ed67597ace74c26060179 /rust/helpers/build_bug.c | |
| parent | 69313850dce33ce8c24b38576a279421f4c60996 (diff) | |
btrfs: fix missing error handling when adding delayed ref with qgroups enabled
When adding a delayed ref head, at delayed-ref.c:add_delayed_ref_head(),
if we fail to insert the qgroup record we don't error out, we ignore it.
In fact we treat it as if there was no error and there was already an
existing record - we don't distinguish between the cases where
btrfs_qgroup_trace_extent_nolock() returns 1, meaning a record already
existed and we can free the given record, and the case where it returns
a negative error value, meaning the insertion into the xarray that is
used to track records failed.
Effectively we end up ignoring that we are lacking qgroup record in the
dirty extents xarray, resulting in incorrect qgroup accounting.
Fix this by checking for errors and return them to the callers.
Fixes: 3cce39a8ca4e ("btrfs: qgroup: use xarray to track dirty extents in transaction")
Reviewed-by: Qu Wenruo <wqu@suse.com>
Signed-off-by: Filipe Manana <fdmanana@suse.com>
Reviewed-by: David Sterba <dsterba@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>
Diffstat (limited to 'rust/helpers/build_bug.c')
0 files changed, 0 insertions, 0 deletions
