Commit cfc0eed0 authored by ethanwu's avatar ethanwu Committed by David Sterba

btrfs: backref, only search backref entries from leaves of the same root

We could have some nodes/leaves in subvolume whose owner are not the
that subvolume. In this way, when we resolve normal backrefs of that
subvolume, we should avoid collecting those references from these blocks.
Reviewed-by: default avatarJosef Bacik <josef@toxicpanda.com>
Reviewed-by: default avatarJohannes Thumshirn <johannes.thumshirn@wdc.com>
Signed-off-by: default avatarethanwu <ethanwu@synology.com>
Signed-off-by: default avatarDavid Sterba <dsterba@suse.com>
parent ed58f2e6
...@@ -443,11 +443,14 @@ static int add_all_parents(struct btrfs_root *root, struct btrfs_path *path, ...@@ -443,11 +443,14 @@ static int add_all_parents(struct btrfs_root *root, struct btrfs_path *path,
* slot == nritems. * slot == nritems.
* 2. We are searching for normal backref but bytenr of this leaf * 2. We are searching for normal backref but bytenr of this leaf
* matches shared data backref * matches shared data backref
* 3. The leaf owner is not equal to the root we are searching
*
* For these cases, go to the next leaf before we continue. * For these cases, go to the next leaf before we continue.
*/ */
eb = path->nodes[0]; eb = path->nodes[0];
if (path->slots[0] >= btrfs_header_nritems(eb) || if (path->slots[0] >= btrfs_header_nritems(eb) ||
is_shared_data_backref(preftrees, eb->start)) { is_shared_data_backref(preftrees, eb->start) ||
ref->root_id != btrfs_header_owner(eb)) {
if (time_seq == SEQ_LAST) if (time_seq == SEQ_LAST)
ret = btrfs_next_leaf(root, path); ret = btrfs_next_leaf(root, path);
else else
...@@ -466,9 +469,12 @@ static int add_all_parents(struct btrfs_root *root, struct btrfs_path *path, ...@@ -466,9 +469,12 @@ static int add_all_parents(struct btrfs_root *root, struct btrfs_path *path,
/* /*
* We are searching for normal backref but bytenr of this leaf * We are searching for normal backref but bytenr of this leaf
* matches shared data backref. * matches shared data backref, OR
* the leaf owner is not equal to the root we are searching for
*/ */
if (slot == 0 && is_shared_data_backref(preftrees, eb->start)) { if (slot == 0 &&
(is_shared_data_backref(preftrees, eb->start) ||
ref->root_id != btrfs_header_owner(eb))) {
if (time_seq == SEQ_LAST) if (time_seq == SEQ_LAST)
ret = btrfs_next_leaf(root, path); ret = btrfs_next_leaf(root, path);
else else
......
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