Home

Description

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.

PUBLISHED Reserved 2026-03-09 | Published 2026-04-10 | Updated 2026-05-11 | Assigner Linux

Product status

Default status
unaffected

144974e7f9e32b53b02f6c8632be45d8f43d6ab5 (git) before 91817ad5452defe69bc7bc0e355f0ed5d01125cc
affected

144974e7f9e32b53b02f6c8632be45d8f43d6ab5 (git) before ce0caaed5940162780c5c223b8ae54968a5f059b
affected

144974e7f9e32b53b02f6c8632be45d8f43d6ab5 (git) before 228b37936376143f4b60cc6828663f6eaceb81b5
affected

144974e7f9e32b53b02f6c8632be45d8f43d6ab5 (git) before 3428dc5520c811e66622b2f5fa43341bf9a1f8b3
affected

144974e7f9e32b53b02f6c8632be45d8f43d6ab5 (git) before 387ebb0453b99d71491419a5dc4ab4bee0cacbac
affected

144974e7f9e32b53b02f6c8632be45d8f43d6ab5 (git) before 8479891d1f04a8ce55366fe4ca361ccdb96f02e1
affected

Default status
affected

3.3
affected

Any version before 3.3
unaffected

6.1.167 (semver)
unaffected

6.6.130 (semver)
unaffected

6.12.78 (semver)
unaffected

6.18.19 (semver)
unaffected

6.19.9 (semver)
unaffected

7.0 (original_commit_for_fix)
unaffected

References

git.kernel.org/...c/91817ad5452defe69bc7bc0e355f0ed5d01125cc

git.kernel.org/...c/ce0caaed5940162780c5c223b8ae54968a5f059b

git.kernel.org/...c/228b37936376143f4b60cc6828663f6eaceb81b5

git.kernel.org/...c/3428dc5520c811e66622b2f5fa43341bf9a1f8b3

git.kernel.org/...c/387ebb0453b99d71491419a5dc4ab4bee0cacbac

git.kernel.org/...c/8479891d1f04a8ce55366fe4ca361ccdb96f02e1

cve.org (CVE-2026-31412)

nvd.nist.gov (CVE-2026-31412)

Download JSON