[Piglit] [PATCH 1/2] arb_direct_state_access: Remove over-complicated getcompressedtextureimage test.

Laura Ekstrand laura at jlekstrand.net
Fri Feb 13 11:36:35 PST 2015


---
 .../getcompressedtextureimage.c                    | 447 ---------------------
 1 file changed, 447 deletions(-)
 delete mode 100644 tests/spec/arb_direct_state_access/getcompressedtextureimage.c

diff --git a/tests/spec/arb_direct_state_access/getcompressedtextureimage.c b/tests/spec/arb_direct_state_access/getcompressedtextureimage.c
deleted file mode 100644
index ca39b3e..0000000
--- a/tests/spec/arb_direct_state_access/getcompressedtextureimage.c
+++ /dev/null
@@ -1,447 +0,0 @@
-/*
- * Copyright © 2012 Marek Olšák <maraeo at gmail.com>
- * 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 getcompressedtextureimage-targets.c
- *
- * Adapted for testing glGetCompressedTextureImage in ARB_direct_state_access
- * by Laura Ekstrand <laura at jlekstrand.net>, November 2014.
- */
-
-#include "piglit-util-gl.h"
-
-PIGLIT_GL_TEST_CONFIG_BEGIN
-
-	config.window_width = 216;
-	config.supports_gl_compat_version = 10;
-
-	config.window_visual = PIGLIT_GL_VISUAL_RGBA |
-			       PIGLIT_GL_VISUAL_DOUBLE;
-
-PIGLIT_GL_TEST_CONFIG_END
-
-#define IMAGE_WIDTH 32
-#define IMAGE_HEIGHT 32
-#define IMAGE_SIZE (IMAGE_WIDTH * IMAGE_HEIGHT * 4)
-#define DISPLAY_GAP 4
-
-static void
-show_image(GLubyte *data, int num_layers, const char *title)
-{
-	GLuint name;
-	int i;
-	char junk[50];
-
-	if (!piglit_automatic) {
-		/* Create the texture handle. */
-		glCreateTextures(GL_TEXTURE_2D, 1, &name);
-		glTextureStorage2D(name, 1, GL_RGBA8, IMAGE_WIDTH,
-			IMAGE_HEIGHT);
-		glTextureParameteri(name, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
-		glTextureParameteri(name, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
-		glEnable(GL_TEXTURE_2D);
-		glBindTextureUnit(0, name);
-
-		/* Draw the layers, separated by some space */
-		glClear(GL_COLOR_BUFFER_BIT);
-		for (i = 0; i < num_layers; ++i) {
-			int x = (IMAGE_WIDTH + DISPLAY_GAP) * (i % 6);
-			int y = (IMAGE_HEIGHT + DISPLAY_GAP) * (i / 6);
-			glTextureSubImage2D(name, 0, 0, 0,
-					    IMAGE_WIDTH, IMAGE_HEIGHT,
-					    GL_RGBA, GL_UNSIGNED_BYTE,
-					    data + i * IMAGE_SIZE);
-			piglit_draw_rect_tex(x, y, IMAGE_WIDTH, IMAGE_HEIGHT,
-					     0, 0, 1, 1);
-		}
-
-		/* Make the title. */
-		printf("****** %s ******\n", title);
-
-		piglit_present_results();
-
-		/* Pause. */
-		printf("Enter any char to continue.\n>>>>>>");
-		scanf("%s", junk);
-		printf("\n");
-
-		glDeleteTextures(1, &name);
-	}
-}
-
-static GLubyte *
-make_layer_data(int num_layers)
-{
-	int x, y, z;
-	GLubyte *layer_data =
-		malloc(num_layers * IMAGE_SIZE * sizeof(GLubyte));
-	int num_channels = IMAGE_SIZE/(IMAGE_WIDTH * IMAGE_HEIGHT);
-
-	for (z = 0; z < num_layers; z++) {
-		/* Get some data, but make sure the faces are different */
-		GLubyte *data = piglit_rgbw_image_ubyte(IMAGE_WIDTH,
-							IMAGE_HEIGHT, true);
-		for (y = 0; y < IMAGE_HEIGHT; ++y) {
-			for (x = 0; x < IMAGE_WIDTH; ++x) {
-				int idx = num_channels*(IMAGE_WIDTH*y + x);
-				data[idx+0] *= ((float) (z + 1)/ (float) num_layers);
-				data[idx+1] *= ((float) (z + 1)/ (float) num_layers);
-				data[idx+2] *= ((float) (z + 1)/ (float) num_layers);
-			}
-		}
-
-		/* Copy in the data */
-		memcpy(layer_data + IMAGE_SIZE * z, data, IMAGE_SIZE);
-
-		free(data);
-	}
-
-	/* Show the first layer of the completed layer data. */
-	show_image(layer_data, num_layers, "Test Data");
-
-	return layer_data;
-}
-
-static bool
-compare_layer(int layer, int num_elements, int tolerance,
-			  GLubyte *data, GLubyte *expected)
-{
-	int i;
-
-	for (i = 0; i < num_elements; ++i) {
-		if (fabs((int)data[i] - (int)expected[i]) > tolerance) {
-			printf("GetCompressedTextureImage() returns incorrect"
-			       " data in byte %i for layer %i\n",
-			       i, layer);
-			printf("    corresponding to (%i,%i), channel %i\n",
-			       (i / 4) / IMAGE_WIDTH, (i / 4) % IMAGE_HEIGHT,
-				i % 4);
-			printf("    expected: %i\n", expected[i]);
-			printf("    got: %i\n", data[i]);
-			return false;
-		}
-	}
-	return true;
-}
-
-static enum piglit_result
-getTexImage(bool doPBO, GLenum target, GLubyte *data,
-	    GLenum internalformat, int tolerance)
-{
-	int i;
-	int num_layers=1, num_faces=1, layer_size;
-	GLubyte *data2 = NULL;
-	GLubyte *dataGet;
-	GLuint packPBO;
-	bool pass = true;
-	GLuint name;
-	GLint compressed;
-	GLint comp_size;
-
-	/* Upload the data. */
-	switch (target) {
-
-	/* These are all targets that can be compressed according to
-	 * _mesa_target_can_be_compressed */
-
-	case GL_TEXTURE_2D:
-		glCreateTextures(target, 1, &name);
-		glTextureStorage2D(name, 1, internalformat, IMAGE_WIDTH,
-				   IMAGE_HEIGHT);
-		glTextureSubImage2D(name, 0, 0, 0, IMAGE_WIDTH, IMAGE_HEIGHT,
-				    GL_RGBA, GL_UNSIGNED_BYTE, data);
-		layer_size = IMAGE_SIZE;
-		break;
-
-	case GL_TEXTURE_CUBE_MAP:
-		num_faces = 6;
-		glCreateTextures(target, 1, &name);
-		/* This is invalid. You must use 2D storage call for cube. */
-		glTextureStorage3D(name, 1, internalformat,
-				   IMAGE_WIDTH, IMAGE_HEIGHT, num_faces);
-		pass &= piglit_check_gl_error(GL_INVALID_ENUM);
-		glTextureStorage2D(name, 1, internalformat,
-				   IMAGE_WIDTH, IMAGE_HEIGHT);
-		/* This is legal. */
-		glTextureSubImage3D(name, 0, 0, 0, 0, IMAGE_WIDTH,
-				    IMAGE_HEIGHT, num_faces, GL_RGBA,
-				    GL_UNSIGNED_BYTE, data);
-		layer_size = IMAGE_SIZE;
-		break;
-
-	case GL_TEXTURE_2D_ARRAY:
-	case GL_TEXTURE_CUBE_MAP_ARRAY:
-		num_layers = 6 * 3;
-		glCreateTextures(target, 1, &name);
-		glTextureStorage3D(name, 1, internalformat, IMAGE_WIDTH,
-				   IMAGE_HEIGHT, num_layers);
-		glTextureSubImage3D(name, 0, 0, 0, 0,
-				    IMAGE_WIDTH, IMAGE_HEIGHT, num_layers,
-				    GL_RGBA, GL_UNSIGNED_BYTE, data);
-		layer_size = IMAGE_SIZE;
-		break;
-
-	default:
-		puts("Invalid texture target.");
-		return PIGLIT_FAIL;
-
-	}
-
-	/* Make sure the driver has compressed the image. */
-	glGetTextureLevelParameteriv(name, 0, GL_TEXTURE_COMPRESSED,
-		&compressed);
-	printf("\tIs the texture compressed? %s.\n",
-		compressed ? "yes" : "no");
-
-	glGetTextureLevelParameteriv(name, 0,
-				     GL_TEXTURE_COMPRESSED_IMAGE_SIZE,
-				     &comp_size);
-	/*  The OpenGL 4.5 core spec
-	 *  (30.10.2014) Section 8.11 Texture Queries says:
-	 *       "For GetTextureLevelParameter* only, texture may also be a
-	 *       cube map texture object.  In this case the query is always
-	 *       performed for face zero (the TEXTURE_CUBE_MAP_POSITIVE_X
-	 *       face), since there is no way to specify another face."
-	 */
-	if (target == GL_TEXTURE_CUBE_MAP)
-		comp_size *= num_faces;
-	printf("\tThe size of the texture in bytes is %d.\n", comp_size);
-
-	/* Show the uncompressed data. */
-	show_image(data, num_layers * num_faces, "Data Before Compression");
-
-
-	/* Setup the PBO or data array to read into from
-	 * glGetCompressedTextureImage */
-	if (doPBO) {
-		glCreateBuffers(1, &packPBO);
-		glBindBuffer(GL_PIXEL_PACK_BUFFER, packPBO);
-		/* Make the buffer big enough to hold uncompressed data. */
-		glBufferData(GL_PIXEL_PACK_BUFFER, layer_size * num_faces *
-			     num_layers * sizeof(GLubyte),
-			     NULL, GL_STREAM_READ);
-	} else {
-		glBindBuffer(GL_PIXEL_PACK_BUFFER, 0);
-		data2 = malloc(layer_size * num_faces * num_layers *
-			       sizeof(GLubyte));
-		memset(data2, 123, layer_size * num_faces * num_layers *
-			       sizeof(GLubyte));
-	}
-	pass = piglit_check_gl_error(GL_NO_ERROR) && pass;
-	assert(num_layers * num_faces * layer_size <= 18 * IMAGE_SIZE);
-
-
-	/* Download the compressed texture image. */
-	if (doPBO)
-		glGetCompressedTextureImage(name, 0, comp_size, NULL);
-	else
-		glGetCompressedTextureImage(name, 0, comp_size, data2);
-	pass = piglit_check_gl_error(GL_NO_ERROR) && pass;
-
-	if (doPBO)
-		dataGet = (GLubyte *) glMapBufferRange(
-					       GL_PIXEL_PACK_BUFFER, 0,
-					       comp_size,
-					       GL_MAP_READ_BIT);
-	else
-		dataGet = data2;
-
-	/* Re-upload the texture in compressed form. */
-	switch (target) {
-	case GL_TEXTURE_2D:
-		glCompressedTextureSubImage2D(name, 0, 0, 0,
-					      IMAGE_WIDTH, IMAGE_HEIGHT,
-					      internalformat, comp_size,
-					      dataGet);
-		break;
-
-	case GL_TEXTURE_CUBE_MAP:
-		glCompressedTextureSubImage3D(name, 0, 0, 0, 0,
-					      IMAGE_WIDTH, IMAGE_HEIGHT,
-					      num_faces,
-					      internalformat, comp_size,
-					      dataGet);
-		break;
-
-	case GL_TEXTURE_2D_ARRAY:
-	case GL_TEXTURE_CUBE_MAP_ARRAY:
-		glCompressedTextureSubImage3D(name, 0, 0, 0, 0,
-					      IMAGE_WIDTH, IMAGE_HEIGHT,
-					      num_layers,
-					      internalformat, comp_size,
-					      dataGet);
-		break;
-	}
-
-
-	/* Get the uncompressed version for comparison. */
-	if (doPBO) {
-		glUnmapBuffer(GL_PIXEL_PACK_BUFFER);
-		glGetTextureImage(name, 0, GL_RGBA, GL_UNSIGNED_BYTE,
-			layer_size * num_layers * num_faces * sizeof(GLubyte),
-			NULL);
-	}
-	else {
-		glGetTextureImage(name, 0, GL_RGBA, GL_UNSIGNED_BYTE,
-			layer_size * num_layers * num_faces * sizeof(GLubyte),
-			data2);
-	}
-	pass = piglit_check_gl_error(GL_NO_ERROR) && pass;
-	if (doPBO)
-		dataGet = (GLubyte *) glMapBufferRange(
-					       GL_PIXEL_PACK_BUFFER, 0,
-					       layer_size * num_layers *
-					       num_faces * sizeof(GLubyte),
-					       GL_MAP_READ_BIT);
-	else
-		dataGet = data2;
-
-	/* Examine the image after pulling it off the graphics card. */
-	show_image(dataGet, num_layers * num_faces, "Data After Compression");
-
-	/* Do the comparison */
-	for (i = 0; i < num_faces * num_layers; i++) {
-		pass = compare_layer(i, layer_size, tolerance, dataGet,
-				     data + (i * layer_size)) && pass;
-		dataGet += layer_size;
-	}
-
-	if (doPBO) {
-		glUnmapBuffer(GL_PIXEL_PACK_BUFFER);
-		glDeleteBuffers(1, &packPBO);
-	}
-
-	glDeleteTextures(1, &name);
-	free(data2);
-
-	return pass ? PIGLIT_PASS : PIGLIT_FAIL;
-}
-
-struct target_and_mask {
-	GLenum target;
-	bool mask;
-};
-
-static struct target_and_mask targets[] = {
-	{GL_TEXTURE_2D, 1},
-	{GL_TEXTURE_CUBE_MAP, 1},
-	{GL_TEXTURE_2D_ARRAY, 1},
-	{GL_TEXTURE_CUBE_MAP_ARRAY, 1},
-};
-
-static void
-clear_target_mask(GLenum target)
-{
-	int i;
-	for (i = 0; i < ARRAY_SIZE(targets); ++i) {
-		if (targets[i].target == target) {
-			targets[i].mask = 0;
-		}
-	}
-}
-
-void
-piglit_init(int argc, char **argv)
-{
-	piglit_require_extension("GL_ARB_direct_state_access");
-	piglit_require_extension("GL_ARB_texture_storage");
-
-	if (!piglit_is_extension_supported("GL_ARB_texture_cube_map"))
-		clear_target_mask(GL_TEXTURE_CUBE_MAP);
-	if (!piglit_is_extension_supported("GL_EXT_texture_array")) {
-		clear_target_mask(GL_TEXTURE_2D_ARRAY);
-	}
-	if (!piglit_is_extension_supported("GL_ARB_texture_cube_map_array"))
-		clear_target_mask(GL_TEXTURE_CUBE_MAP_ARRAY);
-
-	glClearColor(0.5, 0.5, 0.5, 1);
-	piglit_ortho_projection(piglit_width, piglit_height, GL_FALSE);
-}
-
-enum piglit_result
-piglit_display(void)
-{
-	int i;
-	GLenum internalformat = GL_COMPRESSED_RGBA_FXT1_3DFX;
-	int tolerance = 8;
-	GLubyte *data;
-	enum piglit_result subtest;
-	enum piglit_result result = PIGLIT_PASS;
-
-	piglit_require_extension("GL_3DFX_texture_compression_FXT1");
-
-	data = make_layer_data(18);
-
-	for (i = 0; i < ARRAY_SIZE(targets); ++i) {
-		if (!targets[i].mask)
-			continue;
-
-		printf("Testing %s into PBO\n",
-			piglit_get_gl_enum_name(targets[i].target));
-		subtest = getTexImage(true, targets[i].target, data,
-				      internalformat, tolerance);
-		piglit_report_subtest_result(subtest, "getTexImage %s PBO",
-					     piglit_get_gl_enum_name(
-						targets[i].target));
-		if (subtest == PIGLIT_FAIL)
-			result = PIGLIT_FAIL;
-
-		printf("\n"); /* Separate tests with some white space. */
-
-		printf("Testing %s into client array\n",
-			piglit_get_gl_enum_name(targets[i].target));
-		subtest = getTexImage(false, targets[i].target, data,
-				      internalformat, tolerance);
-		piglit_report_subtest_result(subtest, "getTexImage %s",
-					     piglit_get_gl_enum_name(
-						targets[i].target));
-		if (subtest == PIGLIT_FAIL)
-			result = PIGLIT_FAIL;
-
-		printf("\n\n"); /* Separate targets with some white space. */
-
-		if (!piglit_check_gl_error(GL_NO_ERROR))
-			result = PIGLIT_FAIL;
-	}
-
-	/* 1D targets can't be compressed in Mesa right now,
-	 * but here is a trivial test for the entry point. */
-	glCompressedTextureSubImage1D(250, 0, 0, 60,
-				      internalformat, 60*4*8,
-				      NULL);
-
-	if (!piglit_check_gl_error(GL_INVALID_OPERATION)) /* Bad texture */
-		subtest = PIGLIT_FAIL;
-	else
-		subtest = PIGLIT_PASS;
-	piglit_report_subtest_result(subtest, "Compressed Texture"
-				     " Sub Image 1D");
-	if (subtest == PIGLIT_FAIL)
-		result = PIGLIT_FAIL;
-
-	free(data);
-
-	return result;
-}
-
-- 
2.1.0



More information about the Piglit mailing list