Description
In the Linux kernel, the following vulnerability has been resolved: ocfs2: fix out-of-bounds write in ocfs2_write_end_inline KASAN reports a use-after-free write of 4086 bytes in ocfs2_write_end_inline, called from ocfs2_write_end_nolock during a copy_file_range splice fallback on a corrupted ocfs2 filesystem mounted on a loop device. The actual bug is an out-of-bounds write past the inode block buffer, not a true use-after-free. The write overflows into an adjacent freed page, which KASAN reports as UAF. The root cause is that ocfs2_try_to_write_inline_data trusts the on-disk id_count field to determine whether a write fits in inline data. On a corrupted filesystem, id_count can exceed the physical maximum inline data capacity, causing writes to overflow the inode block buffer. Call trace (crash path): vfs_copy_file_range (fs/read_write.c:1634) do_splice_direct splice_direct_to_actor iter_file_splice_write ocfs2_file_write_iter generic_perform_write ocfs2_write_end ocfs2_write_end_nolock (fs/ocfs2/aops.c:1949) ocfs2_write_end_inline (fs/ocfs2/aops.c:1915) memcpy_from_folio <-- KASAN: write OOB So add id_count upper bound check in ocfs2_validate_inode_block() to alongside the existing i_size check to fix it.
Product status
1afc32b952335f665327a1a9001ba1b44bb76fd9 (git) before e2c9dc6b6e96f3585f2a1062ca3374a52db0938f
1afc32b952335f665327a1a9001ba1b44bb76fd9 (git) before 947f953978b0d9463498d548d0f054f5a75be2e9
1afc32b952335f665327a1a9001ba1b44bb76fd9 (git) before 0c1af902223b6fcedb60904ca0b551254686c7b9
1afc32b952335f665327a1a9001ba1b44bb76fd9 (git) before 69d3c69ade1e4285ab4ca48fe7acee0767e65604
1afc32b952335f665327a1a9001ba1b44bb76fd9 (git) before 7bc5da4842bed3252d26e742213741a4d0ac1b14
2.6.24
Any version before 2.6.24
6.6.136 (semver)
6.12.83 (semver)
6.18.24 (semver)
6.19.14 (semver)
7.0 (original_commit_for_fix)
References
git.kernel.org/...c/e2c9dc6b6e96f3585f2a1062ca3374a52db0938f
git.kernel.org/...c/947f953978b0d9463498d548d0f054f5a75be2e9
git.kernel.org/...c/0c1af902223b6fcedb60904ca0b551254686c7b9
git.kernel.org/...c/69d3c69ade1e4285ab4ca48fe7acee0767e65604
git.kernel.org/...c/7bc5da4842bed3252d26e742213741a4d0ac1b14