DEBIAN-CVE-2026-31412
In the Linux kernel, the following vulnerability has been resolved: usb: gadget: f_mass_storage: Fix potential integer overflow in check_command_size_in_blocks() The `check_command_size_in_blocks()` function calculates the data size in bytes by left shifting `common->data_size_from_cmnd` by the block size (`common->curlun->blkbits`). However, it does not validate whether this shift operation will cause an integer overflow. Initially, the block size is set up in `fsg_lun_open()` , and the `common->data_size_from_cmnd` is set up in `do_scsi_command()`. During initialization, there is no integer overflow check for the interaction between two variables. So if a malicious USB host sends a SCSI READ or WRITE command requesting a large amount of data (`common->data_size_from_cmnd`), the left shift operation can wrap around. This results in a truncated data size, which can bypass boundary checks and potentially lead to memory corruption or out-of-bounds accesses. Fix this by using the check_shl_overflow() macro to safely perform the shift and catch any overflows.
Risk Scores
Affected Products
| Vendor | Product | Versions |
|---|---|---|
| Debian:11 | linux | 5.16, 6.16.12-1~bpo13+1, 6.16.12-2 |
| Debian:12 | linux | 6.7.1-1~exp1, 6.12.11-1+alpha.1, 6.12.12-1 |
| Debian:14 | linux | 6.18.1-1~exp1, 6.12.48-1, 6.12.57-1 |
| Debian:13 | linux | 6.12.63-1, 6.12.38-1, 6.12.41-1 |
| Debian:11 | linux-6.1 | 6.1.153-1, 6.1.158-1, 6.1.159-1 |
Exploit Intelligence
- 4593.2.0.yml (github-poc)
- 4628.1.0.yml (github-poc)
Timeline
- Apr 10, 2026 CVE Published
- May 2, 2026 CVE Updated