CVE-2026-31412
Gravedad CVSS v3.1:
MEDIA
Tipo:
CWE-190
Desbordamiento o ajuste de enteros
Fecha de publicación:
10/04/2026
Última modificación:
20/05/2026
Descripción
*** Pendiente de traducción *** In the Linux kernel, the following vulnerability has been resolved:<br />
<br />
usb: gadget: f_mass_storage: Fix potential integer overflow in check_command_size_in_blocks()<br />
<br />
The `check_command_size_in_blocks()` function calculates the data size<br />
in bytes by left shifting `common->data_size_from_cmnd` by the block<br />
size (`common->curlun->blkbits`). However, it does not validate whether<br />
this shift operation will cause an integer overflow.<br />
<br />
Initially, the block size is set up in `fsg_lun_open()` , and the<br />
`common->data_size_from_cmnd` is set up in `do_scsi_command()`. During<br />
initialization, there is no integer overflow check for the interaction<br />
between two variables.<br />
<br />
So if a malicious USB host sends a SCSI READ or WRITE command<br />
requesting a large amount of data (`common->data_size_from_cmnd`), the<br />
left shift operation can wrap around. This results in a truncated data<br />
size, which can bypass boundary checks and potentially lead to memory<br />
corruption or out-of-bounds accesses.<br />
<br />
Fix this by using the check_shl_overflow() macro to safely perform the<br />
shift and catch any overflows.
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:*:*:*:*:*:*:*:* | 3.3 (incluyendo) | 6.1.167 (excluyendo) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.2 (incluyendo) | 6.6.130 (excluyendo) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.7 (incluyendo) | 6.12.78 (excluyendo) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.13 (incluyendo) | 6.18.19 (excluyendo) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.19 (incluyendo) | 6.19.9 (excluyendo) |
| cpe:2.3:o:linux:linux_kernel:7.0:rc1:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:7.0:rc2:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:7.0:rc3:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:7.0:rc4:*:*:*:*:*:* |
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/228b37936376143f4b60cc6828663f6eaceb81b5
- https://git.kernel.org/stable/c/3428dc5520c811e66622b2f5fa43341bf9a1f8b3
- https://git.kernel.org/stable/c/387ebb0453b99d71491419a5dc4ab4bee0cacbac
- https://git.kernel.org/stable/c/8479891d1f04a8ce55366fe4ca361ccdb96f02e1
- https://git.kernel.org/stable/c/91817ad5452defe69bc7bc0e355f0ed5d01125cc
- https://git.kernel.org/stable/c/ce0caaed5940162780c5c223b8ae54968a5f059b



