CVE-2024-46840

In the Linux kernel, the following vulnerability has been resolved: btrfs: clean up our handling of refs == 0 in snapshot delete In reada we BUG_ON(refs == 0), which could be unkind since we aren't holding a lock on the extent leaf and thus could get a transient incorrect answer. In walk_down_proc we also BUG_ON(refs == 0), which could happen if we have extent tree corruption. Change that to return -EUCLEAN. In do_walk_down() we catch this case and handle it correctly, however we return -EIO, which -EUCLEAN is a more appropriate error code. Finally in walk_up_proc we have the same BUG_ON(refs == 0), so convert that to proper error handling. Also adjust the error message so we can actually do something with the information.
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:*:*:*:*:*:*:*:*

History

08 Oct 2024, 18:15

Type Values Removed Values Added
CVSS v2 : unknown
v3 : unknown
v2 : unknown
v3 : 5.5
First Time Linux linux Kernel
Linux
CPE cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*
References () https://git.kernel.org/stable/c/03804641ec2d0da4fa088ad21c88e703d151ce16 - () https://git.kernel.org/stable/c/03804641ec2d0da4fa088ad21c88e703d151ce16 - Patch
References () https://git.kernel.org/stable/c/71291aa7246645ef622621934d2067400380645e - () https://git.kernel.org/stable/c/71291aa7246645ef622621934d2067400380645e - Patch
References () https://git.kernel.org/stable/c/728d4d045b628e006b48a448f3326a7194c88d32 - () https://git.kernel.org/stable/c/728d4d045b628e006b48a448f3326a7194c88d32 - Patch
References () https://git.kernel.org/stable/c/7d1df13bf078ffebfedd361d714ff6cee1ff01b9 - () https://git.kernel.org/stable/c/7d1df13bf078ffebfedd361d714ff6cee1ff01b9 - Patch
References () https://git.kernel.org/stable/c/9cc887ac24b7a0598f4042ae9af6b9a33072f75b - () https://git.kernel.org/stable/c/9cc887ac24b7a0598f4042ae9af6b9a33072f75b - Patch
References () https://git.kernel.org/stable/c/b8ccef048354074a548f108e51d0557d6adfd3a3 - () https://git.kernel.org/stable/c/b8ccef048354074a548f108e51d0557d6adfd3a3 - Patch
References () https://git.kernel.org/stable/c/c60676b81fab456b672796830f6d8057058f029c - () https://git.kernel.org/stable/c/c60676b81fab456b672796830f6d8057058f029c - Patch
References () https://git.kernel.org/stable/c/c847b28a799733b04574060ab9d00f215970627d - () https://git.kernel.org/stable/c/c847b28a799733b04574060ab9d00f215970627d - Patch
CWE NVD-CWE-noinfo

30 Sep 2024, 12:45

Type Values Removed Values Added
Summary
  • (es) En el kernel de Linux, se ha resuelto la siguiente vulnerabilidad: btrfs: limpia nuestro manejo de refs == 0 en la eliminación de instantáneas En reada tenemos BUG_ON(refs == 0), lo que podría ser desagradable ya que no estamos manteniendo un bloqueo en la hoja de extensión y, por lo tanto, podríamos obtener una respuesta incorrecta transitoria. En walk_down_proc también tenemos BUG_ON(refs == 0), lo que podría suceder si tenemos corrupción del árbol de extensión. Cambia eso para que devuelva -EUCLEAN. En do_walk_down() capturamos este caso y lo manejamos correctamente, sin embargo, devolvemos -EIO, que -EUCLEAN es un código de error más apropiado. Finalmente, en walk_up_proc tenemos el mismo BUG_ON(refs == 0), así que conviértelo en un manejo de errores adecuado. También ajusta el mensaje de error para que podamos hacer algo con la información.

27 Sep 2024, 13:15

Type Values Removed Values Added
New CVE

Information

Published : 2024-09-27 13:15

Updated : 2024-10-08 18:15


NVD link : CVE-2024-46840

Mitre link : CVE-2024-46840

CVE.ORG link : CVE-2024-46840


JSON object : View

Products Affected

linux

  • linux_kernel