*/
        bool free_path;
 
-       /* Output fields. Only set when can_nocow_file_extent() returns 1. */
-
-       u64 disk_bytenr;
-       u64 disk_num_bytes;
-       u64 extent_offset;
-       /* Number of bytes that can be written to in NOCOW mode. */
-       u64 num_bytes;
-
-       /* The expected file extent for the NOCOW write. */
+       /*
+        * Output fields. Only set when can_nocow_file_extent() returns 1.
+        * The expected file extent for the NOCOW write.
+        */
        struct btrfs_file_extent file_extent;
 };
 
        struct btrfs_root *root = inode->root;
        struct btrfs_file_extent_item *fi;
        struct btrfs_root *csum_root;
+       u64 io_start;
        u64 extent_end;
        u8 extent_type;
        int can_nocow = 0;
        if (extent_type == BTRFS_FILE_EXTENT_INLINE)
                goto out;
 
-       /* Can't access these fields unless we know it's not an inline extent. */
-       args->disk_bytenr = btrfs_file_extent_disk_bytenr(leaf, fi);
-       args->disk_num_bytes = btrfs_file_extent_disk_num_bytes(leaf, fi);
-       args->extent_offset = btrfs_file_extent_offset(leaf, fi);
-
        if (!(inode->flags & BTRFS_INODE_NODATACOW) &&
            extent_type == BTRFS_FILE_EXTENT_REG)
                goto out;
                goto out;
 
        /* An explicit hole, must COW. */
-       if (args->disk_bytenr == 0)
+       if (btrfs_file_extent_disk_bytenr(leaf, fi) == 0)
                goto out;
 
        /* Compressed/encrypted/encoded extents must be COWed. */
        btrfs_release_path(path);
 
        ret = btrfs_cross_ref_exist(root, btrfs_ino(inode),
-                                   key->offset - args->extent_offset,
-                                   args->disk_bytenr, args->strict, path);
+                                   key->offset - args->file_extent.offset,
+                                   args->file_extent.disk_bytenr, args->strict, path);
        WARN_ON_ONCE(ret > 0 && is_freespace_inode);
        if (ret != 0)
                goto out;
            atomic_read(&root->snapshot_force_cow))
                goto out;
 
-       args->disk_bytenr += args->extent_offset;
-       args->disk_bytenr += args->start - key->offset;
-       args->num_bytes = min(args->end + 1, extent_end) - args->start;
-
-       args->file_extent.num_bytes = args->num_bytes;
+       args->file_extent.num_bytes = min(args->end + 1, extent_end) - args->start;
        args->file_extent.offset += args->start - key->offset;
+       io_start = args->file_extent.disk_bytenr + args->file_extent.offset;
 
        /*
         * Force COW if csums exist in the range. This ensures that csums for a
         * given extent are either valid or do not exist.
         */
 
-       csum_root = btrfs_csum_root(root->fs_info, args->disk_bytenr);
-       ret = btrfs_lookup_csums_list(csum_root, args->disk_bytenr,
-                                     args->disk_bytenr + args->num_bytes - 1,
+       csum_root = btrfs_csum_root(root->fs_info, io_start);
+       ret = btrfs_lookup_csums_list(csum_root, io_start,
+                                     io_start + args->file_extent.num_bytes - 1,
                                      NULL, nowait);
        WARN_ON_ONCE(ret > 0 && is_freespace_inode);
        if (ret != 0)
                struct extent_buffer *leaf;
                struct extent_state *cached_state = NULL;
                u64 extent_end;
-               u64 ram_bytes;
                u64 nocow_end;
                int extent_type;
                bool is_prealloc;
                        ret = -EUCLEAN;
                        goto error;
                }
