From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail-it0-f65.google.com ([209.85.214.65]:53658 "EHLO mail-it0-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752096AbeFFLhY (ORCPT ); Wed, 6 Jun 2018 07:37:24 -0400 Received: by mail-it0-f65.google.com with SMTP id a195-v6so7570277itd.3 for ; Wed, 06 Jun 2018 04:37:23 -0700 (PDT) MIME-Version: 1.0 In-Reply-To: <20180606104033.4947-7-hch@lst.de> References: <20180606104033.4947-1-hch@lst.de> <20180606104033.4947-7-hch@lst.de> From: Andreas Gruenbacher Date: Wed, 6 Jun 2018 13:37:22 +0200 Message-ID: Subject: Re: [PATCH 6/6] iomap: add a page_done callback To: Christoph Hellwig Cc: linux-xfs@vger.kernel.org, Dan Williams , linux-fsdevel , cluster-devel , linux-ext4 Content-Type: text/plain; charset="UTF-8" Sender: linux-fsdevel-owner@vger.kernel.org List-ID: On 6 June 2018 at 12:40, Christoph Hellwig wrote: > 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 > --- > 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 "thus" -> "this" > + * write path. > + */ > + void (*page_done)(struct inode *inode, loff_t pos, unsigned copied, > + struct page *page, struct iomap *iomap); > }; > > /* > -- > 2.14.2 > Andreas