xserver: Branch 'server-21.1-branch'

GitLab Mirror gitlab-mirror at kemper.freedesktop.org
Tue Feb 25 10:36:22 UTC 2025


 hw/xfree86/dri2/dri2.c |   14 ++++++++++++--
 1 file changed, 12 insertions(+), 2 deletions(-)

New commits:
commit 0c6a7750f2ac9158ace8161f94f7e3bd4c9f5263
Author: Doug Brown <doug at schmorgal.com>
Date:   Mon Jul 15 19:44:23 2024 -0700

    dri2: Protect against dri2ClientPrivate assertion failures
    
    If DRI2ScreenInit hasn't been called yet, DRI2Authenticate and
    DRI2CreateDrawable2 cause the X server to crash. This has been observed
    to happen on multiple modern Linux distros in various conditions,
    including QEMU and VMware VMs. Make these functions more robust in order
    to prevent the crash.
    
    This patch was originally provided by Bernhard Übelacker and expanded
    upon by Mark Wagner.
    
    Signed-off-by: Doug Brown <doug at schmorgal.com>
    Closes: https://gitlab.freedesktop.org/xorg/xserver/-/issues/1053
    Closes: https://gitlab.freedesktop.org/xorg/xserver/-/issues/1534
    (cherry picked from commit a0834009cfb10b8982a1f2b47b8ed00de254c2c3)
    
    Part-of: <https://gitlab.freedesktop.org/xorg/xserver/-/merge_requests/1824>

diff --git a/hw/xfree86/dri2/dri2.c b/hw/xfree86/dri2/dri2.c
index 3397bb50c..3975d40ca 100644
--- a/hw/xfree86/dri2/dri2.c
+++ b/hw/xfree86/dri2/dri2.c
@@ -356,10 +356,15 @@ DRI2CreateDrawable2(ClientPtr client, DrawablePtr pDraw, XID id,
                     XID *dri2_id_out)
 {
     DRI2DrawablePtr pPriv;
-    DRI2ClientPtr dri2_client = dri2ClientPrivate(client);
+    DRI2ClientPtr dri2_client;
     XID dri2_id;
     int rc;
 
+    if (!dixPrivateKeyRegistered(dri2ScreenPrivateKey))
+        return BadValue;
+
+    dri2_client = dri2ClientPrivate(client);
+
     pPriv = DRI2GetDrawable(pDraw);
     if (pPriv == NULL)
         pPriv = DRI2AllocateDrawable(pDraw);
@@ -1362,9 +1367,14 @@ Bool
 DRI2Authenticate(ClientPtr client, ScreenPtr pScreen, uint32_t magic)
 {
     DRI2ScreenPtr ds;
-    DRI2ClientPtr dri2_client = dri2ClientPrivate(client);
+    DRI2ClientPtr dri2_client;
     ScreenPtr primescreen;
 
+    if (!dixPrivateKeyRegistered(dri2ScreenPrivateKey))
+        return FALSE;
+
+    dri2_client = dri2ClientPrivate(client);
+
     ds = DRI2GetScreenPrime(pScreen, dri2_client->prime_id);
     if (ds == NULL)
         return FALSE;


More information about the xorg-commit mailing list