diff options
author | Kent Overstreet <kent.overstreet@linux.dev> | 2023-08-03 17:33:20 -0400 |
---|---|---|
committer | Kent Overstreet <kent.overstreet@linux.dev> | 2023-10-22 17:10:09 -0400 |
commit | a1d1072fe75a52786b74f8a6093db3fa6a5d15d6 (patch) | |
tree | 240d282a6e201372fff4e7c331cefda068a1ad92 /fs/bcachefs/recovery.c | |
parent | 77212d3a76a4becabeac8736b686a533dd75913b (diff) | |
download | lwn-a1d1072fe75a52786b74f8a6093db3fa6a5d15d6.tar.gz lwn-a1d1072fe75a52786b74f8a6093db3fa6a5d15d6.zip |
bcachefs: Print out required recovery passes on version upgrade
Signed-off-by: Kent Overstreet <kent.overstreet@linux.dev>
Diffstat (limited to 'fs/bcachefs/recovery.c')
-rw-r--r-- | fs/bcachefs/recovery.c | 62 |
1 files changed, 37 insertions, 25 deletions
diff --git a/fs/bcachefs/recovery.c b/fs/bcachefs/recovery.c index 55a233c2c7cc..bcc1ee0b4ef2 100644 --- a/fs/bcachefs/recovery.c +++ b/fs/bcachefs/recovery.c @@ -1120,6 +1120,35 @@ static int bch2_fs_upgrade_for_subvolumes(struct bch_fs *c) return ret; } +static const char * const recovery_pass_names[] = { +#define x(_fn, _when) #_fn, + BCH_RECOVERY_PASSES() +#undef x + NULL +}; + +static int bch2_check_allocations(struct bch_fs *c) +{ + return bch2_gc(c, true, c->opts.norecovery); +} + +static int bch2_set_may_go_rw(struct bch_fs *c) +{ + set_bit(BCH_FS_MAY_GO_RW, &c->flags); + return 0; +} + +struct recovery_pass_fn { + int (*fn)(struct bch_fs *); + unsigned when; +}; + +static struct recovery_pass_fn recovery_passes[] = { +#define x(_fn, _when) { .fn = bch2_##_fn, .when = _when }, + BCH_RECOVERY_PASSES() +#undef x +}; + static void check_version_upgrade(struct bch_fs *c) { unsigned latest_compatible = bch2_version_compatible(c->sb.version); @@ -1172,7 +1201,12 @@ static void check_version_upgrade(struct bch_fs *c) recovery_passes = bch2_upgrade_recovery_passes(c, old_version, new_version); if (recovery_passes) { - prt_str(&buf, "fsck required"); + if ((recovery_passes & RECOVERY_PASS_ALL_FSCK) == RECOVERY_PASS_ALL_FSCK) + prt_str(&buf, "fsck required"); + else { + prt_str(&buf, "running recovery passses: "); + prt_bitflags(&buf, recovery_pass_names, recovery_passes); + } c->recovery_passes_explicit |= recovery_passes; c->opts.fix_errors = FSCK_FIX_yes; @@ -1188,29 +1222,6 @@ static void check_version_upgrade(struct bch_fs *c) } } -static int bch2_check_allocations(struct bch_fs *c) -{ - return bch2_gc(c, true, c->opts.norecovery); -} - -static int bch2_set_may_go_rw(struct bch_fs *c) -{ - set_bit(BCH_FS_MAY_GO_RW, &c->flags); - return 0; -} - -struct recovery_pass_fn { - int (*fn)(struct bch_fs *); - const char *name; - unsigned when; -}; - -static struct recovery_pass_fn recovery_passes[] = { -#define x(_fn, _when) { .fn = bch2_##_fn, .name = #_fn, .when = _when }, - BCH_RECOVERY_PASSES() -#undef x -}; - u64 bch2_fsck_recovery_passes(void) { u64 ret = 0; @@ -1248,7 +1259,8 @@ static int bch2_run_recovery_pass(struct bch_fs *c, enum bch_recovery_pass pass) struct recovery_pass_fn *p = recovery_passes + pass; if (!(p->when & PASS_SILENT)) - printk(KERN_INFO bch2_log_msg(c, "%s..."), p->name); + printk(KERN_INFO bch2_log_msg(c, "%s..."), + recovery_pass_names[pass]); ret = p->fn(c); if (ret) return ret; |