summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--meta/recipes-graphics/xwayland/xwayland/CVE-2025-49180.patch45
-rw-r--r--meta/recipes-graphics/xwayland/xwayland_23.2.5.bb1
2 files changed, 46 insertions, 0 deletions
diff --git a/meta/recipes-graphics/xwayland/xwayland/CVE-2025-49180.patch b/meta/recipes-graphics/xwayland/xwayland/CVE-2025-49180.patch
new file mode 100644
index 0000000000..51939acf63
--- /dev/null
+++ b/meta/recipes-graphics/xwayland/xwayland/CVE-2025-49180.patch
@@ -0,0 +1,45 @@
1From 3c3a4b767b16174d3213055947ea7f4f88e10ec6 Mon Sep 17 00:00:00 2001
2From: Olivier Fourdan <ofourdan@redhat.com>
3Date: Tue, 20 May 2025 15:18:19 +0200
4Subject: [PATCH] randr: Check for overflow in RRChangeProviderProperty()
5
6A client might send a request causing an integer overflow when computing
7the total size to allocate in RRChangeProviderProperty().
8
9To avoid the issue, check that total length in bytes won't exceed the
10maximum integer value.
11
12CVE-2025-49180
13
14This issue was discovered by Nils Emmerich <nemmerich@ernw.de> and
15reported by Julian Suleder via ERNW Vulnerability Disclosure.
16
17Signed-off-by: Olivier Fourdan <ofourdan@redhat.com>
18Reviewed-by: Peter Hutterer <peter.hutterer@who-t.net>
19Part-of: <https://gitlab.freedesktop.org/xorg/xserver/-/merge_requests/2024>
20
21CVE: CVE-2025-49180
22
23Upstream-Status: Backport [https://gitlab.freedesktop.org/xorg/xserver/-/commit/3c3a4b767b16174d3213055947ea7f4f88e10ec6]
24
25Signed-off-by: Archana Polampalli <archana.polampalli@windriver.com>
26---
27 randr/rrproviderproperty.c | 3 ++-
28 1 file changed, 2 insertions(+), 1 deletion(-)
29
30diff --git a/randr/rrproviderproperty.c b/randr/rrproviderproperty.c
31index 90c5a9a..0aa35ad 100644
32--- a/randr/rrproviderproperty.c
33+++ b/randr/rrproviderproperty.c
34@@ -179,7 +179,8 @@ RRChangeProviderProperty(RRProviderPtr provider, Atom property, Atom type,
35
36 if (mode == PropModeReplace || len > 0) {
37 void *new_data = NULL, *old_data = NULL;
38-
39+ if (total_len > MAXINT / size_in_bytes)
40+ return BadValue;
41 total_size = total_len * size_in_bytes;
42 new_value.data = (void *) malloc(total_size);
43 if (!new_value.data && total_size) {
44--
452.40.0
diff --git a/meta/recipes-graphics/xwayland/xwayland_23.2.5.bb b/meta/recipes-graphics/xwayland/xwayland_23.2.5.bb
index 490e1ca05f..49e35ca442 100644
--- a/meta/recipes-graphics/xwayland/xwayland_23.2.5.bb
+++ b/meta/recipes-graphics/xwayland/xwayland_23.2.5.bb
@@ -30,6 +30,7 @@ SRC_URI = "https://www.x.org/archive/individual/xserver/xwayland-${PV}.tar.xz \
30 file://CVE-2025-49177.patch \ 30 file://CVE-2025-49177.patch \
31 file://CVE-2025-49178.patch \ 31 file://CVE-2025-49178.patch \
32 file://CVE-2025-49179.patch \ 32 file://CVE-2025-49179.patch \
33 file://CVE-2025-49180.patch \
33" 34"
34SRC_URI[sha256sum] = "33ec7ff2687a59faaa52b9b09aa8caf118e7ecb6aed8953f526a625ff9f4bd90" 35SRC_URI[sha256sum] = "33ec7ff2687a59faaa52b9b09aa8caf118e7ecb6aed8953f526a625ff9f4bd90"
35 36