CVE-2026-47104 PUBLISHED

libusb < 1.0.30 Out-of-Bounds Read in parse_iad_array()

Assigner: VulnCheck
Reserved: 18.05.2026 Published: 27.05.2026 Updated: 27.05.2026

libusb before version 1.0.30 contains a one-byte out-of-bounds read vulnerability in parse_iad_array() in descriptor.c that allows attackers to trigger a denial of service by supplying a malformed USB descriptor whose bLength equals size minus one, causing the bounds check to use the original buffer size instead of the remaining size. Attackers in virtualized environments with USB passthrough can supply crafted descriptors through libusb_get_active_interface_association_descriptors or libusb_get_interface_association_descriptors to read one byte past the end of the malloc allocation, resulting in a denial of service.

Metrics

CVSS Vector: CVSS:4.0/AV:L/AC:L/AT:N/PR:N/UI:N/VC:N/VI:N/VA:L/SC:N/SI:N/SA:N
CVSS Score: 5.1

Product Status

Vendor libusb
Product libusb
Versions Default: affected
  • affected from 0 to 1.0.30 (excl.)

Credits

  • @MarkLee131 finder

References

Problem Types

  • Out-of-bounds Read CWE