Commit 0e6dd8fb authored by Kent Overstreet's avatar Kent Overstreet Committed by Kent Overstreet

bcachefs: Ensure bch2_btree_iter_next() always advances

Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent 87c3beb4
...@@ -1110,7 +1110,8 @@ int __must_check bch2_btree_iter_traverse(struct btree_iter *iter) ...@@ -1110,7 +1110,8 @@ int __must_check bch2_btree_iter_traverse(struct btree_iter *iter)
{ {
int ret; int ret;
ret = __bch2_btree_iter_traverse(iter); ret = bch2_trans_cond_resched(iter->trans) ?:
__bch2_btree_iter_traverse(iter);
if (unlikely(ret)) if (unlikely(ret))
ret = __btree_iter_traverse_all(iter->trans, iter, ret); ret = __btree_iter_traverse_all(iter->trans, iter, ret);
...@@ -1302,9 +1303,11 @@ struct bkey_s_c bch2_btree_iter_peek(struct btree_iter *iter) ...@@ -1302,9 +1303,11 @@ struct bkey_s_c bch2_btree_iter_peek(struct btree_iter *iter)
return btree_iter_peek_uptodate(iter); return btree_iter_peek_uptodate(iter);
while (1) { while (1) {
if (iter->uptodate >= BTREE_ITER_NEED_RELOCK) {
ret = bch2_btree_iter_traverse(iter); ret = bch2_btree_iter_traverse(iter);
if (unlikely(ret)) if (unlikely(ret))
return bkey_s_c_err(ret); return bkey_s_c_err(ret);
}
k = __btree_iter_peek(iter, l); k = __btree_iter_peek(iter, l);
if (likely(k.k)) if (likely(k.k))
...@@ -1356,10 +1359,17 @@ struct bkey_s_c bch2_btree_iter_next(struct btree_iter *iter) ...@@ -1356,10 +1359,17 @@ struct bkey_s_c bch2_btree_iter_next(struct btree_iter *iter)
bch2_btree_iter_checks(iter, BTREE_ITER_KEYS); bch2_btree_iter_checks(iter, BTREE_ITER_KEYS);
iter->pos = btree_type_successor(iter->btree_id, iter->k.p);
if (unlikely(iter->uptodate != BTREE_ITER_UPTODATE)) { if (unlikely(iter->uptodate != BTREE_ITER_UPTODATE)) {
k = bch2_btree_iter_peek(iter); /*
if (IS_ERR_OR_NULL(k.k)) * XXX: when we just need to relock we should be able to avoid
return k; * calling traverse, but we need to kill BTREE_ITER_NEED_PEEK
* for that to work
*/
btree_iter_set_dirty(iter, BTREE_ITER_NEED_TRAVERSE);
return bch2_btree_iter_peek(iter);
} }
do { do {
...@@ -1559,9 +1569,11 @@ struct bkey_s_c bch2_btree_iter_peek_slot(struct btree_iter *iter) ...@@ -1559,9 +1569,11 @@ struct bkey_s_c bch2_btree_iter_peek_slot(struct btree_iter *iter)
if (iter->uptodate == BTREE_ITER_UPTODATE) if (iter->uptodate == BTREE_ITER_UPTODATE)
return btree_iter_peek_uptodate(iter); return btree_iter_peek_uptodate(iter);
if (iter->uptodate >= BTREE_ITER_NEED_RELOCK) {
ret = bch2_btree_iter_traverse(iter); ret = bch2_btree_iter_traverse(iter);
if (unlikely(ret)) if (unlikely(ret))
return bkey_s_c_err(ret); return bkey_s_c_err(ret);
}
return __bch2_btree_iter_peek_slot(iter); return __bch2_btree_iter_peek_slot(iter);
} }
......
...@@ -195,13 +195,14 @@ static inline int btree_iter_cmp(const struct btree_iter *l, ...@@ -195,13 +195,14 @@ static inline int btree_iter_cmp(const struct btree_iter *l,
* Unlocks before scheduling * Unlocks before scheduling
* Note: does not revalidate iterator * Note: does not revalidate iterator
*/ */
static inline void bch2_trans_cond_resched(struct btree_trans *trans) static inline int bch2_trans_cond_resched(struct btree_trans *trans)
{ {
if (need_resched()) { if (need_resched() || race_fault()) {
bch2_trans_unlock(trans); bch2_trans_unlock(trans);
schedule(); schedule();
} else if (race_fault()) { return bch2_trans_relock(trans) ? 0 : -EINTR;
bch2_trans_unlock(trans); } else {
return 0;
} }
} }
...@@ -229,8 +230,6 @@ static inline struct bkey_s_c __bch2_btree_iter_peek(struct btree_iter *iter, ...@@ -229,8 +230,6 @@ static inline struct bkey_s_c __bch2_btree_iter_peek(struct btree_iter *iter,
static inline struct bkey_s_c __bch2_btree_iter_next(struct btree_iter *iter, static inline struct bkey_s_c __bch2_btree_iter_next(struct btree_iter *iter,
unsigned flags) unsigned flags)
{ {
bch2_trans_cond_resched(iter->trans);
return flags & BTREE_ITER_SLOTS return flags & BTREE_ITER_SLOTS
? bch2_btree_iter_next_slot(iter) ? bch2_btree_iter_next_slot(iter)
: bch2_btree_iter_next(iter); : bch2_btree_iter_next(iter);
......
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