Commit 75c8d030 authored by Kent Overstreet's avatar Kent Overstreet Committed by Kent Overstreet

bcachefs: Kill old rebuild_replicas option

This option was useful when the replicas mechism was new and still being
debugged, but hasn't been used in ages - let's delete it.
Signed-off-by: default avatarKent Overstreet <kent.overstreet@gmail.com>
parent 41fc8622
...@@ -518,7 +518,6 @@ enum { ...@@ -518,7 +518,6 @@ enum {
/* misc: */ /* misc: */
BCH_FS_NEED_ANOTHER_GC, BCH_FS_NEED_ANOTHER_GC,
BCH_FS_DELETED_NODES, BCH_FS_DELETED_NODES,
BCH_FS_REBUILD_REPLICAS,
}; };
struct btree_debug { struct btree_debug {
......
...@@ -382,10 +382,9 @@ static inline int update_replicas(struct bch_fs *c, struct bkey_s_c k, ...@@ -382,10 +382,9 @@ static inline int update_replicas(struct bch_fs *c, struct bkey_s_c k,
idx = bch2_replicas_entry_idx(c, r); idx = bch2_replicas_entry_idx(c, r);
if (idx < 0 && if (idx < 0 &&
(test_bit(BCH_FS_REBUILD_REPLICAS, &c->flags) ||
fsck_err(c, "no replicas entry\n" fsck_err(c, "no replicas entry\n"
" while marking %s", " while marking %s",
(bch2_bkey_val_to_text(&buf, c, k), buf.buf)))) { (bch2_bkey_val_to_text(&buf, c, k), buf.buf))) {
percpu_up_read(&c->mark_lock); percpu_up_read(&c->mark_lock);
ret = bch2_mark_replicas(c, r); ret = bch2_mark_replicas(c, r);
percpu_down_read(&c->mark_lock); percpu_down_read(&c->mark_lock);
......
...@@ -1054,7 +1054,7 @@ int bch2_journal_read(struct bch_fs *c, u64 *blacklist_seq, u64 *start_seq) ...@@ -1054,7 +1054,7 @@ int bch2_journal_read(struct bch_fs *c, u64 *blacklist_seq, u64 *start_seq)
jlist.ret = 0; jlist.ret = 0;
for_each_member_device(ca, c, iter) { for_each_member_device(ca, c, iter) {
if (!test_bit(BCH_FS_REBUILD_REPLICAS, &c->flags) && if (!c->opts.fsck &&
!(bch2_dev_has_data(c, ca) & (1 << BCH_DATA_journal))) !(bch2_dev_has_data(c, ca) & (1 << BCH_DATA_journal)))
continue; continue;
...@@ -1211,10 +1211,9 @@ int bch2_journal_read(struct bch_fs *c, u64 *blacklist_seq, u64 *start_seq) ...@@ -1211,10 +1211,9 @@ int bch2_journal_read(struct bch_fs *c, u64 *blacklist_seq, u64 *start_seq)
bch2_replicas_entry_to_text(&buf, &replicas.e); bch2_replicas_entry_to_text(&buf, &replicas.e);
if (!degraded && if (!degraded &&
(test_bit(BCH_FS_REBUILD_REPLICAS, &c->flags) ||
fsck_err_on(!bch2_replicas_marked(c, &replicas.e), c, fsck_err_on(!bch2_replicas_marked(c, &replicas.e), c,
"superblock not marked as containing replicas %s", "superblock not marked as containing replicas %s",
buf.buf))) { buf.buf)) {
ret = bch2_mark_replicas(c, &replicas.e); ret = bch2_mark_replicas(c, &replicas.e);
if (ret) if (ret)
goto err; goto err;
......
...@@ -316,11 +316,6 @@ enum opt_type { ...@@ -316,11 +316,6 @@ enum opt_type {
OPT_BOOL(), \ OPT_BOOL(), \
BCH2_NO_SB_OPT, false, \ BCH2_NO_SB_OPT, false, \
NULL, "Don't replay the journal") \ NULL, "Don't replay the journal") \
x(rebuild_replicas, u8, \
OPT_FS|OPT_MOUNT, \
OPT_BOOL(), \
BCH2_NO_SB_OPT, false, \
NULL, "Rebuild the superblock replicas section") \
x(keep_journal, u8, \ x(keep_journal, u8, \
0, \ 0, \
OPT_BOOL(), \ OPT_BOOL(), \
......
...@@ -1087,12 +1087,6 @@ int bch2_fs_recovery(struct bch_fs *c) ...@@ -1087,12 +1087,6 @@ int bch2_fs_recovery(struct bch_fs *c)
c->opts.fix_errors = FSCK_OPT_YES; c->opts.fix_errors = FSCK_OPT_YES;
} }
if (!c->replicas.entries ||
c->opts.rebuild_replicas) {
bch_info(c, "building replicas info");
set_bit(BCH_FS_REBUILD_REPLICAS, &c->flags);
}
if (!c->opts.nochanges) { if (!c->opts.nochanges) {
if (c->sb.version < bcachefs_metadata_version_new_data_types) { if (c->sb.version < bcachefs_metadata_version_new_data_types) {
bch_info(c, "version prior to new_data_types, upgrade and fsck required"); bch_info(c, "version prior to new_data_types, upgrade and fsck required");
...@@ -1224,10 +1218,7 @@ int bch2_fs_recovery(struct bch_fs *c) ...@@ -1224,10 +1218,7 @@ int bch2_fs_recovery(struct bch_fs *c)
if (!c->opts.fsck) if (!c->opts.fsck)
set_bit(BCH_FS_FSCK_DONE, &c->flags); set_bit(BCH_FS_FSCK_DONE, &c->flags);
if (c->opts.fsck || if (c->opts.fsck) {
!(c->sb.compat & (1ULL << BCH_COMPAT_alloc_info)) ||
!(c->sb.compat & (1ULL << BCH_COMPAT_alloc_metadata)) ||
test_bit(BCH_FS_REBUILD_REPLICAS, &c->flags)) {
bool metadata_only = c->opts.norecovery; bool metadata_only = c->opts.norecovery;
bch_info(c, "checking allocations"); bch_info(c, "checking allocations");
...@@ -1236,24 +1227,24 @@ int bch2_fs_recovery(struct bch_fs *c) ...@@ -1236,24 +1227,24 @@ int bch2_fs_recovery(struct bch_fs *c)
if (ret) if (ret)
goto err; goto err;
bch_verbose(c, "done checking allocations"); bch_verbose(c, "done checking allocations");
}
if (c->opts.fsck) {
bch_info(c, "checking need_discard and freespace btrees"); bch_info(c, "checking need_discard and freespace btrees");
err = "error checking need_discard and freespace btrees"; err = "error checking need_discard and freespace btrees";
ret = bch2_check_alloc_info(c); ret = bch2_check_alloc_info(c);
if (ret) if (ret)
goto err; goto err;
bch_verbose(c, "done checking need_discard and freespace btrees");
bch_info(c, "checking lrus");
err = "error checking lrus";
ret = bch2_check_lrus(c, true); ret = bch2_check_lrus(c, true);
if (ret) if (ret)
goto err; goto err;
bch_verbose(c, "done checking need_discard and freespace btrees"); bch_verbose(c, "done checking lrus");
} }
bch2_stripes_heap_start(c); bch2_stripes_heap_start(c);
clear_bit(BCH_FS_REBUILD_REPLICAS, &c->flags);
set_bit(BCH_FS_INITIAL_GC_DONE, &c->flags); set_bit(BCH_FS_INITIAL_GC_DONE, &c->flags);
set_bit(BCH_FS_MAY_GO_RW, &c->flags); set_bit(BCH_FS_MAY_GO_RW, &c->flags);
......
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