Only try to call DRI function if DRI got initialized properly.
authorKristian Høgsberg <krh@redhat.com>
Mon, 10 Mar 2008 21:59:46 +0000 (17:59 -0400)
committerKristian Høgsberg <krh@redhat.com>
Mon, 10 Mar 2008 22:46:19 +0000 (18:46 -0400)
src/glx/x11/glxcmds.c
src/glx/x11/glxext.c

index c761ddf..1437ea5 100644 (file)
@@ -360,6 +360,10 @@ CreateContext(Display *dpy, XVisualInfo *vis,
              Bool use_glx_1_3, int renderType)
 {
     GLXContext gc;
+#ifdef GLX_DIRECT_RENDERING
+    int screen = (fbconfig == NULL) ? vis->screen : fbconfig->screen;
+    __GLXscreenConfigs * const psc = GetGLXScreenConfigs(dpy, screen);
+#endif
 
     if ( dpy == NULL )
        return NULL;
@@ -373,9 +377,7 @@ CreateContext(Display *dpy, XVisualInfo *vis,
            return NULL;
 
 #ifdef GLX_DIRECT_RENDERING
-       if (allowDirect) {
-           int screen = (fbconfig == NULL) ? vis->screen : fbconfig->screen;
-           __GLXscreenConfigs * const psc = GetGLXScreenConfigs(dpy, screen);
+       if (allowDirect && psc->driScreen) {
            const __GLcontextModes * mode;
 
            if (fbconfig == NULL) {
index 47f8da0..bb3fc89 100644 (file)
@@ -771,7 +771,8 @@ static Bool AllocAndFetchScreenConfigs(Display *dpy, __GLXdisplayPrivate *priv)
        psc->scr = i;
        psc->dpy = dpy;
 #ifdef GLX_DIRECT_RENDERING
-       psc->driScreen = (*priv->driDisplay->createScreen)(psc, i, priv);
+       if (priv->driDisplay)
+           psc->driScreen = (*priv->driDisplay->createScreen)(psc, i, priv);
 #endif
     }
     SyncHandle();