Some driver/card combinations (r200/RV280, i915/915G) don't support OpenGL 2.1. These create in some corner cases an indirect context instead of a direct context when calling glXCreateContextAttribsARB(). This happens because of a bad default value. To avoid this, choose a more sane default OpenGL 1.0 as mentioned in the ARB_create_context spec:
The default values for GLX_CONTEXT_MAJOR_VERSION_ARB and GLX_CONTEXT_MINOR_VERSION_ARB are 1 and 0 respectively. In this case, implementations will typically return the most recent version of OpenGL they support which is backwards compatible with OpenGL 1.0 (e.g. 3.0, 3.1 + GL_ARB_compatibility, or 3.2 compatibility profile)
This fixes: http://bugs.winehq.org/show_bug.cgi?id=34238 Signed-off-by: Rico Schüller <kgbric...@web.de> --- src/glx/dri2_glx.c | 10 +++++----- src/glx/dri_common.c | 14 +++++++------- src/glx/drisw_glx.c | 10 +++++----- 3 files changed, 17 insertions(+), 17 deletions(-)
diff --git a/src/glx/dri2_glx.c b/src/glx/dri2_glx.c index c54edac..112d6d4 100644 --- a/src/glx/dri2_glx.c +++ b/src/glx/dri2_glx.c @@ -260,12 +260,12 @@ dri2_create_context_attribs(struct glx_screen *base, __GLXDRIconfigPrivate *config = (__GLXDRIconfigPrivate *) config_base; __DRIcontext *shared = NULL; - uint32_t minor_ver = 1; - uint32_t major_ver = 2; - uint32_t renderType = GLX_RGBA_TYPE; - uint32_t flags = 0; + uint32_t minor_ver; + uint32_t major_ver; + uint32_t renderType; + uint32_t flags; unsigned api; - int reset = __DRI_CTX_RESET_NO_NOTIFICATION; + int reset; uint32_t ctx_attribs[2 * 5]; unsigned num_ctx_attribs = 0; diff --git a/src/glx/dri_common.c b/src/glx/dri_common.c index b2a3117..5f199e9 100644 --- a/src/glx/dri_common.c +++ b/src/glx/dri_common.c @@ -470,8 +470,14 @@ dri2_convert_glx_attribs(unsigned num_attribs, const uint32_t *attribs, bool got_profile = false; uint32_t profile; + *major_ver = 1; + *minor_ver = 0; + *render_type = GLX_RGBA_TYPE; + *reset = __DRI_CTX_RESET_NO_NOTIFICATION; + *flags = 0; + *api = __DRI_API_OPENGL; + if (num_attribs == 0) { - *api = __DRI_API_OPENGL; return true; } @@ -482,11 +488,6 @@ dri2_convert_glx_attribs(unsigned num_attribs, const uint32_t *attribs, return false; } - *major_ver = 1; - *minor_ver = 0; - *render_type = GLX_RGBA_TYPE; - *reset = __DRI_CTX_RESET_NO_NOTIFICATION; - for (i = 0; i < num_attribs; i++) { switch (attribs[i * 2]) { case GLX_CONTEXT_MAJOR_VERSION_ARB: @@ -526,7 +527,6 @@ dri2_convert_glx_attribs(unsigned num_attribs, const uint32_t *attribs, } } - *api = __DRI_API_OPENGL; if (!got_profile) { if (*major_ver > 3 || (*major_ver == 3 && *minor_ver >= 2)) *api = __DRI_API_OPENGL_CORE; diff --git a/src/glx/drisw_glx.c b/src/glx/drisw_glx.c index 0583cd1..393be20 100644 --- a/src/glx/drisw_glx.c +++ b/src/glx/drisw_glx.c @@ -433,12 +433,12 @@ drisw_create_context_attribs(struct glx_screen *base, struct drisw_screen *psc = (struct drisw_screen *) base; __DRIcontext *shared = NULL; - uint32_t minor_ver = 1; - uint32_t major_ver = 0; - uint32_t renderType = GLX_RGBA_TYPE; - uint32_t flags = 0; + uint32_t minor_ver; + uint32_t major_ver; + uint32_t renderType; + uint32_t flags; unsigned api; - int reset = __DRI_CTX_RESET_NO_NOTIFICATION; + int reset; uint32_t ctx_attribs[2 * 4]; unsigned num_ctx_attribs = 0;
_______________________________________________ mesa-dev mailing list mesa-dev@lists.freedesktop.org http://lists.freedesktop.org/mailman/listinfo/mesa-dev