{"id":2229421,"url":"http://patchwork.ozlabs.org/api/1.1/patches/2229421/?format=json","web_url":"http://patchwork.ozlabs.org/project/linux-ext4/patch/20260428083332.768693-8-aalbersh@kernel.org/","project":{"id":8,"url":"http://patchwork.ozlabs.org/api/1.1/projects/8/?format=json","name":"Linux ext4 filesystem development","link_name":"linux-ext4","list_id":"linux-ext4.vger.kernel.org","list_email":"linux-ext4@vger.kernel.org","web_url":null,"scm_url":null,"webscm_url":null},"msgid":"<20260428083332.768693-8-aalbersh@kernel.org>","date":"2026-04-28T08:33:13","name":"[v9,07/22] iomap: introduce IOMAP_F_FSVERITY and teach writeback to handle fsverity","commit_ref":null,"pull_url":null,"state":"new","archived":false,"hash":"fc951fdce1804572ece3a86f722b2a85a1e5b628","submitter":{"id":92821,"url":"http://patchwork.ozlabs.org/api/1.1/people/92821/?format=json","name":"Andrey Albershteyn","email":"aalbersh@kernel.org"},"delegate":null,"mbox":"http://patchwork.ozlabs.org/project/linux-ext4/patch/20260428083332.768693-8-aalbersh@kernel.org/mbox/","series":[{"id":501796,"url":"http://patchwork.ozlabs.org/api/1.1/series/501796/?format=json","web_url":"http://patchwork.ozlabs.org/project/linux-ext4/list/?series=501796","date":"2026-04-28T08:33:09","name":"[v9,01/22] fsverity: report validation errors through fserror to fsnotify","version":9,"mbox":"http://patchwork.ozlabs.org/series/501796/mbox/"}],"comments":"http://patchwork.ozlabs.org/api/patches/2229421/comments/","check":"pending","checks":"http://patchwork.ozlabs.org/api/patches/2229421/checks/","tags":{},"headers":{"Return-Path":"\n <SRS0=3bps=C3=vger.kernel.org=linux-ext4+bounces-16153-patchwork-incoming=ozlabs.org@ozlabs.org>","X-Original-To":["incoming@patchwork.ozlabs.org","linux-ext4@vger.kernel.org"],"Delivered-To":["patchwork-incoming@legolas.ozlabs.org","patchwork-incoming@ozlabs.org"],"Authentication-Results":["legolas.ozlabs.org;\n\tdkim=pass (2048-bit key;\n unprotected) header.d=kernel.org header.i=@kernel.org header.a=rsa-sha256\n header.s=k20201202 header.b=khIh9f6W;\n\tdkim-atps=neutral","legolas.ozlabs.org;\n spf=pass (sender SPF authorized) smtp.mailfrom=ozlabs.org\n (client-ip=2404:9400:2221:ea00::3; helo=mail.ozlabs.org;\n envelope-from=srs0=3bps=c3=vger.kernel.org=linux-ext4+bounces-16153-patchwork-incoming=ozlabs.org@ozlabs.org;\n receiver=patchwork.ozlabs.org)","gandalf.ozlabs.org;\n arc=pass smtp.remote-ip=\"2600:3c09:e001:a7::12fc:5321\"\n arc.chain=subspace.kernel.org","gandalf.ozlabs.org;\n dmarc=pass (p=quarantine dis=none) header.from=kernel.org","gandalf.ozlabs.org;\n\tdkim=pass (2048-bit key;\n unprotected) header.d=kernel.org header.i=@kernel.org header.a=rsa-sha256\n header.s=k20201202 header.b=khIh9f6W;\n\tdkim-atps=neutral","gandalf.ozlabs.org;\n spf=pass (sender SPF authorized) smtp.mailfrom=vger.kernel.org\n (client-ip=2600:3c09:e001:a7::12fc:5321; helo=sto.lore.kernel.org;\n envelope-from=linux-ext4+bounces-16153-patchwork-incoming=ozlabs.org@vger.kernel.org;\n receiver=ozlabs.org)","smtp.subspace.kernel.org;\n\tdkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org\n header.b=\"khIh9f6W\"","smtp.subspace.kernel.org;\n arc=none smtp.client-ip=10.30.226.201"],"Received":["from mail.ozlabs.org (mail.ozlabs.org [IPv6:2404:9400:2221:ea00::3])\n\t(using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)\n\t key-exchange x25519 server-signature ECDSA (secp384r1 raw public key)\n server-digest SHA384)\n\t(No client certificate requested)\n\tby legolas.ozlabs.org (Postfix) with ESMTPS id 4g4YnS2j59z1xvV\n\tfor <incoming@patchwork.ozlabs.org>; Tue, 28 Apr 2026 18:41:32 +1000 (AEST)","from mail.ozlabs.org (mail.ozlabs.org [IPv6:2404:9400:2221:ea00::3])\n\tby gandalf.ozlabs.org (Postfix) with ESMTP id 4g4YnS2JwZz4wKh\n\tfor <incoming@patchwork.ozlabs.org>; Tue, 28 Apr 2026 18:41:32 +1000 (AEST)","by gandalf.ozlabs.org (Postfix)\n\tid 4g4YnS2C15z4wLR; Tue, 28 Apr 2026 18:41:32 +1000 (AEST)","from sto.lore.kernel.org (sto.lore.kernel.org\n [IPv6:2600:3c09:e001:a7::12fc:5321])\n\t(using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)\n\t key-exchange x25519)\n\t(No client certificate requested)\n\tby gandalf.ozlabs.org (Postfix) with ESMTPS id 4g4YnN474vz4wKh\n\tfor <patchwork-incoming@ozlabs.org>; Tue, 28 Apr 2026 18:41:28 +1000 (AEST)","from smtp.subspace.kernel.org (conduit.subspace.kernel.org\n [100.90.174.1])\n\tby sto.lore.kernel.org (Postfix) with ESMTP id 7693E3031414\n\tfor <patchwork-incoming@ozlabs.org>; Tue, 28 Apr 2026 08:34:53 +0000 (UTC)","from localhost.localdomain (localhost.localdomain [127.0.0.1])\n\tby smtp.subspace.kernel.org (Postfix) with ESMTP id 5B1923D811C;\n\tTue, 28 Apr 2026 08:34:16 +0000 (UTC)","from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org\n [10.30.226.201])\n\t(using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits))\n\t(No client certificate requested)\n\tby smtp.subspace.kernel.org (Postfix) with ESMTPS id 1A5543D6483;\n\tTue, 28 Apr 2026 08:34:15 +0000 (UTC)","by smtp.kernel.org (Postfix) with ESMTPSA id 51947C2BCB5;\n\tTue, 28 Apr 2026 08:34:13 +0000 (UTC)"],"ARC-Seal":["i=2; a=rsa-sha256; d=ozlabs.org; s=201707; t=1777365692; cv=pass;\n\tb=hQ8LQS6uai388nJXyiRaK6veXEz5Uv6QqkP4BpALxh/CHjy6Eo/hEhM8GEDGgGV+tZHZY7qFdazHGXhEVJuxD9ECUv+fIjeVOn5NwRtVir9ETQpuEB1o/uAl/RbOEr1cyjlCZt4krFRWdesdmNl7veNK5JtRw+5aumbhHC4qhYNhC2idfqW0AZ++E4c4s+kD8CZ4vk5BPEETbuplx0Bupi8iiQPt4hOlmduLqzVsvnrKhALKchSTI/LluikjBRcU/oFPKSlYjeNAyXUqWM78b/Q2p/NttGOSthFnuvwYGgnGL9Hk8kieGQwkBBBge7MjSyNOSh+36TQruwx5o66QWA==","i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116;\n\tt=1777365256; cv=none;\n b=rcM07E8iHooCpF3DNipMlBULdhEYNeWwX+Y4ZhSsGFt9YjaNylpYabKdRQnr+LKpRd0nsC+cXz5zvbWSH0qKHwrgzWoQwJO4cHUUZnLGcV5yv2IQ/sbao5HEjuUWy35oS1qVdU8brw6NkMOvsoq+NPJpUFDSYVmkygra+m1Wg8U="],"ARC-Message-Signature":["i=2; a=rsa-sha256; d=ozlabs.org; s=201707;\n\tt=1777365692; c=relaxed/relaxed;\n\tbh=10tlwbpm7IipzItbU4Bn2MSqqrlz5zXrSihJT62muZE=;\n\th=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References:\n\t MIME-Version;\n b=fgyLqfLrSc0KfLNGfahCjzMjh8hjsAcffhBbQRspdZgMGMP7UT2ulQqszy6Y3UgvWUZlxD97q6Qdy0wEheh3f2tPWXbop6WzGlbSviP3AmJuHJ6dZTbCKpPgEqUKnEHTyuHWvAj8xG4UUmd+plQXIgNbYpT6c+0MGM9h/SkcuxsOz+pSPX9VYHmr/VDLrO6i7Xy6UzL0zoQ5ROcTErZ/kpVQNKIBbX7fvq0WntgdxQLCTE6K4NCTtHXUUzgx4G8R+8TXDFttf092nBzPf3UxrMa/EKsepMPt56gD9WqHdS84PU/ydjYu+NqJT5LR+xjkBeIatSOH+Eh0uVO/SJmaIg==","i=1; a=rsa-sha256; d=subspace.kernel.org;\n\ts=arc-20240116; t=1777365256; c=relaxed/simple;\n\tbh=/SbaSxqoCapi7/7jAyx+81s7Wq+jj6RPYvLhQ5Ccgu4=;\n\th=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References:\n\t MIME-Version;\n b=Yxwi+B6YwjaXeCrFrN2T8tIUBWfq3S9/O4gd+9LA+wnYfEyWXE9b+JSiZz8+UWo0puZfq/nXW60HQ/KVii2QsbDlv/EJB32cgFPunr+67Agu8U9Dg6Ko/Hf0xM/769y9KjqdTBEpwJC0yXfaeXDo/Efi792jm+owPnIqoajkoGs="],"ARC-Authentication-Results":["i=2; gandalf.ozlabs.org;\n dmarc=pass (p=quarantine dis=none) header.from=kernel.org;\n dkim=pass (2048-bit key;\n unprotected) header.d=kernel.org header.i=@kernel.org header.a=rsa-sha256\n header.s=k20201202 header.b=khIh9f6W; dkim-atps=neutral;\n spf=pass (client-ip=2600:3c09:e001:a7::12fc:5321; helo=sto.lore.kernel.org;\n envelope-from=linux-ext4+bounces-16153-patchwork-incoming=ozlabs.org@vger.kernel.org;\n receiver=ozlabs.org) smtp.mailfrom=vger.kernel.org","i=1; smtp.subspace.kernel.org;\n dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org\n header.b=khIh9f6W; arc=none smtp.client-ip=10.30.226.201"],"DKIM-Signature":"v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org;\n\ts=k20201202; t=1777365255;\n\tbh=/SbaSxqoCapi7/7jAyx+81s7Wq+jj6RPYvLhQ5Ccgu4=;\n\th=From:To:Cc:Subject:Date:In-Reply-To:References:From;\n\tb=khIh9f6WfvdFH7yUkKKgjPF6Jj1mlLb0fA8bMioNjKaey64MGGrmcbyyp6ZGVIXpY\n\t wKg5ZPxCVBNIXHZ/WrWOAcTwTWbAE2z7ZOepqXVerJo/tevFO+vZjk6FuRR3Vk4T1x\n\t 9n4W2IVqDuhi6qCZ5NDm0H5wXK4u9HP8apO/1ujMigXWqfQ2JomqYhsVeepKdPtXHl\n\t ABvA1+3k2Wj58YcSTcJPfFhFO8kOclIXO6gWywtU9JhqPQWI6o2m0fRwTs1JYxCH0p\n\t oIjBLNBXR3yuG3S5fa8WDk7ldAMxT8LCshv5c+PTl/145FOI+uWvbIQUg7+drfMaVt\n\t b3/G+NVulVDaQ==","From":"Andrey Albershteyn <aalbersh@kernel.org>","To":"linux-xfs@vger.kernel.org,\n\tfsverity@lists.linux.dev,\n\tlinux-fsdevel@vger.kernel.org,\n\tebiggers@kernel.org","Cc":"Andrey Albershteyn <aalbersh@kernel.org>,\n\thch@lst.de,\n\tlinux-ext4@vger.kernel.org,\n\tlinux-f2fs-devel@lists.sourceforge.net,\n\tlinux-btrfs@vger.kernel.org,\n\tlinux-unionfs@vger.kernel.org,\n\tdjwong@kernel.org","Subject":"[PATCH v9 07/22] iomap: introduce IOMAP_F_FSVERITY and teach\n writeback to handle fsverity","Date":"Tue, 28 Apr 2026 10:33:13 +0200","Message-ID":"<20260428083332.768693-8-aalbersh@kernel.org>","X-Mailer":"git-send-email 2.51.2","In-Reply-To":"<20260428083332.768693-1-aalbersh@kernel.org>","References":"<20260428083332.768693-1-aalbersh@kernel.org>","Precedence":"bulk","X-Mailing-List":"linux-ext4@vger.kernel.org","List-Id":"<linux-ext4.vger.kernel.org>","List-Subscribe":"<mailto:linux-ext4+subscribe@vger.kernel.org>","List-Unsubscribe":"<mailto:linux-ext4+unsubscribe@vger.kernel.org>","MIME-Version":"1.0","Content-Transfer-Encoding":"8bit","X-Spam-Status":"No, score=-1.2 required=5.0 tests=ARC_SIGNED,ARC_VALID,\n\tDKIMWL_WL_HIGH,DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DMARC_PASS,\n\tMAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS autolearn=disabled\n\tversion=4.0.1","X-Spam-Checker-Version":"SpamAssassin 4.0.1 (2024-03-25) on gandalf.ozlabs.org"},"content":"This flag indicates that I/O is for fsverity metadata.\n\nIn the write path skip i_size check and i_size updates as metadata is\npast EOF. In writeback don't update i_size and continue writeback if\neven folio is beyond EOF. In read path don't zero fsverity folios, again\nthey are past EOF.\n\nThe iomap_block_needs_zeroing() is also called from write path. For\nfolios of larger order we don't want to zero out pages in the folio as\nthese could contain other merkle tree blocks. For fsverity, filesystem\nwill request to read PAGE_SIZE memory regions. For data folios, iomap\nwill zero the rest of the folio for anything which is beyond EOF. We\ndon't want this for fsverity folios.\n\nSigned-off-by: Andrey Albershteyn <aalbersh@kernel.org>\nReviewed-by: \"Darrick J. Wong\" <djwong@kernel.org>\nReviewed-by: Christoph Hellwig <hch@lst.de>\n---\n fs/iomap/buffered-io.c | 43 +++++++++++++++++++++++++++++++++---------\n fs/iomap/trace.h       |  3 ++-\n include/linux/iomap.h  |  8 ++++++++\n 3 files changed, 44 insertions(+), 10 deletions(-)","diff":"diff --git a/fs/iomap/buffered-io.c b/fs/iomap/buffered-io.c\nindex e4b6886e5c3c..38c9592fba43 100644\n--- a/fs/iomap/buffered-io.c\n+++ b/fs/iomap/buffered-io.c\n@@ -353,9 +353,26 @@ static inline bool iomap_block_needs_zeroing(const struct iomap_iter *iter,\n {\n \tconst struct iomap *srcmap = iomap_iter_srcmap(iter);\n \n-\treturn srcmap->type != IOMAP_MAPPED ||\n-\t\t(srcmap->flags & IOMAP_F_NEW) ||\n-\t\tpos >= i_size_read(iter->inode);\n+\t/*\n+\t * If this block has not been written, there's nothing to read\n+\t */\n+\tif (srcmap->type != IOMAP_MAPPED)\n+\t\treturn true;\n+\n+\t/*\n+\t * Newly allocated blocks have not been written\n+\t */\n+\tif (srcmap->flags & IOMAP_F_NEW)\n+\t\treturn true;\n+\n+\t/*\n+\t * fsverity metadata is stored past i_size, we need to read it instead\n+\t * of zeroing\n+\t */\n+\tif (srcmap->flags & IOMAP_F_FSVERITY)\n+\t\treturn false;\n+\n+\treturn pos >= i_size_read(iter->inode);\n }\n \n /**\n@@ -1167,13 +1184,14 @@ static int iomap_write_iter(struct iomap_iter *iter, struct iov_iter *i,\n \t\t * unlock and release the folio.\n \t\t */\n \t\told_size = iter->inode->i_size;\n-\t\tif (pos + written > old_size) {\n+\t\tif (pos + written > old_size &&\n+\t\t    !(iter->iomap.flags & IOMAP_F_FSVERITY)) {\n \t\t\ti_size_write(iter->inode, pos + written);\n \t\t\titer->iomap.flags |= IOMAP_F_SIZE_CHANGED;\n \t\t}\n \t\t__iomap_put_folio(iter, write_ops, written, folio);\n \n-\t\tif (old_size < pos)\n+\t\tif (old_size < pos && !(iter->iomap.flags & IOMAP_F_FSVERITY))\n \t\t\tpagecache_isize_extended(iter->inode, old_size, pos);\n \n \t\tcond_resched();\n@@ -1801,13 +1819,20 @@ static int iomap_writeback_range(struct iomap_writepage_ctx *wpc,\n  * Check interaction of the folio with the file end.\n  *\n  * If the folio is entirely beyond i_size, return false.  If it straddles\n- * i_size, adjust end_pos and zero all data beyond i_size.\n+ * i_size, adjust end_pos and zero all data beyond i_size. Don't skip fsverity\n+ * folios as those are beyond i_size.\n  */\n-static bool iomap_writeback_handle_eof(struct folio *folio, struct inode *inode,\n-\t\tu64 *end_pos)\n+static bool iomap_writeback_handle_eof(struct folio *folio,\n+\t\tstruct iomap_writepage_ctx *wpc, u64 *end_pos)\n {\n+\tstruct inode *inode = wpc->inode;\n \tu64 isize = i_size_read(inode);\n \n+\tif (wpc->iomap.flags & IOMAP_F_FSVERITY) {\n+\t\tWARN_ON_ONCE(folio_pos(folio) < isize);\n+\t\treturn true;\n+\t}\n+\n \tif (*end_pos > isize) {\n \t\tsize_t poff = offset_in_folio(folio, isize);\n \t\tpgoff_t end_index = isize >> PAGE_SHIFT;\n@@ -1873,7 +1898,7 @@ int iomap_writeback_folio(struct iomap_writepage_ctx *wpc, struct folio *folio)\n \n \ttrace_iomap_writeback_folio(inode, pos, folio_size(folio));\n \n-\tif (!iomap_writeback_handle_eof(folio, inode, &end_pos))\n+\tif (!iomap_writeback_handle_eof(folio, wpc, &end_pos))\n \t\treturn 0;\n \tWARN_ON_ONCE(end_pos <= pos);\n \ndiff --git a/fs/iomap/trace.h b/fs/iomap/trace.h\nindex 532787277b16..5252051cc137 100644\n--- a/fs/iomap/trace.h\n+++ b/fs/iomap/trace.h\n@@ -118,7 +118,8 @@ DEFINE_RANGE_EVENT(iomap_zero_iter);\n \t{ IOMAP_F_ATOMIC_BIO,\t\"ATOMIC_BIO\" }, \\\n \t{ IOMAP_F_PRIVATE,\t\"PRIVATE\" }, \\\n \t{ IOMAP_F_SIZE_CHANGED,\t\"SIZE_CHANGED\" }, \\\n-\t{ IOMAP_F_STALE,\t\"STALE\" }\n+\t{ IOMAP_F_STALE,\t\"STALE\" }, \\\n+\t{ IOMAP_F_FSVERITY,\t\"FSVERITY\" }\n \n \n #define IOMAP_DIO_STRINGS \\\ndiff --git a/include/linux/iomap.h b/include/linux/iomap.h\nindex 531f9ebdeeae..4506a99d5285 100644\n--- a/include/linux/iomap.h\n+++ b/include/linux/iomap.h\n@@ -87,6 +87,14 @@ struct vm_fault;\n #define IOMAP_F_INTEGRITY\t0\n #endif /* CONFIG_BLK_DEV_INTEGRITY */\n \n+/*\n+ * Indicates reads and writes of fsverity metadata.\n+ *\n+ * Fsverity metadata is stored after the regular file data and thus beyond\n+ * i_size.\n+ */\n+#define IOMAP_F_FSVERITY\t(1U << 10)\n+\n /*\n  * Flag reserved for file system specific usage\n  */\n","prefixes":["v9","07/22"]}