xfs: remove xfs_page_mkwrite_iomap_ops

Shared the regular buffered write iomap_ops with the page fault path
and just check for the IOMAP_FAULT flag to skip delalloc punching.

This keeps the delalloc punching checks in one place, and will make it
easier to convert iomap to an iter model where the begin and end
handlers are merged into a single callback.

Signed-off-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Darrick J. Wong <djwong@kernel.org>
Signed-off-by: Carlos Maiolino <cem@kernel.org>
This commit is contained in:
Christoph Hellwig 2024-10-29 16:12:00 +01:00 committed by Carlos Maiolino
parent a7fd3327d3
commit fe4e0faac9
3 changed files with 9 additions and 11 deletions

View File

@ -1474,7 +1474,7 @@ xfs_write_fault(
if (IS_DAX(inode)) if (IS_DAX(inode))
ret = xfs_dax_fault_locked(vmf, order, true); ret = xfs_dax_fault_locked(vmf, order, true);
else else
ret = iomap_page_mkwrite(vmf, &xfs_page_mkwrite_iomap_ops); ret = iomap_page_mkwrite(vmf, &xfs_buffered_write_iomap_ops);
xfs_iunlock(ip, lock_mode); xfs_iunlock(ip, lock_mode);
sb_end_pagefault(inode->i_sb); sb_end_pagefault(inode->i_sb);

View File

@ -1234,6 +1234,14 @@ xfs_buffered_write_iomap_end(
if (iomap->type != IOMAP_DELALLOC || !(iomap->flags & IOMAP_F_NEW)) if (iomap->type != IOMAP_DELALLOC || !(iomap->flags & IOMAP_F_NEW))
return 0; return 0;
/*
* iomap_page_mkwrite() will never fail in a way that requires delalloc
* extents that it allocated to be revoked. Hence never try to release
* them here.
*/
if (flags & IOMAP_FAULT)
return 0;
/* Nothing to do if we've written the entire delalloc extent */ /* Nothing to do if we've written the entire delalloc extent */
start_byte = iomap_last_written_block(inode, offset, written); start_byte = iomap_last_written_block(inode, offset, written);
end_byte = round_up(offset + length, i_blocksize(inode)); end_byte = round_up(offset + length, i_blocksize(inode));
@ -1260,15 +1268,6 @@ const struct iomap_ops xfs_buffered_write_iomap_ops = {
.iomap_end = xfs_buffered_write_iomap_end, .iomap_end = xfs_buffered_write_iomap_end,
}; };
/*
* iomap_page_mkwrite() will never fail in a way that requires delalloc extents
* that it allocated to be revoked. Hence we do not need an .iomap_end method
* for this operation.
*/
const struct iomap_ops xfs_page_mkwrite_iomap_ops = {
.iomap_begin = xfs_buffered_write_iomap_begin,
};
static int static int
xfs_read_iomap_begin( xfs_read_iomap_begin(
struct inode *inode, struct inode *inode,

View File

@ -48,7 +48,6 @@ xfs_aligned_fsb_count(
} }
extern const struct iomap_ops xfs_buffered_write_iomap_ops; extern const struct iomap_ops xfs_buffered_write_iomap_ops;
extern const struct iomap_ops xfs_page_mkwrite_iomap_ops;
extern const struct iomap_ops xfs_direct_write_iomap_ops; extern const struct iomap_ops xfs_direct_write_iomap_ops;
extern const struct iomap_ops xfs_read_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_seek_iomap_ops;