At the end of the inode, on an extents iterator, peek_slot() has to
advance to the next position to avoid returning a 0 size extent, which
is not allowed.
Changing iter->pos confuses peek_prev(), but we don't need to call
peek_slot() in this case.
Signed-off-by: Kent Overstreet <kent.overstreet@linux.dev>
                                              struct bpos end)
 {
        if ((iter->flags & (BTREE_ITER_is_extents|BTREE_ITER_filter_snapshots)) &&
-          !bkey_eq(iter->pos, POS_MAX)) {
+          !bkey_eq(iter->pos, POS_MAX) &&
+          !((iter->flags & BTREE_ITER_is_extents) &&
+            iter->pos.offset == U64_MAX)) {
+
                /*
                 * bkey_start_pos(), for extents, is not monotonically
                 * increasing until after filtering for snapshots: