bcachefs: Fix setting of downgrade recovery passes/errors
authorKent Overstreet <kent.overstreet@linux.dev>
Mon, 27 May 2024 20:30:19 +0000 (16:30 -0400)
committerKent Overstreet <kent.overstreet@linux.dev>
Tue, 28 May 2024 15:29:26 +0000 (11:29 -0400)
bch2_check_version_downgrade() was setting c->sb.version, which
bch2_sb_set_downgrade() expects to be at the previous version; and it
shouldn't even have been set directly because c->sb.version is updated
by write_super().

Signed-off-by: Kent Overstreet <kent.overstreet@linux.dev>
fs/bcachefs/super-io.c

index f1bee6c5222d24b0dd32da210c7924b350c05d59..d73a0222f709541e5fadd288360c202d787d04e3 100644 (file)
@@ -1132,18 +1132,12 @@ bool bch2_check_version_downgrade(struct bch_fs *c)
         * c->sb will be checked before we write the superblock, so update it as
         * well:
         */
-       if (BCH_SB_VERSION_UPGRADE_COMPLETE(c->disk_sb.sb) > bcachefs_metadata_version_current) {
+       if (BCH_SB_VERSION_UPGRADE_COMPLETE(c->disk_sb.sb) > bcachefs_metadata_version_current)
                SET_BCH_SB_VERSION_UPGRADE_COMPLETE(c->disk_sb.sb, bcachefs_metadata_version_current);
-               c->sb.version_upgrade_complete = bcachefs_metadata_version_current;
-       }
-       if (c->sb.version > bcachefs_metadata_version_current) {
+       if (c->sb.version > bcachefs_metadata_version_current)
                c->disk_sb.sb->version = cpu_to_le16(bcachefs_metadata_version_current);
-               c->sb.version = bcachefs_metadata_version_current;
-       }
-       if (c->sb.version_min > bcachefs_metadata_version_current) {
+       if (c->sb.version_min > bcachefs_metadata_version_current)
                c->disk_sb.sb->version_min = cpu_to_le16(bcachefs_metadata_version_current);
-               c->sb.version_min = bcachefs_metadata_version_current;
-       }
        c->disk_sb.sb->compat[0] &= cpu_to_le64((1ULL << BCH_COMPAT_NR) - 1);
        return ret;
 }