Commit 67b07638 authored by Kent Overstreet's avatar Kent Overstreet Committed by Kent Overstreet

bcachefs: traverse_all() is responsible for clearing should_be_locked

bch2_btree_iter_traverse_all() may loop, and it needs to clear
iter->should_be_locked on every iteration.
Signed-off-by: default avatarKent Overstreet <kent.overstreet@gmail.com>
parent fe523397
...@@ -1249,7 +1249,6 @@ static int __btree_iter_traverse_all(struct btree_trans *trans, int ret, ...@@ -1249,7 +1249,6 @@ static int __btree_iter_traverse_all(struct btree_trans *trans, int ret,
struct btree_iter *iter; struct btree_iter *iter;
u8 sorted[BTREE_ITER_MAX]; u8 sorted[BTREE_ITER_MAX];
int i, nr_sorted = 0; int i, nr_sorted = 0;
bool relock_fail;
if (trans->in_traverse_all) if (trans->in_traverse_all)
return -EINTR; return -EINTR;
...@@ -1257,17 +1256,10 @@ static int __btree_iter_traverse_all(struct btree_trans *trans, int ret, ...@@ -1257,17 +1256,10 @@ static int __btree_iter_traverse_all(struct btree_trans *trans, int ret,
trans->in_traverse_all = true; trans->in_traverse_all = true;
retry_all: retry_all:
nr_sorted = 0; nr_sorted = 0;
relock_fail = false;
trans_for_each_iter(trans, iter) { trans_for_each_iter(trans, iter) {
if (!bch2_btree_iter_relock(iter, _THIS_IP_))
relock_fail = true;
sorted[nr_sorted++] = iter->idx; sorted[nr_sorted++] = iter->idx;
} iter->should_be_locked = false;
if (!relock_fail) {
trans->in_traverse_all = false;
return 0;
} }
#define btree_iter_cmp_by_idx(_l, _r) \ #define btree_iter_cmp_by_idx(_l, _r) \
...@@ -2372,11 +2364,9 @@ void bch2_trans_reset(struct btree_trans *trans, unsigned flags) ...@@ -2372,11 +2364,9 @@ void bch2_trans_reset(struct btree_trans *trans, unsigned flags)
{ {
struct btree_iter *iter; struct btree_iter *iter;
trans_for_each_iter(trans, iter) { trans_for_each_iter(trans, iter)
iter->flags &= ~(BTREE_ITER_KEEP_UNTIL_COMMIT| iter->flags &= ~(BTREE_ITER_KEEP_UNTIL_COMMIT|
BTREE_ITER_SET_POS_AFTER_COMMIT); BTREE_ITER_SET_POS_AFTER_COMMIT);
iter->should_be_locked = false;
}
bch2_trans_unlink_iters(trans); bch2_trans_unlink_iters(trans);
......
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