diff options
author | Arne Jansen <sensille@gmx.net> | 2011-09-14 08:01:24 -0400 |
---|---|---|
committer | Jan Schmidt <list.btrfs@jan-o-sch.net> | 2011-12-22 10:22:28 -0500 |
commit | eebe063b7f916087cd5c61de57b20a3a30894a96 (patch) | |
tree | d49c4a91abd9bef6f2fd546715f719c66ae1fd90 /fs/btrfs/delayed-ref.c | |
parent | 66d7e7f09f77456fe68683247d77721032a00ee5 (diff) |
Btrfs: always save ref_root in delayed refs
For consistent backref walking and (later) qgroup calculation the
information to which root a delayed ref belongs is useful even for shared
refs.
Signed-off-by: Arne Jansen <sensille@gmx.net>
Signed-off-by: Jan Schmidt <list.btrfs@jan-o-sch.net>
Diffstat (limited to 'fs/btrfs/delayed-ref.c')
-rw-r--r-- | fs/btrfs/delayed-ref.c | 18 |
1 files changed, 8 insertions, 10 deletions
diff --git a/fs/btrfs/delayed-ref.c b/fs/btrfs/delayed-ref.c index 3a0f0ab804f4..babd37badb43 100644 --- a/fs/btrfs/delayed-ref.c +++ b/fs/btrfs/delayed-ref.c | |||
@@ -495,13 +495,12 @@ static noinline int add_delayed_tree_ref(struct btrfs_fs_info *fs_info, | |||
495 | ref->in_tree = 1; | 495 | ref->in_tree = 1; |
496 | 496 | ||
497 | full_ref = btrfs_delayed_node_to_tree_ref(ref); | 497 | full_ref = btrfs_delayed_node_to_tree_ref(ref); |
498 | if (parent) { | 498 | full_ref->parent = parent; |
499 | full_ref->parent = parent; | 499 | full_ref->root = ref_root; |
500 | if (parent) | ||
500 | ref->type = BTRFS_SHARED_BLOCK_REF_KEY; | 501 | ref->type = BTRFS_SHARED_BLOCK_REF_KEY; |
501 | } else { | 502 | else |
502 | full_ref->root = ref_root; | ||
503 | ref->type = BTRFS_TREE_BLOCK_REF_KEY; | 503 | ref->type = BTRFS_TREE_BLOCK_REF_KEY; |
504 | } | ||
505 | full_ref->level = level; | 504 | full_ref->level = level; |
506 | 505 | ||
507 | trace_btrfs_delayed_tree_ref(ref, full_ref, action); | 506 | trace_btrfs_delayed_tree_ref(ref, full_ref, action); |
@@ -551,13 +550,12 @@ static noinline int add_delayed_data_ref(struct btrfs_fs_info *fs_info, | |||
551 | ref->in_tree = 1; | 550 | ref->in_tree = 1; |
552 | 551 | ||
553 | full_ref = btrfs_delayed_node_to_data_ref(ref); | 552 | full_ref = btrfs_delayed_node_to_data_ref(ref); |
554 | if (parent) { | 553 | full_ref->parent = parent; |
555 | full_ref->parent = parent; | 554 | full_ref->root = ref_root; |
555 | if (parent) | ||
556 | ref->type = BTRFS_SHARED_DATA_REF_KEY; | 556 | ref->type = BTRFS_SHARED_DATA_REF_KEY; |
557 | } else { | 557 | else |
558 | full_ref->root = ref_root; | ||
559 | ref->type = BTRFS_EXTENT_DATA_REF_KEY; | 558 | ref->type = BTRFS_EXTENT_DATA_REF_KEY; |
560 | } | ||
561 | 559 | ||
562 | full_ref->objectid = owner; | 560 | full_ref->objectid = owner; |
563 | full_ref->offset = offset; | 561 | full_ref->offset = offset; |