CVE-2024-35895

In the Linux kernel, the following vulnerability has been resolved: bpf, sockmap: Prevent lock inversion deadlock in map delete elem syzkaller started using corpuses where a BPF tracing program deletes elements from a sockmap/sockhash map. Because BPF tracing programs can be invoked from any interrupt context, locks taken during a map_delete_elem operation must be hardirq-safe. Otherwise a deadlock due to lock inversion is possible, as reported by lockdep: CPU0 CPU1 ---- ---- lock(&htab->buckets[i].lock); local_irq_disable(); lock(&host->lock); lock(&htab->buckets[i].lock); <Interrupt> lock(&host->lock); Locks in sockmap are hardirq-unsafe by design. We expects elements to be deleted from sockmap/sockhash only in task (normal) context with interrupts enabled, or in softirq context. Detect when map_delete_elem operation is invoked from a context which is _not_ hardirq-unsafe, that is interrupts are disabled, and bail out with an error. Note that map updates are not affected by this issue. BPF verifier does not allow updating sockmap/sockhash from a BPF tracing program today.
Configurations

Configuration 1 (hide)

OR cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*
cpe:2.3:o:linux:linux_kernel:6.9:rc1:*:*:*:*:*:*
cpe:2.3:o:linux:linux_kernel:6.9:rc2:*:*:*:*:*:*

Configuration 2 (hide)

cpe:2.3:o:debian:debian_linux:10.0:*:*:*:*:*:*:*

History

30 Dec 2024, 17:12

Type Values Removed Values Added
References () https://git.kernel.org/stable/c/668b3074aa14829e2ac2759799537a93b60fef86 - () https://git.kernel.org/stable/c/668b3074aa14829e2ac2759799537a93b60fef86 - Patch
References () https://git.kernel.org/stable/c/6af057ccdd8e7619960aca1f0428339f213b31cd - () https://git.kernel.org/stable/c/6af057ccdd8e7619960aca1f0428339f213b31cd - Patch
References () https://git.kernel.org/stable/c/a44770fed86515eedb5a7c00b787f847ebb134a5 - () https://git.kernel.org/stable/c/a44770fed86515eedb5a7c00b787f847ebb134a5 - Patch
References () https://git.kernel.org/stable/c/d1e73fb19a4c872d7a399ad3c66e8ca30e0875ec - () https://git.kernel.org/stable/c/d1e73fb19a4c872d7a399ad3c66e8ca30e0875ec - Patch
References () https://git.kernel.org/stable/c/dd54b48db0c822ae7b520bc80751f0a0a173ef75 - () https://git.kernel.org/stable/c/dd54b48db0c822ae7b520bc80751f0a0a173ef75 - Patch
References () https://git.kernel.org/stable/c/f7990498b05ac41f7d6a190dc0418ef1d21bf058 - () https://git.kernel.org/stable/c/f7990498b05ac41f7d6a190dc0418ef1d21bf058 - Patch
References () https://git.kernel.org/stable/c/ff91059932401894e6c86341915615c5eb0eca48 - () https://git.kernel.org/stable/c/ff91059932401894e6c86341915615c5eb0eca48 - Patch
References () https://lists.debian.org/debian-lts-announce/2024/06/msg00017.html - () https://lists.debian.org/debian-lts-announce/2024/06/msg00017.html - Mailing List
CPE cpe:2.3:o:debian:debian_linux:10.0:*:*:*:*:*:*:*
cpe:2.3:o:linux:linux_kernel:6.9:rc2:*:*:*:*:*:*
cpe:2.3:o:linux:linux_kernel:6.9:rc1:*:*:*:*:*:*
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*
CWE CWE-667
CVSS v2 : unknown
v3 : unknown
v2 : unknown
v3 : 5.5
First Time Debian
Linux linux Kernel
Debian debian Linux
Linux

27 Dec 2024, 13:15

Type Values Removed Values Added
References
  • {'url': 'https://git.kernel.org/stable/c/913c30f827e17d8cda1da6eeb990f350d36cb69b', 'source': '416baaa9-dc9f-4396-8d5f-8c081fb06d67'}

Information

Published : 2024-05-19 09:15

Updated : 2024-12-30 17:12


NVD link : CVE-2024-35895

Mitre link : CVE-2024-35895

CVE.ORG link : CVE-2024-35895


JSON object : View

Products Affected

linux

  • linux_kernel

debian

  • debian_linux
CWE
CWE-667

Improper Locking