CVE-2024-39469 Information
Description
In the Linux kernel the following vulnerability has been resolved:
nilfs2: fix nilfs_empty_dir() misjudgment and long loop on I/O errors
The error handling in nilfs_empty_dir() when a directory folio/page read fails is incorrect as in the old ext2 implementation and if the folio/page cannot be read or nilfs_check_folio() fails it will falsely determine the directory as empty and corrupt the file system.
In addition since nilfs_empty_dir() does not immediately return on a failed folio/page read but continues to loop this can cause a long loop with I/O if i_size of the directory’s inode is also corrupted causing the log writer thread to wait and hang as reported by syzbot.
Fix these issues by making nilfs_empty_dir() immediately return a false value (0) if it fails to get a directory folio/page.
Reference
https://git.kernel.org/stable/c/129dcd3e7d036218db3f59c82d82004b9539ed82 https://git.kernel.org/stable/c/d18b05eda7fa77f02114f15b02c009f28ee42346 https://git.kernel.org/stable/c/59f14875a96ef93f05b82ad3c980605f2cb444b5 https://git.kernel.org/stable/c/7373a51e7998b508af7136530f3a997b286ce81c
Share on: