Commit 2b2c1a89 authored by Kent Overstreet's avatar Kent Overstreet Committed by Kent Overstreet

bcachefs: Simplify btree_iter_(next|prev)_leaf()

There's no good reason for these functions to not be using
bch2_btree_iter_set_pos().
Signed-off-by: default avatarKent Overstreet <kent.overstreet@gmail.com>
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent eaf79831
...@@ -1554,38 +1554,29 @@ void bch2_btree_iter_set_pos(struct btree_iter *iter, struct bpos new_pos) ...@@ -1554,38 +1554,29 @@ void bch2_btree_iter_set_pos(struct btree_iter *iter, struct bpos new_pos)
static inline bool btree_iter_set_pos_to_next_leaf(struct btree_iter *iter) static inline bool btree_iter_set_pos_to_next_leaf(struct btree_iter *iter)
{ {
struct btree_iter_level *l = &iter->l[0]; struct bpos next_pos = iter->l[0].b->key.k.p;
bool ret; bool ret = bkey_cmp(next_pos, POS_MAX) != 0;
bkey_init(&iter->k);
iter->k.p = iter->pos = l->b->key.k.p;
ret = bkey_cmp(iter->pos, POS_MAX) != 0;
if (ret && !(iter->flags & BTREE_ITER_IS_EXTENTS)) if (ret && !(iter->flags & BTREE_ITER_IS_EXTENTS))
iter->k.p = iter->pos = bkey_successor(iter->pos); next_pos = bkey_successor(next_pos);
btree_iter_pos_changed(iter, 1); bch2_btree_iter_set_pos(iter, next_pos);
return ret; return ret;
} }
static inline bool btree_iter_set_pos_to_prev_leaf(struct btree_iter *iter) static inline bool btree_iter_set_pos_to_prev_leaf(struct btree_iter *iter)
{ {
struct btree_iter_level *l = &iter->l[0]; struct bpos next_pos = iter->l[0].b->data->min_key;
bool ret; bool ret = bkey_cmp(next_pos, POS_MIN) != 0;
bkey_init(&iter->k);
iter->k.p = iter->pos = l->b->data->min_key;
iter->uptodate = BTREE_ITER_NEED_TRAVERSE;
ret = bkey_cmp(iter->pos, POS_MIN) != 0;
if (ret) { if (ret) {
iter->k.p = iter->pos = bkey_predecessor(iter->pos); next_pos = bkey_predecessor(next_pos);
if (iter->flags & BTREE_ITER_IS_EXTENTS) if (iter->flags & BTREE_ITER_IS_EXTENTS)
iter->k.p = iter->pos = bkey_predecessor(iter->pos); next_pos = bkey_predecessor(next_pos);
} }
btree_iter_pos_changed(iter, -1); bch2_btree_iter_set_pos(iter, next_pos);
return ret; return ret;
} }
......
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