Skip to content

Commit

Permalink
btrfs: print the actual offset in btrfs_root_name
Browse files Browse the repository at this point in the history
We're supposed to print the root_key.offset in btrfs_root_name in the
case of a reloc root, not the objectid.  Fix this helper to take the key
so we have access to the offset when we need it.

Fixes: 457f186 ("btrfs: pretty print leaked root name")
Reviewed-by: Qu Wenruo <[email protected]>
Reviewed-by: Nikolay Borisov <[email protected]>
Signed-off-by: Josef Bacik <[email protected]>
Reviewed-by: David Sterba <[email protected]>
Signed-off-by: David Sterba <[email protected]>
  • Loading branch information
josefbacik authored and kdave committed Jan 7, 2021
1 parent a8cc263 commit 7100873
Show file tree
Hide file tree
Showing 3 changed files with 7 additions and 7 deletions.
2 changes: 1 addition & 1 deletion fs/btrfs/disk-io.c
Original file line number Diff line number Diff line change
Expand Up @@ -1457,7 +1457,7 @@ void btrfs_check_leaked_roots(struct btrfs_fs_info *fs_info)
root = list_first_entry(&fs_info->allocated_roots,
struct btrfs_root, leak_list);
btrfs_err(fs_info, "leaked root %s refcount %d",
btrfs_root_name(root->root_key.objectid, buf),
btrfs_root_name(&root->root_key, buf),
refcount_read(&root->refs));
while (refcount_read(&root->refs) > 1)
btrfs_put_root(root);
Expand Down
10 changes: 5 additions & 5 deletions fs/btrfs/print-tree.c
Original file line number Diff line number Diff line change
Expand Up @@ -26,22 +26,22 @@ static const struct root_name_map root_map[] = {
{ BTRFS_DATA_RELOC_TREE_OBJECTID, "DATA_RELOC_TREE" },
};

const char *btrfs_root_name(u64 objectid, char *buf)
const char *btrfs_root_name(const struct btrfs_key *key, char *buf)
{
int i;

if (objectid == BTRFS_TREE_RELOC_OBJECTID) {
if (key->objectid == BTRFS_TREE_RELOC_OBJECTID) {
snprintf(buf, BTRFS_ROOT_NAME_BUF_LEN,
"TREE_RELOC offset=%llu", objectid);
"TREE_RELOC offset=%llu", key->offset);
return buf;
}

for (i = 0; i < ARRAY_SIZE(root_map); i++) {
if (root_map[i].id == objectid)
if (root_map[i].id == key->objectid)
return root_map[i].name;
}

snprintf(buf, BTRFS_ROOT_NAME_BUF_LEN, "%llu", objectid);
snprintf(buf, BTRFS_ROOT_NAME_BUF_LEN, "%llu", key->objectid);
return buf;
}

Expand Down
2 changes: 1 addition & 1 deletion fs/btrfs/print-tree.h
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,6 @@

void btrfs_print_leaf(struct extent_buffer *l);
void btrfs_print_tree(struct extent_buffer *c, bool follow);
const char *btrfs_root_name(u64 objectid, char *buf);
const char *btrfs_root_name(const struct btrfs_key *key, char *buf);

#endif

0 comments on commit 7100873

Please sign in to comment.