bch2_read_extent(trans, rbio, iter.pos,
                                 data_btree, k, offset_into_extent, flags);
+               swap(rbio->bio.bi_iter.bi_size, bytes);
 
                if (flags & BCH_READ_last_fragment)
                        break;
 
-               swap(rbio->bio.bi_iter.bi_size, bytes);
                bio_advance(&rbio->bio, bytes);
 err:
                if (ret &&
 
                ret = __bch2_read_extent(trans, rbio, bvec_iter, iter.pos,
                                         data_btree, k,
                                         offset_into_extent, failed, flags, -1);
+               swap(bvec_iter.bi_size, bytes);
+
                if (ret)
                        goto err;
 
                if (flags & BCH_READ_last_fragment)
                        break;
 
-               swap(bvec_iter.bi_size, bytes);
                bio_advance_iter(&rbio->bio, &bvec_iter, bytes);
 err:
                if (ret == -BCH_ERR_data_read_retry_csum_err_maybe_userspace)
 
                        enum btree_id data_btree, struct bkey_s_c k,
                        unsigned offset_into_extent, unsigned flags)
 {
-       __bch2_read_extent(trans, rbio, rbio->bio.bi_iter, read_pos,
-                          data_btree, k, offset_into_extent, NULL, flags, -1);
+       int ret = __bch2_read_extent(trans, rbio, rbio->bio.bi_iter, read_pos,
+                                    data_btree, k, offset_into_extent, NULL, flags, -1);
+       /* __bch2_read_extent only returns errors if BCH_READ_in_retry is set */
+       WARN(ret, "unhandled error from __bch2_read_extent()");
 }
 
 int __bch2_read(struct btree_trans *, struct bch_read_bio *, struct bvec_iter,