[Mesa-dev] [PATCH] mesa, st/glx, st/wgl: Move GL version validation into an helper.

jfonseca at vmware.com jfonseca at vmware.com
Fri Nov 14 12:33:00 PST 2014


From: José Fonseca <jfonseca at vmware.com>

As suggested by Brian Paul.

Tested with piglit glx-create-context-invalid-{gl,es}-version.
---
 src/gallium/state_trackers/glx/xlib/glx_api.c    | 13 +++-------
 src/gallium/state_trackers/wgl/stw_ext_context.c | 13 +++-------
 src/mesa/main/version.c                          | 33 ++++++++++++++++++++++++
 src/mesa/main/version.h                          |  6 +++++
 4 files changed, 47 insertions(+), 18 deletions(-)

diff --git a/src/gallium/state_trackers/glx/xlib/glx_api.c b/src/gallium/state_trackers/glx/xlib/glx_api.c
index 1807edb..d4e028c 100644
--- a/src/gallium/state_trackers/glx/xlib/glx_api.c
+++ b/src/gallium/state_trackers/glx/xlib/glx_api.c
@@ -36,6 +36,8 @@
 #include <X11/Xmd.h>
 #include <GL/glxproto.h>
 
+#include "main/version.h"
+
 #include "xm_api.h"
 
 
@@ -2792,19 +2794,12 @@ glXCreateContextAttribsARB(Display *dpy, GLXFBConfig config,
    if (majorVersion <= 0 ||
        minorVersion < 0 ||
        (profileMask != GLX_CONTEXT_ES_PROFILE_BIT_EXT &&
-        ((majorVersion == 1 && minorVersion > 5) ||
-         (majorVersion == 2 && minorVersion > 1) ||
-         (majorVersion == 3 && minorVersion > 3) ||
-         (majorVersion == 4 && minorVersion > 5) ||
-         majorVersion > 4))) {
+        !_mesa_is_valid_version(majorVersion, minorVersion))) {
       generate_error(dpy, BadMatch, 0, X_GLXCreateContextAtrribsARB, True);
       return NULL;
    }
    if (profileMask == GLX_CONTEXT_ES_PROFILE_BIT_EXT &&
-       ((majorVersion == 1 && minorVersion > 1) ||
-        (majorVersion == 2 && minorVersion > 0) ||
-        (majorVersion == 3 && minorVersion > 1) ||
-        majorVersion > 3)) {
+       !_mesa_is_valid_es_version(majorVersion, minorVersion)) {
       /* GLX_EXT_create_context_es2_profile says nothing to justifying a
        * different error code for invalid ES versions, but this is what NVIDIA
        * does and piglit expects.
diff --git a/src/gallium/state_trackers/wgl/stw_ext_context.c b/src/gallium/state_trackers/wgl/stw_ext_context.c
index 8a96cac..ee46334 100644
--- a/src/gallium/state_trackers/wgl/stw_ext_context.c
+++ b/src/gallium/state_trackers/wgl/stw_ext_context.c
@@ -30,6 +30,8 @@
 #include <GL/gl.h>
 #include <GL/wglext.h>
 
+#include "main/version.h"
+
 #include "stw_icd.h"
 #include "stw_context.h"
 #include "stw_device.h"
@@ -114,16 +116,9 @@ wglCreateContextAttribsARB(HDC hDC, HGLRC hShareContext, const int *attribList)
    if (majorVersion <= 0 ||
        minorVersion < 0 ||
        (profileMask != WGL_CONTEXT_ES_PROFILE_BIT_EXT &&
-        ((majorVersion == 1 && minorVersion > 5) ||
-         (majorVersion == 2 && minorVersion > 1) ||
-         (majorVersion == 3 && minorVersion > 3) ||
-         (majorVersion == 4 && minorVersion > 5) ||
-         majorVersion > 4)) ||
+        !_mesa_is_valid_version(majorVersion, minorVersion)) ||
        (profileMask == WGL_CONTEXT_ES_PROFILE_BIT_EXT &&
-        ((majorVersion == 1 && minorVersion > 1) ||
-         (majorVersion == 2 && minorVersion > 0) ||
-         (majorVersion == 3 && minorVersion > 1) ||
-         majorVersion > 3))) {
+        !_mesa_is_valid_es_version(majorVersion, minorVersion))) {
       SetLastError(ERROR_INVALID_VERSION_ARB);
       return NULL;
    }
diff --git a/src/mesa/main/version.c b/src/mesa/main/version.c
index 4951891..5bdef16 100644
--- a/src/mesa/main/version.c
+++ b/src/mesa/main/version.c
@@ -460,3 +460,36 @@ _mesa_compute_version(struct gl_context *ctx)
       break;
    }
 }
+
+
+GLboolean
+_mesa_is_valid_version(int major, int minor)
+{
+   static const char max_minor_version[] = {
+      /* 1 . */ 5,
+      /* 2 . */ 1,
+      /* 3 . */ 3,
+      /* 4 . */ 5,
+   };
+
+   return (major >= 0 &&
+           major < sizeof max_minor_version &&
+           minor >= 0 &&
+           minor <= max_minor_version[major - 1]);
+}
+
+
+GLboolean
+_mesa_is_valid_es_version(int major, int minor)
+{
+   static const char max_minor_version[] = {
+      /* 1 . */ 1,
+      /* 2 . */ 0,
+      /* 3 . */ 1,
+   };
+
+   return (major >= 0 &&
+           major < sizeof max_minor_version &&
+           minor >= 0 &&
+           minor <= max_minor_version[major - 1]);
+}
diff --git a/src/mesa/main/version.h b/src/mesa/main/version.h
index 450a0e3..e2e1fc2 100644
--- a/src/mesa/main/version.h
+++ b/src/mesa/main/version.h
@@ -50,4 +50,10 @@ _mesa_override_glsl_version(struct gl_constants *consts);
 extern int
 _mesa_get_gl_version_override(void);
 
+extern GLboolean
+_mesa_is_valid_version(int major, int minor);
+
+extern GLboolean
+_mesa_is_valid_es_version(int major, int minor);
+
 #endif /* VERSION_H */
-- 
2.1.1



More information about the mesa-dev mailing list