[Piglit] [PATCH] tests: add INTEL_blackhole_render

Alejandro Piñeiro apinheiro at igalia.com
Fri Mar 16 07:31:18 UTC 2018


Looks good to me, just a minor comment below.


On 15/03/18 15:15, Lionel Landwerlin wrote:
> Signed-off-by: Lionel Landwerlin <lionel.g.landwerlin at intel.com>
> ---
>  registry/gl.xml                                    |   8 +-
>  tests/all.py                                       |   9 ++
>  tests/spec/CMakeLists.txt                          |   1 +
>  .../spec/intel_blackhole_render/CMakeLists.gl.txt  |  14 ++
>  .../intel_blackhole_render/CMakeLists.gles2.txt    |  13 ++
>  .../intel_blackhole_render/CMakeLists.gles3.txt    |  13 ++
>  tests/spec/intel_blackhole_render/CMakeLists.txt   |   1 +
>  .../intel_blackhole_render/blackhole_dispatch.c    | 127 +++++++++++++++++
>  tests/spec/intel_blackhole_render/blackhole_draw.c | 156 +++++++++++++++++++++
>  tests/spec/nv_image_formats/CMakeLists.gl.txt      |   8 ++
>  10 files changed, 349 insertions(+), 1 deletion(-)
>  create mode 100644 tests/spec/intel_blackhole_render/CMakeLists.gl.txt
>  create mode 100644 tests/spec/intel_blackhole_render/CMakeLists.gles2.txt
>  create mode 100644 tests/spec/intel_blackhole_render/CMakeLists.gles3.txt
>  create mode 100644 tests/spec/intel_blackhole_render/CMakeLists.txt
>  create mode 100644 tests/spec/intel_blackhole_render/blackhole_dispatch.c
>  create mode 100644 tests/spec/intel_blackhole_render/blackhole_draw.c
>  create mode 100644 tests/spec/nv_image_formats/CMakeLists.gl.txt
>
> diff --git a/registry/gl.xml b/registry/gl.xml
> index 7b13ff907..3c371905d 100644
> --- a/registry/gl.xml
> +++ b/registry/gl.xml
> @@ -4518,7 +4518,8 @@ typedef unsigned int GLhandleARB;
>          <enum value="0x83F9" name="GL_PERFQUERY_DONOT_FLUSH_INTEL"/>
>          <enum value="0x83FA" name="GL_PERFQUERY_FLUSH_INTEL"/>
>          <enum value="0x83FB" name="GL_PERFQUERY_WAIT_INTEL"/>
> -            <unused start="0x83FC" end="0x83FD" vendor="INTEL"/>
> +        <enum value="0x83FC" name="GL_BLACKHOLE_RENDER_INTEL"/>
> +            <unused start="0x83FD" vendor="INTEL"/>
>          <enum value="0x83FE" name="GL_CONSERVATIVE_RASTERIZATION_INTEL"/>
>          <enum value="0x83FF" name="GL_TEXTURE_MEMORY_LAYOUT_INTEL"/>
>      </enums>
> @@ -44054,6 +44055,11 @@ typedef unsigned int GLhandleARB;
>                  <command name="glMapTexture2DINTEL"/>
>              </require>
>          </extension>
> +        <extension name="GL_INTEL_blackhole_render" supported="gl|glcore|gles2">
> +            <require>
> +                <enum name="GL_BLACKHOLE_RENDER_INTEL"/>
> +            </require>
> +        </extension>
>          <extension name="GL_INTEL_parallel_arrays" supported="gl">
>              <require>
>                  <enum name="GL_PARALLEL_ARRAYS_INTEL"/>
> diff --git a/tests/all.py b/tests/all.py
> index 8c5877a63..c30a5dfdb 100644
> --- a/tests/all.py
> +++ b/tests/all.py
> @@ -4971,6 +4971,15 @@ with profile.test_list.group_manager(
>      g(['intel_conservative_rasterization-innercoverage_gles3'])
>      g(['intel_conservative_rasterization-tri_gles3'])
>  
> +# Group INTEL_blackhole_render
> +with profile.test_list.group_manager(
> +        PiglitGLTest,
> +        grouptools.join('spec', 'INTEL_blackhole_render')) as g:
> +    g(['intel_conservative_rasterization-draw'])
> +    g(['intel_conservative_rasterization-dispatch'])
> +    g(['intel_conservative_rasterization-draw_gles2'])
> +    g(['intel_conservative_rasterization-draw_gles3'])
> +
>  # Group ARB_bindless_texture
>  with profile.test_list.group_manager(
>  	PiglitGLTest,
> diff --git a/tests/spec/CMakeLists.txt b/tests/spec/CMakeLists.txt
> index e57e8d703..dc14beb4e 100644
> --- a/tests/spec/CMakeLists.txt
> +++ b/tests/spec/CMakeLists.txt
> @@ -177,3 +177,4 @@ add_subdirectory (arb_post_depth_coverage)
>  add_subdirectory (arb_fragment_shader_interlock)
>  add_subdirectory (ext_occlusion_query_boolean)
>  add_subdirectory (ext_disjoint_timer_query)
> +add_subdirectory (intel_blackhole_render)
> diff --git a/tests/spec/intel_blackhole_render/CMakeLists.gl.txt b/tests/spec/intel_blackhole_render/CMakeLists.gl.txt
> new file mode 100644
> index 000000000..379fc5f9a
> --- /dev/null
> +++ b/tests/spec/intel_blackhole_render/CMakeLists.gl.txt
> @@ -0,0 +1,14 @@
> +include_directories(
> +	${GLEXT_INCLUDE_DIR}
> +	${OPENGL_INCLUDE_PATH}
> +)
> +
> +link_libraries (
> +	piglitutil_${piglit_target_api}
> +	${OPENGL_gl_LIBRARY}
> +)
> +
> +piglit_add_executable (intel_blackhole-dispatch blackhole_dispatch.c)
> +piglit_add_executable (intel_blackhole-draw blackhole_draw.c)
> +
> +# vim: ft=cmake:
> diff --git a/tests/spec/intel_blackhole_render/CMakeLists.gles2.txt b/tests/spec/intel_blackhole_render/CMakeLists.gles2.txt
> new file mode 100644
> index 000000000..076c559d5
> --- /dev/null
> +++ b/tests/spec/intel_blackhole_render/CMakeLists.gles2.txt
> @@ -0,0 +1,13 @@
> +include_directories(
> +	${GLEXT_INCLUDE_DIR}
> +	${OPENGL_INCLUDE_PATH}
> +)
> +
> +link_libraries (
> +	piglitutil_${piglit_target_api}
> +	${OPENGL_gl_LIBRARY}
> +)

Is adding ${OPENGL_gl_LIBRARY} at link_libraries really needed at this
gles CMakeKist? As far as I have seen, most gles2/3 CMakeLists just adds
piglitutil_${piglit_target_api}.

> +
> +piglit_add_executable (intel_blackhole-draw_gles2 blackhole_draw.c)
> +
> +# vim: ft=cmake:
> diff --git a/tests/spec/intel_blackhole_render/CMakeLists.gles3.txt b/tests/spec/intel_blackhole_render/CMakeLists.gles3.txt
> new file mode 100644
> index 000000000..f0b912d99
> --- /dev/null
> +++ b/tests/spec/intel_blackhole_render/CMakeLists.gles3.txt
> @@ -0,0 +1,13 @@
> +include_directories(
> +	${GLEXT_INCLUDE_DIR}
> +	${OPENGL_INCLUDE_PATH}
> +)
> +
> +link_libraries (
> +	piglitutil_${piglit_target_api}
> +	${OPENGL_gl_LIBRARY}
> +)

Ditto.

If it is not needed, it would be good to simplify them, but in any case:
Reviewed-by: Alejandro Piñeiro <apinheiro at igalia.com>

> +
> +piglit_add_executable (intel_blackhole-draw_gles3 blackhole_draw.c)
> +
> +# vim: ft=cmake:
> diff --git a/tests/spec/intel_blackhole_render/CMakeLists.txt b/tests/spec/intel_blackhole_render/CMakeLists.txt
> new file mode 100644
> index 000000000..144a306f4
> --- /dev/null
> +++ b/tests/spec/intel_blackhole_render/CMakeLists.txt
> @@ -0,0 +1 @@
> +piglit_include_target_api()
> diff --git a/tests/spec/intel_blackhole_render/blackhole_dispatch.c b/tests/spec/intel_blackhole_render/blackhole_dispatch.c
> new file mode 100644
> index 000000000..6e9ed4203
> --- /dev/null
> +++ b/tests/spec/intel_blackhole_render/blackhole_dispatch.c
> @@ -0,0 +1,127 @@
> +/*
> + * Copyright © 2018 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 blackhole_draw.c
> + *
> + * Verifies that with GL_INTEL_black_render enabled, dispatch operations have no
> + * effect.
> + */
> +
> +#include "piglit-util-gl.h"
> +
> +PIGLIT_GL_TEST_CONFIG_BEGIN
> +
> +#if defined(PIGLIT_USE_OPENGL)
> +	config.supports_gl_core_version = 42;
> +#elif defined(PIGLIT_USE_OPENGL_ES2) || defined(PIGLIT_USE_OPENGL_ES3)
> +	config.supports_gl_es_version = 20;
> +#endif
> +	config.window_visual = PIGLIT_GL_VISUAL_DOUBLE | PIGLIT_GL_VISUAL_RGBA;
> +
> +PIGLIT_GL_TEST_CONFIG_END
> +
> +#define SIZE_X (4)
> +
> +static const char *compute_shader =
> +	"#version 430\n"
> +	"layout (local_size_x = 1) in;"
> +	"uniform float value;"
> +	"\n"
> +	"layout (std430, binding = 0) buffer OutBuf { float output_values[]; };\n"
> +	"\n"
> +	"void main()\n"
> +	"{\n"
> +	"    uint pos = gl_GlobalInvocationID.x;\n"
> +	"    output_values[pos] = value;\n"
> +	"}\n";
> +
> +enum piglit_result
> +piglit_display(void)
> +{
> +	return PIGLIT_FAIL;
> +}
> +
> +void
> +piglit_init(int argc, char **argv)
> +{
> +	enum piglit_result result = PIGLIT_PASS;
> +	GLuint data_bo = 0;
> +	GLfloat *data_buf;
> +	GLint ok = 1;
> +	GLint prog = 0;
> +	GLuint shader;
> +	const float one = 1.0f;
> +
> +	piglit_require_extension("GL_ARB_compute_shader");
> +
> +	data_buf = calloc(SIZE_X, sizeof(*data_buf));
> +	glGenBuffers(1, &data_bo);
> +	glBindBufferBase(GL_SHADER_STORAGE_BUFFER, 0, data_bo);
> +	glBufferData(GL_SHADER_STORAGE_BUFFER,
> +		     sizeof(float) * SIZE_X,
> +		     data_buf, GL_STATIC_DRAW);
> +	free(data_buf);
> +
> +	shader = glCreateShader(GL_COMPUTE_SHADER);
> +
> +	glShaderSource(shader, 1,
> +		       (const GLchar **) &compute_shader,
> +		       NULL);
> +
> +	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);
> +	glUniform1f(glGetUniformLocation(prog, "value"), 1.0f);
> +	glDispatchCompute(SIZE_X, 1, 1);
> +	glMemoryBarrier(GL_ALL_BARRIER_BITS);
> +
> +	if (!piglit_probe_buffer(data_bo, GL_SHADER_STORAGE_BUFFER, "output_values",
> +				 SIZE_X, 1, &one))
> +		result = PIGLIT_FAIL;
> +
> +	glEnable(GL_BLACKHOLE_RENDER_INTEL);
> +	glMemoryBarrier(GL_ALL_BARRIER_BITS);
> +	glUniform1f(glGetUniformLocation(prog, "value"), 2.0f);
> +	glDispatchCompute(SIZE_X, 1, 1);
> +	glMemoryBarrier(GL_ALL_BARRIER_BITS);
> +
> +	if (!piglit_probe_buffer(data_bo, GL_SHADER_STORAGE_BUFFER, "output_values",
> +				 SIZE_X, 1, &one))
> +		result = PIGLIT_FAIL;
> +
> +	piglit_report_result(result);
> +}
> diff --git a/tests/spec/intel_blackhole_render/blackhole_draw.c b/tests/spec/intel_blackhole_render/blackhole_draw.c
> new file mode 100644
> index 000000000..20d3ab57a
> --- /dev/null
> +++ b/tests/spec/intel_blackhole_render/blackhole_draw.c
> @@ -0,0 +1,156 @@
> +/*
> + * Copyright © 2018 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 blackhole_draw.c
> + *
> + * Verifies that with GL_INTEL_black_render enabled, rendering operations have
> + * no effect.
> + */
> +
> +#include "piglit-util-gl.h"
> +#include "piglit-matrix.h"
> +
> +PIGLIT_GL_TEST_CONFIG_BEGIN
> +
> +#if defined(PIGLIT_USE_OPENGL)
> +	config.supports_gl_core_version = 42;
> +#elif defined(PIGLIT_USE_OPENGL_ES2) || defined(PIGLIT_USE_OPENGL_ES3)
> +	config.supports_gl_es_version = 20;
> +#endif
> +
> +	config.window_width = 400;
> +	config.window_height = 400;
> +	config.window_visual = PIGLIT_GL_VISUAL_RGBA | PIGLIT_GL_VISUAL_DOUBLE;
> +
> +PIGLIT_GL_TEST_CONFIG_END
> +
> +enum piglit_result
> +piglit_display(void)
> +{
> +	float delta = 1.01 / piglit_width;
> +	GLuint prog;
> +
> +	prog = piglit_build_simple_program(
> +#if defined(PIGLIT_USE_OPENGL)
> +		"#version 330\n"
> +#elif defined(PIGLIT_USE_OPENGL_ES2) || defined(PIGLIT_USE_OPENGL_ES3)
> +		"#version 300 es\n"
> +#endif
> +		"in vec4 piglit_vertex;\n"
> +		"void main()\n"
> +		"{\n"
> +		"  gl_Position = piglit_vertex;\n"
> +		"}\n",
> +#if defined(PIGLIT_USE_OPENGL)
> +		"#version 330\n"
> +		"out vec4 color;\n"
> +#elif defined(PIGLIT_USE_OPENGL_ES2) || defined(PIGLIT_USE_OPENGL_ES3)
> +		"#version 300 es\n"
> +		"out highp vec4 color;\n"
> +#endif
> +		"void main()\n"
> +		"{\n"
> +		"  color = vec4(1.0, 0.0, 0.0, 1.0);\n"
> +		"}\n");
> +	if (!prog)
> +		piglit_report_result(PIGLIT_FAIL);
> +
> +	glBindFramebuffer(GL_DRAW_FRAMEBUFFER, piglit_winsys_fbo);
> +	glViewport(0, 0, piglit_width, piglit_height);
> +
> +	glClearColor(0.0, 0.0, 0.0, 0.0);
> +
> +	glUseProgram(prog);
> +
> +	GLuint vao;
> +	glGenVertexArrays(1, &vao);
> +	glBindVertexArray(vao);
> +
> +	GLuint vbo;
> +	float vertices[3][2] = {
> +		{ -0.5, -1 + delta, },
> +		{ 0, 0.8, },
> +		{ 0.5, -1 + delta, },
> +	};
> +	glGenBuffers(1, &vbo);
> +	glBindBuffer(GL_ARRAY_BUFFER, vbo);
> +	glBufferData(GL_ARRAY_BUFFER, sizeof(vertices), vertices, GL_STATIC_DRAW);
> +	glVertexAttribPointer(0, 2, GL_FLOAT, GL_FALSE, 2 * sizeof(GLfloat), NULL);
> +	glEnableVertexAttribArray(0);
> +
> +	glDisable(GL_BLACKHOLE_RENDER_INTEL);
> +	glClear(GL_COLOR_BUFFER_BIT);
> +	glDrawArrays(GL_TRIANGLES, 0, 3);
> +
> +	if(!piglit_check_gl_error(GL_NO_ERROR))
> +		return PIGLIT_FAIL;
> +
> +	piglit_present_results();
> +
> +	const float normal_expected[] = { 1.0, 0.0, 0.0, 1.0 };
> +	if (!piglit_probe_pixel_rgba(piglit_width / 2,
> +				     piglit_height / 2,
> +				     normal_expected))
> +		return PIGLIT_FAIL;
> +
> +	glClearColor(0.0, 1.0, 0.0, 1.0);
> +	glClear(GL_COLOR_BUFFER_BIT);
> +
> +	glEnable(GL_BLACKHOLE_RENDER_INTEL);
> +
> +	glDrawArrays(GL_TRIANGLES, 0, 3);
> +
> +	if(!piglit_check_gl_error(GL_NO_ERROR))
> +		return PIGLIT_FAIL;
> +
> +	piglit_present_results();
> +
> +	const float blackhole_draw_expected[] = { 0.0, 1.0, 0.0, 1.0 };
> +	if (!piglit_probe_pixel_rgba(piglit_width / 2,
> +				     piglit_height / 2,
> +				     blackhole_draw_expected))
> +		return PIGLIT_FAIL;
> +
> +	glClearColor(1.0, 0.0, 0.0, 1.0);
> +
> +	if(!piglit_check_gl_error(GL_NO_ERROR))
> +		return PIGLIT_FAIL;
> +
> +	piglit_present_results();
> +
> +	const float blackhole_clear_expected[] = { 0.0, 1.0, 0.0, 1.0 };
> +	if (!piglit_probe_pixel_rgba(piglit_width / 2,
> +				     piglit_height / 2,
> +				     blackhole_clear_expected))
> +		return PIGLIT_FAIL;
> +
> +	glDisable(GL_BLACKHOLE_RENDER_INTEL);
> +
> +	return PIGLIT_PASS;
> +}
> +
> +void piglit_init(int argc, char **argv)
> +{
> +	piglit_require_extension("GL_INTEL_blackhole_render");
> +}
> diff --git a/tests/spec/nv_image_formats/CMakeLists.gl.txt b/tests/spec/nv_image_formats/CMakeLists.gl.txt
> new file mode 100644
> index 000000000..ef1b22d5e
> --- /dev/null
> +++ b/tests/spec/nv_image_formats/CMakeLists.gl.txt
> @@ -0,0 +1,8 @@
> +link_libraries(
> +	piglitutil_${piglit_target_api}
> +	${OPENGL_gl_LIBRARY}
> +	)
> +
> +piglit_add_executable (nv_image_formats copy-image-formats.c)
> +
> +# vim: ft=cmake:



More information about the Piglit mailing list