[Mesa-dev] [PATCH 1/2] mesa: Add support for the ARB_pipeline_statisticcs_Query extension

Ilia Mirkin imirkin at alum.mit.edu
Fri Jan 2 14:00:18 PST 2015


On Fri, Jan 2, 2015 at 4:43 PM, Ben Widawsky
<benjamin.widawsky at intel.com> wrote:
> This was originally part of a single patch which added the extension, and
> implemented it for i965 classic. For information about the evolution of the
> patch, please see the subsequent commit.
>
> One difference here as compared to the original mega patch is this does build
> support for the compute shader query. Since it cannot be tested on any platform,
> it will always return NULL for now. Jordan has already written a patch to
> address this, and when that patch lands, this logic can be modified. Tesselation
> shader support still won't build, so it's stubbed out.
>
> Cc: Jordan Justen <jljusten at gmail.com>
> Cc: Ilia Mirkin <imirkin at alum.mit.edu>
> Signed-off-by: Ben Widawsky <ben at bwidawsk.net>
> ---
>  .../glapi/gen/ARB_pipeline_statistics_query.xml    | 24 +++++++
>  src/mapi/glapi/gen/Makefile.am                     |  1 +
>  src/mapi/glapi/gen/gl_API.xml                      |  3 +
>  src/mesa/main/config.h                             |  3 +
>  src/mesa/main/extensions.c                         |  1 +
>  src/mesa/main/mtypes.h                             | 15 ++++
>  src/mesa/main/queryobj.c                           | 81 ++++++++++++++++++++++
>  7 files changed, 128 insertions(+)
>  create mode 100644 src/mapi/glapi/gen/ARB_pipeline_statistics_query.xml
>
> diff --git a/src/mapi/glapi/gen/ARB_pipeline_statistics_query.xml b/src/mapi/glapi/gen/ARB_pipeline_statistics_query.xml
> new file mode 100644
> index 0000000..1c66533
> --- /dev/null
> +++ b/src/mapi/glapi/gen/ARB_pipeline_statistics_query.xml
> @@ -0,0 +1,24 @@
> +<?xml version="1.0"?>
> +<!DOCTYPE OpenGLAPI SYSTEM "gl_API.dtd">
> +
> +<!-- Note: no GLX protocol info yet. -->
> +
> +<OpenGLAPI>
> +
> +<category name="GL_ARB_pipeline_statistics_query" number="171">
> +
> +  <enum name="VERTICES_SUBMITTED"                      value="0x82EE"/>
> +  <enum name="PRIMITIVES_SUBMITTED"                    value="0x82EF"/>
> +  <enum name="VERTEX_SHADER_INVOCATIONS"               value="0x82F0"/>
> +  <enum name="TESS_CONTROL_SHADER_PATCHES"             value="0x82F1"/>
> +  <enum name="TESS_EVALUATION_SHADER_INVOCATIONS"      value="0x82F2"/>
> +  <!-- <enum name="GEOMETRY_SHADER_INVOCATIONS"             value="0x887F"/> -->
> +  <enum name="GEOMETRY_SHADER_PRIMITIVES_EMITTED"      value="0x82F3"/>
> +  <enum name="FRAGMENT_SHADER_INVOCATIONS"             value="0x82F4"/>
> +  <enum name="COMPUTE_SHADER_INVOCATIONS"              value="0x82F5"/>
> +  <enum name="CLIPPING_INPUT_PRIMITIVES"               value="0x82F6"/>
> +  <enum name="CLIPPING_OUTPUT_PRIMITIVES"              value="0x82F7"/>
> +
> +</category>
> +
> +</OpenGLAPI>
> diff --git a/src/mapi/glapi/gen/Makefile.am b/src/mapi/glapi/gen/Makefile.am
> index e56b46e..8af2801 100644
> --- a/src/mapi/glapi/gen/Makefile.am
> +++ b/src/mapi/glapi/gen/Makefile.am
> @@ -137,6 +137,7 @@ API_XML = \
>         ARB_invalidate_subdata.xml \
>         ARB_map_buffer_range.xml \
>         ARB_multi_bind.xml \
> +       ARB_pipeline_statistics_query.xml \
>         ARB_robustness.xml \
>         ARB_sample_shading.xml \
>         ARB_sampler_objects.xml \
> diff --git a/src/mapi/glapi/gen/gl_API.xml b/src/mapi/glapi/gen/gl_API.xml
> index e1b1246..46026ac 100644
> --- a/src/mapi/glapi/gen/gl_API.xml
> +++ b/src/mapi/glapi/gen/gl_API.xml
> @@ -8381,6 +8381,9 @@
>
>  <xi:include href="KHR_context_flush_control.xml" xmlns:xi="http://www.w3.org/2001/XInclude"/>
>
> +<!-- ARB extension 171 -->
> +<xi:include href="ARB_pipeline_statistics_query.xml" xmlns:xi="http://www.w3.org/2001/XInclude"/>
> +
>  <!-- Non-ARB extensions sorted by extension number. -->
>
>  <category name="GL_EXT_blend_color" number="2">
> diff --git a/src/mesa/main/config.h b/src/mesa/main/config.h
> index 4ec4b75..50e87fa 100644
> --- a/src/mesa/main/config.h
> +++ b/src/mesa/main/config.h
> @@ -300,6 +300,9 @@
>  #define MAX_COMPUTE_IMAGE_UNIFORMS          8
>  /*@}*/
>
> +/** For GL_ARB_pipeline_statistics_query */
> +#define MAX_PIPELINE_STATISTICS             11
> +
>  /*
>   * Color channel component order
>   *
> diff --git a/src/mesa/main/extensions.c b/src/mesa/main/extensions.c
> index 0df04c2..997c774 100644
> --- a/src/mesa/main/extensions.c
> +++ b/src/mesa/main/extensions.c
> @@ -133,6 +133,7 @@ static const struct extension extension_table[] = {
>     { "GL_ARB_multitexture",                        o(dummy_true),                              GLL,            1998 },
>     { "GL_ARB_occlusion_query2",                    o(ARB_occlusion_query2),                    GL,             2003 },
>     { "GL_ARB_occlusion_query",                     o(ARB_occlusion_query),                     GLL,            2001 },
> +   { "GL_ARB_pipeline_statistics_query",           o(ARB_pipeline_statistics_query),           GL,             2014 },
>     { "GL_ARB_pixel_buffer_object",                 o(EXT_pixel_buffer_object),                 GL,             2004 },
>     { "GL_ARB_point_parameters",                    o(EXT_point_parameters),                    GLL,            1997 },
>     { "GL_ARB_point_sprite",                        o(ARB_point_sprite),                        GL,             2003 },
> diff --git a/src/mesa/main/mtypes.h b/src/mesa/main/mtypes.h
> index b95dfb9..9c2a73d 100644
> --- a/src/mesa/main/mtypes.h
> +++ b/src/mesa/main/mtypes.h
> @@ -3069,6 +3069,9 @@ struct gl_query_state
>     /** GL_ARB_timer_query */
>     struct gl_query_object *TimeElapsed;
>
> +   /** GL_ARB_pipeline_statistics_query */
> +   struct gl_query_object *pipeline_stats[MAX_PIPELINE_STATISTICS];
> +
>     GLenum CondRenderMode;
>  };
>
> @@ -3455,6 +3458,17 @@ struct gl_constants
>        GLuint Timestamp;
>        GLuint PrimitivesGenerated;
>        GLuint PrimitivesWritten;
> +      GLuint VerticesSubmitted;
> +      GLuint PrimitivesSubmitted;
> +      GLuint VsInvocations;
> +      GLuint TessPatches;
> +      GLuint TessInvocations;
> +      GLuint GsInvocations;
> +      GLuint GsPrimitives;
> +      GLuint FsInvocations;
> +      GLuint ComputeInvocations;
> +      GLuint ClInPrimitives;
> +      GLuint ClOutPrimitives;
>     } QueryCounterBits;
>
>     GLuint MaxDrawBuffers;    /**< GL_ARB_draw_buffers */
> @@ -3751,6 +3765,7 @@ struct gl_extensions
>     GLboolean ARB_map_buffer_range;
>     GLboolean ARB_occlusion_query;
>     GLboolean ARB_occlusion_query2;
> +   GLboolean ARB_pipeline_statistics_query;
>     GLboolean ARB_point_sprite;
>     GLboolean ARB_sample_shading;
>     GLboolean ARB_seamless_cube_map;
> diff --git a/src/mesa/main/queryobj.c b/src/mesa/main/queryobj.c
> index 932359c..698141a 100644
> --- a/src/mesa/main/queryobj.c
> +++ b/src/mesa/main/queryobj.c
> @@ -142,6 +142,14 @@ _mesa_init_query_object_functions(struct dd_function_table *driver)
>     driver->CheckQuery = _mesa_check_query;
>  }
>
> +static struct gl_query_object **
> +get_pipe_stats_binding_point(struct gl_context *ctx,
> +                             GLenum target)
> +{

if (!supported) return NULL, right?

> +   const int which = target - GL_VERTICES_SUBMITTED_ARB;
> +   assert(which < MAX_PIPELINE_STATISTICS);
> +   return &ctx->Query.pipeline_stats[which];
> +}
>
>  /**
>   * Return pointer to the query object binding point for the given target and
> @@ -183,6 +191,46 @@ get_query_binding_point(struct gl_context *ctx, GLenum target, GLuint index)
>           return &ctx->Query.PrimitivesWritten[index];
>        else
>           return NULL;
> +
> +   case GL_VERTICES_SUBMITTED_ARB:
> +   case GL_PRIMITIVES_SUBMITTED_ARB:
> +   case GL_VERTEX_SHADER_INVOCATIONS_ARB:
> +   case GL_FRAGMENT_SHADER_INVOCATIONS_ARB:
> +   case GL_CLIPPING_INPUT_PRIMITIVES_ARB:
> +   case GL_CLIPPING_OUTPUT_PRIMITIVES_ARB:
> +      if (ctx->Extensions.ARB_pipeline_statistics_query)

&& _mesa_is_desktop_gl(ctx) here and below? Not sure what the general
policy is. But it doesn't seem that the extension is defined for ES,
nor anything similar to it.

> +         return get_pipe_stats_binding_point(ctx, target);
> +      else
> +         return NULL;
> +
> +   case GL_GEOMETRY_SHADER_INVOCATIONS:
> +      /* GL_GEOMETRY_SHADER_INVOCATIONS is defined in a non-sequential order */
> +      target = GL_VERTICES_SUBMITTED_ARB + MAX_PIPELINE_STATISTICS - 1;
> +      /* fallthrough */
> +   case GL_GEOMETRY_SHADER_PRIMITIVES_EMITTED_ARB:
> +      if (_mesa_has_geometry_shaders(ctx))
> +         return get_pipe_stats_binding_point(ctx, target);
> +      else
> +         return NULL;
> +
> +#if 0 /* Not yet able to build or test */
> +   case GL_TESS_CONTROL_SHADER_PATCHES_ARB:
> +   case GL_TESS_EVALUATION_SHADER_INVOCATIONS_ARB:
> +      if (ctx->Version >= 40 || ctx->Extensions.ARB_tessellation_shader)
> +         return get_pipe_stats_binding_point(ctx, target);
> +      else
> +         return NULL;
> +#endif
> +
> +   case GL_COMPUTE_SHADER_INVOCATIONS_ARB:
> +      /* No CS to test this with yet */
> +      if (1)
> +         return NULL;

But presumably ARB_compute_shader isn't enabled either... seems fine
to just omit the if (1) return NULL, since it'll just return NULL
anyways.

> +
> +      if (ctx->Version >= 43 || ctx->Extensions.ARB_compute_shader)

Although actually this probably needs a _mesa_has_geometry_shaders
style thing, since ARB_cs (and ARB_tess) will only be enabled in core
contexts.

> +         return get_pipe_stats_binding_point(ctx, target);

           else (to match the other places you do this)

  -ilia


More information about the mesa-dev mailing list