From: Goldwyn Rodrigues <rgoldwyn@suse.com>
The put_folio() sets folio->private to EXTENT_PAGE_PRIVATE if not
already set using set_page_extent_mapped().
Signed-off-by: Goldwyn Rodrigues <rgoldwyn@suse.com>
---
fs/btrfs/extent_io.c | 13 +++++++++++++
1 file changed, 13 insertions(+)
diff --git a/fs/btrfs/extent_io.c b/fs/btrfs/extent_io.c
index 43418b6d4824..ee0d37388441 100644
--- a/fs/btrfs/extent_io.c
+++ b/fs/btrfs/extent_io.c
@@ -901,6 +901,18 @@ void clear_folio_extent_mapped(struct folio *folio)
folio_detach_private(folio);
}
+static void btrfs_put_folio(struct inode *inode, loff_t pos,
+ unsigned copied, struct folio *folio)
+{
+ set_folio_extent_mapped(folio);
+ folio_unlock(folio);
+ folio_put(folio);
+}
+
+static const struct iomap_folio_ops btrfs_iomap_folio_ops = {
+ .put_folio = btrfs_put_folio,
+};
+
static void btrfs_em_to_iomap(struct inode *inode,
struct extent_map *em, struct iomap *iomap,
loff_t sector_pos, bool write)
@@ -928,6 +940,7 @@ static void btrfs_em_to_iomap(struct inode *inode,
iomap->offset = em->start;
iomap->bdev = fs_info->fs_devices->latest_dev->bdev;
iomap->length = em->len;
+ iomap->folio_ops = &btrfs_iomap_folio_ops;
}
static struct extent_map *__get_extent_map(struct inode *inode,
--
2.46.1