On Tue 30-06-26 17:09:32, Joanne Koong wrote:
> Now that all filesystems implement ->iomap_next() and the legacy
> ->iomap_begin()/->iomap_end() fallback is gone, struct iomap_ops only
> wraps a single iomap_next function pointer. Drop the struct entirely and
> pass the iomap_next_fn directly to iomap_iter() and all the iomap/dax
> entry points; filesystems pass their ->iomap_next function instead of an
> ops struct.
> 
> No functional change intended.
> 
> Signed-off-by: Joanne Koong <[email protected]>

Feel free to add:

Acked-by: Jan Kara <[email protected]>

for ext2 & ext4 changes.

                                                                Honza

> ---
>  block/fops.c           | 10 +++-----
>  fs/btrfs/direct-io.c   |  8 ++----
>  fs/dax.c               | 47 ++++++++++++++++++------------------
>  fs/erofs/data.c        | 24 ++++++++----------
>  fs/erofs/internal.h    |  3 ++-
>  fs/erofs/zmap.c        |  8 ++----
>  fs/exfat/file.c        | 18 +++++++-------
>  fs/exfat/inode.c       |  6 ++---
>  fs/exfat/iomap.c       | 16 +++---------
>  fs/exfat/iomap.h       |  6 +++--
>  fs/ext2/ext2.h         |  3 ++-
>  fs/ext2/file.c         |  4 +--
>  fs/ext2/inode.c        |  8 ++----
>  fs/ext4/ext4.h         |  6 +++--
>  fs/ext4/extents.c      |  8 ++----
>  fs/ext4/file.c         | 14 +++++------
>  fs/ext4/inode.c        | 20 +++++----------
>  fs/f2fs/data.c         |  9 +++----
>  fs/f2fs/f2fs.h         |  3 ++-
>  fs/f2fs/file.c         |  4 +--
>  fs/fuse/dax.c          | 10 +++-----
>  fs/fuse/file.c         | 10 +++-----
>  fs/gfs2/aops.c         |  6 ++---
>  fs/gfs2/bmap.c         | 10 +++-----
>  fs/gfs2/bmap.h         |  3 ++-
>  fs/gfs2/file.c         |  6 ++---
>  fs/gfs2/inode.c        |  6 ++---
>  fs/hpfs/file.c         |  6 +----
>  fs/internal.h          |  1 -
>  fs/iomap/buffered-io.c | 38 ++++++++++++++---------------
>  fs/iomap/direct-io.c   |  8 +++---
>  fs/iomap/fiemap.c      |  8 +++---
>  fs/iomap/iter.c        |  8 +++---
>  fs/iomap/seek.c        |  8 +++---
>  fs/iomap/swapfile.c    |  4 +--
>  fs/ntfs/aops.c         |  6 ++---
>  fs/ntfs/file.c         | 24 +++++++++---------
>  fs/ntfs/inode.c        |  2 +-
>  fs/ntfs/iomap.c        | 42 +++++++-------------------------
>  fs/ntfs/iomap.h        | 15 ++++++++----
>  fs/ntfs3/file.c        | 16 ++++++------
>  fs/ntfs3/inode.c       | 12 +++------
>  fs/ntfs3/ntfs_fs.h     |  3 ++-
>  fs/remap_range.c       |  6 ++---
>  fs/xfs/xfs_aops.c      |  8 +++---
>  fs/xfs/xfs_file.c      | 40 +++++++++++++++---------------
>  fs/xfs/xfs_iomap.c     | 55 +++++++++---------------------------------
>  fs/xfs/xfs_iomap.h     | 24 ++++++++++++------
>  fs/xfs/xfs_iops.c      |  4 +--
>  fs/xfs/xfs_reflink.c   |  6 ++---
>  fs/zonefs/file.c       | 22 ++++++-----------
>  include/linux/dax.h    | 18 ++++++--------
>  include/linux/fs.h     |  7 ++++--
>  include/linux/iomap.h  | 46 +++++++++++++++--------------------
>  54 files changed, 302 insertions(+), 411 deletions(-)
> 
> diff --git a/block/fops.c b/block/fops.c
> index c2721e2c659b..9ccec477f90d 100644
> --- a/block/fops.c
> +++ b/block/fops.c
> @@ -459,10 +459,6 @@ static int blkdev_iomap_next(const struct iomap_iter 
> *iter, struct iomap *iomap,
>       return iomap_process(iter, iomap, srcmap, blkdev_iomap_begin, NULL);
>  }
>  
> -static const struct iomap_ops blkdev_iomap_ops = {
> -     .iomap_next             = blkdev_iomap_next,
> -};
> -
>  #ifdef CONFIG_BUFFER_HEAD
>  static int blkdev_get_block(struct inode *inode, sector_t iblock,
>               struct buffer_head *bh, int create)
> @@ -516,13 +512,13 @@ const struct address_space_operations def_blk_aops = {
>  #else /* CONFIG_BUFFER_HEAD */
>  static int blkdev_read_folio(struct file *file, struct folio *folio)
>  {
> -     iomap_bio_read_folio(folio, &blkdev_iomap_ops);
> +     iomap_bio_read_folio(folio, blkdev_iomap_next);
>       return 0;
>  }
>  
>  static void blkdev_readahead(struct readahead_control *rac)
>  {
> -     iomap_bio_readahead(rac, &blkdev_iomap_ops);
> +     iomap_bio_readahead(rac, blkdev_iomap_next);
>  }
>  
>  static ssize_t blkdev_writeback_range(struct iomap_writepage_ctx *wpc,
> @@ -713,7 +709,7 @@ blkdev_direct_write(struct kiocb *iocb, struct iov_iter 
> *from)
>  
>  static ssize_t blkdev_buffered_write(struct kiocb *iocb, struct iov_iter 
> *from)
>  {
> -     return iomap_file_buffered_write(iocb, from, &blkdev_iomap_ops, NULL,
> +     return iomap_file_buffered_write(iocb, from, blkdev_iomap_next, NULL,
>                       NULL);
>  }
>  
> diff --git a/fs/btrfs/direct-io.c b/fs/btrfs/direct-io.c
> index 46dd72982fba..f1feeb68642d 100644
> --- a/fs/btrfs/direct-io.c
> +++ b/fs/btrfs/direct-io.c
> @@ -805,10 +805,6 @@ static int btrfs_dio_iomap_next(const struct iomap_iter 
> *iter,
>                            btrfs_dio_iomap_end);
>  }
>  
> -static const struct iomap_ops btrfs_dio_iomap_ops = {
> -     .iomap_next             = btrfs_dio_iomap_next,
> -};
> -
>  static const struct iomap_dio_ops btrfs_dio_ops = {
>       .submit_io              = btrfs_dio_submit_io,
>       .bio_set                = &btrfs_dio_bioset,
> @@ -819,7 +815,7 @@ static ssize_t btrfs_dio_read(struct kiocb *iocb, struct 
> iov_iter *iter,
>  {
>       struct btrfs_dio_data data = { 0 };
>  
> -     return iomap_dio_rw(iocb, iter, &btrfs_dio_iomap_ops, &btrfs_dio_ops,
> +     return iomap_dio_rw(iocb, iter, btrfs_dio_iomap_next, &btrfs_dio_ops,
>                           IOMAP_DIO_PARTIAL | IOMAP_DIO_FSBLOCK_ALIGNED, 
> &data, done_before);
>  }
>  
> @@ -828,7 +824,7 @@ static struct iomap_dio *btrfs_dio_write(struct kiocb 
> *iocb, struct iov_iter *it
>  {
>       struct btrfs_dio_data data = { 0 };
>  
> -     return __iomap_dio_rw(iocb, iter, &btrfs_dio_iomap_ops, &btrfs_dio_ops,
> +     return __iomap_dio_rw(iocb, iter, btrfs_dio_iomap_next, &btrfs_dio_ops,
>                           IOMAP_DIO_PARTIAL | IOMAP_DIO_FSBLOCK_ALIGNED, 
> &data, done_before);
>  }
>  
> diff --git a/fs/dax.c b/fs/dax.c
> index 6d175cd47a99..c0a6b87dc052 100644
> --- a/fs/dax.c
> +++ b/fs/dax.c
> @@ -1492,7 +1492,7 @@ static int dax_unshare_iter(struct iomap_iter *iter)
>  }
>  
>  int dax_file_unshare(struct inode *inode, loff_t pos, loff_t len,
> -             const struct iomap_ops *ops)
> +             iomap_next_fn iomap_next)
>  {
>       struct iomap_iter iter = {
>               .inode          = inode,
> @@ -1506,7 +1506,7 @@ int dax_file_unshare(struct inode *inode, loff_t pos, 
> loff_t len,
>               return 0;
>  
>       iter.len = min(len, size - pos);
> -     while ((ret = iomap_iter(&iter, ops)) > 0)
> +     while ((ret = iomap_iter(&iter, iomap_next)) > 0)
>               iter.status = dax_unshare_iter(&iter);
>       return ret;
>  }
> @@ -1584,7 +1584,7 @@ static int dax_zero_iter(struct iomap_iter *iter, bool 
> *did_zero)
>  }
>  
>  int dax_zero_range(struct inode *inode, loff_t pos, loff_t len, bool 
> *did_zero,
> -             const struct iomap_ops *ops)
> +             iomap_next_fn iomap_next)
>  {
>       struct iomap_iter iter = {
>               .inode          = inode,
> @@ -1594,14 +1594,14 @@ int dax_zero_range(struct inode *inode, loff_t pos, 
> loff_t len, bool *did_zero,
>       };
>       int ret;
>  
> -     while ((ret = iomap_iter(&iter, ops)) > 0)
> +     while ((ret = iomap_iter(&iter, iomap_next)) > 0)
>               iter.status = dax_zero_iter(&iter, did_zero);
>       return ret;
>  }
>  EXPORT_SYMBOL_GPL(dax_zero_range);
>  
>  int dax_truncate_page(struct inode *inode, loff_t pos, bool *did_zero,
> -             const struct iomap_ops *ops)
> +             iomap_next_fn iomap_next)
>  {
>       unsigned int blocksize = i_blocksize(inode);
>       unsigned int off = pos & (blocksize - 1);
> @@ -1609,7 +1609,7 @@ int dax_truncate_page(struct inode *inode, loff_t pos, 
> bool *did_zero,
>       /* Block boundary? Nothing to do */
>       if (!off)
>               return 0;
> -     return dax_zero_range(inode, pos, blocksize - off, did_zero, ops);
> +     return dax_zero_range(inode, pos, blocksize - off, did_zero, 
> iomap_next);
>  }
>  EXPORT_SYMBOL_GPL(dax_truncate_page);
>  
> @@ -1734,7 +1734,7 @@ static int dax_iomap_iter(struct iomap_iter *iomi, 
> struct iov_iter *iter)
>   * dax_iomap_rw - Perform I/O to a DAX file
>   * @iocb:    The control block for this I/O
>   * @iter:    The addresses to do I/O from or to
> - * @ops:     iomap ops passed from the file system
> + * @iomap_next: iomap_next callback passed from the file system
>   *
>   * This function performs read and write operations to directly mapped
>   * persistent memory.  The callers needs to take care of read/write exclusion
> @@ -1742,7 +1742,7 @@ static int dax_iomap_iter(struct iomap_iter *iomi, 
> struct iov_iter *iter)
>   */
>  ssize_t
>  dax_iomap_rw(struct kiocb *iocb, struct iov_iter *iter,
> -             const struct iomap_ops *ops)
> +             iomap_next_fn iomap_next)
>  {
>       struct iomap_iter iomi = {
>               .inode          = iocb->ki_filp->f_mapping->host,
> @@ -1769,7 +1769,7 @@ dax_iomap_rw(struct kiocb *iocb, struct iov_iter *iter,
>       if (iocb->ki_flags & IOCB_NOWAIT)
>               iomi.flags |= IOMAP_NOWAIT;
>  
> -     while ((ret = iomap_iter(&iomi, ops)) > 0)
> +     while ((ret = iomap_iter(&iomi, iomap_next)) > 0)
>               iomi.status = dax_iomap_iter(&iomi, iter);
>  
>       done = iomi.pos - iocb->ki_pos;
> @@ -1897,7 +1897,7 @@ static vm_fault_t dax_fault_iter(struct vm_fault *vmf,
>  }
>  
>  static vm_fault_t dax_iomap_pte_fault(struct vm_fault *vmf, unsigned long 
> *pfnp,
> -                            int *iomap_errp, const struct iomap_ops *ops)
> +                            int *iomap_errp, iomap_next_fn iomap_next)
>  {
>       struct address_space *mapping = vmf->vma->vm_file->f_mapping;
>       XA_STATE(xas, &mapping->i_pages, vmf->pgoff);
> @@ -1942,7 +1942,7 @@ static vm_fault_t dax_iomap_pte_fault(struct vm_fault 
> *vmf, unsigned long *pfnp,
>               goto unlock_entry;
>       }
>  
> -     while ((error = iomap_iter(&iter, ops)) > 0) {
> +     while ((error = iomap_iter(&iter, iomap_next)) > 0) {
>               if (WARN_ON_ONCE(iomap_length(&iter) < PAGE_SIZE)) {
>                       iter.status = -EIO;     /* fs corruption? */
>                       continue;
> @@ -2007,7 +2007,7 @@ static bool dax_fault_check_fallback(struct vm_fault 
> *vmf, struct xa_state *xas,
>  }
>  
>  static vm_fault_t dax_iomap_pmd_fault(struct vm_fault *vmf, unsigned long 
> *pfnp,
> -                            const struct iomap_ops *ops)
> +                            iomap_next_fn iomap_next)
>  {
>       struct address_space *mapping = vmf->vma->vm_file->f_mapping;
>       XA_STATE_ORDER(xas, &mapping->i_pages, vmf->pgoff, PMD_ORDER);
> @@ -2064,7 +2064,7 @@ static vm_fault_t dax_iomap_pmd_fault(struct vm_fault 
> *vmf, unsigned long *pfnp,
>       }
>  
>       iter.pos = (loff_t)xas.xa_index << PAGE_SHIFT;
> -     while (iomap_iter(&iter, ops) > 0) {
> +     while (iomap_iter(&iter, iomap_next) > 0) {
>               if (iomap_length(&iter) < PMD_SIZE)
>                       continue; /* actually breaks out of the loop */
>  
> @@ -2086,7 +2086,7 @@ static vm_fault_t dax_iomap_pmd_fault(struct vm_fault 
> *vmf, unsigned long *pfnp,
>  }
>  #else
>  static vm_fault_t dax_iomap_pmd_fault(struct vm_fault *vmf, unsigned long 
> *pfnp,
> -                            const struct iomap_ops *ops)
> +                            iomap_next_fn iomap_next)
>  {
>       return VM_FAULT_FALLBACK;
>  }
> @@ -2098,7 +2098,7 @@ static vm_fault_t dax_iomap_pmd_fault(struct vm_fault 
> *vmf, unsigned long *pfnp,
>   * @order: Order of the page to fault in
>   * @pfnp: PFN to insert for synchronous faults if fsync is required
>   * @iomap_errp: Storage for detailed error code in case of error
> - * @ops: Iomap ops passed from the file system
> + * @iomap_next: iomap_next callback passed from the file system
>   *
>   * When a page fault occurs, filesystems may call this helper in
>   * their fault handler for DAX files. dax_iomap_fault() assumes the caller
> @@ -2107,12 +2107,12 @@ static vm_fault_t dax_iomap_pmd_fault(struct vm_fault 
> *vmf, unsigned long *pfnp,
>   */
>  vm_fault_t dax_iomap_fault(struct vm_fault *vmf, unsigned int order,
>                       unsigned long *pfnp, int *iomap_errp,
> -                     const struct iomap_ops *ops)
> +                     iomap_next_fn iomap_next)
>  {
>       if (order == 0)
> -             return dax_iomap_pte_fault(vmf, pfnp, iomap_errp, ops);
> +             return dax_iomap_pte_fault(vmf, pfnp, iomap_errp, iomap_next);
>       else if (order == PMD_ORDER)
> -             return dax_iomap_pmd_fault(vmf, pfnp, ops);
> +             return dax_iomap_pmd_fault(vmf, pfnp, iomap_next);
>       else
>               return VM_FAULT_FALLBACK;
>  }
> @@ -2240,7 +2240,7 @@ static int dax_range_compare_iter(struct iomap_iter 
> *it_src,
>  
>  int dax_dedupe_file_range_compare(struct inode *src, loff_t srcoff,
>               struct inode *dst, loff_t dstoff, loff_t len, bool *same,
> -             const struct iomap_ops *ops)
> +             iomap_next_fn iomap_next)
>  {
>       struct iomap_iter src_iter = {
>               .inode          = src,
> @@ -2256,8 +2256,8 @@ int dax_dedupe_file_range_compare(struct inode *src, 
> loff_t srcoff,
>       };
>       int ret, status;
>  
> -     while ((ret = iomap_iter(&src_iter, ops)) > 0 &&
> -            (ret = iomap_iter(&dst_iter, ops)) > 0) {
> +     while ((ret = iomap_iter(&src_iter, iomap_next)) > 0 &&
> +            (ret = iomap_iter(&dst_iter, iomap_next)) > 0) {
>               status = dax_range_compare_iter(&src_iter, &dst_iter,
>                               min(src_iter.len, dst_iter.len), same);
>               if (status < 0)
> @@ -2270,9 +2270,10 @@ int dax_dedupe_file_range_compare(struct inode *src, 
> loff_t srcoff,
>  int dax_remap_file_range_prep(struct file *file_in, loff_t pos_in,
>                             struct file *file_out, loff_t pos_out,
>                             loff_t *len, unsigned int remap_flags,
> -                           const struct iomap_ops *ops)
> +                           iomap_next_fn iomap_next)
>  {
>       return __generic_remap_file_range_prep(file_in, pos_in, file_out,
> -                                            pos_out, len, remap_flags, ops);
> +                                            pos_out, len, remap_flags,
> +                                            iomap_next);
>  }
>  EXPORT_SYMBOL_GPL(dax_remap_file_range_prep);
> diff --git a/fs/erofs/data.c b/fs/erofs/data.c
> index 47dba61ec576..f6fe8c7eaf6d 100644
> --- a/fs/erofs/data.c
> +++ b/fs/erofs/data.c
> @@ -387,10 +387,6 @@ static int erofs_iomap_next(const struct iomap_iter 
> *iter, struct iomap *iomap,
>                            erofs_iomap_end);
>  }
>  
> -static const struct iomap_ops erofs_iomap_ops = {
> -     .iomap_next = erofs_iomap_next,
> -};
> -
>  int erofs_fiemap(struct inode *inode, struct fiemap_extent_info *fieinfo,
>                u64 start, u64 len)
>  {
> @@ -398,9 +394,9 @@ int erofs_fiemap(struct inode *inode, struct 
> fiemap_extent_info *fieinfo,
>               if (!IS_ENABLED(CONFIG_EROFS_FS_ZIP))
>                       return -EOPNOTSUPP;
>               return iomap_fiemap(inode, fieinfo, start, len,
> -                                 &z_erofs_iomap_report_ops);
> +                                 z_erofs_iomap_next_report);
>       }
> -     return iomap_fiemap(inode, fieinfo, start, len, &erofs_iomap_ops);
> +     return iomap_fiemap(inode, fieinfo, start, len, erofs_iomap_next);
>  }
>  
>  /*
> @@ -419,7 +415,7 @@ static int erofs_read_folio(struct file *file, struct 
> folio *folio)
>       };
>  
>       trace_erofs_read_folio(iter_ctx.realinode, folio, true);
> -     iomap_read_folio(&erofs_iomap_ops, &read_ctx, &iter_ctx);
> +     iomap_read_folio(erofs_iomap_next, &read_ctx, &iter_ctx);
>       if (need_iput)
>               iput(iter_ctx.realinode);
>       return 0;
> @@ -438,14 +434,14 @@ static void erofs_readahead(struct readahead_control 
> *rac)
>  
>       trace_erofs_readahead(iter_ctx.realinode, readahead_index(rac),
>                             readahead_count(rac), true);
> -     iomap_readahead(&erofs_iomap_ops, &read_ctx, &iter_ctx);
> +     iomap_readahead(erofs_iomap_next, &read_ctx, &iter_ctx);
>       if (need_iput)
>               iput(iter_ctx.realinode);
>  }
>  
>  static sector_t erofs_bmap(struct address_space *mapping, sector_t block)
>  {
> -     return iomap_bmap(mapping, block, &erofs_iomap_ops);
> +     return iomap_bmap(mapping, block, erofs_iomap_next);
>  }
>  
>  static ssize_t erofs_file_read_iter(struct kiocb *iocb, struct iov_iter *to)
> @@ -457,14 +453,14 @@ static ssize_t erofs_file_read_iter(struct kiocb *iocb, 
> struct iov_iter *to)
>               return 0;
>  
>       if (IS_ENABLED(CONFIG_FS_DAX) && IS_DAX(inode))
> -             return dax_iomap_rw(iocb, to, &erofs_iomap_ops);
> +             return dax_iomap_rw(iocb, to, erofs_iomap_next);
>  
>       if ((iocb->ki_flags & IOCB_DIRECT) && inode->i_sb->s_bdev) {
>               struct erofs_iomap_iter_ctx iter_ctx = {
>                       .realinode = inode,
>               };
>  
> -             return iomap_dio_rw(iocb, to, &erofs_iomap_ops,
> +             return iomap_dio_rw(iocb, to, erofs_iomap_next,
>                                   NULL, 0, &iter_ctx, 0);
>       }
>       return filemap_read(iocb, to, 0);
> @@ -484,7 +480,7 @@ const struct address_space_operations erofs_aops = {
>  static vm_fault_t erofs_dax_huge_fault(struct vm_fault *vmf,
>               unsigned int order)
>  {
> -     return dax_iomap_fault(vmf, order, NULL, NULL, &erofs_iomap_ops);
> +     return dax_iomap_fault(vmf, order, NULL, NULL, erofs_iomap_next);
>  }
>  
>  static vm_fault_t erofs_dax_fault(struct vm_fault *vmf)
> @@ -516,12 +512,12 @@ static int erofs_file_mmap_prepare(struct vm_area_desc 
> *desc)
>  static loff_t erofs_file_llseek(struct file *file, loff_t offset, int whence)
>  {
>       struct inode *inode = file->f_mapping->host;
> -     const struct iomap_ops *ops = &erofs_iomap_ops;
> +     iomap_next_fn ops = erofs_iomap_next;
>  
>       if (erofs_inode_is_data_compressed(EROFS_I(inode)->datalayout)) {
>               if (!IS_ENABLED(CONFIG_EROFS_FS_ZIP))
>                       return generic_file_llseek(file, offset, whence);
> -             ops = &z_erofs_iomap_report_ops;
> +             ops = z_erofs_iomap_next_report;
>       }
>  
>       if (whence == SEEK_HOLE)
> diff --git a/fs/erofs/internal.h b/fs/erofs/internal.h
> index 580f8d9f14e7..72ccd6f335b8 100644
> --- a/fs/erofs/internal.h
> +++ b/fs/erofs/internal.h
> @@ -397,7 +397,8 @@ extern const struct file_operations erofs_file_fops;
>  extern const struct file_operations erofs_dir_fops;
>  extern const struct file_operations erofs_ishare_fops;
>  
> -extern const struct iomap_ops z_erofs_iomap_report_ops;
> +int z_erofs_iomap_next_report(const struct iomap_iter *iter,
> +             struct iomap *iomap, struct iomap *srcmap);
>  
>  void *erofs_read_metadata(struct super_block *sb, struct erofs_buf *buf,
>                         erofs_off_t *offset, int *lengthp);
> diff --git a/fs/erofs/zmap.c b/fs/erofs/zmap.c
> index dd058413a0b6..59054eecd69e 100644
> --- a/fs/erofs/zmap.c
> +++ b/fs/erofs/zmap.c
> @@ -821,13 +821,9 @@ static int z_erofs_iomap_begin_report(struct inode 
> *inode, loff_t offset,
>       return 0;
>  }
>  
> -static int z_erofs_iomap_next_report(const struct iomap_iter *iter,
> -                                  struct iomap *iomap, struct iomap *srcmap)
> +int z_erofs_iomap_next_report(const struct iomap_iter *iter,
> +                           struct iomap *iomap, struct iomap *srcmap)
>  {
>       return iomap_process(iter, iomap, srcmap, z_erofs_iomap_begin_report,
>                            NULL);
>  }
> -
> -const struct iomap_ops z_erofs_iomap_report_ops = {
> -     .iomap_next = z_erofs_iomap_next_report,
> -};
> diff --git a/fs/exfat/file.c b/fs/exfat/file.c
> index 5fc13378d35f..c05849d305ae 100644
> --- a/fs/exfat/file.c
> +++ b/fs/exfat/file.c
> @@ -668,7 +668,7 @@ static int exfat_extend_valid_size(struct inode *inode, 
> loff_t new_valid_size)
>  
>               ret = iomap_zero_range(inode, old_valid_size,
>                               new_valid_size - old_valid_size, NULL,
> -                             &exfat_write_iomap_ops, NULL, NULL);
> +                             exfat_write_iomap_next, NULL, NULL);
>               if (ret) {
>                       truncate_setsize(inode, old_valid_size);
>                       exfat_truncate(inode);
> @@ -687,7 +687,7 @@ static ssize_t exfat_fallback_buffered_write(struct kiocb 
> *iocb,
>  
>       iocb->ki_flags &= ~IOCB_DIRECT;
>  
> -     written = iomap_file_buffered_write(iocb, from, &exfat_write_iomap_ops,
> +     written = iomap_file_buffered_write(iocb, from, exfat_write_iomap_next,
>                       NULL, NULL);
>       if (written < 0)
>               return written;
> @@ -709,7 +709,7 @@ static ssize_t exfat_dio_write_iter(struct kiocb *iocb, 
> struct iov_iter *from)
>  {
>       ssize_t ret;
>  
> -     ret = iomap_dio_rw(iocb, from, &exfat_write_iomap_ops,
> +     ret = iomap_dio_rw(iocb, from, exfat_write_iomap_next,
>                       &exfat_write_dio_ops, 0, NULL, 0);
>       if (ret == -ENOTBLK)
>               ret = 0;
> @@ -773,7 +773,7 @@ static ssize_t exfat_file_write_iter(struct kiocb *iocb, 
> struct iov_iter *iter)
>               ret = exfat_dio_write_iter(iocb, iter);
>       else
>               ret = iomap_file_buffered_write(iocb, iter,
> -                             &exfat_write_iomap_ops, NULL, NULL);
> +                             exfat_write_iomap_next, NULL, NULL);
>       if (ret < 0)
>               goto unlock;
>  
> @@ -809,7 +809,7 @@ static ssize_t exfat_file_read_iter(struct kiocb *iocb, 
> struct iov_iter *iter)
>  
>       if (iocb->ki_flags & IOCB_DIRECT) {
>               file_accessed(iocb->ki_filp);
> -             ret = iomap_dio_rw(iocb, iter, &exfat_iomap_ops, NULL, 0,
> +             ret = iomap_dio_rw(iocb, iter, exfat_iomap_next, NULL, 0,
>                               NULL, 0);
>       } else {
>               ret = generic_file_read_iter(iocb, iter);
> @@ -850,7 +850,7 @@ static vm_fault_t exfat_page_mkwrite(struct vm_fault *vmf)
>                        */
>                       err = iomap_zero_range(inode, ei->zeroed_size,
>                                       mmap_valid_size - ei->zeroed_size, NULL,
> -                                     &exfat_iomap_ops, NULL, NULL);
> +                                     exfat_iomap_next, NULL, NULL);
>                       if (err < 0) {
>                               inode_unlock(inode);
>                               return vmf_fs_error(err);
> @@ -866,7 +866,7 @@ static vm_fault_t exfat_page_mkwrite(struct vm_fault *vmf)
>       file_update_time(vmf->vma->vm_file);
>  
>       filemap_invalidate_lock_shared(inode->i_mapping);
> -     ret = iomap_page_mkwrite(vmf, &exfat_write_iomap_ops, NULL);
> +     ret = iomap_page_mkwrite(vmf, exfat_write_iomap_next, NULL);
>       filemap_invalidate_unlock_shared(inode->i_mapping);
>       sb_end_pagefault(inode->i_sb);
>       inode_unlock(inode);
> @@ -939,12 +939,12 @@ static loff_t exfat_file_llseek(struct file *file, 
> loff_t offset, int whence)
>       switch (whence) {
>       case SEEK_HOLE:
>               inode_lock_shared(inode);
> -             offset = iomap_seek_hole(inode, offset, &exfat_iomap_ops);
> +             offset = iomap_seek_hole(inode, offset, exfat_iomap_next);
>               inode_unlock_shared(inode);
>               break;
>       case SEEK_DATA:
>               inode_lock_shared(inode);
> -             offset = iomap_seek_data(inode, offset, &exfat_iomap_ops);
> +             offset = iomap_seek_data(inode, offset, exfat_iomap_next);
>               inode_unlock_shared(inode);
>               break;
>       default:
> diff --git a/fs/exfat/inode.c b/fs/exfat/inode.c
> index 89826aea5e1e..a6b9aa2ad792 100644
> --- a/fs/exfat/inode.c
> +++ b/fs/exfat/inode.c
> @@ -248,7 +248,7 @@ static int exfat_read_folio(struct file *file, struct 
> folio *folio)
>               .ops = &exfat_iomap_bio_read_ops,
>       };
>  
> -     iomap_read_folio(&exfat_iomap_ops, &ctx, NULL);
> +     iomap_read_folio(exfat_iomap_next, &ctx, NULL);
>       return 0;
>  }
>  
> @@ -269,7 +269,7 @@ static void exfat_readahead(struct readahead_control *rac)
>           ei->valid_size < pos + readahead_length(rac))
>               return;
>  
> -     iomap_readahead(&exfat_iomap_ops, &ctx, NULL);
> +     iomap_readahead(exfat_iomap_next, &ctx, NULL);
>  }
>  
>  static int exfat_writepages(struct address_space *mapping,
> @@ -293,7 +293,7 @@ static sector_t exfat_aop_bmap(struct address_space 
> *mapping, sector_t block)
>  
>       /* exfat_get_cluster() assumes the requested blocknr isn't truncated. */
>       down_read(&EXFAT_I(mapping->host)->truncate_lock);
> -     blocknr = iomap_bmap(mapping, block, &exfat_iomap_ops);
> +     blocknr = iomap_bmap(mapping, block, exfat_iomap_next);
>       up_read(&EXFAT_I(mapping->host)->truncate_lock);
>       return blocknr;
>  }
> diff --git a/fs/exfat/iomap.c b/fs/exfat/iomap.c
> index 8d33690a562d..6120e0758f7b 100644
> --- a/fs/exfat/iomap.c
> +++ b/fs/exfat/iomap.c
> @@ -151,16 +151,12 @@ static int exfat_write_iomap_begin(struct inode *inode, 
> loff_t offset, loff_t le
>       return __exfat_iomap_begin(inode, offset, length, flags, iomap, true);
>  }
>  
> -static int exfat_iomap_next(const struct iomap_iter *iter, struct iomap 
> *iomap,
> +int exfat_iomap_next(const struct iomap_iter *iter, struct iomap *iomap,
>               struct iomap *srcmap)
>  {
>       return iomap_process(iter, iomap, srcmap, exfat_iomap_begin, NULL);
>  }
>  
> -const struct iomap_ops exfat_iomap_ops = {
> -     .iomap_next = exfat_iomap_next,
> -};
> -
>  /*
>   * exfat_write_iomap_end - Update the state after write
>   *
> @@ -192,17 +188,13 @@ static int exfat_write_iomap_end(struct inode *inode, 
> loff_t pos, loff_t length,
>       return written;
>  }
>  
> -static int exfat_write_iomap_next(const struct iomap_iter *iter,
> -             struct iomap *iomap, struct iomap *srcmap)
> +int exfat_write_iomap_next(const struct iomap_iter *iter, struct iomap 
> *iomap,
> +             struct iomap *srcmap)
>  {
>       return iomap_process(iter, iomap, srcmap,
>                       exfat_write_iomap_begin, exfat_write_iomap_end);
>  }
>  
> -const struct iomap_ops exfat_write_iomap_ops = {
> -     .iomap_next     = exfat_write_iomap_next,
> -};
> -
>  /*
>   * exfat_writeback_range - Map folio during writeback
>   *
> @@ -279,5 +271,5 @@ const struct iomap_read_ops exfat_iomap_bio_read_ops = {
>  int exfat_iomap_swap_activate(struct swap_info_struct *sis,
>                              struct file *file, sector_t *span)
>  {
> -     return iomap_swapfile_activate(sis, file, span, &exfat_iomap_ops);
> +     return iomap_swapfile_activate(sis, file, span, exfat_iomap_next);
>  }
> diff --git a/fs/exfat/iomap.h b/fs/exfat/iomap.h
> index fd8a913f7794..47d7b753735e 100644
> --- a/fs/exfat/iomap.h
> +++ b/fs/exfat/iomap.h
> @@ -7,8 +7,10 @@
>  #define _LINUX_EXFAT_IOMAP_H
>  
>  extern const struct iomap_dio_ops exfat_write_dio_ops;
> -extern const struct iomap_ops exfat_iomap_ops;
> -extern const struct iomap_ops exfat_write_iomap_ops;
> +int exfat_iomap_next(const struct iomap_iter *iter, struct iomap *iomap,
> +             struct iomap *srcmap);
> +int exfat_write_iomap_next(const struct iomap_iter *iter, struct iomap 
> *iomap,
> +             struct iomap *srcmap);
>  extern const struct iomap_writeback_ops exfat_writeback_ops;
>  extern const struct iomap_read_ops exfat_iomap_bio_read_ops;
>  
> diff --git a/fs/ext2/ext2.h b/fs/ext2/ext2.h
> index 79f7b395258c..59ef8b898940 100644
> --- a/fs/ext2/ext2.h
> +++ b/fs/ext2/ext2.h
> @@ -780,7 +780,8 @@ extern const struct file_operations ext2_file_operations;
>  /* inode.c */
>  extern void ext2_set_file_ops(struct inode *inode);
>  extern const struct address_space_operations ext2_aops;
> -extern const struct iomap_ops ext2_iomap_ops;
> +int ext2_iomap_next(const struct iomap_iter *iter, struct iomap *iomap,
> +             struct iomap *srcmap);
>  
>  /* namei.c */
>  extern const struct inode_operations ext2_dir_inode_operations;
> diff --git a/fs/ext2/file.c b/fs/ext2/file.c
> index 8dca9ec4cacd..1fc00ad77517 100644
> --- a/fs/ext2/file.c
> +++ b/fs/ext2/file.c
> @@ -70,7 +70,7 @@ static ssize_t ext2_dio_read_iter(struct kiocb *iocb, 
> struct iov_iter *to)
>  
>       trace_ext2_dio_read_begin(iocb, to, 0);
>       inode_lock_shared(inode);
> -     ret = iomap_dio_rw(iocb, to, &ext2_iomap_ops, NULL, 0, NULL, 0);
> +     ret = iomap_dio_rw(iocb, to, ext2_iomap_next, NULL, 0, NULL, 0);
>       inode_unlock_shared(inode);
>       trace_ext2_dio_read_end(iocb, to, ret);
>  
> @@ -134,7 +134,7 @@ static ssize_t ext2_dio_write_iter(struct kiocb *iocb, 
> struct iov_iter *from)
>          (!IS_ALIGNED(iocb->ki_pos | iov_iter_alignment(from), blocksize)))
>               flags |= IOMAP_DIO_FORCE_WAIT;
>  
> -     ret = iomap_dio_rw(iocb, from, &ext2_iomap_ops, &ext2_dio_write_ops,
> +     ret = iomap_dio_rw(iocb, from, ext2_iomap_next, &ext2_dio_write_ops,
>                          flags, NULL, 0);
>  
>       /* ENOTBLK is magic return value for fallback to buffered-io */
> diff --git a/fs/ext2/inode.c b/fs/ext2/inode.c
> index 0693059caa35..74d5be85341d 100644
> --- a/fs/ext2/inode.c
> +++ b/fs/ext2/inode.c
> @@ -860,17 +860,13 @@ ext2_iomap_end(struct inode *inode, loff_t offset, 
> loff_t length,
>       return 0;
>  }
>  
> -static int ext2_iomap_next(const struct iomap_iter *iter, struct iomap 
> *iomap,
> +int ext2_iomap_next(const struct iomap_iter *iter, struct iomap *iomap,
>                          struct iomap *srcmap)
>  {
>       return iomap_process(iter, iomap, srcmap, ext2_iomap_begin,
>                            ext2_iomap_end);
>  }
>  
> -const struct iomap_ops ext2_iomap_ops = {
> -     .iomap_next             = ext2_iomap_next,
> -};
> -
>  int ext2_fiemap(struct inode *inode, struct fiemap_extent_info *fieinfo,
>               u64 start, u64 len)
>  {
> @@ -888,7 +884,7 @@ int ext2_fiemap(struct inode *inode, struct 
> fiemap_extent_info *fieinfo,
>       if (i_size == 0)
>               i_size = 1;
>       len = min_t(u64, len, i_size);
> -     ret = iomap_fiemap(inode, fieinfo, start, len, &ext2_iomap_ops);
> +     ret = iomap_fiemap(inode, fieinfo, start, len, ext2_iomap_next);
>       inode_unlock(inode);
>  
>       return ret;
> diff --git a/fs/ext4/ext4.h b/fs/ext4/ext4.h
> index b37c136ea3ab..755fde1baf03 100644
> --- a/fs/ext4/ext4.h
> +++ b/fs/ext4/ext4.h
> @@ -4004,8 +4004,10 @@ static inline void 
> ext4_clear_io_unwritten_flag(ext4_io_end_t *io_end)
>               io_end->flag &= ~EXT4_IO_END_UNWRITTEN;
>  }
>  
> -extern const struct iomap_ops ext4_iomap_ops;
> -extern const struct iomap_ops ext4_iomap_report_ops;
> +int ext4_iomap_next(const struct iomap_iter *iter, struct iomap *iomap,
> +             struct iomap *srcmap);
> +int ext4_iomap_next_report(const struct iomap_iter *iter, struct iomap 
> *iomap,
> +             struct iomap *srcmap);
>  
>  static inline int ext4_buffer_uptodate(struct buffer_head *bh)
>  {
> diff --git a/fs/ext4/extents.c b/fs/ext4/extents.c
> index 431298eca7e8..aa3c5c0915c0 100644
> --- a/fs/ext4/extents.c
> +++ b/fs/ext4/extents.c
> @@ -5177,10 +5177,6 @@ static int ext4_iomap_xattr_next(const struct 
> iomap_iter *iter,
>       return iomap_process(iter, iomap, srcmap, ext4_iomap_xattr_begin, NULL);
>  }
>  
> -static const struct iomap_ops ext4_iomap_xattr_ops = {
> -     .iomap_next             = ext4_iomap_xattr_next,
> -};
> -
>  static int ext4_fiemap_check_ranges(struct inode *inode, u64 start, u64 *len)
>  {
>       u64 maxbytes = ext4_get_maxbytes(inode);
> @@ -5223,10 +5219,10 @@ int ext4_fiemap(struct inode *inode, struct 
> fiemap_extent_info *fieinfo,
>       if (fieinfo->fi_flags & FIEMAP_FLAG_XATTR) {
>               fieinfo->fi_flags &= ~FIEMAP_FLAG_XATTR;
>               error = iomap_fiemap(inode, fieinfo, start, len,
> -                                  &ext4_iomap_xattr_ops);
> +                                  ext4_iomap_xattr_next);
>       } else {
>               error = iomap_fiemap(inode, fieinfo, start, len,
> -                                  &ext4_iomap_report_ops);
> +                                  ext4_iomap_next_report);
>       }
>  unlock:
>       inode_unlock_shared(inode);
> diff --git a/fs/ext4/file.c b/fs/ext4/file.c
> index eb1a323962b1..dbe073e181a7 100644
> --- a/fs/ext4/file.c
> +++ b/fs/ext4/file.c
> @@ -91,7 +91,7 @@ static ssize_t ext4_dio_read_iter(struct kiocb *iocb, 
> struct iov_iter *to)
>               return generic_file_read_iter(iocb, to);
>       }
>  
> -     ret = iomap_dio_rw(iocb, to, &ext4_iomap_ops, NULL, 0, NULL, 0);
> +     ret = iomap_dio_rw(iocb, to, ext4_iomap_next, NULL, 0, NULL, 0);
>       inode_unlock_shared(inode);
>  
>       file_accessed(iocb->ki_filp);
> @@ -119,7 +119,7 @@ static ssize_t ext4_dax_read_iter(struct kiocb *iocb, 
> struct iov_iter *to)
>               /* Fallback to buffered IO in case we cannot support DAX */
>               return generic_file_read_iter(iocb, to);
>       }
> -     ret = dax_iomap_rw(iocb, to, &ext4_iomap_ops);
> +     ret = dax_iomap_rw(iocb, to, ext4_iomap_next);
>       inode_unlock_shared(inode);
>  
>       file_accessed(iocb->ki_filp);
> @@ -589,7 +589,7 @@ static ssize_t ext4_dio_write_iter(struct kiocb *iocb, 
> struct iov_iter *from)
>                       goto out;
>       }
>  
> -     ret = iomap_dio_rw(iocb, from, &ext4_iomap_ops, &ext4_dio_write_ops,
> +     ret = iomap_dio_rw(iocb, from, ext4_iomap_next, &ext4_dio_write_ops,
>                          dio_flags, NULL, 0);
>       if (ret == -ENOTBLK)
>               ret = 0;
> @@ -688,7 +688,7 @@ ext4_dax_write_iter(struct kiocb *iocb, struct iov_iter 
> *from)
>               ext4_journal_stop(handle);
>       }
>  
> -     ret = dax_iomap_rw(iocb, from, &ext4_iomap_ops);
> +     ret = dax_iomap_rw(iocb, from, ext4_iomap_next);
>  
>       if (extend) {
>               ret = ext4_handle_inode_extension(inode, offset, ret, count);
> @@ -776,7 +776,7 @@ static vm_fault_t ext4_dax_huge_fault(struct vm_fault 
> *vmf, unsigned int order)
>       } else {
>               filemap_invalidate_lock_shared(mapping);
>       }
> -     result = dax_iomap_fault(vmf, order, &pfn, &error, &ext4_iomap_ops);
> +     result = dax_iomap_fault(vmf, order, &pfn, &error, ext4_iomap_next);
>       if (write) {
>               ext4_journal_stop(handle);
>  
> @@ -955,13 +955,13 @@ loff_t ext4_llseek(struct file *file, loff_t offset, 
> int whence)
>       case SEEK_HOLE:
>               inode_lock_shared(inode);
>               offset = iomap_seek_hole(inode, offset,
> -                                      &ext4_iomap_report_ops);
> +                                      ext4_iomap_next_report);
>               inode_unlock_shared(inode);
>               break;
>       case SEEK_DATA:
>               inode_lock_shared(inode);
>               offset = iomap_seek_data(inode, offset,
> -                                      &ext4_iomap_report_ops);
> +                                      ext4_iomap_next_report);
>               inode_unlock_shared(inode);
>               break;
>       }
> diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c
> index cf7aa8275651..4c30dd8dbec7 100644
> --- a/fs/ext4/inode.c
> +++ b/fs/ext4/inode.c
> @@ -3391,7 +3391,7 @@ static sector_t ext4_bmap(struct address_space 
> *mapping, sector_t block)
>               filemap_write_and_wait(mapping);
>       }
>  
> -     ret = iomap_bmap(mapping, block, &ext4_iomap_ops);
> +     ret = iomap_bmap(mapping, block, ext4_iomap_next);
>  
>  out:
>       inode_unlock_shared(inode);
> @@ -3850,16 +3850,12 @@ static int ext4_iomap_begin(struct inode *inode, 
> loff_t offset, loff_t length,
>       return 0;
>  }
>  
> -static int ext4_iomap_next(const struct iomap_iter *iter, struct iomap 
> *iomap,
> +int ext4_iomap_next(const struct iomap_iter *iter, struct iomap *iomap,
>                          struct iomap *srcmap)
>  {
>       return iomap_process(iter, iomap, srcmap, ext4_iomap_begin, NULL);
>  }
>  
> -const struct iomap_ops ext4_iomap_ops = {
> -     .iomap_next             = ext4_iomap_next,
> -};
> -
>  static int ext4_iomap_begin_report(struct inode *inode, loff_t offset,
>                                  loff_t length, unsigned int flags,
>                                  struct iomap *iomap, struct iomap *srcmap)
> @@ -3911,17 +3907,13 @@ static int ext4_iomap_begin_report(struct inode 
> *inode, loff_t offset,
>       return 0;
>  }
>  
> -static int ext4_iomap_next_report(const struct iomap_iter *iter,
> -                               struct iomap *iomap, struct iomap *srcmap)
> +int ext4_iomap_next_report(const struct iomap_iter *iter, struct iomap 
> *iomap,
> +                        struct iomap *srcmap)
>  {
>       return iomap_process(iter, iomap, srcmap, ext4_iomap_begin_report,
>                            NULL);
>  }
>  
> -const struct iomap_ops ext4_iomap_report_ops = {
> -     .iomap_next = ext4_iomap_next_report,
> -};
> -
>  /*
>   * For data=journal mode, folio should be marked dirty only when it was
>   * writeably mapped. When that happens, it was already attached to the
> @@ -3957,7 +3949,7 @@ static int ext4_iomap_swap_activate(struct 
> swap_info_struct *sis,
>                                   struct file *file, sector_t *span)
>  {
>       return iomap_swapfile_activate(sis, file, span,
> -                                    &ext4_iomap_report_ops);
> +                                    ext4_iomap_next_report);
>  }
>  
>  static const struct address_space_operations ext4_aops = {
> @@ -4204,7 +4196,7 @@ static int ext4_block_zero_range(struct inode *inode,
>  
>       if (IS_DAX(inode)) {
>               return dax_zero_range(inode, from, length, did_zero,
> -                                   &ext4_iomap_ops);
> +                                   ext4_iomap_next);
>       } else if (ext4_should_journal_data(inode)) {
>               return ext4_block_journalled_zero_range(inode, from, length,
>                                                       did_zero);
> diff --git a/fs/f2fs/data.c b/fs/f2fs/data.c
> index afc9b2adaa98..9c281336c9b3 100644
> --- a/fs/f2fs/data.c
> +++ b/fs/f2fs/data.c
> @@ -4171,6 +4171,7 @@ static bool f2fs_dirty_data_folio(struct address_space 
> *mapping,
>  }
>  
>  
> +
>  static sector_t f2fs_bmap_compress(struct inode *inode, sector_t block)
>  {
>  #ifdef CONFIG_F2FS_FS_COMPRESSION
> @@ -4653,12 +4654,8 @@ static int f2fs_iomap_begin(struct inode *inode, 
> loff_t offset, loff_t length,
>       return 0;
>  }
>  
> -static int f2fs_iomap_next(const struct iomap_iter *iter, struct iomap 
> *iomap,
> -                        struct iomap *srcmap)
> +int f2fs_iomap_next(const struct iomap_iter *iter, struct iomap *iomap,
> +                 struct iomap *srcmap)
>  {
>       return iomap_process(iter, iomap, srcmap, f2fs_iomap_begin, NULL);
>  }
> -
> -const struct iomap_ops f2fs_iomap_ops = {
> -     .iomap_next     = f2fs_iomap_next,
> -};
> diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h
> index 8f3e632f315c..946a91834aec 100644
> --- a/fs/f2fs/f2fs.h
> +++ b/fs/f2fs/f2fs.h
> @@ -4216,7 +4216,8 @@ int f2fs_init_post_read_processing(void);
>  void f2fs_destroy_post_read_processing(void);
>  int f2fs_init_wq(struct f2fs_sb_info *sbi);
>  void f2fs_destroy_wq(struct f2fs_sb_info *sbi);
> -extern const struct iomap_ops f2fs_iomap_ops;
> +int f2fs_iomap_next(const struct iomap_iter *iter, struct iomap *iomap,
> +                 struct iomap *srcmap);
>  
>  /*
>   * gc.c
> diff --git a/fs/f2fs/file.c b/fs/f2fs/file.c
> index 4b52c56d71f0..74514b117257 100644
> --- a/fs/f2fs/file.c
> +++ b/fs/f2fs/file.c
> @@ -4884,7 +4884,7 @@ static ssize_t f2fs_dio_read_iter(struct kiocb *iocb, 
> struct iov_iter *to)
>        * F2FS_DIO_READ counter will be decremented correctly in all cases.
>        */
>       inc_page_count(sbi, F2FS_DIO_READ);
> -     dio = __iomap_dio_rw(iocb, to, &f2fs_iomap_ops,
> +     dio = __iomap_dio_rw(iocb, to, f2fs_iomap_next,
>                            &f2fs_iomap_dio_read_ops, 0, NULL, 0);
>       if (IS_ERR_OR_NULL(dio)) {
>               ret = PTR_ERR_OR_ZERO(dio);
> @@ -5220,7 +5220,7 @@ static ssize_t f2fs_dio_write_iter(struct kiocb *iocb, 
> struct iov_iter *from,
>       dio_flags = 0;
>       if (pos + count > inode->i_size)
>               dio_flags |= IOMAP_DIO_FORCE_WAIT;
> -     dio = __iomap_dio_rw(iocb, from, &f2fs_iomap_ops,
> +     dio = __iomap_dio_rw(iocb, from, f2fs_iomap_next,
>                            &f2fs_iomap_dio_write_ops, dio_flags, iocb, 0);
>       if (IS_ERR_OR_NULL(dio)) {
>               ret = PTR_ERR_OR_ZERO(dio);
> diff --git a/fs/fuse/dax.c b/fs/fuse/dax.c
> index e8d8c9f5d728..a6e9721552ba 100644
> --- a/fs/fuse/dax.c
> +++ b/fs/fuse/dax.c
> @@ -660,10 +660,6 @@ static int fuse_iomap_next(const struct iomap_iter 
> *iter, struct iomap *iomap,
>                            fuse_iomap_end);
>  }
>  
> -static const struct iomap_ops fuse_iomap_ops = {
> -     .iomap_next = fuse_iomap_next,
> -};
> -
>  static void fuse_wait_dax_page(struct inode *inode)
>  {
>       filemap_invalidate_unlock(inode->i_mapping);
> @@ -691,7 +687,7 @@ ssize_t fuse_dax_read_iter(struct kiocb *iocb, struct 
> iov_iter *to)
>               inode_lock_shared(inode);
>       }
>  
> -     ret = dax_iomap_rw(iocb, to, &fuse_iomap_ops);
> +     ret = dax_iomap_rw(iocb, to, fuse_iomap_next);
>       inode_unlock_shared(inode);
>  
>       /* TODO file_accessed(iocb->f_filp) */
> @@ -746,7 +742,7 @@ ssize_t fuse_dax_write_iter(struct kiocb *iocb, struct 
> iov_iter *from)
>       if (file_extending_write(iocb, from))
>               ret = fuse_dax_direct_write(iocb, from);
>       else
> -             ret = dax_iomap_rw(iocb, from, &fuse_iomap_ops);
> +             ret = dax_iomap_rw(iocb, from, fuse_iomap_next);
>  
>  out:
>       inode_unlock(inode);
> @@ -781,7 +777,7 @@ static vm_fault_t __fuse_dax_fault(struct vm_fault *vmf, 
> unsigned int order,
>        * to populate page cache or access memory we are trying to free.
>        */
>       filemap_invalidate_lock_shared(inode->i_mapping);
> -     ret = dax_iomap_fault(vmf, order, &pfn, &error, &fuse_iomap_ops);
> +     ret = dax_iomap_fault(vmf, order, &pfn, &error, fuse_iomap_next);
>       if ((ret & VM_FAULT_ERROR) && error == -EAGAIN) {
>               error = 0;
>               retry = true;
> diff --git a/fs/fuse/file.c b/fs/fuse/file.c
> index 5c0d400629cc..b3e95a28623d 100644
> --- a/fs/fuse/file.c
> +++ b/fs/fuse/file.c
> @@ -896,10 +896,6 @@ static int fuse_iomap_next(const struct iomap_iter 
> *iter, struct iomap *iomap,
>       return iomap_process(iter, iomap, srcmap, fuse_iomap_begin, NULL);
>  }
>  
> -static const struct iomap_ops fuse_iomap_ops = {
> -     .iomap_next     = fuse_iomap_next,
> -};
> -
>  struct fuse_fill_read_data {
>       struct file *file;
>  
> @@ -1020,7 +1016,7 @@ static int fuse_read_folio(struct file *file, struct 
> folio *folio)
>               return -EIO;
>       }
>  
> -     iomap_read_folio(&fuse_iomap_ops, &ctx, NULL);
> +     iomap_read_folio(fuse_iomap_next, &ctx, NULL);
>       fuse_invalidate_atime(inode);
>       return 0;
>  }
> @@ -1121,7 +1117,7 @@ static void fuse_readahead(struct readahead_control 
> *rac)
>       if (fuse_is_bad(inode))
>               return;
>  
> -     iomap_readahead(&fuse_iomap_ops, &ctx, NULL);
> +     iomap_readahead(fuse_iomap_next, &ctx, NULL);
>  }
>  
>  static ssize_t fuse_cache_read_iter(struct kiocb *iocb, struct iov_iter *to)
> @@ -1553,7 +1549,7 @@ static ssize_t fuse_cache_write_iter(struct kiocb 
> *iocb, struct iov_iter *from)
>                * and granular dirty tracking for large folios.
>                */
>               written = iomap_file_buffered_write(iocb, from,
> -                                                 &fuse_iomap_ops,
> +                                                 fuse_iomap_next,
>                                                   &fuse_iomap_write_ops,
>                                                   file);
>       } else {
> diff --git a/fs/gfs2/aops.c b/fs/gfs2/aops.c
> index 0a7b8076af3a..66bc19c011cc 100644
> --- a/fs/gfs2/aops.c
> +++ b/fs/gfs2/aops.c
> @@ -425,7 +425,7 @@ static int gfs2_read_folio(struct file *file, struct 
> folio *folio)
>  
>       if (!gfs2_is_jdata(ip) ||
>           (i_blocksize(inode) == PAGE_SIZE && !folio_buffers(folio))) {
> -             iomap_bio_read_folio(folio, &gfs2_iomap_ops);
> +             iomap_bio_read_folio(folio, gfs2_iomap_next);
>       } else if (gfs2_is_stuffed(ip)) {
>               error = stuffed_read_folio(ip, folio);
>       } else {
> @@ -500,7 +500,7 @@ static void gfs2_readahead(struct readahead_control *rac)
>       else if (gfs2_is_jdata(ip))
>               mpage_readahead(rac, gfs2_block_map);
>       else
> -             iomap_bio_readahead(rac, &gfs2_iomap_ops);
> +             iomap_bio_readahead(rac, gfs2_iomap_next);
>  }
>  
>  /**
> @@ -571,7 +571,7 @@ static sector_t gfs2_bmap(struct address_space *mapping, 
> sector_t lblock)
>               return 0;
>  
>       if (!gfs2_is_stuffed(ip))
> -             dblock = iomap_bmap(mapping, lblock, &gfs2_iomap_ops);
> +             dblock = iomap_bmap(mapping, lblock, gfs2_iomap_next);
>  
>       gfs2_glock_dq_uninit(&i_gh);
>  
> diff --git a/fs/gfs2/bmap.c b/fs/gfs2/bmap.c
> index 6cb1d4513882..1b96f5622be6 100644
> --- a/fs/gfs2/bmap.c
> +++ b/fs/gfs2/bmap.c
> @@ -1200,17 +1200,13 @@ static int gfs2_iomap_end(struct inode *inode, loff_t 
> pos, loff_t length,
>       return 0;
>  }
>  
> -static int gfs2_iomap_next(const struct iomap_iter *iter, struct iomap 
> *iomap,
> -                        struct iomap *srcmap)
> +int gfs2_iomap_next(const struct iomap_iter *iter, struct iomap *iomap,
> +                 struct iomap *srcmap)
>  {
>       return iomap_process(iter, iomap, srcmap, gfs2_iomap_begin,
>                            gfs2_iomap_end);
>  }
>  
> -const struct iomap_ops gfs2_iomap_ops = {
> -     .iomap_next = gfs2_iomap_next,
> -};
> -
>  /**
>   * gfs2_block_map - Map one or more blocks of an inode to a disk block
>   * @inode: The inode
> @@ -1324,7 +1320,7 @@ static int gfs2_block_zero_range(struct inode *inode, 
> loff_t from, loff_t length
>       if (from >= inode->i_size)
>               return 0;
>       length = min(length, inode->i_size - from);
> -     return iomap_zero_range(inode, from, length, NULL, &gfs2_iomap_ops,
> +     return iomap_zero_range(inode, from, length, NULL, gfs2_iomap_next,
>                       &gfs2_iomap_write_ops, NULL);
>  }
>  
> diff --git a/fs/gfs2/bmap.h b/fs/gfs2/bmap.h
> index e3d6efdfd890..2c2b7ab39259 100644
> --- a/fs/gfs2/bmap.h
> +++ b/fs/gfs2/bmap.h
> @@ -43,7 +43,8 @@ static inline void gfs2_write_calc_reserv(const struct 
> gfs2_inode *ip,
>       }
>  }
>  
> -extern const struct iomap_ops gfs2_iomap_ops;
> +int gfs2_iomap_next(const struct iomap_iter *iter, struct iomap *iomap,
> +             struct iomap *srcmap);
>  extern const struct iomap_write_ops gfs2_iomap_write_ops;
>  extern const struct iomap_writeback_ops gfs2_writeback_ops;
>  
> diff --git a/fs/gfs2/file.c b/fs/gfs2/file.c
> index b8c10de113ba..ef5f521a46c0 100644
> --- a/fs/gfs2/file.c
> +++ b/fs/gfs2/file.c
> @@ -844,7 +844,7 @@ static ssize_t gfs2_file_direct_read(struct kiocb *iocb, 
> struct iov_iter *to,
>               goto out_uninit;
>       pagefault_disable();
>       to->nofault = true;
> -     ret = iomap_dio_rw(iocb, to, &gfs2_iomap_ops, NULL,
> +     ret = iomap_dio_rw(iocb, to, gfs2_iomap_next, NULL,
>                          IOMAP_DIO_PARTIAL, NULL, read);
>       to->nofault = false;
>       pagefault_enable();
> @@ -910,7 +910,7 @@ static ssize_t gfs2_file_direct_write(struct kiocb *iocb, 
> struct iov_iter *from,
>               goto out_unlock;
>  
>       from->nofault = true;
> -     ret = iomap_dio_rw(iocb, from, &gfs2_iomap_ops, NULL,
> +     ret = iomap_dio_rw(iocb, from, gfs2_iomap_next, NULL,
>                          IOMAP_DIO_PARTIAL, NULL, written);
>       from->nofault = false;
>       if (ret <= 0) {
> @@ -1062,7 +1062,7 @@ static ssize_t gfs2_file_buffered_write(struct kiocb 
> *iocb,
>               goto out_unlock;
>  
>       pagefault_disable();
> -     ret = iomap_file_buffered_write(iocb, from, &gfs2_iomap_ops,
> +     ret = iomap_file_buffered_write(iocb, from, gfs2_iomap_next,
>                       &gfs2_iomap_write_ops, NULL);
>       pagefault_enable();
>       if (ret > 0)
> diff --git a/fs/gfs2/inode.c b/fs/gfs2/inode.c
> index 8a77794bbd4a..737a3b6c5268 100644
> --- a/fs/gfs2/inode.c
> +++ b/fs/gfs2/inode.c
> @@ -2217,7 +2217,7 @@ static int gfs2_fiemap(struct inode *inode, struct 
> fiemap_extent_info *fieinfo,
>               goto out;
>  
>       pagefault_disable();
> -     ret = iomap_fiemap(inode, fieinfo, start, len, &gfs2_iomap_ops);
> +     ret = iomap_fiemap(inode, fieinfo, start, len, gfs2_iomap_next);
>       pagefault_enable();
>  
>       gfs2_glock_dq_uninit(&gh);
> @@ -2242,7 +2242,7 @@ loff_t gfs2_seek_data(struct file *file, loff_t offset)
>       inode_lock_shared(inode);
>       ret = gfs2_glock_nq_init(ip->i_gl, LM_ST_SHARED, 0, &gh);
>       if (!ret)
> -             ret = iomap_seek_data(inode, offset, &gfs2_iomap_ops);
> +             ret = iomap_seek_data(inode, offset, gfs2_iomap_next);
>       gfs2_glock_dq_uninit(&gh);
>       inode_unlock_shared(inode);
>  
> @@ -2261,7 +2261,7 @@ loff_t gfs2_seek_hole(struct file *file, loff_t offset)
>       inode_lock_shared(inode);
>       ret = gfs2_glock_nq_init(ip->i_gl, LM_ST_SHARED, 0, &gh);
>       if (!ret)
> -             ret = iomap_seek_hole(inode, offset, &gfs2_iomap_ops);
> +             ret = iomap_seek_hole(inode, offset, gfs2_iomap_next);
>       gfs2_glock_dq_uninit(&gh);
>       inode_unlock_shared(inode);
>  
> diff --git a/fs/hpfs/file.c b/fs/hpfs/file.c
> index 1df9f28fb40b..08d5df5fb3cf 100644
> --- a/fs/hpfs/file.c
> +++ b/fs/hpfs/file.c
> @@ -162,10 +162,6 @@ static int hpfs_iomap_next(const struct iomap_iter 
> *iter, struct iomap *iomap,
>       return iomap_process(iter, iomap, srcmap, hpfs_iomap_begin, NULL);
>  }
>  
> -static const struct iomap_ops hpfs_iomap_ops = {
> -     .iomap_next             = hpfs_iomap_next,
> -};
> -
>  static int hpfs_read_folio(struct file *file, struct folio *folio)
>  {
>       return mpage_read_folio(folio, hpfs_get_block);
> @@ -242,7 +238,7 @@ static int hpfs_fiemap(struct inode *inode, struct 
> fiemap_extent_info *fieinfo,
>  
>       inode_lock(inode);
>       len = min_t(u64, len, i_size_read(inode));
> -     ret = iomap_fiemap(inode, fieinfo, start, len, &hpfs_iomap_ops);
> +     ret = iomap_fiemap(inode, fieinfo, start, len, hpfs_iomap_next);
>       inode_unlock(inode);
>  
>       return ret;
> diff --git a/fs/internal.h b/fs/internal.h
> index 355d93f92208..19601f8406dc 100644
> --- a/fs/internal.h
> +++ b/fs/internal.h
> @@ -8,7 +8,6 @@
>  struct super_block;
>  struct file_system_type;
>  struct iomap;
> -struct iomap_ops;
>  struct linux_binprm;
>  struct path;
>  struct mount;
> diff --git a/fs/iomap/buffered-io.c b/fs/iomap/buffered-io.c
> index 3f0932e46fd6..0aa8abc438c1 100644
> --- a/fs/iomap/buffered-io.c
> +++ b/fs/iomap/buffered-io.c
> @@ -626,7 +626,7 @@ static int iomap_read_folio_iter(struct iomap_iter *iter,
>       return 0;
>  }
>  
> -void iomap_read_folio(const struct iomap_ops *ops,
> +void iomap_read_folio(iomap_next_fn iomap_next,
>               struct iomap_read_folio_ctx *ctx, void *private)
>  {
>       struct folio *folio = ctx->cur_folio;
> @@ -650,7 +650,7 @@ void iomap_read_folio(const struct iomap_ops *ops,
>               fsverity_readahead(ctx->vi, folio->index,
>                                  folio_nr_pages(folio));
>  
> -     while ((ret = iomap_iter(&iter, ops)) > 0) {
> +     while ((ret = iomap_iter(&iter, iomap_next)) > 0) {
>               iter.status = iomap_read_folio_iter(&iter, ctx,
>                               &bytes_submitted);
>               iomap_read_submit(&iter, ctx);
> @@ -688,22 +688,22 @@ static int iomap_readahead_iter(struct iomap_iter *iter,
>  
>  /**
>   * iomap_readahead - Attempt to read pages from a file.
> - * @ops: The operations vector for the filesystem.
> + * @iomap_next: The iomap_next callback for the filesystem.
>   * @ctx: The ctx used for issuing readahead.
>   * @private: The filesystem-specific information for issuing iomap_iter.
>   *
>   * This function is for filesystems to call to implement their readahead
>   * address_space operation.
>   *
> - * Context: The @ops callbacks may submit I/O (eg to read the addresses of
> + * Context: The @iomap_next callback may submit I/O (eg to read the 
> addresses of
>   * blocks from disc), and may wait for it.  The caller may be trying to
>   * access a different page, and so sleeping excessively should be avoided.
>   * It may allocate memory, but should avoid costly allocations.  This
>   * function is called with memalloc_nofs set, so allocations will not cause
>   * the filesystem to be reentered.
>   */
> -void iomap_readahead(const struct iomap_ops *ops,
> -             struct iomap_read_folio_ctx *ctx, void *private)
> +void iomap_readahead(iomap_next_fn iomap_next, struct iomap_read_folio_ctx 
> *ctx,
> +             void *private)
>  {
>       struct readahead_control *rac = ctx->rac;
>       struct iomap_iter iter = {
> @@ -725,7 +725,7 @@ void iomap_readahead(const struct iomap_ops *ops,
>               fsverity_readahead(ctx->vi, readahead_index(rac),
>                               readahead_count(rac));
>  
> -     while (iomap_iter(&iter, ops) > 0) {
> +     while (iomap_iter(&iter, iomap_next) > 0) {
>               iter.status = iomap_readahead_iter(&iter, ctx,
>                                       &cur_bytes_submitted);
>               iomap_read_submit(&iter, ctx);
> @@ -1268,7 +1268,7 @@ static int iomap_write_iter(struct iomap_iter *iter, 
> struct iov_iter *i,
>  
>  ssize_t
>  iomap_file_buffered_write(struct kiocb *iocb, struct iov_iter *i,
> -             const struct iomap_ops *ops,
> +             iomap_next_fn iomap_next,
>               const struct iomap_write_ops *write_ops, void *private)
>  {
>       struct iomap_iter iter = {
> @@ -1285,7 +1285,7 @@ iomap_file_buffered_write(struct kiocb *iocb, struct 
> iov_iter *i,
>       if (iocb->ki_flags & IOCB_DONTCACHE)
>               iter.flags |= IOMAP_DONTCACHE;
>  
> -     while ((ret = iomap_iter(&iter, ops)) > 0)
> +     while ((ret = iomap_iter(&iter, iomap_next)) > 0)
>               iter.status = iomap_write_iter(&iter, i, write_ops);
>  
>       if (unlikely(iter.pos == iocb->ki_pos))
> @@ -1297,7 +1297,7 @@ iomap_file_buffered_write(struct kiocb *iocb, struct 
> iov_iter *i,
>  EXPORT_SYMBOL_GPL(iomap_file_buffered_write);
>  
>  int iomap_fsverity_write(struct file *file, loff_t pos, size_t length,
> -             const void *buf, const struct iomap_ops *ops,
> +             const void *buf, iomap_next_fn iomap_next,
>               const struct iomap_write_ops *write_ops)
>  {
>       int                     ret;
> @@ -1314,7 +1314,7 @@ int iomap_fsverity_write(struct file *file, loff_t pos, 
> size_t length,
>  
>       iov_iter_kvec(&iiter, WRITE, &kvec, 1, length);
>  
> -     ret = iomap_file_buffered_write(&iocb, &iiter, ops, write_ops, NULL);
> +     ret = iomap_file_buffered_write(&iocb, &iiter, iomap_next, write_ops, 
> NULL);
>       if (ret < 0)
>               return ret;
>       return ret == length ? 0 : -EIO;
> @@ -1586,7 +1586,7 @@ static int iomap_unshare_iter(struct iomap_iter *iter,
>  
>  int
>  iomap_file_unshare(struct inode *inode, loff_t pos, loff_t len,
> -             const struct iomap_ops *ops,
> +             iomap_next_fn iomap_next,
>               const struct iomap_write_ops *write_ops)
>  {
>       struct iomap_iter iter = {
> @@ -1601,7 +1601,7 @@ iomap_file_unshare(struct inode *inode, loff_t pos, 
> loff_t len,
>               return 0;
>  
>       iter.len = min(len, size - pos);
> -     while ((ret = iomap_iter(&iter, ops)) > 0)
> +     while ((ret = iomap_iter(&iter, iomap_next)) > 0)
>               iter.status = iomap_unshare_iter(&iter, write_ops);
>       return ret;
>  }
> @@ -1710,7 +1710,7 @@ EXPORT_SYMBOL_GPL(iomap_fill_dirty_folios);
>  
>  int
>  iomap_zero_range(struct inode *inode, loff_t pos, loff_t len, bool *did_zero,
> -             const struct iomap_ops *ops,
> +             iomap_next_fn iomap_next,
>               const struct iomap_write_ops *write_ops, void *private)
>  {
>       struct folio_batch fbatch;
> @@ -1735,7 +1735,7 @@ iomap_zero_range(struct inode *inode, loff_t pos, 
> loff_t len, bool *did_zero,
>        */
>       range_dirty = filemap_range_needs_writeback(mapping, iter.pos,
>                                       iter.pos + iter.len - 1);
> -     while ((ret = iomap_iter(&iter, ops)) > 0) {
> +     while ((ret = iomap_iter(&iter, iomap_next)) > 0) {
>               const struct iomap *srcmap = iomap_iter_srcmap(&iter);
>  
>               if (!(iter.iomap.flags & IOMAP_F_FOLIO_BATCH) &&
> @@ -1761,7 +1761,7 @@ EXPORT_SYMBOL_GPL(iomap_zero_range);
>  
>  int
>  iomap_truncate_page(struct inode *inode, loff_t pos, bool *did_zero,
> -             const struct iomap_ops *ops,
> +             iomap_next_fn iomap_next,
>               const struct iomap_write_ops *write_ops, void *private)
>  {
>       unsigned int blocksize = i_blocksize(inode);
> @@ -1770,7 +1770,7 @@ iomap_truncate_page(struct inode *inode, loff_t pos, 
> bool *did_zero,
>       /* Block boundary? Nothing to do */
>       if (!off)
>               return 0;
> -     return iomap_zero_range(inode, pos, blocksize - off, did_zero, ops,
> +     return iomap_zero_range(inode, pos, blocksize - off, did_zero, 
> iomap_next,
>                       write_ops, private);
>  }
>  EXPORT_SYMBOL_GPL(iomap_truncate_page);
> @@ -1795,7 +1795,7 @@ static int iomap_folio_mkwrite_iter(struct iomap_iter 
> *iter,
>       return iomap_iter_advance(iter, length);
>  }
>  
> -vm_fault_t iomap_page_mkwrite(struct vm_fault *vmf, const struct iomap_ops 
> *ops,
> +vm_fault_t iomap_page_mkwrite(struct vm_fault *vmf, iomap_next_fn iomap_next,
>               void *private)
>  {
>       struct iomap_iter iter = {
> @@ -1812,7 +1812,7 @@ vm_fault_t iomap_page_mkwrite(struct vm_fault *vmf, 
> const struct iomap_ops *ops,
>               goto out_unlock;
>       iter.pos = folio_pos(folio);
>       iter.len = ret;
> -     while ((ret = iomap_iter(&iter, ops)) > 0)
> +     while ((ret = iomap_iter(&iter, iomap_next)) > 0)
>               iter.status = iomap_folio_mkwrite_iter(&iter, folio);
>  
>       if (ret < 0)
> diff --git a/fs/iomap/direct-io.c b/fs/iomap/direct-io.c
> index b485e3b191da..e299d186f743 100644
> --- a/fs/iomap/direct-io.c
> +++ b/fs/iomap/direct-io.c
> @@ -676,7 +676,7 @@ static int iomap_dio_iter(struct iomap_iter *iter, struct 
> iomap_dio *dio)
>   */
>  struct iomap_dio *
>  __iomap_dio_rw(struct kiocb *iocb, struct iov_iter *iter,
> -             const struct iomap_ops *ops, const struct iomap_dio_ops *dops,
> +             iomap_next_fn iomap_next, const struct iomap_dio_ops *dops,
>               unsigned int dio_flags, void *private, size_t done_before)
>  {
>       struct inode *inode = file_inode(iocb->ki_filp);
> @@ -800,7 +800,7 @@ __iomap_dio_rw(struct kiocb *iocb, struct iov_iter *iter,
>       inode_dio_begin(inode);
>  
>       blk_start_plug(&plug);
> -     while ((ret = iomap_iter(&iomi, ops)) > 0) {
> +     while ((ret = iomap_iter(&iomi, iomap_next)) > 0) {
>               iomi.status = iomap_dio_iter(&iomi, dio);
>  
>               /*
> @@ -890,12 +890,12 @@ EXPORT_SYMBOL_GPL(__iomap_dio_rw);
>  
>  ssize_t
>  iomap_dio_rw(struct kiocb *iocb, struct iov_iter *iter,
> -             const struct iomap_ops *ops, const struct iomap_dio_ops *dops,
> +             iomap_next_fn iomap_next, const struct iomap_dio_ops *dops,
>               unsigned int dio_flags, void *private, size_t done_before)
>  {
>       struct iomap_dio *dio;
>  
> -     dio = __iomap_dio_rw(iocb, iter, ops, dops, dio_flags, private,
> +     dio = __iomap_dio_rw(iocb, iter, iomap_next, dops, dio_flags, private,
>                            done_before);
>       if (IS_ERR_OR_NULL(dio))
>               return PTR_ERR_OR_ZERO(dio);
> diff --git a/fs/iomap/fiemap.c b/fs/iomap/fiemap.c
> index d11dadff8286..fc488f05d8ce 100644
> --- a/fs/iomap/fiemap.c
> +++ b/fs/iomap/fiemap.c
> @@ -56,7 +56,7 @@ static int iomap_fiemap_iter(struct iomap_iter *iter,
>  }
>  
>  int iomap_fiemap(struct inode *inode, struct fiemap_extent_info *fi,
> -             u64 start, u64 len, const struct iomap_ops *ops)
> +             u64 start, u64 len, iomap_next_fn iomap_next)
>  {
>       struct iomap_iter iter = {
>               .inode          = inode,
> @@ -73,7 +73,7 @@ int iomap_fiemap(struct inode *inode, struct 
> fiemap_extent_info *fi,
>       if (ret)
>               return ret;
>  
> -     while ((ret = iomap_iter(&iter, ops)) > 0)
> +     while ((ret = iomap_iter(&iter, iomap_next)) > 0)
>               iter.status = iomap_fiemap_iter(&iter, fi, &prev);
>  
>       if (prev.type != IOMAP_HOLE) {
> @@ -92,7 +92,7 @@ EXPORT_SYMBOL_GPL(iomap_fiemap);
>  /* legacy ->bmap interface.  0 is the error return (!) */
>  sector_t
>  iomap_bmap(struct address_space *mapping, sector_t bno,
> -             const struct iomap_ops *ops)
> +             iomap_next_fn iomap_next)
>  {
>       struct iomap_iter iter = {
>               .inode  = mapping->host,
> @@ -107,7 +107,7 @@ iomap_bmap(struct address_space *mapping, sector_t bno,
>               return 0;
>  
>       bno = 0;
> -     while ((ret = iomap_iter(&iter, ops)) > 0) {
> +     while ((ret = iomap_iter(&iter, iomap_next)) > 0) {
>               if (iter.iomap.type == IOMAP_MAPPED)
>                       bno = iomap_sector(&iter.iomap, iter.pos) >> blkshift;
>               /* leave iter.status unset to abort loop */
> diff --git a/fs/iomap/iter.c b/fs/iomap/iter.c
> index 466c491bdef6..984045af310a 100644
> --- a/fs/iomap/iter.c
> +++ b/fs/iomap/iter.c
> @@ -42,7 +42,7 @@ static inline void iomap_iter_done(struct iomap_iter *iter)
>  /**
>   * iomap_iter - iterate over a ranges in a file
>   * @iter: iteration structue
> - * @ops: iomap ops provided by the file system
> + * @iomap_next: iomap_next callback provided by the file system
>   *
>   * Iterate over filesystem-provided space mappings for the provided file 
> range.
>   *
> @@ -54,13 +54,13 @@ static inline void iomap_iter_done(struct iomap_iter 
> *iter)
>   * of the loop body:  leave @iter.status unchanged, or set it to a negative
>   * errno.
>   */
> -int iomap_iter(struct iomap_iter *iter, const struct iomap_ops *ops)
> +int iomap_iter(struct iomap_iter *iter, iomap_next_fn iomap_next)
>  {
>       int ret;
>  
> -     trace_iomap_iter(iter, ops, _RET_IP_);
> +     trace_iomap_iter(iter, iomap_next, _RET_IP_);
>  
> -     ret = ops->iomap_next(iter, &iter->iomap, &iter->srcmap);
> +     ret = iomap_next(iter, &iter->iomap, &iter->srcmap);
>       iter->status = 0;
>       if (ret > 0)
>               iomap_iter_done(iter);
> diff --git a/fs/iomap/seek.c b/fs/iomap/seek.c
> index 6cbc587c93da..1bc5053d3fc1 100644
> --- a/fs/iomap/seek.c
> +++ b/fs/iomap/seek.c
> @@ -27,7 +27,7 @@ static int iomap_seek_hole_iter(struct iomap_iter *iter,
>  }
>  
>  loff_t
> -iomap_seek_hole(struct inode *inode, loff_t pos, const struct iomap_ops *ops)
> +iomap_seek_hole(struct inode *inode, loff_t pos, iomap_next_fn iomap_next)
>  {
>       loff_t size = i_size_read(inode);
>       struct iomap_iter iter = {
> @@ -42,7 +42,7 @@ iomap_seek_hole(struct inode *inode, loff_t pos, const 
> struct iomap_ops *ops)
>               return -ENXIO;
>  
>       iter.len = size - pos;
> -     while ((ret = iomap_iter(&iter, ops)) > 0)
> +     while ((ret = iomap_iter(&iter, iomap_next)) > 0)
>               iter.status = iomap_seek_hole_iter(&iter, &pos);
>       if (ret < 0)
>               return ret;
> @@ -73,7 +73,7 @@ static int iomap_seek_data_iter(struct iomap_iter *iter,
>  }
>  
>  loff_t
> -iomap_seek_data(struct inode *inode, loff_t pos, const struct iomap_ops *ops)
> +iomap_seek_data(struct inode *inode, loff_t pos, iomap_next_fn iomap_next)
>  {
>       loff_t size = i_size_read(inode);
>       struct iomap_iter iter = {
> @@ -88,7 +88,7 @@ iomap_seek_data(struct inode *inode, loff_t pos, const 
> struct iomap_ops *ops)
>               return -ENXIO;
>  
>       iter.len = size - pos;
> -     while ((ret = iomap_iter(&iter, ops)) > 0)
> +     while ((ret = iomap_iter(&iter, iomap_next)) > 0)
>               iter.status = iomap_seek_data_iter(&iter, &pos);
>       if (ret < 0)
>               return ret;
> diff --git a/fs/iomap/swapfile.c b/fs/iomap/swapfile.c
> index 0db77c449467..b8bb34deddfc 100644
> --- a/fs/iomap/swapfile.c
> +++ b/fs/iomap/swapfile.c
> @@ -139,7 +139,7 @@ static int iomap_swapfile_iter(struct iomap_iter *iter,
>   */
>  int iomap_swapfile_activate(struct swap_info_struct *sis,
>               struct file *swap_file, sector_t *pagespan,
> -             const struct iomap_ops *ops)
> +             iomap_next_fn iomap_next)
>  {
>       struct inode *inode = swap_file->f_mapping->host;
>       struct iomap_iter iter = {
> @@ -163,7 +163,7 @@ int iomap_swapfile_activate(struct swap_info_struct *sis,
>       if (ret)
>               return ret;
>  
> -     while ((ret = iomap_iter(&iter, ops)) > 0)
> +     while ((ret = iomap_iter(&iter, iomap_next)) > 0)
>               iter.status = iomap_swapfile_iter(&iter, &iter.iomap, &isi);
>       if (ret < 0)
>               return ret;
> diff --git a/fs/ntfs/aops.c b/fs/ntfs/aops.c
> index 1fbf832ad165..43ad597ed491 100644
> --- a/fs/ntfs/aops.c
> +++ b/fs/ntfs/aops.c
> @@ -97,7 +97,7 @@ static int ntfs_read_folio(struct file *file, struct folio 
> *folio)
>                       return ntfs_read_compressed_block(folio);
>       }
>  
> -     iomap_read_folio(&ntfs_read_iomap_ops, &ctx, NULL);
> +     iomap_read_folio(ntfs_read_iomap_next, &ctx, NULL);
>       return 0;
>  }
>  
> @@ -238,7 +238,7 @@ static void ntfs_readahead(struct readahead_control *rac)
>        */
>       if (!NInoNonResident(ni) || NInoCompressed(ni))
>               return;
> -     iomap_readahead(&ntfs_read_iomap_ops, &ctx, NULL);
> +     iomap_readahead(ntfs_read_iomap_next, &ctx, NULL);
>  }
>  
>  static int ntfs_writepages(struct address_space *mapping,
> @@ -274,7 +274,7 @@ static int ntfs_swap_activate(struct swap_info_struct 
> *sis,
>               struct file *swap_file, sector_t *span)
>  {
>       return iomap_swapfile_activate(sis, swap_file, span,
> -                     &ntfs_read_iomap_ops);
> +                     ntfs_read_iomap_next);
>  }
>  
>  const struct address_space_operations ntfs_aops = {
> diff --git a/fs/ntfs/file.c b/fs/ntfs/file.c
> index 6a7b638e523d..a4f99128b46c 100644
> --- a/fs/ntfs/file.c
> +++ b/fs/ntfs/file.c
> @@ -281,7 +281,7 @@ static int ntfs_setattr_size(struct inode *vi, struct 
> iattr *attr)
>                               round_up(old_size, PAGE_SIZE) - old_size,
>                               attr->ia_size - old_size);
>               err = iomap_zero_range(vi, old_size, len,
> -                             NULL, &ntfs_seek_iomap_ops,
> +                             NULL, ntfs_seek_iomap_next,
>                               &ntfs_iomap_folio_ops, NULL);
>       }
>  
> @@ -417,12 +417,12 @@ static loff_t ntfs_file_llseek(struct file *file, 
> loff_t offset, int whence)
>       switch (whence) {
>       case SEEK_HOLE:
>               inode_lock_shared(inode);
> -             offset = iomap_seek_hole(inode, offset, &ntfs_seek_iomap_ops);
> +             offset = iomap_seek_hole(inode, offset, ntfs_seek_iomap_next);
>               inode_unlock_shared(inode);
>               break;
>       case SEEK_DATA:
>               inode_lock_shared(inode);
> -             offset = iomap_seek_data(inode, offset, &ntfs_seek_iomap_ops);
> +             offset = iomap_seek_data(inode, offset, ntfs_seek_iomap_next);
>               inode_unlock_shared(inode);
>               break;
>       default:
> @@ -458,7 +458,7 @@ static ssize_t ntfs_file_read_iter(struct kiocb *iocb, 
> struct iov_iter *to)
>               }
>  
>               file_accessed(iocb->ki_filp);
> -             ret = iomap_dio_rw(iocb, to, &ntfs_read_iomap_ops, NULL, 0,
> +             ret = iomap_dio_rw(iocb, to, ntfs_read_iomap_next, NULL, 0,
>                               NULL, 0);
>       } else {
>               ret = generic_file_read_iter(iocb, to);
> @@ -496,7 +496,7 @@ static ssize_t ntfs_dio_write_iter(struct kiocb *iocb, 
> struct iov_iter *from)
>  {
>       ssize_t ret;
>  
> -     ret = iomap_dio_rw(iocb, from, &ntfs_dio_iomap_ops,
> +     ret = iomap_dio_rw(iocb, from, ntfs_dio_iomap_next,
>                       &ntfs_write_dio_ops, 0, NULL, 0);
>       if (ret == -ENOTBLK)
>               ret = 0;
> @@ -511,7 +511,7 @@ static ssize_t ntfs_dio_write_iter(struct kiocb *iocb, 
> struct iov_iter *from)
>               offset = iocb->ki_pos;
>               iocb->ki_flags &= ~IOCB_DIRECT;
>               written = iomap_file_buffered_write(iocb, from,
> -                             &ntfs_write_iomap_ops, &ntfs_iomap_folio_ops,
> +                             ntfs_write_iomap_next, &ntfs_iomap_folio_ops,
>                               NULL);
>               if (written < 0) {
>                       ret = written;
> @@ -594,7 +594,7 @@ static ssize_t ntfs_file_write_iter(struct kiocb *iocb, 
> struct iov_iter *from)
>       if (NInoNonResident(ni) && iocb->ki_flags & IOCB_DIRECT)
>               ret = ntfs_dio_write_iter(iocb, from);
>       else
> -             ret = iomap_file_buffered_write(iocb, from, 
> &ntfs_write_iomap_ops,
> +             ret = iomap_file_buffered_write(iocb, from, 
> ntfs_write_iomap_next,
>                               &ntfs_iomap_folio_ops, NULL);
>  out:
>       if (ret < 0 && ret != -EIOCBQUEUED) {
> @@ -623,7 +623,7 @@ static vm_fault_t ntfs_filemap_page_mkwrite(struct 
> vm_fault *vmf)
>       sb_start_pagefault(inode->i_sb);
>       file_update_time(vmf->vma->vm_file);
>  
> -     ret = iomap_page_mkwrite(vmf, &ntfs_page_mkwrite_iomap_ops, NULL);
> +     ret = iomap_page_mkwrite(vmf, ntfs_page_mkwrite_iomap_next, NULL);
>       sb_end_pagefault(inode->i_sb);
>       return ret;
>  }
> @@ -670,7 +670,7 @@ static int ntfs_file_mmap_prepare(struct vm_area_desc 
> *desc)
>  static int ntfs_fiemap(struct inode *inode, struct fiemap_extent_info 
> *fieinfo,
>               u64 start, u64 len)
>  {
> -     return iomap_fiemap(inode, fieinfo, start, len, &ntfs_read_iomap_ops);
> +     return iomap_fiemap(inode, fieinfo, start, len, ntfs_read_iomap_next);
>  }
>  
>  static const char *ntfs_get_link(struct dentry *dentry, struct inode *inode,
> @@ -911,7 +911,7 @@ static int ntfs_punch_hole(struct ntfs_inode *ni, int 
> mode, loff_t offset,
>                                  ntfs_cluster_to_bytes(vol, start_vcn + 1),
>                                  end_offset);
>                       err = iomap_zero_range(vi, offset, to - offset,
> -                                            NULL, &ntfs_seek_iomap_ops,
> +                                            NULL, ntfs_seek_iomap_next,
>                                              &ntfs_iomap_folio_ops, NULL);
>                       if (err < 0)
>                               goto out;
> @@ -927,7 +927,7 @@ static int ntfs_punch_hole(struct ntfs_inode *ni, int 
> mode, loff_t offset,
>               from = ntfs_cluster_to_bytes(vol, end_vcn - 1);
>               if (from < ni->initialized_size) {
>                       err = iomap_zero_range(vi, from, end_offset - from,
> -                                            NULL, &ntfs_seek_iomap_ops,
> +                                            NULL, ntfs_seek_iomap_next,
>                                              &ntfs_iomap_folio_ops, NULL);
>                       if (err < 0)
>                               goto out;
> @@ -1131,7 +1131,7 @@ static long ntfs_fallocate(struct file *file, int mode, 
> loff_t offset, loff_t le
>                                          round_up(old_size, PAGE_SIZE) - 
> old_size,
>                                          offset - old_size);
>                       err = iomap_zero_range(vi, old_size, len, NULL,
> -                                            &ntfs_seek_iomap_ops,
> +                                            ntfs_seek_iomap_next,
>                                              &ntfs_iomap_folio_ops, NULL);
>               }
>               NInoSetFileNameDirty(ni);
> diff --git a/fs/ntfs/inode.c b/fs/ntfs/inode.c
> index c2715521e562..05132d92e87b 100644
> --- a/fs/ntfs/inode.c
> +++ b/fs/ntfs/inode.c
> @@ -2415,7 +2415,7 @@ int ntfs_extend_initialized_size(struct inode *vi, 
> const loff_t offset,
>       if (!NInoCompressed(ni) && old_init_size < offset) {
>               err = iomap_zero_range(vi, old_init_size,
>                                      offset - old_init_size,
> -                                    NULL, &ntfs_seek_iomap_ops,
> +                                    NULL, ntfs_seek_iomap_next,
>                                      &ntfs_iomap_folio_ops, NULL);
>               if (err)
>                       return err;
> diff --git a/fs/ntfs/iomap.c b/fs/ntfs/iomap.c
> index 0f9f02e1593e..502f08f01354 100644
> --- a/fs/ntfs/iomap.c
> +++ b/fs/ntfs/iomap.c
> @@ -277,16 +277,12 @@ static int ntfs_read_iomap_begin(struct inode *inode, 
> loff_t offset, loff_t leng
>                       srcmap, true);
>  }
>  
> -static int ntfs_read_iomap_next(const struct iomap_iter *iter,
> -             struct iomap *iomap, struct iomap *srcmap)
> +int ntfs_read_iomap_next(const struct iomap_iter *iter, struct iomap *iomap,
> +             struct iomap *srcmap)
>  {
>       return iomap_process(iter, iomap, srcmap, ntfs_read_iomap_begin, NULL);
>  }
>  
> -const struct iomap_ops ntfs_read_iomap_ops = {
> -     .iomap_next = ntfs_read_iomap_next,
> -};
> -
>  /*
>   * Check that the cached iomap still matches the NTFS runlist before
>   * iomap_zero_range() is called. if the runlist changes while iomap is
> @@ -342,20 +338,12 @@ static int ntfs_zero_read_iomap_next(const struct 
> iomap_iter *iter,
>                       ntfs_zero_read_iomap_end);
>  }
>  
> -static const struct iomap_ops ntfs_zero_read_iomap_ops = {
> -     .iomap_next = ntfs_zero_read_iomap_next,
> -};
> -
> -static int ntfs_seek_iomap_next(const struct iomap_iter *iter,
> +int ntfs_seek_iomap_next(const struct iomap_iter *iter,
>               struct iomap *iomap, struct iomap *srcmap)
>  {
>       return iomap_process(iter, iomap, srcmap, ntfs_seek_iomap_begin, NULL);
>  }
>  
> -const struct iomap_ops ntfs_seek_iomap_ops = {
> -     .iomap_next = ntfs_seek_iomap_next,
> -};
> -
>  int ntfs_dio_zero_range(struct inode *inode, loff_t offset, loff_t length)
>  {
>       if ((offset | length) & (SECTOR_SIZE - 1))
> @@ -373,7 +361,7 @@ static int ntfs_zero_range(struct inode *inode, loff_t 
> offset, loff_t length)
>       return iomap_zero_range(inode,
>                               offset, length,
>                               NULL,
> -                             &ntfs_zero_read_iomap_ops,
> +                             ntfs_zero_read_iomap_next,
>                               &ntfs_zero_iomap_folio_ops,
>                               NULL);
>  }
> @@ -782,17 +770,13 @@ static int ntfs_write_iomap_end(struct inode *inode, 
> loff_t pos, loff_t length,
>       return written;
>  }
>  
> -static int ntfs_write_iomap_next(const struct iomap_iter *iter,
> -             struct iomap *iomap, struct iomap *srcmap)
> +int ntfs_write_iomap_next(const struct iomap_iter *iter, struct iomap *iomap,
> +             struct iomap *srcmap)
>  {
>       return iomap_process(iter, iomap, srcmap, ntfs_write_iomap_begin,
>                       ntfs_write_iomap_end);
>  }
>  
> -const struct iomap_ops ntfs_write_iomap_ops = {
> -     .iomap_next             = ntfs_write_iomap_next,
> -};
> -
>  static int ntfs_page_mkwrite_iomap_begin(struct inode *inode, loff_t offset,
>                                 loff_t length, unsigned int flags,
>                                 struct iomap *iomap, struct iomap *srcmap)
> @@ -801,17 +785,13 @@ static int ntfs_page_mkwrite_iomap_begin(struct inode 
> *inode, loff_t offset,
>                       NTFS_IOMAP_FLAGS_MKWRITE);
>  }
>  
> -static int ntfs_page_mkwrite_iomap_next(const struct iomap_iter *iter,
> +int ntfs_page_mkwrite_iomap_next(const struct iomap_iter *iter,
>               struct iomap *iomap, struct iomap *srcmap)
>  {
>       return iomap_process(iter, iomap, srcmap, ntfs_page_mkwrite_iomap_begin,
>                       ntfs_write_iomap_end);
>  }
>  
> -const struct iomap_ops ntfs_page_mkwrite_iomap_ops = {
> -     .iomap_next             = ntfs_page_mkwrite_iomap_next,
> -};
> -
>  static int ntfs_dio_iomap_begin(struct inode *inode, loff_t offset,
>                                 loff_t length, unsigned int flags,
>                                 struct iomap *iomap, struct iomap *srcmap)
> @@ -820,17 +800,13 @@ static int ntfs_dio_iomap_begin(struct inode *inode, 
> loff_t offset,
>                       NTFS_IOMAP_FLAGS_DIO);
>  }
>  
> -static int ntfs_dio_iomap_next(const struct iomap_iter *iter,
> -             struct iomap *iomap, struct iomap *srcmap)
> +int ntfs_dio_iomap_next(const struct iomap_iter *iter, struct iomap *iomap,
> +             struct iomap *srcmap)
>  {
>       return iomap_process(iter, iomap, srcmap, ntfs_dio_iomap_begin,
>                       ntfs_write_iomap_end);
>  }
>  
> -const struct iomap_ops ntfs_dio_iomap_ops = {
> -     .iomap_next             = ntfs_dio_iomap_next,
> -};
> -
>  static ssize_t ntfs_writeback_range(struct iomap_writepage_ctx *wpc,
>               struct folio *folio, u64 offset, unsigned int len, u64 end_pos)
>  {
> diff --git a/fs/ntfs/iomap.h b/fs/ntfs/iomap.h
> index 3abc1d493e91..69443de1fefd 100644
> --- a/fs/ntfs/iomap.h
> +++ b/fs/ntfs/iomap.h
> @@ -12,11 +12,16 @@
>  #include "volume.h"
>  #include "inode.h"
>  
> -extern const struct iomap_ops ntfs_write_iomap_ops;
> -extern const struct iomap_ops ntfs_read_iomap_ops;
> -extern const struct iomap_ops ntfs_seek_iomap_ops;
> -extern const struct iomap_ops ntfs_page_mkwrite_iomap_ops;
> -extern const struct iomap_ops ntfs_dio_iomap_ops;
> +int ntfs_write_iomap_next(const struct iomap_iter *iter, struct iomap *iomap,
> +             struct iomap *srcmap);
> +int ntfs_read_iomap_next(const struct iomap_iter *iter, struct iomap *iomap,
> +             struct iomap *srcmap);
> +int ntfs_seek_iomap_next(const struct iomap_iter *iter, struct iomap *iomap,
> +             struct iomap *srcmap);
> +int ntfs_page_mkwrite_iomap_next(const struct iomap_iter *iter,
> +             struct iomap *iomap, struct iomap *srcmap);
> +int ntfs_dio_iomap_next(const struct iomap_iter *iter, struct iomap *iomap,
> +             struct iomap *srcmap);
>  extern const struct iomap_writeback_ops ntfs_writeback_ops;
>  extern const struct iomap_write_ops ntfs_iomap_folio_ops;
>  extern int ntfs_dio_zero_range(struct inode *inode, loff_t offset, loff_t 
> length);
> diff --git a/fs/ntfs3/file.c b/fs/ntfs3/file.c
> index d601f088618c..55844b42920a 100644
> --- a/fs/ntfs3/file.c
> +++ b/fs/ntfs3/file.c
> @@ -315,7 +315,7 @@ static int ntfs_extend_initialized_size(struct file *file,
>       }
>  
>       err = iomap_zero_range(inode, valid, new_valid - valid, NULL,
> -                            &ntfs_iomap_ops, &ntfs_iomap_folio_ops, NULL);
> +                            ntfs_iomap_next, &ntfs_iomap_folio_ops, NULL);
>       if (err) {
>               ni->i_valid = valid;
>               ntfs_inode_warn(inode,
> @@ -554,7 +554,7 @@ static long ntfs_fallocate(struct file *file, int mode, 
> loff_t vbo, loff_t len)
>               /* Zero head of punch. */
>               if (tmp > from) {
>                       err = iomap_zero_range(inode, from, tmp - from, NULL,
> -                                            &ntfs_iomap_ops,
> +                                            ntfs_iomap_next,
>                                              &ntfs_iomap_folio_ops, NULL);
>                       if (err)
>                               goto out;
> @@ -572,7 +572,7 @@ static long ntfs_fallocate(struct file *file, int mode, 
> loff_t vbo, loff_t len)
>               /* Zero tail of punch. */
>               if (vbo < end_a && end_a < end) {
>                       err = iomap_zero_range(inode, end_a, end - end_a, NULL,
> -                                            &ntfs_iomap_ops,
> +                                            ntfs_iomap_next,
>                                              &ntfs_iomap_folio_ops, NULL);
>                       if (err)
>                               goto out;
> @@ -872,7 +872,7 @@ static ssize_t ntfs_file_read_iter(struct kiocb *iocb, 
> struct iov_iter *iter)
>                               goto out;
>               }
>  
> -             err = iomap_dio_rw(iocb, iter, &ntfs_iomap_ops, NULL, dio_flags,
> +             err = iomap_dio_rw(iocb, iter, ntfs_iomap_next, NULL, dio_flags,
>                                  NULL, 0);
>  
>               if (err <= 0)
> @@ -1286,7 +1286,7 @@ static ssize_t ntfs_file_write_iter(struct kiocb *iocb, 
> struct iov_iter *from)
>           !ntfs_should_use_dio(iocb, from)) {
>               iocb->ki_flags &= ~IOCB_DIRECT;
>  
> -             ret = iomap_file_buffered_write(iocb, from, &ntfs_iomap_ops,
> +             ret = iomap_file_buffered_write(iocb, from, ntfs_iomap_next,
>                                               &ntfs_iomap_folio_ops, NULL);
>               inode_unlock(inode);
>  
> @@ -1303,7 +1303,7 @@ static ssize_t ntfs_file_write_iter(struct kiocb *iocb, 
> struct iov_iter *from)
>                       goto out;
>       }
>  
> -     ret = iomap_dio_rw(iocb, from, &ntfs_iomap_ops, NULL,
> +     ret = iomap_dio_rw(iocb, from, ntfs_iomap_next, NULL,
>                          IOMAP_DIO_FORCE_WAIT, NULL, 0);
>  
>       if (ret == -ENOTBLK) {
> @@ -1316,7 +1316,7 @@ static ssize_t ntfs_file_write_iter(struct kiocb *iocb, 
> struct iov_iter *from)
>               vbo = iocb->ki_pos;
>  
>               iocb->ki_flags &= ~IOCB_DIRECT;
> -             err = iomap_file_buffered_write(iocb, from, &ntfs_iomap_ops,
> +             err = iomap_file_buffered_write(iocb, from, ntfs_iomap_next,
>                                               &ntfs_iomap_folio_ops, NULL);
>               if (err < 0) {
>                       ret = err;
> @@ -1465,7 +1465,7 @@ int ntfs_fiemap(struct inode *inode, struct 
> fiemap_extent_info *fieinfo,
>  
>       inode_lock_shared(inode);
>  
> -     err = iomap_fiemap(inode, fieinfo, start, len, &ntfs_iomap_ops);
> +     err = iomap_fiemap(inode, fieinfo, start, len, ntfs_iomap_next);
>  
>       inode_unlock_shared(inode);
>       return err;
> diff --git a/fs/ntfs3/inode.c b/fs/ntfs3/inode.c
> index c5676c51a3a4..8a454ab6ee2a 100644
> --- a/fs/ntfs3/inode.c
> +++ b/fs/ntfs3/inode.c
> @@ -576,7 +576,7 @@ static sector_t ntfs_bmap(struct address_space *mapping, 
> sector_t block)
>               ni_allocate_da_blocks(ni);
>       }
>  
> -     return iomap_bmap(mapping, block, &ntfs_iomap_ops);
> +     return iomap_bmap(mapping, block, ntfs_iomap_next);
>  }
>  
>  static void ntfs_iomap_read_end_io(struct bio *bio)
> @@ -649,7 +649,7 @@ static int ntfs_read_folio(struct file *file, struct 
> folio *folio)
>               return err;
>       }
>  
> -     iomap_read_folio(&ntfs_iomap_ops, &ctx, NULL);
> +     iomap_read_folio(ntfs_iomap_next, &ctx, NULL);
>       return 0;
>  }
>  
> @@ -673,7 +673,7 @@ static void ntfs_readahead(struct readahead_control *rac)
>               return;
>       }
>  
> -     iomap_readahead(&ntfs_iomap_ops, &ctx, NULL);
> +     iomap_readahead(ntfs_iomap_next, &ctx, NULL);
>  }
>  
>  int ntfs_set_size(struct inode *inode, u64 new_size)
> @@ -2101,17 +2101,13 @@ const struct address_space_operations ntfs_aops_cmpr 
> = {
>       .invalidate_folio = iomap_invalidate_folio,
>  };
>  
> -static int ntfs_iomap_next(const struct iomap_iter *iter, struct iomap 
> *iomap,
> +int ntfs_iomap_next(const struct iomap_iter *iter, struct iomap *iomap,
>                          struct iomap *srcmap)
>  {
>       return iomap_process(iter, iomap, srcmap, ntfs_iomap_begin,
>                            ntfs_iomap_end);
>  }
>  
> -const struct iomap_ops ntfs_iomap_ops = {
> -     .iomap_next     = ntfs_iomap_next,
> -};
> -
>  const struct iomap_write_ops ntfs_iomap_folio_ops = {
>       .put_folio = ntfs_iomap_put_folio,
>  };
> diff --git a/fs/ntfs3/ntfs_fs.h b/fs/ntfs3/ntfs_fs.h
> index d98d7e474476..e00dae3ce700 100644
> --- a/fs/ntfs3/ntfs_fs.h
> +++ b/fs/ntfs3/ntfs_fs.h
> @@ -785,7 +785,8 @@ int ntfs_create_inode(struct mnt_idmap *idmap, struct 
> inode *dir,
>  int ntfs_link_inode(struct inode *inode, struct dentry *dentry);
>  int ntfs_unlink_inode(struct inode *dir, const struct dentry *dentry);
>  void ntfs_evict_inode(struct inode *inode);
> -extern const struct iomap_ops ntfs_iomap_ops;
> +int ntfs_iomap_next(const struct iomap_iter *iter, struct iomap *iomap,
> +                 struct iomap *srcmap);
>  extern const struct iomap_write_ops ntfs_iomap_folio_ops;
>  extern const struct inode_operations ntfs_link_inode_operations;
>  extern const struct address_space_operations ntfs_aops;
> diff --git a/fs/remap_range.c b/fs/remap_range.c
> index 26afbbbfb10c..3d0a355dc90e 100644
> --- a/fs/remap_range.c
> +++ b/fs/remap_range.c
> @@ -277,7 +277,7 @@ int
>  __generic_remap_file_range_prep(struct file *file_in, loff_t pos_in,
>                               struct file *file_out, loff_t pos_out,
>                               loff_t *len, unsigned int remap_flags,
> -                             const struct iomap_ops *dax_read_ops)
> +                             iomap_next_fn dax_read_next)
>  {
>       struct inode *inode_in = file_inode(file_in);
>       struct inode *inode_out = file_inode(file_out);
> @@ -340,10 +340,10 @@ __generic_remap_file_range_prep(struct file *file_in, 
> loff_t pos_in,
>               if (!IS_DAX(inode_in))
>                       ret = vfs_dedupe_file_range_compare(file_in, pos_in,
>                                       file_out, pos_out, *len, &is_same);
> -             else if (dax_read_ops)
> +             else if (dax_read_next)
>                       ret = dax_dedupe_file_range_compare(inode_in, pos_in,
>                                       inode_out, pos_out, *len, &is_same,
> -                                     dax_read_ops);
> +                                     dax_read_next);
>               else
>                       return -EINVAL;
>               if (ret)
> diff --git a/fs/xfs/xfs_aops.c b/fs/xfs/xfs_aops.c
> index 2a0c54256e93..91480cb6a4d8 100644
> --- a/fs/xfs/xfs_aops.c
> +++ b/fs/xfs/xfs_aops.c
> @@ -752,7 +752,7 @@ xfs_vm_bmap(
>        */
>       if (xfs_is_cow_inode(ip) || XFS_IS_REALTIME_INODE(ip))
>               return 0;
> -     return iomap_bmap(mapping, block, &xfs_read_iomap_ops);
> +     return iomap_bmap(mapping, block, xfs_read_iomap_next);
>  }
>  
>  static void
> @@ -793,7 +793,7 @@ xfs_vm_read_folio(
>       struct iomap_read_folio_ctx     ctx = { .cur_folio = folio };
>  
>       ctx.ops = xfs_get_iomap_read_ops(folio->mapping);
> -     iomap_read_folio(&xfs_read_iomap_ops, &ctx, NULL);
> +     iomap_read_folio(xfs_read_iomap_next, &ctx, NULL);
>       return 0;
>  }
>  
> @@ -804,7 +804,7 @@ xfs_vm_readahead(
>       struct iomap_read_folio_ctx     ctx = { .rac = rac };
>  
>       ctx.ops = xfs_get_iomap_read_ops(rac->mapping),
> -     iomap_readahead(&xfs_read_iomap_ops, &ctx, NULL);
> +     iomap_readahead(xfs_read_iomap_next, &ctx, NULL);
>  }
>  
>  static int
> @@ -850,7 +850,7 @@ xfs_vm_swap_activate(
>       sis->bdev = xfs_inode_buftarg(ip)->bt_bdev;
>  
>       return iomap_swapfile_activate(sis, swap_file, span,
> -                     &xfs_read_iomap_ops);
> +                     xfs_read_iomap_next);
>  }
>  
>  const struct address_space_operations xfs_address_space_operations = {
> diff --git a/fs/xfs/xfs_file.c b/fs/xfs/xfs_file.c
> index 7f8bef1a9954..a987ffbf3c02 100644
> --- a/fs/xfs/xfs_file.c
> +++ b/fs/xfs/xfs_file.c
> @@ -269,7 +269,7 @@ xfs_file_dio_read(
>               dio_ops = &xfs_dio_read_bounce_ops;
>               dio_flags |= IOMAP_DIO_BOUNCE;
>       }
> -     ret = iomap_dio_rw(iocb, to, &xfs_read_iomap_ops, dio_ops, dio_flags,
> +     ret = iomap_dio_rw(iocb, to, xfs_read_iomap_next, dio_ops, dio_flags,
>                       NULL, 0);
>       xfs_iunlock(ip, XFS_IOLOCK_SHARED);
>  
> @@ -292,7 +292,7 @@ xfs_file_dax_read(
>       ret = xfs_ilock_iocb(iocb, XFS_IOLOCK_SHARED);
>       if (ret)
>               return ret;
> -     ret = dax_iomap_rw(iocb, to, &xfs_read_iomap_ops);
> +     ret = dax_iomap_rw(iocb, to, xfs_read_iomap_next);
>       xfs_iunlock(ip, XFS_IOLOCK_SHARED);
>  
>       file_accessed(iocb->ki_filp);
> @@ -742,7 +742,7 @@ xfs_file_dio_write_aligned(
>       struct xfs_inode        *ip,
>       struct kiocb            *iocb,
>       struct iov_iter         *from,
> -     const struct iomap_ops  *ops,
> +     iomap_next_fn           iomap_next,
>       const struct iomap_dio_ops *dops,
>       struct xfs_zone_alloc_ctx *ac)
>  {
> @@ -777,7 +777,7 @@ xfs_file_dio_write_aligned(
>       if (mapping_stable_writes(iocb->ki_filp->f_mapping))
>               dio_flags |= IOMAP_DIO_BOUNCE;
>       trace_xfs_file_direct_write(iocb, from);
> -     ret = iomap_dio_rw(iocb, from, ops, dops, dio_flags, ac, 0);
> +     ret = iomap_dio_rw(iocb, from, iomap_next, dops, dio_flags, ac, 0);
>  out_unlock:
>       xfs_iunlock(ip, iolock);
>       return ret;
> @@ -799,7 +799,7 @@ xfs_file_dio_write_zoned(
>       if (ret < 0)
>               return ret;
>       ret = xfs_file_dio_write_aligned(ip, iocb, from,
> -                     &xfs_zoned_direct_write_iomap_ops,
> +                     xfs_zoned_direct_write_iomap_next,
>                       &xfs_dio_zoned_write_ops, &ac);
>       xfs_zoned_space_unreserve(ip->i_mount, &ac);
>       return ret;
> @@ -824,16 +824,16 @@ xfs_file_dio_write_atomic(
>       unsigned int            iolock = XFS_IOLOCK_SHARED;
>       ssize_t                 ret, ocount = iov_iter_count(from);
>       unsigned int            dio_flags = 0;
> -     const struct iomap_ops  *dops;
> +     iomap_next_fn           dops;
>  
>       /*
>        * HW offload should be faster, so try that first if it is already
>        * known that the write length is not too large.
>        */
>       if (ocount > xfs_inode_buftarg(ip)->bt_awu_max)
> -             dops = &xfs_atomic_write_cow_iomap_ops;
> +             dops = xfs_atomic_write_cow_iomap_next;
>       else
> -             dops = &xfs_direct_write_iomap_ops;
> +             dops = xfs_direct_write_iomap_next;
>  
>  retry:
>       ret = xfs_ilock_iocb_for_write(iocb, &iolock);
> @@ -862,9 +862,9 @@ xfs_file_dio_write_atomic(
>        * possible. The REQ_ATOMIC-based method is typically not possible if
>        * the write spans multiple extents or the disk blocks are misaligned.
>        */
> -     if (ret == -ENOPROTOOPT && dops == &xfs_direct_write_iomap_ops) {
> +     if (ret == -ENOPROTOOPT && dops == xfs_direct_write_iomap_next) {
>               xfs_iunlock(ip, iolock);
> -             dops = &xfs_atomic_write_cow_iomap_ops;
> +             dops = xfs_atomic_write_cow_iomap_next;
>               goto retry;
>       }
>  
> @@ -947,7 +947,7 @@ xfs_file_dio_write_unaligned(
>               flags |= IOMAP_DIO_BOUNCE;
>  
>       trace_xfs_file_direct_write(iocb, from);
> -     ret = iomap_dio_rw(iocb, from, &xfs_direct_write_iomap_ops,
> +     ret = iomap_dio_rw(iocb, from, xfs_direct_write_iomap_next,
>                          &xfs_dio_write_ops, flags, NULL, 0);
>  
>       /*
> @@ -987,7 +987,7 @@ xfs_file_dio_write(
>       if (iocb->ki_flags & IOCB_ATOMIC)
>               return xfs_file_dio_write_atomic(ip, iocb, from);
>       return xfs_file_dio_write_aligned(ip, iocb, from,
> -                     &xfs_direct_write_iomap_ops, &xfs_dio_write_ops, NULL);
> +                     xfs_direct_write_iomap_next, &xfs_dio_write_ops, NULL);
>  }
>  
>  static noinline ssize_t
> @@ -1011,7 +1011,7 @@ xfs_file_dax_write(
>       pos = iocb->ki_pos;
>  
>       trace_xfs_file_dax_write(iocb, from);
> -     ret = dax_iomap_rw(iocb, from, &xfs_dax_write_iomap_ops);
> +     ret = dax_iomap_rw(iocb, from, xfs_dax_write_iomap_next);
>       if (ret > 0 && iocb->ki_pos > i_size_read(inode)) {
>               i_size_write(inode, iocb->ki_pos);
>               error = xfs_setfilesize(ip, pos, ret);
> @@ -1054,7 +1054,7 @@ xfs_file_buffered_write(
>  
>       trace_xfs_file_buffered_write(iocb, from);
>       ret = iomap_file_buffered_write(iocb, from,
> -                     &xfs_buffered_write_iomap_ops, &xfs_iomap_write_ops,
> +                     xfs_buffered_write_iomap_next, &xfs_iomap_write_ops,
>                       NULL);
>  
>       /*
> @@ -1135,7 +1135,7 @@ xfs_file_buffered_write_zoned(
>  retry:
>       trace_xfs_file_buffered_write(iocb, from);
>       ret = iomap_file_buffered_write(iocb, from,
> -                     &xfs_buffered_write_iomap_ops, &xfs_iomap_write_ops,
> +                     xfs_buffered_write_iomap_next, &xfs_iomap_write_ops,
>                       &ac);
>       if (ret == -ENOSPC && !cleared_space) {
>               /*
> @@ -1856,10 +1856,10 @@ xfs_file_llseek(
>       default:
>               return generic_file_llseek(file, offset, whence);
>       case SEEK_HOLE:
> -             offset = iomap_seek_hole(inode, offset, &xfs_seek_iomap_ops);
> +             offset = iomap_seek_hole(inode, offset, xfs_seek_iomap_next);
>               break;
>       case SEEK_DATA:
> -             offset = iomap_seek_data(inode, offset, &xfs_seek_iomap_ops);
> +             offset = iomap_seek_data(inode, offset, xfs_seek_iomap_next);
>               break;
>       }
>  
> @@ -1883,8 +1883,8 @@ xfs_dax_fault_locked(
>       }
>       ret = dax_iomap_fault(vmf, order, &pfn, NULL,
>                       (write_fault && !vmf->cow_page) ?
> -                             &xfs_dax_write_iomap_ops :
> -                             &xfs_read_iomap_ops);
> +                             xfs_dax_write_iomap_next :
> +                             xfs_read_iomap_next);
>       if (ret & VM_FAULT_NEEDDSYNC)
>               ret = dax_finish_sync_fault(vmf, order, pfn);
>       return ret;
> @@ -1948,7 +1948,7 @@ __xfs_write_fault(
>       if (IS_DAX(inode))
>               ret = xfs_dax_fault_locked(vmf, order, true);
>       else
> -             ret = iomap_page_mkwrite(vmf, &xfs_buffered_write_iomap_ops,
> +             ret = iomap_page_mkwrite(vmf, xfs_buffered_write_iomap_next,
>                               ac);
>       xfs_iunlock(ip, lock_mode);
>  
> diff --git a/fs/xfs/xfs_iomap.c b/fs/xfs/xfs_iomap.c
> index 4fa1a5c985db..71c4bb024f04 100644
> --- a/fs/xfs/xfs_iomap.c
> +++ b/fs/xfs/xfs_iomap.c
> @@ -1037,7 +1037,7 @@ xfs_direct_write_iomap_begin(
>       return error;
>  }
>  
> -static int
> +int
>  xfs_direct_write_iomap_next(
>       const struct iomap_iter *iter,
>       struct iomap            *iomap,
> @@ -1047,10 +1047,6 @@ xfs_direct_write_iomap_next(
>                       NULL);
>  }
>  
> -const struct iomap_ops xfs_direct_write_iomap_ops = {
> -     .iomap_next             = xfs_direct_write_iomap_next,
> -};
> -
>  #ifdef CONFIG_XFS_RT
>  /*
>   * This is really simple.  The space has already been reserved before taking 
> the
> @@ -1099,7 +1095,7 @@ xfs_zoned_direct_write_iomap_begin(
>       return 0;
>  }
>  
> -static int
> +int
>  xfs_zoned_direct_write_iomap_next(
>       const struct iomap_iter *iter,
>       struct iomap            *iomap,
> @@ -1109,9 +1105,6 @@ xfs_zoned_direct_write_iomap_next(
>                       xfs_zoned_direct_write_iomap_begin, NULL);
>  }
>  
> -const struct iomap_ops xfs_zoned_direct_write_iomap_ops = {
> -     .iomap_next             = xfs_zoned_direct_write_iomap_next,
> -};
>  #endif /* CONFIG_XFS_RT */
>  
>  #ifdef DEBUG
> @@ -1294,7 +1287,7 @@ xfs_atomic_write_cow_iomap_begin(
>       return error;
>  }
>  
> -static int
> +int
>  xfs_atomic_write_cow_iomap_next(
>       const struct iomap_iter *iter,
>       struct iomap            *iomap,
> @@ -1304,10 +1297,6 @@ xfs_atomic_write_cow_iomap_next(
>                       xfs_atomic_write_cow_iomap_begin, NULL);
>  }
>  
> -const struct iomap_ops xfs_atomic_write_cow_iomap_ops = {
> -     .iomap_next             = xfs_atomic_write_cow_iomap_next,
> -};
> -
>  static int
>  xfs_dax_write_iomap_end(
>       struct inode            *inode,
> @@ -1328,7 +1317,7 @@ xfs_dax_write_iomap_end(
>       return xfs_reflink_end_cow(ip, pos, written);
>  }
>  
> -static int
> +int
>  xfs_dax_write_iomap_next(
>       const struct iomap_iter *iter,
>       struct iomap            *iomap,
> @@ -1338,10 +1327,6 @@ xfs_dax_write_iomap_next(
>                       xfs_dax_write_iomap_end);
>  }
>  
> -const struct iomap_ops xfs_dax_write_iomap_ops = {
> -     .iomap_next     = xfs_dax_write_iomap_next,
> -};
> -
>  /*
>   * Convert a hole to a delayed allocation.
>   */
> @@ -2207,7 +2192,7 @@ xfs_buffered_write_iomap_end(
>       return 0;
>  }
>  
> -static int
> +int
>  xfs_buffered_write_iomap_next(
>       const struct iomap_iter *iter,
>       struct iomap            *iomap,
> @@ -2218,10 +2203,6 @@ xfs_buffered_write_iomap_next(
>                       xfs_buffered_write_iomap_end);
>  }
>  
> -const struct iomap_ops xfs_buffered_write_iomap_ops = {
> -     .iomap_next             = xfs_buffered_write_iomap_next,
> -};
> -
>  static int
>  xfs_read_iomap_begin(
>       struct inode            *inode,
> @@ -2263,7 +2244,7 @@ xfs_read_iomap_begin(
>                                shared ? IOMAP_F_SHARED : 0, seq);
>  }
>  
> -static int
> +int
>  xfs_read_iomap_next(
>       const struct iomap_iter *iter,
>       struct iomap            *iomap,
> @@ -2272,10 +2253,6 @@ xfs_read_iomap_next(
>       return iomap_process(iter, iomap, srcmap, xfs_read_iomap_begin, NULL);
>  }
>  
> -const struct iomap_ops xfs_read_iomap_ops = {
> -     .iomap_next             = xfs_read_iomap_next,
> -};
> -
>  static int
>  xfs_seek_iomap_begin(
>       struct inode            *inode,
> @@ -2360,7 +2337,7 @@ xfs_seek_iomap_begin(
>       return error;
>  }
>  
> -static int
> +int
>  xfs_seek_iomap_next(
>       const struct iomap_iter *iter,
>       struct iomap            *iomap,
> @@ -2369,10 +2346,6 @@ xfs_seek_iomap_next(
>       return iomap_process(iter, iomap, srcmap, xfs_seek_iomap_begin, NULL);
>  }
>  
> -const struct iomap_ops xfs_seek_iomap_ops = {
> -     .iomap_next             = xfs_seek_iomap_next,
> -};
> -
>  static int
>  xfs_xattr_iomap_begin(
>       struct inode            *inode,
> @@ -2416,7 +2389,7 @@ xfs_xattr_iomap_begin(
>       return xfs_bmbt_to_iomap(ip, iomap, &imap, flags, IOMAP_F_XATTR, seq);
>  }
>  
> -static int
> +int
>  xfs_xattr_iomap_next(
>       const struct iomap_iter *iter,
>       struct iomap            *iomap,
> @@ -2425,10 +2398,6 @@ xfs_xattr_iomap_next(
>       return iomap_process(iter, iomap, srcmap, xfs_xattr_iomap_begin, NULL);
>  }
>  
> -const struct iomap_ops xfs_xattr_iomap_ops = {
> -     .iomap_next             = xfs_xattr_iomap_next,
> -};
> -
>  int
>  xfs_zero_range(
>       struct xfs_inode        *ip,
> @@ -2443,9 +2412,9 @@ xfs_zero_range(
>  
>       if (IS_DAX(inode))
>               return dax_zero_range(inode, pos, len, did_zero,
> -                                   &xfs_dax_write_iomap_ops);
> +                                   xfs_dax_write_iomap_next);
>       return iomap_zero_range(inode, pos, len, did_zero,
> -                     &xfs_buffered_write_iomap_ops, &xfs_iomap_write_ops,
> +                     xfs_buffered_write_iomap_next, &xfs_iomap_write_ops,
>                       ac);
>  }
>  
> @@ -2460,8 +2429,8 @@ xfs_truncate_page(
>  
>       if (IS_DAX(inode))
>               return dax_truncate_page(inode, pos, did_zero,
> -                                     &xfs_dax_write_iomap_ops);
> +                                     xfs_dax_write_iomap_next);
>       return iomap_truncate_page(inode, pos, did_zero,
> -                     &xfs_buffered_write_iomap_ops, &xfs_iomap_write_ops,
> +                     xfs_buffered_write_iomap_next, &xfs_iomap_write_ops,
>                       ac);
>  }
> diff --git a/fs/xfs/xfs_iomap.h b/fs/xfs/xfs_iomap.h
> index ebcce7d49446..01875d20fb66 100644
> --- a/fs/xfs/xfs_iomap.h
> +++ b/fs/xfs/xfs_iomap.h
> @@ -49,14 +49,22 @@ xfs_aligned_fsb_count(
>       return count_fsb;
>  }
>  
> -extern const struct iomap_ops xfs_buffered_write_iomap_ops;
> -extern const struct iomap_ops xfs_direct_write_iomap_ops;
> -extern const struct iomap_ops xfs_zoned_direct_write_iomap_ops;
> -extern const struct iomap_ops xfs_read_iomap_ops;
> -extern const struct iomap_ops xfs_seek_iomap_ops;
> -extern const struct iomap_ops xfs_xattr_iomap_ops;
> -extern const struct iomap_ops xfs_dax_write_iomap_ops;
> -extern const struct iomap_ops xfs_atomic_write_cow_iomap_ops;
> +int xfs_buffered_write_iomap_next(const struct iomap_iter *iter,
> +             struct iomap *iomap, struct iomap *srcmap);
> +int xfs_direct_write_iomap_next(const struct iomap_iter *iter,
> +             struct iomap *iomap, struct iomap *srcmap);
> +int xfs_zoned_direct_write_iomap_next(const struct iomap_iter *iter,
> +             struct iomap *iomap, struct iomap *srcmap);
> +int xfs_read_iomap_next(const struct iomap_iter *iter, struct iomap *iomap,
> +             struct iomap *srcmap);
> +int xfs_seek_iomap_next(const struct iomap_iter *iter, struct iomap *iomap,
> +             struct iomap *srcmap);
> +int xfs_xattr_iomap_next(const struct iomap_iter *iter, struct iomap *iomap,
> +             struct iomap *srcmap);
> +int xfs_dax_write_iomap_next(const struct iomap_iter *iter, struct iomap 
> *iomap,
> +             struct iomap *srcmap);
> +int xfs_atomic_write_cow_iomap_next(const struct iomap_iter *iter,
> +             struct iomap *iomap, struct iomap *srcmap);
>  extern const struct iomap_write_ops xfs_iomap_write_ops;
>  
>  #endif /* __XFS_IOMAP_H__*/
> diff --git a/fs/xfs/xfs_iops.c b/fs/xfs/xfs_iops.c
> index 6339f4956ecb..5c3d9a365f93 100644
> --- a/fs/xfs/xfs_iops.c
> +++ b/fs/xfs/xfs_iops.c
> @@ -1239,10 +1239,10 @@ xfs_vn_fiemap(
>       if (fieinfo->fi_flags & FIEMAP_FLAG_XATTR) {
>               fieinfo->fi_flags &= ~FIEMAP_FLAG_XATTR;
>               error = iomap_fiemap(inode, fieinfo, start, length,
> -                             &xfs_xattr_iomap_ops);
> +                             xfs_xattr_iomap_next);
>       } else {
>               error = iomap_fiemap(inode, fieinfo, start, length,
> -                             &xfs_read_iomap_ops);
> +                             xfs_read_iomap_next);
>       }
>       xfs_iunlock(XFS_I(inode), XFS_IOLOCK_SHARED);
>  
> diff --git a/fs/xfs/xfs_reflink.c b/fs/xfs/xfs_reflink.c
> index a5c188b78138..2b9792626bab 100644
> --- a/fs/xfs/xfs_reflink.c
> +++ b/fs/xfs/xfs_reflink.c
> @@ -1683,7 +1683,7 @@ xfs_reflink_remap_prep(
>                               pos_out, len, remap_flags);
>       else
>               ret = dax_remap_file_range_prep(file_in, pos_in, file_out,
> -                             pos_out, len, remap_flags, &xfs_read_iomap_ops);
> +                             pos_out, len, remap_flags, xfs_read_iomap_next);
>       if (ret || *len == 0)
>               goto out_unlock;
>  
> @@ -1878,10 +1878,10 @@ xfs_reflink_unshare(
>  
>       if (IS_DAX(inode))
>               error = dax_file_unshare(inode, offset, len,
> -                             &xfs_dax_write_iomap_ops);
> +                             xfs_dax_write_iomap_next);
>       else
>               error = iomap_file_unshare(inode, offset, len,
> -                             &xfs_buffered_write_iomap_ops,
> +                             xfs_buffered_write_iomap_next,
>                               &xfs_iomap_write_ops);
>       if (error)
>               goto out;
> diff --git a/fs/zonefs/file.c b/fs/zonefs/file.c
> index a29a8756d660..3ef1a655dbfe 100644
> --- a/fs/zonefs/file.c
> +++ b/fs/zonefs/file.c
> @@ -64,10 +64,6 @@ static int zonefs_read_iomap_next(const struct iomap_iter 
> *iter,
>                            NULL);
>  }
>  
> -static const struct iomap_ops zonefs_read_iomap_ops = {
> -     .iomap_next     = zonefs_read_iomap_next,
> -};
> -
>  static int zonefs_write_iomap_begin(struct inode *inode, loff_t offset,
>                                   loff_t length, unsigned int flags,
>                                   struct iomap *iomap, struct iomap *srcmap)
> @@ -120,19 +116,15 @@ static int zonefs_write_iomap_next(const struct 
> iomap_iter *iter,
>                            NULL);
>  }
>  
> -static const struct iomap_ops zonefs_write_iomap_ops = {
> -     .iomap_next     = zonefs_write_iomap_next,
> -};
> -
>  static int zonefs_read_folio(struct file *unused, struct folio *folio)
>  {
> -     iomap_bio_read_folio(folio, &zonefs_read_iomap_ops);
> +     iomap_bio_read_folio(folio, zonefs_read_iomap_next);
>       return 0;
>  }
>  
>  static void zonefs_readahead(struct readahead_control *rac)
>  {
> -     iomap_bio_readahead(rac, &zonefs_read_iomap_ops);
> +     iomap_bio_readahead(rac, zonefs_read_iomap_next);
>  }
>  
>  /*
> @@ -193,7 +185,7 @@ static int zonefs_swap_activate(struct swap_info_struct 
> *sis,
>       }
>  
>       return iomap_swapfile_activate(sis, swap_file, span,
> -                                    &zonefs_read_iomap_ops);
> +                                    zonefs_read_iomap_next);
>  }
>  
>  const struct address_space_operations zonefs_file_aops = {
> @@ -323,7 +315,7 @@ static vm_fault_t zonefs_filemap_page_mkwrite(struct 
> vm_fault *vmf)
>  
>       /* Serialize against truncates */
>       filemap_invalidate_lock_shared(inode->i_mapping);
> -     ret = iomap_page_mkwrite(vmf, &zonefs_write_iomap_ops, NULL);
> +     ret = iomap_page_mkwrite(vmf, zonefs_write_iomap_next, NULL);
>       filemap_invalidate_unlock_shared(inode->i_mapping);
>  
>       sb_end_pagefault(inode->i_sb);
> @@ -539,7 +531,7 @@ static ssize_t zonefs_file_dio_write(struct kiocb *iocb, 
> struct iov_iter *from)
>        * page invalidation. Overwrite that error code with EBUSY so that
>        * the user can make sense of the error.
>        */
> -     ret = iomap_dio_rw(iocb, from, &zonefs_write_iomap_ops,
> +     ret = iomap_dio_rw(iocb, from, zonefs_write_iomap_next,
>                          &zonefs_write_dio_ops, 0, NULL, 0);
>       if (ret == -ENOTBLK)
>               ret = -EBUSY;
> @@ -589,7 +581,7 @@ static ssize_t zonefs_file_buffered_write(struct kiocb 
> *iocb,
>       if (ret <= 0)
>               goto inode_unlock;
>  
> -     ret = iomap_file_buffered_write(iocb, from, &zonefs_write_iomap_ops,
> +     ret = iomap_file_buffered_write(iocb, from, zonefs_write_iomap_next,
>                       NULL, NULL);
>       if (ret == -EIO)
>               zonefs_io_error(inode, true);
> @@ -684,7 +676,7 @@ static ssize_t zonefs_file_read_iter(struct kiocb *iocb, 
> struct iov_iter *to)
>                       goto inode_unlock;
>               }
>               file_accessed(iocb->ki_filp);
> -             ret = iomap_dio_rw(iocb, to, &zonefs_read_iomap_ops,
> +             ret = iomap_dio_rw(iocb, to, zonefs_read_iomap_next,
>                                  &zonefs_read_dio_ops, 0, NULL, 0);
>       } else {
>               ret = generic_file_read_iter(iocb, to);
> diff --git a/include/linux/dax.h b/include/linux/dax.h
> index fe6c3ded1b50..a5a88f5186bf 100644
> --- a/include/linux/dax.h
> +++ b/include/linux/dax.h
> @@ -3,6 +3,7 @@
>  #define _LINUX_DAX_H
>  
>  #include <linux/fs.h>
> +#include <linux/iomap.h>
>  #include <linux/mm.h>
>  #include <linux/radix-tree.h>
>  
> @@ -10,9 +11,6 @@ typedef unsigned long dax_entry_t;
>  
>  struct dax_device;
>  struct gendisk;
> -struct iomap_ops;
> -struct iomap_iter;
> -struct iomap;
>  
>  enum dax_access_mode {
>       DAX_ACCESS,
> @@ -213,11 +211,11 @@ static inline void dax_unlock_mapping_entry(struct 
> address_space *mapping,
>  #endif
>  
>  int dax_file_unshare(struct inode *inode, loff_t pos, loff_t len,
> -             const struct iomap_ops *ops);
> +             iomap_next_fn iomap_next);
>  int dax_zero_range(struct inode *inode, loff_t pos, loff_t len, bool 
> *did_zero,
> -             const struct iomap_ops *ops);
> +             iomap_next_fn iomap_next);
>  int dax_truncate_page(struct inode *inode, loff_t pos, bool *did_zero,
> -             const struct iomap_ops *ops);
> +             iomap_next_fn iomap_next);
>  
>  static inline bool dax_page_is_idle(struct page *page)
>  {
> @@ -266,10 +264,10 @@ int dax_holder_notify_failure(struct dax_device 
> *dax_dev, u64 off, u64 len,
>  void dax_flush(struct dax_device *dax_dev, void *addr, size_t size);
>  
>  ssize_t dax_iomap_rw(struct kiocb *iocb, struct iov_iter *iter,
> -             const struct iomap_ops *ops);
> +             iomap_next_fn iomap_next);
>  vm_fault_t dax_iomap_fault(struct vm_fault *vmf, unsigned int order,
>                       unsigned long *pfnp, int *errp,
> -                     const struct iomap_ops *ops);
> +                     iomap_next_fn iomap_next);
>  vm_fault_t dax_finish_sync_fault(struct vm_fault *vmf,
>               unsigned int order, unsigned long pfn);
>  int dax_delete_mapping_entry(struct address_space *mapping, pgoff_t index);
> @@ -288,11 +286,11 @@ void dax_break_layout_final(struct inode *inode);
>  int dax_dedupe_file_range_compare(struct inode *src, loff_t srcoff,
>                                 struct inode *dest, loff_t destoff,
>                                 loff_t len, bool *is_same,
> -                               const struct iomap_ops *ops);
> +                               iomap_next_fn iomap_next);
>  int dax_remap_file_range_prep(struct file *file_in, loff_t pos_in,
>                             struct file *file_out, loff_t pos_out,
>                             loff_t *len, unsigned int remap_flags,
> -                           const struct iomap_ops *ops);
> +                           iomap_next_fn iomap_next);
>  static inline bool dax_mapping(struct address_space *mapping)
>  {
>       return mapping->host && IS_DAX(mapping->host);
> diff --git a/include/linux/fs.h b/include/linux/fs.h
> index d10897b3a1e3..2eb063438a3b 100644
> --- a/include/linux/fs.h
> +++ b/include/linux/fs.h
> @@ -70,7 +70,8 @@ struct fsnotify_mark_connector;
>  struct fs_context;
>  struct fs_parameter_spec;
>  struct file_kattr;
> -struct iomap_ops;
> +struct iomap_iter;
> +struct iomap;
>  struct delegated_inode;
>  
>  extern void __init inode_init(void);
> @@ -2079,7 +2080,9 @@ int remap_verify_area(struct file *file, loff_t pos, 
> loff_t len, bool write);
>  int __generic_remap_file_range_prep(struct file *file_in, loff_t pos_in,
>                                   struct file *file_out, loff_t pos_out,
>                                   loff_t *len, unsigned int remap_flags,
> -                                 const struct iomap_ops *dax_read_ops);
> +                                 int (*dax_read_next)(const struct 
> iomap_iter *iter,
> +                                                      struct iomap *iomap,
> +                                                      struct iomap *srcmap));
>  int generic_remap_file_range_prep(struct file *file_in, loff_t pos_in,
>                                 struct file *file_out, loff_t pos_out,
>                                 loff_t *count, unsigned int remap_flags);
> diff --git a/include/linux/iomap.h b/include/linux/iomap.h
> index 52d6f585b941..3b41f123a92d 100644
> --- a/include/linux/iomap.h
> +++ b/include/linux/iomap.h
> @@ -237,12 +237,6 @@ typedef int (*iomap_end_fn)(struct inode *inode, loff_t 
> pos, loff_t length,
>  typedef int (*iomap_next_fn)(const struct iomap_iter *iter, struct iomap 
> *iomap,
>               struct iomap *srcmap);
>  
> -struct iomap_ops {
> -     iomap_begin_fn iomap_begin;
> -     iomap_end_fn iomap_end;
> -     iomap_next_fn iomap_next;
> -};
> -
>  /**
>   * struct iomap_iter - Iterate through a range of a file
>   * @inode: Set at the start of the iteration and should not change.
> @@ -271,7 +265,7 @@ struct iomap_iter {
>       void *private;
>  };
>  
> -int iomap_iter(struct iomap_iter *iter, const struct iomap_ops *ops);
> +int iomap_iter(struct iomap_iter *iter, iomap_next_fn iomap_next);
>  int iomap_iter_advance(struct iomap_iter *iter, u64 count);
>  
>  /**
> @@ -365,14 +359,14 @@ static inline bool iomap_want_unshare_iter(const struct 
> iomap_iter *iter)
>  }
>  
>  ssize_t iomap_file_buffered_write(struct kiocb *iocb, struct iov_iter *from,
> -             const struct iomap_ops *ops,
> +             iomap_next_fn iomap_next,
>               const struct iomap_write_ops *write_ops, void *private);
>  int iomap_fsverity_write(struct file *file, loff_t pos, size_t length,
> -             const void *buf, const struct iomap_ops *ops,
> +             const void *buf, iomap_next_fn iomap_next,
>               const struct iomap_write_ops *write_ops);
> -void iomap_read_folio(const struct iomap_ops *ops,
> +void iomap_read_folio(iomap_next_fn iomap_next,
>               struct iomap_read_folio_ctx *ctx, void *private);
> -void iomap_readahead(const struct iomap_ops *ops,
> +void iomap_readahead(iomap_next_fn iomap_next,
>               struct iomap_read_folio_ctx *ctx, void *private);
>  bool iomap_is_partially_uptodate(struct folio *, size_t from, size_t count);
>  struct folio *iomap_get_folio(struct iomap_iter *iter, loff_t pos, size_t 
> len);
> @@ -380,17 +374,17 @@ bool iomap_release_folio(struct folio *folio, gfp_t 
> gfp_flags);
>  void iomap_invalidate_folio(struct folio *folio, size_t offset, size_t len);
>  bool iomap_dirty_folio(struct address_space *mapping, struct folio *folio);
>  int iomap_file_unshare(struct inode *inode, loff_t pos, loff_t len,
> -             const struct iomap_ops *ops,
> +             iomap_next_fn iomap_next,
>               const struct iomap_write_ops *write_ops);
>  unsigned int iomap_fill_dirty_folios(struct iomap_iter *iter, loff_t *start,
>               loff_t end, unsigned int *iomap_flags);
>  int iomap_zero_range(struct inode *inode, loff_t pos, loff_t len,
> -             bool *did_zero, const struct iomap_ops *ops,
> +             bool *did_zero, iomap_next_fn iomap_next,
>               const struct iomap_write_ops *write_ops, void *private);
>  int iomap_truncate_page(struct inode *inode, loff_t pos, bool *did_zero,
> -             const struct iomap_ops *ops,
> +             iomap_next_fn iomap_next,
>               const struct iomap_write_ops *write_ops, void *private);
> -vm_fault_t iomap_page_mkwrite(struct vm_fault *vmf, const struct iomap_ops 
> *ops,
> +vm_fault_t iomap_page_mkwrite(struct vm_fault *vmf, iomap_next_fn iomap_next,
>               void *private);
>  typedef void (*iomap_punch_t)(struct inode *inode, loff_t offset, loff_t 
> length,
>               struct iomap *iomap);
> @@ -399,13 +393,13 @@ void iomap_write_delalloc_release(struct inode *inode, 
> loff_t start_byte,
>               iomap_punch_t punch);
>  
>  int iomap_fiemap(struct inode *inode, struct fiemap_extent_info *fieinfo,
> -             u64 start, u64 len, const struct iomap_ops *ops);
> +             u64 start, u64 len, iomap_next_fn iomap_next);
>  loff_t iomap_seek_hole(struct inode *inode, loff_t offset,
> -             const struct iomap_ops *ops);
> +             iomap_next_fn iomap_next);
>  loff_t iomap_seek_data(struct inode *inode, loff_t offset,
> -             const struct iomap_ops *ops);
> +             iomap_next_fn iomap_next);
>  sector_t iomap_bmap(struct address_space *mapping, sector_t bno,
> -             const struct iomap_ops *ops);
> +             iomap_next_fn iomap_next);
>  
>  /*
>   * Flags for iomap_ioend->io_flags.
> @@ -612,10 +606,10 @@ struct iomap_dio_ops {
>  #define IOMAP_DIO_BOUNCE             (1 << 4)
>  
>  ssize_t iomap_dio_rw(struct kiocb *iocb, struct iov_iter *iter,
> -             const struct iomap_ops *ops, const struct iomap_dio_ops *dops,
> +             iomap_next_fn iomap_next, const struct iomap_dio_ops *dops,
>               unsigned int dio_flags, void *private, size_t done_before);
>  struct iomap_dio *__iomap_dio_rw(struct kiocb *iocb, struct iov_iter *iter,
> -             const struct iomap_ops *ops, const struct iomap_dio_ops *dops,
> +             iomap_next_fn iomap_next, const struct iomap_dio_ops *dops,
>               unsigned int dio_flags, void *private, size_t done_before);
>  ssize_t iomap_dio_complete(struct iomap_dio *dio);
>  void iomap_dio_bio_end_io(struct bio *bio);
> @@ -626,7 +620,7 @@ struct swap_info_struct;
>  
>  int iomap_swapfile_activate(struct swap_info_struct *sis,
>               struct file *swap_file, sector_t *pagespan,
> -             const struct iomap_ops *ops);
> +             iomap_next_fn iomap_next);
>  #else
>  # define iomap_swapfile_activate(sis, swapfile, pagespan, ops)       (-EIO)
>  #endif /* CONFIG_SWAP */
> @@ -640,25 +634,25 @@ int iomap_bio_read_folio_range(const struct iomap_iter 
> *iter,
>  extern const struct iomap_read_ops iomap_bio_read_ops;
>  
>  static inline void iomap_bio_read_folio(struct folio *folio,
> -             const struct iomap_ops *ops)
> +             iomap_next_fn iomap_next)
>  {
>       struct iomap_read_folio_ctx ctx = {
>               .ops            = &iomap_bio_read_ops,
>               .cur_folio      = folio,
>       };
>  
> -     iomap_read_folio(ops, &ctx, NULL);
> +     iomap_read_folio(iomap_next, &ctx, NULL);
>  }
>  
>  static inline void iomap_bio_readahead(struct readahead_control *rac,
> -             const struct iomap_ops *ops)
> +             iomap_next_fn iomap_next)
>  {
>       struct iomap_read_folio_ctx ctx = {
>               .ops            = &iomap_bio_read_ops,
>               .rac            = rac,
>       };
>  
> -     iomap_readahead(ops, &ctx, NULL);
> +     iomap_readahead(iomap_next, &ctx, NULL);
>  }
>  #endif /* CONFIG_BLOCK */
>  
> -- 
> 2.52.0
> 
-- 
Jan Kara <[email protected]>
SUSE Labs, CR

Reply via email to