[Piglit] [PATCH] Add a very basic version of the "primgen" test.

Ben Widawsky ben at bwidawsk.net
Wed Nov 12 12:24:03 PST 2014


On Wed, Nov 12, 2014 at 11:53:11AM -0800, Ben Widawsky wrote:
> 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

Sorry, ignore this. I changed some mail settings recently, and my client
wrapped it.

> 
> >  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

-- 
Ben Widawsky, Intel Open Source Technology Center


More information about the Piglit mailing list