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]>
---
 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


Reply via email to