Vulnerability Details CVE-2026-26965
FreeRDP is a free implementation of the Remote Desktop Protocol. Prior to version 3.23.0, in the RLE planar decode path, `planar_decompress_plane_rle()` writes into `pDstData` at `((nYDst+y) * nDstStep) + (4*nXDst) + nChannel` without verifying that `(nYDst+nSrcHeight)` fits in the destination height or that `(nXDst+nSrcWidth)` fits in the destination stride. When `TempFormat != DstFormat`, `pDstData` becomes `planar->pTempData` (sized for the desktop), while `nYDst` is only validated against the **surface** by `is_within_surface()`. A malicious RDP server can exploit this to perform a heap out-of-bounds write with attacker-controlled offset and pixel data on any connecting FreeRDP client. The OOB write reaches up to 132,096 bytes past the temp buffer end, and on the brk heap (desktop ≤ 128×128), an adjacent `NSC_CONTEXT` struct's `decode` function pointer is overwritten with attacker-controlled pixel data — control-flow–relevant corruption (function pointer overwritten) demonstrated under deterministic heap layout (`nsc->decode = 0xFF414141FF414141`). Version 3.23.0 fixes the vulnerability.
Exploit prediction scoring system (EPSS) score
EPSS Score 0.001
EPSS Ranking 17.3%
CVSS Severity
CVSS v3 Score 8.8
Products affected by CVE-2026-26965
-
cpe:2.3:a:freerdp:freerdp:-
-
cpe:2.3:a:freerdp:freerdp:1.0.0
-
cpe:2.3:a:freerdp:freerdp:1.0.1
-
cpe:2.3:a:freerdp:freerdp:1.0.2
-
cpe:2.3:a:freerdp:freerdp:1.1.0
-
cpe:2.3:a:freerdp:freerdp:1.2.0
-
cpe:2.3:a:freerdp:freerdp:2.0.0
-
cpe:2.3:a:freerdp:freerdp:2.1.0
-
cpe:2.3:a:freerdp:freerdp:2.1.1
-
cpe:2.3:a:freerdp:freerdp:2.1.2
-
cpe:2.3:a:freerdp:freerdp:2.10.0
-
cpe:2.3:a:freerdp:freerdp:2.11.0
-
cpe:2.3:a:freerdp:freerdp:2.11.1
-
cpe:2.3:a:freerdp:freerdp:2.11.2
-
cpe:2.3:a:freerdp:freerdp:2.11.3
-
cpe:2.3:a:freerdp:freerdp:2.11.4
-
cpe:2.3:a:freerdp:freerdp:2.11.5
-
cpe:2.3:a:freerdp:freerdp:2.11.6
-
cpe:2.3:a:freerdp:freerdp:2.11.7
-
cpe:2.3:a:freerdp:freerdp:2.11.8
-
cpe:2.3:a:freerdp:freerdp:2.2.0
-
cpe:2.3:a:freerdp:freerdp:2.3.0
-
cpe:2.3:a:freerdp:freerdp:2.3.1
-
cpe:2.3:a:freerdp:freerdp:2.3.2
-
cpe:2.3:a:freerdp:freerdp:2.4.0
-
cpe:2.3:a:freerdp:freerdp:2.4.1
-
cpe:2.3:a:freerdp:freerdp:2.5.0
-
cpe:2.3:a:freerdp:freerdp:2.6.0
-
cpe:2.3:a:freerdp:freerdp:2.6.1
-
cpe:2.3:a:freerdp:freerdp:2.7.0
-
cpe:2.3:a:freerdp:freerdp:2.8.0
-
cpe:2.3:a:freerdp:freerdp:2.8.1
-
cpe:2.3:a:freerdp:freerdp:2.9.0
-
cpe:2.3:a:freerdp:freerdp:3.0.0
-
cpe:2.3:a:freerdp:freerdp:3.1.0
-
cpe:2.3:a:freerdp:freerdp:3.10.0
-
cpe:2.3:a:freerdp:freerdp:3.10.1
-
cpe:2.3:a:freerdp:freerdp:3.10.2
-
cpe:2.3:a:freerdp:freerdp:3.10.3
-
cpe:2.3:a:freerdp:freerdp:3.11.0
-
cpe:2.3:a:freerdp:freerdp:3.11.1
-
cpe:2.3:a:freerdp:freerdp:3.12.0
-
cpe:2.3:a:freerdp:freerdp:3.13.0
-
cpe:2.3:a:freerdp:freerdp:3.14.0
-
cpe:2.3:a:freerdp:freerdp:3.14.1
-
cpe:2.3:a:freerdp:freerdp:3.15.0
-
cpe:2.3:a:freerdp:freerdp:3.16.0
-
cpe:2.3:a:freerdp:freerdp:3.17.0
-
cpe:2.3:a:freerdp:freerdp:3.17.1
-
cpe:2.3:a:freerdp:freerdp:3.17.2
-
cpe:2.3:a:freerdp:freerdp:3.18.0
-
cpe:2.3:a:freerdp:freerdp:3.19.0
-
cpe:2.3:a:freerdp:freerdp:3.19.1
-
cpe:2.3:a:freerdp:freerdp:3.2.0
-
cpe:2.3:a:freerdp:freerdp:3.20.0
-
cpe:2.3:a:freerdp:freerdp:3.20.1
-
cpe:2.3:a:freerdp:freerdp:3.20.2
-
cpe:2.3:a:freerdp:freerdp:3.21.0
-
cpe:2.3:a:freerdp:freerdp:3.22.0
-
cpe:2.3:a:freerdp:freerdp:3.3.0
-
cpe:2.3:a:freerdp:freerdp:3.4.0
-
cpe:2.3:a:freerdp:freerdp:3.5.0
-
cpe:2.3:a:freerdp:freerdp:3.5.1
-
cpe:2.3:a:freerdp:freerdp:3.6.0
-
cpe:2.3:a:freerdp:freerdp:3.6.1
-
cpe:2.3:a:freerdp:freerdp:3.6.2
-
cpe:2.3:a:freerdp:freerdp:3.6.3
-
cpe:2.3:a:freerdp:freerdp:3.7.0
-
cpe:2.3:a:freerdp:freerdp:3.8.0
-
cpe:2.3:a:freerdp:freerdp:3.9.0