Commit 22b383ad authored by Kent Overstreet's avatar Kent Overstreet Committed by Kent Overstreet

bcachefs: Kill retry loop in btree merge path

Signed-off-by: default avatarKent Overstreet <kent.overstreet@gmail.com>
parent f48361b0
...@@ -1572,12 +1572,7 @@ int __bch2_foreground_maybe_merge(struct btree_trans *trans, ...@@ -1572,12 +1572,7 @@ int __bch2_foreground_maybe_merge(struct btree_trans *trans,
struct btree *b, *m, *n, *prev, *next, *parent; struct btree *b, *m, *n, *prev, *next, *parent;
struct bpos sib_pos; struct bpos sib_pos;
size_t sib_u64s; size_t sib_u64s;
int ret = 0, ret2 = 0; int ret = 0;
retry:
ret = bch2_btree_path_traverse(trans, path, false);
if (ret)
return ret;
BUG_ON(!path->should_be_locked); BUG_ON(!path->should_be_locked);
BUG_ON(!btree_node_locked(path, level)); BUG_ON(!btree_node_locked(path, level));
...@@ -1587,7 +1582,7 @@ int __bch2_foreground_maybe_merge(struct btree_trans *trans, ...@@ -1587,7 +1582,7 @@ int __bch2_foreground_maybe_merge(struct btree_trans *trans,
if ((sib == btree_prev_sib && !bpos_cmp(b->data->min_key, POS_MIN)) || if ((sib == btree_prev_sib && !bpos_cmp(b->data->min_key, POS_MIN)) ||
(sib == btree_next_sib && !bpos_cmp(b->data->max_key, SPOS_MAX))) { (sib == btree_next_sib && !bpos_cmp(b->data->max_key, SPOS_MAX))) {
b->sib_u64s[sib] = U16_MAX; b->sib_u64s[sib] = U16_MAX;
goto out; return 0;
} }
sib_pos = sib == btree_prev_sib sib_pos = sib == btree_prev_sib
...@@ -1715,29 +1710,10 @@ int __bch2_foreground_maybe_merge(struct btree_trans *trans, ...@@ -1715,29 +1710,10 @@ int __bch2_foreground_maybe_merge(struct btree_trans *trans,
bch2_btree_update_done(as); bch2_btree_update_done(as);
out: out:
bch2_trans_verify_locks(trans);
if (sib_path)
bch2_path_put(trans, sib_path, true);
/*
* Don't downgrade locks here: we're called after successful insert,
* and the caller will downgrade locks after a successful insert
* anyways (in case e.g. a split was required first)
*
* And we're also called when inserting into interior nodes in the
* split path, and downgrading to read locks in there is potentially
* confusing:
*/
return ret ?: ret2;
err: err:
if (sib_path) bch2_path_put(trans, sib_path, true);
bch2_path_put(trans, sib_path, true); bch2_trans_verify_locks(trans);
sib_path = NULL; return ret;
if (ret == -EINTR && bch2_trans_relock(trans))
goto retry;
goto out;
} }
/** /**
......
...@@ -129,11 +129,7 @@ static inline int bch2_foreground_maybe_merge_sibling(struct btree_trans *trans, ...@@ -129,11 +129,7 @@ static inline int bch2_foreground_maybe_merge_sibling(struct btree_trans *trans,
{ {
struct btree *b; struct btree *b;
if (path->uptodate >= BTREE_ITER_NEED_TRAVERSE) EBUG_ON(!btree_node_locked(path, level));
return 0;
if (!bch2_btree_node_relock(trans, path, level))
return 0;
b = path->l[level].b; b = path->l[level].b;
if (b->sib_u64s[sib] > trans->c->btree_foreground_merge_threshold) if (b->sib_u64s[sib] > trans->c->btree_foreground_merge_threshold)
......
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