mirror of
https://git.yoctoproject.org/poky
synced 2026-05-05 07:39:49 +02:00
libsdl2: Add fix for CVE-2022-4743
Add a patch to fix CVE-2022-4743 security issue "A potential memory leak issue was discovered in SDL2 in GLES_CreateTexture() function in SDL_render_gles.c. The vulnerability allows an attacker to cause a denial of service attack. The vulnerability affects SDL2 v2.0.4 and above. SDL-1.x are not affected." as per NVD (From OE-Core rev: f40ad856e814366c2d3588001dea1e0df7a3fed6) Signed-off-by: Ranjitsinh Rathod <ranjitsinh.rathod@kpit.com> Signed-off-by: Ranjitsinh Rathod <ranjitsinhrathod1991@gmail.com> Signed-off-by: Steve Sakoman <steve@sakoman.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
committed by
Richard Purdie
parent
262f47eff8
commit
4f6333a564
38
meta/recipes-graphics/libsdl2/libsdl2/CVE-2022-4743.patch
Normal file
38
meta/recipes-graphics/libsdl2/libsdl2/CVE-2022-4743.patch
Normal file
@@ -0,0 +1,38 @@
|
||||
From 00b67f55727bc0944c3266e2b875440da132ce4b Mon Sep 17 00:00:00 2001
|
||||
From: zhailiangliang <zhailiangliang@loongson.cn>
|
||||
Date: Wed, 21 Sep 2022 10:30:38 +0800
|
||||
Subject: [PATCH] Fix potential memory leak in GLES_CreateTexture
|
||||
|
||||
|
||||
CVE: CVE-2022-4743
|
||||
Upstream-Status: Backport [https://github.com/libsdl-org/SDL/commit/00b67f55727bc0944c3266e2b875440da132ce4b.patch]
|
||||
Signed-off-by: Ranjitsinh Rathod <ranjitsinh.rathod@kpit.com>
|
||||
|
||||
---
|
||||
src/render/opengles/SDL_render_gles.c | 6 ++++++
|
||||
1 file changed, 6 insertions(+)
|
||||
|
||||
diff --git a/src/render/opengles/SDL_render_gles.c b/src/render/opengles/SDL_render_gles.c
|
||||
index a5fbab309eda..ba08a46e2805 100644
|
||||
--- a/src/render/opengles/SDL_render_gles.c
|
||||
+++ b/src/render/opengles/SDL_render_gles.c
|
||||
@@ -359,6 +359,9 @@ GLES_CreateTexture(SDL_Renderer * renderer, SDL_Texture * texture)
|
||||
renderdata->glGenTextures(1, &data->texture);
|
||||
result = renderdata->glGetError();
|
||||
if (result != GL_NO_ERROR) {
|
||||
+ if (texture->access == SDL_TEXTUREACCESS_STREAMING) {
|
||||
+ SDL_free(data->pixels);
|
||||
+ }
|
||||
SDL_free(data);
|
||||
return GLES_SetError("glGenTextures()", result);
|
||||
}
|
||||
@@ -387,6 +390,9 @@ GLES_CreateTexture(SDL_Renderer * renderer, SDL_Texture * texture)
|
||||
|
||||
result = renderdata->glGetError();
|
||||
if (result != GL_NO_ERROR) {
|
||||
+ if (texture->access == SDL_TEXTUREACCESS_STREAMING) {
|
||||
+ SDL_free(data->pixels);
|
||||
+ }
|
||||
SDL_free(data);
|
||||
return GLES_SetError("glTexImage2D()", result);
|
||||
}
|
||||
@@ -22,6 +22,7 @@ SRC_URI = "http://www.libsdl.org/release/SDL2-${PV}.tar.gz \
|
||||
file://directfb-renderfillrect-fix.patch \
|
||||
file://CVE-2020-14409-14410.patch \
|
||||
file://CVE-2021-33657.patch \
|
||||
file://CVE-2022-4743.patch \
|
||||
"
|
||||
|
||||
S = "${WORKDIR}/SDL2-${PV}"
|
||||
|
||||
Reference in New Issue
Block a user