{"id":2224555,"url":"http://patchwork.ozlabs.org/api/patches/2224555/?format=json","web_url":"http://patchwork.ozlabs.org/project/linux-ext4/patch/20260417151423.GA1808289@mit.edu/","project":{"id":8,"url":"http://patchwork.ozlabs.org/api/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,"list_archive_url":"","list_archive_url_format":"","commit_url_format":""},"msgid":"<20260417151423.GA1808289@mit.edu>","list_archive_url":null,"date":"2026-04-17T15:14:23","name":"[GIT,PULL] ext4 changes for 7.1-rc1","commit_ref":null,"pull_url":"https://git.kernel.org/pub/scm/linux/kernel/git/tytso/ext4.git tags/ext4_for_linux-7.0-rc1","state":"new","archived":false,"hash":null,"submitter":{"id":350,"url":"http://patchwork.ozlabs.org/api/people/350/?format=json","name":"Theodore Tso","email":"tytso@mit.edu"},"delegate":null,"mbox":"http://patchwork.ozlabs.org/project/linux-ext4/patch/20260417151423.GA1808289@mit.edu/mbox/","series":[{"id":500361,"url":"http://patchwork.ozlabs.org/api/series/500361/?format=json","web_url":"http://patchwork.ozlabs.org/project/linux-ext4/list/?series=500361","date":"2026-04-17T15:14:23","name":"[GIT,PULL] ext4 changes for 7.1-rc1","version":1,"mbox":"http://patchwork.ozlabs.org/series/500361/mbox/"}],"comments":"http://patchwork.ozlabs.org/api/patches/2224555/comments/","check":"pending","checks":"http://patchwork.ozlabs.org/api/patches/2224555/checks/","tags":{},"related":[],"headers":{"Return-Path":"\n <SRS0=jYCf=CQ=vger.kernel.org=linux-ext4+bounces-15886-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=mit.edu header.i=@mit.edu header.a=rsa-sha256\n header.s=outgoing header.b=XD9EjQnp;\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=jycf=cq=vger.kernel.org=linux-ext4+bounces-15886-patchwork-incoming=ozlabs.org@ozlabs.org;\n receiver=patchwork.ozlabs.org)","gandalf.ozlabs.org;\n arc=pass smtp.remote-ip=172.234.253.10 arc.chain=subspace.kernel.org","gandalf.ozlabs.org;\n dmarc=pass (p=none dis=none) header.from=mit.edu","gandalf.ozlabs.org;\n\tdkim=pass (2048-bit key;\n unprotected) header.d=mit.edu header.i=@mit.edu header.a=rsa-sha256\n header.s=outgoing header.b=XD9EjQnp;\n\tdkim-atps=neutral","gandalf.ozlabs.org;\n spf=pass (sender SPF authorized) smtp.mailfrom=vger.kernel.org\n (client-ip=172.234.253.10; helo=sea.lore.kernel.org;\n envelope-from=linux-ext4+bounces-15886-patchwork-incoming=ozlabs.org@vger.kernel.org;\n receiver=ozlabs.org)","smtp.subspace.kernel.org;\n\tdkim=pass (2048-bit key) header.d=mit.edu header.i=@mit.edu\n header.b=\"XD9EjQnp\"","smtp.subspace.kernel.org;\n arc=none smtp.client-ip=18.9.28.11","smtp.subspace.kernel.org;\n dmarc=pass (p=none dis=none) header.from=mit.edu","smtp.subspace.kernel.org;\n spf=pass smtp.mailfrom=mit.edu"],"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 4fxz585TSyz1yCv\n\tfor <incoming@patchwork.ozlabs.org>; Sat, 18 Apr 2026 01:17:16 +1000 (AEST)","from mail.ozlabs.org (mail.ozlabs.org [IPv6:2404:9400:2221:ea00::3])\n\tby gandalf.ozlabs.org (Postfix) with ESMTP id 4fxz5275Z5z4wJr\n\tfor <incoming@patchwork.ozlabs.org>; Sat, 18 Apr 2026 01:17:10 +1000 (AEST)","by gandalf.ozlabs.org (Postfix)\n\tid 4fxz526wpkz4wK5; Sat, 18 Apr 2026 01:17:10 +1000 (AEST)","from sea.lore.kernel.org (sea.lore.kernel.org [172.234.253.10])\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 4fxz4y6Ry3z4wJr\n\tfor <patchwork-incoming@ozlabs.org>; Sat, 18 Apr 2026 01:17:06 +1000 (AEST)","from smtp.subspace.kernel.org (conduit.subspace.kernel.org\n [100.90.174.1])\n\tby sea.lore.kernel.org (Postfix) with ESMTP id B41B7305FFF6\n\tfor <patchwork-incoming@ozlabs.org>; Fri, 17 Apr 2026 15:14:37 +0000 (UTC)","from localhost.localdomain (localhost.localdomain [127.0.0.1])\n\tby smtp.subspace.kernel.org (Postfix) with ESMTP id 8669C3C661A;\n\tFri, 17 Apr 2026 15:14:36 +0000 (UTC)","from outgoing.mit.edu (outgoing-auth-1.mit.edu [18.9.28.11])\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 D7DCE2989BC\n\tfor <linux-ext4@vger.kernel.org>; Fri, 17 Apr 2026 15:14:34 +0000 (UTC)","from trampoline.thunk.org (pool-173-48-114-3.bstnma.fios.verizon.net\n [173.48.114.3])\n\t(authenticated bits=0)\n        (User authenticated as tytso@ATHENA.MIT.EDU)\n\tby outgoing.mit.edu (8.14.7/8.12.4) with ESMTP id 63HFENSw013891\n\t(version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT);\n\tFri, 17 Apr 2026 11:14:24 -0400","by trampoline.thunk.org (Postfix, from userid 15806)\n\tid 3490B2E00D6; Fri, 17 Apr 2026 11:14:23 -0400 (EDT)"],"ARC-Seal":["i=2; a=rsa-sha256; d=ozlabs.org; s=201707; t=1776439030; cv=pass;\n\tb=VOEvb+atS0PQQRobuY3YK5dhwhKSPEtEGkfXVO03ns4G6p/txyJexjJQMWeQfN/dT5JCx3mj+DylU5NGnn3PgDUh/i9GCuHnoF+utokcOhDYuQxsTf2xbrEFCCJYDsfNYXzWMgSfRi93XV5AySMXHofsrMdk0SoQptWz6LZs7MU4JBeB5KY2PdogUEBZDcRqV5g71n7BohrqJaTcx+xaXg0NA6i7MB9HQ5QUV6xy0L8BkG/mm4+d/cE/qZgY4mQTwwscm0bv7BEI1MkPbhioDyhmj9+RtFIIcF2YnKuWIjUqU5BQBkRJ66mR+JKseFWQwj1P1aa1Es3WE5XATIus4A==","i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116;\n\tt=1776438876; cv=none;\n b=BBzlMZ9PBhW0OsUFozJwR/pp/tVa/1Ucu8GpGyV0T9L7iFHhvME/OXrG2PvaoJvHVp2C41QNgkblfQtI/hGZ7XApGNluY8YMUrRijZcpcJdjtmnTsr91n+25GrMwQb+I+mSxQaEo7YJB9XmQLl/gevpY+qQjs53aQYlzC+9ADgg="],"ARC-Message-Signature":["i=2; a=rsa-sha256; d=ozlabs.org; s=201707;\n\tt=1776439030; c=relaxed/relaxed;\n\tbh=EKHVeJD9dY7hQy8W1IlIYquK7wolhNCE4s2J1NMSI9Y=;\n\th=Date:From:To:Cc:Subject:Message-ID:MIME-Version:Content-Type:\n\t Content-Disposition;\n b=eRsGslbtEVARwdsFyBnZ+9wNoXsz0lhOWI9VUErfr0QxiTtIZChnkLY0/W49SxHxFlZRdn6UmtL4kDStaU1Ms6xKB2I6gIuqs0J8AEqRwzteEKg4Hs9yaSkMCL4dxjk94lzXz52/qxYvCxaMPOvgNoGHOqtaNCtfnaxiVXheOLTZtb7wJTXhPmtn4z/ePyeIMoHZoFNnl0X10SjnWYzpn3k3QMc0GtbgkucRkUwdvAYgmpTkQge6CnIanAgCgWjqzxEf5Rj0JJ20gbRlOLwL7j/TtgGhy+8LE6UwRBZ4kb8Wyu5fT+jtuFTVi8H2dXyPxZs5hEp6ujJEYw2mbTq9yA==","i=1; a=rsa-sha256; d=subspace.kernel.org;\n\ts=arc-20240116; t=1776438876; c=relaxed/simple;\n\tbh=o0UJ+gc5WHEzlj1JkE/KZChTlTpklXU12GQ7rXrZVvY=;\n\th=Date:From:To:Cc:Subject:Message-ID:MIME-Version:Content-Type:\n\t Content-Disposition;\n b=pbft25AO/LfYOGkR1U75wNpnjQwtpBDluW8VJLv77R9ye3Y2W1SAdQwM+O8bcJtWgLmHD1yeVVXHdZmuIoOEGkkcPE44JyX5XhYGKWMEy+KSeQd3IEII5uxQeWYnf7nnhK0bossqDnyqsws/PD/LbOxOjVpDgxcdr5s0/qMqKsU="],"ARC-Authentication-Results":["i=2; gandalf.ozlabs.org;\n dmarc=pass (p=none dis=none) header.from=mit.edu; dkim=pass (2048-bit key;\n unprotected) header.d=mit.edu header.i=@mit.edu header.a=rsa-sha256\n header.s=outgoing header.b=XD9EjQnp; dkim-atps=neutral;\n spf=pass (client-ip=172.234.253.10; helo=sea.lore.kernel.org;\n envelope-from=linux-ext4+bounces-15886-patchwork-incoming=ozlabs.org@vger.kernel.org;\n receiver=ozlabs.org) smtp.mailfrom=vger.kernel.org","i=1; smtp.subspace.kernel.org;\n dmarc=pass (p=none dis=none) header.from=mit.edu;\n spf=pass smtp.mailfrom=mit.edu;\n dkim=pass (2048-bit key) header.d=mit.edu header.i=@mit.edu\n header.b=XD9EjQnp; arc=none smtp.client-ip=18.9.28.11"],"DKIM-Signature":"v=1; a=rsa-sha256; c=relaxed/relaxed; d=mit.edu; s=outgoing;\n\tt=1776438864; bh=EKHVeJD9dY7hQy8W1IlIYquK7wolhNCE4s2J1NMSI9Y=;\n\th=Date:From:Subject:Message-ID:MIME-Version:Content-Type;\n\tb=XD9EjQnpQWm7jPXVBmwAljneZJN2F3vOk5NDRO2PIHty7Z8S8X1kqi49N+PwNZleM\n\t kg0ZogRxFoaXGK6TNMNTwt02FXGievegEh5zxflY/LBbiS1WVfo5WB3JttW93mCa6y\n\t VA2OF4MIEbCecO9hK/bqky2dNWF4jcw5n2EdwPMnZcUlP4LtWmKvdm9Lrpp5GXNSkZ\n\t rloibSruwESKhRrAbOEN6HjDwxg6RbPqqMVhtv/2A//1oNS3o3Xw11rMYD22k9sE50\n\t Uiy9nlR++7it3jSeJMiwkEzvDMJj2EyN6iG7tgQDoEDbdkxagxYiPfA8uXXNjaJeQJ\n\t I3k8h+AQ8Gq0g==","Date":"Fri, 17 Apr 2026 11:14:23 -0400","From":"\"Theodore Ts'o\" <tytso@mit.edu>","To":"Linus Torvalds <torvalds@linux-foundation.org>","Cc":"Linux Kernel Developers List <linux-kernel@vger.kernel.org>,\n        Ext4 Developers List <linux-ext4@vger.kernel.org>","Subject":"[GIT PULL] ext4 changes for 7.1-rc1","Message-ID":"<20260417151423.GA1808289@mit.edu>","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-Type":"text/plain; charset=us-ascii","Content-Disposition":"inline","X-Spam-Status":"No, score=-1.2 required=5.0 tests=ARC_SIGNED,ARC_VALID,\n\tDKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DMARC_PASS,\n\tHEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,SPF_HELO_NONE,\n\tSPF_PASS autolearn=disabled version=4.0.1","X-Spam-Checker-Version":"SpamAssassin 4.0.1 (2024-03-25) on gandalf.ozlabs.org"},"content":"The following changes since commit 9ee29d20aab228adfb02ca93f87fb53c56c2f3af:\n\n  ext4: always drain queued discard work in ext4_mb_release() (2026-03-27 23:39:10 -0400)\n\nare available in the Git repository at:\n\n  https://git.kernel.org/pub/scm/linux/kernel/git/tytso/ext4.git tags/ext4_for_linux-7.0-rc1\n\nfor you to fetch changes up to 981fcc5674e67158d24d23e841523eccba19d0e7:\n\n  jbd2: fix deadlock in jbd2_journal_cancel_revoke() (2026-04-09 22:09:39 -0400)\n\n----------------------------------------------------------------\nVarious clean ups and bug fixes in ext4 for 7.1:\n\n  * Refactor code paths involved with partial block zero-out in\n    prearation for converting ext4 to use iomap for buffered writes.\n  * Remove use of d_alloc() from ext4 in preparation for the deprecation\n    of this interface.\n  * Replace some J_ASSERTS with a journal abort so we can avoid a kernel\n    panic for a localized file system error\n  * Simplify various code paths in mballoc, move_extent, and fast commit\n  * Fix rare deadlock in jbd2_journal_cancel_revoke() that can be\n    triggered by generic/013 when blocksize < pagesize.\n  * Fix memory leak when releasing an extended attribute when its\n    value is stored in an ea_inode\n  * Fix various potential kunit test bugs in fs/ext4/extents.c\n  * Fix potential out-of-bounds access in check_xattr() with a corrupted\n    file system\n  * Make the jbd2_inode dirty range tracking safe for lockless reads\n  * Avoid a WARN_ON when writeback files due to a corrupted file system;\n    we already print an ext4 warning indicatign that data will be lost,\n    so the WARN_ON is not necessary and doesn't add any new information\n\n----------------------------------------------------------------\nDavid Laight (1):\n      ext4: fix diagnostic printf formats\n\nDeepanshu Kartikey (2):\n      ext4: unmap invalidated folios from page tables in mpage_release_unused_pages()\n      ext4: fix bounds check in check_xattrs() to prevent out-of-bounds access\n\nGuoqing Jiang (1):\n      ext4: remove tl argument from ext4_fc_replay_{add,del}_range\n\nJulia Lawall (1):\n      ext4/move_extent: use folio_next_pos()\n\nLi Chen (5):\n      ext4: remove unused i_fc_wait\n      jbd2: add jinode dirty range accessors\n      ext4: use jbd2 jinode dirty range accessor\n      ocfs2: use jbd2 jinode dirty range accessor\n      jbd2: store jinode dirty range in PAGE_SIZE units\n\nMilos Nikic (2):\n      jbd2: gracefully abort instead of panicking on unlocked buffer\n      jbd2: gracefully abort on transaction state corruptions\n\nNeilBrown (3):\n      ext4: split __ext4_add_entry() out of ext4_add_entry()\n      ext4: add ext4_fc_eligible()\n      ext4: move dcache manipulation out of __ext4_link()\n\nPhilipp Hahn (1):\n      ext4: prefer IS_ERR_OR_NULL over manual NULL check\n\nSohei Koyama (1):\n      ext4: fix missing brelse() in ext4_xattr_inode_dec_ref_all()\n\nWeixie Cui (1):\n      ext4: simplify mballoc preallocation size rounding for small files\n\nYe Bin (5):\n      ext4: fix miss unlock 'sb->s_umount' in extents_kunit_init()\n      ext4: call deactivate_super() in extents_kunit_exit()\n      ext4: fix the error handling process in extents_kunit_init).\n      ext4: fix possible null-ptr-deref in extents_kunit_exit()\n      ext4: fix possible null-ptr-deref in mbt_kunit_exit()\n\nZhang Yi (14):\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      jbd2: fix deadlock in jbd2_journal_cancel_revoke()\n\n fs/ext4/ext4.h         |  14 +--\n fs/ext4/extents-test.c |  60 +++++++---\n fs/ext4/extents.c      | 163 +++++++++++++-------------\n fs/ext4/fast_commit.c  |  89 ++++-----------\n fs/ext4/file.c         |  17 +++\n fs/ext4/inode.c        | 304 ++++++++++++++++++++++++++++++++-----------------\n fs/ext4/mballoc-test.c |   6 +-\n fs/ext4/mballoc.c      |  26 ++---\n fs/ext4/move_extent.c  |   4 +-\n fs/ext4/namei.c        |  48 ++++----\n fs/ext4/super.c        |  16 ++-\n fs/ext4/symlink.c      |   2 +-\n fs/ext4/xattr.c        |   6 +-\n fs/jbd2/commit.c       |  55 ++++++---\n fs/jbd2/journal.c      |   5 +-\n fs/jbd2/revoke.c       |   8 +-\n fs/jbd2/transaction.c  | 142 +++++++++++++++++------\n fs/ocfs2/journal.c     |   9 +-\n include/linux/jbd2.h   |  38 +++++--\n 19 files changed, 628 insertions(+), 384 deletions(-)","diff":null,"prefixes":["GIT","PULL"]}