mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-16 02:14:58 +00:00
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:
parent
a7fd3327d3
commit
fe4e0faac9
@ -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);
|
||||||
|
@ -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,
|
||||||
|
@ -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;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user