Commit 1ae29c1f authored by Kent Overstreet's avatar Kent Overstreet Committed by Kent Overstreet

bcachefs: Extent btree iterators are no longer special

Since iter->real_pos was introduced, we no longer have to deal with
extent btree iterators that have skipped past deleted keys - this is a
real performance improvement on btree updates.
Signed-off-by: default avatarKent Overstreet <kent.overstreet@gmail.com>
parent 068bcaa5
...@@ -601,13 +601,9 @@ static void bch2_btree_path_verify_level(struct btree_trans *trans, ...@@ -601,13 +601,9 @@ static void bch2_btree_path_verify_level(struct btree_trans *trans,
bch2_btree_node_iter_verify(&l->iter, l->b); bch2_btree_node_iter_verify(&l->iter, l->b);
/* /*
* For interior nodes, the iterator will have skipped past * For interior nodes, the iterator will have skipped past deleted keys:
* deleted keys:
*
* For extents, the iterator may have skipped past deleted keys (but not
* whiteouts)
*/ */
p = level || btree_node_type_is_extents(path->btree_id) p = level
? bch2_btree_node_iter_prev(&tmp, l->b) ? bch2_btree_node_iter_prev(&tmp, l->b)
: bch2_btree_node_iter_prev_all(&tmp, l->b); : bch2_btree_node_iter_prev_all(&tmp, l->b);
k = bch2_btree_node_iter_peek_all(&l->iter, l->b); k = bch2_btree_node_iter_peek_all(&l->iter, l->b);
...@@ -829,8 +825,7 @@ static void __bch2_btree_node_iter_fix(struct btree_path *path, ...@@ -829,8 +825,7 @@ static void __bch2_btree_node_iter_fix(struct btree_path *path,
*/ */
if (!bch2_btree_node_iter_end(node_iter) && if (!bch2_btree_node_iter_end(node_iter) &&
iter_current_key_modified && iter_current_key_modified &&
(b->c.level || b->c.level) {
btree_node_type_is_extents(path->btree_id))) {
struct bset_tree *t; struct bset_tree *t;
struct bkey_packed *k, *k2, *p; struct bkey_packed *k, *k2, *p;
......
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