mirror of
https://github.com/openembedded/meta-openembedded.git
synced 2026-06-13 17:39:57 +00:00
freerdp3: fix CVE-2026-29774
Details: https://nvd.nist.gov/vuln/detail/CVE-2026-29774 Signed-off-by: Ankur Tyagi <ankur.tyagi85@gmail.com> Signed-off-by: Anuj Mittal <anuj.mittal@oss.qualcomm.com>
This commit is contained in:
@@ -0,0 +1,75 @@
|
||||
From b590224c94effa3104a2db98a59478a9c4ed6f02 Mon Sep 17 00:00:00 2001
|
||||
From: Armin Novak <armin.novak@thincast.com>
|
||||
Date: Sat, 28 Feb 2026 11:38:23 +0100
|
||||
Subject: [PATCH] [codec,h264] validate rectangles before use
|
||||
|
||||
CVE: CVE-2026-29774
|
||||
Upstream-Status: Backport [https://github.com/FreeRDP/FreeRDP/commit/6482b7a92fff3959582cef052d1967ad6bde3738]
|
||||
Signed-off-by: Ankur Tyagi <ankur.tyagi85@gmail.com>
|
||||
---
|
||||
libfreerdp/codec/h264.c | 38 ++++++++++++++++++++++++++++++++++++++
|
||||
1 file changed, 38 insertions(+)
|
||||
|
||||
diff --git a/libfreerdp/codec/h264.c b/libfreerdp/codec/h264.c
|
||||
index 718bd2ccf..13d592600 100644
|
||||
--- a/libfreerdp/codec/h264.c
|
||||
+++ b/libfreerdp/codec/h264.c
|
||||
@@ -91,6 +91,36 @@ BOOL avc420_ensure_buffer(H264_CONTEXT* h264, UINT32 stride, UINT32 width, UINT3
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
+static BOOL isRectValid(UINT32 width, UINT32 height, const RECTANGLE_16* rect)
|
||||
+{
|
||||
+ WINPR_ASSERT(rect);
|
||||
+ if (rect->left > width)
|
||||
+ return FALSE;
|
||||
+ if (rect->right > width)
|
||||
+ return FALSE;
|
||||
+ if (rect->left >= rect->right)
|
||||
+ return FALSE;
|
||||
+ if (rect->top > height)
|
||||
+ return FALSE;
|
||||
+ if (rect->bottom > height)
|
||||
+ return FALSE;
|
||||
+ if (rect->top >= rect->bottom)
|
||||
+ return FALSE;
|
||||
+ return TRUE;
|
||||
+}
|
||||
+
|
||||
+static BOOL areRectsValid(UINT32 width, UINT32 height, const RECTANGLE_16* rects, UINT32 count)
|
||||
+{
|
||||
+ WINPR_ASSERT(rects || (count == 0));
|
||||
+ for (size_t x = 0; x < count; x++)
|
||||
+ {
|
||||
+ const RECTANGLE_16* rect = &rects[x];
|
||||
+ if (!isRectValid(width, height, rect))
|
||||
+ return FALSE;
|
||||
+ }
|
||||
+ return TRUE;
|
||||
+}
|
||||
+
|
||||
INT32 avc420_decompress(H264_CONTEXT* h264, const BYTE* pSrcData, UINT32 SrcSize, BYTE* pDstData,
|
||||
DWORD DstFormat, UINT32 nDstStep, UINT32 nDstWidth, UINT32 nDstHeight,
|
||||
const RECTANGLE_16* regionRects, UINT32 numRegionRects)
|
||||
@@ -101,6 +131,9 @@ INT32 avc420_decompress(H264_CONTEXT* h264, const BYTE* pSrcData, UINT32 SrcSize
|
||||
if (!h264 || h264->Compressor)
|
||||
return -1001;
|
||||
|
||||
+ if (!areRectsValid(nDstWidth, nDstHeight, regionRects, numRegionRects))
|
||||
+ return -1013;
|
||||
+
|
||||
status = h264->subsystem->Decompress(h264, pSrcData, SrcSize);
|
||||
|
||||
if (status == 0)
|
||||
@@ -523,6 +556,11 @@ INT32 avc444_decompress(H264_CONTEXT* h264, BYTE op, const RECTANGLE_16* regionR
|
||||
if (!h264 || !regionRects || !pSrcData || !pDstData || h264->Compressor)
|
||||
return -1001;
|
||||
|
||||
+ if (!areRectsValid(nDstWidth, nDstHeight, regionRects, numRegionRects))
|
||||
+ return -1013;
|
||||
+ if (!areRectsValid(nDstWidth, nDstHeight, auxRegionRects, numAuxRegionRect))
|
||||
+ return -1014;
|
||||
+
|
||||
switch (op)
|
||||
{
|
||||
case 0: /* YUV420 in stream 1
|
||||
@@ -31,6 +31,7 @@ SRC_URI = "git://github.com/FreeRDP/FreeRDP.git;branch=master;protocol=https \
|
||||
file://CVE-2026-24681.patch \
|
||||
file://CVE-2026-24682.patch \
|
||||
file://CVE-2026-24683.patch \
|
||||
file://CVE-2026-29774.patch \
|
||||
"
|
||||
|
||||
S = "${WORKDIR}/git"
|
||||
|
||||
Reference in New Issue
Block a user