Home

Description

FreeRDP is a free implementation of the Remote Desktop Protocol. Prior to 3.24.0, a size_t underflow in the IMA-ADPCM and MS-ADPCM audio decoders leads to heap-buffer-overflow write via the RDPSND audio channel. In libfreerdp/codec/dsp.c, the IMA-ADPCM and MS-ADPCM decoders subtract block header sizes from a size_t variable without checking for underflow. When nBlockAlign (received from the server) is set such that size % block_size == 0 triggers the header parsing at a point where size is smaller than the header (4 or 8 bytes), the subtraction wraps size to ~SIZE_MAX. The while (size > 0) loop then continues for an astronomical number of iterations. This vulnerability is fixed in 3.24.0.

PUBLISHED Reserved 2026-03-09 | Published 2026-03-13 | Updated 2026-03-13 | Assigner GitHub_M




MEDIUM: 6.5CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:L/A:N

Problem types

CWE-191: Integer Underflow (Wrap or Wraparound)

CWE-122: Heap-based Buffer Overflow

Product status

< 3.24.0
affected

References

github.com/...reeRDP/security/advisories/GHSA-85x9-4xxp-xhm5

github.com/...ommit/16df2300e1e3f5a51f68fb1626429e58b531b7c8

cve.org (CVE-2026-31883)

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

Download JSON