This will be used by gfs2 to attach data to transactions for the journaled data mode. But the concept is generic enough that we might be able to use it for other purposes like encryption/integrity post-processing in the future. Based on a patch from Andreas Gruenbacher. Signed-off-by: Christoph Hellwig <hch@xxxxxx> --- fs/iomap.c | 3 +++ include/linux/iomap.h | 8 ++++++++ 2 files changed, 11 insertions(+) diff --git a/fs/iomap.c b/fs/iomap.c index f2a491b98b7c..a7ecdd5ddd17 100644 --- a/fs/iomap.c +++ b/fs/iomap.c @@ -201,6 +201,9 @@ iomap_write_end(struct inode *inode, loff_t pos, unsigned len, copied, page, NULL); } + if (iomap->page_done) + iomap->page_done(inode, pos, copied, page, iomap); + if (ret < len) iomap_write_failed(inode, pos, len); return ret; diff --git a/include/linux/iomap.h b/include/linux/iomap.h index 69ef622f650e..474e2255ac6e 100644 --- a/include/linux/iomap.h +++ b/include/linux/iomap.h @@ -58,6 +58,14 @@ struct iomap { struct dax_device *dax_dev; void *inline_data; }; + + /* + * Called when finished processing a page in the mapping returned in + * thus iomap. At least for now this is only supported in the buffered + * write path. + */ + void (*page_done)(struct inode *inode, loff_t pos, unsigned copied, + struct page *page, struct iomap *iomap); }; /* -- 2.14.2 -- To unsubscribe from this list: send the line "unsubscribe linux-xfs" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html