CVE-2024-39277

CVSS v3.1 7.8 (High)
78% Progress
EPSS 0.04 % (5th)
0.04% Progress
Affected Products 1
Advisories 11
NVD Status Modified

In the Linux kernel, the following vulnerability has been resolved:

dma-mapping: benchmark: handle NUMA_NO_NODE correctly

cpumask_of_node() can be called for NUMA_NO_NODE inside do_map_benchmark()
resulting in the following sanitizer report:

UBSAN: array-index-out-of-bounds in ./arch/x86/include/asm/topology.h:72:28
index -1 is out of range for type 'cpumask [64][1]'
CPU: 1 PID: 990 Comm: dma_map_benchma Not tainted 6.9.0-rc6 #29
Hardware name: QEMU Standard PC (i440FX + PIIX, 1996)
Call Trace:
<TASK>
dump_stack_lvl (lib/dump_stack.c:117)
ubsan_epilogue (lib/ubsan.c:232)
__ubsan_handle_out_of_bounds (lib/ubsan.c:429)
cpumask_of_node (arch/x86/include/asm/topology.h:72) [inline]
do_map_benchmark (kernel/dma/map_benchmark.c:104)
map_benchmark_ioctl (kernel/dma/map_benchmark.c:246)
full_proxy_unlocked_ioctl (fs/debugfs/file.c:333)
__x64_sys_ioctl (fs/ioctl.c:890)
do_syscall_64 (arch/x86/entry/common.c:83)
entry_SYSCALL_64_after_hwframe (arch/x86/entry/entry_64.S:130)

Use cpumask_of_node() in place when binding a kernel thread to a cpuset
of a particular node.

Note that the provided node id is checked inside map_benchmark_ioctl().
It's just a NUMA_NO_NODE case which is not handled properly later.

Found by Linux Verification Center (linuxtesting.org).

Weaknesses
CWE-125
Out-of-bounds Read
CVE Status
PUBLISHED
NVD Status
Modified
CNA
kernel.org
Published Date
2024-06-21 12:15:11
(2 months ago)
Updated Date
2024-08-20 14:35:25
(4 weeks ago)

Affected Products

Loading...
Loading...
Loading...

Configuration #1

    CPE23 From Up To
  Linux Kernel prior 5.11 version cpe:2.3:o:linux:linux_kernel < 5.11
  Linux Kernel from 5.15 version and prior 5.15.161 version cpe:2.3:o:linux:linux_kernel >= 5.15 < 5.15.161
  Linux Kernel from 6.1 version and prior 6.1.93 version cpe:2.3:o:linux:linux_kernel >= 6.1 < 6.1.93
  Linux Kernel from 6.6 version and prior 6.6.33 version cpe:2.3:o:linux:linux_kernel >= 6.6 < 6.6.33
  Linux Kernel from 6.9 version and prior 6.9.4 version cpe:2.3:o:linux:linux_kernel >= 6.9 < 6.9.4
  Linux Kernel 6.10.0 Rc1 cpe:2.3:o:linux:linux_kernel:6.10.0:rc1
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...