]> www.infradead.org Git - linux.git/commitdiff
xfs: use xfs_direct_write_iomap_ops for DAX zeroing
authorChristoph Hellwig <hch@lst.de>
Mon, 29 Nov 2021 10:21:56 +0000 (11:21 +0100)
committerDan Williams <dan.j.williams@intel.com>
Sat, 4 Dec 2021 16:58:53 +0000 (08:58 -0800)
While the buffered write iomap ops do work due to the fact that zeroing
never allocates blocks, the DAX zeroing should use the direct ops just
like actual DAX I/O.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Dan Williams <dan.j.williams@intel.com>
Reviewed-by: Darrick J. Wong <djwong@kernel.org>
Link: https://lore.kernel.org/r/20211129102203.2243509-23-hch@lst.de
Signed-off-by: Dan Williams <dan.j.williams@intel.com>
fs/xfs/xfs_iomap.c

index 6a0c3b307bd737e30d7e92d62113a43977816eb6..9b7f92c6aef33403083b30835fa7302111759198 100644 (file)
@@ -1322,7 +1322,7 @@ xfs_zero_range(
 
        if (IS_DAX(inode))
                return dax_zero_range(inode, pos, len, did_zero,
-                                     &xfs_buffered_write_iomap_ops);
+                                     &xfs_direct_write_iomap_ops);
        return iomap_zero_range(inode, pos, len, did_zero,
                                &xfs_buffered_write_iomap_ops);
 }
@@ -1337,7 +1337,7 @@ xfs_truncate_page(
 
        if (IS_DAX(inode))
                return dax_truncate_page(inode, pos, did_zero,
-                                       &xfs_buffered_write_iomap_ops);
+                                       &xfs_direct_write_iomap_ops);
        return iomap_truncate_page(inode, pos, did_zero,
                                   &xfs_buffered_write_iomap_ops);
 }