Commit 96ed47d1 authored by Kent Overstreet's avatar Kent Overstreet

bcachefs: bch2_btree_path_traverse() -> btree_path_idx_t

Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent f6363aca
...@@ -994,16 +994,16 @@ static int bch2_btree_path_traverse_all(struct btree_trans *trans) ...@@ -994,16 +994,16 @@ static int bch2_btree_path_traverse_all(struct btree_trans *trans)
/* Now, redo traversals in correct order: */ /* Now, redo traversals in correct order: */
i = 0; i = 0;
while (i < trans->nr_sorted) { while (i < trans->nr_sorted) {
path = trans->paths + trans->sorted[i]; btree_path_idx_t idx = trans->sorted[i];
/* /*
* Traversing a path can cause another path to be added at about * Traversing a path can cause another path to be added at about
* the same position: * the same position:
*/ */
if (path->uptodate) { if (trans->paths[idx].uptodate) {
__btree_path_get(path, false); __btree_path_get(&trans->paths[idx], false);
ret = bch2_btree_path_traverse_one(trans, path, 0, _THIS_IP_); ret = bch2_btree_path_traverse_one(trans, idx, 0, _THIS_IP_);
__btree_path_put(path, false); __btree_path_put(&trans->paths[idx], false);
if (bch2_err_matches(ret, BCH_ERR_transaction_restart) || if (bch2_err_matches(ret, BCH_ERR_transaction_restart) ||
bch2_err_matches(ret, ENOMEM)) bch2_err_matches(ret, ENOMEM))
...@@ -1108,10 +1108,11 @@ static inline unsigned btree_path_up_until_good_node(struct btree_trans *trans, ...@@ -1108,10 +1108,11 @@ static inline unsigned btree_path_up_until_good_node(struct btree_trans *trans,
* stashed in the iterator and returned from bch2_trans_exit(). * stashed in the iterator and returned from bch2_trans_exit().
*/ */
int bch2_btree_path_traverse_one(struct btree_trans *trans, int bch2_btree_path_traverse_one(struct btree_trans *trans,
struct btree_path *path, btree_path_idx_t path_idx,
unsigned flags, unsigned flags,
unsigned long trace_ip) unsigned long trace_ip)
{ {
struct btree_path *path = &trans->paths[path_idx];
unsigned depth_want = path->level; unsigned depth_want = path->level;
int ret = -((int) trans->restarted); int ret = -((int) trans->restarted);
...@@ -1135,6 +1136,8 @@ int bch2_btree_path_traverse_one(struct btree_trans *trans, ...@@ -1135,6 +1136,8 @@ int bch2_btree_path_traverse_one(struct btree_trans *trans,
goto out; goto out;
} }
path = &trans->paths[path_idx];
if (unlikely(path->level >= BTREE_MAX_DEPTH)) if (unlikely(path->level >= BTREE_MAX_DEPTH))
goto out; goto out;
...@@ -1665,7 +1668,7 @@ struct bkey_s_c bch2_btree_path_peek_slot(struct btree_path *path, struct bkey * ...@@ -1665,7 +1668,7 @@ struct bkey_s_c bch2_btree_path_peek_slot(struct btree_path *path, struct bkey *
int __must_check int __must_check
__bch2_btree_iter_traverse(struct btree_iter *iter) __bch2_btree_iter_traverse(struct btree_iter *iter)
{ {
return bch2_btree_path_traverse(iter->trans, iter->path, iter->flags); return bch2_btree_path_traverse(iter->trans, iter->path->idx, iter->flags);
} }
int __must_check int __must_check
...@@ -1679,7 +1682,7 @@ bch2_btree_iter_traverse(struct btree_iter *iter) ...@@ -1679,7 +1682,7 @@ bch2_btree_iter_traverse(struct btree_iter *iter)
iter->flags & BTREE_ITER_INTENT, iter->flags & BTREE_ITER_INTENT,
btree_iter_ip_allocated(iter)); btree_iter_ip_allocated(iter));
ret = bch2_btree_path_traverse(trans, iter->path, iter->flags); ret = bch2_btree_path_traverse(trans, iter->path->idx, iter->flags);
if (ret) if (ret)
return ret; return ret;
...@@ -1698,7 +1701,7 @@ struct btree *bch2_btree_iter_peek_node(struct btree_iter *iter) ...@@ -1698,7 +1701,7 @@ struct btree *bch2_btree_iter_peek_node(struct btree_iter *iter)
EBUG_ON(iter->path->cached); EBUG_ON(iter->path->cached);
bch2_btree_iter_verify(iter); bch2_btree_iter_verify(iter);
ret = bch2_btree_path_traverse(trans, iter->path, iter->flags); ret = bch2_btree_path_traverse(trans, iter->path->idx, iter->flags);
if (ret) if (ret)
goto err; goto err;
...@@ -1783,7 +1786,7 @@ struct btree *bch2_btree_iter_next_node(struct btree_iter *iter) ...@@ -1783,7 +1786,7 @@ struct btree *bch2_btree_iter_next_node(struct btree_iter *iter)
btree_path_set_level_down(trans, path, iter->min_depth); btree_path_set_level_down(trans, path, iter->min_depth);
ret = bch2_btree_path_traverse(trans, path, iter->flags); ret = bch2_btree_path_traverse(trans, path->idx, iter->flags);
if (ret) if (ret)
goto err; goto err;
...@@ -1937,7 +1940,7 @@ struct bkey_s_c btree_trans_peek_key_cache(struct btree_iter *iter, struct bpos ...@@ -1937,7 +1940,7 @@ struct bkey_s_c btree_trans_peek_key_cache(struct btree_iter *iter, struct bpos
iter->flags & BTREE_ITER_INTENT, iter->flags & BTREE_ITER_INTENT,
btree_iter_ip_allocated(iter)); btree_iter_ip_allocated(iter));
ret = bch2_btree_path_traverse(trans, iter->key_cache_path, ret = bch2_btree_path_traverse(trans, iter->key_cache_path->idx,
iter->flags|BTREE_ITER_CACHED) ?: iter->flags|BTREE_ITER_CACHED) ?:
bch2_btree_path_relock(trans, iter->path, _THIS_IP_); bch2_btree_path_relock(trans, iter->path, _THIS_IP_);
if (unlikely(ret)) if (unlikely(ret))
...@@ -1970,7 +1973,7 @@ static struct bkey_s_c __bch2_btree_iter_peek(struct btree_iter *iter, struct bp ...@@ -1970,7 +1973,7 @@ static struct bkey_s_c __bch2_btree_iter_peek(struct btree_iter *iter, struct bp
iter->flags & BTREE_ITER_INTENT, iter->flags & BTREE_ITER_INTENT,
btree_iter_ip_allocated(iter)); btree_iter_ip_allocated(iter));
ret = bch2_btree_path_traverse(trans, iter->path, iter->flags); ret = bch2_btree_path_traverse(trans, iter->path->idx, iter->flags);
if (unlikely(ret)) { if (unlikely(ret)) {
/* ensure that iter->k is consistent with iter->pos: */ /* ensure that iter->k is consistent with iter->pos: */
bch2_btree_iter_set_pos(iter, iter->pos); bch2_btree_iter_set_pos(iter, iter->pos);
...@@ -2123,7 +2126,7 @@ struct bkey_s_c bch2_btree_iter_peek_upto(struct btree_iter *iter, struct bpos e ...@@ -2123,7 +2126,7 @@ struct bkey_s_c bch2_btree_iter_peek_upto(struct btree_iter *iter, struct bpos e
iter->update_path->idx, pos, iter->update_path->idx, pos,
iter->flags & BTREE_ITER_INTENT, iter->flags & BTREE_ITER_INTENT,
_THIS_IP_); _THIS_IP_);
ret = bch2_btree_path_traverse(trans, iter->update_path, iter->flags); ret = bch2_btree_path_traverse(trans, iter->update_path->idx, iter->flags);
if (unlikely(ret)) { if (unlikely(ret)) {
k = bkey_s_c_err(ret); k = bkey_s_c_err(ret);
goto out_no_locked; goto out_no_locked;
...@@ -2249,7 +2252,7 @@ struct bkey_s_c bch2_btree_iter_peek_prev(struct btree_iter *iter) ...@@ -2249,7 +2252,7 @@ struct bkey_s_c bch2_btree_iter_peek_prev(struct btree_iter *iter)
iter->flags & BTREE_ITER_INTENT, iter->flags & BTREE_ITER_INTENT,
btree_iter_ip_allocated(iter)); btree_iter_ip_allocated(iter));
ret = bch2_btree_path_traverse(trans, iter->path, iter->flags); ret = bch2_btree_path_traverse(trans, iter->path->idx, iter->flags);
if (unlikely(ret)) { if (unlikely(ret)) {
/* ensure that iter->k is consistent with iter->pos: */ /* ensure that iter->k is consistent with iter->pos: */
bch2_btree_iter_set_pos(iter, iter->pos); bch2_btree_iter_set_pos(iter, iter->pos);
...@@ -2382,7 +2385,7 @@ struct bkey_s_c bch2_btree_iter_peek_slot(struct btree_iter *iter) ...@@ -2382,7 +2385,7 @@ struct bkey_s_c bch2_btree_iter_peek_slot(struct btree_iter *iter)
iter->flags & BTREE_ITER_INTENT, iter->flags & BTREE_ITER_INTENT,
btree_iter_ip_allocated(iter)); btree_iter_ip_allocated(iter));
ret = bch2_btree_path_traverse(trans, iter->path, iter->flags); ret = bch2_btree_path_traverse(trans, iter->path->idx, iter->flags);
if (unlikely(ret)) { if (unlikely(ret)) {
k = bkey_s_c_err(ret); k = bkey_s_c_err(ret);
goto out_no_locked; goto out_no_locked;
......
...@@ -189,20 +189,19 @@ bch2_btree_path_set_pos(struct btree_trans *trans, ...@@ -189,20 +189,19 @@ bch2_btree_path_set_pos(struct btree_trans *trans,
: path; : path;
} }
int __must_check bch2_btree_path_traverse_one(struct btree_trans *, struct btree_path *, int __must_check bch2_btree_path_traverse_one(struct btree_trans *,
btree_path_idx_t,
unsigned, unsigned long); unsigned, unsigned long);
static inline int __must_check bch2_btree_path_traverse(struct btree_trans *trans, static inline int __must_check bch2_btree_path_traverse(struct btree_trans *trans,
struct btree_path *path, unsigned flags) btree_path_idx_t path, unsigned flags)
{ {
if (path->uptodate < BTREE_ITER_NEED_RELOCK) if (trans->paths[path].uptodate < BTREE_ITER_NEED_RELOCK)
return 0; return 0;
return bch2_btree_path_traverse_one(trans, path, flags, _RET_IP_); return bch2_btree_path_traverse_one(trans, path, flags, _RET_IP_);
} }
int __must_check bch2_btree_path_traverse(struct btree_trans *,
struct btree_path *, unsigned);
btree_path_idx_t bch2_path_get(struct btree_trans *, enum btree_id, struct bpos, btree_path_idx_t bch2_path_get(struct btree_trans *, enum btree_id, struct bpos,
unsigned, unsigned, unsigned, unsigned long); unsigned, unsigned, unsigned, unsigned long);
struct bkey_s_c bch2_btree_path_peek_slot(struct btree_path *, struct bkey *); struct bkey_s_c bch2_btree_path_peek_slot(struct btree_path *, struct bkey *);
......
...@@ -350,7 +350,7 @@ static noinline int flush_new_cached_update(struct btree_trans *trans, ...@@ -350,7 +350,7 @@ static noinline int flush_new_cached_update(struct btree_trans *trans,
btree_path_idx_t path_idx = btree_path_idx_t path_idx =
bch2_path_get(trans, path->btree_id, path->pos, 1, 0, bch2_path_get(trans, path->btree_id, path->pos, 1, 0,
BTREE_ITER_INTENT, _THIS_IP_); BTREE_ITER_INTENT, _THIS_IP_);
ret = bch2_btree_path_traverse(trans, trans->paths + path_idx, 0); ret = bch2_btree_path_traverse(trans, path_idx, 0);
if (ret) if (ret)
goto out; goto out;
...@@ -372,7 +372,7 @@ static noinline int flush_new_cached_update(struct btree_trans *trans, ...@@ -372,7 +372,7 @@ static noinline int flush_new_cached_update(struct btree_trans *trans,
btree_path_set_should_be_locked(btree_path); btree_path_set_should_be_locked(btree_path);
ret = bch2_trans_update_by_path(trans, btree_path, i->k, flags, ip); ret = bch2_trans_update_by_path(trans, btree_path, i->k, flags, ip);
out: out:
bch2_path_put(trans, btree_path->idx, true); bch2_path_put(trans, path_idx, true);
return ret; return ret;
} }
...@@ -480,7 +480,7 @@ static noinline int bch2_trans_update_get_key_cache(struct btree_trans *trans, ...@@ -480,7 +480,7 @@ static noinline int bch2_trans_update_get_key_cache(struct btree_trans *trans,
iter->flags & BTREE_ITER_INTENT, iter->flags & BTREE_ITER_INTENT,
_THIS_IP_); _THIS_IP_);
ret = bch2_btree_path_traverse(trans, iter->key_cache_path, ret = bch2_btree_path_traverse(trans, iter->key_cache_path->idx,
BTREE_ITER_CACHED); BTREE_ITER_CACHED);
if (unlikely(ret)) if (unlikely(ret))
return ret; return ret;
......
...@@ -1795,12 +1795,14 @@ int __bch2_foreground_maybe_merge(struct btree_trans *trans, ...@@ -1795,12 +1795,14 @@ int __bch2_foreground_maybe_merge(struct btree_trans *trans,
? bpos_predecessor(b->data->min_key) ? bpos_predecessor(b->data->min_key)
: bpos_successor(b->data->max_key); : bpos_successor(b->data->max_key);
sib_path = trans->paths + bch2_path_get(trans, path->btree_id, sib_pos, btree_path_idx_t sib_path_idx =
bch2_path_get(trans, path->btree_id, sib_pos,
U8_MAX, level, BTREE_ITER_INTENT, _THIS_IP_); U8_MAX, level, BTREE_ITER_INTENT, _THIS_IP_);
ret = bch2_btree_path_traverse(trans, sib_path, false); ret = bch2_btree_path_traverse(trans, sib_path_idx, false);
if (ret) if (ret)
goto err; goto err;
sib_path = trans->paths + sib_path_idx;
btree_path_set_should_be_locked(sib_path); btree_path_set_should_be_locked(sib_path);
m = sib_path->l[level].b; m = sib_path->l[level].b;
...@@ -1927,7 +1929,7 @@ int __bch2_foreground_maybe_merge(struct btree_trans *trans, ...@@ -1927,7 +1929,7 @@ int __bch2_foreground_maybe_merge(struct btree_trans *trans,
err: err:
if (new_path) if (new_path)
bch2_path_put(trans, new_path->idx, true); bch2_path_put(trans, new_path->idx, true);
bch2_path_put(trans, sib_path->idx, true); bch2_path_put(trans, sib_path_idx, true);
bch2_trans_verify_locks(trans); bch2_trans_verify_locks(trans);
return ret; return ret;
err_free_update: err_free_update:
......
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