Commit 98f2197d authored by Kent Overstreet's avatar Kent Overstreet Committed by Kent Overstreet

bcachefs: Fix bch2_write_super to obey very_degraded option

Signed-off-by: default avatarKent Overstreet <kent.overstreet@gmail.com>
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent ed8269cc
...@@ -699,8 +699,12 @@ int bch2_write_super(struct bch_fs *c) ...@@ -699,8 +699,12 @@ int bch2_write_super(struct bch_fs *c)
const char *err; const char *err;
struct bch_devs_mask sb_written; struct bch_devs_mask sb_written;
bool wrote, can_mount_without_written, can_mount_with_written; bool wrote, can_mount_without_written, can_mount_with_written;
unsigned degraded_flags = BCH_FORCE_IF_DEGRADED;
int ret = 0; int ret = 0;
if (c->opts.very_degraded)
degraded_flags |= BCH_FORCE_IF_LOST;
lockdep_assert_held(&c->sb_lock); lockdep_assert_held(&c->sb_lock);
closure_init_stack(cl); closure_init_stack(cl);
...@@ -769,13 +773,13 @@ int bch2_write_super(struct bch_fs *c) ...@@ -769,13 +773,13 @@ int bch2_write_super(struct bch_fs *c)
nr_wrote = dev_mask_nr(&sb_written); nr_wrote = dev_mask_nr(&sb_written);
can_mount_with_written = can_mount_with_written =
bch2_have_enough_devs(c, sb_written, BCH_FORCE_IF_DEGRADED, false); bch2_have_enough_devs(c, sb_written, degraded_flags, false);
for (i = 0; i < ARRAY_SIZE(sb_written.d); i++) for (i = 0; i < ARRAY_SIZE(sb_written.d); i++)
sb_written.d[i] = ~sb_written.d[i]; sb_written.d[i] = ~sb_written.d[i];
can_mount_without_written = can_mount_without_written =
bch2_have_enough_devs(c, sb_written, BCH_FORCE_IF_DEGRADED, false); bch2_have_enough_devs(c, sb_written, degraded_flags, false);
/* /*
* If we would be able to mount _without_ the devices we successfully * If we would be able to mount _without_ the devices we successfully
......
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