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
CVSS v2 : unknown
v3 : unknown
v2 : unknown
v3 : 5.5
CWE CWE-667
CPE cpe:2.3:o:linux:linux_kernel:6.9:rc2:*:*:*:*:*:*
cpe:2.3:o:debian:debian_linux:10.0:*:*:*:*:*:*:*
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*
cpe:2.3:o:linux:linux_kernel:6.9:rc1:*:*:*:*:*:*
First Time Debian debian Linux
Debian
Linux
Linux linux Kernel
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

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'}

21 Nov 2024, 09:21

Type Values Removed Values Added
References
  • () https://lists.debian.org/debian-lts-announce/2024/06/msg00017.html -
References () https://git.kernel.org/stable/c/668b3074aa14829e2ac2759799537a93b60fef86 - () https://git.kernel.org/stable/c/668b3074aa14829e2ac2759799537a93b60fef86 -
References () https://git.kernel.org/stable/c/6af057ccdd8e7619960aca1f0428339f213b31cd - () https://git.kernel.org/stable/c/6af057ccdd8e7619960aca1f0428339f213b31cd -
References () https://git.kernel.org/stable/c/a44770fed86515eedb5a7c00b787f847ebb134a5 - () https://git.kernel.org/stable/c/a44770fed86515eedb5a7c00b787f847ebb134a5 -
References () https://git.kernel.org/stable/c/d1e73fb19a4c872d7a399ad3c66e8ca30e0875ec - () https://git.kernel.org/stable/c/d1e73fb19a4c872d7a399ad3c66e8ca30e0875ec -
References () https://git.kernel.org/stable/c/dd54b48db0c822ae7b520bc80751f0a0a173ef75 - () https://git.kernel.org/stable/c/dd54b48db0c822ae7b520bc80751f0a0a173ef75 -
References () https://git.kernel.org/stable/c/f7990498b05ac41f7d6a190dc0418ef1d21bf058 - () https://git.kernel.org/stable/c/f7990498b05ac41f7d6a190dc0418ef1d21bf058 -
References () https://git.kernel.org/stable/c/ff91059932401894e6c86341915615c5eb0eca48 - () https://git.kernel.org/stable/c/ff91059932401894e6c86341915615c5eb0eca48 -

29 Aug 2024, 17:15

Type Values Removed Values Added
References
  • {'url': 'https://lists.debian.org/debian-lts-announce/2024/06/msg00017.html', 'source': '416baaa9-dc9f-4396-8d5f-8c081fb06d67'}
  • () https://git.kernel.org/stable/c/913c30f827e17d8cda1da6eeb990f350d36cb69b -

25 Jun 2024, 22:15

Type Values Removed Values Added
References
  • () https://lists.debian.org/debian-lts-announce/2024/06/msg00017.html -
Summary
  • (es) En el kernel de Linux, se ha resuelto la siguiente vulnerabilidad: bpf, sockmap: Evitar el punto muerto de inversión de bloqueo en la eliminación del mapa elem syzkaller comenzó a usar corpus donde un programa de seguimiento BPF elimina elementos de un mapa sockmap/sockhash. Debido a que los programas de seguimiento BPF se pueden invocar desde cualquier contexto de interrupción, los bloqueos realizados durante una operación map_delete_elem deben ser seguros. De lo contrario, es posible que se produzca un punto muerto debido a la inversión del bloqueo, como lo informa lockdep: CPU0 CPU1 ---- ---- lock(&amp;htab-&gt;buckets[i].lock); local_irq_disable(); bloquear(&amp;host-&gt;bloquear); lock(&amp;htab-&gt;cubos[i].lock); bloqueo(&amp;host-&gt;bloqueo); Los bloqueos en sockmap son difíciles de inseguro por diseño. Esperamos que los elementos se eliminen de sockmap/sockhash solo en el contexto de la tarea (normal) con las interrupciones habilitadas o en el contexto de softirq. Detecta cuándo se invoca la operación map_delete_elem desde un contexto que _no_ es hardirq-inseguro, es decir, las interrupciones están deshabilitadas y sale con un error. Tenga en cuenta que las actualizaciones de mapas no se ven afectadas por este problema. El verificador de BPF no permite actualizar sockmap/sockhash desde un programa de seguimiento de BPF en la actualidad.

19 May 2024, 09:15

Type Values Removed Values Added
New CVE

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