CVE-2026-31806
CRITICALCVSS v3.1: 9.8 · EPSS: 0.0053 (40.9 percentile)
Source data as of:
At a glance
- Severity
- CRITICAL
- CVSS
- 9.8 v3.1 · NVD
- EPSS
- 0.0053 (40.9 percentile) · FIRST.org
- CISA KEV
- No
- Type
- Heap Overflow · NVD CWE
- Attack conditions (CVSS vector)
- NetworkNo privilegesNo user interaction · Source: NVD Vector
- Affected vendors
- freerdp
- Published
- 2026-03-13 · Modified: 2026-06-30
- References
- Jump to references (8)
CVSS / EPSS / KEV
Source — CVSS: NVD · EPSS: FIRST.org · KEV: CISA. Data & Sources
Description
FreeRDP is a free implementation of the Remote Desktop Protocol. Prior to 3.24.0, the gdi_surface_bits() function processes SURFACE_BITS_COMMAND messages sent by the RDP server. When the command is handled using NSCodec, the bmp.width and bmp.height values provided by the server are not properly validated against the actual desktop dimensions. A malicious RDP server can supply crafted bmp.width and bmp.height values that exceed the expected surface size. Because these values are used during bitmap decoding and memory operations without proper bounds checking, this can lead to a heap buffer overflow. Since the attacker can also control the associated pixel data transmitted by the server, the overflow may be exploitable to overwrite adjacent heap memory. This vulnerability is fixed in 3.24.0.
References
Reference URLs as listed by NVD, grouped by a mechanical match on the link's host/pattern. Labels describe the link type only.
- Patch https://github.com/FreeRDP/FreeRDP/commit/83d9aedea278a74af3e490ff5eeb889c016dbb2b
- Vendor advisory https://github.com/FreeRDP/FreeRDP/security/advisories/GHSA-rrqm-46rj-cmx2
- Distro https://access.redhat.com/errata/RHSA-2026:10076
- Distro https://access.redhat.com/errata/RHSA-2026:10734
- Distro https://access.redhat.com/errata/RHSA-2026:10735
- Distro https://access.redhat.com/errata/RHSA-2026:10951
- Distro https://access.redhat.com/errata/RHSA-2026:11323
- Distro https://access.redhat.com/errata/RHSA-2026:19033