CVE-2026-46048
Gravedad CVSS v3.1:
MEDIA
Tipo:
No Disponible / Otro tipo
Fecha de publicación:
27/05/2026
Última modificación:
16/06/2026
Descripción
*** Pendiente de traducción *** In the Linux kernel, the following vulnerability has been resolved:<br />
<br />
ALSA: caiaq: fix usb_dev refcount leak on probe failure<br />
<br />
create_card() takes a reference on the USB device with usb_get_dev()<br />
and stores the matching usb_put_dev() in card_free(), which is<br />
installed as the snd_card&#39;s ->private_free destructor.<br />
<br />
However, ->private_free is only assigned near the end of init_card(),<br />
after several failure points (usb_set_interface(), EP type checks,<br />
usb_submit_urb(), the EP1_CMD_GET_DEVICE_INFO exchange, and its<br />
timeout). When any of those fail, init_card() returns an error to<br />
snd_probe(), which calls snd_card_free(card). Because ->private_free<br />
is still NULL, card_free() never runs, the usb_get_dev() reference<br />
is not dropped, and the struct usb_device leaks along with its<br />
descriptor allocations and device_private.<br />
<br />
syzbot reproduces this with a malformed UAC3 device whose only valid<br />
altsetting is 0; init_card()&#39;s usb_set_interface(usb_dev, 0, 1) call<br />
fails with -EIO and triggers the leak.<br />
<br />
Move the ->private_free assignment into create_card(), immediately<br />
after usb_get_dev(), so that every error path reaching snd_card_free()<br />
balances the reference. card_free()&#39;s callees (snd_usb_caiaq_input_free,<br />
free_urbs, kfree) already tolerate the partially-initialized state<br />
because the chip private area is zero-initialized by snd_card_new().
Impacto
Puntuación base 3.x
5.50
Gravedad 3.x
MEDIA
Productos y versiones vulnerables
| CPE | Desde | Hasta |
|---|---|---|
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.6.136 (incluyendo) | 6.6.140 (excluyendo) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.12.84 (incluyendo) | 6.12.86 (excluyendo) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.18.25 (incluyendo) | 6.18.27 (excluyendo) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 7.0.2 (incluyendo) | 7.0.4 (excluyendo) |
| cpe:2.3:o:linux:linux_kernel:7.1:rc1:*:*:*:*:*:* |
Para consultar la lista completa de nombres de CPE con productos y versiones, ver esta página
Referencias a soluciones, herramientas e información
- https://git.kernel.org/stable/c/21ca595aafa40d3ac70eab1f4cb62cc00ca21657
- https://git.kernel.org/stable/c/50c6a1f05973f56d23280c9d7645a7a5734e0907
- https://git.kernel.org/stable/c/6153878c5255bb69b7d0868105ca078ef13cbcf8
- https://git.kernel.org/stable/c/6fa8dff64fb6c401ced40a05797b327659317498
- https://git.kernel.org/stable/c/7a5f1cd22d47f8ca4b760b6334378ae42c1bd24b
- https://git.kernel.org/stable/c/a8d907acc3e5a078c2e5637ff60c30c6d2ddc23a
- https://git.kernel.org/stable/c/c874db8a1d2f9f08161470d00cfe8db2f5cca2cc
- https://git.kernel.org/stable/c/da3b8fd6a202d94fef11a443abc9171c52426a1c



