Commit c558c577 authored by Kent Overstreet's avatar Kent Overstreet

bcachefs: bch2_btree_trans_peek_slot_updates

refactoring the BTREE_ITER_WITH_UPDATES code, prep for removing the flag
and making it always-on
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent 359e89ad
...@@ -1921,32 +1921,16 @@ void bch2_btree_trans_peek_updates(struct btree_trans *trans, struct btree_iter ...@@ -1921,32 +1921,16 @@ void bch2_btree_trans_peek_updates(struct btree_trans *trans, struct btree_iter
} }
static noinline static noinline
struct bkey_i *__bch2_btree_trans_peek_updates(struct btree_iter *iter) void bch2_btree_trans_peek_slot_updates(struct btree_trans *trans, struct btree_iter *iter,
struct bkey_s_c *k)
{ {
struct btree_trans *trans = iter->trans; trans_for_each_update(trans, i)
struct bkey_i *ret = NULL; if (!i->key_cache_already_flushed &&
i->btree_id == iter->btree_id &&
trans_for_each_update(trans, i) { bpos_eq(i->k->k.p, iter->pos)) {
if (i->btree_id < iter->btree_id) iter->k = i->k->k;
continue; *k = bkey_i_to_s_c(i->k);
if (i->btree_id > iter->btree_id)
break;
if (bpos_lt(i->k->k.p, btree_iter_path(trans, iter)->pos))
continue;
if (i->key_cache_already_flushed)
continue;
if (!ret || bpos_lt(i->k->k.p, ret->k.p))
ret = i->k;
} }
return ret;
}
static inline struct bkey_i *btree_trans_peek_updates(struct btree_iter *iter)
{
return iter->flags & BTREE_ITER_WITH_UPDATES
? __bch2_btree_trans_peek_updates(iter)
: NULL;
} }
static struct bkey_i *bch2_btree_journal_peek(struct btree_trans *trans, static struct bkey_i *bch2_btree_journal_peek(struct btree_trans *trans,
...@@ -2478,12 +2462,12 @@ struct bkey_s_c bch2_btree_iter_peek_slot(struct btree_iter *iter) ...@@ -2478,12 +2462,12 @@ struct bkey_s_c bch2_btree_iter_peek_slot(struct btree_iter *iter)
if ((iter->flags & BTREE_ITER_CACHED) || if ((iter->flags & BTREE_ITER_CACHED) ||
!(iter->flags & (BTREE_ITER_IS_EXTENTS|BTREE_ITER_FILTER_SNAPSHOTS))) { !(iter->flags & (BTREE_ITER_IS_EXTENTS|BTREE_ITER_FILTER_SNAPSHOTS))) {
struct bkey_i *next_update; k = bkey_s_c_null;
if ((next_update = btree_trans_peek_updates(iter)) && if (unlikely((iter->flags & BTREE_ITER_WITH_UPDATES) &&
bpos_eq(next_update->k.p, iter->pos)) { trans->nr_updates)) {
iter->k = next_update->k; bch2_btree_trans_peek_slot_updates(trans, iter, &k);
k = bkey_i_to_s_c(next_update); if (k.k)
goto out; goto out;
} }
......
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