Commit 7541787f authored by Kent Overstreet's avatar Kent Overstreet

bcachefs: Improve sysfs compression_stats

Break it out by compression type, and include average extent size.

Also, format into a nice table.
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent 9b34f02c
...@@ -258,15 +258,16 @@ static int bch2_compression_stats_to_text(struct printbuf *out, struct bch_fs *c ...@@ -258,15 +258,16 @@ static int bch2_compression_stats_to_text(struct printbuf *out, struct bch_fs *c
struct btree_iter iter; struct btree_iter iter;
struct bkey_s_c k; struct bkey_s_c k;
enum btree_id id; enum btree_id id;
u64 nr_uncompressed_extents = 0, struct compression_type_stats {
nr_compressed_extents = 0, u64 nr_extents;
nr_incompressible_extents = 0, u64 sectors_compressed;
uncompressed_sectors = 0, u64 sectors_uncompressed;
incompressible_sectors = 0, } s[BCH_COMPRESSION_TYPE_NR];
compressed_sectors_compressed = 0, u64 compressed_incompressible = 0;
compressed_sectors_uncompressed = 0;
int ret = 0; int ret = 0;
memset(s, 0, sizeof(s));
if (!test_bit(BCH_FS_STARTED, &c->flags)) if (!test_bit(BCH_FS_STARTED, &c->flags))
return -EPERM; return -EPERM;
...@@ -279,36 +280,30 @@ static int bch2_compression_stats_to_text(struct printbuf *out, struct bch_fs *c ...@@ -279,36 +280,30 @@ static int bch2_compression_stats_to_text(struct printbuf *out, struct bch_fs *c
ret = for_each_btree_key2(trans, iter, id, POS_MIN, ret = for_each_btree_key2(trans, iter, id, POS_MIN,
BTREE_ITER_ALL_SNAPSHOTS, k, ({ BTREE_ITER_ALL_SNAPSHOTS, k, ({
struct bkey_ptrs_c ptrs = bch2_bkey_ptrs_c(k); struct bkey_ptrs_c ptrs = bch2_bkey_ptrs_c(k);
struct bch_extent_crc_unpacked crc;
const union bch_extent_entry *entry; const union bch_extent_entry *entry;
struct extent_ptr_decoded p; bool compressed = false, incompressible = false;
bool compressed = false, uncompressed = false, incompressible = false;
bkey_for_each_crc(k.k, ptrs, crc, entry) {
bkey_for_each_ptr_decode(k.k, ptrs, p, entry) { incompressible |= crc.compression_type == BCH_COMPRESSION_TYPE_incompressible;
switch (p.crc.compression_type) { compressed |= crc_is_compressed(crc);
case BCH_COMPRESSION_TYPE_none:
uncompressed = true; if (crc_is_compressed(crc)) {
uncompressed_sectors += k.k->size; s[crc.compression_type].nr_extents++;
break; s[crc.compression_type].sectors_compressed += crc.compressed_size;
case BCH_COMPRESSION_TYPE_incompressible: s[crc.compression_type].sectors_uncompressed += crc.uncompressed_size;
incompressible = true;
incompressible_sectors += k.k->size;
break;
default:
compressed_sectors_compressed +=
p.crc.compressed_size;
compressed_sectors_uncompressed +=
p.crc.uncompressed_size;
compressed = true;
break;
} }
} }
if (incompressible) compressed_incompressible += compressed && incompressible;
nr_incompressible_extents++;
else if (uncompressed) if (!compressed) {
nr_uncompressed_extents++; unsigned t = incompressible ? BCH_COMPRESSION_TYPE_incompressible : 0;
else if (compressed)
nr_compressed_extents++; s[t].nr_extents++;
s[t].sectors_compressed += k.k->size;
s[t].sectors_uncompressed += k.k->size;
}
0; 0;
})); }));
} }
...@@ -318,26 +313,45 @@ static int bch2_compression_stats_to_text(struct printbuf *out, struct bch_fs *c ...@@ -318,26 +313,45 @@ static int bch2_compression_stats_to_text(struct printbuf *out, struct bch_fs *c
if (ret) if (ret)
return ret; return ret;
prt_printf(out, "uncompressed:\n"); prt_str(out, "type");
prt_printf(out, " nr extents: %llu\n", nr_uncompressed_extents); printbuf_tabstop_push(out, 12);
prt_printf(out, " size: "); prt_tab(out);
prt_human_readable_u64(out, uncompressed_sectors << 9);
prt_printf(out, "\n");
prt_printf(out, "compressed:\n"); prt_str(out, "compressed");
prt_printf(out, " nr extents: %llu\n", nr_compressed_extents); printbuf_tabstop_push(out, 16);
prt_printf(out, " compressed size: "); prt_tab_rjust(out);
prt_human_readable_u64(out, compressed_sectors_compressed << 9);
prt_printf(out, "\n"); prt_str(out, "uncompressed");
prt_printf(out, " uncompressed size: "); printbuf_tabstop_push(out, 16);
prt_human_readable_u64(out, compressed_sectors_uncompressed << 9); prt_tab_rjust(out);
prt_printf(out, "\n");
prt_str(out, "average extent size");
printbuf_tabstop_push(out, 24);
prt_tab_rjust(out);
prt_newline(out);
for (unsigned i = 0; i < ARRAY_SIZE(s); i++) {
prt_str(out, bch2_compression_types[i]);
prt_tab(out);
prt_human_readable_u64(out, s[i].sectors_compressed << 9);
prt_tab_rjust(out);
prt_human_readable_u64(out, s[i].sectors_uncompressed << 9);
prt_tab_rjust(out);
prt_human_readable_u64(out, s[i].nr_extents
? div_u64(s[i].sectors_uncompressed << 9, s[i].nr_extents)
: 0);
prt_tab_rjust(out);
prt_newline(out);
}
if (compressed_incompressible) {
prt_printf(out, "%llu compressed & incompressible extents", compressed_incompressible);
prt_newline(out);
}
prt_printf(out, "incompressible:\n");
prt_printf(out, " nr extents: %llu\n", nr_incompressible_extents);
prt_printf(out, " size: ");
prt_human_readable_u64(out, incompressible_sectors << 9);
prt_printf(out, "\n");
return 0; return 0;
} }
......
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