Commit 0d763863 authored by Kent Overstreet's avatar Kent Overstreet

bcachefs: Improve bch2_stripe_to_text()

We now print pointers as bucket:offset, the same as how we print extent
pointers.
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent 33669e0c
...@@ -138,20 +138,28 @@ void bch2_stripe_to_text(struct printbuf *out, struct bch_fs *c, ...@@ -138,20 +138,28 @@ void bch2_stripe_to_text(struct printbuf *out, struct bch_fs *c,
struct bkey_s_c k) struct bkey_s_c k)
{ {
const struct bch_stripe *s = bkey_s_c_to_stripe(k).v; const struct bch_stripe *s = bkey_s_c_to_stripe(k).v;
unsigned i; unsigned i, nr_data = s->nr_blocks - s->nr_redundant;
prt_printf(out, "algo %u sectors %u blocks %u:%u csum %u gran %u", prt_printf(out, "algo %u sectors %u blocks %u:%u csum %u gran %u",
s->algorithm, s->algorithm,
le16_to_cpu(s->sectors), le16_to_cpu(s->sectors),
s->nr_blocks - s->nr_redundant, nr_data,
s->nr_redundant, s->nr_redundant,
s->csum_type, s->csum_type,
1U << s->csum_granularity_bits); 1U << s->csum_granularity_bits);
for (i = 0; i < s->nr_blocks; i++) for (i = 0; i < s->nr_blocks; i++) {
prt_printf(out, " %u:%llu:%u", s->ptrs[i].dev, const struct bch_extent_ptr *ptr = s->ptrs + i;
(u64) s->ptrs[i].offset, struct bch_dev *ca = bch_dev_bkey_exists(c, ptr->dev);
stripe_blockcount_get(s, i)); u32 offset;
u64 b = sector_to_bucket_and_offset(ca, ptr->offset, &offset);
prt_printf(out, " %u:%llu:%u", ptr->dev, b, offset);
if (i < nr_data)
prt_printf(out, "#%u", stripe_blockcount_get(s, i));
if (ptr_stale(ca, ptr))
prt_printf(out, " stale");
}
} }
/* returns blocknr in stripe that we matched: */ /* returns blocknr in stripe that we matched: */
......
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