Commit 542e6396 authored by Kent Overstreet's avatar Kent Overstreet

bcachefs: bch2_btree_iter_peek_prev() no longer uses path->idx

Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent 566eabd3
...@@ -2245,10 +2245,10 @@ struct bkey_s_c bch2_btree_iter_peek_prev(struct btree_iter *iter) ...@@ -2245,10 +2245,10 @@ struct bkey_s_c bch2_btree_iter_peek_prev(struct btree_iter *iter)
{ {
struct btree_trans *trans = iter->trans; struct btree_trans *trans = iter->trans;
struct bpos search_key = iter->pos; struct bpos search_key = iter->pos;
struct btree_path *saved_path = NULL;
struct bkey_s_c k; struct bkey_s_c k;
struct bkey saved_k; struct bkey saved_k;
const struct bch_val *saved_v; const struct bch_val *saved_v;
btree_path_idx_t saved_path = 0;
int ret; int ret;
EBUG_ON(btree_iter_path(trans, iter)->cached || EBUG_ON(btree_iter_path(trans, iter)->cached ||
...@@ -2299,8 +2299,8 @@ struct bkey_s_c bch2_btree_iter_peek_prev(struct btree_iter *iter) ...@@ -2299,8 +2299,8 @@ struct bkey_s_c bch2_btree_iter_peek_prev(struct btree_iter *iter)
if (saved_path && !bkey_eq(k.k->p, saved_k.p)) { if (saved_path && !bkey_eq(k.k->p, saved_k.p)) {
bch2_path_put_nokeep(trans, iter->path, bch2_path_put_nokeep(trans, iter->path,
iter->flags & BTREE_ITER_INTENT); iter->flags & BTREE_ITER_INTENT);
iter->path = saved_path->idx; iter->path = saved_path;
saved_path = NULL; saved_path = 0;
iter->k = saved_k; iter->k = saved_k;
k.v = saved_v; k.v = saved_v;
goto got_key; goto got_key;
...@@ -2310,9 +2310,9 @@ struct bkey_s_c bch2_btree_iter_peek_prev(struct btree_iter *iter) ...@@ -2310,9 +2310,9 @@ struct bkey_s_c bch2_btree_iter_peek_prev(struct btree_iter *iter)
iter->snapshot, iter->snapshot,
k.k->p.snapshot)) { k.k->p.snapshot)) {
if (saved_path) if (saved_path)
bch2_path_put_nokeep(trans, saved_path->idx, bch2_path_put_nokeep(trans, saved_path,
iter->flags & BTREE_ITER_INTENT); iter->flags & BTREE_ITER_INTENT);
saved_path = trans->paths + btree_path_clone(trans, iter->path, saved_path = btree_path_clone(trans, iter->path,
iter->flags & BTREE_ITER_INTENT); iter->flags & BTREE_ITER_INTENT);
path = btree_iter_path(trans, iter); path = btree_iter_path(trans, iter);
saved_k = *k.k; saved_k = *k.k;
...@@ -2354,7 +2354,7 @@ struct bkey_s_c bch2_btree_iter_peek_prev(struct btree_iter *iter) ...@@ -2354,7 +2354,7 @@ struct bkey_s_c bch2_btree_iter_peek_prev(struct btree_iter *iter)
iter->pos.snapshot = iter->snapshot; iter->pos.snapshot = iter->snapshot;
out_no_locked: out_no_locked:
if (saved_path) if (saved_path)
bch2_path_put_nokeep(trans, saved_path->idx, iter->flags & BTREE_ITER_INTENT); bch2_path_put_nokeep(trans, saved_path, iter->flags & BTREE_ITER_INTENT);
bch2_btree_iter_verify_entry_exit(iter); bch2_btree_iter_verify_entry_exit(iter);
bch2_btree_iter_verify(iter); bch2_btree_iter_verify(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