diff options
author | Boris Burkov <boris@bur.io> | 2023-12-02 00:00:13 +0300 |
---|---|---|
committer | David Sterba <dsterba@suse.com> | 2023-12-07 00:32:57 +0300 |
commit | e85a0adacf170634878fffcbf34b725aff3f49ed (patch) | |
tree | 02caac7c49f9d78102d52934161d57657e2b05ea /scripts/gdb/linux/radixtree.py | |
parent | a86805504b88f636a6458520d85afdf0634e3c6b (diff) | |
download | linux-e85a0adacf170634878fffcbf34b725aff3f49ed.tar.xz |
btrfs: ensure releasing squota reserve on head refs
A reservation goes through a 3 step lifetime:
- generated during delalloc
- released/counted by ordered_extent allocation
- freed by running delayed ref
That third step depends on must_insert_reserved on the head ref, so the
head ref with that field set owns the reservation. Once you prepare to
run the head ref, must_insert_reserved is unset, which means that
running the ref must free the reservation, whether or not it succeeds,
or else the reservation is leaked. That results in either a risk of
spurious ENOSPC if the fs stays writeable or a warning on unmount if it
is readonly.
The existing squota code was aware of these invariants, but missed a few
cases. Improve it by adding a helper function to use in the cleanup
paths and call it from the existing early returns in running delayed
refs. This also simplifies btrfs_record_squota_delta and struct
btrfs_quota_delta.
This fixes (or at least improves the reliability of) generic/475 with
"mkfs -O squota". On my machine, that test failed ~4/10 times without
this patch and passed 100/100 times with it.
Signed-off-by: Boris Burkov <boris@bur.io>
Signed-off-by: David Sterba <dsterba@suse.com>
Diffstat (limited to 'scripts/gdb/linux/radixtree.py')
0 files changed, 0 insertions, 0 deletions