mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
synced 2025-09-02 16:44:59 +00:00
bcachefs: Add the status of bucket gen gc to sysfs
Signed-off-by: Kent Overstreet <kent.overstreet@gmail.com> Signed-off-by: Kent Overstreet <kent.overstreet@linux.dev>
This commit is contained in:
parent
319c130507
commit
ac516d0e7d
@ -719,6 +719,9 @@ struct bch_fs {
|
|||||||
atomic_t kick_gc;
|
atomic_t kick_gc;
|
||||||
unsigned long gc_count;
|
unsigned long gc_count;
|
||||||
|
|
||||||
|
enum btree_id gc_gens_btree;
|
||||||
|
struct bpos gc_gens_pos;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Tracks GC's progress - everything in the range [ZERO_KEY..gc_cur_pos]
|
* Tracks GC's progress - everything in the range [ZERO_KEY..gc_cur_pos]
|
||||||
* has been marked by GC.
|
* has been marked by GC.
|
||||||
|
@ -1193,6 +1193,8 @@ static int bch2_gc_btree_gens(struct bch_fs *c, enum btree_id btree_id)
|
|||||||
|
|
||||||
while ((k = bch2_btree_iter_peek(iter)).k &&
|
while ((k = bch2_btree_iter_peek(iter)).k &&
|
||||||
!(ret = bkey_err(k))) {
|
!(ret = bkey_err(k))) {
|
||||||
|
c->gc_gens_pos = iter->pos;
|
||||||
|
|
||||||
if (gc_btree_gens_key(c, k)) {
|
if (gc_btree_gens_key(c, k)) {
|
||||||
bch2_bkey_buf_reassemble(&sk, c, k);
|
bch2_bkey_buf_reassemble(&sk, c, k);
|
||||||
bch2_extent_normalize(c, bkey_i_to_s(sk.k));
|
bch2_extent_normalize(c, bkey_i_to_s(sk.k));
|
||||||
@ -1244,6 +1246,8 @@ int bch2_gc_gens(struct bch_fs *c)
|
|||||||
|
|
||||||
for (i = 0; i < BTREE_ID_NR; i++)
|
for (i = 0; i < BTREE_ID_NR; i++)
|
||||||
if ((1 << i) & BTREE_ID_HAS_PTRS) {
|
if ((1 << i) & BTREE_ID_HAS_PTRS) {
|
||||||
|
c->gc_gens_btree = i;
|
||||||
|
c->gc_gens_pos = POS_MIN;
|
||||||
ret = bch2_gc_btree_gens(c, i);
|
ret = bch2_gc_btree_gens(c, i);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
bch_err(c, "error recalculating oldest_gen: %i", ret);
|
bch_err(c, "error recalculating oldest_gen: %i", ret);
|
||||||
@ -1260,6 +1264,9 @@ int bch2_gc_gens(struct bch_fs *c)
|
|||||||
up_read(&ca->bucket_lock);
|
up_read(&ca->bucket_lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
c->gc_gens_btree = 0;
|
||||||
|
c->gc_gens_pos = POS_MIN;
|
||||||
|
|
||||||
c->gc_count++;
|
c->gc_count++;
|
||||||
err:
|
err:
|
||||||
up_read(&c->gc_lock);
|
up_read(&c->gc_lock);
|
||||||
|
@ -136,6 +136,7 @@ write_attribute(trigger_btree_coalesce);
|
|||||||
write_attribute(trigger_gc);
|
write_attribute(trigger_gc);
|
||||||
write_attribute(prune_cache);
|
write_attribute(prune_cache);
|
||||||
rw_attribute(btree_gc_periodic);
|
rw_attribute(btree_gc_periodic);
|
||||||
|
rw_attribute(gc_gens_pos);
|
||||||
|
|
||||||
read_attribute(uuid);
|
read_attribute(uuid);
|
||||||
read_attribute(minor);
|
read_attribute(minor);
|
||||||
@ -312,6 +313,13 @@ static int bch2_compression_stats_to_text(struct printbuf *out, struct bch_fs *c
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void bch2_gc_gens_pos_to_text(struct printbuf *out, struct bch_fs *c)
|
||||||
|
{
|
||||||
|
pr_buf(out, "%s: ", bch2_btree_ids[c->gc_gens_btree]);
|
||||||
|
bch2_bpos_to_text(out, c->gc_gens_pos);
|
||||||
|
pr_buf(out, "\n");
|
||||||
|
}
|
||||||
|
|
||||||
SHOW(bch2_fs)
|
SHOW(bch2_fs)
|
||||||
{
|
{
|
||||||
struct bch_fs *c = container_of(kobj, struct bch_fs, kobj);
|
struct bch_fs *c = container_of(kobj, struct bch_fs, kobj);
|
||||||
@ -337,6 +345,11 @@ SHOW(bch2_fs)
|
|||||||
|
|
||||||
sysfs_printf(btree_gc_periodic, "%u", (int) c->btree_gc_periodic);
|
sysfs_printf(btree_gc_periodic, "%u", (int) c->btree_gc_periodic);
|
||||||
|
|
||||||
|
if (attr == &sysfs_gc_gens_pos) {
|
||||||
|
bch2_gc_gens_pos_to_text(&out, c);
|
||||||
|
return out.pos - buf;
|
||||||
|
}
|
||||||
|
|
||||||
sysfs_printf(copy_gc_enabled, "%i", c->copy_gc_enabled);
|
sysfs_printf(copy_gc_enabled, "%i", c->copy_gc_enabled);
|
||||||
|
|
||||||
sysfs_printf(rebalance_enabled, "%i", c->rebalance.enabled);
|
sysfs_printf(rebalance_enabled, "%i", c->rebalance.enabled);
|
||||||
@ -566,6 +579,7 @@ struct attribute *bch2_fs_internal_files[] = {
|
|||||||
&sysfs_trigger_journal_flush,
|
&sysfs_trigger_journal_flush,
|
||||||
&sysfs_trigger_btree_coalesce,
|
&sysfs_trigger_btree_coalesce,
|
||||||
&sysfs_trigger_gc,
|
&sysfs_trigger_gc,
|
||||||
|
&sysfs_gc_gens_pos,
|
||||||
&sysfs_prune_cache,
|
&sysfs_prune_cache,
|
||||||
|
|
||||||
&sysfs_copy_gc_enabled,
|
&sysfs_copy_gc_enabled,
|
||||||
|
Loading…
Reference in New Issue
Block a user