First published: Fri Sep 13 2024(Updated: )
In the Linux kernel, the following vulnerability has been resolved: libfs: fix infinite directory reads for offset dir After we switch tmpfs dir operations from simple_dir_operations to simple_offset_dir_operations, every rename happened will fill new dentry to dest dir's maple tree(&SHMEM_I(inode)->dir_offsets->mt) with a free key starting with octx->newx_offset, and then set newx_offset equals to free key + 1. This will lead to infinite readdir combine with rename happened at the same time, which fail generic/736 in xfstests(detail show as below). 1. create 5000 files(1 2 3...) under one dir 2. call readdir(man 3 readdir) once, and get one entry 3. rename(entry, "TEMPFILE"), then rename("TEMPFILE", entry) 4. loop 2~3, until readdir return nothing or we loop too many times(tmpfs break test with the second condition) We choose the same logic what commit 9b378f6ad48cf ("btrfs: fix infinite directory reads") to fix it, record the last_index when we open dir, and do not emit the entry which index >= last_index. The file->private_data now used in offset dir can use directly to do this, and we also update the last_index when we llseek the dir file. [brauner: only update last_index after seek when offset is zero like Jan suggested]
Credit: 416baaa9-dc9f-4396-8d5f-8c081fb06d67 416baaa9-dc9f-4396-8d5f-8c081fb06d67
Affected Software | Affected Version | How to fix |
---|---|---|
Linux kernel | >=6.6<6.10.7 | |
Linux kernel | =6.11-rc1 | |
Linux kernel | =6.11-rc2 | |
Linux kernel | =6.11-rc3 | |
Linux Kernel | >=6.6<6.10.7 | |
Linux Kernel | =6.11-rc1 | |
Linux Kernel | =6.11-rc2 | |
Linux Kernel | =6.11-rc3 | |
debian/linux | 5.10.223-1 5.10.234-1 6.1.123-1 6.1.128-1 6.12.17-1 |
Sign up to SecAlerts for real-time vulnerability data matched to your software, aggregated from hundreds of sources.
CVE-2024-46701 is classified as a vulnerability in the Linux kernel affecting directory operations.
To fix CVE-2024-46701, upgrade the Linux kernel to a version that is patched, such as 5.10.223-1, 5.10.226-1, or 6.12.11-1.
CVE-2024-46701 affects Linux kernel versions from 6.6 to 6.10.7 and specific release candidates 6.11-rc1, 6.11-rc2, and 6.11-rc3.
CVE-2024-46701 addresses an infinite directory reads issue in libfs related to the kernel directory operations.
CVE-2024-46701 is classified as a local vulnerability affecting filesystem operations in the Linux kernel.