1 /*-------------------------------------------------------------------------
2  * drawElements Quality Program OpenGL (ES) Module
3  * -----------------------------------------------
4  *
5  * Copyright 2015 The Android Open Source Project
6  *
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  *
11  *      http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  *
19  *//*!
20  * \file
21  * \brief Texture State Query tests.
22  *//*--------------------------------------------------------------------*/
23 
24 #include "glsTextureStateQueryTests.hpp"
25 #include "gluStrUtil.hpp"
26 #include "gluObjectWrapper.hpp"
27 #include "gluCallLogWrapper.hpp"
28 #include "gluContextInfo.hpp"
29 #include "gluTextureUtil.hpp"
30 #include "glwEnums.hpp"
31 #include "deUniquePtr.hpp"
32 #include "deRandom.hpp"
33 #include "deStringUtil.hpp"
34 
35 namespace deqp
36 {
37 namespace gls
38 {
39 namespace TextureStateQueryTests
40 {
41 namespace
42 {
43 
44 using namespace glw;
45 using namespace gls::StateQueryUtil;
46 
mapTesterToPname(TesterType tester)47 static glw::GLenum mapTesterToPname (TesterType tester)
48 {
49 
50 #define CASE_ALL_SETTERS(X) case X: case X ## _SET_PURE_INT: case X ## _SET_PURE_UINT
51 
52 	switch (tester)
53 	{
54 		CASE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_R):				return GL_TEXTURE_SWIZZLE_R;
55 		CASE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_G):				return GL_TEXTURE_SWIZZLE_G;
56 		CASE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_B):				return GL_TEXTURE_SWIZZLE_B;
57 		CASE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_A):				return GL_TEXTURE_SWIZZLE_A;
58 
59 		CASE_ALL_SETTERS(TESTER_TEXTURE_WRAP_S):
60 		case TESTER_TEXTURE_WRAP_S_CLAMP_TO_BORDER:				return GL_TEXTURE_WRAP_S;
61 
62 		CASE_ALL_SETTERS(TESTER_TEXTURE_WRAP_T):
63 		case TESTER_TEXTURE_WRAP_T_CLAMP_TO_BORDER:				return GL_TEXTURE_WRAP_T;
64 
65 		CASE_ALL_SETTERS(TESTER_TEXTURE_WRAP_R):
66 		case TESTER_TEXTURE_WRAP_R_CLAMP_TO_BORDER:				return GL_TEXTURE_WRAP_R;
67 
68 		CASE_ALL_SETTERS(TESTER_TEXTURE_MAG_FILTER):			return GL_TEXTURE_MAG_FILTER;
69 		CASE_ALL_SETTERS(TESTER_TEXTURE_MIN_FILTER):			return GL_TEXTURE_MIN_FILTER;
70 		CASE_ALL_SETTERS(TESTER_TEXTURE_MIN_LOD):				return GL_TEXTURE_MIN_LOD;
71 		CASE_ALL_SETTERS(TESTER_TEXTURE_MAX_LOD):				return GL_TEXTURE_MAX_LOD;
72 		CASE_ALL_SETTERS(TESTER_TEXTURE_BASE_LEVEL):			return GL_TEXTURE_BASE_LEVEL;
73 		CASE_ALL_SETTERS(TESTER_TEXTURE_MAX_LEVEL):				return GL_TEXTURE_MAX_LEVEL;
74 		CASE_ALL_SETTERS(TESTER_TEXTURE_COMPARE_MODE):			return GL_TEXTURE_COMPARE_MODE;
75 		CASE_ALL_SETTERS(TESTER_TEXTURE_COMPARE_FUNC):			return GL_TEXTURE_COMPARE_FUNC;
76 		case TESTER_TEXTURE_IMMUTABLE_LEVELS:					return GL_TEXTURE_IMMUTABLE_LEVELS;
77 		case TESTER_TEXTURE_IMMUTABLE_FORMAT:					return GL_TEXTURE_IMMUTABLE_FORMAT;
78 		CASE_ALL_SETTERS(TESTER_DEPTH_STENCIL_TEXTURE_MODE):	return GL_DEPTH_STENCIL_TEXTURE_MODE;
79 		CASE_ALL_SETTERS(TESTER_TEXTURE_SRGB_DECODE_EXT):		return GL_TEXTURE_SRGB_DECODE_EXT;
80 		case TESTER_TEXTURE_BORDER_COLOR:						return GL_TEXTURE_BORDER_COLOR;
81 
82 		default:
83 			DE_ASSERT(false);
84 			return -1;
85 	}
86 
87 #undef CASE_PURE_SETTERS
88 }
89 
querySupportsSigned(QueryType type)90 static bool querySupportsSigned (QueryType type)
91 {
92 	return	type != QUERY_TEXTURE_PARAM_PURE_UNSIGNED_INTEGER &&
93 			type != QUERY_SAMPLER_PARAM_PURE_UNSIGNED_INTEGER;
94 }
95 
isPureIntTester(TesterType tester)96 static bool isPureIntTester (TesterType tester)
97 {
98 #define HANDLE_ALL_SETTERS(X) \
99 		case X: \
100 		case X ## _SET_PURE_UINT: return false; \
101 		case X ## _SET_PURE_INT: return true;
102 
103 	switch (tester)
104 	{
105 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_R)
106 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_G)
107 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_B)
108 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_A)
109 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_WRAP_S)
110 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_WRAP_T)
111 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_WRAP_R)
112 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_MAG_FILTER)
113 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_MIN_FILTER)
114 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_MIN_LOD)
115 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_MAX_LOD)
116 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_BASE_LEVEL)
117 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_MAX_LEVEL)
118 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_COMPARE_MODE)
119 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_COMPARE_FUNC)
120 		HANDLE_ALL_SETTERS(TESTER_DEPTH_STENCIL_TEXTURE_MODE)
121 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_SRGB_DECODE_EXT)
122 
123 		case TESTER_TEXTURE_IMMUTABLE_LEVELS:
124 		case TESTER_TEXTURE_IMMUTABLE_FORMAT:
125 		case TESTER_TEXTURE_WRAP_S_CLAMP_TO_BORDER:
126 		case TESTER_TEXTURE_WRAP_T_CLAMP_TO_BORDER:
127 		case TESTER_TEXTURE_WRAP_R_CLAMP_TO_BORDER:
128 		case TESTER_TEXTURE_BORDER_COLOR:
129 			return false;
130 
131 		default:
132 			DE_ASSERT(false);
133 			return false;
134 	}
135 
136 #undef HANDLE_ALL_SETTERS
137 }
138 
isPureUintTester(TesterType tester)139 static bool isPureUintTester (TesterType tester)
140 {
141 #define HANDLE_ALL_SETTERS(X) \
142 		case X: \
143 		case X ## _SET_PURE_INT: return false; \
144 		case X ## _SET_PURE_UINT: return true;
145 
146 	switch (tester)
147 	{
148 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_R)
149 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_G)
150 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_B)
151 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_A)
152 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_WRAP_S)
153 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_WRAP_T)
154 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_WRAP_R)
155 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_MAG_FILTER)
156 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_MIN_FILTER)
157 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_MIN_LOD)
158 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_MAX_LOD)
159 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_BASE_LEVEL)
160 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_MAX_LEVEL)
161 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_COMPARE_MODE)
162 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_COMPARE_FUNC)
163 		HANDLE_ALL_SETTERS(TESTER_DEPTH_STENCIL_TEXTURE_MODE)
164 		HANDLE_ALL_SETTERS(TESTER_TEXTURE_SRGB_DECODE_EXT)
165 
166 		case TESTER_TEXTURE_IMMUTABLE_LEVELS:
167 		case TESTER_TEXTURE_IMMUTABLE_FORMAT:
168 		case TESTER_TEXTURE_WRAP_S_CLAMP_TO_BORDER:
169 		case TESTER_TEXTURE_WRAP_T_CLAMP_TO_BORDER:
170 		case TESTER_TEXTURE_WRAP_R_CLAMP_TO_BORDER:
171 		case TESTER_TEXTURE_BORDER_COLOR:
172 			return false;
173 
174 		default:
175 			DE_ASSERT(false);
176 			return false;
177 	}
178 
179 #undef HANDLE_ALL_SETTERS
180 }
181 
182 class RequiredExtensions
183 {
184 public:
RequiredExtensions(void)185 								RequiredExtensions	(void)									{ }
RequiredExtensions(const char * ext)186 	explicit					RequiredExtensions	(const char* ext)						{ add(ext);				}
RequiredExtensions(const char * extA,const char * extB)187 								RequiredExtensions	(const char* extA, const char* extB)	{ add(extA); add(extB);	}
188 
189 	void						add					(const char* ext);
190 	void						add					(const RequiredExtensions& other);
191 	void						check				(const glu::ContextInfo&) const;
192 
193 private:
194 	std::vector<const char*>	m_extensions;
195 };
196 
add(const char * ext)197 void RequiredExtensions::add (const char* ext)
198 {
199 	for (int ndx = 0; ndx < (int)m_extensions.size(); ++ndx)
200 		if (deStringEqual(m_extensions[ndx], ext) == DE_TRUE)
201 			return;
202 	m_extensions.push_back(ext);
203 }
204 
add(const RequiredExtensions & other)205 void RequiredExtensions::add (const RequiredExtensions& other)
206 {
207 	for (int ndx = 0; ndx < (int)other.m_extensions.size(); ++ndx)
208 		add(other.m_extensions[ndx]);
209 }
210 
check(const glu::ContextInfo & ctxInfo) const211 void RequiredExtensions::check (const glu::ContextInfo& ctxInfo) const
212 {
213 	std::vector<const char*> failedExtensions;
214 
215 	for (int ndx = 0; ndx < (int)m_extensions.size(); ++ndx)
216 		if (!ctxInfo.isExtensionSupported(m_extensions[ndx]))
217 			failedExtensions.push_back(m_extensions[ndx]);
218 
219 	if (!failedExtensions.empty())
220 	{
221 		std::ostringstream buf;
222 		buf << "Test requires extension: ";
223 
224 		for (int ndx = 0; ndx < (int)failedExtensions.size(); ++ndx)
225 		{
226 			if (ndx)
227 				buf << ", ";
228 			buf << failedExtensions[ndx];
229 		}
230 
231 		throw tcu::NotSupportedError(buf.str());
232 	}
233 }
234 
235 namespace es30
236 {
237 
isCoreTextureTarget(glw::GLenum target)238 static bool isCoreTextureTarget (glw::GLenum target)
239 {
240 	return	target == GL_TEXTURE_2D			||
241 			target == GL_TEXTURE_3D			||
242 			target == GL_TEXTURE_2D_ARRAY	||
243 			target == GL_TEXTURE_CUBE_MAP;
244 }
245 
getTextureTargetExtension(glw::GLenum target)246 static RequiredExtensions getTextureTargetExtension (glw::GLenum target)
247 {
248 	DE_UNREF(target);
249 	DE_ASSERT(false);
250 	return RequiredExtensions();
251 }
252 
isCoreTextureParam(glw::GLenum pname)253 static bool isCoreTextureParam (glw::GLenum pname)
254 {
255 	return	pname == GL_TEXTURE_BASE_LEVEL			||
256 			pname == GL_TEXTURE_COMPARE_MODE		||
257 			pname == GL_TEXTURE_COMPARE_FUNC		||
258 			pname == GL_TEXTURE_MAG_FILTER			||
259 			pname == GL_TEXTURE_MAX_LEVEL			||
260 			pname == GL_TEXTURE_MAX_LOD				||
261 			pname == GL_TEXTURE_MIN_FILTER			||
262 			pname == GL_TEXTURE_MIN_LOD				||
263 			pname == GL_TEXTURE_SWIZZLE_R			||
264 			pname == GL_TEXTURE_SWIZZLE_G			||
265 			pname == GL_TEXTURE_SWIZZLE_B			||
266 			pname == GL_TEXTURE_SWIZZLE_A			||
267 			pname == GL_TEXTURE_WRAP_S				||
268 			pname == GL_TEXTURE_WRAP_T				||
269 			pname == GL_TEXTURE_WRAP_R				||
270 			pname == GL_TEXTURE_IMMUTABLE_FORMAT	||
271 			pname == GL_TEXTURE_IMMUTABLE_LEVELS;
272 }
273 
getTextureParamExtension(glw::GLenum pname)274 static RequiredExtensions getTextureParamExtension (glw::GLenum pname)
275 {
276 	DE_UNREF(pname);
277 	DE_ASSERT(false);
278 	return RequiredExtensions();
279 }
280 
isCoreQuery(QueryType query)281 static bool isCoreQuery (QueryType query)
282 {
283 	return	query == QUERY_TEXTURE_PARAM_INTEGER		||
284 			query == QUERY_TEXTURE_PARAM_FLOAT			||
285 			query == QUERY_TEXTURE_PARAM_INTEGER_VEC4	||
286 			query == QUERY_TEXTURE_PARAM_FLOAT_VEC4		||
287 			query == QUERY_SAMPLER_PARAM_INTEGER		||
288 			query == QUERY_SAMPLER_PARAM_FLOAT			||
289 			query == QUERY_SAMPLER_PARAM_INTEGER_VEC4	||
290 			query == QUERY_SAMPLER_PARAM_FLOAT_VEC4;
291 }
292 
getQueryExtension(QueryType query)293 static RequiredExtensions getQueryExtension (QueryType query)
294 {
295 	DE_UNREF(query);
296 	DE_ASSERT(false);
297 	return RequiredExtensions();
298 }
299 
isCoreTester(TesterType tester)300 static bool isCoreTester (TesterType tester)
301 {
302 	return	tester == TESTER_TEXTURE_SWIZZLE_R			||
303 			tester == TESTER_TEXTURE_SWIZZLE_G			||
304 			tester == TESTER_TEXTURE_SWIZZLE_B			||
305 			tester == TESTER_TEXTURE_SWIZZLE_A			||
306 			tester == TESTER_TEXTURE_WRAP_S				||
307 			tester == TESTER_TEXTURE_WRAP_T				||
308 			tester == TESTER_TEXTURE_WRAP_R				||
309 			tester == TESTER_TEXTURE_MAG_FILTER			||
310 			tester == TESTER_TEXTURE_MIN_FILTER			||
311 			tester == TESTER_TEXTURE_MIN_LOD			||
312 			tester == TESTER_TEXTURE_MAX_LOD			||
313 			tester == TESTER_TEXTURE_BASE_LEVEL			||
314 			tester == TESTER_TEXTURE_MAX_LEVEL			||
315 			tester == TESTER_TEXTURE_COMPARE_MODE		||
316 			tester == TESTER_TEXTURE_COMPARE_FUNC		||
317 			tester == TESTER_TEXTURE_IMMUTABLE_LEVELS	||
318 			tester == TESTER_TEXTURE_IMMUTABLE_FORMAT;
319 }
320 
getTesterExtension(TesterType tester)321 static RequiredExtensions getTesterExtension (TesterType tester)
322 {
323 	DE_UNREF(tester);
324 	DE_ASSERT(false);
325 	return RequiredExtensions();
326 }
327 
328 } // es30
329 
330 namespace es31
331 {
332 
isCoreTextureTarget(glw::GLenum target)333 static bool isCoreTextureTarget (glw::GLenum target)
334 {
335 	return	es30::isCoreTextureTarget(target) ||
336 			target == GL_TEXTURE_2D_MULTISAMPLE;
337 }
338 
getTextureTargetExtension(glw::GLenum target)339 static RequiredExtensions getTextureTargetExtension (glw::GLenum target)
340 {
341 	switch (target)
342 	{
343 		case GL_TEXTURE_2D_MULTISAMPLE_ARRAY:	return RequiredExtensions("GL_OES_texture_storage_multisample_2d_array");
344 		case GL_TEXTURE_BUFFER:					return RequiredExtensions("GL_EXT_texture_buffer");
345 		case GL_TEXTURE_CUBE_MAP_ARRAY:			return RequiredExtensions("GL_EXT_texture_cube_map_array");
346 		default:
347 			DE_ASSERT(false);
348 			return RequiredExtensions();
349 	}
350 }
351 
isCoreTextureParam(glw::GLenum pname)352 static bool isCoreTextureParam (glw::GLenum pname)
353 {
354 	return	es30::isCoreTextureParam(pname) ||
355 			pname == GL_DEPTH_STENCIL_TEXTURE_MODE;
356 }
357 
getTextureParamExtension(glw::GLenum pname)358 static RequiredExtensions getTextureParamExtension (glw::GLenum pname)
359 {
360 	switch (pname)
361 	{
362 		case GL_TEXTURE_SRGB_DECODE_EXT:	return RequiredExtensions("GL_EXT_texture_sRGB_decode");
363 		case GL_TEXTURE_BORDER_COLOR:		return RequiredExtensions("GL_EXT_texture_border_clamp");
364 		default:
365 			DE_ASSERT(false);
366 			return RequiredExtensions();
367 	}
368 }
369 
isCoreQuery(QueryType query)370 static bool isCoreQuery (QueryType query)
371 {
372 	return es30::isCoreQuery(query);
373 }
374 
getQueryExtension(QueryType query)375 static RequiredExtensions getQueryExtension (QueryType query)
376 {
377 	switch (query)
378 	{
379 		case QUERY_TEXTURE_PARAM_PURE_INTEGER:
380 		case QUERY_TEXTURE_PARAM_PURE_UNSIGNED_INTEGER:
381 		case QUERY_TEXTURE_PARAM_PURE_INTEGER_VEC4:
382 		case QUERY_TEXTURE_PARAM_PURE_UNSIGNED_INTEGER_VEC4:
383 		case QUERY_SAMPLER_PARAM_PURE_INTEGER:
384 		case QUERY_SAMPLER_PARAM_PURE_UNSIGNED_INTEGER:
385 		case QUERY_SAMPLER_PARAM_PURE_INTEGER_VEC4:
386 		case QUERY_SAMPLER_PARAM_PURE_UNSIGNED_INTEGER_VEC4:
387 			return RequiredExtensions("GL_EXT_texture_border_clamp");
388 
389 		default:
390 			DE_ASSERT(false);
391 			return RequiredExtensions();
392 	}
393 }
394 
isCoreTester(TesterType tester)395 static bool isCoreTester (TesterType tester)
396 {
397 	return	es30::isCoreTester(tester)							||
398 			tester == TESTER_DEPTH_STENCIL_TEXTURE_MODE;
399 }
400 
getTesterExtension(TesterType tester)401 static RequiredExtensions getTesterExtension (TesterType tester)
402 {
403 #define CASE_PURE_SETTERS(X) case X ## _SET_PURE_INT: case X ## _SET_PURE_UINT
404 
405 	switch (tester)
406 	{
407 		CASE_PURE_SETTERS(TESTER_TEXTURE_SWIZZLE_R):
408 		CASE_PURE_SETTERS(TESTER_TEXTURE_SWIZZLE_G):
409 		CASE_PURE_SETTERS(TESTER_TEXTURE_SWIZZLE_B):
410 		CASE_PURE_SETTERS(TESTER_TEXTURE_SWIZZLE_A):
411 		CASE_PURE_SETTERS(TESTER_TEXTURE_WRAP_S):
412 		CASE_PURE_SETTERS(TESTER_TEXTURE_WRAP_T):
413 		CASE_PURE_SETTERS(TESTER_TEXTURE_WRAP_R):
414 		CASE_PURE_SETTERS(TESTER_TEXTURE_MAG_FILTER):
415 		CASE_PURE_SETTERS(TESTER_TEXTURE_MIN_FILTER):
416 		CASE_PURE_SETTERS(TESTER_TEXTURE_MIN_LOD):
417 		CASE_PURE_SETTERS(TESTER_TEXTURE_MAX_LOD):
418 		CASE_PURE_SETTERS(TESTER_TEXTURE_BASE_LEVEL):
419 		CASE_PURE_SETTERS(TESTER_TEXTURE_MAX_LEVEL):
420 		CASE_PURE_SETTERS(TESTER_TEXTURE_COMPARE_MODE):
421 		CASE_PURE_SETTERS(TESTER_TEXTURE_COMPARE_FUNC):
422 		CASE_PURE_SETTERS(TESTER_DEPTH_STENCIL_TEXTURE_MODE):
423 		case TESTER_TEXTURE_WRAP_S_CLAMP_TO_BORDER:
424 		case TESTER_TEXTURE_WRAP_T_CLAMP_TO_BORDER:
425 		case TESTER_TEXTURE_WRAP_R_CLAMP_TO_BORDER:
426 		case TESTER_TEXTURE_BORDER_COLOR:
427 			return RequiredExtensions("GL_EXT_texture_border_clamp");
428 
429 		case TESTER_TEXTURE_SRGB_DECODE_EXT:
430 			return RequiredExtensions("GL_EXT_texture_sRGB_decode");
431 
432 		CASE_PURE_SETTERS(TESTER_TEXTURE_SRGB_DECODE_EXT):
433 			return RequiredExtensions("GL_EXT_texture_sRGB_decode", "GL_EXT_texture_border_clamp");
434 
435 		default:
436 			DE_ASSERT(false);
437 			return RequiredExtensions();
438 	}
439 
440 #undef CASE_PURE_SETTERS
441 }
442 
443 } // es31
444 
445 namespace es32
446 {
447 
isCoreTextureTarget(glw::GLenum target)448 static bool isCoreTextureTarget (glw::GLenum target)
449 {
450 	return	es31::isCoreTextureTarget(target)			||
451 			target == GL_TEXTURE_2D_MULTISAMPLE_ARRAY	||
452 			target == GL_TEXTURE_BUFFER					||
453 			target == GL_TEXTURE_CUBE_MAP_ARRAY;
454 }
455 
getTextureTargetExtension(glw::GLenum target)456 static RequiredExtensions getTextureTargetExtension (glw::GLenum target)
457 {
458 	DE_UNREF(target);
459 	DE_ASSERT(false);
460 	return RequiredExtensions();
461 }
462 
isCoreTextureParam(glw::GLenum pname)463 static bool isCoreTextureParam (glw::GLenum pname)
464 {
465 	return	es31::isCoreTextureParam(pname)		||
466 			pname == GL_TEXTURE_BORDER_COLOR;
467 }
468 
getTextureParamExtension(glw::GLenum pname)469 static RequiredExtensions getTextureParamExtension (glw::GLenum pname)
470 {
471 	switch (pname)
472 	{
473 		case GL_TEXTURE_SRGB_DECODE_EXT:	return RequiredExtensions("GL_EXT_texture_sRGB_decode");
474 		default:
475 			DE_ASSERT(false);
476 			return RequiredExtensions();
477 	}
478 }
479 
isCoreQuery(QueryType query)480 static bool isCoreQuery (QueryType query)
481 {
482 	return	es31::isCoreQuery(query)								||
483 			query == QUERY_TEXTURE_PARAM_PURE_INTEGER				||
484 			query == QUERY_TEXTURE_PARAM_PURE_INTEGER				||
485 			query == QUERY_TEXTURE_PARAM_PURE_UNSIGNED_INTEGER		||
486 			query == QUERY_TEXTURE_PARAM_PURE_INTEGER_VEC4			||
487 			query == QUERY_TEXTURE_PARAM_PURE_UNSIGNED_INTEGER_VEC4	||
488 			query == QUERY_SAMPLER_PARAM_PURE_INTEGER				||
489 			query == QUERY_SAMPLER_PARAM_PURE_UNSIGNED_INTEGER		||
490 			query == QUERY_SAMPLER_PARAM_PURE_INTEGER_VEC4			||
491 			query == QUERY_SAMPLER_PARAM_PURE_UNSIGNED_INTEGER_VEC4;
492 }
493 
getQueryExtension(QueryType query)494 static RequiredExtensions getQueryExtension (QueryType query)
495 {
496 	DE_UNREF(query);
497 	DE_ASSERT(false);
498 	return RequiredExtensions();
499 }
500 
isCoreTester(TesterType tester)501 static bool isCoreTester (TesterType tester)
502 {
503 #define COMPARE_PURE_SETTERS(TESTER, X) (TESTER == X ## _SET_PURE_INT) || (TESTER == X ## _SET_PURE_UINT)
504 
505 	return	es31::isCoreTester(tester)										||
506 			COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_SWIZZLE_R)			||
507 			COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_SWIZZLE_G)			||
508 			COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_SWIZZLE_B)			||
509 			COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_SWIZZLE_A)			||
510 			COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_WRAP_S)				||
511 			COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_WRAP_T)				||
512 			COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_WRAP_R)				||
513 			COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_MAG_FILTER)			||
514 			COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_MIN_FILTER)			||
515 			COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_MIN_LOD)			||
516 			COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_MAX_LOD)			||
517 			COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_BASE_LEVEL)			||
518 			COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_MAX_LEVEL)			||
519 			COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_COMPARE_MODE)		||
520 			COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_COMPARE_FUNC)		||
521 			COMPARE_PURE_SETTERS(tester, TESTER_DEPTH_STENCIL_TEXTURE_MODE)	||
522 			tester == TESTER_TEXTURE_WRAP_S_CLAMP_TO_BORDER					||
523 			tester == TESTER_TEXTURE_WRAP_T_CLAMP_TO_BORDER					||
524 			tester == TESTER_TEXTURE_WRAP_R_CLAMP_TO_BORDER					||
525 			tester == TESTER_TEXTURE_BORDER_COLOR;
526 
527 #undef COMPARE_PURE_SETTERS
528 }
529 
getTesterExtension(TesterType tester)530 static RequiredExtensions getTesterExtension (TesterType tester)
531 {
532 #define CASE_PURE_SETTERS(X) case X ## _SET_PURE_INT: case X ## _SET_PURE_UINT
533 
534 	switch (tester)
535 	{
536 		CASE_PURE_SETTERS(TESTER_TEXTURE_SRGB_DECODE_EXT):
537 		case TESTER_TEXTURE_SRGB_DECODE_EXT:
538 			return RequiredExtensions("GL_EXT_texture_sRGB_decode");
539 
540 		default:
541 			DE_ASSERT(false);
542 			return RequiredExtensions();
543 	}
544 
545 #undef CASE_PURE_SETTERS
546 }
547 
548 } // es32
549 
isCoreTextureTarget(const glu::ContextType & contextType,glw::GLenum target)550 static bool isCoreTextureTarget (const glu::ContextType& contextType, glw::GLenum target)
551 {
552 	if (contextSupports(contextType, glu::ApiType::es(3,2)))
553 		return es32::isCoreTextureTarget(target);
554 	else if (contextSupports(contextType, glu::ApiType::es(3,1)))
555 		return es31::isCoreTextureTarget(target);
556 	else if (contextSupports(contextType, glu::ApiType::es(3,0)))
557 		return es30::isCoreTextureTarget(target);
558 	else
559 	{
560 		DE_ASSERT(false);
561 		return DE_NULL;
562 	}
563 }
564 
isCoreTextureParam(const glu::ContextType & contextType,glw::GLenum pname)565 static bool isCoreTextureParam (const glu::ContextType& contextType, glw::GLenum pname)
566 {
567 	if (contextSupports(contextType, glu::ApiType::es(3,2)))
568 		return es32::isCoreTextureParam(pname);
569 	else if (contextSupports(contextType, glu::ApiType::es(3,1)))
570 		return es31::isCoreTextureParam(pname);
571 	else if (contextSupports(contextType, glu::ApiType::es(3,0)))
572 		return es30::isCoreTextureParam(pname);
573 	else
574 	{
575 		DE_ASSERT(false);
576 		return DE_NULL;
577 	}
578 }
579 
isCoreQuery(const glu::ContextType & contextType,QueryType query)580 static bool isCoreQuery (const glu::ContextType& contextType, QueryType query)
581 {
582 	if (contextSupports(contextType, glu::ApiType::es(3,2)))
583 		return es32::isCoreQuery(query);
584 	else if (contextSupports(contextType, glu::ApiType::es(3,1)))
585 		return es31::isCoreQuery(query);
586 	else if (contextSupports(contextType, glu::ApiType::es(3,0)))
587 		return es30::isCoreQuery(query);
588 	else
589 	{
590 		DE_ASSERT(false);
591 		return DE_NULL;
592 	}
593 }
594 
isCoreTester(const glu::ContextType & contextType,TesterType tester)595 static bool isCoreTester (const glu::ContextType& contextType, TesterType tester)
596 {
597 	if (contextSupports(contextType, glu::ApiType::es(3,2)))
598 		return es32::isCoreTester(tester);
599 	else if (contextSupports(contextType, glu::ApiType::es(3,1)))
600 		return es31::isCoreTester(tester);
601 	else if (contextSupports(contextType, glu::ApiType::es(3,0)))
602 		return es30::isCoreTester(tester);
603 	else
604 	{
605 		DE_ASSERT(false);
606 		return DE_NULL;
607 	}
608 }
609 
getTextureTargetExtension(const glu::ContextType & contextType,glw::GLenum target)610 static RequiredExtensions getTextureTargetExtension (const glu::ContextType& contextType, glw::GLenum target)
611 {
612 	DE_ASSERT(!isCoreTextureTarget(contextType, target));
613 
614 	if (contextSupports(contextType, glu::ApiType::es(3,2)))
615 		return es32::getTextureTargetExtension(target);
616 	if (contextSupports(contextType, glu::ApiType::es(3,1)))
617 		return es31::getTextureTargetExtension(target);
618 	else if (contextSupports(contextType, glu::ApiType::es(3,0)))
619 		return es30::getTextureTargetExtension(target);
620 	else
621 	{
622 		DE_ASSERT(false);
623 		return RequiredExtensions();
624 	}
625 }
626 
getTextureParamExtension(const glu::ContextType & contextType,glw::GLenum pname)627 static RequiredExtensions getTextureParamExtension (const glu::ContextType& contextType, glw::GLenum pname)
628 {
629 	DE_ASSERT(!isCoreTextureParam(contextType, pname));
630 
631 	if (contextSupports(contextType, glu::ApiType::es(3,2)))
632 		return es32::getTextureParamExtension(pname);
633 	else if (contextSupports(contextType, glu::ApiType::es(3,1)))
634 		return es31::getTextureParamExtension(pname);
635 	else if (contextSupports(contextType, glu::ApiType::es(3,0)))
636 		return es30::getTextureParamExtension(pname);
637 	else
638 	{
639 		DE_ASSERT(false);
640 		return RequiredExtensions();
641 	}
642 }
643 
getQueryExtension(const glu::ContextType & contextType,QueryType query)644 static RequiredExtensions getQueryExtension (const glu::ContextType& contextType, QueryType query)
645 {
646 	DE_ASSERT(!isCoreQuery(contextType, query));
647 
648 	if (contextSupports(contextType, glu::ApiType::es(3,2)))
649 		return es32::getQueryExtension(query);
650 	else if (contextSupports(contextType, glu::ApiType::es(3,1)))
651 		return es31::getQueryExtension(query);
652 	else if (contextSupports(contextType, glu::ApiType::es(3,0)))
653 		return es30::getQueryExtension(query);
654 	else
655 	{
656 		DE_ASSERT(false);
657 		return RequiredExtensions();
658 	}
659 }
660 
getTesterExtension(const glu::ContextType & contextType,TesterType tester)661 static RequiredExtensions getTesterExtension (const glu::ContextType& contextType, TesterType tester)
662 {
663 	DE_ASSERT(!isCoreTester(contextType, tester));
664 
665 	if (contextSupports(contextType, glu::ApiType::es(3,2)))
666 		return es32::getTesterExtension(tester);
667 	else if (contextSupports(contextType, glu::ApiType::es(3,1)))
668 		return es31::getTesterExtension(tester);
669 	else if (contextSupports(contextType, glu::ApiType::es(3,0)))
670 		return es30::getTesterExtension(tester);
671 	else
672 	{
673 		DE_ASSERT(false);
674 		return RequiredExtensions();
675 	}
676 }
677 
678 class TextureTest : public tcu::TestCase
679 {
680 public:
681 						TextureTest	(tcu::TestContext&			testCtx,
682 									 const glu::RenderContext&	renderCtx,
683 									 const char*				name,
684 									 const char*				desc,
685 									 glw::GLenum				target,
686 									 TesterType					tester,
687 									 QueryType					type);
688 
689 	void				init		(void);
690 	IterateResult		iterate		(void);
691 
692 	virtual void		test		(glu::CallLogWrapper& gl, tcu::ResultCollector& result) const = 0;
693 
694 protected:
695 	const glu::RenderContext&	m_renderCtx;
696 	const glw::GLenum			m_target;
697 	const glw::GLenum			m_pname;
698 	const TesterType			m_tester;
699 	const QueryType				m_type;
700 };
701 
TextureTest(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,glw::GLenum target,TesterType tester,QueryType type)702 TextureTest::TextureTest (tcu::TestContext&			testCtx,
703 						  const glu::RenderContext&	renderCtx,
704 						  const char*				name,
705 						  const char*				desc,
706 						  glw::GLenum				target,
707 						  TesterType				tester,
708 						  QueryType					type)
709 	: TestCase		(testCtx, name, desc)
710 	, m_renderCtx	(renderCtx)
711 	, m_target		(target)
712 	, m_pname		(mapTesterToPname(tester))
713 	, m_tester		(tester)
714 	, m_type		(type)
715 {
716 }
717 
init(void)718 void TextureTest::init (void)
719 {
720 	const de::UniquePtr<glu::ContextInfo>	ctxInfo		(glu::ContextInfo::create(m_renderCtx));
721 	RequiredExtensions						extensions;
722 
723 	// target
724 	if (!isCoreTextureTarget(m_renderCtx.getType(), m_target))
725 		extensions.add(getTextureTargetExtension(m_renderCtx.getType(), m_target));
726 
727 	// param
728 	if (!isCoreTextureParam(m_renderCtx.getType(), m_pname))
729 		extensions.add(getTextureParamExtension(m_renderCtx.getType(), m_pname));
730 
731 	// query
732 	if (!isCoreQuery(m_renderCtx.getType(), m_type))
733 		extensions.add(getQueryExtension(m_renderCtx.getType(), m_type));
734 
735 	// test type
736 	if (!isCoreTester(m_renderCtx.getType(), m_tester))
737 		extensions.add(getTesterExtension(m_renderCtx.getType(), m_tester));
738 
739 	extensions.check(*ctxInfo);
740 }
741 
iterate(void)742 TextureTest::IterateResult TextureTest::iterate (void)
743 {
744 	glu::CallLogWrapper		gl		(m_renderCtx.getFunctions(), m_testCtx.getLog());
745 	tcu::ResultCollector	result	(m_testCtx.getLog(), " // ERROR: ");
746 
747 	gl.enableLogging(true);
748 	test(gl, result);
749 
750 	result.setTestContextResult(m_testCtx);
751 	return STOP;
752 }
753 
754 class IsTextureCase : public tcu::TestCase
755 {
756 public:
757 								IsTextureCase	(tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target);
758 
759 	void						init			(void);
760 	IterateResult				iterate			(void);
761 
762 protected:
763 	const glu::RenderContext&	m_renderCtx;
764 	const glw::GLenum			m_target;
765 };
766 
IsTextureCase(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,glw::GLenum target)767 IsTextureCase::IsTextureCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target)
768 	: tcu::TestCase	(testCtx, name, desc)
769 	, m_renderCtx	(renderCtx)
770 	, m_target		(target)
771 {
772 }
773 
init(void)774 void IsTextureCase::init (void)
775 {
776 	const de::UniquePtr<glu::ContextInfo>	ctxInfo		(glu::ContextInfo::create(m_renderCtx));
777 	RequiredExtensions						extensions;
778 
779 	// target
780 	if (!isCoreTextureTarget(m_renderCtx.getType(), m_target))
781 		extensions.add(getTextureTargetExtension(m_renderCtx.getType(), m_target));
782 
783 	extensions.check(*ctxInfo);
784 }
785 
iterate(void)786 IsTextureCase::IterateResult IsTextureCase::iterate (void)
787 {
788 	glu::CallLogWrapper		gl			(m_renderCtx.getFunctions(), m_testCtx.getLog());
789 	tcu::ResultCollector	result		(m_testCtx.getLog(), " // ERROR: ");
790 	glw::GLuint				textureId	= 0;
791 
792 	gl.enableLogging(true);
793 
794 	gl.glGenTextures(1, &textureId);
795 	gl.glBindTexture(m_target, textureId);
796 	GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glBindTexture");
797 
798 	verifyStateObjectBoolean(result, gl, textureId, true, QUERY_ISTEXTURE);
799 
800 	gl.glDeleteTextures(1, &textureId);
801 	GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glDeleteTextures");
802 
803 	verifyStateObjectBoolean(result, gl, textureId, false, QUERY_ISTEXTURE);
804 
805 	result.setTestContextResult(m_testCtx);
806 	return STOP;
807 }
808 
809 class DepthStencilModeCase : public TextureTest
810 {
811 public:
812 			DepthStencilModeCase	(tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type);
813 	void	test					(glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
814 };
815 
DepthStencilModeCase(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,glw::GLenum target,TesterType tester,QueryType type)816 DepthStencilModeCase::DepthStencilModeCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type)
817 	: TextureTest(testCtx, renderCtx, name, desc, target, tester, type)
818 {
819 }
820 
test(glu::CallLogWrapper & gl,tcu::ResultCollector & result) const821 void DepthStencilModeCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
822 {
823 	const bool		isPureCase	= isPureIntTester(m_tester) || isPureUintTester(m_tester);
824 	glu::Texture	texture		(m_renderCtx);
825 
826 	gl.glBindTexture(m_target, *texture);
827 	GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "bind");
828 
829 	if (!isPureCase)
830 	{
831 		const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
832 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_DEPTH_COMPONENT, m_type);
833 	}
834 
835 	if (!isPureCase)
836 	{
837 		const tcu::ScopedLogSection	section				(m_testCtx.getLog(), "Toggle", "Toggle");
838 		const glw::GLint			depthComponentInt	= GL_DEPTH_COMPONENT;
839 		const glw::GLfloat			depthComponentFloat	= (glw::GLfloat)GL_DEPTH_COMPONENT;
840 
841 		gl.glTexParameteri(m_target, m_pname, GL_STENCIL_INDEX);
842 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
843 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_STENCIL_INDEX, m_type);
844 
845 		gl.glTexParameteriv(m_target, m_pname, &depthComponentInt);
846 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
847 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_DEPTH_COMPONENT, m_type);
848 
849 		gl.glTexParameterf(m_target, m_pname, GL_STENCIL_INDEX);
850 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
851 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_STENCIL_INDEX, m_type);
852 
853 		gl.glTexParameterfv(m_target, m_pname, &depthComponentFloat);
854 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
855 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_DEPTH_COMPONENT, m_type);
856 	}
857 
858 	if (isPureIntTester(m_tester))
859 	{
860 		const glw::GLint depthComponent	= GL_DEPTH_COMPONENT;
861 		const glw::GLint stencilIndex	= GL_STENCIL_INDEX;
862 
863 		gl.glTexParameterIiv(m_target, m_pname, &stencilIndex);
864 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
865 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_STENCIL_INDEX, m_type);
866 
867 		gl.glTexParameterIiv(m_target, m_pname, &depthComponent);
868 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
869 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_DEPTH_COMPONENT, m_type);
870 	}
871 
872 	if (isPureUintTester(m_tester))
873 	{
874 		const glw::GLuint depthComponent	= GL_DEPTH_COMPONENT;
875 		const glw::GLuint stencilIndex	= GL_STENCIL_INDEX;
876 
877 		gl.glTexParameterIuiv(m_target, m_pname, &stencilIndex);
878 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
879 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_STENCIL_INDEX, m_type);
880 
881 		gl.glTexParameterIuiv(m_target, m_pname, &depthComponent);
882 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
883 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_DEPTH_COMPONENT, m_type);
884 	}
885 }
886 
887 class TextureSRGBDecodeCase : public TextureTest
888 {
889 public:
890 			TextureSRGBDecodeCase	(tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type);
891 	void	test					(glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
892 };
893 
TextureSRGBDecodeCase(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,glw::GLenum target,TesterType tester,QueryType type)894 TextureSRGBDecodeCase::TextureSRGBDecodeCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type)
895 	: TextureTest(testCtx, renderCtx, name, desc, target, tester, type)
896 {
897 }
898 
test(glu::CallLogWrapper & gl,tcu::ResultCollector & result) const899 void TextureSRGBDecodeCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
900 {
901 	const bool		isPureCase	= isPureIntTester(m_tester) || isPureUintTester(m_tester);
902 	glu::Texture	texture		(m_renderCtx);
903 
904 	gl.glBindTexture(m_target, *texture);
905 	GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "bind");
906 
907 	if (!isPureCase)
908 	{
909 		const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
910 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_DECODE_EXT, m_type);
911 	}
912 
913 	if (!isPureCase)
914 	{
915 		const tcu::ScopedLogSection	section			(m_testCtx.getLog(), "Toggle", "Toggle");
916 		const glw::GLint			decodeInt		= GL_DECODE_EXT;
917 		const glw::GLfloat			decodeFloat		= (glw::GLfloat)GL_DECODE_EXT;
918 
919 		gl.glTexParameteri(m_target, m_pname, GL_SKIP_DECODE_EXT);
920 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
921 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_SKIP_DECODE_EXT, m_type);
922 
923 		gl.glTexParameteriv(m_target, m_pname, &decodeInt);
924 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
925 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_DECODE_EXT, m_type);
926 
927 		gl.glTexParameterf(m_target, m_pname, GL_SKIP_DECODE_EXT);
928 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
929 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_SKIP_DECODE_EXT, m_type);
930 
931 		gl.glTexParameterfv(m_target, m_pname, &decodeFloat);
932 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
933 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_DECODE_EXT, m_type);
934 	}
935 
936 	if (isPureIntTester(m_tester))
937 	{
938 		const glw::GLint skipDecode	= GL_SKIP_DECODE_EXT;
939 		const glw::GLint decode		= GL_DECODE_EXT;
940 
941 		gl.glTexParameterIiv(m_target, m_pname, &skipDecode);
942 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
943 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_SKIP_DECODE_EXT, m_type);
944 
945 		gl.glTexParameterIiv(m_target, m_pname, &decode);
946 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
947 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_DECODE_EXT, m_type);
948 	}
949 
950 	if (isPureUintTester(m_tester))
951 	{
952 		const glw::GLuint skipDecode	= GL_SKIP_DECODE_EXT;
953 		const glw::GLuint decode		= GL_DECODE_EXT;
954 
955 		gl.glTexParameterIuiv(m_target, m_pname, &skipDecode);
956 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
957 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_SKIP_DECODE_EXT, m_type);
958 
959 		gl.glTexParameterIuiv(m_target, m_pname, &decode);
960 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
961 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_DECODE_EXT, m_type);
962 	}
963 }
964 
965 class TextureSwizzleCase : public TextureTest
966 {
967 public:
968 			TextureSwizzleCase	(tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type);
969 	void	test				(glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
970 };
971 
TextureSwizzleCase(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,glw::GLenum target,TesterType tester,QueryType type)972 TextureSwizzleCase::TextureSwizzleCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type)
973 	: TextureTest(testCtx, renderCtx, name, desc, target, tester, type)
974 {
975 }
976 
test(glu::CallLogWrapper & gl,tcu::ResultCollector & result) const977 void TextureSwizzleCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
978 {
979 	const bool	isPureCase		= isPureIntTester(m_tester) || isPureUintTester(m_tester);
980 	const int	initialValue	= (m_pname == GL_TEXTURE_SWIZZLE_R) ? (GL_RED) :
981 								  (m_pname == GL_TEXTURE_SWIZZLE_G) ? (GL_GREEN) :
982 								  (m_pname == GL_TEXTURE_SWIZZLE_B) ? (GL_BLUE) :
983 								  (m_pname == GL_TEXTURE_SWIZZLE_A) ? (GL_ALPHA) :
984 								  (-1);
985 
986 	if (!isPureCase)
987 	{
988 		const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
989 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, initialValue, m_type);
990 	}
991 
992 	{
993 		const tcu::ScopedLogSection	section			(m_testCtx.getLog(), "Set", "Set");
994 		const GLenum				swizzleValues[]	= {GL_RED, GL_GREEN, GL_BLUE, GL_ALPHA, GL_ZERO, GL_ONE};
995 
996 		if (isPureCase)
997 		{
998 			for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(swizzleValues); ++ndx)
999 			{
1000 				if (isPureIntTester(m_tester))
1001 				{
1002 					const glw::GLint value = (glw::GLint)swizzleValues[ndx];
1003 					gl.glTexParameterIiv(m_target, m_pname, &value);
1004 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
1005 				}
1006 				else
1007 				{
1008 					DE_ASSERT(isPureUintTester(m_tester));
1009 
1010 					const glw::GLuint value = swizzleValues[ndx];
1011 					gl.glTexParameterIuiv(m_target, m_pname, &value);
1012 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
1013 				}
1014 
1015 				verifyStateTextureParamInteger(result, gl, m_target, m_pname, swizzleValues[ndx], m_type);
1016 			}
1017 		}
1018 		else
1019 		{
1020 			for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(swizzleValues); ++ndx)
1021 			{
1022 				gl.glTexParameteri(m_target, m_pname, swizzleValues[ndx]);
1023 				GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameteri");
1024 
1025 				verifyStateTextureParamInteger(result, gl, m_target, m_pname, swizzleValues[ndx], m_type);
1026 			}
1027 
1028 			//check unit conversions with float
1029 
1030 			for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(swizzleValues); ++ndx)
1031 			{
1032 				gl.glTexParameterf(m_target, m_pname, (GLfloat)swizzleValues[ndx]);
1033 				GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterf");
1034 
1035 				verifyStateTextureParamInteger(result, gl, m_target, m_pname, swizzleValues[ndx], m_type);
1036 			}
1037 		}
1038 	}
1039 }
1040 
1041 class TextureWrapCase : public TextureTest
1042 {
1043 public:
1044 			TextureWrapCase	(tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type);
1045 	void	test			(glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1046 };
1047 
TextureWrapCase(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,glw::GLenum target,TesterType tester,QueryType type)1048 TextureWrapCase::TextureWrapCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type)
1049 	: TextureTest(testCtx, renderCtx, name, desc, target, tester, type)
1050 {
1051 }
1052 
test(glu::CallLogWrapper & gl,tcu::ResultCollector & result) const1053 void TextureWrapCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1054 {
1055 	const bool isPureCase = isPureIntTester(m_tester) || isPureUintTester(m_tester);
1056 
1057 	if (!isPureCase)
1058 	{
1059 		const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
1060 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_REPEAT, m_type);
1061 	}
1062 
1063 	{
1064 		const tcu::ScopedLogSection	section			(m_testCtx.getLog(), "Set", "Set");
1065 		const GLenum				wrapValues[]	= {GL_CLAMP_TO_EDGE, GL_REPEAT, GL_MIRRORED_REPEAT};
1066 
1067 		if (isPureCase)
1068 		{
1069 			for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(wrapValues); ++ndx)
1070 			{
1071 				if (isPureIntTester(m_tester))
1072 				{
1073 					const glw::GLint value = (glw::GLint)wrapValues[ndx];
1074 					gl.glTexParameterIiv(m_target, m_pname, &value);
1075 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
1076 				}
1077 				else
1078 				{
1079 					DE_ASSERT(isPureUintTester(m_tester));
1080 
1081 					const glw::GLuint value = wrapValues[ndx];
1082 					gl.glTexParameterIuiv(m_target, m_pname, &value);
1083 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
1084 				}
1085 
1086 				verifyStateTextureParamInteger(result, gl, m_target, m_pname, wrapValues[ndx], m_type);
1087 			}
1088 		}
1089 		else
1090 		{
1091 			for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(wrapValues); ++ndx)
1092 			{
1093 				gl.glTexParameteri(m_target, m_pname, wrapValues[ndx]);
1094 				GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameteri");
1095 
1096 				verifyStateTextureParamInteger(result, gl, m_target, m_pname, wrapValues[ndx], m_type);
1097 			}
1098 
1099 			//check unit conversions with float
1100 
1101 			for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(wrapValues); ++ndx)
1102 			{
1103 				gl.glTexParameterf(m_target, m_pname, (GLfloat)wrapValues[ndx]);
1104 				GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterf");
1105 
1106 				verifyStateTextureParamInteger(result, gl, m_target, m_pname, wrapValues[ndx], m_type);
1107 			}
1108 		}
1109 	}
1110 }
1111 
1112 class TextureFilterCase : public TextureTest
1113 {
1114 public:
1115 			TextureFilterCase	(tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type);
1116 	void	test				(glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1117 };
1118 
TextureFilterCase(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,glw::GLenum target,TesterType tester,QueryType type)1119 TextureFilterCase::TextureFilterCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type)
1120 	: TextureTest(testCtx, renderCtx, name, desc, target, tester, type)
1121 {
1122 }
1123 
test(glu::CallLogWrapper & gl,tcu::ResultCollector & result) const1124 void TextureFilterCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1125 {
1126 	const bool			isPureCase	= isPureIntTester(m_tester) || isPureUintTester(m_tester);
1127 	const glw::GLenum	initial		= (m_pname == GL_TEXTURE_MAG_FILTER) ? (GL_LINEAR)
1128 									: (m_pname == GL_TEXTURE_MIN_FILTER) ? (GL_NEAREST_MIPMAP_LINEAR)
1129 									: (0);
1130 
1131 	if (!isPureCase)
1132 	{
1133 		const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
1134 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, initial, m_type);
1135 	}
1136 
1137 	{
1138 		const tcu::ScopedLogSection	section		(m_testCtx.getLog(), "Set", "Set");
1139 		std::vector<GLenum>			values;
1140 
1141 		values.push_back(GL_NEAREST);
1142 		values.push_back(GL_LINEAR);
1143 		if (m_pname == GL_TEXTURE_MIN_FILTER)
1144 		{
1145 			values.push_back(GL_NEAREST_MIPMAP_NEAREST);
1146 			values.push_back(GL_NEAREST_MIPMAP_LINEAR);
1147 			values.push_back(GL_LINEAR_MIPMAP_NEAREST);
1148 			values.push_back(GL_LINEAR_MIPMAP_LINEAR);
1149 		}
1150 
1151 		if (isPureCase)
1152 		{
1153 			for (int ndx = 0; ndx < (int)values.size(); ++ndx)
1154 			{
1155 				if (isPureIntTester(m_tester))
1156 				{
1157 					const glw::GLint value = (glw::GLint)values[ndx];
1158 					gl.glTexParameterIiv(m_target, m_pname, &value);
1159 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
1160 				}
1161 				else
1162 				{
1163 					DE_ASSERT(isPureUintTester(m_tester));
1164 
1165 					const glw::GLuint value = values[ndx];
1166 					gl.glTexParameterIuiv(m_target, m_pname, &value);
1167 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
1168 				}
1169 
1170 				verifyStateTextureParamInteger(result, gl, m_target, m_pname, values[ndx], m_type);
1171 			}
1172 		}
1173 		else
1174 		{
1175 			for (int ndx = 0; ndx < (int)values.size(); ++ndx)
1176 			{
1177 				gl.glTexParameteri(m_target, m_pname, values[ndx]);
1178 				GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameteri");
1179 
1180 				verifyStateTextureParamInteger(result, gl, m_target, m_pname, values[ndx], m_type);
1181 			}
1182 
1183 			//check unit conversions with float
1184 
1185 			for (int ndx = 0; ndx < (int)values.size(); ++ndx)
1186 			{
1187 				gl.glTexParameterf(m_target, m_pname, (GLfloat)values[ndx]);
1188 				GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterf");
1189 
1190 				verifyStateTextureParamInteger(result, gl, m_target, m_pname, values[ndx], m_type);
1191 			}
1192 		}
1193 	}
1194 }
1195 
1196 class TextureLODCase : public TextureTest
1197 {
1198 public:
1199 			TextureLODCase	(tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type);
1200 	void	test			(glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1201 };
1202 
TextureLODCase(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,glw::GLenum target,TesterType tester,QueryType type)1203 TextureLODCase::TextureLODCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type)
1204 	: TextureTest(testCtx, renderCtx, name, desc, target, tester, type)
1205 {
1206 }
1207 
test(glu::CallLogWrapper & gl,tcu::ResultCollector & result) const1208 void TextureLODCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1209 {
1210 	const bool	isPureCase		= isPureIntTester(m_tester) || isPureUintTester(m_tester);
1211 	const int	initialValue 	= (m_pname == GL_TEXTURE_MIN_LOD) ? (-1000)
1212 								: (m_pname == GL_TEXTURE_MAX_LOD) ? (1000)
1213 								: (-1);
1214 
1215 	if ((querySupportsSigned(m_type) || initialValue >= 0) && !isPureCase)
1216 	{
1217 		const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
1218 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, initialValue, m_type);
1219 	}
1220 
1221 	{
1222 		const tcu::ScopedLogSection	section			(m_testCtx.getLog(), "Set", "Set");
1223 		const int					numIterations	= 20;
1224 		de::Random					rnd				(0xabcdef);
1225 
1226 		if (isPureCase)
1227 		{
1228 			if (isPureIntTester(m_tester))
1229 			{
1230 				for (int ndx = 0; ndx < numIterations; ++ndx)
1231 				{
1232 					const GLint ref = rnd.getInt(-1000, 1000);
1233 
1234 					gl.glTexParameterIiv(m_target, m_pname, &ref);
1235 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
1236 
1237 					verifyStateTextureParamFloat(result, gl, m_target, m_pname, (float)ref, m_type);
1238 				}
1239 			}
1240 			else
1241 			{
1242 				DE_ASSERT(isPureUintTester(m_tester));
1243 
1244 				for (int ndx = 0; ndx < numIterations; ++ndx)
1245 				{
1246 					const GLuint ref = (glw::GLuint)rnd.getInt(0, 1000);
1247 
1248 					gl.glTexParameterIuiv(m_target, m_pname, &ref);
1249 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
1250 
1251 					verifyStateTextureParamFloat(result, gl, m_target, m_pname, (float)ref, m_type);
1252 				}
1253 			}
1254 		}
1255 		else
1256 		{
1257 			const int minLimit = (querySupportsSigned(m_type)) ? (-1000) : (0);
1258 
1259 			for (int ndx = 0; ndx < numIterations; ++ndx)
1260 			{
1261 				const GLfloat ref = rnd.getFloat((float)minLimit, 1000.f);
1262 
1263 				gl.glTexParameterf(m_target, m_pname, ref);
1264 				GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterf");
1265 
1266 				verifyStateTextureParamFloat(result, gl, m_target, m_pname, ref, m_type);
1267 			}
1268 
1269 			// check unit conversions with int
1270 
1271 			for (int ndx = 0; ndx < numIterations; ++ndx)
1272 			{
1273 				const GLint ref = rnd.getInt(minLimit, 1000);
1274 
1275 				gl.glTexParameteri(m_target, m_pname, ref);
1276 				GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameteri");
1277 
1278 				verifyStateTextureParamFloat(result, gl, m_target, m_pname, (float)ref, m_type);
1279 			}
1280 		}
1281 	}
1282 }
1283 
1284 class TextureLevelCase : public TextureTest
1285 {
1286 public:
1287 			TextureLevelCase	(tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type);
1288 	void	test				(glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1289 };
1290 
TextureLevelCase(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,glw::GLenum target,TesterType tester,QueryType type)1291 TextureLevelCase::TextureLevelCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type)
1292 	: TextureTest(testCtx, renderCtx, name, desc, target, tester, type)
1293 {
1294 }
1295 
test(glu::CallLogWrapper & gl,tcu::ResultCollector & result) const1296 void TextureLevelCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1297 {
1298 	const bool	isPureCase		= isPureIntTester(m_tester) || isPureUintTester(m_tester);
1299 	const int	initialValue	= (m_pname == GL_TEXTURE_BASE_LEVEL) ? (0)
1300 								: (m_pname == GL_TEXTURE_MAX_LEVEL)	? (1000)
1301 								: (-1);
1302 
1303 	if (!isPureCase)
1304 	{
1305 		const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
1306 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, initialValue, m_type);
1307 	}
1308 
1309 	if (m_target == GL_TEXTURE_2D_MULTISAMPLE		||
1310 		m_target == GL_TEXTURE_2D_MULTISAMPLE_ARRAY)
1311 	{
1312 		// only 0 allowed
1313 		{
1314 			const tcu::ScopedLogSection section(m_testCtx.getLog(), "Set", "Set");
1315 
1316 			gl.glTexParameteri(m_target, m_pname, 0);
1317 			GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameteri");
1318 			verifyStateTextureParamInteger(result, gl, m_target, m_pname, 0, m_type);
1319 
1320 			gl.glTexParameterf(m_target, m_pname, 0.0f);
1321 			GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterf");
1322 			verifyStateTextureParamInteger(result, gl, m_target, m_pname, 0, m_type);
1323 		}
1324 	}
1325 	else
1326 	{
1327 		const tcu::ScopedLogSection	section			(m_testCtx.getLog(), "Set", "Set");
1328 		const int					numIterations	= 20;
1329 		de::Random					rnd				(0xabcdef);
1330 
1331 		if (isPureCase)
1332 		{
1333 			for (int ndx = 0; ndx < numIterations; ++ndx)
1334 			{
1335 				const GLint		ref		= rnd.getInt(0, 64000);
1336 				const GLuint	uRef	= (glw::GLuint)ref;
1337 
1338 				if (isPureIntTester(m_tester))
1339 				{
1340 					gl.glTexParameterIiv(m_target, m_pname, &ref);
1341 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
1342 				}
1343 				else
1344 				{
1345 					DE_ASSERT(isPureUintTester(m_tester));
1346 					gl.glTexParameterIuiv(m_target, m_pname, &uRef);
1347 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
1348 				}
1349 
1350 				verifyStateTextureParamInteger(result, gl, m_target, m_pname, ref, m_type);
1351 			}
1352 		}
1353 		else
1354 		{
1355 			for (int ndx = 0; ndx < numIterations; ++ndx)
1356 			{
1357 				const GLint ref = rnd.getInt(0, 64000);
1358 
1359 				gl.glTexParameteri(m_target, m_pname, ref);
1360 				GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameteri");
1361 
1362 				verifyStateTextureParamInteger(result, gl, m_target, m_pname, ref, m_type);
1363 			}
1364 
1365 			// check unit conversions with float
1366 
1367 			const float nonSignificantOffsets[] = {-0.45f, -0.25f, 0, 0.45f}; // offsets O so that for any integers z in Z, o in O roundToClosestInt(z+o)==z
1368 
1369 			const int numConversionIterations = 30;
1370 			for (int ndx = 0; ndx < numConversionIterations; ++ndx)
1371 			{
1372 				const GLint ref = rnd.getInt(1, 64000);
1373 
1374 				for (int offsetNdx = 0; offsetNdx < DE_LENGTH_OF_ARRAY(nonSignificantOffsets); ++offsetNdx)
1375 				{
1376 					gl.glTexParameterf(m_target, m_pname, ((GLfloat)ref) + nonSignificantOffsets[offsetNdx]);
1377 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterf");
1378 
1379 					verifyStateTextureParamInteger(result, gl, m_target, m_pname, ref, m_type);
1380 				}
1381 			}
1382 		}
1383 	}
1384 }
1385 
1386 class TextureCompareModeCase : public TextureTest
1387 {
1388 public:
1389 			TextureCompareModeCase	(tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type);
1390 	void	test					(glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1391 };
1392 
TextureCompareModeCase(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,glw::GLenum target,TesterType tester,QueryType type)1393 TextureCompareModeCase::TextureCompareModeCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type)
1394 	: TextureTest(testCtx, renderCtx, name, desc, target, tester, type)
1395 {
1396 }
1397 
test(glu::CallLogWrapper & gl,tcu::ResultCollector & result) const1398 void TextureCompareModeCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1399 {
1400 	const bool isPureCase = isPureIntTester(m_tester) || isPureUintTester(m_tester);
1401 
1402 	if (!isPureCase)
1403 	{
1404 		const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
1405 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_NONE, m_type);
1406 	}
1407 
1408 	{
1409 		const tcu::ScopedLogSection	section		(m_testCtx.getLog(), "Set", "Set");
1410 		const GLenum				modes[]		= {GL_COMPARE_REF_TO_TEXTURE, GL_NONE};
1411 
1412 		if (isPureCase)
1413 		{
1414 			for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(modes); ++ndx)
1415 			{
1416 				if (isPureIntTester(m_tester))
1417 				{
1418 					const glw::GLint value = (glw::GLint)modes[ndx];
1419 					gl.glTexParameterIiv(m_target, m_pname, &value);
1420 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
1421 				}
1422 				else
1423 				{
1424 					DE_ASSERT(isPureUintTester(m_tester));
1425 
1426 					const glw::GLuint value = modes[ndx];
1427 					gl.glTexParameterIuiv(m_target, m_pname, &value);
1428 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
1429 				}
1430 
1431 				verifyStateTextureParamInteger(result, gl, m_target, m_pname, modes[ndx], m_type);
1432 			}
1433 		}
1434 		else
1435 		{
1436 			for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(modes); ++ndx)
1437 			{
1438 				gl.glTexParameteri(m_target, m_pname, modes[ndx]);
1439 				GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameteri");
1440 
1441 				verifyStateTextureParamInteger(result, gl, m_target, m_pname, modes[ndx], m_type);
1442 			}
1443 
1444 			//check unit conversions with float
1445 
1446 			for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(modes); ++ndx)
1447 			{
1448 				gl.glTexParameterf(m_target, m_pname, (GLfloat)modes[ndx]);
1449 				GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterf");
1450 
1451 				verifyStateTextureParamInteger(result, gl, m_target, m_pname, modes[ndx], m_type);
1452 			}
1453 		}
1454 	}
1455 }
1456 
1457 class TextureCompareFuncCase : public TextureTest
1458 {
1459 public:
1460 			TextureCompareFuncCase	(tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type);
1461 	void	test					(glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1462 };
1463 
TextureCompareFuncCase(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,glw::GLenum target,TesterType tester,QueryType type)1464 TextureCompareFuncCase::TextureCompareFuncCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type)
1465 	: TextureTest(testCtx, renderCtx, name, desc, target, tester, type)
1466 {
1467 }
1468 
test(glu::CallLogWrapper & gl,tcu::ResultCollector & result) const1469 void TextureCompareFuncCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1470 {
1471 	const bool isPureCase = isPureIntTester(m_tester) || isPureUintTester(m_tester);
1472 
1473 	if (!isPureCase)
1474 	{
1475 		const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
1476 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_LEQUAL, m_type);
1477 	}
1478 
1479 	{
1480 		const tcu::ScopedLogSection	section			(m_testCtx.getLog(), "Set", "Set");
1481 		const GLenum				compareFuncs[]	= {GL_LEQUAL, GL_GEQUAL, GL_LESS, GL_GREATER, GL_EQUAL, GL_NOTEQUAL, GL_ALWAYS, GL_NEVER};
1482 
1483 		if (isPureCase)
1484 		{
1485 			for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(compareFuncs); ++ndx)
1486 			{
1487 				if (isPureIntTester(m_tester))
1488 				{
1489 					const glw::GLint value = (glw::GLint)compareFuncs[ndx];
1490 					gl.glTexParameterIiv(m_target, m_pname, &value);
1491 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
1492 				}
1493 				else
1494 				{
1495 					DE_ASSERT(isPureUintTester(m_tester));
1496 
1497 					const glw::GLuint value = compareFuncs[ndx];
1498 					gl.glTexParameterIuiv(m_target, m_pname, &value);
1499 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
1500 				}
1501 
1502 				verifyStateTextureParamInteger(result, gl, m_target, m_pname, compareFuncs[ndx], m_type);
1503 			}
1504 		}
1505 		else
1506 		{
1507 			for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(compareFuncs); ++ndx)
1508 			{
1509 				gl.glTexParameteri(m_target, m_pname, compareFuncs[ndx]);
1510 				GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameteri");
1511 
1512 				verifyStateTextureParamInteger(result, gl, m_target, m_pname, compareFuncs[ndx], m_type);
1513 			}
1514 
1515 			//check unit conversions with float
1516 
1517 			for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(compareFuncs); ++ndx)
1518 			{
1519 				gl.glTexParameterf(m_target, m_pname, (GLfloat)compareFuncs[ndx]);
1520 				GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterf");
1521 
1522 				verifyStateTextureParamInteger(result, gl, m_target, m_pname, compareFuncs[ndx], m_type);
1523 			}
1524 		}
1525 	}
1526 }
1527 
1528 class TextureImmutableLevelsCase : public TextureTest
1529 {
1530 public:
1531 			TextureImmutableLevelsCase	(tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, QueryType type);
1532 	void	test						(glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1533 };
1534 
TextureImmutableLevelsCase(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,glw::GLenum target,QueryType type)1535 TextureImmutableLevelsCase::TextureImmutableLevelsCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, QueryType type)
1536 	: TextureTest(testCtx, renderCtx, name, desc, target, TESTER_TEXTURE_IMMUTABLE_LEVELS, type)
1537 {
1538 }
1539 
test(glu::CallLogWrapper & gl,tcu::ResultCollector & result) const1540 void TextureImmutableLevelsCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1541 {
1542 	{
1543 		const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
1544 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, 0, m_type);
1545 	}
1546 
1547 	if (m_target == GL_TEXTURE_2D_MULTISAMPLE		||
1548 		m_target == GL_TEXTURE_2D_MULTISAMPLE_ARRAY)
1549 	{
1550 		// no levels
1551 		const tcu::ScopedLogSection	section		(m_testCtx.getLog(), "Level", "Level");
1552 		GLuint						textureID	= 0;
1553 
1554 		gl.glGenTextures(1, &textureID);
1555 		gl.glBindTexture(m_target, textureID);
1556 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glBindTexture");
1557 
1558 		if (m_target == GL_TEXTURE_2D_MULTISAMPLE)
1559 			gl.glTexStorage2DMultisample(m_target, 2, GL_RGB8, 64, 64, GL_FALSE);
1560 		else if (m_target == GL_TEXTURE_2D_MULTISAMPLE_ARRAY)
1561 			gl.glTexStorage3DMultisample(m_target, 2, GL_RGB8, 64, 64, 2, GL_FALSE);
1562 		else
1563 			DE_ASSERT(false);
1564 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexStorage");
1565 
1566 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, 1, m_type);
1567 
1568 		gl.glDeleteTextures(1, &textureID);
1569 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glDeleteTextures");
1570 	}
1571 	else
1572 	{
1573 		for (int level = 1; level <= 7; ++level)
1574 		{
1575 			const tcu::ScopedLogSection	section		(m_testCtx.getLog(), "Levels", "Levels = " + de::toString(level));
1576 			GLuint						textureID	= 0;
1577 
1578 			gl.glGenTextures(1, &textureID);
1579 			gl.glBindTexture(m_target, textureID);
1580 			GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glBindTexture");
1581 
1582 			if (m_target == GL_TEXTURE_2D || m_target == GL_TEXTURE_CUBE_MAP)
1583 				gl.glTexStorage2D(m_target, level, GL_RGB8, 64, 64);
1584 			else if (m_target == GL_TEXTURE_2D_ARRAY || m_target == GL_TEXTURE_3D)
1585 				gl.glTexStorage3D(m_target, level, GL_RGB8, 64, 64, 64);
1586 			else if (m_target == GL_TEXTURE_CUBE_MAP_ARRAY)
1587 				gl.glTexStorage3D(m_target, level, GL_RGB8, 64, 64, 6 * 2);
1588 			else
1589 				DE_ASSERT(false);
1590 			GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexStorage");
1591 
1592 			verifyStateTextureParamInteger(result, gl, m_target, m_pname, level, m_type);
1593 
1594 			gl.glDeleteTextures(1, &textureID);
1595 			GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glDeleteTextures");
1596 		}
1597 	}
1598 }
1599 
1600 class TextureImmutableFormatCase : public TextureTest
1601 {
1602 public:
1603 			TextureImmutableFormatCase	(tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, QueryType type);
1604 	void	test						(glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1605 };
1606 
TextureImmutableFormatCase(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,glw::GLenum target,QueryType type)1607 TextureImmutableFormatCase::TextureImmutableFormatCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, QueryType type)
1608 	: TextureTest(testCtx, renderCtx, name, desc, target, TESTER_TEXTURE_IMMUTABLE_FORMAT, type)
1609 {
1610 }
1611 
test(glu::CallLogWrapper & gl,tcu::ResultCollector & result) const1612 void TextureImmutableFormatCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1613 {
1614 	{
1615 		const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
1616 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, 0, m_type);
1617 	}
1618 
1619 	{
1620 		const tcu::ScopedLogSection	subsection	(m_testCtx.getLog(), "Immutable", "Immutable");
1621 		GLuint						textureID	= 0;
1622 
1623 		gl.glGenTextures(1, &textureID);
1624 		gl.glBindTexture(m_target, textureID);
1625 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glBindTexture");
1626 
1627 		switch (m_target)
1628 		{
1629 			case GL_TEXTURE_2D:
1630 			case GL_TEXTURE_CUBE_MAP:
1631 			{
1632 				gl.glTexStorage2D(m_target, 1, GL_RGBA8, 32, 32);
1633 				break;
1634 			}
1635 			case GL_TEXTURE_2D_ARRAY:
1636 			case GL_TEXTURE_3D:
1637 			{
1638 				gl.glTexStorage3D(m_target, 1, GL_RGBA8, 32, 32, 8);
1639 				break;
1640 			}
1641 			case GL_TEXTURE_2D_MULTISAMPLE:
1642 			{
1643 				gl.glTexStorage2DMultisample(m_target, 2, GL_RGB8, 64, 64, GL_FALSE);
1644 				break;
1645 			}
1646 			case GL_TEXTURE_2D_MULTISAMPLE_ARRAY:
1647 			{
1648 				gl.glTexStorage3DMultisample(m_target, 2, GL_RGB8, 64, 64, 2, GL_FALSE);
1649 				break;
1650 			}
1651 			case GL_TEXTURE_CUBE_MAP_ARRAY:
1652 			{
1653 				gl.glTexStorage3D(m_target, 1, GL_RGBA8, 32, 32, 6 * 2);
1654 				break;
1655 			}
1656 			default:
1657 				DE_ASSERT(false);
1658 		}
1659 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "setup texture");
1660 
1661 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, 1, m_type);
1662 
1663 		gl.glDeleteTextures(1, &textureID);
1664 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glDeleteTextures");
1665 	}
1666 
1667 	// no mutable
1668 	if (m_target == GL_TEXTURE_2D_MULTISAMPLE ||
1669 		m_target == GL_TEXTURE_2D_MULTISAMPLE_ARRAY)
1670 		return;
1671 
1672 	// test mutable
1673 	{
1674 		const tcu::ScopedLogSection	subsection		(m_testCtx.getLog(), "Mutable", "Mutable");
1675 		GLuint						textureID		= 0;
1676 
1677 		gl.glGenTextures(1, &textureID);
1678 		gl.glBindTexture(m_target, textureID);
1679 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glBindTexture");
1680 
1681 		switch (m_target)
1682 		{
1683 			case GL_TEXTURE_2D:
1684 			{
1685 				gl.glTexImage2D(m_target, 0, GL_RGBA8, 32, 32, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
1686 				break;
1687 			}
1688 			case GL_TEXTURE_CUBE_MAP:
1689 			{
1690 				gl.glTexImage2D(GL_TEXTURE_CUBE_MAP_NEGATIVE_Y, 0, GL_RGBA8, 32, 32, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
1691 				break;
1692 			}
1693 			case GL_TEXTURE_2D_ARRAY:
1694 			case GL_TEXTURE_3D:
1695 			{
1696 				gl.glTexImage3D(m_target, 0, GL_RGBA8, 32, 32, 8, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
1697 				break;
1698 			}
1699 			case GL_TEXTURE_CUBE_MAP_ARRAY:
1700 			{
1701 				gl.glTexImage3D(m_target, 0, GL_RGBA8, 32, 32, 6 * 2, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
1702 				break;
1703 			}
1704 			default:
1705 				DE_ASSERT(false);
1706 		}
1707 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "setup texture");
1708 
1709 		verifyStateTextureParamInteger(result, gl, m_target, m_pname, 0, m_type);
1710 
1711 		gl.glDeleteTextures(1, &textureID);
1712 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glDeleteTextures");
1713 	}
1714 }
1715 
1716 class TextureWrapClampToBorderCase : public TextureTest
1717 {
1718 public:
1719 			TextureWrapClampToBorderCase	(tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type);
1720 	void	test							(glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1721 };
1722 
TextureWrapClampToBorderCase(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,glw::GLenum target,TesterType tester,QueryType type)1723 TextureWrapClampToBorderCase::TextureWrapClampToBorderCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type)
1724 	: TextureTest(testCtx, renderCtx, name, desc, target, tester, type)
1725 {
1726 }
1727 
test(glu::CallLogWrapper & gl,tcu::ResultCollector & result) const1728 void TextureWrapClampToBorderCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1729 {
1730 	gl.glTexParameteri(m_target, m_pname, GL_CLAMP_TO_BORDER_EXT);
1731 	GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameteri");
1732 	verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_CLAMP_TO_BORDER_EXT, m_type);
1733 
1734 	gl.glTexParameteri(m_target, m_pname, GL_REPEAT);
1735 	GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameteri");
1736 
1737 	gl.glTexParameterf(m_target, m_pname, (GLfloat)GL_CLAMP_TO_BORDER_EXT);
1738 	GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterf");
1739 
1740 	verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_CLAMP_TO_BORDER_EXT, m_type);
1741 }
1742 
1743 class TextureBorderColorCase : public TextureTest
1744 {
1745 public:
1746 			TextureBorderColorCase	(tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, QueryType type);
1747 	void	test					(glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1748 };
1749 
TextureBorderColorCase(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,glw::GLenum target,QueryType type)1750 TextureBorderColorCase::TextureBorderColorCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, QueryType type)
1751 	: TextureTest(testCtx, renderCtx, name, desc, target, TESTER_TEXTURE_BORDER_COLOR, type)
1752 {
1753 }
1754 
test(glu::CallLogWrapper & gl,tcu::ResultCollector & result) const1755 void TextureBorderColorCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1756 {
1757 	// border color is undefined if queried with pure type and was not set to pure value
1758 	if (m_type == QUERY_TEXTURE_PARAM_INTEGER_VEC4 || m_type == QUERY_TEXTURE_PARAM_FLOAT_VEC4)
1759 	{
1760 		const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
1761 		verifyStateTextureParamFloatVec4(result, gl, m_target, m_pname, tcu::Vec4(0.0f, 0.0f, 0.0f, 0.0f), m_type);
1762 	}
1763 
1764 	if (m_type == QUERY_TEXTURE_PARAM_PURE_INTEGER_VEC4)
1765 	{
1766 		const tcu::ScopedLogSection	section			(m_testCtx.getLog(), "Set", "Set");
1767 		const tcu::IVec4			color			(0x7FFFFFFF, -2, 3, -128);
1768 
1769 		gl.glTexParameterIiv(m_target, m_pname, color.getPtr());
1770 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
1771 
1772 		verifyStateTextureParamIntegerVec4(result, gl, m_target, m_pname, color, m_type);
1773 	}
1774 	else if (m_type == QUERY_TEXTURE_PARAM_PURE_UNSIGNED_INTEGER_VEC4)
1775 	{
1776 		const tcu::ScopedLogSection	section			(m_testCtx.getLog(), "Set", "Set");
1777 		const tcu::UVec4			color			(0x8000000ul, 2, 3, 128);
1778 
1779 		gl.glTexParameterIuiv(m_target, m_pname, color.getPtr());
1780 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
1781 
1782 		verifyStateTextureParamUnsignedIntegerVec4(result, gl, m_target, m_pname, color, m_type);
1783 	}
1784 	else
1785 	{
1786 		DE_ASSERT(m_type == QUERY_TEXTURE_PARAM_INTEGER_VEC4 || m_type == QUERY_TEXTURE_PARAM_FLOAT_VEC4);
1787 
1788 		const tcu::ScopedLogSection	section			(m_testCtx.getLog(), "Set", "Set");
1789 		const tcu::Vec4				color			(0.25f, 1.0f, 0.0f, 0.77f);
1790 		const tcu::IVec4			icolor			(0x8000000ul, 0x7FFFFFFF, 0, 0x0FFFFFFF);
1791 
1792 		gl.glTexParameterfv(m_target, m_pname, color.getPtr());
1793 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterfv");
1794 
1795 		verifyStateTextureParamFloatVec4(result, gl, m_target, m_pname, color, m_type);
1796 
1797 		gl.glTexParameteriv(m_target, m_pname, icolor.getPtr());
1798 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameteriv");
1799 
1800 		verifyStateTextureParamNormalizedI32Vec4(result, gl, m_target, m_pname, icolor, m_type);
1801 	}
1802 }
1803 
1804 class SamplerTest : public tcu::TestCase
1805 {
1806 public:
1807 						SamplerTest	(tcu::TestContext&			testCtx,
1808 									 const glu::RenderContext&	renderCtx,
1809 									 const char*				name,
1810 									 const char*				desc,
1811 									 TesterType					tester,
1812 									 QueryType					type);
1813 
1814 	void				init		(void);
1815 	IterateResult		iterate		(void);
1816 
1817 	virtual void		test		(glu::CallLogWrapper& gl, tcu::ResultCollector& result) const = 0;
1818 
1819 protected:
1820 	const glu::RenderContext&	m_renderCtx;
1821 	const glw::GLenum			m_pname;
1822 	const TesterType			m_tester;
1823 	const QueryType				m_type;
1824 	glw::GLuint					m_target;
1825 };
1826 
SamplerTest(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,TesterType tester,QueryType type)1827 SamplerTest::SamplerTest (tcu::TestContext&			testCtx,
1828 						  const glu::RenderContext&	renderCtx,
1829 						  const char*				name,
1830 						  const char*				desc,
1831 						  TesterType				tester,
1832 						  QueryType					type)
1833 	: TestCase		(testCtx, name, desc)
1834 	, m_renderCtx	(renderCtx)
1835 	, m_pname		(mapTesterToPname(tester))
1836 	, m_tester		(tester)
1837 	, m_type		(type)
1838 	, m_target		(0)
1839 {
1840 }
1841 
init(void)1842 void SamplerTest::init (void)
1843 {
1844 	const de::UniquePtr<glu::ContextInfo>	ctxInfo		(glu::ContextInfo::create(m_renderCtx));
1845 	RequiredExtensions						extensions;
1846 
1847 	// param
1848 	if (!isCoreTextureParam(m_renderCtx.getType(), m_pname))
1849 		extensions.add(getTextureParamExtension(m_renderCtx.getType(), m_pname));
1850 
1851 	// query
1852 	if (!isCoreQuery(m_renderCtx.getType(), m_type))
1853 		extensions.add(getQueryExtension(m_renderCtx.getType(), m_type));
1854 
1855 	// test type
1856 	if (!isCoreTester(m_renderCtx.getType(), m_tester))
1857 		extensions.add(getTesterExtension(m_renderCtx.getType(), m_tester));
1858 
1859 	extensions.check(*ctxInfo);
1860 }
1861 
iterate(void)1862 SamplerTest::IterateResult SamplerTest::iterate (void)
1863 {
1864 	glu::CallLogWrapper		gl		(m_renderCtx.getFunctions(), m_testCtx.getLog());
1865 	tcu::ResultCollector	result	(m_testCtx.getLog(), " // ERROR: ");
1866 	glu::Sampler			sampler	(m_renderCtx);
1867 
1868 	gl.enableLogging(true);
1869 
1870 	m_target = *sampler;
1871 	test(gl, result);
1872 	m_target = 0;
1873 
1874 	result.setTestContextResult(m_testCtx);
1875 	return STOP;
1876 }
1877 
1878 class SamplerWrapCase : public SamplerTest
1879 {
1880 public:
1881 			SamplerWrapCase	(tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, TesterType tester, QueryType type);
1882 	void	test			(glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1883 };
1884 
SamplerWrapCase(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,TesterType tester,QueryType type)1885 SamplerWrapCase::SamplerWrapCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, TesterType tester, QueryType type)
1886 	: SamplerTest(testCtx, renderCtx, name, desc, tester, type)
1887 {
1888 }
1889 
test(glu::CallLogWrapper & gl,tcu::ResultCollector & result) const1890 void SamplerWrapCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1891 {
1892 	const bool isPureCase = isPureIntTester(m_tester) || isPureUintTester(m_tester);
1893 
1894 	if (!isPureCase)
1895 	{
1896 		const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
1897 		verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_REPEAT, m_type);
1898 	}
1899 
1900 	{
1901 		const tcu::ScopedLogSection	section			(m_testCtx.getLog(), "Set", "Set");
1902 		const GLenum				wrapValues[]	= {GL_CLAMP_TO_EDGE, GL_REPEAT, GL_MIRRORED_REPEAT};
1903 
1904 		if (isPureCase)
1905 		{
1906 			for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(wrapValues); ++ndx)
1907 			{
1908 				if (isPureIntTester(m_tester))
1909 				{
1910 					const glw::GLint value = (glw::GLint)wrapValues[ndx];
1911 					gl.glSamplerParameterIiv(m_target, m_pname, &value);
1912 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIiv");
1913 				}
1914 				else
1915 				{
1916 					DE_ASSERT(isPureUintTester(m_tester));
1917 
1918 					const glw::GLuint value = wrapValues[ndx];
1919 					gl.glSamplerParameterIuiv(m_target, m_pname, &value);
1920 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIuiv");
1921 				}
1922 
1923 				verifyStateSamplerParamInteger(result, gl, m_target, m_pname, wrapValues[ndx], m_type);
1924 			}
1925 		}
1926 		else
1927 		{
1928 			for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(wrapValues); ++ndx)
1929 			{
1930 				gl.glSamplerParameteri(m_target, m_pname, wrapValues[ndx]);
1931 				GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameteri");
1932 
1933 				verifyStateSamplerParamInteger(result, gl, m_target, m_pname, wrapValues[ndx], m_type);
1934 			}
1935 
1936 			//check unit conversions with float
1937 
1938 			for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(wrapValues); ++ndx)
1939 			{
1940 				gl.glSamplerParameterf(m_target, m_pname, (GLfloat)wrapValues[ndx]);
1941 				GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterf");
1942 
1943 				verifyStateSamplerParamInteger(result, gl, m_target, m_pname, wrapValues[ndx], m_type);
1944 			}
1945 		}
1946 	}
1947 }
1948 
1949 class SamplerFilterCase : public SamplerTest
1950 {
1951 public:
1952 			SamplerFilterCase	(tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, TesterType tester, QueryType type);
1953 	void	test				(glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1954 };
1955 
SamplerFilterCase(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,TesterType tester,QueryType type)1956 SamplerFilterCase::SamplerFilterCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, TesterType tester, QueryType type)
1957 	: SamplerTest(testCtx, renderCtx, name, desc, tester, type)
1958 {
1959 }
1960 
test(glu::CallLogWrapper & gl,tcu::ResultCollector & result) const1961 void SamplerFilterCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1962 {
1963 	const bool			isPureCase	= isPureIntTester(m_tester) || isPureUintTester(m_tester);
1964 	const glw::GLenum	initial		= (m_pname == GL_TEXTURE_MAG_FILTER) ? (GL_LINEAR)
1965 									: (m_pname == GL_TEXTURE_MIN_FILTER) ? (GL_NEAREST_MIPMAP_LINEAR)
1966 									: (0);
1967 
1968 	if (!isPureCase)
1969 	{
1970 		const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
1971 		verifyStateSamplerParamInteger(result, gl, m_target, m_pname, initial, m_type);
1972 	}
1973 
1974 	{
1975 		const tcu::ScopedLogSection	section		(m_testCtx.getLog(), "Set", "Set");
1976 		std::vector<GLenum>			values;
1977 
1978 		values.push_back(GL_NEAREST);
1979 		values.push_back(GL_LINEAR);
1980 		if (m_pname == GL_TEXTURE_MIN_FILTER)
1981 		{
1982 			values.push_back(GL_NEAREST_MIPMAP_NEAREST);
1983 			values.push_back(GL_NEAREST_MIPMAP_LINEAR);
1984 			values.push_back(GL_LINEAR_MIPMAP_NEAREST);
1985 			values.push_back(GL_LINEAR_MIPMAP_LINEAR);
1986 		}
1987 
1988 		if (isPureCase)
1989 		{
1990 			for (int ndx = 0; ndx < (int)values.size(); ++ndx)
1991 			{
1992 				if (isPureIntTester(m_tester))
1993 				{
1994 					const glw::GLint value = (glw::GLint)values[ndx];
1995 					gl.glSamplerParameterIiv(m_target, m_pname, &value);
1996 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIiv");
1997 				}
1998 				else
1999 				{
2000 					DE_ASSERT(isPureUintTester(m_tester));
2001 
2002 					const glw::GLuint value = values[ndx];
2003 					gl.glSamplerParameterIuiv(m_target, m_pname, &value);
2004 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIuiv");
2005 				}
2006 
2007 				verifyStateSamplerParamInteger(result, gl, m_target, m_pname, values[ndx], m_type);
2008 			}
2009 		}
2010 		else
2011 		{
2012 			for (int ndx = 0; ndx < (int)values.size(); ++ndx)
2013 			{
2014 				gl.glSamplerParameteri(m_target, m_pname, values[ndx]);
2015 				GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameteri");
2016 
2017 				verifyStateSamplerParamInteger(result, gl, m_target, m_pname, values[ndx], m_type);
2018 			}
2019 
2020 			//check unit conversions with float
2021 
2022 			for (int ndx = 0; ndx < (int)values.size(); ++ndx)
2023 			{
2024 				gl.glSamplerParameterf(m_target, m_pname, (GLfloat)values[ndx]);
2025 				GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterf");
2026 
2027 				verifyStateSamplerParamInteger(result, gl, m_target, m_pname, values[ndx], m_type);
2028 			}
2029 		}
2030 	}
2031 }
2032 
2033 class SamplerLODCase : public SamplerTest
2034 {
2035 public:
2036 			SamplerLODCase	(tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, TesterType tester, QueryType type);
2037 	void	test			(glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
2038 };
2039 
SamplerLODCase(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,TesterType tester,QueryType type)2040 SamplerLODCase::SamplerLODCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, TesterType tester, QueryType type)
2041 	: SamplerTest(testCtx, renderCtx, name, desc, tester, type)
2042 {
2043 }
2044 
test(glu::CallLogWrapper & gl,tcu::ResultCollector & result) const2045 void SamplerLODCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
2046 {
2047 	const bool	isPureCase		= isPureIntTester(m_tester) || isPureUintTester(m_tester);
2048 	const int	initialValue 	= (m_pname == GL_TEXTURE_MIN_LOD) ? (-1000)
2049 								: (m_pname == GL_TEXTURE_MAX_LOD) ? (1000)
2050 								: (-1);
2051 
2052 	if ((querySupportsSigned(m_type) || initialValue >= 0) && !isPureCase)
2053 	{
2054 		const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
2055 		verifyStateSamplerParamInteger(result, gl, m_target, m_pname, initialValue, m_type);
2056 	}
2057 
2058 	{
2059 		const tcu::ScopedLogSection	section			(m_testCtx.getLog(), "Set", "Set");
2060 		const int					numIterations	= 20;
2061 		de::Random					rnd				(0xabcdef);
2062 
2063 		if (isPureCase)
2064 		{
2065 			if (isPureIntTester(m_tester))
2066 			{
2067 				for (int ndx = 0; ndx < numIterations; ++ndx)
2068 				{
2069 					const GLint ref = rnd.getInt(-1000, 1000);
2070 
2071 					gl.glSamplerParameterIiv(m_target, m_pname, &ref);
2072 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIiv");
2073 
2074 					verifyStateSamplerParamFloat(result, gl, m_target, m_pname, (float)ref, m_type);
2075 				}
2076 			}
2077 			else
2078 			{
2079 				DE_ASSERT(isPureUintTester(m_tester));
2080 
2081 				for (int ndx = 0; ndx < numIterations; ++ndx)
2082 				{
2083 					const GLuint ref = (glw::GLuint)rnd.getInt(0, 1000);
2084 
2085 					gl.glSamplerParameterIuiv(m_target, m_pname, &ref);
2086 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIuiv");
2087 
2088 					verifyStateSamplerParamFloat(result, gl, m_target, m_pname, (float)ref, m_type);
2089 				}
2090 			}
2091 		}
2092 		else
2093 		{
2094 			const int minLimit = (querySupportsSigned(m_type)) ? (-1000) : (0);
2095 
2096 			for (int ndx = 0; ndx < numIterations; ++ndx)
2097 			{
2098 				const GLfloat ref = rnd.getFloat((float)minLimit, 1000.f);
2099 
2100 				gl.glSamplerParameterf(m_target, m_pname, ref);
2101 				GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterf");
2102 
2103 				verifyStateSamplerParamFloat(result, gl, m_target, m_pname, ref, m_type);
2104 			}
2105 
2106 			// check unit conversions with int
2107 
2108 			for (int ndx = 0; ndx < numIterations; ++ndx)
2109 			{
2110 				const GLint ref = rnd.getInt(minLimit, 1000);
2111 
2112 				gl.glSamplerParameteri(m_target, m_pname, ref);
2113 				GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameteri");
2114 
2115 				verifyStateSamplerParamFloat(result, gl, m_target, m_pname, (float)ref, m_type);
2116 			}
2117 		}
2118 	}
2119 }
2120 
2121 class SamplerCompareModeCase : public SamplerTest
2122 {
2123 public:
2124 			SamplerCompareModeCase	(tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, TesterType tester, QueryType type);
2125 	void	test					(glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
2126 };
2127 
SamplerCompareModeCase(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,TesterType tester,QueryType type)2128 SamplerCompareModeCase::SamplerCompareModeCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, TesterType tester, QueryType type)
2129 	: SamplerTest(testCtx, renderCtx, name, desc, tester, type)
2130 {
2131 }
2132 
test(glu::CallLogWrapper & gl,tcu::ResultCollector & result) const2133 void SamplerCompareModeCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
2134 {
2135 	const bool isPureCase = isPureIntTester(m_tester) || isPureUintTester(m_tester);
2136 
2137 	if (!isPureCase)
2138 	{
2139 		const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
2140 		verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_NONE, m_type);
2141 	}
2142 
2143 	{
2144 		const tcu::ScopedLogSection	section		(m_testCtx.getLog(), "Set", "Set");
2145 		const GLenum				modes[]		= {GL_COMPARE_REF_TO_TEXTURE, GL_NONE};
2146 
2147 		if (isPureCase)
2148 		{
2149 			for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(modes); ++ndx)
2150 			{
2151 				if (isPureIntTester(m_tester))
2152 				{
2153 					const glw::GLint value = (glw::GLint)modes[ndx];
2154 					gl.glSamplerParameterIiv(m_target, m_pname, &value);
2155 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIiv");
2156 				}
2157 				else
2158 				{
2159 					DE_ASSERT(isPureUintTester(m_tester));
2160 
2161 					const glw::GLuint value = modes[ndx];
2162 					gl.glSamplerParameterIuiv(m_target, m_pname, &value);
2163 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIuiv");
2164 				}
2165 
2166 				verifyStateSamplerParamInteger(result, gl, m_target, m_pname, modes[ndx], m_type);
2167 			}
2168 		}
2169 		else
2170 		{
2171 			for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(modes); ++ndx)
2172 			{
2173 				gl.glSamplerParameteri(m_target, m_pname, modes[ndx]);
2174 				GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameteri");
2175 
2176 				verifyStateSamplerParamInteger(result, gl, m_target, m_pname, modes[ndx], m_type);
2177 			}
2178 
2179 			//check unit conversions with float
2180 
2181 			for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(modes); ++ndx)
2182 			{
2183 				gl.glSamplerParameterf(m_target, m_pname, (GLfloat)modes[ndx]);
2184 				GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterf");
2185 
2186 				verifyStateSamplerParamInteger(result, gl, m_target, m_pname, modes[ndx], m_type);
2187 			}
2188 		}
2189 	}
2190 }
2191 
2192 class SamplerCompareFuncCase : public SamplerTest
2193 {
2194 public:
2195 			SamplerCompareFuncCase	(tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, TesterType tester, QueryType type);
2196 	void	test					(glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
2197 };
2198 
SamplerCompareFuncCase(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,TesterType tester,QueryType type)2199 SamplerCompareFuncCase::SamplerCompareFuncCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, TesterType tester, QueryType type)
2200 	: SamplerTest(testCtx, renderCtx, name, desc, tester, type)
2201 {
2202 }
2203 
test(glu::CallLogWrapper & gl,tcu::ResultCollector & result) const2204 void SamplerCompareFuncCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
2205 {
2206 	const bool isPureCase = isPureIntTester(m_tester) || isPureUintTester(m_tester);
2207 
2208 	if (!isPureCase)
2209 	{
2210 		const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
2211 		verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_LEQUAL, m_type);
2212 	}
2213 
2214 	{
2215 		const tcu::ScopedLogSection	section			(m_testCtx.getLog(), "Set", "Set");
2216 		const GLenum				compareFuncs[]	= {GL_LEQUAL, GL_GEQUAL, GL_LESS, GL_GREATER, GL_EQUAL, GL_NOTEQUAL, GL_ALWAYS, GL_NEVER};
2217 
2218 		if (isPureCase)
2219 		{
2220 			for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(compareFuncs); ++ndx)
2221 			{
2222 				if (isPureIntTester(m_tester))
2223 				{
2224 					const glw::GLint value = (glw::GLint)compareFuncs[ndx];
2225 					gl.glSamplerParameterIiv(m_target, m_pname, &value);
2226 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIiv");
2227 				}
2228 				else
2229 				{
2230 					DE_ASSERT(isPureUintTester(m_tester));
2231 
2232 					const glw::GLuint value = compareFuncs[ndx];
2233 					gl.glSamplerParameterIuiv(m_target, m_pname, &value);
2234 					GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIuiv");
2235 				}
2236 
2237 				verifyStateSamplerParamInteger(result, gl, m_target, m_pname, compareFuncs[ndx], m_type);
2238 			}
2239 		}
2240 		else
2241 		{
2242 			for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(compareFuncs); ++ndx)
2243 			{
2244 				gl.glSamplerParameteri(m_target, m_pname, compareFuncs[ndx]);
2245 				GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameteri");
2246 
2247 				verifyStateSamplerParamInteger(result, gl, m_target, m_pname, compareFuncs[ndx], m_type);
2248 			}
2249 
2250 			//check unit conversions with float
2251 
2252 			for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(compareFuncs); ++ndx)
2253 			{
2254 				gl.glSamplerParameterf(m_target, m_pname, (GLfloat)compareFuncs[ndx]);
2255 				GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterf");
2256 
2257 				verifyStateSamplerParamInteger(result, gl, m_target, m_pname, compareFuncs[ndx], m_type);
2258 			}
2259 		}
2260 	}
2261 }
2262 
2263 class SamplerWrapClampToBorderCase : public SamplerTest
2264 {
2265 public:
2266 			SamplerWrapClampToBorderCase	(tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, TesterType tester, QueryType type);
2267 	void	test							(glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
2268 };
2269 
SamplerWrapClampToBorderCase(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,TesterType tester,QueryType type)2270 SamplerWrapClampToBorderCase::SamplerWrapClampToBorderCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, TesterType tester, QueryType type)
2271 	: SamplerTest(testCtx, renderCtx, name, desc, tester, type)
2272 {
2273 }
2274 
test(glu::CallLogWrapper & gl,tcu::ResultCollector & result) const2275 void SamplerWrapClampToBorderCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
2276 {
2277 	gl.glSamplerParameteri(m_target, m_pname, GL_CLAMP_TO_BORDER_EXT);
2278 	GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameteri");
2279 	verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_CLAMP_TO_BORDER_EXT, m_type);
2280 
2281 	gl.glSamplerParameteri(m_target, m_pname, GL_REPEAT);
2282 	GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameteri");
2283 
2284 	gl.glSamplerParameterf(m_target, m_pname, (GLfloat)GL_CLAMP_TO_BORDER_EXT);
2285 	GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterf");
2286 
2287 	verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_CLAMP_TO_BORDER_EXT, m_type);
2288 }
2289 
2290 class SamplerSRGBDecodeCase : public SamplerTest
2291 {
2292 public:
2293 			SamplerSRGBDecodeCase	(tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, TesterType tester, QueryType type);
2294 	void	test					(glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
2295 };
2296 
SamplerSRGBDecodeCase(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,TesterType tester,QueryType type)2297 SamplerSRGBDecodeCase::SamplerSRGBDecodeCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, TesterType tester, QueryType type)
2298 	: SamplerTest(testCtx, renderCtx, name, desc, tester, type)
2299 {
2300 }
2301 
test(glu::CallLogWrapper & gl,tcu::ResultCollector & result) const2302 void SamplerSRGBDecodeCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
2303 {
2304 	const bool isPureCase = isPureIntTester(m_tester) || isPureUintTester(m_tester);
2305 
2306 	if (!isPureCase)
2307 	{
2308 		const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
2309 		verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_DECODE_EXT, m_type);
2310 	}
2311 
2312 	{
2313 		const tcu::ScopedLogSection	section			(m_testCtx.getLog(), "Toggle", "Toggle");
2314 		const glw::GLint			decodeInt		= GL_DECODE_EXT;
2315 		const glw::GLfloat			decodeFloat		= (glw::GLfloat)GL_DECODE_EXT;
2316 
2317 		gl.glSamplerParameteri(m_target, m_pname, GL_SKIP_DECODE_EXT);
2318 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
2319 		verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_SKIP_DECODE_EXT, m_type);
2320 
2321 		gl.glSamplerParameteriv(m_target, m_pname, &decodeInt);
2322 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
2323 		verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_DECODE_EXT, m_type);
2324 
2325 		gl.glSamplerParameterf(m_target, m_pname, GL_SKIP_DECODE_EXT);
2326 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
2327 		verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_SKIP_DECODE_EXT, m_type);
2328 
2329 		gl.glSamplerParameterfv(m_target, m_pname, &decodeFloat);
2330 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
2331 		verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_DECODE_EXT, m_type);
2332 	}
2333 
2334 	if (isPureIntTester(m_tester))
2335 	{
2336 		const glw::GLint skipDecode	= GL_SKIP_DECODE_EXT;
2337 		const glw::GLint decode		= GL_DECODE_EXT;
2338 
2339 		gl.glSamplerParameterIiv(m_target, m_pname, &skipDecode);
2340 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIiv");
2341 		verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_SKIP_DECODE_EXT, m_type);
2342 
2343 		gl.glSamplerParameterIiv(m_target, m_pname, &decode);
2344 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIiv");
2345 		verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_DECODE_EXT, m_type);
2346 	}
2347 
2348 	if (isPureUintTester(m_tester))
2349 	{
2350 		const glw::GLuint skipDecode	= GL_SKIP_DECODE_EXT;
2351 		const glw::GLuint decode		= GL_DECODE_EXT;
2352 
2353 		gl.glSamplerParameterIuiv(m_target, m_pname, &skipDecode);
2354 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIuiv");
2355 		verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_SKIP_DECODE_EXT, m_type);
2356 
2357 		gl.glSamplerParameterIuiv(m_target, m_pname, &decode);
2358 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIuiv");
2359 		verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_DECODE_EXT, m_type);
2360 	}
2361 }
2362 
2363 class SamplerBorderColorCase : public SamplerTest
2364 {
2365 public:
2366 			SamplerBorderColorCase	(tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, QueryType type);
2367 	void	test					(glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
2368 };
2369 
SamplerBorderColorCase(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const char * name,const char * desc,QueryType type)2370 SamplerBorderColorCase::SamplerBorderColorCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, QueryType type)
2371 	: SamplerTest(testCtx, renderCtx, name, desc, TESTER_TEXTURE_BORDER_COLOR, type)
2372 {
2373 	DE_ASSERT(m_type == QUERY_SAMPLER_PARAM_INTEGER_VEC4					||
2374 			  m_type == QUERY_SAMPLER_PARAM_FLOAT_VEC4						||
2375 			  m_type == QUERY_SAMPLER_PARAM_PURE_INTEGER_VEC4				||
2376 			  m_type == QUERY_SAMPLER_PARAM_PURE_UNSIGNED_INTEGER_VEC4);
2377 }
2378 
test(glu::CallLogWrapper & gl,tcu::ResultCollector & result) const2379 void SamplerBorderColorCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
2380 {
2381 	// border color is undefined if queried with pure type and was not set to pure value
2382 	if (m_type == QUERY_SAMPLER_PARAM_INTEGER_VEC4 || m_type == QUERY_SAMPLER_PARAM_FLOAT_VEC4)
2383 	{
2384 		const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
2385 		verifyStateSamplerParamFloatVec4(result, gl, m_target, m_pname, tcu::Vec4(0.0f, 0.0f, 0.0f, 0.0f), m_type);
2386 	}
2387 
2388 	if (m_type == QUERY_SAMPLER_PARAM_PURE_INTEGER_VEC4)
2389 	{
2390 		const tcu::ScopedLogSection	section			(m_testCtx.getLog(), "Set", "Set");
2391 		const tcu::IVec4			color			(0x7FFFFFFF, -2, 3, -128);
2392 
2393 		gl.glSamplerParameterIiv(m_target, m_pname, color.getPtr());
2394 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIiv");
2395 
2396 		verifyStateSamplerParamIntegerVec4(result, gl, m_target, m_pname, color, m_type);
2397 	}
2398 	else if (m_type == QUERY_SAMPLER_PARAM_PURE_UNSIGNED_INTEGER_VEC4)
2399 	{
2400 		const tcu::ScopedLogSection	section			(m_testCtx.getLog(), "Set", "Set");
2401 		const tcu::UVec4			color			(0x8000000ul, 2, 3, 128);
2402 
2403 		gl.glSamplerParameterIuiv(m_target, m_pname, color.getPtr());
2404 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIuiv");
2405 
2406 		verifyStateSamplerParamUnsignedIntegerVec4(result, gl, m_target, m_pname, color, m_type);
2407 	}
2408 	else
2409 	{
2410 		DE_ASSERT(m_type == QUERY_SAMPLER_PARAM_INTEGER_VEC4 || m_type == QUERY_SAMPLER_PARAM_FLOAT_VEC4);
2411 
2412 		const tcu::ScopedLogSection	section			(m_testCtx.getLog(), "Set", "Set");
2413 		const tcu::Vec4				color			(0.25f, 1.0f, 0.0f, 0.77f);
2414 		const tcu::IVec4			icolor			(0x8000000ul, 0x7FFFFFFF, 0, 0x0FFFFFFF);
2415 
2416 		gl.glSamplerParameterfv(m_target, m_pname, color.getPtr());
2417 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterfv");
2418 
2419 		verifyStateSamplerParamFloatVec4(result, gl, m_target, m_pname, color, m_type);
2420 
2421 		gl.glSamplerParameteriv(m_target, m_pname, icolor.getPtr());
2422 		GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameteriv");
2423 
2424 		verifyStateSamplerParamNormalizedI32Vec4(result, gl, m_target, m_pname, icolor, m_type);
2425 	}
2426 }
2427 
2428 } // anonymous
2429 
isLegalTesterForTarget(glw::GLenum target,TesterType tester)2430 bool isLegalTesterForTarget (glw::GLenum target, TesterType tester)
2431 {
2432 	// no 3d filtering on 2d targets
2433 	if ((tester == TESTER_TEXTURE_WRAP_R || tester == TESTER_TEXTURE_WRAP_R_CLAMP_TO_BORDER) &&  target != GL_TEXTURE_3D)
2434 		return false;
2435 
2436 	// no sampling on multisample
2437 	if (isMultisampleTarget(target) && isSamplerStateTester(tester))
2438 		return false;
2439 
2440 	// no states in buffer
2441 	if (target == GL_TEXTURE_BUFFER)
2442 		return false;
2443 
2444 	return true;
2445 }
2446 
isMultisampleTarget(glw::GLenum target)2447 bool isMultisampleTarget (glw::GLenum target)
2448 {
2449 	return	target == GL_TEXTURE_2D_MULTISAMPLE			||
2450 			target == GL_TEXTURE_2D_MULTISAMPLE_ARRAY;
2451 }
2452 
isSamplerStateTester(TesterType tester)2453 bool isSamplerStateTester (TesterType tester)
2454 {
2455 	return	tester == TESTER_TEXTURE_WRAP_S					||
2456 			tester == TESTER_TEXTURE_WRAP_T					||
2457 			tester == TESTER_TEXTURE_WRAP_R					||
2458 			tester == TESTER_TEXTURE_MAG_FILTER				||
2459 			tester == TESTER_TEXTURE_MIN_FILTER				||
2460 			tester == TESTER_TEXTURE_MIN_LOD				||
2461 			tester == TESTER_TEXTURE_MAX_LOD				||
2462 			tester == TESTER_TEXTURE_COMPARE_MODE			||
2463 			tester == TESTER_TEXTURE_COMPARE_FUNC			||
2464 			tester == TESTER_TEXTURE_SRGB_DECODE_EXT		||
2465 			tester == TESTER_TEXTURE_BORDER_COLOR			||
2466 			tester == TESTER_TEXTURE_WRAP_S_CLAMP_TO_BORDER	||
2467 			tester == TESTER_TEXTURE_WRAP_T_CLAMP_TO_BORDER	||
2468 			tester == TESTER_TEXTURE_WRAP_R_CLAMP_TO_BORDER;
2469 }
2470 
createIsTextureTest(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const std::string & name,const std::string & description,glw::GLenum target)2471 tcu::TestCase* createIsTextureTest (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const std::string& name, const std::string& description, glw::GLenum target)
2472 {
2473 	return new IsTextureCase(testCtx, renderCtx, name.c_str(), description.c_str(), target);
2474 }
2475 
createTexParamTest(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const std::string & name,const std::string & description,QueryType queryType,glw::GLenum target,TesterType tester)2476 tcu::TestCase* createTexParamTest (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const std::string& name, const std::string& description, QueryType queryType, glw::GLenum target, TesterType tester)
2477 {
2478 	if (isMultisampleTarget(target) && isSamplerStateTester(tester))
2479 	{
2480 		DE_FATAL("Multisample textures have no sampler state");
2481 		return DE_NULL;
2482 	}
2483 	if (target == GL_TEXTURE_BUFFER)
2484 	{
2485 		DE_FATAL("Buffer textures have no texture state");
2486 		return DE_NULL;
2487 	}
2488 	if (target != GL_TEXTURE_3D && mapTesterToPname(tester) == GL_TEXTURE_WRAP_R)
2489 	{
2490 		DE_FATAL("Only 3D textures have wrap r filter");
2491 		return DE_NULL;
2492 	}
2493 
2494 #define CASE_ALL_SETTERS(X) case X: case X ## _SET_PURE_INT: case X ## _SET_PURE_UINT
2495 
2496 	switch (tester)
2497 	{
2498 		CASE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_R):
2499 		CASE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_G):
2500 		CASE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_B):
2501 		CASE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_A):
2502 			return new TextureSwizzleCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, tester, queryType);
2503 
2504 		CASE_ALL_SETTERS(TESTER_TEXTURE_WRAP_S):
2505 		CASE_ALL_SETTERS(TESTER_TEXTURE_WRAP_T):
2506 		CASE_ALL_SETTERS(TESTER_TEXTURE_WRAP_R):
2507 			return new TextureWrapCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, tester, queryType);
2508 
2509 		CASE_ALL_SETTERS(TESTER_TEXTURE_MAG_FILTER):
2510 		CASE_ALL_SETTERS(TESTER_TEXTURE_MIN_FILTER):
2511 			return new TextureFilterCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, tester, queryType);
2512 
2513 		CASE_ALL_SETTERS(TESTER_TEXTURE_MIN_LOD):
2514 		CASE_ALL_SETTERS(TESTER_TEXTURE_MAX_LOD):
2515 			return new TextureLODCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, tester, queryType);
2516 
2517 		CASE_ALL_SETTERS(TESTER_TEXTURE_BASE_LEVEL):
2518 		CASE_ALL_SETTERS(TESTER_TEXTURE_MAX_LEVEL):
2519 			return new TextureLevelCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, tester, queryType);
2520 
2521 		CASE_ALL_SETTERS(TESTER_TEXTURE_COMPARE_MODE):
2522 			return new TextureCompareModeCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, tester, queryType);
2523 
2524 		CASE_ALL_SETTERS(TESTER_TEXTURE_COMPARE_FUNC):
2525 			return new TextureCompareFuncCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, tester, queryType);
2526 
2527 		case TESTER_TEXTURE_IMMUTABLE_LEVELS:
2528 			return new TextureImmutableLevelsCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, queryType);
2529 
2530 		case TESTER_TEXTURE_IMMUTABLE_FORMAT:
2531 			return new TextureImmutableFormatCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, queryType);
2532 
2533 		case TESTER_TEXTURE_WRAP_S_CLAMP_TO_BORDER:
2534 		case TESTER_TEXTURE_WRAP_T_CLAMP_TO_BORDER:
2535 		case TESTER_TEXTURE_WRAP_R_CLAMP_TO_BORDER:
2536 			return new TextureWrapClampToBorderCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, tester, queryType);
2537 
2538 		CASE_ALL_SETTERS(TESTER_DEPTH_STENCIL_TEXTURE_MODE):
2539 			return new DepthStencilModeCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, tester, queryType);
2540 
2541 		CASE_ALL_SETTERS(TESTER_TEXTURE_SRGB_DECODE_EXT):
2542 			return new TextureSRGBDecodeCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, tester, queryType);
2543 
2544 		case TESTER_TEXTURE_BORDER_COLOR:
2545 			return new TextureBorderColorCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, queryType);
2546 
2547 		default:
2548 			break;
2549 	}
2550 
2551 #undef CASE_ALL_SETTERS
2552 
2553 	DE_ASSERT(false);
2554 	return DE_NULL;
2555 }
2556 
createSamplerParamTest(tcu::TestContext & testCtx,const glu::RenderContext & renderCtx,const std::string & name,const std::string & description,StateQueryUtil::QueryType queryType,TesterType tester)2557 tcu::TestCase* createSamplerParamTest (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const std::string& name, const std::string& description, StateQueryUtil::QueryType queryType, TesterType tester)
2558 {
2559 #define CASE_ALL_SETTERS(X) case X: case X ## _SET_PURE_INT: case X ## _SET_PURE_UINT
2560 
2561 	switch (tester)
2562 	{
2563 		CASE_ALL_SETTERS(TESTER_TEXTURE_WRAP_S):
2564 		CASE_ALL_SETTERS(TESTER_TEXTURE_WRAP_T):
2565 		CASE_ALL_SETTERS(TESTER_TEXTURE_WRAP_R):
2566 			return new SamplerWrapCase(testCtx, renderCtx, name.c_str(), description.c_str(), tester, queryType);
2567 
2568 		CASE_ALL_SETTERS(TESTER_TEXTURE_MAG_FILTER):
2569 		CASE_ALL_SETTERS(TESTER_TEXTURE_MIN_FILTER):
2570 			return new SamplerFilterCase(testCtx, renderCtx, name.c_str(), description.c_str(), tester, queryType);
2571 
2572 		CASE_ALL_SETTERS(TESTER_TEXTURE_MIN_LOD):
2573 		CASE_ALL_SETTERS(TESTER_TEXTURE_MAX_LOD):
2574 			return new SamplerLODCase(testCtx, renderCtx, name.c_str(), description.c_str(), tester, queryType);
2575 
2576 		CASE_ALL_SETTERS(TESTER_TEXTURE_COMPARE_MODE):
2577 			return new SamplerCompareModeCase(testCtx, renderCtx, name.c_str(), description.c_str(), tester, queryType);
2578 
2579 		CASE_ALL_SETTERS(TESTER_TEXTURE_COMPARE_FUNC):
2580 			return new SamplerCompareFuncCase(testCtx, renderCtx, name.c_str(), description.c_str(), tester, queryType);
2581 
2582 		case TESTER_TEXTURE_WRAP_S_CLAMP_TO_BORDER:
2583 		case TESTER_TEXTURE_WRAP_T_CLAMP_TO_BORDER:
2584 		case TESTER_TEXTURE_WRAP_R_CLAMP_TO_BORDER:
2585 			return new SamplerWrapClampToBorderCase(testCtx, renderCtx, name.c_str(), description.c_str(), tester, queryType);
2586 
2587 		CASE_ALL_SETTERS(TESTER_TEXTURE_SRGB_DECODE_EXT):
2588 			return new SamplerSRGBDecodeCase(testCtx, renderCtx, name.c_str(), description.c_str(), tester, queryType);
2589 
2590 		case TESTER_TEXTURE_BORDER_COLOR:
2591 			return new SamplerBorderColorCase(testCtx, renderCtx, name.c_str(), description.c_str(), queryType);
2592 
2593 		default:
2594 			break;
2595 	}
2596 
2597 #undef CASE_ALL_SETTERS
2598 
2599 	DE_ASSERT(false);
2600 	return DE_NULL;
2601 }
2602 
2603 } // TextureStateQueryTests
2604 } // gls
2605 } // deqp
2606