mirror of
https://github.com/torvalds/linux.git
synced 2024-11-22 12:11:40 +00:00
btrfs: fix calculation of the global block reserve's size
At btrfs_update_global_block_rsv(), we are assuming an unlink operation
uses 5 metadata units, but that's not true anymore, it uses 6 since the
commit bca4ad7c0b
("btrfs: reserve correct number of items for unlink
and rmdir"). So update the code and comments to consider 6 units.
Reviewed-by: Josef Bacik <josef@toxicpanda.com>
Signed-off-by: Filipe Manana <fdmanana@suse.com>
Reviewed-by: David Sterba <dsterba@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>
This commit is contained in:
parent
b13d57db90
commit
ba4ec8fbce
@ -350,14 +350,14 @@ void btrfs_update_global_block_rsv(struct btrfs_fs_info *fs_info)
|
||||
|
||||
/*
|
||||
* But we also want to reserve enough space so we can do the fallback
|
||||
* global reserve for an unlink, which is an additional 5 items (see the
|
||||
* global reserve for an unlink, which is an additional 6 items (see the
|
||||
* comment in __unlink_start_trans for what we're modifying.)
|
||||
*
|
||||
* But we also need space for the delayed ref updates from the unlink,
|
||||
* so its 10, 5 for the actual operation, and 5 for the delayed ref
|
||||
* so its 12, 6 for the actual operation, and 6 for the delayed ref
|
||||
* updates.
|
||||
*/
|
||||
min_items += 10;
|
||||
min_items += 12;
|
||||
|
||||
num_bytes = max_t(u64, num_bytes,
|
||||
btrfs_calc_insert_metadata_size(fs_info, min_items));
|
||||
|
Loading…
Reference in New Issue
Block a user