diff options
| author | Filipe Manana <[email protected]> | 2023-06-13 17:07:54 +0100 | 
|---|---|---|
| committer | David Sterba <[email protected]> | 2023-06-19 13:59:39 +0200 | 
| commit | 6822b3f708608d74820cd69e76de16d42899a230 (patch) | |
| tree | a3f2289eba32fae1b402de60a05d50fa22ba1225 /scripts/gdb/linux/slab.py | |
| parent | df9f278239046719c91aeb59ec0afb1a99ee8b2b (diff) | |
btrfs: do not BUG_ON after failure to migrate space during truncation
During truncation we reserve 2 metadata units when starting a transaction
(reserved space goes to fs_info->trans_block_rsv) and then attempt to
migrate 1 unit (min_size bytes) from fs_info->trans_block_rsv into the
local block reserve. If we ever fail we trigger a BUG_ON(), which should
never happen, because we reserved 2 units. However if we happen to fail
for some reason, we don't need to be so dire and hit a BUG_ON(), we can
just error out the truncation and, since this is highly unexpected,
surround the error check with WARN_ON(), to get an informative stack
trace and tag the branh as 'unlikely'. Also make the 'min_size' variable
const, since it's not supposed to ever change and any accidental change
could possibly make the space migration not so unlikely to fail.
Reviewed-by: Qu Wenruo <[email protected]>
Signed-off-by: Filipe Manana <[email protected]>
Signed-off-by: David Sterba <[email protected]>
Diffstat (limited to 'scripts/gdb/linux/slab.py')
0 files changed, 0 insertions, 0 deletions