]> git.ipfire.org Git - thirdparty/kernel/stable-queue.git/commitdiff
drop queue-6.6/nilfs2-handle-inconsistent-state-in-nilfs_btnode_create_block.patch
authorGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 29 Jul 2024 14:08:35 +0000 (16:08 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 29 Jul 2024 14:08:35 +0000 (16:08 +0200)
queue-6.6/nilfs2-handle-inconsistent-state-in-nilfs_btnode_create_block.patch [deleted file]
queue-6.6/series

diff --git a/queue-6.6/nilfs2-handle-inconsistent-state-in-nilfs_btnode_create_block.patch b/queue-6.6/nilfs2-handle-inconsistent-state-in-nilfs_btnode_create_block.patch
deleted file mode 100644 (file)
index 0acb738..0000000
+++ /dev/null
@@ -1,97 +0,0 @@
-From 4811f7af6090e8f5a398fbdd766f903ef6c0d787 Mon Sep 17 00:00:00 2001
-From: Ryusuke Konishi <konishi.ryusuke@gmail.com>
-Date: Thu, 25 Jul 2024 14:20:07 +0900
-Subject: nilfs2: handle inconsistent state in nilfs_btnode_create_block()
-
-From: Ryusuke Konishi <konishi.ryusuke@gmail.com>
-
-commit 4811f7af6090e8f5a398fbdd766f903ef6c0d787 upstream.
-
-Syzbot reported that a buffer state inconsistency was detected in
-nilfs_btnode_create_block(), triggering a kernel bug.
-
-It is not appropriate to treat this inconsistency as a bug; it can occur
-if the argument block address (the buffer index of the newly created
-block) is a virtual block number and has been reallocated due to
-corruption of the bitmap used to manage its allocation state.
-
-So, modify nilfs_btnode_create_block() and its callers to treat it as a
-possible filesystem error, rather than triggering a kernel bug.
-
-Link: https://lkml.kernel.org/r/20240725052007.4562-1-konishi.ryusuke@gmail.com
-Fixes: a60be987d45d ("nilfs2: B-tree node cache")
-Signed-off-by: Ryusuke Konishi <konishi.ryusuke@gmail.com>
-Reported-by: syzbot+89cc4f2324ed37988b60@syzkaller.appspotmail.com
-Closes: https://syzkaller.appspot.com/bug?extid=89cc4f2324ed37988b60
-Cc: <stable@vger.kernel.org>
-Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
-Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
----
- fs/nilfs2/btnode.c |   25 ++++++++++++++++++++-----
- fs/nilfs2/btree.c  |    4 ++--
- 2 files changed, 22 insertions(+), 7 deletions(-)
-
---- a/fs/nilfs2/btnode.c
-+++ b/fs/nilfs2/btnode.c
-@@ -51,12 +51,21 @@ nilfs_btnode_create_block(struct address
-       bh = nilfs_grab_buffer(inode, btnc, blocknr, BIT(BH_NILFS_Node));
-       if (unlikely(!bh))
--              return NULL;
-+              return ERR_PTR(-ENOMEM);
-       if (unlikely(buffer_mapped(bh) || buffer_uptodate(bh) ||
-                    buffer_dirty(bh))) {
--              brelse(bh);
--              BUG();
-+              /*
-+               * The block buffer at the specified new address was already
-+               * in use.  This can happen if it is a virtual block number
-+               * and has been reallocated due to corruption of the bitmap
-+               * used to manage its allocation state (if not, the buffer
-+               * clearing of an abandoned b-tree node is missing somewhere).
-+               */
-+              nilfs_error(inode->i_sb,
-+                          "state inconsistency probably due to duplicate use of b-tree node block address %llu (ino=%lu)",
-+                          (unsigned long long)blocknr, inode->i_ino);
-+              goto failed;
-       }
-       memset(bh->b_data, 0, i_blocksize(inode));
-       bh->b_bdev = inode->i_sb->s_bdev;
-@@ -67,6 +76,12 @@ nilfs_btnode_create_block(struct address
-       unlock_page(bh->b_page);
-       put_page(bh->b_page);
-       return bh;
-+
-+failed:
-+      folio_unlock(bh->b_folio);
-+      folio_put(bh->b_folio);
-+      brelse(bh);
-+      return ERR_PTR(-EIO);
- }
- int nilfs_btnode_submit_block(struct address_space *btnc, __u64 blocknr,
-@@ -217,8 +232,8 @@ retry:
-       }
-       nbh = nilfs_btnode_create_block(btnc, newkey);
--      if (!nbh)
--              return -ENOMEM;
-+      if (IS_ERR(nbh))
-+              return PTR_ERR(nbh);
-       BUG_ON(nbh == obh);
-       ctxt->newbh = nbh;
---- a/fs/nilfs2/btree.c
-+++ b/fs/nilfs2/btree.c
-@@ -63,8 +63,8 @@ static int nilfs_btree_get_new_block(con
-       struct buffer_head *bh;
-       bh = nilfs_btnode_create_block(btnc, ptr);
--      if (!bh)
--              return -ENOMEM;
-+      if (IS_ERR(bh))
-+              return PTR_ERR(bh);
-       set_buffer_nilfs_volatile(bh);
-       *bhp = bh;
index 10ee3cffa5fe5e8f3850a431526921cdf53d4e15..5d8b3b16909288b518629a7d6eb2dde44f101480 100644 (file)
@@ -439,4 +439,3 @@ f2fs-fix-to-don-t-dirty-inode-for-readonly-filesystem.patch
 f2fs-fix-return-value-of-f2fs_convert_inline_inode.patch
 f2fs-use-meta-inode-for-gc-of-atomic-file.patch
 f2fs-use-meta-inode-for-gc-of-cow-file.patch
-nilfs2-handle-inconsistent-state-in-nilfs_btnode_create_block.patch