Commit e9b9e475 authored by Kent Overstreet's avatar Kent Overstreet

bcachefs: bch2_dev_freespace_init() Print out status every 10 seconds

It appears freespace init can still take awhile, and we've had a report
or two of it getting stuck - let's have it print out where it's at every
10 seconds.
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent b1c945b3
...@@ -1890,7 +1890,8 @@ void bch2_do_invalidates(struct bch_fs *c) ...@@ -1890,7 +1890,8 @@ void bch2_do_invalidates(struct bch_fs *c)
bch2_write_ref_put(c, BCH_WRITE_REF_invalidate); bch2_write_ref_put(c, BCH_WRITE_REF_invalidate);
} }
static int bch2_dev_freespace_init(struct bch_fs *c, struct bch_dev *ca) static int bch2_dev_freespace_init(struct bch_fs *c, struct bch_dev *ca,
unsigned long *last_updated)
{ {
struct btree_trans trans; struct btree_trans trans;
struct btree_iter iter; struct btree_iter iter;
...@@ -1910,6 +1911,12 @@ static int bch2_dev_freespace_init(struct bch_fs *c, struct bch_dev *ca) ...@@ -1910,6 +1911,12 @@ static int bch2_dev_freespace_init(struct bch_fs *c, struct bch_dev *ca)
* freespace/need_discard/need_gc_gens btrees as needed: * freespace/need_discard/need_gc_gens btrees as needed:
*/ */
while (1) { while (1) {
if (*last_updated + HZ * 10 < jiffies) {
bch_info(ca, "%s: currently at %llu/%llu",
__func__, iter.pos.offset, ca->mi.nbuckets);
*last_updated = jiffies;
}
bch2_trans_begin(&trans); bch2_trans_begin(&trans);
if (bkey_ge(iter.pos, end)) { if (bkey_ge(iter.pos, end)) {
...@@ -1989,6 +1996,7 @@ int bch2_fs_freespace_init(struct bch_fs *c) ...@@ -1989,6 +1996,7 @@ int bch2_fs_freespace_init(struct bch_fs *c)
unsigned i; unsigned i;
int ret = 0; int ret = 0;
bool doing_init = false; bool doing_init = false;
unsigned long last_updated = jiffies;
/* /*
* We can crash during the device add path, so we need to check this on * We can crash during the device add path, so we need to check this on
...@@ -2004,7 +2012,7 @@ int bch2_fs_freespace_init(struct bch_fs *c) ...@@ -2004,7 +2012,7 @@ int bch2_fs_freespace_init(struct bch_fs *c)
doing_init = true; doing_init = true;
} }
ret = bch2_dev_freespace_init(c, ca); ret = bch2_dev_freespace_init(c, ca, &last_updated);
if (ret) { if (ret) {
percpu_ref_put(&ca->ref); percpu_ref_put(&ca->ref);
return ret; return ret;
......
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