From: Kent Overstreet Date: Wed, 9 Oct 2019 14:25:32 +0000 (-0400) Subject: bcachefs: Fix bch2_btree_iter_next() after peek_slot() X-Git-Url: http://git.maquefel.me/?a=commitdiff_plain;h=14989d547ee308033e080792239e640e076a4460;p=linux.git bcachefs: Fix bch2_btree_iter_next() after peek_slot() this deserves a unit test Signed-off-by: Kent Overstreet --- diff --git a/fs/bcachefs/btree_iter.c b/fs/bcachefs/btree_iter.c index 78bc82c7b9c33..8c6d3193c3fe9 100644 --- a/fs/bcachefs/btree_iter.c +++ b/fs/bcachefs/btree_iter.c @@ -1440,6 +1440,14 @@ struct bkey_s_c bch2_btree_iter_next(struct btree_iter *iter) return bch2_btree_iter_peek(iter); } + if (unlikely(bkey_deleted(&iter->k))) { + /* + * we're currently pointed at a hole, because previously we were + * iterating over slots: + */ + return bch2_btree_iter_peek(iter); + } + do { bch2_btree_node_iter_advance(&l->iter, l->b); p = bch2_btree_node_iter_peek_all(&l->iter, l->b);