diff options
| author | Joanne Koong <joannelkoong@gmail.com> | 2025-07-15 13:21:21 -0700 |
|---|---|---|
| committer | Christian Brauner <brauner@kernel.org> | 2025-07-17 09:55:19 +0200 |
| commit | 707c5d3471e32ecfdcfa5ebe4e8023f886d4b1fd (patch) | |
| tree | 0aef2140090c129702ce5c1d41e5428ff981a3bc /fs/fuse | |
| parent | fuse: use iomap for folio laundering (diff) | |
| download | linux-707c5d3471e32ecfdcfa5ebe4e8023f886d4b1fd.tar.gz linux-707c5d3471e32ecfdcfa5ebe4e8023f886d4b1fd.zip | |
fuse: hook into iomap for invalidating and checking partial uptodateness
Hook into iomap_invalidate_folio() so that if the entire folio is being
invalidated during truncation, the dirty state is cleared and the folio
doesn't get written back. As well the folio's corresponding ifs struct
will get freed.
Hook into iomap_is_partially_uptodate() since iomap tracks uptodateness
granularly when it does buffered writes.
Signed-off-by: Joanne Koong <joannelkoong@gmail.com>
Link: https://lore.kernel.org/20250715202122.2282532-5-joannelkoong@gmail.com
Reviewed-by: Darrick J. Wong <djwong@kernel.org>
Signed-off-by: Christian Brauner <brauner@kernel.org>
Diffstat (limited to 'fs/fuse')
| -rw-r--r-- | fs/fuse/file.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/fs/fuse/file.c b/fs/fuse/file.c index a4ef19ad7199..3ffb7c4eae04 100644 --- a/fs/fuse/file.c +++ b/fs/fuse/file.c @@ -3110,6 +3110,8 @@ static const struct address_space_operations fuse_file_aops = { .launder_folio = fuse_launder_folio, .dirty_folio = iomap_dirty_folio, .release_folio = iomap_release_folio, + .invalidate_folio = iomap_invalidate_folio, + .is_partially_uptodate = iomap_is_partially_uptodate, .migrate_folio = filemap_migrate_folio, .bmap = fuse_bmap, .direct_IO = fuse_direct_IO, |
