]> git.sesse.net Git - bcachefs-tools-debian/commitdiff
Update bcachefs sources to fb39031ade bcachefs: bch2_sb_maybe_downgrade(), bch2_sb_up...
authorKent Overstreet <kent.overstreet@linux.dev>
Mon, 10 Jul 2023 16:23:51 +0000 (12:23 -0400)
committerKent Overstreet <kent.overstreet@linux.dev>
Mon, 10 Jul 2023 16:34:08 +0000 (12:34 -0400)
Signed-off-by: Kent Overstreet <kent.overstreet@linux.dev>
.bcachefs_revision
libbcachefs/btree_update_interior.c
libbcachefs/btree_update_leaf.c
libbcachefs/recovery.c
libbcachefs/super-io.c
libbcachefs/super-io.h

index f1aa0f0c7d3e2a43a5ec5d2f79fe23d98d98bed8..381d64566191db52c7de87d399f48f1b95d9c4a7 100644 (file)
@@ -1 +1 @@
-1e3ca87f7b8e33f8d96260afebc7e78959f93073
+fb39031ade476044b4d89e6a8f20de8e025be39c
index 5592feff79d17760dc504155b7ca39c111c5fd39..3659b2c08109b71bb09e5d7fc166b6f049e92ab2 100644 (file)
@@ -1158,6 +1158,17 @@ bch2_btree_update_start(struct btree_trans *trans, struct btree_path *path,
            bch2_err_matches(ret, ENOMEM)) {
                struct closure cl;
 
+               /*
+                * XXX: this should probably be a separate BTREE_INSERT_NONBLOCK
+                * flag
+                */
+               if (bch2_err_matches(ret, ENOSPC) &&
+                   (flags & BTREE_INSERT_JOURNAL_RECLAIM) &&
+                   watermark != BCH_WATERMARK_reclaim) {
+                       ret = -BCH_ERR_journal_reclaim_would_deadlock;
+                       goto err;
+               }
+
                closure_init_stack(&cl);
 
                do {
index 6e12e8e7c301b045f1d47877a2123e70f690b21b..53219fdcff667b29cf86baeacc19e8fa499b4291 100644 (file)
@@ -958,6 +958,10 @@ int bch2_trans_commit_error(struct btree_trans *trans, unsigned flags,
                        bch2_replicas_delta_list_mark(c, trans->fs_usage_deltas));
                break;
        case -BCH_ERR_journal_res_get_blocked:
+               /*
+                * XXX: this should probably be a separate BTREE_INSERT_NONBLOCK
+                * flag
+                */
                if ((flags & BTREE_INSERT_JOURNAL_RECLAIM) &&
                    (flags & BCH_WATERMARK_MASK) != BCH_WATERMARK_reclaim) {
                        ret = -BCH_ERR_journal_reclaim_would_deadlock;
index 995e1b13f63ec87bcdb466d7c215c8ab4577d8c7..47adb667a46ab6eaac0f13ca7f81cfa594a03cab 100644 (file)
@@ -1169,8 +1169,7 @@ static void check_version_upgrade(struct bch_fs *c)
                c->opts.fix_errors      = FSCK_OPT_YES;
 
                mutex_lock(&c->sb_lock);
-               c->disk_sb.sb->version = cpu_to_le16(new_version);
-               c->disk_sb.sb->features[0] |= cpu_to_le64(BCH_SB_FEATURES_ALL);
+               bch2_sb_upgrade(c, new_version);
                mutex_unlock(&c->sb_lock);
 
                printbuf_exit(&buf);
@@ -1528,10 +1527,11 @@ int bch2_fs_initialize(struct bch_fs *c)
        c->disk_sb.sb->compat[0] |= cpu_to_le64(1ULL << BCH_COMPAT_extents_above_btree_updates_done);
        c->disk_sb.sb->compat[0] |= cpu_to_le64(1ULL << BCH_COMPAT_bformat_overflow_done);
 
+       bch2_sb_maybe_downgrade(c);
+
        if (c->opts.version_upgrade != BCH_VERSION_UPGRADE_none) {
-               c->disk_sb.sb->version = cpu_to_le16(bcachefs_metadata_version_current);
+               bch2_sb_upgrade(c, bcachefs_metadata_version_current);
                SET_BCH_SB_VERSION_UPGRADE_COMPLETE(c->disk_sb.sb, bcachefs_metadata_version_current);
-               c->disk_sb.sb->features[0] |= cpu_to_le64(BCH_SB_FEATURES_ALL);
                bch2_write_super(c);
        }
        mutex_unlock(&c->sb_lock);
index b4aec5b6aef661cb5b1b669734ef6c80ae295918..1ac36060ed2d839215b751f8fd1f02d4d2ab0d61 100644 (file)
@@ -1197,17 +1197,10 @@ int bch2_sb_clean_validate_late(struct bch_fs *c, struct bch_sb_field_clean *cle
        return 0;
 }
 
-int bch2_fs_mark_dirty(struct bch_fs *c)
+/* Downgrade if superblock is at a higher version than currently supported: */
+void bch2_sb_maybe_downgrade(struct bch_fs *c)
 {
-       int ret;
-
-       /*
-        * Unconditionally write superblock, to verify it hasn't changed before
-        * we go rw:
-        */
-
-       mutex_lock(&c->sb_lock);
-       SET_BCH_SB_CLEAN(c->disk_sb.sb, false);
+       lockdep_assert_held(&c->sb_lock);
 
        /*
         * Downgrade, if superblock is at a higher version than currently
@@ -1220,8 +1213,31 @@ int bch2_fs_mark_dirty(struct bch_fs *c)
        if (c->sb.version_min > bcachefs_metadata_version_current)
                c->disk_sb.sb->version_min = cpu_to_le16(bcachefs_metadata_version_current);
        c->disk_sb.sb->compat[0] &= cpu_to_le64((1ULL << BCH_COMPAT_NR) - 1);
+}
+
+void bch2_sb_upgrade(struct bch_fs *c, unsigned new_version)
+{
+       lockdep_assert_held(&c->sb_lock);
 
+       c->disk_sb.sb->version = cpu_to_le16(new_version);
+       c->disk_sb.sb->features[0] |= cpu_to_le64(BCH_SB_FEATURES_ALL);
+}
+
+int bch2_fs_mark_dirty(struct bch_fs *c)
+{
+       int ret;
+
+       /*
+        * Unconditionally write superblock, to verify it hasn't changed before
+        * we go rw:
+        */
+
+       mutex_lock(&c->sb_lock);
+       SET_BCH_SB_CLEAN(c->disk_sb.sb, false);
+
+       bch2_sb_maybe_downgrade(c);
        c->disk_sb.sb->features[0] |= cpu_to_le64(BCH_SB_FEATURES_ALWAYS);
+
        ret = bch2_write_super(c);
        mutex_unlock(&c->sb_lock);
 
index a850cc4ae6c751c913e48be6a64604c580335b74..b365f088ba41dd66ff5fb76ac60cfe44bd36354a 100644 (file)
@@ -124,6 +124,9 @@ void bch2_journal_super_entries_add_common(struct bch_fs *,
 
 int bch2_sb_clean_validate_late(struct bch_fs *, struct bch_sb_field_clean *, int);
 
+void bch2_sb_maybe_downgrade(struct bch_fs *);
+void bch2_sb_upgrade(struct bch_fs *, unsigned);
+
 int bch2_fs_mark_dirty(struct bch_fs *);
 void bch2_fs_mark_clean(struct bch_fs *);