[Piglit] [PATCH] ARB_pipeline_statistics_query (comp): basic test
Ben Widawsky
ben at bwidawsk.net
Thu Dec 11 15:48:49 PST 2014
On Thu, Dec 11, 2014 at 01:37:10PM -0800, Jordan Justen wrote:
> Signed-off-by: Jordan Justen <jordan.l.justen at intel.com>
> Cc: Ben Widawsky <ben at bwidawsk.net>
> ---
> Requires Ben's ARB_pipeline_statistics_query series.
I'll just suck this in and push it with the rest, provided nobody has issues
with it.
>
> tests/all.py | 2 +
> .../spec/arb_pipeline_statistics/CMakeLists.gl.txt | 2 +
> .../arb_pipeline_statistics/pipeline_stats_comp.c | 242 +++++++++++++++++++++
> 3 files changed, 246 insertions(+)
> create mode 100644 tests/spec/arb_pipeline_statistics/pipeline_stats_comp.c
>
> diff --git a/tests/all.py b/tests/all.py
> index a0c560b..c57d452 100644
> --- a/tests/all.py
> +++ b/tests/all.py
> @@ -3658,6 +3658,8 @@ arb_pipeline_statistics['arb_pipeline_stats_fs_basic_stats'] = \
> PiglitGLTest('arb_pipeline_stats_frag', run_concurrent=True)
> arb_pipeline_statistics['arb_pipeline_stats_gs_basic_stats'] = \
> PiglitGLTest('arb_pipeline_stats_geom', run_concurrent=True)
> +arb_pipeline_statistics['arb_pipeline_stats_cs_basic_stats'] = \
> + PiglitGLTest('arb_pipeline_stats_comp', run_concurrent=True)
>
> # group glslparsertest ------------------------------------------------------
> glslparsertest = {}
> diff --git a/tests/spec/arb_pipeline_statistics/CMakeLists.gl.txt b/tests/spec/arb_pipeline_statistics/CMakeLists.gl.txt
> index 0c80a31..9f5072e 100644
> --- a/tests/spec/arb_pipeline_statistics/CMakeLists.gl.txt
> +++ b/tests/spec/arb_pipeline_statistics/CMakeLists.gl.txt
> @@ -26,5 +26,7 @@ piglit_add_executable (arb_pipeline_stats_clip pipeline_stats_clip.c)
> target_link_libraries (arb_pipeline_stats_clip pipestat_help)
> piglit_add_executable (arb_pipeline_stats_frag pipeline_stats_frag.c)
> target_link_libraries (arb_pipeline_stats_frag pipestat_help)
> +piglit_add_executable (arb_pipeline_stats_comp pipeline_stats_comp.c)
> +target_link_libraries (arb_pipeline_stats_comp pipestat_help)
>
> # vim: ft=cmake
> diff --git a/tests/spec/arb_pipeline_statistics/pipeline_stats_comp.c b/tests/spec/arb_pipeline_statistics/pipeline_stats_comp.c
> new file mode 100644
> index 0000000..6b7005b
> --- /dev/null
> +++ b/tests/spec/arb_pipeline_statistics/pipeline_stats_comp.c
> @@ -0,0 +1,242 @@
> +/*
> + * Copyright © 2014 Intel Corporation
> + *
> + * Permission is hereby granted, free of charge, to any person obtaining a
> + * copy of this software and associated documentation files (the "Software"),
> + * to deal in the Software without restriction, including without limitation
> + * the rights to use, copy, modify, merge, publish, distribute, sublicense,
> + * and/or sell copies of the Software, and to permit persons to whom the
> + * Software is furnished to do so, subject to the following conditions:
> + *
> + * The above copyright notice and this permission notice (including the next
> + * paragraph) shall be included in all copies or substantial portions of the
> + * Software.
> + *
> + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
> + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
> + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
> + * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
> + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
> + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
> + * IN THE SOFTWARE.
> + */
> +
> +/** \file pipeline_stats_comp.c
> + *
> + * This test verifies that the vertex shader related tokens of
> + * ARB_pipeline_statistics_query() work as expected. OpenGL 4.4 Specification,
> + * Core Profile.
> + *
> + * When BeginQuery is called with a target of COMPUTE_SHADER_INVOCATIONS,
> + * the compute shader invocations count maintained by the GL is set to zero.
> + * When a compute shader invocations query is active, the counter is
> + * incremented every time the compute shader is invoked (see section 11.3).
> + * In case of instanced compute shaders (see section 11.3.4.2) the compute
> + * shader invocations count is incremented for each separate instanced
> + * invocation.
> + *
> + * When BeginQuery is called with a target of COMPUTE_SHADER_PRIMITIVES_-
> + * EMITTED_ARB, the compute shader output primitives count maintained by the
> + * GL is set to zero. When a compute shader primitives emitted query is
> + * active, the counter is incremented every time the compute shader emits
> + * a primitive to a vertex stream that is further processed by the GL (see
> + * section 11.3.2). Restarting primitive topology using the shading language
> + * built-in functions EndPrimitive or EndStreamPrimitive does not increment
> + * the compute shader output primitives count.
> + */
> +
> +#include "piglit-util-gl.h"
> +#include "pipestat_help.h"
> +
> +PIGLIT_GL_TEST_CONFIG_BEGIN
> + config.supports_gl_core_version = 32;
> + config.supports_gl_compat_version = 32;
> + config.window_visual = PIGLIT_GL_VISUAL_DOUBLE | PIGLIT_GL_VISUAL_RGBA;
> +PIGLIT_GL_TEST_CONFIG_END
> +
> +#define NUM_ATOMIC_COUNTERS 1
> +
> +static GLuint atomics_bo = 0;
> +
> +static int sizes[] = {
> + 1, 2, 3, 4, 5, 7, 8, 9, 15, 16, 17, 31, 32, 33, 63, 64, 65,
> + 127, 128, 129, 255, 256, 257, 511, 512, 513, 1023, 1024
> +};
> +
> +static struct query queries[] = {
> + {
> + .query = GL_COMPUTE_SHADER_INVOCATIONS_ARB,
> + .name = "GL_COMPUTE_SHADER_INVOCATIONS_ARB",
> + .expected = 0 /* Adjusted by confirm_size */},
> +};
> +
> +static const char *compute_shader_template =
> + "#version 330\n"
> + "#extension GL_ARB_compute_shader: enable\n"
> + "#extension GL_ARB_shader_atomic_counters: require\n"
> + "\n"
> + "layout(binding = 0) uniform atomic_uint atc;\n"
> + "\n"
> + "layout(local_size_x = %d, local_size_y = %d, local_size_z = %d) in;\n"
> + "\n"
> + "void main()\n"
> + "{\n"
> + " atomicCounterIncrement(atc);\n"
> + "}\n";
> +
> +
> +static enum piglit_result
> +confirm_size(uint32_t xs, uint32_t ys, uint32_t zs)
> +{
> + uint32_t *p;
> + uint32_t expected;
> +
> + expected = xs * ys * zs;
> +
> + glBindBufferBase(GL_ATOMIC_COUNTER_BUFFER, 0, atomics_bo);
> + p = glMapBufferRange(GL_ATOMIC_COUNTER_BUFFER,
> + 0,
> + NUM_ATOMIC_COUNTERS * sizeof(uint32_t),
> + GL_MAP_READ_BIT | GL_MAP_WRITE_BIT);
> +
> + if (!p) {
> + printf("Couldn't map atomic counter to verify expected value.\n");
> + return PIGLIT_FAIL;
> + }
> +
> + /* Adjust the expected thread count */
> + queries[0].expected += expected;
> +
> + if (expected != p[0]) {
> + printf("Atomic counter test failed for (%d, %d, %d)\n",
> + xs, ys, zs);
> + printf(" Reference: %u\n", expected);
> + printf(" Observed: %u\n", p[0]);
> + glUnmapBuffer(GL_ATOMIC_COUNTER_BUFFER);
> + return PIGLIT_FAIL;
> + }
> +
> + memset(p, 0, sizeof (uint32_t) * NUM_ATOMIC_COUNTERS);
> +
> + glUnmapBuffer(GL_ATOMIC_COUNTER_BUFFER);
> +
> + return PIGLIT_PASS;
> +}
> +
> +
> +static enum piglit_result
> +test_size(uint32_t x, uint32_t y, uint32_t z)
> +{
> + enum piglit_result result = PIGLIT_PASS;
> + char *compute_shader;
> + GLint shader_string_size;
> + GLuint shader = glCreateShader(GL_COMPUTE_SHADER);
> + GLint ok;
> + static GLint prog = 0;
> +
> + if (prog != 0) {
> + glDeleteProgram(prog);
> + }
> +
> + asprintf(&compute_shader, compute_shader_template, x, y, z);
> +
> + glShaderSource(shader, 1,
> + (const GLchar **) &compute_shader,
> + &shader_string_size);
> +
> + glCompileShader(shader);
> +
> + glGetShaderiv(shader, GL_COMPILE_STATUS, &ok);
> + assert(ok);
> +
> + prog = glCreateProgram();
> +
> + glAttachShader(prog, shader);
> +
> + glLinkProgram(prog);
> +
> + glGetProgramiv(prog, GL_LINK_STATUS, &ok);
> + assert(ok);
> +
> + glUseProgram(prog);
> +
> + glMemoryBarrier(GL_ALL_BARRIER_BITS);
> + glDispatchCompute(1, 1, 1);
> + glMemoryBarrier(GL_ALL_BARRIER_BITS);
> +
> + result = confirm_size(x, y, z);
> + if (result != PIGLIT_PASS)
> + piglit_report_result(result);
> + return result;
> +}
> +
> +
> +static enum piglit_result
> +test_all_sizes()
> +{
> + enum piglit_result result = PIGLIT_PASS;
> + uint32_t xi, yi, zi;
> + uint32_t x, y, z;
> +
> +
> + for (zi = 0; zi <= ARRAY_SIZE(sizes); zi++) {
> + z = sizes[zi];
> + if (z > 64)
> + break;
> + for (yi = 0; yi <= ARRAY_SIZE(sizes); yi++) {
> + y = sizes[yi];
> + if ((y * z) > 1024)
> + break;
> + for (xi = 0; xi <= ARRAY_SIZE(sizes); xi++) {
> + x = sizes[xi];
> + if ((x * y * z) > 1024)
> + break;
> + result = test_size(x, y, z);
> + if (result != PIGLIT_PASS)
> + return result;
> + }
> + }
> + }
> +
> + return result;
> +}
> +
> +
> +static void
> +test_all_sizes_for_query(void)
> +{
> + test_all_sizes();
> +}
> +
> +
> +enum piglit_result
> +piglit_display(void)
> +{
> + return PIGLIT_FAIL;
> +}
> +
> +
> +void
> +piglit_init(int argc, char **argv)
> +{
> + enum piglit_result result;
> + GLuint *atomics_buf;
> +
> + piglit_require_extension("GL_ARB_compute_shader");
> + piglit_require_extension("GL_ARB_shader_atomic_counters");
> +
> + do_query_init(queries, ARRAY_SIZE(queries));
> +
> + atomics_buf = calloc(NUM_ATOMIC_COUNTERS, sizeof(GLuint));
> + glGenBuffers(1, &atomics_bo);
> + glBindBufferBase(GL_ATOMIC_COUNTER_BUFFER, 0, atomics_bo);
> + glBufferData(GL_ATOMIC_COUNTER_BUFFER,
> + sizeof(GLuint) * NUM_ATOMIC_COUNTERS,
> + atomics_buf, GL_STATIC_DRAW);
> + free(atomics_buf);
> +
> + result = do_query_func(queries, ARRAY_SIZE(queries),
> + test_all_sizes_for_query);
> +
> + piglit_report_result(result);
> +}
> --
> 2.1.3
>
More information about the Piglit
mailing list