CVE Database
/

CVE-2026-31624

Back to search

CVE-2026-31624

Published: Apr 24, 2026

Modified: Jun 1, 2026

PUBLISHED

Description

In the Linux kernel, the following vulnerability has been resolved: HID: core: clamp report_size in s32ton() to avoid undefined shift s32ton() shifts by n-1 where n is the field's report_size, a value that comes directly from a HID device. The HID parser bounds report_size only to <= 256, so a broken HID device can supply a report descriptor with a wide field that triggers shift exponents up to 256 on a 32-bit type when an output report is built via hid_output_field() or hid_set_field(). Commit ec61b41918587 ("HID: core: fix shift-out-of-bounds in hid_report_raw_event") added the same n > 32 clamp to the function snto32(), but s32ton() was never given the same fix as I guess syzbot hadn't figured out how to fuzz a device the same way. Fix this up by just clamping the max value of n, just like snto32() does.

VendorProductVersions

Linux

Linux

affected
dde5845a529ff753364a6d1aea61180946270bfa - < 76ad02854a30c394e0c076e6e6bed0a388573a94
affected
dde5845a529ff753364a6d1aea61180946270bfa - < eb415ddaf25e09ddb8fe5736a70c9de2e6462534
affected
dde5845a529ff753364a6d1aea61180946270bfa - < 0ab048dbdb1daacf17d52e9252297eb6e1298e49
affected
dde5845a529ff753364a6d1aea61180946270bfa - < 932ae5309e53561197aa7d1606c7cf63af10e24f
affected
dde5845a529ff753364a6d1aea61180946270bfa - < 58386f00af710922cafb0fb69211497beddfaa95

+4 more versions

Linux

Linux

affected
2.6.20
unaffected
0 - < 2.6.20
unaffected
5.10.258 - <= 5.10.*
unaffected
5.15.209 - <= 5.15.*
unaffected
6.1.175 - <= 6.1.*

+6 more versions

Security Training

Train your team to recognize and prevent security threats with our comprehensive security awareness program.

Start Training

Vulnerability Scanning

Discover vulnerabilities in your applications and infrastructure before attackers do.

Scan Now