{
        struct btrfs_root *root = sctx->send_root;
        struct btrfs_fs_info *fs_info = root->fs_info;
-       struct folio *folio;
-       pgoff_t index = offset >> PAGE_SHIFT;
-       pgoff_t last_index;
-       unsigned pg_offset = offset_in_page(offset);
+       u64 cur = offset;
+       const u64 end = offset + len;
+       const pgoff_t last_index = ((end - 1) >> PAGE_SHIFT);
        struct address_space *mapping = sctx->cur_inode->i_mapping;
        int ret;
 
        if (ret)
                return ret;
 
-       last_index = (offset + len - 1) >> PAGE_SHIFT;
-
-       while (index <= last_index) {
-               unsigned cur_len = min_t(unsigned, len,
-                                        PAGE_SIZE - pg_offset);
+       while (cur < end) {
+               pgoff_t index = (cur >> PAGE_SHIFT);
+               unsigned int cur_len;
+               unsigned int pg_offset;
+               struct folio *folio;
 
                folio = filemap_lock_folio(mapping, index);
                if (IS_ERR(folio)) {
                                break;
                        }
                }
-
-               WARN_ON(folio_order(folio));
+               pg_offset = offset_in_folio(folio, cur);
+               cur_len = min_t(unsigned int, end - cur, folio_size(folio) - pg_offset);
 
                if (folio_test_readahead(folio))
                        page_cache_async_readahead(mapping, &sctx->ra, NULL, folio,
                                  pg_offset, cur_len);
                folio_unlock(folio);
                folio_put(folio);
-               index++;
-               pg_offset = 0;
-               len -= cur_len;
+               cur += cur_len;
                sctx->send_size += cur_len;
        }