Commit a2c8d27e authored by Filipe Manana's avatar Filipe Manana Committed by David Sterba

btrfs: use a structure to pass arguments to backref walking functions

The public backref walking functions have quite a lot of arguments that
are passed down the call stack to find_parent_nodes(), the core function
of the backref walking code.

The next patches in series will need to add even arguments to these
functions that should be passed not only to find_parent_nodes(), but also
to other functions used by the later (directly or even lower in the call
stack).

So create a structure to hold all these arguments and state used by the
main backref walking function, find_parent_nodes(), and use it as the
argument for the public backref walking functions iterate_extent_inodes(),
btrfs_find_all_leafs() and btrfs_find_all_roots().
Signed-off-by: default avatarFilipe Manana <fdmanana@suse.com>
Signed-off-by: default avatarDavid Sterba <dsterba@suse.com>
parent 6ce6ba53
This diff is collapsed.
...@@ -13,11 +13,63 @@ ...@@ -13,11 +13,63 @@
#include "extent_io.h" #include "extent_io.h"
/* /*
* Pass to backref walking functions to tell them to include references from * Context and arguments for backref walking functions. Some of the fields are
* all file extent items that point to the target data extent, regardless if * to be filled by the caller of such functions while other are filled by the
* they refer to the whole extent or just sections of it (bookend extents). * functions themselves, as described below.
*/ */
#define BTRFS_IGNORE_EXTENT_OFFSET ((u64)-1) struct btrfs_backref_walk_ctx {
/*
* The address of the extent for which we are doing backref walking.
* Can be either a data extent or a metadata extent.
*
* Must always be set by the top level caller.
*/
u64 bytenr;
/*
* Offset relative to the target extent. This is only used for data
* extents, and it's meaningful because we can have file extent items
* that point only to a section of a data extent ("bookend" extents),
* and we want to filter out any that don't point to a section of the
* data extent containing the given offset.
*
* Must always be set by the top level caller.
*/
u64 extent_item_pos;
/*
* If true and bytenr corresponds to a data extent, then references from
* all file extent items that point to the data extent are considered,
* @extent_item_pos is ignored.
*/
bool ignore_extent_item_pos;
/* A valid transaction handle or NULL. */
struct btrfs_trans_handle *trans;
/*
* The file system's info object, can not be NULL.
*
* Must always be set by the top level caller.
*/
struct btrfs_fs_info *fs_info;
/*
* Time sequence acquired from btrfs_get_tree_mod_seq(), in case the
* caller joined the tree mod log to get a consistent view of b+trees
* while we do backref walking, or BTRFS_SEQ_LAST.
* When using BTRFS_SEQ_LAST, delayed refs are not checked and it uses
* commit roots when searching b+trees - this is a special case for
* qgroups used during a transaction commit.
*/
u64 time_seq;
/*
* Used to collect the bytenr of metadata extents that point to the
* target extent.
*/
struct ulist *refs;
/*
* List used to collect the IDs of the roots from which the target
* extent is accessible. Can be NULL in case the caller does not care
* about collecting root IDs.
*/
struct ulist *roots;
};
struct inode_fs_paths { struct inode_fs_paths {
struct btrfs_path *btrfs_path; struct btrfs_path *btrfs_path;
...@@ -96,10 +148,9 @@ int tree_backref_for_extent(unsigned long *ptr, struct extent_buffer *eb, ...@@ -96,10 +148,9 @@ int tree_backref_for_extent(unsigned long *ptr, struct extent_buffer *eb,
struct btrfs_key *key, struct btrfs_extent_item *ei, struct btrfs_key *key, struct btrfs_extent_item *ei,
u32 item_size, u64 *out_root, u8 *out_level); u32 item_size, u64 *out_root, u8 *out_level);
int iterate_extent_inodes(struct btrfs_fs_info *fs_info, int iterate_extent_inodes(struct btrfs_backref_walk_ctx *ctx,
u64 extent_item_objectid, bool search_commit_root,
u64 extent_offset, int search_commit_root, iterate_extent_inodes_t *iterate, void *user_ctx);
iterate_extent_inodes_t *iterate, void *ctx);
int iterate_inodes_from_logical(u64 logical, struct btrfs_fs_info *fs_info, int iterate_inodes_from_logical(u64 logical, struct btrfs_fs_info *fs_info,
struct btrfs_path *path, void *ctx, struct btrfs_path *path, void *ctx,
...@@ -107,13 +158,8 @@ int iterate_inodes_from_logical(u64 logical, struct btrfs_fs_info *fs_info, ...@@ -107,13 +158,8 @@ int iterate_inodes_from_logical(u64 logical, struct btrfs_fs_info *fs_info,
int paths_from_inode(u64 inum, struct inode_fs_paths *ipath); int paths_from_inode(u64 inum, struct inode_fs_paths *ipath);
int btrfs_find_all_leafs(struct btrfs_trans_handle *trans, int btrfs_find_all_leafs(struct btrfs_backref_walk_ctx *ctx);
struct btrfs_fs_info *fs_info, u64 bytenr, int btrfs_find_all_roots(struct btrfs_backref_walk_ctx *ctx,
u64 time_seq, struct ulist **leafs,
u64 extent_item_pos);
int btrfs_find_all_roots(struct btrfs_trans_handle *trans,
struct btrfs_fs_info *fs_info, u64 bytenr,
u64 time_seq, struct ulist **roots,
bool skip_commit_root_sem); bool skip_commit_root_sem);
char *btrfs_ref_to_path(struct btrfs_root *fs_root, struct btrfs_path *path, char *btrfs_ref_to_path(struct btrfs_root *fs_root, struct btrfs_path *path,
u32 name_len, unsigned long name_off, u32 name_len, unsigned long name_off,
......
...@@ -1794,8 +1794,7 @@ int btrfs_qgroup_trace_extent_nolock(struct btrfs_fs_info *fs_info, ...@@ -1794,8 +1794,7 @@ int btrfs_qgroup_trace_extent_nolock(struct btrfs_fs_info *fs_info,
int btrfs_qgroup_trace_extent_post(struct btrfs_trans_handle *trans, int btrfs_qgroup_trace_extent_post(struct btrfs_trans_handle *trans,
struct btrfs_qgroup_extent_record *qrecord) struct btrfs_qgroup_extent_record *qrecord)
{ {
struct ulist *old_root; struct btrfs_backref_walk_ctx ctx = { 0 };
u64 bytenr = qrecord->bytenr;
int ret; int ret;
/* /*
...@@ -1822,8 +1821,10 @@ int btrfs_qgroup_trace_extent_post(struct btrfs_trans_handle *trans, ...@@ -1822,8 +1821,10 @@ int btrfs_qgroup_trace_extent_post(struct btrfs_trans_handle *trans,
if (trans->fs_info->qgroup_flags & BTRFS_QGROUP_RUNTIME_FLAG_NO_ACCOUNTING) if (trans->fs_info->qgroup_flags & BTRFS_QGROUP_RUNTIME_FLAG_NO_ACCOUNTING)
return 0; return 0;
ret = btrfs_find_all_roots(NULL, trans->fs_info, bytenr, 0, &old_root, ctx.bytenr = qrecord->bytenr;
true); ctx.fs_info = trans->fs_info;
ret = btrfs_find_all_roots(&ctx, true);
if (ret < 0) { if (ret < 0) {
qgroup_mark_inconsistent(trans->fs_info); qgroup_mark_inconsistent(trans->fs_info);
btrfs_warn(trans->fs_info, btrfs_warn(trans->fs_info,
...@@ -1839,7 +1840,7 @@ int btrfs_qgroup_trace_extent_post(struct btrfs_trans_handle *trans, ...@@ -1839,7 +1840,7 @@ int btrfs_qgroup_trace_extent_post(struct btrfs_trans_handle *trans,
* *
* So modifying qrecord->old_roots is safe here * So modifying qrecord->old_roots is safe here
*/ */
qrecord->old_roots = old_root; qrecord->old_roots = ctx.roots;
return 0; return 0;
} }
...@@ -2750,17 +2751,22 @@ int btrfs_qgroup_account_extents(struct btrfs_trans_handle *trans) ...@@ -2750,17 +2751,22 @@ int btrfs_qgroup_account_extents(struct btrfs_trans_handle *trans)
if (!ret && !(fs_info->qgroup_flags & if (!ret && !(fs_info->qgroup_flags &
BTRFS_QGROUP_RUNTIME_FLAG_NO_ACCOUNTING)) { BTRFS_QGROUP_RUNTIME_FLAG_NO_ACCOUNTING)) {
struct btrfs_backref_walk_ctx ctx = { 0 };
ctx.bytenr = record->bytenr;
ctx.fs_info = fs_info;
/* /*
* Old roots should be searched when inserting qgroup * Old roots should be searched when inserting qgroup
* extent record * extent record
*/ */
if (WARN_ON(!record->old_roots)) { if (WARN_ON(!record->old_roots)) {
/* Search commit root to find old_roots */ /* Search commit root to find old_roots */
ret = btrfs_find_all_roots(NULL, fs_info, ret = btrfs_find_all_roots(&ctx, false);
record->bytenr, 0,
&record->old_roots, false);
if (ret < 0) if (ret < 0)
goto cleanup; goto cleanup;
record->old_roots = ctx.roots;
ctx.roots = NULL;
} }
/* Free the reserved data space */ /* Free the reserved data space */
...@@ -2773,10 +2779,11 @@ int btrfs_qgroup_account_extents(struct btrfs_trans_handle *trans) ...@@ -2773,10 +2779,11 @@ int btrfs_qgroup_account_extents(struct btrfs_trans_handle *trans)
* which doesn't lock tree or delayed_refs and search * which doesn't lock tree or delayed_refs and search
* current root. It's safe inside commit_transaction(). * current root. It's safe inside commit_transaction().
*/ */
ret = btrfs_find_all_roots(trans, fs_info, ctx.trans = trans;
record->bytenr, BTRFS_SEQ_LAST, &new_roots, false); ret = btrfs_find_all_roots(&ctx, false);
if (ret < 0) if (ret < 0)
goto cleanup; goto cleanup;
new_roots = ctx.roots;
if (qgroup_to_skip) { if (qgroup_to_skip) {
ulist_del(new_roots, qgroup_to_skip, 0); ulist_del(new_roots, qgroup_to_skip, 0);
ulist_del(record->old_roots, qgroup_to_skip, ulist_del(record->old_roots, qgroup_to_skip,
...@@ -3242,7 +3249,6 @@ static int qgroup_rescan_leaf(struct btrfs_trans_handle *trans, ...@@ -3242,7 +3249,6 @@ static int qgroup_rescan_leaf(struct btrfs_trans_handle *trans,
struct btrfs_root *extent_root; struct btrfs_root *extent_root;
struct btrfs_key found; struct btrfs_key found;
struct extent_buffer *scratch_leaf = NULL; struct extent_buffer *scratch_leaf = NULL;
struct ulist *roots = NULL;
u64 num_bytes; u64 num_bytes;
bool done; bool done;
int slot; int slot;
...@@ -3292,6 +3298,8 @@ static int qgroup_rescan_leaf(struct btrfs_trans_handle *trans, ...@@ -3292,6 +3298,8 @@ static int qgroup_rescan_leaf(struct btrfs_trans_handle *trans,
mutex_unlock(&fs_info->qgroup_rescan_lock); mutex_unlock(&fs_info->qgroup_rescan_lock);
for (; slot < btrfs_header_nritems(scratch_leaf); ++slot) { for (; slot < btrfs_header_nritems(scratch_leaf); ++slot) {
struct btrfs_backref_walk_ctx ctx = { 0 };
btrfs_item_key_to_cpu(scratch_leaf, &found, slot); btrfs_item_key_to_cpu(scratch_leaf, &found, slot);
if (found.type != BTRFS_EXTENT_ITEM_KEY && if (found.type != BTRFS_EXTENT_ITEM_KEY &&
found.type != BTRFS_METADATA_ITEM_KEY) found.type != BTRFS_METADATA_ITEM_KEY)
...@@ -3301,13 +3309,15 @@ static int qgroup_rescan_leaf(struct btrfs_trans_handle *trans, ...@@ -3301,13 +3309,15 @@ static int qgroup_rescan_leaf(struct btrfs_trans_handle *trans,
else else
num_bytes = found.offset; num_bytes = found.offset;
ret = btrfs_find_all_roots(NULL, fs_info, found.objectid, 0, ctx.bytenr = found.objectid;
&roots, false); ctx.fs_info = fs_info;
ret = btrfs_find_all_roots(&ctx, false);
if (ret < 0) if (ret < 0)
goto out; goto out;
/* For rescan, just pass old_roots as NULL */ /* For rescan, just pass old_roots as NULL */
ret = btrfs_qgroup_account_extent(trans, found.objectid, ret = btrfs_qgroup_account_extent(trans, found.objectid,
num_bytes, NULL, roots); num_bytes, NULL, ctx.roots);
if (ret < 0) if (ret < 0)
goto out; goto out;
} }
......
...@@ -3408,24 +3408,27 @@ int add_data_references(struct reloc_control *rc, ...@@ -3408,24 +3408,27 @@ int add_data_references(struct reloc_control *rc,
struct btrfs_path *path, struct btrfs_path *path,
struct rb_root *blocks) struct rb_root *blocks)
{ {
struct btrfs_fs_info *fs_info = rc->extent_root->fs_info; struct btrfs_backref_walk_ctx ctx = { 0 };
struct ulist *leaves = NULL;
struct ulist_iterator leaf_uiter; struct ulist_iterator leaf_uiter;
struct ulist_node *ref_node = NULL; struct ulist_node *ref_node = NULL;
const u32 blocksize = fs_info->nodesize; const u32 blocksize = rc->extent_root->fs_info->nodesize;
int ret = 0; int ret = 0;
btrfs_release_path(path); btrfs_release_path(path);
ret = btrfs_find_all_leafs(NULL, fs_info, extent_key->objectid,
0, &leaves, BTRFS_IGNORE_EXTENT_OFFSET); ctx.bytenr = extent_key->objectid;
ctx.ignore_extent_item_pos = true;
ctx.fs_info = rc->extent_root->fs_info;
ret = btrfs_find_all_leafs(&ctx);
if (ret < 0) if (ret < 0)
return ret; return ret;
ULIST_ITER_INIT(&leaf_uiter); ULIST_ITER_INIT(&leaf_uiter);
while ((ref_node = ulist_next(leaves, &leaf_uiter))) { while ((ref_node = ulist_next(ctx.refs, &leaf_uiter))) {
struct extent_buffer *eb; struct extent_buffer *eb;
eb = read_tree_block(fs_info, ref_node->val, 0, 0, 0, NULL); eb = read_tree_block(ctx.fs_info, ref_node->val, 0, 0, 0, NULL);
if (IS_ERR(eb)) { if (IS_ERR(eb)) {
ret = PTR_ERR(eb); ret = PTR_ERR(eb);
break; break;
...@@ -3441,7 +3444,7 @@ int add_data_references(struct reloc_control *rc, ...@@ -3441,7 +3444,7 @@ int add_data_references(struct reloc_control *rc,
} }
if (ret < 0) if (ret < 0)
free_block_list(blocks); free_block_list(blocks);
ulist_free(leaves); ulist_free(ctx.refs);
return ret; return ret;
} }
......
...@@ -909,7 +909,6 @@ static void scrub_print_warning(const char *errstr, struct scrub_block *sblock) ...@@ -909,7 +909,6 @@ static void scrub_print_warning(const char *errstr, struct scrub_block *sblock)
struct btrfs_extent_item *ei; struct btrfs_extent_item *ei;
struct scrub_warning swarn; struct scrub_warning swarn;
unsigned long ptr = 0; unsigned long ptr = 0;
u64 extent_item_pos;
u64 flags = 0; u64 flags = 0;
u64 ref_root; u64 ref_root;
u32 item_size; u32 item_size;
...@@ -941,7 +940,6 @@ static void scrub_print_warning(const char *errstr, struct scrub_block *sblock) ...@@ -941,7 +940,6 @@ static void scrub_print_warning(const char *errstr, struct scrub_block *sblock)
if (ret < 0) if (ret < 0)
goto out; goto out;
extent_item_pos = swarn.logical - found_key.objectid;
swarn.extent_item_size = found_key.offset; swarn.extent_item_size = found_key.offset;
eb = path->nodes[0]; eb = path->nodes[0];
...@@ -964,12 +962,18 @@ static void scrub_print_warning(const char *errstr, struct scrub_block *sblock) ...@@ -964,12 +962,18 @@ static void scrub_print_warning(const char *errstr, struct scrub_block *sblock)
} while (ret != 1); } while (ret != 1);
btrfs_release_path(path); btrfs_release_path(path);
} else { } else {
struct btrfs_backref_walk_ctx ctx = { 0 };
btrfs_release_path(path); btrfs_release_path(path);
ctx.bytenr = found_key.objectid;
ctx.extent_item_pos = swarn.logical - found_key.objectid;
ctx.fs_info = fs_info;
swarn.path = path; swarn.path = path;
swarn.dev = dev; swarn.dev = dev;
iterate_extent_inodes(fs_info, found_key.objectid,
extent_item_pos, 1, iterate_extent_inodes(&ctx, true, scrub_print_warning_inode, &swarn);
scrub_print_warning_inode, &swarn);
} }
out: out:
......
...@@ -1356,12 +1356,12 @@ static int find_extent_clone(struct send_ctx *sctx, ...@@ -1356,12 +1356,12 @@ static int find_extent_clone(struct send_ctx *sctx,
u64 logical; u64 logical;
u64 disk_byte; u64 disk_byte;
u64 num_bytes; u64 num_bytes;
u64 extent_item_pos;
u64 extent_refs; u64 extent_refs;
u64 flags = 0; u64 flags = 0;
struct btrfs_file_extent_item *fi; struct btrfs_file_extent_item *fi;
struct extent_buffer *eb = path->nodes[0]; struct extent_buffer *eb = path->nodes[0];
struct backref_ctx backref_ctx = {0}; struct backref_ctx backref_ctx = { 0 };
struct btrfs_backref_walk_ctx backref_walk_ctx = { 0 };
struct clone_root *cur_clone_root; struct clone_root *cur_clone_root;
struct btrfs_key found_key; struct btrfs_key found_key;
struct btrfs_path *tmp_path; struct btrfs_path *tmp_path;
...@@ -1461,14 +1461,13 @@ static int find_extent_clone(struct send_ctx *sctx, ...@@ -1461,14 +1461,13 @@ static int find_extent_clone(struct send_ctx *sctx,
/* /*
* Now collect all backrefs. * Now collect all backrefs.
*/ */
backref_walk_ctx.bytenr = found_key.objectid;
if (compressed == BTRFS_COMPRESS_NONE) if (compressed == BTRFS_COMPRESS_NONE)
extent_item_pos = logical - found_key.objectid; backref_walk_ctx.extent_item_pos = logical - found_key.objectid;
else backref_walk_ctx.fs_info = fs_info;
extent_item_pos = 0;
ret = iterate_extent_inodes(fs_info, found_key.objectid,
extent_item_pos, 1, __iterate_backrefs,
&backref_ctx);
ret = iterate_extent_inodes(&backref_walk_ctx, true, __iterate_backrefs,
&backref_ctx);
if (ret < 0) if (ret < 0)
goto out; goto out;
......
...@@ -205,6 +205,7 @@ static int remove_extent_ref(struct btrfs_root *root, u64 bytenr, ...@@ -205,6 +205,7 @@ static int remove_extent_ref(struct btrfs_root *root, u64 bytenr,
static int test_no_shared_qgroup(struct btrfs_root *root, static int test_no_shared_qgroup(struct btrfs_root *root,
u32 sectorsize, u32 nodesize) u32 sectorsize, u32 nodesize)
{ {
struct btrfs_backref_walk_ctx ctx = { 0 };
struct btrfs_trans_handle trans; struct btrfs_trans_handle trans;
struct btrfs_fs_info *fs_info = root->fs_info; struct btrfs_fs_info *fs_info = root->fs_info;
struct ulist *old_roots = NULL; struct ulist *old_roots = NULL;
...@@ -220,16 +221,22 @@ static int test_no_shared_qgroup(struct btrfs_root *root, ...@@ -220,16 +221,22 @@ static int test_no_shared_qgroup(struct btrfs_root *root,
return ret; return ret;
} }
ctx.bytenr = nodesize;
ctx.trans = &trans;
ctx.fs_info = fs_info;
/* /*
* Since the test trans doesn't have the complicated delayed refs, * Since the test trans doesn't have the complicated delayed refs,
* we can only call btrfs_qgroup_account_extent() directly to test * we can only call btrfs_qgroup_account_extent() directly to test
* quota. * quota.
*/ */
ret = btrfs_find_all_roots(&trans, fs_info, nodesize, 0, &old_roots, false); ret = btrfs_find_all_roots(&ctx, false);
if (ret) { if (ret) {
test_err("couldn't find old roots: %d", ret); test_err("couldn't find old roots: %d", ret);
return ret; return ret;
} }
old_roots = ctx.roots;
ctx.roots = NULL;
ret = insert_normal_tree_ref(root, nodesize, nodesize, 0, ret = insert_normal_tree_ref(root, nodesize, nodesize, 0,
BTRFS_FS_TREE_OBJECTID); BTRFS_FS_TREE_OBJECTID);
...@@ -238,12 +245,14 @@ static int test_no_shared_qgroup(struct btrfs_root *root, ...@@ -238,12 +245,14 @@ static int test_no_shared_qgroup(struct btrfs_root *root,
return ret; return ret;
} }
ret = btrfs_find_all_roots(&trans, fs_info, nodesize, 0, &new_roots, false); ret = btrfs_find_all_roots(&ctx, false);
if (ret) { if (ret) {
ulist_free(old_roots); ulist_free(old_roots);
test_err("couldn't find old roots: %d", ret); test_err("couldn't find old roots: %d", ret);
return ret; return ret;
} }
new_roots = ctx.roots;
ctx.roots = NULL;
ret = btrfs_qgroup_account_extent(&trans, nodesize, nodesize, old_roots, ret = btrfs_qgroup_account_extent(&trans, nodesize, nodesize, old_roots,
new_roots); new_roots);
...@@ -262,11 +271,13 @@ static int test_no_shared_qgroup(struct btrfs_root *root, ...@@ -262,11 +271,13 @@ static int test_no_shared_qgroup(struct btrfs_root *root,
return -EINVAL; return -EINVAL;
} }
ret = btrfs_find_all_roots(&trans, fs_info, nodesize, 0, &old_roots, false); ret = btrfs_find_all_roots(&ctx, false);
if (ret) { if (ret) {
test_err("couldn't find old roots: %d", ret); test_err("couldn't find old roots: %d", ret);
return ret; return ret;
} }
old_roots = ctx.roots;
ctx.roots = NULL;
ret = remove_extent_item(root, nodesize, nodesize); ret = remove_extent_item(root, nodesize, nodesize);
if (ret) { if (ret) {
...@@ -274,12 +285,14 @@ static int test_no_shared_qgroup(struct btrfs_root *root, ...@@ -274,12 +285,14 @@ static int test_no_shared_qgroup(struct btrfs_root *root,
return -EINVAL; return -EINVAL;
} }
ret = btrfs_find_all_roots(&trans, fs_info, nodesize, 0, &new_roots, false); ret = btrfs_find_all_roots(&ctx, false);
if (ret) { if (ret) {
ulist_free(old_roots); ulist_free(old_roots);
test_err("couldn't find old roots: %d", ret); test_err("couldn't find old roots: %d", ret);
return ret; return ret;
} }
new_roots = ctx.roots;
ctx.roots = NULL;
ret = btrfs_qgroup_account_extent(&trans, nodesize, nodesize, old_roots, ret = btrfs_qgroup_account_extent(&trans, nodesize, nodesize, old_roots,
new_roots); new_roots);
...@@ -304,6 +317,7 @@ static int test_no_shared_qgroup(struct btrfs_root *root, ...@@ -304,6 +317,7 @@ static int test_no_shared_qgroup(struct btrfs_root *root,
static int test_multiple_refs(struct btrfs_root *root, static int test_multiple_refs(struct btrfs_root *root,
u32 sectorsize, u32 nodesize) u32 sectorsize, u32 nodesize)
{ {
struct btrfs_backref_walk_ctx ctx = { 0 };
struct btrfs_trans_handle trans; struct btrfs_trans_handle trans;
struct btrfs_fs_info *fs_info = root->fs_info; struct btrfs_fs_info *fs_info = root->fs_info;
struct ulist *old_roots = NULL; struct ulist *old_roots = NULL;
...@@ -324,11 +338,17 @@ static int test_multiple_refs(struct btrfs_root *root, ...@@ -324,11 +338,17 @@ static int test_multiple_refs(struct btrfs_root *root,
return ret; return ret;
} }
ret = btrfs_find_all_roots(&trans, fs_info, nodesize, 0, &old_roots, false); ctx.bytenr = nodesize;
ctx.trans = &trans;
ctx.fs_info = fs_info;
ret = btrfs_find_all_roots(&ctx, false);
if (ret) { if (ret) {
test_err("couldn't find old roots: %d", ret); test_err("couldn't find old roots: %d", ret);
return ret; return ret;
} }
old_roots = ctx.roots;
ctx.roots = NULL;
ret = insert_normal_tree_ref(root, nodesize, nodesize, 0, ret = insert_normal_tree_ref(root, nodesize, nodesize, 0,
BTRFS_FS_TREE_OBJECTID); BTRFS_FS_TREE_OBJECTID);
...@@ -337,12 +357,14 @@ static int test_multiple_refs(struct btrfs_root *root, ...@@ -337,12 +357,14 @@ static int test_multiple_refs(struct btrfs_root *root,
return ret; return ret;
} }
ret = btrfs_find_all_roots(&trans, fs_info, nodesize, 0, &new_roots, false); ret = btrfs_find_all_roots(&ctx, false);
if (ret) { if (ret) {
ulist_free(old_roots); ulist_free(old_roots);
test_err("couldn't find old roots: %d", ret); test_err("couldn't find old roots: %d", ret);
return ret; return ret;
} }
new_roots = ctx.roots;
ctx.roots = NULL;
ret = btrfs_qgroup_account_extent(&trans, nodesize, nodesize, old_roots, ret = btrfs_qgroup_account_extent(&trans, nodesize, nodesize, old_roots,
new_roots); new_roots);
...@@ -357,11 +379,13 @@ static int test_multiple_refs(struct btrfs_root *root, ...@@ -357,11 +379,13 @@ static int test_multiple_refs(struct btrfs_root *root,
return -EINVAL; return -EINVAL;
} }
ret = btrfs_find_all_roots(&trans, fs_info, nodesize, 0, &old_roots, false); ret = btrfs_find_all_roots(&ctx, false);
if (ret) { if (ret) {
test_err("couldn't find old roots: %d", ret); test_err("couldn't find old roots: %d", ret);
return ret; return ret;
} }
old_roots = ctx.roots;
ctx.roots = NULL;
ret = add_tree_ref(root, nodesize, nodesize, 0, ret = add_tree_ref(root, nodesize, nodesize, 0,
BTRFS_FIRST_FREE_OBJECTID); BTRFS_FIRST_FREE_OBJECTID);
...@@ -370,12 +394,14 @@ static int test_multiple_refs(struct btrfs_root *root, ...@@ -370,12 +394,14 @@ static int test_multiple_refs(struct btrfs_root *root,
return ret; return ret;
} }
ret = btrfs_find_all_roots(&trans, fs_info, nodesize, 0, &new_roots, false); ret = btrfs_find_all_roots(&ctx, false);
if (ret) { if (ret) {
ulist_free(old_roots); ulist_free(old_roots);
test_err("couldn't find old roots: %d", ret); test_err("couldn't find old roots: %d", ret);
return ret; return ret;
} }
new_roots = ctx.roots;
ctx.roots = NULL;
ret = btrfs_qgroup_account_extent(&trans, nodesize, nodesize, old_roots, ret = btrfs_qgroup_account_extent(&trans, nodesize, nodesize, old_roots,
new_roots); new_roots);
...@@ -396,11 +422,13 @@ static int test_multiple_refs(struct btrfs_root *root, ...@@ -396,11 +422,13 @@ static int test_multiple_refs(struct btrfs_root *root,
return -EINVAL; return -EINVAL;
} }
ret = btrfs_find_all_roots(&trans, fs_info, nodesize, 0, &old_roots, false); ret = btrfs_find_all_roots(&ctx, false);
if (ret) { if (ret) {
test_err("couldn't find old roots: %d", ret); test_err("couldn't find old roots: %d", ret);
return ret; return ret;
} }
old_roots = ctx.roots;
ctx.roots = NULL;
ret = remove_extent_ref(root, nodesize, nodesize, 0, ret = remove_extent_ref(root, nodesize, nodesize, 0,
BTRFS_FIRST_FREE_OBJECTID); BTRFS_FIRST_FREE_OBJECTID);
...@@ -409,12 +437,14 @@ static int test_multiple_refs(struct btrfs_root *root, ...@@ -409,12 +437,14 @@ static int test_multiple_refs(struct btrfs_root *root,
return ret; return ret;
} }
ret = btrfs_find_all_roots(&trans, fs_info, nodesize, 0, &new_roots, false); ret = btrfs_find_all_roots(&ctx, false);
if (ret) { if (ret) {
ulist_free(old_roots); ulist_free(old_roots);
test_err("couldn't find old roots: %d", ret); test_err("couldn't find old roots: %d", ret);
return ret; return ret;
} }
new_roots = ctx.roots;
ctx.roots = NULL;
ret = btrfs_qgroup_account_extent(&trans, nodesize, nodesize, old_roots, ret = btrfs_qgroup_account_extent(&trans, nodesize, nodesize, old_roots,
new_roots); new_roots);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment