Commit c61b7e21 authored by Kent Overstreet's avatar Kent Overstreet Committed by Kent Overstreet

bcachefs: Fix a null ptr deref in bch2_btree_iter_traverse_one()

We use sentinal values that aren't NULL to indicate there's a btree node
at a higher level; occasionally, this may result in
btree_iter_up_until_good_node() stopping at one of those sentinal
values.
Signed-off-by: default avatarKent Overstreet <kent.overstreet@gmail.com>
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent 649a9b68
...@@ -1235,7 +1235,7 @@ static int btree_iter_traverse_one(struct btree_iter *iter) ...@@ -1235,7 +1235,7 @@ static int btree_iter_traverse_one(struct btree_iter *iter)
* *
* XXX correctly using BTREE_ITER_UPTODATE should make this unnecessary * XXX correctly using BTREE_ITER_UPTODATE should make this unnecessary
*/ */
if (btree_iter_node(iter, iter->level)) { if (is_btree_node(iter, iter->level)) {
BUG_ON(!btree_iter_pos_in_node(iter, iter->l[iter->level].b)); BUG_ON(!btree_iter_pos_in_node(iter, iter->l[iter->level].b));
btree_iter_advance_to_pos(iter, &iter->l[iter->level], -1); btree_iter_advance_to_pos(iter, &iter->l[iter->level], -1);
......
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