Home

Description

AGL agl-service-can-low-level thru 17.1.12 contains a heap buffer over-read in the isotp-c library. In isotp_continue_receive (receive.c:87-89), the payload_length for a Single Frame is extracted from a 4-bit nibble in the CAN frame data, yielding values 0-15. However, a standard CAN frame is only 8 bytes, with payload starting at data[1] (7 bytes available). When payload_length exceeds the available data (e.g., nibble=15 but only 7 payload bytes exist), memcpy(message.payload, &data[1], payload_length) reads up to 8 bytes past the end of the data buffer.

PUBLISHED Reserved 2026-04-06 | Published 2026-05-01 | Updated 2026-05-01 | Assigner mitre




HIGH: 7.1CVSS:3.1/AC:L/AV:A/A:H/C:L/I:N/PR:N/S:U/UI:N

References

gerrit.automotivelinux.org/...apps/agl-service-can-low-level

gist.github.com/sgInnora/8526eedcfd826d05ef1fc45d8f405643

cve.org (CVE-2026-37532)

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

Download JSON