]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
bcachefs: Add assertions for unexpected transaction restarts
authorKent Overstreet <kent.overstreet@gmail.com>
Thu, 7 Jul 2022 04:37:46 +0000 (00:37 -0400)
committerKent Overstreet <kent.overstreet@linux.dev>
Sun, 22 Oct 2023 21:09:38 +0000 (17:09 -0400)
Signed-off-by: Kent Overstreet <kent.overstreet@gmail.com>
fs/bcachefs/btree_iter.h
fs/bcachefs/btree_update_interior.c

index c0b3c9d0650529cf813335d13fb2b41ac63024dd..51beeddcd45e62c951d5d5cef85f8ff43d9d2046 100644 (file)
@@ -427,13 +427,17 @@ __bch2_btree_iter_peek_and_restart(struct btree_trans *trans,
 
 #define lockrestart_do(_trans, _do)                                    \
 ({                                                                     \
+       u32 _restart_count;                                             \
        int _ret;                                                       \
                                                                        \
        do {                                                            \
-               bch2_trans_begin(_trans);                               \
+               _restart_count = bch2_trans_begin(_trans);              \
                _ret = (_do);                                           \
        } while (bch2_err_matches(_ret, BCH_ERR_transaction_restart));  \
                                                                        \
+       if (!_ret)                                                      \
+               bch2_trans_verify_not_restarted(_trans, _restart_count);\
+                                                                       \
        _ret;                                                           \
 })
 
@@ -474,7 +478,7 @@ __bch2_btree_iter_peek_and_restart(struct btree_trans *trans,
                             (_start), (_flags));                       \
                                                                        \
        while (1) {                                                     \
-               bch2_trans_begin(_trans);                               \
+               u32 _restart_count = bch2_trans_begin(_trans);          \
                (_k) = bch2_btree_iter_peek_type(&(_iter), (_flags));   \
                if (!(_k).k) {                                          \
                        _ret = 0;                                       \
@@ -486,6 +490,7 @@ __bch2_btree_iter_peek_and_restart(struct btree_trans *trans,
                        continue;                                       \
                if (_ret)                                               \
                        break;                                          \
+               bch2_trans_verify_not_restarted(_trans, _restart_count);\
                if (!bch2_btree_iter_advance(&(_iter)))                 \
                        break;                                          \
        }                                                               \
@@ -503,7 +508,7 @@ __bch2_btree_iter_peek_and_restart(struct btree_trans *trans,
                             (_start), (_flags));                       \
                                                                        \
        while (1) {                                                     \
-               bch2_trans_begin(_trans);                               \
+               u32 _restart_count = bch2_trans_begin(_trans);          \
                (_k) = bch2_btree_iter_peek_prev_type(&(_iter), (_flags));\
                if (!(_k).k) {                                          \
                        _ret = 0;                                       \
@@ -515,6 +520,7 @@ __bch2_btree_iter_peek_and_restart(struct btree_trans *trans,
                        continue;                                       \
                if (_ret)                                               \
                        break;                                          \
+               bch2_trans_verify_not_restarted(_trans, _restart_count);\
                if (!bch2_btree_iter_rewind(&(_iter)))                  \
                        break;                                          \
        }                                                               \
index 2190f288e21f2f5758cbbbab328e50f828235ce1..e10c159ec0799bd4725b4b23798567a128df6c95 100644 (file)
@@ -969,6 +969,7 @@ bch2_btree_update_start(struct btree_trans *trans, struct btree_path *path,
        unsigned update_level = level;
        int journal_flags = flags & JOURNAL_WATERMARK_MASK;
        int ret = 0;
+       u32 restart_count = trans->restart_count;
 
        BUG_ON(!path->should_be_locked);
 
@@ -1094,6 +1095,7 @@ bch2_btree_update_start(struct btree_trans *trans, struct btree_path *path,
        if (ret)
                goto err;
 
+       bch2_trans_verify_not_restarted(trans, restart_count);
        return as;
 err:
        bch2_btree_update_free(as);