summaryrefslogtreecommitdiffstats
path: root/meta/recipes-graphics
diff options
context:
space:
mode:
authorVijay Anusuri <vanusuri@mvista.com>2023-11-06 21:04:23 +0530
committerRichard Purdie <richard.purdie@linuxfoundation.org>2023-11-08 11:00:09 +0000
commita193c0224a4100f2e75bfff40b0832758affeb45 (patch)
treea00ae88887cedac9de81d8aa573c13d68bd52af5 /meta/recipes-graphics
parent1c135f1d7af041167555fe1a368b56799bb89cf9 (diff)
downloadpoky-a193c0224a4100f2e75bfff40b0832758affeb45.tar.gz
xserver-xorg: Fix for CVE-2023-5574
Upstream-Status: Backport [https://gitlab.freedesktop.org/xorg/xserver/-/commit/1953f460b9ad1a9cdf0fcce70f6ad3310b713d5f & https://gitlab.freedesktop.org/xorg/xserver/-/commit/b6fe3f924aecac6d6e311673511ce61aa2f7a81f & https://gitlab.freedesktop.org/xorg/xserver/-/commit/ab2c58ba4719fc31c19c7829b06bdba8a88bd586] (From OE-Core rev: 9291d7e7aca8ff93d036770e4fb42901c3ea1d60) Signed-off-by: Vijay Anusuri <vanusuri@mvista.com> Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/recipes-graphics')
-rw-r--r--meta/recipes-graphics/xorg-xserver/xserver-xorg/CVE-2023-5574-1.patch113
-rw-r--r--meta/recipes-graphics/xorg-xserver/xserver-xorg/CVE-2023-5574-2.patch42
-rw-r--r--meta/recipes-graphics/xorg-xserver/xserver-xorg/CVE-2023-5574-3.patch54
-rw-r--r--meta/recipes-graphics/xorg-xserver/xserver-xorg_21.1.9.bb3
4 files changed, 212 insertions, 0 deletions
diff --git a/meta/recipes-graphics/xorg-xserver/xserver-xorg/CVE-2023-5574-1.patch b/meta/recipes-graphics/xorg-xserver/xserver-xorg/CVE-2023-5574-1.patch
new file mode 100644
index 0000000000..9a8e583e78
--- /dev/null
+++ b/meta/recipes-graphics/xorg-xserver/xserver-xorg/CVE-2023-5574-1.patch
@@ -0,0 +1,113 @@
1From 1953f460b9ad1a9cdf0fcce70f6ad3310b713d5f Mon Sep 17 00:00:00 2001
2From: Peter Hutterer <peter.hutterer@who-t.net>
3Date: Thu, 12 Oct 2023 12:44:13 +1000
4Subject: [PATCH] fb: properly wrap/unwrap CloseScreen
5
6fbCloseScreen assumes that it overrides miCloseScreen (which just
7calls FreePixmap(screen->devPrivates)) and emulates that instead of
8wrapping it.
9
10This is a wrong assumption, we may have ShmCloseScreen in the mix too,
11resulting in leaks (see below). Fix this by properly setting up the
12CloseScreen wrapper.
13
14This means we no longer need the manual DestroyPixmap call in
15vfbCloseScreen, reverting d348ab06aae21c153ecbc3511aeafc8ab66d8303
16
17CVE-2023-5574, ZDI-CAN-21213
18
19This vulnerability was discovered by:
20Sri working with Trend Micro Zero Day Initiative
21
22Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
23Reviewed-by: Adam Jackson <ajax@redhat.com>
24
25Upstream-Status: Backport [https://gitlab.freedesktop.org/xorg/xserver/-/commit/1953f460b9ad1a9cdf0fcce70f6ad3310b713d5f]
26CVE: CVE-2023-5574
27Signed-off-by: Vijay Anusuri <vanusuri@mvista.com>
28---
29 fb/fb.h | 1 +
30 fb/fbscreen.c | 14 ++++++++++----
31 hw/vfb/InitOutput.c | 7 -------
32 3 files changed, 11 insertions(+), 11 deletions(-)
33
34diff --git a/fb/fb.h b/fb/fb.h
35index d157b6956d..cd7bd05d21 100644
36--- a/fb/fb.h
37+++ b/fb/fb.h
38@@ -410,6 +410,7 @@ typedef struct {
39 #endif
40 DevPrivateKeyRec gcPrivateKeyRec;
41 DevPrivateKeyRec winPrivateKeyRec;
42+ CloseScreenProcPtr CloseScreen;
43 } FbScreenPrivRec, *FbScreenPrivPtr;
44
45 #define fbGetScreenPrivate(pScreen) ((FbScreenPrivPtr) \
46diff --git a/fb/fbscreen.c b/fb/fbscreen.c
47index 4ab807ab50..c481033f98 100644
48--- a/fb/fbscreen.c
49+++ b/fb/fbscreen.c
50@@ -29,6 +29,7 @@
51 Bool
52 fbCloseScreen(ScreenPtr pScreen)
53 {
54+ FbScreenPrivPtr screen_priv = fbGetScreenPrivate(pScreen);
55 int d;
56 DepthPtr depths = pScreen->allowedDepths;
57
58@@ -37,9 +38,10 @@ fbCloseScreen(ScreenPtr pScreen)
59 free(depths[d].vids);
60 free(depths);
61 free(pScreen->visuals);
62- if (pScreen->devPrivate)
63- FreePixmap((PixmapPtr)pScreen->devPrivate);
64- return TRUE;
65+
66+ pScreen->CloseScreen = screen_priv->CloseScreen;
67+
68+ return pScreen->CloseScreen(pScreen);
69 }
70
71 Bool
72@@ -144,6 +146,7 @@ fbFinishScreenInit(ScreenPtr pScreen, void *pbits, int xsize, int ysize,
73 int dpix, int dpiy, int width, int bpp)
74 #endif
75 {
76+ FbScreenPrivPtr screen_priv;
77 VisualPtr visuals;
78 DepthPtr depths;
79 int nvisuals;
80@@ -177,8 +180,11 @@ fbFinishScreenInit(ScreenPtr pScreen, void *pbits, int xsize, int ysize,
81 rootdepth, ndepths, depths,
82 defaultVisual, nvisuals, visuals))
83 return FALSE;
84- /* overwrite miCloseScreen with our own */
85+
86+ screen_priv = fbGetScreenPrivate(pScreen);
87+ screen_priv->CloseScreen = pScreen->CloseScreen;
88 pScreen->CloseScreen = fbCloseScreen;
89+
90 return TRUE;
91 }
92
93diff --git a/hw/vfb/InitOutput.c b/hw/vfb/InitOutput.c
94index 48efb61b2f..076fb7defa 100644
95--- a/hw/vfb/InitOutput.c
96+++ b/hw/vfb/InitOutput.c
97@@ -720,13 +720,6 @@ vfbCloseScreen(ScreenPtr pScreen)
98
99 pScreen->CloseScreen = pvfb->closeScreen;
100
101- /*
102- * fb overwrites miCloseScreen, so do this here
103- */
104- if (pScreen->devPrivate)
105- (*pScreen->DestroyPixmap) (pScreen->devPrivate);
106- pScreen->devPrivate = NULL;
107-
108 return pScreen->CloseScreen(pScreen);
109 }
110
111--
112GitLab
113
diff --git a/meta/recipes-graphics/xorg-xserver/xserver-xorg/CVE-2023-5574-2.patch b/meta/recipes-graphics/xorg-xserver/xserver-xorg/CVE-2023-5574-2.patch
new file mode 100644
index 0000000000..2cdef752c7
--- /dev/null
+++ b/meta/recipes-graphics/xorg-xserver/xserver-xorg/CVE-2023-5574-2.patch
@@ -0,0 +1,42 @@
1From b6fe3f924aecac6d6e311673511ce61aa2f7a81f Mon Sep 17 00:00:00 2001
2From: Peter Hutterer <peter.hutterer@who-t.net>
3Date: Thu, 12 Oct 2023 12:42:06 +1000
4Subject: [PATCH] mi: fix CloseScreen initialization order
5
6If SHM is enabled it will set the CloseScreen pointer, only to be
7overridden by the hardcoded miCloseScreen pointer. Do this the other way
8round, miCloseScreen is the bottom of our stack.
9
10Direct leak of 48 byte(s) in 2 object(s) allocated from:
11 #0 0x7f5ea3ad8cc7 in calloc (/lib64/libasan.so.8+0xd8cc7) (BuildId: d8f3addefe29e892d775c30eb364afd3c2484ca5))
12 #1 0x70adfb in ShmInitScreenPriv ../Xext/shm.c:213
13
14Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
15Reviewed-by: Adam Jackson <ajax@redhat.com>
16
17Upstream-Status: Backport [https://gitlab.freedesktop.org/xorg/xserver/-/commit/b6fe3f924aecac6d6e311673511ce61aa2f7a81f]
18CVE: CVE-2023-5574
19Signed-off-by: Vijay Anusuri <vanusuri@mvista.com>
20---
21 mi/miscrinit.c | 2 +-
22 1 file changed, 1 insertion(+), 1 deletion(-)
23
24diff --git a/mi/miscrinit.c b/mi/miscrinit.c
25index 3bb52b1bc6..b88938c9ae 100644
26--- a/mi/miscrinit.c
27+++ b/mi/miscrinit.c
28@@ -249,10 +249,10 @@ miScreenInit(ScreenPtr pScreen, void *pbits, /* pointer to screen bits */
29 pScreen->numVisuals = numVisuals;
30 pScreen->visuals = visuals;
31 if (width) {
32+ pScreen->CloseScreen = miCloseScreen;
33 #ifdef MITSHM
34 ShmRegisterFbFuncs(pScreen);
35 #endif
36- pScreen->CloseScreen = miCloseScreen;
37 }
38 /* else CloseScreen */
39 /* QueryBestSize */
40--
41GitLab
42
diff --git a/meta/recipes-graphics/xorg-xserver/xserver-xorg/CVE-2023-5574-3.patch b/meta/recipes-graphics/xorg-xserver/xserver-xorg/CVE-2023-5574-3.patch
new file mode 100644
index 0000000000..47c247ef0c
--- /dev/null
+++ b/meta/recipes-graphics/xorg-xserver/xserver-xorg/CVE-2023-5574-3.patch
@@ -0,0 +1,54 @@
1From ab2c58ba4719fc31c19c7829b06bdba8a88bd586 Mon Sep 17 00:00:00 2001
2From: Peter Hutterer <peter.hutterer@who-t.net>
3Date: Tue, 24 Oct 2023 12:09:36 +1000
4Subject: [PATCH] dix: always initialize pScreen->CloseScreen
5
6CloseScreen is wrapped by the various modules, many of which do not
7check if they're the last ones unwrapping. This is fine if the order of
8those modules never changes but when it does we might get a NULL-pointer
9dereference by some naive code doing a
10
11 pScreen->CloseScreen = priv->CloseScreen;
12 free(priv);
13 return (*pScreen->CloseScreen)(pScreen);
14
15To avoid this set it to a default function that just returns TRUE that's
16guaranteed to be the last one.
17
18Upstream-Status: Backport [https://gitlab.freedesktop.org/xorg/xserver/-/commit/ab2c58ba4719fc31c19c7829b06bdba8a88bd586]
19CVE: CVE-2023-5574
20Signed-off-by: Vijay Anusuri <vanusuri@mvista.com>
21---
22 dix/dispatch.c | 9 +++++++++
23 1 file changed, 9 insertions(+)
24
25diff --git a/dix/dispatch.c b/dix/dispatch.c
26index eaac39b7c9..cd092fd409 100644
27--- a/dix/dispatch.c
28+++ b/dix/dispatch.c
29@@ -3890,6 +3890,12 @@ static int indexForScanlinePad[65] = {
30 3 /* 64 bits per scanline pad unit */
31 };
32
33+static Bool
34+DefaultCloseScreen(ScreenPtr screen)
35+{
36+ return TRUE;
37+}
38+
39 /*
40 grow the array of screenRecs if necessary.
41 call the device-supplied initialization procedure
42@@ -3949,6 +3955,9 @@ static int init_screen(ScreenPtr pScreen, int i, Bool gpu)
43 PixmapWidthPaddingInfo[depth].notPower2 = 0;
44 }
45 }
46+
47+ pScreen->CloseScreen = DefaultCloseScreen;
48+
49 return 0;
50 }
51
52--
53GitLab
54
diff --git a/meta/recipes-graphics/xorg-xserver/xserver-xorg_21.1.9.bb b/meta/recipes-graphics/xorg-xserver/xserver-xorg_21.1.9.bb
index 43c06181e3..2e1d2529ab 100644
--- a/meta/recipes-graphics/xorg-xserver/xserver-xorg_21.1.9.bb
+++ b/meta/recipes-graphics/xorg-xserver/xserver-xorg_21.1.9.bb
@@ -2,6 +2,9 @@ require xserver-xorg.inc
2 2
3SRC_URI += "file://0001-xf86pciBus.c-use-Intel-ddx-only-for-pre-gen4-hardwar.patch \ 3SRC_URI += "file://0001-xf86pciBus.c-use-Intel-ddx-only-for-pre-gen4-hardwar.patch \
4 file://0001-Avoid-duplicate-definitions-of-IOPortBase.patch \ 4 file://0001-Avoid-duplicate-definitions-of-IOPortBase.patch \
5 file://CVE-2023-5574-1.patch \
6 file://CVE-2023-5574-2.patch \
7 file://CVE-2023-5574-3.patch \
5 " 8 "
6SRC_URI[sha256sum] = "ff697be2011b4c4966b7806929e51b7a08e9d33800d505305d26d9ccde4b533a" 9SRC_URI[sha256sum] = "ff697be2011b4c4966b7806929e51b7a08e9d33800d505305d26d9ccde4b533a"
7 10