Commit 88dfe193 authored by Kent Overstreet's avatar Kent Overstreet

bcachefs: bch2_btree_id_str()

Since we can run with unknown btree IDs, we can't directly index btree
IDs into fixed size arrays.
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent b0b5bbf9
...@@ -727,7 +727,7 @@ static int bch2_bucket_do_index(struct btree_trans *trans, ...@@ -727,7 +727,7 @@ static int bch2_bucket_do_index(struct btree_trans *trans,
"incorrect key when %s %s:%llu:%llu:0 (got %s should be %s)\n" "incorrect key when %s %s:%llu:%llu:0 (got %s should be %s)\n"
" for %s", " for %s",
set ? "setting" : "clearing", set ? "setting" : "clearing",
bch2_btree_ids[btree], bch2_btree_id_str(btree),
iter.pos.inode, iter.pos.inode,
iter.pos.offset, iter.pos.offset,
bch2_bkey_types[old.k->type], bch2_bkey_types[old.k->type],
...@@ -1245,7 +1245,7 @@ static noinline_for_stack int __bch2_check_discard_freespace_key(struct btree_tr ...@@ -1245,7 +1245,7 @@ static noinline_for_stack int __bch2_check_discard_freespace_key(struct btree_tr
if (fsck_err_on(!bch2_dev_bucket_exists(c, pos), c, if (fsck_err_on(!bch2_dev_bucket_exists(c, pos), c,
"entry in %s btree for nonexistant dev:bucket %llu:%llu", "entry in %s btree for nonexistant dev:bucket %llu:%llu",
bch2_btree_ids[iter->btree_id], pos.inode, pos.offset)) bch2_btree_id_str(iter->btree_id), pos.inode, pos.offset))
goto delete; goto delete;
a = bch2_alloc_to_v4(alloc_k, &a_convert); a = bch2_alloc_to_v4(alloc_k, &a_convert);
...@@ -1255,7 +1255,7 @@ static noinline_for_stack int __bch2_check_discard_freespace_key(struct btree_tr ...@@ -1255,7 +1255,7 @@ static noinline_for_stack int __bch2_check_discard_freespace_key(struct btree_tr
genbits != alloc_freespace_genbits(*a)), c, genbits != alloc_freespace_genbits(*a)), c,
"%s\n incorrectly set at %s:%llu:%llu:0 (free %u, genbits %llu should be %llu)", "%s\n incorrectly set at %s:%llu:%llu:0 (free %u, genbits %llu should be %llu)",
(bch2_bkey_val_to_text(&buf, c, alloc_k), buf.buf), (bch2_bkey_val_to_text(&buf, c, alloc_k), buf.buf),
bch2_btree_ids[iter->btree_id], bch2_btree_id_str(iter->btree_id),
iter->pos.inode, iter->pos.inode,
iter->pos.offset, iter->pos.offset,
a->data_type == state, a->data_type == state,
......
...@@ -55,7 +55,7 @@ int bch2_backpointer_invalid(const struct bch_fs *c, struct bkey_s_c k, ...@@ -55,7 +55,7 @@ int bch2_backpointer_invalid(const struct bch_fs *c, struct bkey_s_c k,
void bch2_backpointer_to_text(struct printbuf *out, const struct bch_backpointer *bp) void bch2_backpointer_to_text(struct printbuf *out, const struct bch_backpointer *bp)
{ {
prt_printf(out, "btree=%s l=%u offset=%llu:%u len=%u pos=", prt_printf(out, "btree=%s l=%u offset=%llu:%u len=%u pos=",
bch2_btree_ids[bp->btree_id], bch2_btree_id_str(bp->btree_id),
bp->level, bp->level,
(u64) (bp->bucket_offset >> MAX_EXTENT_COMPRESS_RATIO_SHIFT), (u64) (bp->bucket_offset >> MAX_EXTENT_COMPRESS_RATIO_SHIFT),
(u32) bp->bucket_offset & ~(~0U << MAX_EXTENT_COMPRESS_RATIO_SHIFT), (u32) bp->bucket_offset & ~(~0U << MAX_EXTENT_COMPRESS_RATIO_SHIFT),
...@@ -453,7 +453,7 @@ static int check_bp_exists(struct btree_trans *trans, ...@@ -453,7 +453,7 @@ static int check_bp_exists(struct btree_trans *trans,
return ret; return ret;
missing: missing:
prt_printf(&buf, "missing backpointer for btree=%s l=%u ", prt_printf(&buf, "missing backpointer for btree=%s l=%u ",
bch2_btree_ids[bp.btree_id], bp.level); bch2_btree_id_str(bp.btree_id), bp.level);
bch2_bkey_val_to_text(&buf, c, orig_k); bch2_bkey_val_to_text(&buf, c, orig_k);
prt_printf(&buf, "\nbp pos "); prt_printf(&buf, "\nbp pos ");
bch2_bpos_to_text(&buf, bp_iter.pos); bch2_bpos_to_text(&buf, bp_iter.pos);
......
...@@ -3,6 +3,7 @@ ...@@ -3,6 +3,7 @@
#define _BCACHEFS_BBPOS_H #define _BCACHEFS_BBPOS_H
#include "bkey_methods.h" #include "bkey_methods.h"
#include "btree_cache.h"
struct bbpos { struct bbpos {
enum btree_id btree; enum btree_id btree;
...@@ -40,7 +41,7 @@ static inline struct bbpos bbpos_successor(struct bbpos pos) ...@@ -40,7 +41,7 @@ static inline struct bbpos bbpos_successor(struct bbpos pos)
static inline void bch2_bbpos_to_text(struct printbuf *out, struct bbpos pos) static inline void bch2_bbpos_to_text(struct printbuf *out, struct bbpos pos)
{ {
prt_str(out, bch2_btree_ids[pos.btree]); prt_str(out, bch2_btree_id_str(pos.btree));
prt_char(out, ':'); prt_char(out, ':');
bch2_bpos_to_text(out, pos.pos); bch2_bpos_to_text(out, pos.pos);
} }
......
...@@ -3,6 +3,7 @@ ...@@ -3,6 +3,7 @@
#include "bcachefs.h" #include "bcachefs.h"
#include "backpointers.h" #include "backpointers.h"
#include "bkey_methods.h" #include "bkey_methods.h"
#include "btree_cache.h"
#include "btree_types.h" #include "btree_types.h"
#include "alloc_background.h" #include "alloc_background.h"
#include "dirent.h" #include "dirent.h"
...@@ -164,7 +165,7 @@ int __bch2_bkey_invalid(struct bch_fs *c, struct bkey_s_c k, ...@@ -164,7 +165,7 @@ int __bch2_bkey_invalid(struct bch_fs *c, struct bkey_s_c k,
if (flags & BKEY_INVALID_COMMIT && if (flags & BKEY_INVALID_COMMIT &&
!(bch2_key_types_allowed[type] & BIT_ULL(k.k->type))) { !(bch2_key_types_allowed[type] & BIT_ULL(k.k->type))) {
prt_printf(err, "invalid key type for btree %s (%s)", prt_printf(err, "invalid key type for btree %s (%s)",
bch2_btree_ids[type], bch2_bkey_types[k.k->type]); bch2_btree_id_str(type), bch2_bkey_types[k.k->type]);
return -BCH_ERR_invalid_bkey; return -BCH_ERR_invalid_bkey;
} }
......
...@@ -783,12 +783,12 @@ static noinline void btree_bad_header(struct bch_fs *c, struct btree *b) ...@@ -783,12 +783,12 @@ static noinline void btree_bad_header(struct bch_fs *c, struct btree *b)
"btree node header doesn't match ptr\n" "btree node header doesn't match ptr\n"
"btree %s level %u\n" "btree %s level %u\n"
"ptr: ", "ptr: ",
bch2_btree_ids[b->c.btree_id], b->c.level); bch2_btree_id_str(b->c.btree_id), b->c.level);
bch2_bkey_val_to_text(&buf, c, bkey_i_to_s_c(&b->key)); bch2_bkey_val_to_text(&buf, c, bkey_i_to_s_c(&b->key));
prt_printf(&buf, "\nheader: btree %s level %llu\n" prt_printf(&buf, "\nheader: btree %s level %llu\n"
"min ", "min ",
bch2_btree_ids[BTREE_NODE_ID(b->data)], bch2_btree_id_str(BTREE_NODE_ID(b->data)),
BTREE_NODE_LEVEL(b->data)); BTREE_NODE_LEVEL(b->data));
bch2_bpos_to_text(&buf, b->data->min_key); bch2_bpos_to_text(&buf, b->data->min_key);
...@@ -1151,8 +1151,21 @@ void bch2_btree_node_evict(struct btree_trans *trans, const struct bkey_i *k) ...@@ -1151,8 +1151,21 @@ void bch2_btree_node_evict(struct btree_trans *trans, const struct bkey_i *k)
six_unlock_intent(&b->c.lock); six_unlock_intent(&b->c.lock);
} }
void bch2_btree_node_to_text(struct printbuf *out, struct bch_fs *c, const char *bch2_btree_id_str(enum btree_id btree)
const struct btree *b) {
return btree < BTREE_ID_NR ? __bch2_btree_ids[btree] : "(unknown)";
}
void bch2_btree_pos_to_text(struct printbuf *out, struct bch_fs *c, const struct btree *b)
{
prt_printf(out, "%s level %u/%u\n ",
bch2_btree_id_str(b->c.btree_id),
b->c.level,
bch2_btree_id_root(c, b->c.btree_id)->level);
bch2_bkey_val_to_text(out, c, bkey_i_to_s_c(&b->key));
}
void bch2_btree_node_to_text(struct printbuf *out, struct bch_fs *c, const struct btree *b)
{ {
struct bset_stats stats; struct bset_stats stats;
......
...@@ -123,8 +123,9 @@ static inline struct btree *btree_node_root(struct bch_fs *c, struct btree *b) ...@@ -123,8 +123,9 @@ static inline struct btree *btree_node_root(struct bch_fs *c, struct btree *b)
return bch2_btree_id_root(c, b->c.btree_id)->b; return bch2_btree_id_root(c, b->c.btree_id)->b;
} }
void bch2_btree_node_to_text(struct printbuf *, struct bch_fs *, const char *bch2_btree_id_str(enum btree_id);
const struct btree *); void bch2_btree_pos_to_text(struct printbuf *, struct bch_fs *, const struct btree *);
void bch2_btree_node_to_text(struct printbuf *, struct bch_fs *, const struct btree *);
void bch2_btree_cache_to_text(struct printbuf *, const struct bch_fs *); void bch2_btree_cache_to_text(struct printbuf *, const struct bch_fs *);
#endif /* _BCACHEFS_BTREE_CACHE_H */ #endif /* _BCACHEFS_BTREE_CACHE_H */
...@@ -101,7 +101,7 @@ static int bch2_gc_check_topology(struct bch_fs *c, ...@@ -101,7 +101,7 @@ static int bch2_gc_check_topology(struct bch_fs *c,
"btree node with incorrect min_key at btree %s level %u:\n" "btree node with incorrect min_key at btree %s level %u:\n"
" prev %s\n" " prev %s\n"
" cur %s", " cur %s",
bch2_btree_ids[b->c.btree_id], b->c.level, bch2_btree_id_str(b->c.btree_id), b->c.level,
buf1.buf, buf2.buf) && buf1.buf, buf2.buf) &&
should_restart_for_topology_repair(c)) { should_restart_for_topology_repair(c)) {
bch_info(c, "Halting mark and sweep to start topology repair pass"); bch_info(c, "Halting mark and sweep to start topology repair pass");
...@@ -129,7 +129,7 @@ static int bch2_gc_check_topology(struct bch_fs *c, ...@@ -129,7 +129,7 @@ static int bch2_gc_check_topology(struct bch_fs *c,
"btree node with incorrect max_key at btree %s level %u:\n" "btree node with incorrect max_key at btree %s level %u:\n"
" %s\n" " %s\n"
" expected %s", " expected %s",
bch2_btree_ids[b->c.btree_id], b->c.level, bch2_btree_id_str(b->c.btree_id), b->c.level,
buf1.buf, buf2.buf) && buf1.buf, buf2.buf) &&
should_restart_for_topology_repair(c)) { should_restart_for_topology_repair(c)) {
bch_info(c, "Halting mark and sweep to start topology repair pass"); bch_info(c, "Halting mark and sweep to start topology repair pass");
...@@ -290,7 +290,7 @@ static int btree_repair_node_boundaries(struct bch_fs *c, struct btree *b, ...@@ -290,7 +290,7 @@ static int btree_repair_node_boundaries(struct bch_fs *c, struct btree *b,
"btree node overwritten by next node at btree %s level %u:\n" "btree node overwritten by next node at btree %s level %u:\n"
" node %s\n" " node %s\n"
" next %s", " next %s",
bch2_btree_ids[b->c.btree_id], b->c.level, bch2_btree_id_str(b->c.btree_id), b->c.level,
buf1.buf, buf2.buf)) { buf1.buf, buf2.buf)) {
ret = DROP_PREV_NODE; ret = DROP_PREV_NODE;
goto out; goto out;
...@@ -301,7 +301,7 @@ static int btree_repair_node_boundaries(struct bch_fs *c, struct btree *b, ...@@ -301,7 +301,7 @@ static int btree_repair_node_boundaries(struct bch_fs *c, struct btree *b,
"btree node with incorrect max_key at btree %s level %u:\n" "btree node with incorrect max_key at btree %s level %u:\n"
" node %s\n" " node %s\n"
" next %s", " next %s",
bch2_btree_ids[b->c.btree_id], b->c.level, bch2_btree_id_str(b->c.btree_id), b->c.level,
buf1.buf, buf2.buf)) buf1.buf, buf2.buf))
ret = set_node_max(c, prev, ret = set_node_max(c, prev,
bpos_predecessor(cur->data->min_key)); bpos_predecessor(cur->data->min_key));
...@@ -313,7 +313,7 @@ static int btree_repair_node_boundaries(struct bch_fs *c, struct btree *b, ...@@ -313,7 +313,7 @@ static int btree_repair_node_boundaries(struct bch_fs *c, struct btree *b,
"btree node overwritten by prev node at btree %s level %u:\n" "btree node overwritten by prev node at btree %s level %u:\n"
" prev %s\n" " prev %s\n"
" node %s", " node %s",
bch2_btree_ids[b->c.btree_id], b->c.level, bch2_btree_id_str(b->c.btree_id), b->c.level,
buf1.buf, buf2.buf)) { buf1.buf, buf2.buf)) {
ret = DROP_THIS_NODE; ret = DROP_THIS_NODE;
goto out; goto out;
...@@ -323,7 +323,7 @@ static int btree_repair_node_boundaries(struct bch_fs *c, struct btree *b, ...@@ -323,7 +323,7 @@ static int btree_repair_node_boundaries(struct bch_fs *c, struct btree *b,
"btree node with incorrect min_key at btree %s level %u:\n" "btree node with incorrect min_key at btree %s level %u:\n"
" prev %s\n" " prev %s\n"
" node %s", " node %s",
bch2_btree_ids[b->c.btree_id], b->c.level, bch2_btree_id_str(b->c.btree_id), b->c.level,
buf1.buf, buf2.buf)) buf1.buf, buf2.buf))
ret = set_node_min(c, cur, expected_start); ret = set_node_min(c, cur, expected_start);
} }
...@@ -347,7 +347,7 @@ static int btree_repair_node_end(struct bch_fs *c, struct btree *b, ...@@ -347,7 +347,7 @@ static int btree_repair_node_end(struct bch_fs *c, struct btree *b,
"btree node with incorrect max_key at btree %s level %u:\n" "btree node with incorrect max_key at btree %s level %u:\n"
" %s\n" " %s\n"
" expected %s", " expected %s",
bch2_btree_ids[b->c.btree_id], b->c.level, bch2_btree_id_str(b->c.btree_id), b->c.level,
buf1.buf, buf2.buf)) { buf1.buf, buf2.buf)) {
ret = set_node_max(c, child, b->key.k.p); ret = set_node_max(c, child, b->key.k.p);
if (ret) if (ret)
...@@ -398,7 +398,7 @@ static int bch2_btree_repair_topology_recurse(struct btree_trans *trans, struct ...@@ -398,7 +398,7 @@ static int bch2_btree_repair_topology_recurse(struct btree_trans *trans, struct
if (mustfix_fsck_err_on(ret == -EIO, c, if (mustfix_fsck_err_on(ret == -EIO, c,
"Topology repair: unreadable btree node at btree %s level %u:\n" "Topology repair: unreadable btree node at btree %s level %u:\n"
" %s", " %s",
bch2_btree_ids[b->c.btree_id], bch2_btree_id_str(b->c.btree_id),
b->c.level - 1, b->c.level - 1,
buf.buf)) { buf.buf)) {
bch2_btree_node_evict(trans, cur_k.k); bch2_btree_node_evict(trans, cur_k.k);
...@@ -506,7 +506,7 @@ static int bch2_btree_repair_topology_recurse(struct btree_trans *trans, struct ...@@ -506,7 +506,7 @@ static int bch2_btree_repair_topology_recurse(struct btree_trans *trans, struct
if (mustfix_fsck_err_on(!have_child, c, if (mustfix_fsck_err_on(!have_child, c,
"empty interior btree node at btree %s level %u\n" "empty interior btree node at btree %s level %u\n"
" %s", " %s",
bch2_btree_ids[b->c.btree_id], bch2_btree_id_str(b->c.btree_id),
b->c.level, buf.buf)) b->c.level, buf.buf))
ret = DROP_THIS_NODE; ret = DROP_THIS_NODE;
err: err:
...@@ -970,7 +970,7 @@ static int bch2_gc_btree_init_recurse(struct btree_trans *trans, struct btree *b ...@@ -970,7 +970,7 @@ static int bch2_gc_btree_init_recurse(struct btree_trans *trans, struct btree *b
FSCK_NO_RATELIMIT, FSCK_NO_RATELIMIT,
"Unreadable btree node at btree %s level %u:\n" "Unreadable btree node at btree %s level %u:\n"
" %s", " %s",
bch2_btree_ids[b->c.btree_id], bch2_btree_id_str(b->c.btree_id),
b->c.level - 1, b->c.level - 1,
(printbuf_reset(&buf), (printbuf_reset(&buf),
bch2_bkey_val_to_text(&buf, c, bkey_i_to_s_c(cur.k)), buf.buf)) && bch2_bkey_val_to_text(&buf, c, bkey_i_to_s_c(cur.k)), buf.buf)) &&
......
...@@ -510,16 +510,6 @@ void bch2_btree_init_next(struct btree_trans *trans, struct btree *b) ...@@ -510,16 +510,6 @@ void bch2_btree_init_next(struct btree_trans *trans, struct btree *b)
bch2_trans_node_reinit_iter(trans, b); bch2_trans_node_reinit_iter(trans, b);
} }
static void btree_pos_to_text(struct printbuf *out, struct bch_fs *c,
struct btree *b)
{
prt_printf(out, "%s level %u/%u\n ",
bch2_btree_ids[b->c.btree_id],
b->c.level,
bch2_btree_id_root(c, b->c.btree_id)->level);
bch2_bkey_val_to_text(out, c, bkey_i_to_s_c(&b->key));
}
static void btree_err_msg(struct printbuf *out, struct bch_fs *c, static void btree_err_msg(struct printbuf *out, struct bch_fs *c,
struct bch_dev *ca, struct bch_dev *ca,
struct btree *b, struct bset *i, struct btree *b, struct bset *i,
...@@ -532,7 +522,7 @@ static void btree_err_msg(struct printbuf *out, struct bch_fs *c, ...@@ -532,7 +522,7 @@ static void btree_err_msg(struct printbuf *out, struct bch_fs *c,
if (ca) if (ca)
prt_printf(out, "on %s ", ca->name); prt_printf(out, "on %s ", ca->name);
prt_printf(out, "at btree "); prt_printf(out, "at btree ");
btree_pos_to_text(out, c, b); bch2_btree_pos_to_text(out, c, b);
prt_printf(out, "\n node offset %u", b->written); prt_printf(out, "\n node offset %u", b->written);
if (i) if (i)
...@@ -1177,7 +1167,7 @@ static void btree_node_read_work(struct work_struct *work) ...@@ -1177,7 +1167,7 @@ static void btree_node_read_work(struct work_struct *work)
} }
start: start:
printbuf_reset(&buf); printbuf_reset(&buf);
btree_pos_to_text(&buf, c, b); bch2_btree_pos_to_text(&buf, c, b);
bch2_dev_io_err_on(bio->bi_status, ca, "btree read error %s for %s", bch2_dev_io_err_on(bio->bi_status, ca, "btree read error %s for %s",
bch2_blk_status_to_str(bio->bi_status), buf.buf); bch2_blk_status_to_str(bio->bi_status), buf.buf);
if (rb->have_ioref) if (rb->have_ioref)
...@@ -1213,7 +1203,7 @@ static void btree_node_read_work(struct work_struct *work) ...@@ -1213,7 +1203,7 @@ static void btree_node_read_work(struct work_struct *work)
printbuf_reset(&buf); printbuf_reset(&buf);
bch2_bpos_to_text(&buf, b->key.k.p); bch2_bpos_to_text(&buf, b->key.k.p);
bch_info(c, "%s: rewriting btree node at btree=%s level=%u %s due to error", bch_info(c, "%s: rewriting btree node at btree=%s level=%u %s due to error",
__func__, bch2_btree_ids[b->c.btree_id], b->c.level, buf.buf); __func__, bch2_btree_id_str(b->c.btree_id), b->c.level, buf.buf);
bch2_btree_node_rewrite_async(c, b); bch2_btree_node_rewrite_async(c, b);
} }
...@@ -1524,7 +1514,7 @@ void bch2_btree_node_read(struct bch_fs *c, struct btree *b, ...@@ -1524,7 +1514,7 @@ void bch2_btree_node_read(struct bch_fs *c, struct btree *b,
struct printbuf buf = PRINTBUF; struct printbuf buf = PRINTBUF;
prt_str(&buf, "btree node read error: no device to read from\n at "); prt_str(&buf, "btree node read error: no device to read from\n at ");
btree_pos_to_text(&buf, c, b); bch2_btree_pos_to_text(&buf, c, b);
bch_err(c, "%s", buf.buf); bch_err(c, "%s", buf.buf);
if (c->recovery_passes_explicit & BIT_ULL(BCH_RECOVERY_PASS_check_topology) && if (c->recovery_passes_explicit & BIT_ULL(BCH_RECOVERY_PASS_check_topology) &&
......
...@@ -362,7 +362,7 @@ void bch2_assert_pos_locked(struct btree_trans *trans, enum btree_id id, ...@@ -362,7 +362,7 @@ void bch2_assert_pos_locked(struct btree_trans *trans, enum btree_id id,
bch2_bpos_to_text(&buf, pos); bch2_bpos_to_text(&buf, pos);
panic("not locked: %s %s%s\n", panic("not locked: %s %s%s\n",
bch2_btree_ids[id], buf.buf, bch2_btree_id_str(id), buf.buf,
key_cache ? " cached" : ""); key_cache ? " cached" : "");
} }
...@@ -1371,7 +1371,7 @@ void bch2_trans_updates_to_text(struct printbuf *buf, struct btree_trans *trans) ...@@ -1371,7 +1371,7 @@ void bch2_trans_updates_to_text(struct printbuf *buf, struct btree_trans *trans)
struct bkey_s_c old = { &i->old_k, i->old_v }; struct bkey_s_c old = { &i->old_k, i->old_v };
prt_printf(buf, "update: btree=%s cached=%u %pS", prt_printf(buf, "update: btree=%s cached=%u %pS",
bch2_btree_ids[i->btree_id], bch2_btree_id_str(i->btree_id),
i->cached, i->cached,
(void *) i->ip_allocated); (void *) i->ip_allocated);
prt_newline(buf); prt_newline(buf);
...@@ -1387,7 +1387,7 @@ void bch2_trans_updates_to_text(struct printbuf *buf, struct btree_trans *trans) ...@@ -1387,7 +1387,7 @@ void bch2_trans_updates_to_text(struct printbuf *buf, struct btree_trans *trans)
trans_for_each_wb_update(trans, wb) { trans_for_each_wb_update(trans, wb) {
prt_printf(buf, "update: btree=%s wb=1 %pS", prt_printf(buf, "update: btree=%s wb=1 %pS",
bch2_btree_ids[wb->btree], bch2_btree_id_str(wb->btree),
(void *) i->ip_allocated); (void *) i->ip_allocated);
prt_newline(buf); prt_newline(buf);
...@@ -1416,7 +1416,7 @@ void bch2_btree_path_to_text(struct printbuf *out, struct btree_path *path) ...@@ -1416,7 +1416,7 @@ void bch2_btree_path_to_text(struct printbuf *out, struct btree_path *path)
path->idx, path->ref, path->intent_ref, path->idx, path->ref, path->intent_ref,
path->preserve ? 'P' : ' ', path->preserve ? 'P' : ' ',
path->should_be_locked ? 'S' : ' ', path->should_be_locked ? 'S' : ' ',
bch2_btree_ids[path->btree_id], bch2_btree_id_str(path->btree_id),
path->level); path->level);
bch2_bpos_to_text(out, path->pos); bch2_bpos_to_text(out, path->pos);
...@@ -3025,7 +3025,7 @@ static void check_btree_paths_leaked(struct btree_trans *trans) ...@@ -3025,7 +3025,7 @@ static void check_btree_paths_leaked(struct btree_trans *trans)
trans_for_each_path(trans, path) trans_for_each_path(trans, path)
if (path->ref) if (path->ref)
printk(KERN_ERR " btree %s %pS\n", printk(KERN_ERR " btree %s %pS\n",
bch2_btree_ids[path->btree_id], bch2_btree_id_str(path->btree_id),
(void *) path->ip_allocated); (void *) path->ip_allocated);
/* Be noisy about this: */ /* Be noisy about this: */
bch2_fatal_error(c); bch2_fatal_error(c);
...@@ -3100,7 +3100,7 @@ bch2_btree_bkey_cached_common_to_text(struct printbuf *out, ...@@ -3100,7 +3100,7 @@ bch2_btree_bkey_cached_common_to_text(struct printbuf *out,
prt_tab(out); prt_tab(out);
prt_printf(out, "%px %c l=%u %s:", b, b->cached ? 'c' : 'b', prt_printf(out, "%px %c l=%u %s:", b, b->cached ? 'c' : 'b',
b->level, bch2_btree_ids[b->btree_id]); b->level, bch2_btree_id_str(b->btree_id));
bch2_bpos_to_text(out, btree_node_pos(b)); bch2_bpos_to_text(out, btree_node_pos(b));
prt_tab(out); prt_tab(out);
...@@ -3130,7 +3130,7 @@ void bch2_btree_trans_to_text(struct printbuf *out, struct btree_trans *trans) ...@@ -3130,7 +3130,7 @@ void bch2_btree_trans_to_text(struct printbuf *out, struct btree_trans *trans)
path->idx, path->idx,
path->cached ? 'c' : 'b', path->cached ? 'c' : 'b',
path->level, path->level,
bch2_btree_ids[path->btree_id]); bch2_btree_id_str(path->btree_id));
bch2_bpos_to_text(out, path->pos); bch2_bpos_to_text(out, path->pos);
prt_newline(out); prt_newline(out);
......
...@@ -324,7 +324,7 @@ btree_key_cache_create(struct btree_trans *trans, struct btree_path *path) ...@@ -324,7 +324,7 @@ btree_key_cache_create(struct btree_trans *trans, struct btree_path *path)
ck = bkey_cached_reuse(bc); ck = bkey_cached_reuse(bc);
if (unlikely(!ck)) { if (unlikely(!ck)) {
bch_err(c, "error allocating memory for key cache item, btree %s", bch_err(c, "error allocating memory for key cache item, btree %s",
bch2_btree_ids[path->btree_id]); bch2_btree_id_str(path->btree_id));
return ERR_PTR(-BCH_ERR_ENOMEM_btree_key_cache_create); return ERR_PTR(-BCH_ERR_ENOMEM_btree_key_cache_create);
} }
...@@ -407,7 +407,7 @@ static int btree_key_cache_fill(struct btree_trans *trans, ...@@ -407,7 +407,7 @@ static int btree_key_cache_fill(struct btree_trans *trans,
new_k = kmalloc(new_u64s * sizeof(u64), GFP_KERNEL); new_k = kmalloc(new_u64s * sizeof(u64), GFP_KERNEL);
if (!new_k) { if (!new_k) {
bch_err(trans->c, "error allocating memory for key cache key, btree %s u64s %u", bch_err(trans->c, "error allocating memory for key cache key, btree %s u64s %u",
bch2_btree_ids[ck->key.btree_id], new_u64s); bch2_btree_id_str(ck->key.btree_id), new_u64s);
ret = -BCH_ERR_ENOMEM_btree_key_cache_fill; ret = -BCH_ERR_ENOMEM_btree_key_cache_fill;
goto err; goto err;
} }
......
...@@ -349,7 +349,7 @@ static int btree_key_can_insert_cached(struct btree_trans *trans, unsigned flags ...@@ -349,7 +349,7 @@ static int btree_key_can_insert_cached(struct btree_trans *trans, unsigned flags
new_k = krealloc(ck->k, new_u64s * sizeof(u64), GFP_NOFS); new_k = krealloc(ck->k, new_u64s * sizeof(u64), GFP_NOFS);
if (!new_k) { if (!new_k) {
bch_err(c, "error allocating memory for key cache key, btree %s u64s %u", bch_err(c, "error allocating memory for key cache key, btree %s u64s %u",
bch2_btree_ids[path->btree_id], new_u64s); bch2_btree_id_str(path->btree_id), new_u64s);
return -BCH_ERR_ENOMEM_btree_key_cache_insert; return -BCH_ERR_ENOMEM_btree_key_cache_insert;
} }
......
...@@ -517,7 +517,7 @@ static void bch2_cached_btree_node_to_text(struct printbuf *out, struct bch_fs * ...@@ -517,7 +517,7 @@ static void bch2_cached_btree_node_to_text(struct printbuf *out, struct bch_fs *
prt_printf(out, "%px btree=%s l=%u ", prt_printf(out, "%px btree=%s l=%u ",
b, b,
bch2_btree_ids[b->c.btree_id], bch2_btree_id_str(b->c.btree_id),
b->c.level); b->c.level);
prt_newline(out); prt_newline(out);
...@@ -919,18 +919,18 @@ void bch2_fs_debug_init(struct bch_fs *c) ...@@ -919,18 +919,18 @@ void bch2_fs_debug_init(struct bch_fs *c)
bd < c->btree_debug + ARRAY_SIZE(c->btree_debug); bd < c->btree_debug + ARRAY_SIZE(c->btree_debug);
bd++) { bd++) {
bd->id = bd - c->btree_debug; bd->id = bd - c->btree_debug;
debugfs_create_file(bch2_btree_ids[bd->id], debugfs_create_file(bch2_btree_id_str(bd->id),
0400, c->btree_debug_dir, bd, 0400, c->btree_debug_dir, bd,
&btree_debug_ops); &btree_debug_ops);
snprintf(name, sizeof(name), "%s-formats", snprintf(name, sizeof(name), "%s-formats",
bch2_btree_ids[bd->id]); bch2_btree_id_str(bd->id));
debugfs_create_file(name, 0400, c->btree_debug_dir, bd, debugfs_create_file(name, 0400, c->btree_debug_dir, bd,
&btree_format_debug_ops); &btree_format_debug_ops);
snprintf(name, sizeof(name), "%s-bfloat-failed", snprintf(name, sizeof(name), "%s-bfloat-failed",
bch2_btree_ids[bd->id]); bch2_btree_id_str(bd->id));
debugfs_create_file(name, 0400, c->btree_debug_dir, bd, debugfs_create_file(name, 0400, c->btree_debug_dir, bd,
&bfloat_failed_debug_ops); &bfloat_failed_debug_ops);
......
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
#include "bcachefs.h" #include "bcachefs.h"
#include "bkey_buf.h" #include "bkey_buf.h"
#include "btree_cache.h"
#include "btree_update.h" #include "btree_update.h"
#include "buckets.h" #include "buckets.h"
#include "darray.h" #include "darray.h"
...@@ -444,7 +445,7 @@ static int snapshots_seen_update(struct bch_fs *c, struct snapshots_seen *s, ...@@ -444,7 +445,7 @@ static int snapshots_seen_update(struct bch_fs *c, struct snapshots_seen *s,
if (i->equiv == n.equiv) { if (i->equiv == n.equiv) {
bch_err(c, "snapshot deletion did not finish:\n" bch_err(c, "snapshot deletion did not finish:\n"
" duplicate keys in btree %s at %llu:%llu snapshots %u, %u (equiv %u)\n", " duplicate keys in btree %s at %llu:%llu snapshots %u, %u (equiv %u)\n",
bch2_btree_ids[btree_id], bch2_btree_id_str(btree_id),
pos.inode, pos.offset, pos.inode, pos.offset,
i->id, n.id, n.equiv); i->id, n.id, n.equiv);
set_bit(BCH_FS_NEED_DELETE_DEAD_SNAPSHOTS, &c->flags); set_bit(BCH_FS_NEED_DELETE_DEAD_SNAPSHOTS, &c->flags);
...@@ -809,7 +810,7 @@ static int hash_check_key(struct btree_trans *trans, ...@@ -809,7 +810,7 @@ static int hash_check_key(struct btree_trans *trans,
return ret; return ret;
bad_hash: bad_hash:
if (fsck_err(c, "hash table key at wrong offset: btree %s inode %llu offset %llu, hashed to %llu\n%s", if (fsck_err(c, "hash table key at wrong offset: btree %s inode %llu offset %llu, hashed to %llu\n%s",
bch2_btree_ids[desc.btree_id], hash_k.k->p.inode, hash_k.k->p.offset, hash, bch2_btree_id_str(desc.btree_id), hash_k.k->p.inode, hash_k.k->p.offset, hash,
(printbuf_reset(&buf), (printbuf_reset(&buf),
bch2_bkey_val_to_text(&buf, c, hash_k), buf.buf))) { bch2_bkey_val_to_text(&buf, c, hash_k), buf.buf))) {
ret = hash_redo_key(trans, desc, hash_info, k_iter, hash_k); ret = hash_redo_key(trans, desc, hash_info, k_iter, hash_k);
......
...@@ -369,7 +369,7 @@ static void journal_entry_btree_keys_to_text(struct printbuf *out, struct bch_fs ...@@ -369,7 +369,7 @@ static void journal_entry_btree_keys_to_text(struct printbuf *out, struct bch_fs
prt_newline(out); prt_newline(out);
prt_printf(out, "%s: ", bch2_jset_entry_types[entry->type]); prt_printf(out, "%s: ", bch2_jset_entry_types[entry->type]);
} }
prt_printf(out, "btree=%s l=%u ", bch2_btree_ids[entry->btree_id], entry->level); prt_printf(out, "btree=%s l=%u ", bch2_btree_id_str(entry->btree_id), entry->level);
bch2_bkey_val_to_text(out, c, bkey_i_to_s_c(k)); bch2_bkey_val_to_text(out, c, bkey_i_to_s_c(k));
first = false; first = false;
} }
......
...@@ -1110,7 +1110,7 @@ static void bch2_moving_ctxt_to_text(struct printbuf *out, struct bch_fs *c, str ...@@ -1110,7 +1110,7 @@ static void bch2_moving_ctxt_to_text(struct printbuf *out, struct bch_fs *c, str
prt_printf(out, " data type %s btree_id %s position: ", prt_printf(out, " data type %s btree_id %s position: ",
bch2_data_types[stats->data_type], bch2_data_types[stats->data_type],
bch2_btree_ids[stats->btree_id]); bch2_btree_id_str(stats->btree_id));
bch2_bpos_to_text(out, stats->pos); bch2_bpos_to_text(out, stats->pos);
prt_newline(out); prt_newline(out);
printbuf_indent_add(out, 2); printbuf_indent_add(out, 2);
......
...@@ -42,9 +42,8 @@ const char * const bch2_sb_compat[] = { ...@@ -42,9 +42,8 @@ const char * const bch2_sb_compat[] = {
NULL NULL
}; };
const char * const bch2_btree_ids[] = { const char * const __bch2_btree_ids[] = {
BCH_BTREE_IDS() BCH_BTREE_IDS()
"interior btree node",
NULL NULL
}; };
......
...@@ -16,7 +16,7 @@ extern const char * const bch2_fsck_fix_opts[]; ...@@ -16,7 +16,7 @@ extern const char * const bch2_fsck_fix_opts[];
extern const char * const bch2_version_upgrade_opts[]; extern const char * const bch2_version_upgrade_opts[];
extern const char * const bch2_sb_features[]; extern const char * const bch2_sb_features[];
extern const char * const bch2_sb_compat[]; extern const char * const bch2_sb_compat[];
extern const char * const bch2_btree_ids[]; extern const char * const __bch2_btree_ids[];
extern const char * const bch2_csum_types[]; extern const char * const bch2_csum_types[];
extern const char * const bch2_csum_opts[]; extern const char * const bch2_csum_opts[];
extern const char * const bch2_compression_types[]; extern const char * const bch2_compression_types[];
......
...@@ -182,7 +182,7 @@ static int bch2_journal_replay(struct bch_fs *c) ...@@ -182,7 +182,7 @@ static int bch2_journal_replay(struct bch_fs *c)
bch2_journal_replay_key(trans, k)); bch2_journal_replay_key(trans, k));
if (ret) { if (ret) {
bch_err(c, "journal replay: error while replaying key at btree %s level %u: %s", bch_err(c, "journal replay: error while replaying key at btree %s level %u: %s",
bch2_btree_ids[k->btree_id], k->level, bch2_err_str(ret)); bch2_btree_id_str(k->btree_id), k->level, bch2_err_str(ret));
goto err; goto err;
} }
} }
...@@ -367,7 +367,7 @@ static int read_btree_roots(struct bch_fs *c) ...@@ -367,7 +367,7 @@ static int read_btree_roots(struct bch_fs *c)
__fsck_err(c, btree_id_is_alloc(i) __fsck_err(c, btree_id_is_alloc(i)
? FSCK_CAN_IGNORE : 0, ? FSCK_CAN_IGNORE : 0,
"invalid btree root %s", "invalid btree root %s",
bch2_btree_ids[i]); bch2_btree_id_str(i));
if (i == BTREE_ID_alloc) if (i == BTREE_ID_alloc)
c->sb.compat &= ~(1ULL << BCH_COMPAT_alloc_info); c->sb.compat &= ~(1ULL << BCH_COMPAT_alloc_info);
} }
...@@ -376,7 +376,7 @@ static int read_btree_roots(struct bch_fs *c) ...@@ -376,7 +376,7 @@ static int read_btree_roots(struct bch_fs *c)
if (ret) { if (ret) {
fsck_err(c, fsck_err(c,
"error reading btree root %s", "error reading btree root %s",
bch2_btree_ids[i]); bch2_btree_id_str(i));
if (btree_id_is_alloc(i)) if (btree_id_is_alloc(i))
c->sb.compat &= ~(1ULL << BCH_COMPAT_alloc_info); c->sb.compat &= ~(1ULL << BCH_COMPAT_alloc_info);
ret = 0; ret = 0;
......
...@@ -341,7 +341,7 @@ static int bch2_compression_stats_to_text(struct printbuf *out, struct bch_fs *c ...@@ -341,7 +341,7 @@ static int bch2_compression_stats_to_text(struct printbuf *out, struct bch_fs *c
static void bch2_gc_gens_pos_to_text(struct printbuf *out, struct bch_fs *c) static void bch2_gc_gens_pos_to_text(struct printbuf *out, struct bch_fs *c)
{ {
prt_printf(out, "%s: ", bch2_btree_ids[c->gc_gens_btree]); prt_printf(out, "%s: ", bch2_btree_id_str(c->gc_gens_btree));
bch2_bpos_to_text(out, c->gc_gens_pos); bch2_bpos_to_text(out, c->gc_gens_pos);
prt_printf(out, "\n"); prt_printf(out, "\n");
} }
......
...@@ -68,7 +68,7 @@ DECLARE_EVENT_CLASS(btree_node, ...@@ -68,7 +68,7 @@ DECLARE_EVENT_CLASS(btree_node,
TP_printk("%d,%d %u %s %llu:%llu:%u", TP_printk("%d,%d %u %s %llu:%llu:%u",
MAJOR(__entry->dev), MINOR(__entry->dev), MAJOR(__entry->dev), MINOR(__entry->dev),
__entry->level, __entry->level,
bch2_btree_ids[__entry->btree_id], bch2_btree_id_str(__entry->btree_id),
__entry->pos_inode, __entry->pos_offset, __entry->pos_snapshot) __entry->pos_inode, __entry->pos_offset, __entry->pos_snapshot)
); );
...@@ -461,7 +461,7 @@ TRACE_EVENT(btree_path_relock_fail, ...@@ -461,7 +461,7 @@ TRACE_EVENT(btree_path_relock_fail,
TP_printk("%s %pS btree %s pos %llu:%llu:%u level %u node %s held %u:%u lock count %u:%u iter seq %u lock seq %u", TP_printk("%s %pS btree %s pos %llu:%llu:%u level %u node %s held %u:%u lock count %u:%u iter seq %u lock seq %u",
__entry->trans_fn, __entry->trans_fn,
(void *) __entry->caller_ip, (void *) __entry->caller_ip,
bch2_btree_ids[__entry->btree_id], bch2_btree_id_str(__entry->btree_id),
__entry->pos_inode, __entry->pos_inode,
__entry->pos_offset, __entry->pos_offset,
__entry->pos_snapshot, __entry->pos_snapshot,
...@@ -522,7 +522,7 @@ TRACE_EVENT(btree_path_upgrade_fail, ...@@ -522,7 +522,7 @@ TRACE_EVENT(btree_path_upgrade_fail,
TP_printk("%s %pS btree %s pos %llu:%llu:%u level %u locked %u held %u:%u lock count %u:%u iter seq %u lock seq %u", TP_printk("%s %pS btree %s pos %llu:%llu:%u level %u locked %u held %u:%u lock count %u:%u iter seq %u lock seq %u",
__entry->trans_fn, __entry->trans_fn,
(void *) __entry->caller_ip, (void *) __entry->caller_ip,
bch2_btree_ids[__entry->btree_id], bch2_btree_id_str(__entry->btree_id),
__entry->pos_inode, __entry->pos_inode,
__entry->pos_offset, __entry->pos_offset,
__entry->pos_snapshot, __entry->pos_snapshot,
...@@ -1012,7 +1012,7 @@ DECLARE_EVENT_CLASS(transaction_restart_iter, ...@@ -1012,7 +1012,7 @@ DECLARE_EVENT_CLASS(transaction_restart_iter,
TP_printk("%s %pS btree %s pos %llu:%llu:%u", TP_printk("%s %pS btree %s pos %llu:%llu:%u",
__entry->trans_fn, __entry->trans_fn,
(void *) __entry->caller_ip, (void *) __entry->caller_ip,
bch2_btree_ids[__entry->btree_id], bch2_btree_id_str(__entry->btree_id),
__entry->pos_inode, __entry->pos_inode,
__entry->pos_offset, __entry->pos_offset,
__entry->pos_snapshot) __entry->pos_snapshot)
...@@ -1061,7 +1061,7 @@ TRACE_EVENT(trans_restart_upgrade, ...@@ -1061,7 +1061,7 @@ TRACE_EVENT(trans_restart_upgrade,
TP_printk("%s %pS btree %s pos %llu:%llu:%u locks_want %u -> %u", TP_printk("%s %pS btree %s pos %llu:%llu:%u locks_want %u -> %u",
__entry->trans_fn, __entry->trans_fn,
(void *) __entry->caller_ip, (void *) __entry->caller_ip,
bch2_btree_ids[__entry->btree_id], bch2_btree_id_str(__entry->btree_id),
__entry->pos_inode, __entry->pos_inode,
__entry->pos_offset, __entry->pos_offset,
__entry->pos_snapshot, __entry->pos_snapshot,
...@@ -1219,7 +1219,7 @@ TRACE_EVENT(trans_restart_key_cache_key_realloced, ...@@ -1219,7 +1219,7 @@ TRACE_EVENT(trans_restart_key_cache_key_realloced,
TP_printk("%s %pS btree %s pos %llu:%llu:%u old_u64s %u new_u64s %u", TP_printk("%s %pS btree %s pos %llu:%llu:%u old_u64s %u new_u64s %u",
__entry->trans_fn, __entry->trans_fn,
(void *) __entry->caller_ip, (void *) __entry->caller_ip,
bch2_btree_ids[__entry->btree_id], bch2_btree_id_str(__entry->btree_id),
__entry->pos_inode, __entry->pos_inode,
__entry->pos_offset, __entry->pos_offset,
__entry->pos_snapshot, __entry->pos_snapshot,
......
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