[Mesa-dev] [PATCH 3/8] mesa: Handle QUERY_RESULT_NO_WAIT in GetQueryObject{ui64}v

Rafal Mielniczuk rafal.mielniczuk2 at gmail.com
Wed Mar 19 14:30:45 PDT 2014


Just return and do nothing if query result is not yet available

Signed-off-by: Rafal Mielniczuk <rafal.mielniczuk2 at gmail.com>
---
 src/mesa/main/queryobj.c | 16 ++++++++++++++++
 1 file changed, 16 insertions(+)

diff --git a/src/mesa/main/queryobj.c b/src/mesa/main/queryobj.c
index 86e7c3a..66250b6 100644
--- a/src/mesa/main/queryobj.c
+++ b/src/mesa/main/queryobj.c
@@ -594,6 +594,10 @@ _mesa_GetQueryObjectiv(GLuint id, GLenum pname, GLint *params)
    }
 
    switch (pname) {
+      case GL_QUERY_RESULT_NO_WAIT:
+         if (!q->Ready)
+            break;
+         //else fall through
       case GL_QUERY_RESULT_ARB:
          if (!q->Ready)
             ctx->Driver.WaitQuery(ctx, q);
@@ -645,6 +649,10 @@ _mesa_GetQueryObjectuiv(GLuint id, GLenum pname, GLuint *params)
    }
 
    switch (pname) {
+      case GL_QUERY_RESULT_NO_WAIT:
+         if (!q->Ready)
+            break;
+         //else fall through
       case GL_QUERY_RESULT_ARB:
          if (!q->Ready)
             ctx->Driver.WaitQuery(ctx, q);
@@ -699,6 +707,10 @@ _mesa_GetQueryObjecti64v(GLuint id, GLenum pname, GLint64EXT *params)
    }
 
    switch (pname) {
+      case GL_QUERY_RESULT_NO_WAIT:
+         if (!q->Ready)
+            break;
+         //else fall through
       case GL_QUERY_RESULT_ARB:
          if (!q->Ready)
             ctx->Driver.WaitQuery(ctx, q);
@@ -739,6 +751,10 @@ _mesa_GetQueryObjectui64v(GLuint id, GLenum pname, GLuint64EXT *params)
    }
 
    switch (pname) {
+      case GL_QUERY_RESULT_NO_WAIT:
+         if (!q->Ready)
+            break;
+         //else fall through
       case GL_QUERY_RESULT_ARB:
          if (!q->Ready)
             ctx->Driver.WaitQuery(ctx, q);
-- 
1.9.0



More information about the mesa-dev mailing list