iomap: pass private data to iomap_zero_range
authorChristoph Hellwig <hch@lst.de>
Thu, 6 Feb 2025 06:40:08 +0000 (07:40 +0100)
committerChristian Brauner <brauner@kernel.org>
Thu, 6 Feb 2025 12:02:15 +0000 (13:02 +0100)
Allow the file system to pass private data which can be used by the
iomap_begin and iomap_end methods through the private pointer in the
iomap_iter structure.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Link: https://lore.kernel.org/r/20250206064035.2323428-11-hch@lst.de
Reviewed-by: "Darrick J. Wong" <djwong@kernel.org>
Signed-off-by: Christian Brauner <brauner@kernel.org>
fs/gfs2/bmap.c
fs/iomap/buffered-io.c
fs/xfs/xfs_iomap.c
include/linux/iomap.h

index 1795c4e8dbf66ac947405b8e019e1db5255b928e..366516b98b3f31c822639e49e18241980c2a1e5b 100644 (file)
@@ -1300,7 +1300,8 @@ static int gfs2_block_zero_range(struct inode *inode, loff_t from,
                                 unsigned int length)
 {
        BUG_ON(current->journal_info);
-       return iomap_zero_range(inode, from, length, NULL, &gfs2_iomap_ops);
+       return iomap_zero_range(inode, from, length, NULL, &gfs2_iomap_ops,
+                       NULL);
 }
 
 #define GFS2_JTRUNC_REVOKES 8192
index 8c24d8611edf368ebd43e1bee39d5f65f55696ba..382647fda1d106b0530be4166b5b3a1373fbbca7 100644 (file)
@@ -1391,13 +1391,14 @@ static loff_t iomap_zero_iter(struct iomap_iter *iter, bool *did_zero)
 
 int
 iomap_zero_range(struct inode *inode, loff_t pos, loff_t len, bool *did_zero,
-               const struct iomap_ops *ops)
+               const struct iomap_ops *ops, void *private)
 {
        struct iomap_iter iter = {
                .inode          = inode,
                .pos            = pos,
                .len            = len,
                .flags          = IOMAP_ZERO,
+               .private        = private,
        };
        struct address_space *mapping = inode->i_mapping;
        unsigned int blocksize = i_blocksize(inode);
@@ -1465,7 +1466,8 @@ 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, ops,
+                       NULL);
 }
 EXPORT_SYMBOL_GPL(iomap_truncate_page);
 
index 50fa3ef89f6c9841debe9088db4be13b4682ea2d..3410c55f544a82fae3d7667ae60e9dcfa79d8015 100644 (file)
@@ -1497,7 +1497,7 @@ xfs_zero_range(
                return dax_zero_range(inode, pos, len, did_zero,
                                      &xfs_dax_write_iomap_ops);
        return iomap_zero_range(inode, pos, len, did_zero,
-                               &xfs_buffered_write_iomap_ops);
+                               &xfs_buffered_write_iomap_ops, NULL);
 }
 
 int
index d528eb4d5cfe10c12e9a6c21424c334388436559..eddf524ac749834878ac28f426ee050a5b033fc7 100644 (file)
@@ -313,7 +313,7 @@ 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);
 int iomap_zero_range(struct inode *inode, loff_t pos, loff_t len,
-               bool *did_zero, const struct iomap_ops *ops);
+               bool *did_zero, const struct iomap_ops *ops, void *private);
 int iomap_truncate_page(struct inode *inode, loff_t pos, bool *did_zero,
                const struct iomap_ops *ops);
 vm_fault_t iomap_page_mkwrite(struct vm_fault *vmf, const struct iomap_ops *ops,