CVE-2024-26906: x86/mm: Disallow vsyscall page read for copy_from_kernel_nofault()
In the Linux kernel, the following vulnerability has been resolved:
x86/mm: Disallow vsyscall page read for copyfromkernelnofault()
The Linux kernel CVE team has assigned CVE-2024-26906 to this issue.
Upstream advisory: https://lore.kernel.org/linux-cve-announce/2024041746-CVE-2024-26906-bb35@gregkh/T
Other sources
In the Linux kernel, the following vulnerability has been resolved:
x86/mm: Disallow vsyscall page read for copyfromkernelnofault()
When trying to use copyfromkernelnofault() to read vsyscall page through a bpf program, the following oops was reported:
BUG: unable to handle page fault for address: ffffffffff600000 #PF: supervisor read access in kernel mode #PF: errorcode(0x0000) - not-present page PGD 3231067 P4D 3231067 PUD 3233067 PMD 3235067 PTE 0 Oops: 0000 [#1] PREEMPT SMP PTI CPU: 1 PID: 20390 Comm: testprogs ...... 6.7.0+ #58 Hardware name: QEMU Standard PC (i440FX + PIIX, 1996) ...... RIP: 0010:copyfromkernelnofault+0x6f/0x110 ...... Call Trace: <TASK> ? copyfromkernelnofault+0x6f/0x110 bpfprobereadkernel+0x1d/0x50 bpfprog2061065e56845f08doproberead+0x51/0x8d tracecallbpf+0xc5/0x1c0 perfcallbpfenter.isra.0+0x69/0xb0 perfsyscallenter+0x13e/0x200 syscalltraceenter+0x188/0x1c0 dosyscall64+0xb5/0xe0 entrySYSCALL64afterhwframe+0x6e/0x76 </TASK> ...... ---[ end trace 0000000000000000 ]---
The oops is triggered when:
1) A bpf program uses bpfprobereadkernel() to read from the vsyscall page and invokes copyfromkernelnofault() which in turn calls getuserasm().
2) Because the vsyscall page address is not readable from kernel space, a page fault exception is triggered accordingly.
3) handlepagefault() considers the vsyscall page address as a user space address instead of a kernel space address. This results in the fix-up setup by bpf not being applied and a pagefaultoops() is invoked due to SMAP.
Considering handlepagefault() has already considered the vsyscall page address as a userspace address, fix the problem by disallowing vsyscall page read for copyfromkernelnofault().
— NVD
Linux Kernel is vulnerable to a denial of service, caused by an error related to vsyscall page read for copyfromkernelnofault(). By sending a specially crafted request, a local authenticated attacker could exploit this vulnerability to cause a denial of service.
— IBM
Affected Software
Remediation
Event History
Frequently Asked Questions
What is the severity of CVE-2024-26906?
The severity of CVE-2024-26906 is categorized as high due to its potential impact on system security.
How do I fix CVE-2024-26906?
To fix CVE-2024-26906, update the kernel to versions 5.10.214, 5.15.153, 6.1.83, 6.6.23, 6.7.11, 6.8, or the specific versions provided by your distribution.
Which software is affected by CVE-2024-26906?
Software affected by CVE-2024-26906 includes certain versions of the Linux kernel provided by Red Hat and Debian.
Is there a patch available for CVE-2024-26906?
Yes, a patch for CVE-2024-26906 is available in the updated kernel versions released by the affected distributions.
What are the risks of not addressing CVE-2024-26906?
Not addressing CVE-2024-26906 may leave your system vulnerable to exploitation, which could lead to unauthorized access or data breaches.