diff options
author | Wang Shilong <wangsl.fnst@cn.fujitsu.com> | 2014-01-09 20:42:12 +0800 |
---|---|---|
committer | Chris Mason <clm@fb.com> | 2014-01-31 08:22:22 -0800 |
commit | 4f5ebb3ef55396ef976d3245e2cdf9860680df74 (patch) | |
tree | e8ef0f10d04bc0de538feefe210243715bbd6e9a /btrfs-list.c | |
parent | 62d02453e40ff1ab8d942853fa4919a54eaf4f90 (diff) |
Btrfs-progs: fix to make list specified directory's subvolumes work
Steps to reproduce:
# mkfs.btrfs -f /dev/sda8
# mount /dev/sda8 /mnt
# mkdir /mnt/subvolumes
# btrfs sub create /mnt/subvolumes/subv1
# btrfs sub create /mnt/subvolumes/subv1/subv1.1
# btrfs sub list -o /mnt/subvolumes/subv1 <----we did not list anything
The problem is that we don't set @top_id right, fix it.
Reported-by: Alex <alex@bpmit.com>
Signed-off-by: Wang Shilong <wangsl.fnst@cn.fujitsu.com>
Signed-off-by: David Sterba <dsterba@suse.cz>
Signed-off-by: Chris Mason <clm@fb.com>
Diffstat (limited to 'btrfs-list.c')
-rw-r--r-- | btrfs-list.c | 13 |
1 files changed, 4 insertions, 9 deletions
diff --git a/btrfs-list.c b/btrfs-list.c index fa69910b..9effb27a 100644 --- a/btrfs-list.c +++ b/btrfs-list.c @@ -578,23 +578,18 @@ static int resolve_root(struct root_lookup *rl, struct root_info *ri, full_path = strdup(found->path); len = add_len; } + if (!ri->top_id) + ri->top_id = found->ref_tree; next = found->ref_tree; - - if (next == top_id) { - ri->top_id = top_id; + if (next == top_id) break; - } - /* * if the ref_tree = BTRFS_FS_TREE_OBJECTID, * we are at the top */ - if (next == BTRFS_FS_TREE_OBJECTID) { - ri->top_id = next; + if (next == BTRFS_FS_TREE_OBJECTID) break; - } - /* * if the ref_tree wasn't in our tree of roots, the * subvolume was deleted. |