]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
ocfs2: add inline inode consistency check to ocfs2_validate_inode_block()
authorDmitry Antipov <dmantipov@yandex.ru>
Mon, 13 Apr 2026 15:19:56 +0000 (11:19 -0400)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 22 Apr 2026 11:22:31 +0000 (13:22 +0200)
[ Upstream commit a2b1c419ff72ec62ff5831684e30cd1d4f0b09ee ]

In 'ocfs2_validate_inode_block()', add an extra check whether an inode
with inline data (i.e.  self-contained) has no clusters, thus preventing
an invalid inode from being passed to 'ocfs2_evict_inode()' and below.

Link: https://lkml.kernel.org/r/20251023141650.417129-1-dmantipov@yandex.ru
Signed-off-by: Dmitry Antipov <dmantipov@yandex.ru>
Reported-by: syzbot+c16daba279a1161acfb0@syzkaller.appspotmail.com
Closes: https://syzkaller.appspot.com/bug?extid=c16daba279a1161acfb0
Reviewed-by: Joseph Qi <joseph.qi@linux.alibaba.com>
Cc: Joseph Qi <jiangqi903@gmail.com>
Cc: Mark Fasheh <mark@fasheh.com>
Cc: Joel Becker <jlbec@evilplan.org>
Cc: Junxiao Bi <junxiao.bi@oracle.com>
Cc: Changwei Ge <gechangwei@live.cn>
Cc: Jun Piao <piaojun@huawei.com>
Cc: Heming Zhao <heming.zhao@suse.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Stable-dep-of: 7bc5da4842be ("ocfs2: fix out-of-bounds write in ocfs2_write_end_inline")
Signed-off-by: Sasha Levin <sashal@kernel.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
fs/ocfs2/inode.c

index 0a0a96054bfecb976dbd3d4ea2767f58ae380761..ef17f1bc741efb3a11ee6a976a4806d6ce398c9f 100644 (file)
@@ -1505,6 +1505,14 @@ int ocfs2_validate_inode_block(struct super_block *sb,
                goto bail;
        }
 
+       if ((le16_to_cpu(di->i_dyn_features) & OCFS2_INLINE_DATA_FL) &&
+           le32_to_cpu(di->i_clusters)) {
+               rc = ocfs2_error(sb, "Invalid dinode %llu: %u clusters\n",
+                                (unsigned long long)bh->b_blocknr,
+                                le32_to_cpu(di->i_clusters));
+               goto bail;
+       }
+
        rc = 0;
 
 bail: