From: Michel Dänzer Date: Sun, 30 Aug 2009 10:43:37 +0000 (+0200) Subject: glx/x11: Fix glXCreateGLXPixmap for direct rendering. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=edb117879846155632aaeb66483a3085c7a78815;p=mesa.git glx/x11: Fix glXCreateGLXPixmap for direct rendering. Fixes progs/xdemos/glxpixmap modified to use direct rendering. --- diff --git a/src/glx/x11/glxcmds.c b/src/glx/x11/glxcmds.c index 820d8b98685..3242ac77121 100644 --- a/src/glx/x11/glxcmds.c +++ b/src/glx/x11/glxcmds.c @@ -845,6 +845,34 @@ PUBLIC GLXPixmap glXCreateGLXPixmap(Display *dpy, XVisualInfo *vis, req->glxpixmap = xid = XAllocID(dpy); UnlockDisplay(dpy); SyncHandle(); + +#ifdef GLX_DIRECT_RENDERING + do { + /* FIXME: Maybe delay __DRIdrawable creation until the drawable + * is actually bound to a context... */ + + __GLXdisplayPrivate *const priv = __glXInitialize(dpy); + __GLXDRIdrawable *pdraw; + __GLXscreenConfigs *psc; + __GLcontextModes *modes; + + psc = &priv->screenConfigs[vis->screen]; + if (psc->driScreen == NULL) + break; + modes = _gl_context_modes_find_visual(psc->visuals, vis->visualid); + pdraw = psc->driScreen->createDrawable(psc, pixmap, req->glxpixmap, modes); + if (pdraw == NULL) { + fprintf(stderr, "failed to create pixmap\n"); + break; + } + + if (__glxHashInsert(psc->drawHash, req->glxpixmap, pdraw)) { + (*pdraw->destroyDrawable) (pdraw); + return None; /* FIXME: Check what we're supposed to do here... */ + } + } while (0); +#endif + return xid; }