Cover Letter Detail
Show a cover letter.
GET /api/covers/2216834/?format=api
{ "id": 2216834, "url": "http://patchwork.ozlabs.org/api/covers/2216834/?format=api", "web_url": "http://patchwork.ozlabs.org/project/linux-ext4/cover/20260327102939.1095257-1-yi.zhang@huaweicloud.com/", "project": { "id": 8, "url": "http://patchwork.ozlabs.org/api/projects/8/?format=api", "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, "list_archive_url": "", "list_archive_url_format": "", "commit_url_format": "" }, "msgid": "<20260327102939.1095257-1-yi.zhang@huaweicloud.com>", "list_archive_url": null, "date": "2026-03-27T10:29:26", "name": "[v4,00/13] ext4: refactor partial block zero-out for iomap conversion", "submitter": { "id": 85428, "url": "http://patchwork.ozlabs.org/api/people/85428/?format=api", "name": "Zhang Yi", "email": "yi.zhang@huaweicloud.com" }, "mbox": "http://patchwork.ozlabs.org/project/linux-ext4/cover/20260327102939.1095257-1-yi.zhang@huaweicloud.com/mbox/", "series": [ { "id": 497742, "url": "http://patchwork.ozlabs.org/api/series/497742/?format=api", "web_url": "http://patchwork.ozlabs.org/project/linux-ext4/list/?series=497742", "date": "2026-03-27T10:29:26", "name": "ext4: refactor partial block zero-out for iomap conversion", "version": 4, "mbox": "http://patchwork.ozlabs.org/series/497742/mbox/" } ], "comments": "http://patchwork.ozlabs.org/api/covers/2216834/comments/", "headers": { "Return-Path": "\n <SRS0=a9U/=B3=vger.kernel.org=linux-ext4+bounces-15485-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 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=a9u/=b3=vger.kernel.org=linux-ext4+bounces-15485-patchwork-incoming=ozlabs.org@ozlabs.org;\n receiver=patchwork.ozlabs.org)", "gandalf.ozlabs.org;\n arc=pass smtp.remote-ip=172.232.135.74 arc.chain=subspace.kernel.org", "gandalf.ozlabs.org;\n dmarc=none (p=none dis=none) header.from=huaweicloud.com", "gandalf.ozlabs.org;\n spf=pass (sender SPF authorized) smtp.mailfrom=vger.kernel.org\n (client-ip=172.232.135.74; helo=sto.lore.kernel.org;\n envelope-from=linux-ext4+bounces-15485-patchwork-incoming=ozlabs.org@vger.kernel.org;\n receiver=ozlabs.org)", "smtp.subspace.kernel.org;\n arc=none smtp.client-ip=45.249.212.51", "smtp.subspace.kernel.org;\n dmarc=none (p=none dis=none) header.from=huaweicloud.com", "smtp.subspace.kernel.org;\n spf=pass smtp.mailfrom=huaweicloud.com" ], "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)\n\t(No client certificate requested)\n\tby legolas.ozlabs.org (Postfix) with ESMTPS id 4fhxqk6WQHz1xy1\n\tfor <incoming@patchwork.ozlabs.org>; Fri, 27 Mar 2026 21:35:30 +1100 (AEDT)", "from mail.ozlabs.org (mail.ozlabs.org [IPv6:2404:9400:2221:ea00::3])\n\tby gandalf.ozlabs.org (Postfix) with ESMTP id 4fhxqk5y1Fz4wBB\n\tfor <incoming@patchwork.ozlabs.org>; Fri, 27 Mar 2026 21:35:30 +1100 (AEDT)", "by gandalf.ozlabs.org (Postfix)\n\tid 4fhxqk5k3Kz4wDK; Fri, 27 Mar 2026 21:35:30 +1100 (AEDT)", "from sto.lore.kernel.org (sto.lore.kernel.org [172.232.135.74])\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 4fhxqf3v1Dz4wBB\n\tfor <patchwork-incoming@ozlabs.org>; Fri, 27 Mar 2026 21:35:26 +1100 (AEDT)", "from smtp.subspace.kernel.org (conduit.subspace.kernel.org\n [100.90.174.1])\n\tby sto.lore.kernel.org (Postfix) with ESMTP id 360DC301BAA9\n\tfor <patchwork-incoming@ozlabs.org>; Fri, 27 Mar 2026 10:35:13 +0000 (UTC)", "from localhost.localdomain (localhost.localdomain [127.0.0.1])\n\tby smtp.subspace.kernel.org (Postfix) with ESMTP id 07DF73DA5B7;\n\tFri, 27 Mar 2026 10:34:40 +0000 (UTC)", "from dggsgout11.his.huawei.com (dggsgout11.his.huawei.com\n [45.249.212.51])\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 4AE3F36AB49;\n\tFri, 27 Mar 2026 10:34:34 +0000 (UTC)", "from mail.maildlp.com (unknown [172.19.163.177])\n\tby dggsgout11.his.huawei.com (SkyGuard) with ESMTPS id 4fhxpL1WGszYQtw6;\n\tFri, 27 Mar 2026 18:34:18 +0800 (CST)", "from mail02.huawei.com (unknown [10.116.40.112])\n\tby mail.maildlp.com (Postfix) with ESMTP id C6F7A40594;\n\tFri, 27 Mar 2026 18:34:31 +0800 (CST)", "from huaweicloud.com (unknown [10.50.85.155])\n\tby APP1 (Coremail) with SMTP id cCh0CgC3utouXcZp_T2cCQ--.28730S4;\n\tFri, 27 Mar 2026 18:34:29 +0800 (CST)" ], "ARC-Seal": [ "i=2; a=rsa-sha256; d=ozlabs.org; s=201707; t=1774607730; cv=pass;\n\tb=SekcFdxCsU27RZbyxagJyIWxfrcQe3ldtJEZ5HNy7heh9lQRYgAVYF7kX4JO+/Thp/QJMSDNxjK3C/oHOrGeUp+7zcExDnIPNbVjOYnxP+meEmk0sXnJknA+oGXVsyGj2mYrYknW6M6MYJD3OWTcJz52/geZf/743zzgquSjbKwSAvYngR8FdYtxsheQ1ZpL4LlhHTZUZQxvXP/NuCO8q6PPJAXMe9SZUTTdMvd4rTDTQRb/9VhBHIBFLHnO0iRBy0jtzOoAKfAx10LEt+qRK6PIpQ5j6sHcO33oL/7JC0v1uQFbNpzDZE2YgZ7hKn27tun7EcmcNH8argOp6GFNQg==", "i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116;\n\tt=1774607678; cv=none;\n b=OjikFedseEK0j5yXDL3DqXQ/a7ZmIt+OiPzuLfK+4PXdGCjqIiL9TvTSmoH5uaOFoLvuroVen9T+qtNuovYKBHsBtSwDZPjdUDBVLKI2z8ljVK1E6xncLZqFtSZORTq2t/GwODHy4P2q/t5QhRojTwbUw409KUFDwdWdUUQHx9w=" ], "ARC-Message-Signature": [ "i=2; a=rsa-sha256; d=ozlabs.org; s=201707;\n\tt=1774607730; c=relaxed/relaxed;\n\tbh=GH0rf7uokJ4IwqfoJITf/5DkIv6mp9ta6DDahYSYowE=;\n\th=From:To:Cc:Subject:Date:Message-ID:MIME-Version;\n b=j+KXhycnlZbH7qKQJ3WMzhRoASIqYU+R0anSlVZ+6BVE0aSLNUeHU658+zy/wyr+jipUvMjmhYCV7f5Rjw1ocFvIFirQLniPJcxgIPrFneZrttGeKsP0l4f7Ih6t+RiHA1ExbxsZMWqUFR2Sjm1oCHZuAFcrTs+XSHsPlsNkKnwh6wzSLyfSvLLYSIfhhvVOciGgfEQ45vScjesqGbOp7UQZS1yfXDeiFMV13JUh7kEohz2YwSCvPtsLKCfCQrUZXiPE+RC+cYAqRQIxymK14YSw8SZPfQ/owozDG5VSvujNzBLd4mpOJQa+pCr7VISceLO5KLa8gQ7BGQ+6OdoH/Q==", "i=1; a=rsa-sha256; d=subspace.kernel.org;\n\ts=arc-20240116; t=1774607678; c=relaxed/simple;\n\tbh=V3PreLzrVvDLTjjrE1mubL6PrtDZTq5KlDCUt1cAzaY=;\n\th=From:To:Cc:Subject:Date:Message-ID:MIME-Version;\n b=u6xNHFynwgn5Yn+JJTm1/8qbHG4NUg7yT2mkBbF27uNxFNRh/yAgshNsItJZprmLIt3hzM44FV7iIH4C7A1LPZZsmskBjfF9/GupdkJFyY6smXr84GccUIXk2fd+AUwokMLk2K2cIIlaRVlycsKc1jqMRvr5dwbAzJkTKMxAeUk=" ], "ARC-Authentication-Results": [ "i=2; gandalf.ozlabs.org;\n dmarc=none (p=none dis=none) header.from=huaweicloud.com;\n spf=pass (client-ip=172.232.135.74; helo=sto.lore.kernel.org;\n envelope-from=linux-ext4+bounces-15485-patchwork-incoming=ozlabs.org@vger.kernel.org;\n receiver=ozlabs.org) smtp.mailfrom=vger.kernel.org", "i=1; smtp.subspace.kernel.org;\n dmarc=none (p=none dis=none) header.from=huaweicloud.com;\n spf=pass smtp.mailfrom=huaweicloud.com; arc=none smtp.client-ip=45.249.212.51" ], "From": "Zhang Yi <yi.zhang@huaweicloud.com>", "To": "linux-ext4@vger.kernel.org", "Cc": "linux-fsdevel@vger.kernel.org,\n\tlinux-kernel@vger.kernel.org,\n\ttytso@mit.edu,\n\tadilger.kernel@dilger.ca,\n\tjack@suse.cz,\n\tojaswin@linux.ibm.com,\n\tritesh.list@gmail.com,\n\tlibaokun@linux.alibaba.com,\n\tyi.zhang@huawei.com,\n\tyi.zhang@huaweicloud.com,\n\tyizhang089@gmail.com,\n\tyangerkun@huawei.com,\n\tyukuai@fnnas.com", "Subject": "[PATCH v4 00/13] ext4: refactor partial block zero-out for iomap\n conversion", "Date": "Fri, 27 Mar 2026 18:29:26 +0800", "Message-ID": "<20260327102939.1095257-1-yi.zhang@huaweicloud.com>", "X-Mailer": "git-send-email 2.52.0", "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-CM-TRANSID": "cCh0CgC3utouXcZp_T2cCQ--.28730S4", "X-Coremail-Antispam": "1UD129KBjvJXoWxZF1xKr1xJFWDKFWDCrW8tFb_yoW7JrWfpF\n\tW3tw1Fgr4xG39F9an7Ga1xJ3WSgwn3XF48GrWfG34DZ3yUZryxCFs7K3WF9FWUKrWfG3Wj\n\tqF42y34UWF1DAa7anT9S1TB71UUUUU7qnTZGkaVYY2UrUUUUjbIjqfuFe4nvWSU5nxnvy2\n\t9KBjDU0xBIdaVrnRJUUU9Y14x267AKxVW8JVW5JwAFc2x0x2IEx4CE42xK8VAvwI8IcIk0\n\trVWrJVCq3wAFIxvE14AKwVWUJVWUGwA2ocxC64kIII0Yj41l84x0c7CEw4AK67xGY2AK02\n\t1l84ACjcxK6xIIjxv20xvE14v26w1j6s0DM28EF7xvwVC0I7IYx2IY6xkF7I0E14v26r4U\n\tJVWxJr1l84ACjcxK6I8E87Iv67AKxVW0oVCq3wA2z4x0Y4vEx4A2jsIEc7CjxVAFwI0_Gc\n\tCE3s1le2I262IYc4CY6c8Ij28IcVAaY2xG8wAqx4xG64xvF2IEw4CE5I8CrVC2j2WlYx0E\n\t2Ix0cI8IcVAFwI0_JrI_JrylYx0Ex4A2jsIE14v26r1j6r4UMcvjeVCFs4IE7xkEbVWUJV\n\tW8JwACjcxG0xvY0x0EwIxGrwACjI8F5VA0II8E6IAqYI8I648v4I1lFIxGxcIEc7CjxVA2\n\tY2ka0xkIwI1lc7CjxVAaw2AFwI0_Jw0_GFyl42xK82IYc2Ij64vIr41l4I8I3I0E4IkC6x\n\t0Yz7v_Jr0_Gr1lx2IqxVAqx4xG67AKxVWUJVWUGwC20s026x8GjcxK67AKxVWUGVWUWwC2\n\tzVAF1VAY17CE14v26r1q6r43MIIYrxkI7VAKI48JMIIF0xvE2Ix0cI8IcVAFwI0_Jr0_JF\n\t4lIxAIcVC0I7IYx2IY6xkF7I0E14v26r4j6F4UMIIF0xvE42xK8VAvwI8IcIk0rVWUJVWU\n\tCwCI42IY6I8E87Iv67AKxVWUJVW8JwCI42IY6I8E87Iv6xkF7I0E14v26r4j6r4UJbIYCT\n\tnIWIevJa73UjIFyTuYvjfUFg4SDUUUU", "X-CM-SenderInfo": "d1lo6xhdqjqx5xdzvxpfor3voofrz/", "X-Spam-Status": "No, score=-1.1 required=5.0 tests=ARC_SIGNED,ARC_VALID,\n\tDMARC_MISSING,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,\n\tSPF_HELO_NONE,SPF_PASS autolearn=disabled version=4.0.1", "X-Spam-Checker-Version": "SpamAssassin 4.0.1 (2024-03-25) on gandalf.ozlabs.org" }, "content": "From: Zhang Yi <yi.zhang@huawei.com>\n\nChanges since v3:\n - In patch 04, fix the comments of ext4_block_zero_range().\n - Add patch 09, ensure zeroed partial blocks are persisted in SYNC mode\n for ext4_punch_hole() and ext4_zero_range(), This can resolve the\n breaks in the guarantee of data-ordered mode caused by patch 05, as\n pointed out by Sashiko.\n - Add patch 10, unify the inconsistent SYNC mode checks in all\n fallocate paths.\n - In patch 12, fix two issues related to updating the file size in\n error paths, as pointed out by Sashiko.\n\nChanges since v2:\n - Drop patch 02 in v2 because it will not be used in the later iomap\n conversion.\n - In patch 08, modify ext4_alloc_file_blocks() to zero out EOF block\n when new_size is larger than old_size, preventing the exposure of\n stale data when the user performs fallocate starting within the\n old_size. This was pointed out by Sashiko.\n - In patch 08, add checks for the return value of\n ext4_block_zero_eof().\n - Add patches 09 and 10, move pagecache_isize_extended() out of an\n active journal handle as well to prevent opposite lock ordering.\n This was pointed out by Sashiko.\n - In patch 11, add a check for IOCB_NOWAIT, which was also pointed out\n by Sashiko.\n\nChanges since v1:\n - In patch 04, rename ext4_block_get_zero_range() to\n ext4_load_tail_bh() and drop the unused 'length' parameter as Jan\n suggested.\n - In patch 06, modify the commit message, add another reason to drop\n data=ordered mode when zeroing partial blocks in ext4_punch_hole()\n and ext4_punch_hole() as Jan pointed out.\n - In patch 10, modify the commit message, explain the race condition\n between the buffered write and mmap write that pointed out by Jan.\n - Collect reviewed tags from Jan.\n\nv3: https://lore.kernel.org/linux-ext4/20260326111054.907252-1-yi.zhang@huaweicloud.com/\nv2: https://lore.kernel.org/linux-ext4/20260325072850.3997161-1-yi.zhang@huaweicloud.com/\nv1: https://lore.kernel.org/linux-ext4/20260310014101.4140698-1-yi.zhang@huaweicloud.com/\n\nOriginal cover letter:\n\nThis patch series extracted from my iomap conversion v2 series[1]. It\nrefactors the ext4 zero partial block code path in preparation for\nconverting buffered I/O to the iomap infrastructure. The main changes\nare:\n\n[1] https://lore.kernel.org/linux-ext4/20260203062523.3869120-1-yi.zhang@huawei.com/\n\n1. Introduce ext4_block_zero_eof(): Extend and rename\n ext4_block_truncate_page() to handle post-EOF partial block zeroing\n for both append writes and truncate operations.\n2. Separate ordered data handling: Move data=ordered mode handling from\n __ext4_block_zero_page_range to ext4_block_zero_eof(). Only truncate\n and post-EOF append write/fallocate paths need ordered data mode,\n hole punching and zero range paths don't need ordered data handling.\n3. Split journal mode handling: Extract\n ext4_block_journalled_zero_range() from\n __ext4_block_zero_page_range() for data=journal mode, leaving\n ext4_block_do_zero_range() for data=ordered/writeback modes.\n4. Refactor ext4_alloc_file_blocks(): Change parameters to loff_t byte\n granularity to simplify callers and prepares removing the zero call\n from the allocation loop for unaligned append writes.\n5. Remove handle parameters: Stop passing handle_t * to zero functions.\n Make ext4_block_journalled_zero_range() start its own handle, and\n move zero operations outside active handles. This is required because\n iomap uses \"folio lock -> transaction start\" lock ordering, opposite\n to the current lock ordering.\n6. Centralize zeroing in ext4_write_checks(): Move all post-EOF partial\n block zeroing to ext4_write_checks() so it applies to both regular\n buffered writes and the upcoming iomap path.\n\nThanks\nYi.\n\nZhang Yi (13):\n ext4: add did_zero output parameter to ext4_block_zero_page_range()\n ext4: rename and extend ext4_block_truncate_page()\n ext4: factor out journalled block zeroing range\n ext4: rename ext4_block_zero_page_range() to ext4_block_zero_range()\n ext4: move ordered data handling out of ext4_block_do_zero_range()\n ext4: remove handle parameters from zero partial block functions\n ext4: pass allocate range as loff_t to ext4_alloc_file_blocks()\n ext4: move zero partial block range functions out of active handle\n ext4: ensure zeroed partial blocks are persisted in SYNC mode\n ext4: unify SYNC mode checks in fallocate paths\n ext4: remove ctime/mtime update from ext4_alloc_file_blocks()\n ext4: move pagecache_isize_extended() out of active handle\n ext4: zero post-EOF partial block before appending write\n\n fs/ext4/ext4.h | 5 +-\n fs/ext4/extents.c | 163 ++++++++++++++-------------\n fs/ext4/file.c | 17 +++\n fs/ext4/inode.c | 273 +++++++++++++++++++++++++++++-----------------\n 4 files changed, 278 insertions(+), 180 deletions(-)" }