summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJosef Bacik <josef@toxicpanda.com>2019-08-22 15:14:33 -0400
committerDavid Sterba <dsterba@suse.com>2019-09-09 08:59:13 -0400
commit2bd36e7b4fd60d4ff5f9ba6a0ad84557ae4803c4 (patch)
tree092a2fb134a8cb3387df0bde272d631aa8fd3e21
parent0785a9aacf9de9cd6a89a628b3b5d6b7e9ce5316 (diff)
btrfs: rename the btrfs_calc_*_metadata_size helpers
btrfs_calc_trunc_metadata_size differs from trans_metadata_size in that it doesn't take into account any splitting at the levels, because truncate will never split nodes. However truncate _and_ changing will never split nodes, so rename btrfs_calc_trunc_metadata_size to btrfs_calc_metadata_size. Also btrfs_calc_trans_metadata_size is purely for inserting items, so rename this to btrfs_calc_insert_metadata_size. Making these clearer will help when I start using them differently in upcoming patches. Reviewed-by: Nikolay Borisov <nborisov@suse.com> Signed-off-by: Josef Bacik <josef@toxicpanda.com> Reviewed-by: David Sterba <dsterba@suse.com> Signed-off-by: David Sterba <dsterba@suse.com>
-rw-r--r--fs/btrfs/block-group.c4
-rw-r--r--fs/btrfs/ctree.h14
-rw-r--r--fs/btrfs/delalloc-space.c8
-rw-r--r--fs/btrfs/delayed-inode.c4
-rw-r--r--fs/btrfs/delayed-ref.c8
-rw-r--r--fs/btrfs/file.c4
-rw-r--r--fs/btrfs/free-space-cache.c4
-rw-r--r--fs/btrfs/inode-map.c2
-rw-r--r--fs/btrfs/inode.c6
-rw-r--r--fs/btrfs/props.c2
-rw-r--r--fs/btrfs/root-tree.c2
-rw-r--r--fs/btrfs/space-info.c2
-rw-r--r--fs/btrfs/transaction.c4
13 files changed, 34 insertions, 30 deletions
diff --git a/fs/btrfs/block-group.c b/fs/btrfs/block-group.c
index 55d6d1c36b62..c912ee26e85d 100644
--- a/fs/btrfs/block-group.c
+++ b/fs/btrfs/block-group.c
@@ -3015,8 +3015,8 @@ void check_system_chunk(struct btrfs_trans_handle *trans, u64 type)
3015 num_devs = get_profile_num_devs(fs_info, type); 3015 num_devs = get_profile_num_devs(fs_info, type);
3016 3016
3017 /* num_devs device items to update and 1 chunk item to add or remove */ 3017 /* num_devs device items to update and 1 chunk item to add or remove */
3018 thresh = btrfs_calc_trunc_metadata_size(fs_info, num_devs) + 3018 thresh = btrfs_calc_metadata_size(fs_info, num_devs) +
3019 btrfs_calc_trans_metadata_size(fs_info, 1); 3019 btrfs_calc_insert_metadata_size(fs_info, 1);
3020 3020
3021 if (left < thresh && btrfs_test_opt(fs_info, ENOSPC_DEBUG)) { 3021 if (left < thresh && btrfs_test_opt(fs_info, ENOSPC_DEBUG)) {
3022 btrfs_info(fs_info, "left=%llu, need=%llu, flags=%llu", 3022 btrfs_info(fs_info, "left=%llu, need=%llu, flags=%llu",
diff --git a/fs/btrfs/ctree.h b/fs/btrfs/ctree.h
index 20793742c9d3..d27b39858339 100644
--- a/fs/btrfs/ctree.h
+++ b/fs/btrfs/ctree.h
@@ -2451,17 +2451,21 @@ u64 hash_extent_data_ref(u64 root_objectid, u64 owner, u64 offset);
2451 2451
2452u64 btrfs_csum_bytes_to_leaves(struct btrfs_fs_info *fs_info, u64 csum_bytes); 2452u64 btrfs_csum_bytes_to_leaves(struct btrfs_fs_info *fs_info, u64 csum_bytes);
2453 2453
2454static inline u64 btrfs_calc_trans_metadata_size(struct btrfs_fs_info *fs_info, 2454/*
2455 unsigned num_items) 2455 * Use this if we would be adding new items, as we could split nodes as we cow
2456 * down the tree.
2457 */
2458static inline u64 btrfs_calc_insert_metadata_size(struct btrfs_fs_info *fs_info,
2459 unsigned num_items)
2456{ 2460{
2457 return (u64)fs_info->nodesize * BTRFS_MAX_LEVEL * 2 * num_items; 2461 return (u64)fs_info->nodesize * BTRFS_MAX_LEVEL * 2 * num_items;
2458} 2462}
2459 2463
2460/* 2464/*
2461 * Doing a truncate won't result in new nodes or leaves, just what we need for 2465 * Doing a truncate or a modification won't result in new nodes or leaves, just
2462 * COW. 2466 * what we need for COW.
2463 */ 2467 */
2464static inline u64 btrfs_calc_trunc_metadata_size(struct btrfs_fs_info *fs_info, 2468static inline u64 btrfs_calc_metadata_size(struct btrfs_fs_info *fs_info,
2465 unsigned num_items) 2469 unsigned num_items)
2466{ 2470{
2467 return (u64)fs_info->nodesize * BTRFS_MAX_LEVEL * num_items; 2471 return (u64)fs_info->nodesize * BTRFS_MAX_LEVEL * num_items;
diff --git a/fs/btrfs/delalloc-space.c b/fs/btrfs/delalloc-space.c
index d2dfc201b2e1..62aa18b38a08 100644
--- a/fs/btrfs/delalloc-space.c
+++ b/fs/btrfs/delalloc-space.c
@@ -256,12 +256,12 @@ static void btrfs_calculate_inode_block_rsv_size(struct btrfs_fs_info *fs_info,
256 lockdep_assert_held(&inode->lock); 256 lockdep_assert_held(&inode->lock);
257 outstanding_extents = inode->outstanding_extents; 257 outstanding_extents = inode->outstanding_extents;
258 if (outstanding_extents) 258 if (outstanding_extents)
259 reserve_size = btrfs_calc_trans_metadata_size(fs_info, 259 reserve_size = btrfs_calc_insert_metadata_size(fs_info,
260 outstanding_extents + 1); 260 outstanding_extents + 1);
261 csum_leaves = btrfs_csum_bytes_to_leaves(fs_info, 261 csum_leaves = btrfs_csum_bytes_to_leaves(fs_info,
262 inode->csum_bytes); 262 inode->csum_bytes);
263 reserve_size += btrfs_calc_trans_metadata_size(fs_info, 263 reserve_size += btrfs_calc_insert_metadata_size(fs_info,
264 csum_leaves); 264 csum_leaves);
265 /* 265 /*
266 * For qgroup rsv, the calculation is very simple: 266 * For qgroup rsv, the calculation is very simple:
267 * account one nodesize for each outstanding extent 267 * account one nodesize for each outstanding extent
@@ -284,7 +284,7 @@ static void calc_inode_reservations(struct btrfs_fs_info *fs_info,
284 u64 csum_leaves = btrfs_csum_bytes_to_leaves(fs_info, num_bytes); 284 u64 csum_leaves = btrfs_csum_bytes_to_leaves(fs_info, num_bytes);
285 285
286 /* We add one for the inode update at finish ordered time */ 286 /* We add one for the inode update at finish ordered time */
287 *meta_reserve = btrfs_calc_trans_metadata_size(fs_info, 287 *meta_reserve = btrfs_calc_insert_metadata_size(fs_info,
288 nr_extents + csum_leaves + 1); 288 nr_extents + csum_leaves + 1);
289 *qgroup_reserve = nr_extents * fs_info->nodesize; 289 *qgroup_reserve = nr_extents * fs_info->nodesize;
290} 290}
diff --git a/fs/btrfs/delayed-inode.c b/fs/btrfs/delayed-inode.c
index 6858a05606dd..de87ea7ce84d 100644
--- a/fs/btrfs/delayed-inode.c
+++ b/fs/btrfs/delayed-inode.c
@@ -558,7 +558,7 @@ static int btrfs_delayed_item_reserve_metadata(struct btrfs_trans_handle *trans,
558 src_rsv = trans->block_rsv; 558 src_rsv = trans->block_rsv;
559 dst_rsv = &fs_info->delayed_block_rsv; 559 dst_rsv = &fs_info->delayed_block_rsv;
560 560
561 num_bytes = btrfs_calc_trans_metadata_size(fs_info, 1); 561 num_bytes = btrfs_calc_insert_metadata_size(fs_info, 1);
562 562
563 /* 563 /*
564 * Here we migrate space rsv from transaction rsv, since have already 564 * Here we migrate space rsv from transaction rsv, since have already
@@ -612,7 +612,7 @@ static int btrfs_delayed_inode_reserve_metadata(
612 src_rsv = trans->block_rsv; 612 src_rsv = trans->block_rsv;
613 dst_rsv = &fs_info->delayed_block_rsv; 613 dst_rsv = &fs_info->delayed_block_rsv;
614 614
615 num_bytes = btrfs_calc_trans_metadata_size(fs_info, 1); 615 num_bytes = btrfs_calc_insert_metadata_size(fs_info, 1);
616 616
617 /* 617 /*
618 * btrfs_dirty_inode will update the inode under btrfs_join_transaction 618 * btrfs_dirty_inode will update the inode under btrfs_join_transaction
diff --git a/fs/btrfs/delayed-ref.c b/fs/btrfs/delayed-ref.c
index 9a91d1eb0af4..951a60c740e7 100644
--- a/fs/btrfs/delayed-ref.c
+++ b/fs/btrfs/delayed-ref.c
@@ -79,7 +79,7 @@ int btrfs_should_throttle_delayed_refs(struct btrfs_trans_handle *trans)
79void btrfs_delayed_refs_rsv_release(struct btrfs_fs_info *fs_info, int nr) 79void btrfs_delayed_refs_rsv_release(struct btrfs_fs_info *fs_info, int nr)
80{ 80{
81 struct btrfs_block_rsv *block_rsv = &fs_info->delayed_refs_rsv; 81 struct btrfs_block_rsv *block_rsv = &fs_info->delayed_refs_rsv;
82 u64 num_bytes = btrfs_calc_trans_metadata_size(fs_info, nr); 82 u64 num_bytes = btrfs_calc_insert_metadata_size(fs_info, nr);
83 u64 released = 0; 83 u64 released = 0;
84 84
85 released = __btrfs_block_rsv_release(fs_info, block_rsv, num_bytes, 85 released = __btrfs_block_rsv_release(fs_info, block_rsv, num_bytes,
@@ -105,8 +105,8 @@ void btrfs_update_delayed_refs_rsv(struct btrfs_trans_handle *trans)
105 if (!trans->delayed_ref_updates) 105 if (!trans->delayed_ref_updates)
106 return; 106 return;
107 107
108 num_bytes = btrfs_calc_trans_metadata_size(fs_info, 108 num_bytes = btrfs_calc_insert_metadata_size(fs_info,
109 trans->delayed_ref_updates); 109 trans->delayed_ref_updates);
110 spin_lock(&delayed_rsv->lock); 110 spin_lock(&delayed_rsv->lock);
111 delayed_rsv->size += num_bytes; 111 delayed_rsv->size += num_bytes;
112 delayed_rsv->full = 0; 112 delayed_rsv->full = 0;
@@ -174,7 +174,7 @@ int btrfs_delayed_refs_rsv_refill(struct btrfs_fs_info *fs_info,
174 enum btrfs_reserve_flush_enum flush) 174 enum btrfs_reserve_flush_enum flush)
175{ 175{
176 struct btrfs_block_rsv *block_rsv = &fs_info->delayed_refs_rsv; 176 struct btrfs_block_rsv *block_rsv = &fs_info->delayed_refs_rsv;
177 u64 limit = btrfs_calc_trans_metadata_size(fs_info, 1); 177 u64 limit = btrfs_calc_insert_metadata_size(fs_info, 1);
178 u64 num_bytes = 0; 178 u64 num_bytes = 0;
179 int ret = -ENOSPC; 179 int ret = -ENOSPC;
180 180
diff --git a/fs/btrfs/file.c b/fs/btrfs/file.c
index b31991f0f440..1cb694c96500 100644
--- a/fs/btrfs/file.c
+++ b/fs/btrfs/file.c
@@ -2511,7 +2511,7 @@ int btrfs_punch_hole_range(struct inode *inode, struct btrfs_path *path,
2511 struct btrfs_trans_handle **trans_out) 2511 struct btrfs_trans_handle **trans_out)
2512{ 2512{
2513 struct btrfs_fs_info *fs_info = btrfs_sb(inode->i_sb); 2513 struct btrfs_fs_info *fs_info = btrfs_sb(inode->i_sb);
2514 u64 min_size = btrfs_calc_trans_metadata_size(fs_info, 1); 2514 u64 min_size = btrfs_calc_insert_metadata_size(fs_info, 1);
2515 u64 ino_size = round_up(inode->i_size, fs_info->sectorsize); 2515 u64 ino_size = round_up(inode->i_size, fs_info->sectorsize);
2516 struct btrfs_root *root = BTRFS_I(inode)->root; 2516 struct btrfs_root *root = BTRFS_I(inode)->root;
2517 struct btrfs_trans_handle *trans = NULL; 2517 struct btrfs_trans_handle *trans = NULL;
@@ -2530,7 +2530,7 @@ int btrfs_punch_hole_range(struct inode *inode, struct btrfs_path *path,
2530 ret = -ENOMEM; 2530 ret = -ENOMEM;
2531 goto out; 2531 goto out;
2532 } 2532 }
2533 rsv->size = btrfs_calc_trans_metadata_size(fs_info, 1); 2533 rsv->size = btrfs_calc_insert_metadata_size(fs_info, 1);
2534 rsv->failfast = 1; 2534 rsv->failfast = 1;
2535 2535
2536 /* 2536 /*
diff --git a/fs/btrfs/free-space-cache.c b/fs/btrfs/free-space-cache.c
index faaf57a7c289..265dc75f7a7a 100644
--- a/fs/btrfs/free-space-cache.c
+++ b/fs/btrfs/free-space-cache.c
@@ -211,8 +211,8 @@ int btrfs_check_trunc_cache_free_space(struct btrfs_fs_info *fs_info,
211 int ret; 211 int ret;
212 212
213 /* 1 for slack space, 1 for updating the inode */ 213 /* 1 for slack space, 1 for updating the inode */
214 needed_bytes = btrfs_calc_trunc_metadata_size(fs_info, 1) + 214 needed_bytes = btrfs_calc_insert_metadata_size(fs_info, 1) +
215 btrfs_calc_trans_metadata_size(fs_info, 1); 215 btrfs_calc_metadata_size(fs_info, 1);
216 216
217 spin_lock(&rsv->lock); 217 spin_lock(&rsv->lock);
218 if (rsv->reserved < needed_bytes) 218 if (rsv->reserved < needed_bytes)
diff --git a/fs/btrfs/inode-map.c b/fs/btrfs/inode-map.c
index 86031cdfc356..63cad7865d75 100644
--- a/fs/btrfs/inode-map.c
+++ b/fs/btrfs/inode-map.c
@@ -436,7 +436,7 @@ int btrfs_save_ino_cache(struct btrfs_root *root,
436 * 1 item for free space object 436 * 1 item for free space object
437 * 3 items for pre-allocation 437 * 3 items for pre-allocation
438 */ 438 */
439 trans->bytes_reserved = btrfs_calc_trans_metadata_size(fs_info, 10); 439 trans->bytes_reserved = btrfs_calc_insert_metadata_size(fs_info, 10);
440 ret = btrfs_block_rsv_add(root, trans->block_rsv, 440 ret = btrfs_block_rsv_add(root, trans->block_rsv,
441 trans->bytes_reserved, 441 trans->bytes_reserved,
442 BTRFS_RESERVE_NO_FLUSH); 442 BTRFS_RESERVE_NO_FLUSH);
diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c
index c4116bc58827..31eacbf51d4e 100644
--- a/fs/btrfs/inode.c
+++ b/fs/btrfs/inode.c
@@ -5337,7 +5337,7 @@ static struct btrfs_trans_handle *evict_refill_and_join(struct btrfs_root *root,
5337 struct btrfs_fs_info *fs_info = root->fs_info; 5337 struct btrfs_fs_info *fs_info = root->fs_info;
5338 struct btrfs_block_rsv *global_rsv = &fs_info->global_block_rsv; 5338 struct btrfs_block_rsv *global_rsv = &fs_info->global_block_rsv;
5339 struct btrfs_trans_handle *trans; 5339 struct btrfs_trans_handle *trans;
5340 u64 delayed_refs_extra = btrfs_calc_trans_metadata_size(fs_info, 1); 5340 u64 delayed_refs_extra = btrfs_calc_insert_metadata_size(fs_info, 1);
5341 int ret; 5341 int ret;
5342 5342
5343 /* 5343 /*
@@ -5426,7 +5426,7 @@ void btrfs_evict_inode(struct inode *inode)
5426 rsv = btrfs_alloc_block_rsv(fs_info, BTRFS_BLOCK_RSV_TEMP); 5426 rsv = btrfs_alloc_block_rsv(fs_info, BTRFS_BLOCK_RSV_TEMP);
5427 if (!rsv) 5427 if (!rsv)
5428 goto no_delete; 5428 goto no_delete;
5429 rsv->size = btrfs_calc_trunc_metadata_size(fs_info, 1); 5429 rsv->size = btrfs_calc_metadata_size(fs_info, 1);
5430 rsv->failfast = 1; 5430 rsv->failfast = 1;
5431 5431
5432 btrfs_i_size_write(BTRFS_I(inode), 0); 5432 btrfs_i_size_write(BTRFS_I(inode), 0);
@@ -9040,7 +9040,7 @@ static int btrfs_truncate(struct inode *inode, bool skip_writeback)
9040 int ret; 9040 int ret;
9041 struct btrfs_trans_handle *trans; 9041 struct btrfs_trans_handle *trans;
9042 u64 mask = fs_info->sectorsize - 1; 9042 u64 mask = fs_info->sectorsize - 1;
9043 u64 min_size = btrfs_calc_trunc_metadata_size(fs_info, 1); 9043 u64 min_size = btrfs_calc_metadata_size(fs_info, 1);
9044 9044
9045 if (!skip_writeback) { 9045 if (!skip_writeback) {
9046 ret = btrfs_wait_ordered_range(inode, inode->i_size & (~mask), 9046 ret = btrfs_wait_ordered_range(inode, inode->i_size & (~mask),
diff --git a/fs/btrfs/props.c b/fs/btrfs/props.c
index e0469816c678..1e664e0b59b8 100644
--- a/fs/btrfs/props.c
+++ b/fs/btrfs/props.c
@@ -362,7 +362,7 @@ static int inherit_props(struct btrfs_trans_handle *trans,
362 * reservations if we do add more properties in the future. 362 * reservations if we do add more properties in the future.
363 */ 363 */
364 if (need_reserve) { 364 if (need_reserve) {
365 num_bytes = btrfs_calc_trans_metadata_size(fs_info, 1); 365 num_bytes = btrfs_calc_insert_metadata_size(fs_info, 1);
366 ret = btrfs_block_rsv_add(root, trans->block_rsv, 366 ret = btrfs_block_rsv_add(root, trans->block_rsv,
367 num_bytes, BTRFS_RESERVE_NO_FLUSH); 367 num_bytes, BTRFS_RESERVE_NO_FLUSH);
368 if (ret) 368 if (ret)
diff --git a/fs/btrfs/root-tree.c b/fs/btrfs/root-tree.c
index 47733fb55df7..3b17b647d002 100644
--- a/fs/btrfs/root-tree.c
+++ b/fs/btrfs/root-tree.c
@@ -533,7 +533,7 @@ int btrfs_subvolume_reserve_metadata(struct btrfs_root *root,
533 return ret; 533 return ret;
534 } 534 }
535 535
536 num_bytes = btrfs_calc_trans_metadata_size(fs_info, items); 536 num_bytes = btrfs_calc_insert_metadata_size(fs_info, items);
537 rsv->space_info = btrfs_find_space_info(fs_info, 537 rsv->space_info = btrfs_find_space_info(fs_info,
538 BTRFS_BLOCK_GROUP_METADATA); 538 BTRFS_BLOCK_GROUP_METADATA);
539 ret = btrfs_block_rsv_add(root, rsv, num_bytes, 539 ret = btrfs_block_rsv_add(root, rsv, num_bytes,
diff --git a/fs/btrfs/space-info.c b/fs/btrfs/space-info.c
index 5f8f65599de1..13a4326c8821 100644
--- a/fs/btrfs/space-info.c
+++ b/fs/btrfs/space-info.c
@@ -412,7 +412,7 @@ static inline u64 calc_reclaim_items_nr(struct btrfs_fs_info *fs_info,
412 u64 bytes; 412 u64 bytes;
413 u64 nr; 413 u64 nr;
414 414
415 bytes = btrfs_calc_trans_metadata_size(fs_info, 1); 415 bytes = btrfs_calc_insert_metadata_size(fs_info, 1);
416 nr = div64_u64(to_reclaim, bytes); 416 nr = div64_u64(to_reclaim, bytes);
417 if (!nr) 417 if (!nr)
418 nr = 1; 418 nr = 1;
diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c
index 2e3f6778bfa3..f21416d68c2c 100644
--- a/fs/btrfs/transaction.c
+++ b/fs/btrfs/transaction.c
@@ -485,7 +485,7 @@ start_transaction(struct btrfs_root *root, unsigned int num_items,
485 * worth of delayed refs updates in this trans handle, and 485 * worth of delayed refs updates in this trans handle, and
486 * refill that amount for whatever is missing in the reserve. 486 * refill that amount for whatever is missing in the reserve.
487 */ 487 */
488 num_bytes = btrfs_calc_trans_metadata_size(fs_info, num_items); 488 num_bytes = btrfs_calc_insert_metadata_size(fs_info, num_items);
489 if (delayed_refs_rsv->full == 0) { 489 if (delayed_refs_rsv->full == 0) {
490 delayed_refs_bytes = num_bytes; 490 delayed_refs_bytes = num_bytes;
491 num_bytes <<= 1; 491 num_bytes <<= 1;
@@ -636,7 +636,7 @@ struct btrfs_trans_handle *btrfs_start_transaction_fallback_global_rsv(
636 if (IS_ERR(trans)) 636 if (IS_ERR(trans))
637 return trans; 637 return trans;
638 638
639 num_bytes = btrfs_calc_trans_metadata_size(fs_info, num_items); 639 num_bytes = btrfs_calc_insert_metadata_size(fs_info, num_items);
640 ret = btrfs_cond_migrate_bytes(fs_info, &fs_info->trans_block_rsv, 640 ret = btrfs_cond_migrate_bytes(fs_info, &fs_info->trans_block_rsv,
641 num_bytes, min_factor); 641 num_bytes, min_factor);
642 if (ret) { 642 if (ret) {