-               ram_bytes = btrfs_file_extent_ram_bytes(leaf, fi);
                extent_end = btrfs_file_extent_end(path);
 
                /*
                        goto must_cow;
 
                ret = 0;
-               nocow_bg = btrfs_inc_nocow_writers(fs_info, nocow_args.disk_bytenr);
+               nocow_bg = btrfs_inc_nocow_writers(fs_info,
+                               nocow_args.file_extent.disk_bytenr +
+                               nocow_args.file_extent.offset);
                if (!nocow_bg) {
 must_cow:
                        /*
                        }
                }
 
-               nocow_end = cur_offset + nocow_args.num_bytes - 1;
+               nocow_end = cur_offset + nocow_args.file_extent.num_bytes - 1;
                lock_extent(&inode->io_tree, cur_offset, nocow_end, &cached_state);
 
                is_prealloc = extent_type == BTRFS_FILE_EXTENT_PREALLOC;
                if (is_prealloc) {
                        struct extent_map *em;
 
-                       em = create_io_em(inode, cur_offset, nocow_args.num_bytes,
-                                         nocow_args.disk_num_bytes, /* orig_block_len */
-                                         ram_bytes, BTRFS_COMPRESS_NONE,
+                       em = create_io_em(inode, cur_offset,
+                                         nocow_args.file_extent.num_bytes,
+                                         nocow_args.file_extent.disk_num_bytes,
+                                         nocow_args.file_extent.ram_bytes,
+                                         BTRFS_COMPRESS_NONE,
                                          &nocow_args.file_extent,
                                          BTRFS_ORDERED_PREALLOC);
                        if (IS_ERR(em)) {
                }
 
                ordered = btrfs_alloc_ordered_extent(inode, cur_offset,
-                               nocow_args.num_bytes, nocow_args.num_bytes,
-                               nocow_args.disk_bytenr, nocow_args.num_bytes, 0,
+                               nocow_args.file_extent.num_bytes,
+                               nocow_args.file_extent.num_bytes,
+                               nocow_args.file_extent.disk_bytenr +
+                               nocow_args.file_extent.offset,
+                               nocow_args.file_extent.num_bytes, 0,
                                is_prealloc
                                ? (1 << BTRFS_ORDERED_PREALLOC)
                                : (1 << BTRFS_ORDERED_NOCOW),
  *      any ordered extents.
  */
 noinline int can_nocow_extent(struct inode *inode, u64 offset, u64 *len,
-                             u64 *orig_block_len,
-                             u64 *ram_bytes, struct btrfs_file_extent *file_extent,
+                             struct btrfs_file_extent *file_extent,
                              bool nowait, bool strict)
 {
        struct btrfs_fs_info *fs_info = inode_to_fs_info(inode);
 
        fi = btrfs_item_ptr(leaf, path->slots[0], struct btrfs_file_extent_item);
        found_type = btrfs_file_extent_type(leaf, fi);
-       if (ram_bytes)
-               *ram_bytes = btrfs_file_extent_ram_bytes(leaf, fi);
 
        nocow_args.start = offset;
        nocow_args.end = offset + *len - 1;
        }
 
        ret = 0;
-       if (btrfs_extent_readonly(fs_info, nocow_args.disk_bytenr))
+       if (btrfs_extent_readonly(fs_info,
+                                 nocow_args.file_extent.disk_bytenr +
+                                 nocow_args.file_extent.offset))
                goto out;
 
        if (!(BTRFS_I(inode)->flags & BTRFS_INODE_NODATACOW) &&
            found_type == BTRFS_FILE_EXTENT_PREALLOC) {
                u64 range_end;
 
-               range_end = round_up(offset + nocow_args.num_bytes,
+               range_end = round_up(offset + nocow_args.file_extent.num_bytes,
                                     root->fs_info->sectorsize) - 1;
                ret = test_range_bit_exists(io_tree, offset, range_end, EXTENT_DELALLOC);
                if (ret) {
                }
        }
 
-       if (orig_block_len)
-               *orig_block_len = nocow_args.disk_num_bytes;
        if (file_extent)
                memcpy(file_extent, &nocow_args.file_extent, sizeof(*file_extent));
 
-       *len = nocow_args.num_bytes;
+       *len = nocow_args.file_extent.num_bytes;
        ret = 1;
 out:
        btrfs_free_path(path);
        struct btrfs_file_extent file_extent;
        struct extent_map *em = *map;
        int type;
-       u64 block_start, orig_block_len, ram_bytes;
+       u64 block_start;
        struct btrfs_block_group *bg;
        bool can_nocow = false;
        bool space_reserved = false;
                block_start = extent_map_block_start(em) + (start - em->start);
 
                if (can_nocow_extent(inode, start, &len,
-                                    &orig_block_len, &ram_bytes,
                                     &file_extent, false, false) == 1) {
                        bg = btrfs_inc_nocow_writers(fs_info, block_start);
                        if (bg)
                space_reserved = true;
 
                em2 = btrfs_create_dio_extent(BTRFS_I(inode), dio_data, start, len,
-                                             orig_block_len,
-                                             ram_bytes, type,
+                                             file_extent.disk_num_bytes,
+                                             file_extent.ram_bytes, type,
                                              &file_extent);
                btrfs_dec_nocow_writers(bg);
                if (type == BTRFS_ORDERED_PREALLOC) {
                free_extent_map(em);
                em = NULL;
 
-               ret = can_nocow_extent(inode, start, &len, NULL, NULL, NULL, false, true);
+               ret = can_nocow_extent(inode, start, &len, NULL, false, true);
                if (ret < 0) {
                        goto out;
                } else if (ret) {