[Piglit] [PATCH] Add a very basic version of the "primgen" test.
Ben Widawsky
ben at bwidawsk.net
Wed Nov 12 11:53:11 PST 2014
On Wed, Nov 12, 2014 at 10:33:36AM -0800, Kenneth Graunke wrote:
> We already test this functionality in position.c, but I've found this
> test valuable when doing hardware enabling due to its simplicity:
>
> - No clears (since those require the pixel pipeline to work)
> - No rendering (rasterizer discard is enabled)
> - Minimal vertex shading.
>
> I retained Marek's copyright since this is largely cut and pasted from
> his tests (primgen.c and position.c).
>
> Signed-off-by: Kenneth Graunke <kenneth at whitecape.org>
> ---
> tests/all.py | 1 +
> .../spec/ext_transform_feedback/CMakeLists.gl.txt | 2 +
> .../pipeline-basic-primgen.c | 90 ++++++++++++++++++++++
> 3 files changed, 93 insertions(+)
> create mode 100644 tests/spec/ext_transform_feedback/pipeline-basic-primgen.c
>
> diff --git a/tests/all.py b/tests/all.py
> index f2c5c1f..16d3cff 100644
> --- a/tests/all.py
> +++ b/tests/all.py
> @@ -3121,6 +3121,7 @@ ext_transform_feedback['position-readback-bufferrange-discard'] = PiglitGLTest('
>
> ext_transform_feedback['negative-prims'] = PiglitGLTest('ext_transform_feedback-negative-prims', run_concurrent=True)
> ext_transform_feedback['primgen-query transform-feedback-disabled'] = PiglitGLTest('ext_transform_feedback-primgen', run_concurrent=True)
> +ext_transform_feedback['pipeline-basic-primgen'] = PiglitGLTest('ext_transform_feedback-pipeline-basic-primgen', run_concurrent=True)
>
> ext_transform_feedback['position-render-bufferbase'] = PiglitGLTest('ext_transform_feedback-position render', run_concurrent=True)
> ext_transform_feedback['position-render-bufferbase-discard'] = PiglitGLTest('ext_transform_feedback-position render discard', run_concurrent=True)
> diff --git a/tests/spec/ext_transform_feedback/CMakeLists.gl.txt b/tests/spec/ext_transform_feedback/CMakeLists.gl.txt
> index 95af3a5..abf8ec2 100644
> --- a/tests/spec/ext_transform_feedback/CMakeLists.gl.txt
> +++ b/tests/spec/ext_transform_feedback/CMakeLists.gl.txt
> @@ -31,6 +31,8 @@ piglit_add_executable (ext_transform_feedback-intervening-read intervening-read.
> piglit_add_executable (ext_transform_feedback-max-varyings max-varyings.c)
> piglit_add_executable (ext_transform_feedback-negative-prims negative-prims.c)
> piglit_add_executable (ext_transform_feedback-nonflat-integral nonflat-integral.c)
> +piglit_add_executable (ext_transform_feedback-pipeline-basic-primgen
> +pipeline-basic-primgen.c)
Did you mean for this line wrap
> piglit_add_executable (ext_transform_feedback-primgen primgen.c)
> piglit_add_executable (ext_transform_feedback-separate separate.c)
> piglit_add_executable (ext_transform_feedback-output-type output-type.c)
> diff --git a/tests/spec/ext_transform_feedback/pipeline-basic-primgen.c b/tests/spec/ext_transform_feedback/pipeline-basic-primgen.c
> new file mode 100644
> index 0000000..e5b6a4e
> --- /dev/null
> +++ b/tests/spec/ext_transform_feedback/pipeline-basic-primgen.c
> @@ -0,0 +1,90 @@
> +/*
> + * Copyright © 2013 Marek Olšák <maraeo at gmail.com>
> + * Copyright © 2013 Intel Corporation
2014?
> + *
> + * 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.
> + */
> +
> +/**
> + * Tests if PRIMITIVES_GENERATED works with transform feedback disabled.
> + *
> + * From EXT_transform_feedback:
> + * "the primitives-generated count is incremented every time a primitive
> + * reaches the Discarding Rasterization stage"
> + */
> +
> +#include "piglit-util-gl.h"
> +
> +PIGLIT_GL_TEST_CONFIG_BEGIN
> +
> + config.supports_gl_compat_version = 10;
> + config.window_visual = PIGLIT_GL_VISUAL_DOUBLE | PIGLIT_GL_VISUAL_RGBA;
> +
> +PIGLIT_GL_TEST_CONFIG_END
> +
> +static const char *vstext = "void main() { gl_Position = gl_Vertex; }";
> +
> +void piglit_init(int argc, char **argv)
> +{
> + unsigned qresult;
> + int expected = 2;
> + GLuint vs;
> + GLuint prog;
> + GLuint q;
> +
> + /* Check the driver. */
> + piglit_require_gl_version(15);
> + piglit_require_GLSL();
> + piglit_require_transform_feedback();
> +
> + glGenQueries(1, &q);
> +
> + glEnable(GL_RASTERIZER_DISCARD);
> +
> + /* Create shaders. */
> + vs = piglit_compile_shader_text(GL_VERTEX_SHADER, vstext);
> + prog = glCreateProgram();
> + glAttachShader(prog, vs);
> + glLinkProgram(prog);
> + if (!piglit_link_check_status(prog)) {
> + glDeleteProgram(prog);
> + piglit_report_result(PIGLIT_FAIL);
> + }
> + glUseProgram(prog);
> +
> + /* Draw a rectangle; make sure two primitives were generated. */
> + glBeginQuery(GL_PRIMITIVES_GENERATED, q);
> + piglit_draw_rect(-1, -1, 2, 2);
> + glEndQuery(GL_PRIMITIVES_GENERATED);
> + glGetQueryObjectuiv(q, GL_QUERY_RESULT, &qresult);
> +
> + if (qresult != expected) {
> + printf("Primitives generated: %i, Expected: %i\n",
> + qresult, expected);
> + piglit_report_result(PIGLIT_FAIL);
> + }
Generally for transform feedback and other query buffer stuff, I've
wondered about wrap conditions. I haven't yet found where it's handled,
but for this one in particular, that's total meh.
> +
> + piglit_report_result(PIGLIT_PASS);
> +}
> +
> +enum piglit_result piglit_display(void)
> +{
> + return PIGLIT_FAIL; /* should not get here */
> +}
> --
> 2.1.3
Reviewed-by: Ben Widawsky <ben at bwidawsk.net>
Tested-by: Ben Widawsky <ben at bwidawsk.net>
--
Ben Widawsky, Intel Open Source Technology Center
More information about the Piglit
mailing list