Commit ad9c7992 authored by Kent Overstreet's avatar Kent Overstreet

bcachefs: Kill btree_iter->journal_pos

For BTREE_ITER_WITH_JOURNAL, we memoize lookups in the journal keys, to
avoid the binary search overhead.

Previously we stashed the pos of the last key returned from the journal,
in order to force the lookup to be redone when rewinding.

Now bch2_journal_keys_peek_upto() handles rewinding itself when
necessary - so we can slim down btree_iter.
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent 1ae8a090
...@@ -1854,19 +1854,11 @@ static struct bkey_i *bch2_btree_journal_peek(struct btree_trans *trans, ...@@ -1854,19 +1854,11 @@ static struct bkey_i *bch2_btree_journal_peek(struct btree_trans *trans,
struct btree_iter *iter, struct btree_iter *iter,
struct bpos end_pos) struct bpos end_pos)
{ {
struct bkey_i *k; return bch2_journal_keys_peek_upto(trans->c, iter->btree_id,
iter->path->level,
if (bpos_lt(iter->path->pos, iter->journal_pos)) iter->path->pos,
iter->journal_idx = 0; end_pos,
&iter->journal_idx);
k = bch2_journal_keys_peek_upto(trans->c, iter->btree_id,
iter->path->level,
iter->path->pos,
end_pos,
&iter->journal_idx);
iter->journal_pos = k ? k->k.p : end_pos;
return k;
} }
static noinline static noinline
......
...@@ -455,7 +455,6 @@ static inline void bch2_trans_iter_init_common(struct btree_trans *trans, ...@@ -455,7 +455,6 @@ static inline void bch2_trans_iter_init_common(struct btree_trans *trans,
iter->pos = pos; iter->pos = pos;
iter->k = POS_KEY(pos); iter->k = POS_KEY(pos);
iter->journal_idx = 0; iter->journal_idx = 0;
iter->journal_pos = POS_MIN;
#ifdef CONFIG_BCACHEFS_DEBUG #ifdef CONFIG_BCACHEFS_DEBUG
iter->ip_allocated = ip; iter->ip_allocated = ip;
#endif #endif
......
...@@ -73,6 +73,7 @@ static size_t bch2_journal_key_search(struct journal_keys *keys, ...@@ -73,6 +73,7 @@ static size_t bch2_journal_key_search(struct journal_keys *keys,
return idx_to_pos(keys, __bch2_journal_key_search(keys, id, level, pos)); return idx_to_pos(keys, __bch2_journal_key_search(keys, id, level, pos));
} }
/* Returns first non-overwritten key >= search key: */
struct bkey_i *bch2_journal_keys_peek_upto(struct bch_fs *c, enum btree_id btree_id, struct bkey_i *bch2_journal_keys_peek_upto(struct bch_fs *c, enum btree_id btree_id,
unsigned level, struct bpos pos, unsigned level, struct bpos pos,
struct bpos end_pos, size_t *idx) struct bpos end_pos, size_t *idx)
...@@ -86,12 +87,26 @@ struct bkey_i *bch2_journal_keys_peek_upto(struct bch_fs *c, enum btree_id btree ...@@ -86,12 +87,26 @@ struct bkey_i *bch2_journal_keys_peek_upto(struct bch_fs *c, enum btree_id btree
if (!*idx) if (!*idx)
*idx = __bch2_journal_key_search(keys, btree_id, level, pos); *idx = __bch2_journal_key_search(keys, btree_id, level, pos);
while (*idx &&
__journal_key_cmp(btree_id, level, end_pos, idx_to_key(keys, *idx - 1)) <= 0) {
--(*idx);
iters++;
if (iters == 10) {
*idx = 0;
goto search;
}
}
while ((k = *idx < keys->nr ? idx_to_key(keys, *idx) : NULL)) { while ((k = *idx < keys->nr ? idx_to_key(keys, *idx) : NULL)) {
if (__journal_key_cmp(btree_id, level, end_pos, k) < 0) if (__journal_key_cmp(btree_id, level, end_pos, k) < 0)
return NULL; return NULL;
if (__journal_key_cmp(btree_id, level, pos, k) <= 0 && if (k->overwritten) {
!k->overwritten) (*idx)++;
continue;
}
if (__journal_key_cmp(btree_id, level, pos, k) <= 0)
return k->k; return k->k;
(*idx)++; (*idx)++;
......
...@@ -304,7 +304,6 @@ struct btree_iter { ...@@ -304,7 +304,6 @@ struct btree_iter {
/* BTREE_ITER_WITH_JOURNAL: */ /* BTREE_ITER_WITH_JOURNAL: */
size_t journal_idx; size_t journal_idx;
struct bpos journal_pos;
#ifdef TRACK_PATH_ALLOCATED #ifdef TRACK_PATH_ALLOCATED
unsigned long ip_allocated; unsigned long ip_allocated;
#endif #endif
......
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