diff options
author | Brian Paul <brianp@vmware.com> | 2010-03-05 17:32:36 -0700 |
---|---|---|
committer | Brian Paul <brianp@vmware.com> | 2010-03-05 17:32:36 -0700 |
commit | ae7b3a632dd3f3b005459d77b66a77948260f716 (patch) | |
tree | 861b221d9a5bd81444a6954d64ccd3a8f3007694 /src/glx/glxext.c | |
parent | c781e2841a25aeecac2f9af1a31ce129a530d796 (diff) | |
download | external_mesa3d-ae7b3a632dd3f3b005459d77b66a77948260f716.zip external_mesa3d-ae7b3a632dd3f3b005459d77b66a77948260f716.tar.gz external_mesa3d-ae7b3a632dd3f3b005459d77b66a77948260f716.tar.bz2 |
glx: Move initialization of ext_list_first_time to where it's storage is allocated
Move the initialization of ext_list_first_time from all of the DRI loader's
CreateScreen routines, to where the storage for the screen config is
allocated.
It needs to get set in the screen-config even if DRI is forced off
using LIBGL_ALWAYS_INDIRECT, so that psc->direct_support is initialized
correctly, otherwise __glXExtensionBitIsEnabled() always returns FALSE
Specifically, this causes a problem with an X server which advertises
GLX<=1.2, and the GLX_SGIX_fbconfig extension.
glXGetFBConfigFromVisualSGIX() uses __glXExtensionBitIsEnabled() to
check if the GLX_SGIX_fbconfig extension is available, but that function
won't return correct information because that data has never been
initialized, because ext_list_first_time was never set...
Signed-off-by: Jon TURNEY <jon.turney@dronecode.org.uk>
Signed-off-by: Brian Paul <brianp@vmware.com>
(cherry picked from commit 96ab4d2b84178209ee59017458d9964b32b7e183)
Diffstat (limited to 'src/glx/glxext.c')
-rw-r--r-- | src/glx/glxext.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/src/glx/glxext.c b/src/glx/glxext.c index c2de1a3..b5657ba 100644 --- a/src/glx/glxext.c +++ b/src/glx/glxext.c @@ -717,6 +717,9 @@ AllocAndFetchScreenConfigs(Display * dpy, __GLXdisplayPrivate * priv) if (psc->drawHash == NULL) continue; + /* Initialize per screen dynamic client GLX extensions */ + psc->ext_list_first_time = GL_TRUE; + if (priv->dri2Display) psc->driScreen = (*priv->dri2Display->createScreen) (psc, i, priv); |