mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-08-05 16:54:27 +00:00

The iomap_folio_ops are only used for buffered writes, including the zero and unshare variants. Rename them to iomap_write_ops to better describe the usage, and pass them through the call chain like the other operation specific methods instead of through the iomap. xfs_iomap_valid grows a IOMAP_HOLE check to keep the existing behavior that never attached the folio_ops to a iomap representing a hole. Signed-off-by: Christoph Hellwig <hch@lst.de> Link: https://lore.kernel.org/20250710133343.399917-12-hch@lst.de Acked-by: Damien Le Moal <dlemoal@kernel.org> Reviewed-by: Brian Foster <bfoster@redhat.com> Reviewed-by: Darrick J. Wong <djwong@kernel.org> Signed-off-by: Christian Brauner <brauner@kernel.org>
62 lines
1.9 KiB
C
62 lines
1.9 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
/*
|
|
* Copyright (c) 2003-2005 Silicon Graphics, Inc.
|
|
* All Rights Reserved.
|
|
*/
|
|
#ifndef __XFS_IOMAP_H__
|
|
#define __XFS_IOMAP_H__
|
|
|
|
#include <linux/iomap.h>
|
|
|
|
struct xfs_inode;
|
|
struct xfs_bmbt_irec;
|
|
struct xfs_zone_alloc_ctx;
|
|
|
|
int xfs_iomap_write_direct(struct xfs_inode *ip, xfs_fileoff_t offset_fsb,
|
|
xfs_fileoff_t count_fsb, unsigned int flags,
|
|
struct xfs_bmbt_irec *imap, u64 *sequence);
|
|
int xfs_iomap_write_unwritten(struct xfs_inode *, xfs_off_t, xfs_off_t, bool);
|
|
xfs_fileoff_t xfs_iomap_eof_align_last_fsb(struct xfs_inode *ip,
|
|
xfs_fileoff_t end_fsb);
|
|
|
|
u64 xfs_iomap_inode_sequence(struct xfs_inode *ip, u16 iomap_flags);
|
|
int xfs_bmbt_to_iomap(struct xfs_inode *ip, struct iomap *iomap,
|
|
struct xfs_bmbt_irec *imap, unsigned int mapping_flags,
|
|
u16 iomap_flags, u64 sequence_cookie);
|
|
|
|
int xfs_zero_range(struct xfs_inode *ip, loff_t pos, loff_t len,
|
|
struct xfs_zone_alloc_ctx *ac, bool *did_zero);
|
|
int xfs_truncate_page(struct xfs_inode *ip, loff_t pos,
|
|
struct xfs_zone_alloc_ctx *ac, bool *did_zero);
|
|
|
|
static inline xfs_filblks_t
|
|
xfs_aligned_fsb_count(
|
|
xfs_fileoff_t offset_fsb,
|
|
xfs_filblks_t count_fsb,
|
|
xfs_extlen_t extsz)
|
|
{
|
|
if (extsz) {
|
|
xfs_extlen_t align;
|
|
|
|
div_u64_rem(offset_fsb, extsz, &align);
|
|
if (align)
|
|
count_fsb += align;
|
|
div_u64_rem(count_fsb, extsz, &align);
|
|
if (align)
|
|
count_fsb += extsz - align;
|
|
}
|
|
|
|
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;
|
|
extern const struct iomap_write_ops xfs_iomap_write_ops;
|
|
|
|
#endif /* __XFS_IOMAP_H__*/
|