[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