CVE-2025-37989

In the Linux kernel, the following vulnerability has been resolved: net: phy: leds: fix memory leak A network restart test on a router led to an out-of-memory condition, which was traced to a memory leak in the PHY LED trigger code. The root cause is misuse of the devm API. The registration function (phy_led_triggers_register) is called from phy_attach_direct, not phy_probe, and the unregister function (phy_led_triggers_unregister) is called from phy_detach, not phy_remove. This means the register and unregister functions can be called multiple times for the same PHY device, but devm-allocated memory is not freed until the driver is unbound. This also prevents kmemleak from detecting the leak, as the devm API internally stores the allocated pointer. Fix this by replacing devm_kzalloc/devm_kcalloc with standard kzalloc/kcalloc, and add the corresponding kfree calls in the unregister path.
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:*:*:*:*:*:*:*:*
cpe:2.3:o:linux:linux_kernel:6.15:rc1:*:*:*:*:*:*
cpe:2.3:o:linux:linux_kernel:6.15:rc2:*:*:*:*:*:*
cpe:2.3:o:linux:linux_kernel:6.15:rc3:*:*:*:*:*:*

Configuration 2 (hide)

cpe:2.3:o:debian:debian_linux:11.0:*:*:*:*:*:*:*

History

16 Dec 2025, 20:19

Type Values Removed Values Added
CPE cpe:2.3:o:linux:linux_kernel:6.15:rc2:*:*:*:*:*:*
cpe:2.3:o:debian:debian_linux:11.0:*:*:*:*:*:*:*
cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*
cpe:2.3:o:linux:linux_kernel:6.15:rc3:*:*:*:*:*:*
cpe:2.3:o:linux:linux_kernel:6.15:rc1:*:*:*:*:*:*
References () https://git.kernel.org/stable/c/41143e71052a00d654c15dc924fda50c1e7357d0 - () https://git.kernel.org/stable/c/41143e71052a00d654c15dc924fda50c1e7357d0 - Patch
References () https://git.kernel.org/stable/c/618541a6cc1511064dfa58c89b3445e21844092f - () https://git.kernel.org/stable/c/618541a6cc1511064dfa58c89b3445e21844092f - Patch
References () https://git.kernel.org/stable/c/663c3da86e807c6c07ed48f911c7526fad6fe1ff - () https://git.kernel.org/stable/c/663c3da86e807c6c07ed48f911c7526fad6fe1ff - Patch
References () https://git.kernel.org/stable/c/7f3d5880800f962c347777c4f8358f29f5fc403c - () https://git.kernel.org/stable/c/7f3d5880800f962c347777c4f8358f29f5fc403c - Patch
References () https://git.kernel.org/stable/c/95bed65cc0eb2a610550abf849a8b94374da80a7 - () https://git.kernel.org/stable/c/95bed65cc0eb2a610550abf849a8b94374da80a7 - Patch
References () https://git.kernel.org/stable/c/966d6494e2ed9be9052fcd9815afba830896aaf8 - () https://git.kernel.org/stable/c/966d6494e2ed9be9052fcd9815afba830896aaf8 - Patch
References () https://git.kernel.org/stable/c/b7f0ee992adf601aa00c252418266177eb7ac2bc - () https://git.kernel.org/stable/c/b7f0ee992adf601aa00c252418266177eb7ac2bc - Patch
References () https://git.kernel.org/stable/c/f41f097f68a33d392579885426d0734a81219501 - () https://git.kernel.org/stable/c/f41f097f68a33d392579885426d0734a81219501 - Patch
References () https://lists.debian.org/debian-lts-announce/2025/05/msg00045.html - () https://lists.debian.org/debian-lts-announce/2025/05/msg00045.html - Third Party Advisory
First Time Linux
Debian
Debian debian Linux
Linux linux Kernel
CWE CWE-401
CVSS v2 : unknown
v3 : unknown
v2 : unknown
v3 : 5.5

03 Nov 2025, 20:18

Type Values Removed Values Added
Summary
  • (es) En el kernel de Linux, se ha resuelto la siguiente vulnerabilidad: net: phy: leds: fix memory leakage Una prueba de reinicio de red en un enrutador provocó una condición de falta de memoria, que se rastreó hasta una fuga de memoria en el código de activación del LED PHY. La causa raíz es el uso indebido de la API devm. La función de registro (phy_led_triggers_register) se llama desde phy_attach_direct, no desde phy_probe, y la función de anulación del registro (phy_led_triggers_unregister) se llama desde phy_detach, no desde phy_remove. Esto significa que las funciones de registro y anulación del registro se pueden llamar varias veces para el mismo dispositivo PHY, pero la memoria asignada por devm no se libera hasta que se desvincula el controlador. Esto también evita que kmemleak detecte la fuga, ya que la API devm almacena internamente el puntero asignado. Solucione esto reemplazando devm_kzalloc/devm_kcalloc con kzalloc/kcalloc estándar y agregue las llamadas kfree correspondientes en la ruta de anulación de registro.
References
  • () https://lists.debian.org/debian-lts-announce/2025/05/msg00045.html -

20 May 2025, 18:15

Type Values Removed Values Added
New CVE

Information

Published : 2025-05-20 18:15

Updated : 2025-12-16 20:19


NVD link : CVE-2025-37989

Mitre link : CVE-2025-37989

CVE.ORG link : CVE-2025-37989


JSON object : View

Products Affected

debian

  • debian_linux

linux

  • linux_kernel
CWE
CWE-401

Missing Release of Memory after Effective Lifetime