• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 #ifndef _GL4CENHANCEDLAYOUTSTESTS_HPP
2 #define _GL4CENHANCEDLAYOUTSTESTS_HPP
3 /*-------------------------------------------------------------------------
4  * OpenGL Conformance Test Suite
5  * -----------------------------
6  *
7  * Copyright (c) 2015-2016 The Khronos Group Inc.
8  *
9  * Licensed under the Apache License, Version 2.0 (the "License");
10  * you may not use this file except in compliance with the License.
11  * You may obtain a copy of the License at
12  *
13  *      http://www.apache.org/licenses/LICENSE-2.0
14  *
15  * Unless required by applicable law or agreed to in writing, software
16  * distributed under the License is distributed on an "AS IS" BASIS,
17  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18  * See the License for the specific language governing permissions and
19  * limitations under the License.
20  *
21  */ /*!
22  * \file
23  * \brief
24  */ /*-------------------------------------------------------------------*/
25 
26 /**
27  * \file  gl4cEnhancedLayoutsTests.hpp
28  * \brief Declares test classes for "Enhanced Layouts" functionality.
29  */ /*-------------------------------------------------------------------*/
30 
31 #include "glcTestCase.hpp"
32 #include "glwDefs.hpp"
33 
34 namespace tcu
35 {
36 class MessageBuilder;
37 } /* namespace tcu */
38 
39 namespace gl4cts
40 {
41 
42 namespace EnhancedLayouts
43 {
44 namespace Utils
45 {
46 /** Represents data type
47  *
48  **/
49 struct Type
50 {
51 public:
52 	enum TYPES
53 	{
54 		Float,
55 		Double,
56 		Int,
57 		Uint,
58 	};
59 
60 	/* Public methods */
61 	/* Functionality */
62 	std::vector<glw::GLubyte> GenerateData() const;
63 	std::vector<glw::GLubyte> GenerateDataPacked() const;
64 	glw::GLuint GetActualAlignment(glw::GLuint align, bool is_array) const;
65 	glw::GLuint GetBaseAlignment(bool is_array) const;
66 	std::string GetGLSLConstructor(const glw::GLvoid* data) const;
67 	const glw::GLchar* GetGLSLTypeName() const;
68 	glw::GLuint GetLocations(bool is_vs_input = false) const;
69 	glw::GLuint GetSize(const bool is_std140 = false) const;
70 	glw::GLenum GetTypeGLenum() const;
71 	glw::GLuint GetNumComponents() const;
72 
73 	/* Public static routines */
74 	/* Functionality */
75 	static glw::GLuint CalculateStd140Stride(glw::GLuint alignment, glw::GLuint n_columns,
76 											 glw::GLuint n_array_elements);
77 
78 	static bool DoesTypeSupportMatrix(TYPES type);
79 
80 	static glw::GLuint GetActualOffset(glw::GLuint start_offset, glw::GLuint actual_alignment);
81 
82 	static Type GetType(TYPES basic_type, glw::GLuint n_columns, glw::GLuint n_rows);
83 
84 	static glw::GLuint GetTypeSize(TYPES type);
85 
86 	/* GL gets */
87 	static glw::GLenum GetTypeGLenum(TYPES type);
88 
89 	/* Public fields */
90 	TYPES		m_basic_type;
91 	glw::GLuint m_n_columns;
92 	glw::GLuint m_n_rows;
93 
94 	/* Public constants */
95 	static const Type _double;
96 	static const Type dmat2;
97 	static const Type dmat2x3;
98 	static const Type dmat2x4;
99 	static const Type dmat3x2;
100 	static const Type dmat3;
101 	static const Type dmat3x4;
102 	static const Type dmat4x2;
103 	static const Type dmat4x3;
104 	static const Type dmat4;
105 	static const Type dvec2;
106 	static const Type dvec3;
107 	static const Type dvec4;
108 	static const Type _float;
109 	static const Type _int;
110 	static const Type ivec2;
111 	static const Type ivec3;
112 	static const Type ivec4;
113 	static const Type mat2;
114 	static const Type mat2x3;
115 	static const Type mat2x4;
116 	static const Type mat3x2;
117 	static const Type mat3;
118 	static const Type mat3x4;
119 	static const Type mat4x2;
120 	static const Type mat4x3;
121 	static const Type mat4;
122 	static const Type vec2;
123 	static const Type vec3;
124 	static const Type vec4;
125 	static const Type uint;
126 	static const Type uvec2;
127 	static const Type uvec3;
128 	static const Type uvec4;
129 };
130 
131 /** Represents buffer instance
132  * Provides basic buffer functionality
133  **/
134 class Buffer
135 {
136 public:
137 	/* Public enums */
138 	enum BUFFERS
139 	{
140 		Array,
141 		Element,
142 		Shader_Storage,
143 		Texture,
144 		Transform_feedback,
145 		Uniform,
146 	};
147 
148 	enum USAGE
149 	{
150 		DynamicCopy,
151 		DynamicDraw,
152 		DynamicRead,
153 		StaticCopy,
154 		StaticDraw,
155 		StaticRead,
156 		StreamCopy,
157 		StreamDraw,
158 		StreamRead,
159 	};
160 
161 	enum ACCESS
162 	{
163 		ReadOnly,
164 		WriteOnly,
165 		ReadWrite,
166 	};
167 
168 	/* Public methods */
169 	/* Ctr & Dtr */
170 	Buffer(deqp::Context& context);
171 	~Buffer();
172 
173 	/* Init & Release */
174 	void Init(BUFFERS buffer, USAGE usage, glw::GLsizeiptr size, glw::GLvoid* data);
175 	void Release();
176 
177 	/* Functionality */
178 	void Bind() const;
179 	void BindBase(glw::GLuint index) const;
180 
181 	void BindRange(glw::GLuint index, glw::GLintptr offset, glw::GLsizeiptr size) const;
182 
183 	void Data(USAGE usage, glw::GLsizeiptr size, glw::GLvoid* data);
184 
185 	glw::GLvoid* Map(ACCESS access);
186 
187 	void SubData(glw::GLintptr offset, glw::GLsizeiptr size, glw::GLvoid* data);
188 
189 	void UnMap();
190 
191 	/* Public static routines */
192 	/* Functionality */
193 	static void Bind(const glw::Functions& gl, glw::GLuint id, BUFFERS buffer);
194 
195 	static void BindBase(const glw::Functions& gl, glw::GLuint id, BUFFERS buffer, glw::GLuint index);
196 
197 	static void BindRange(const glw::Functions& gl, glw::GLuint id, BUFFERS buffer, glw::GLuint index,
198 						  glw::GLintptr offset, glw::GLsizeiptr size);
199 
200 	static void Data(const glw::Functions& gl, BUFFERS buffer, USAGE usage, glw::GLsizeiptr size, glw::GLvoid* data);
201 
202 	static void Generate(const glw::Functions& gl, glw::GLuint& out_id);
203 
204 	static void* Map(const glw::Functions& gl, BUFFERS buffer, ACCESS access);
205 
206 	static void SubData(const glw::Functions& gl, BUFFERS buffer, glw::GLintptr offset, glw::GLsizeiptr size,
207 						glw::GLvoid* data);
208 
209 	static void UnMap(const glw::Functions& gl, BUFFERS buffer);
210 
211 	/* GL gets */
212 	static glw::GLenum GetAccessGLenum(ACCESS access);
213 	static glw::GLenum GetBufferGLenum(BUFFERS buffer);
214 	static glw::GLenum GetUsageGLenum(USAGE usage);
215 
216 	/* Gets */
217 	static const glw::GLchar* GetBufferName(BUFFERS buffer);
218 
219 	/* Public fields */
220 	glw::GLuint m_id;
221 
222 	/* Public constants */
223 	static const glw::GLuint m_invalid_id;
224 
225 	/* Buffer type maybe changed for different cases*/
226 	BUFFERS m_buffer;
227 
228 private:
229 	/* Private fields */
230 	deqp::Context& m_context;
231 };
232 
233 /** Represents framebuffer
234  * Provides basic functionality
235  **/
236 class Framebuffer
237 {
238 public:
239 	/* Public methods */
240 	/* Ctr & Dtr */
241 	Framebuffer(deqp::Context& context);
242 	~Framebuffer();
243 
244 	/* Init & Release */
245 	void Init();
246 	void Release();
247 
248 	/* Functionality */
249 	void AttachTexture(glw::GLenum attachment, glw::GLuint texture_id, glw::GLuint width, glw::GLuint height);
250 
251 	void Bind();
252 	void Clear(glw::GLenum mask);
253 
254 	void ClearColor(glw::GLfloat red, glw::GLfloat green, glw::GLfloat blue, glw::GLfloat alpha);
255 
256 	/* Public static routines */
257 	static void AttachTexture(const glw::Functions& gl, glw::GLenum attachment, glw::GLuint texture_id,
258 							  glw::GLuint width, glw::GLuint height);
259 
260 	static void Bind(const glw::Functions& gl, glw::GLuint id);
261 
262 	static void Clear(const glw::Functions& gl, glw::GLenum mask);
263 
264 	static void ClearColor(const glw::Functions& gl, glw::GLfloat red, glw::GLfloat green, glw::GLfloat blue,
265 						   glw::GLfloat alpha);
266 
267 	static void Generate(const glw::Functions& gl, glw::GLuint& out_id);
268 
269 	/* Public fields */
270 	glw::GLuint m_id;
271 
272 	/* Public constants */
273 	static const glw::GLuint m_invalid_id;
274 
275 private:
276 	/* Private fields */
277 	deqp::Context& m_context;
278 };
279 
280 /** Represents shader instance.
281  * Provides basic functionality for shaders.
282  **/
283 class Shader
284 {
285 public:
286 	/* Public enums */
287 	enum STAGES
288 	{
289 		COMPUTE = 0,
290 		VERTEX,
291 		TESS_CTRL,
292 		TESS_EVAL,
293 		GEOMETRY,
294 		FRAGMENT,
295 
296 		/* */
297 		STAGE_MAX
298 	};
299 
300 	/* Public types */
301 
302 	class InvalidSourceException : public std::exception
303 	{
304 	public:
305 		InvalidSourceException(const glw::GLchar* error_message, const std::string& source, STAGES stage);
306 
~InvalidSourceException()307 		virtual ~InvalidSourceException() throw()
308 		{
309 		}
310 
311 		virtual const char* what() const throw();
312 
313 		void log(deqp::Context& context) const;
314 
315 		std::string m_message;
316 		std::string m_source;
317 		STAGES		m_stage;
318 	};
319 
320 	/* Public methods */
321 	/* Ctr & Dtr */
322 	Shader(deqp::Context& context);
323 	~Shader();
324 
325 	/* Init & Realese */
326 	void Init(STAGES stage, const std::string& source);
327 	void Release();
328 
329 	/* Public static routines */
330 	/* Functionality */
331 	static void Compile(const glw::Functions& gl, glw::GLuint id);
332 
333 	static void Create(const glw::Functions& gl, STAGES stage, glw::GLuint& out_id);
334 
335 	static void Source(const glw::Functions& gl, glw::GLuint id, const std::string& source);
336 
337 	/* GL gets */
338 	static glw::GLenum GetShaderStageGLenum(STAGES stage);
339 
340 	/* Get stage name */
341 	static const glw::GLchar* GetStageName(STAGES stage);
342 
343 	/* Logs sources */
344 	static void LogSource(deqp::Context& context, const std::string& source, STAGES stage);
345 
346 	/* Public fields */
347 	glw::GLuint m_id;
348 
349 	/* Public constants */
350 	static const glw::GLuint m_invalid_id;
351 
352 private:
353 	/* Private types */
354 	class CompilationException : public std::exception
355 	{
356 	public:
357 		CompilationException(const glw::GLchar* message);
358 
~CompilationException()359 		virtual ~CompilationException() throw()
360 		{
361 		}
362 
363 		virtual const char* what() const throw();
364 
365 		std::string m_message;
366 	};
367 
368 	/* Private fields */
369 	deqp::Context& m_context;
370 };
371 
372 /* Forward declaration */
373 struct Interface;
374 
375 /** Represents GLSL variable
376  *
377  **/
378 struct Variable
379 {
380 public:
381 	/* Typedefs */
382 	typedef std::vector<Variable>  Vector;
383 	typedef std::vector<Variable*> PtrVector;
384 
385 	/* Enums */
386 	enum STORAGE
387 	{
388 		VARYING_INPUT,
389 		VARYING_OUTPUT,
390 		UNIFORM,
391 		SSB,
392 		MEMBER,
393 
394 		/* */
395 		STORAGE_MAX
396 	};
397 
398 	enum VARYING_DIRECTION
399 	{
400 		INPUT,
401 		OUTPUT,
402 	};
403 
404 	enum FLAVOUR
405 	{
406 		BASIC,
407 		ARRAY,
408 		INDEXED_BY_INVOCATION_ID,
409 	};
410 
411 	/**/
412 	enum TYPE
413 	{
414 		BUILTIN,
415 		INTERFACE,
416 	};
417 
418 	/* Types */
419 	struct Descriptor
420 	{
421 		/* */
422 		typedef std::vector<Descriptor> Vector;
423 
424 		/* */
425 		Descriptor(const glw::GLchar* name, const glw::GLchar* qualifiers, glw::GLint expected_component,
426 				   glw::GLint expected_location, const Type& type, glw::GLboolean normalized,
427 				   glw::GLuint n_array_elements, glw::GLint expected_stride_of_element, glw::GLuint offset);
428 
429 		Descriptor(const glw::GLchar* name, const glw::GLchar* qualifiers, glw::GLint expected_componenet,
430 				   glw::GLint expected_location, Interface* interface, glw::GLuint n_array_elements,
431 				   glw::GLint expected_stride_of_element, glw::GLuint offset);
432 
433 		/* */
434 		std::string GetDefinition(FLAVOUR flavour, STORAGE storage) const;
435 
436 		/* */
437 		glw::GLint	 m_expected_component;
438 		glw::GLint	 m_expected_location;
439 		glw::GLint	 m_expected_stride_of_element;
440 		glw::GLuint	m_n_array_elements;
441 		std::string	m_name;
442 		glw::GLboolean m_normalized;
443 		glw::GLuint	m_offset;
444 		std::string	m_qualifiers;
445 
446 		TYPE m_type;
447 		union {
448 			Type	   m_builtin;
449 			Interface* m_interface;
450 		};
451 	};
452 
453 	/* Constructors */
454 	template <typename T>
Variablegl4cts::EnhancedLayouts::Utils::Variable455 	Variable(const glw::GLchar* name, const glw::GLchar* qualifiers, glw::GLint expected_component,
456 			 glw::GLint expected_location, const Type& type, glw::GLboolean normalized, glw::GLuint n_array_elements,
457 			 glw::GLint expected_stride_of_element, glw::GLuint offset, const T* data, size_t data_size,
458 			 STORAGE storage)
459 		: m_data((glw::GLvoid*)data)
460 		, m_data_size(data_size)
461 		, m_descriptor(name, qualifiers, expected_component, expected_location, type, normalized, n_array_elements,
462 					   expected_stride_of_element, offset)
463 		, m_storage(storage)
464 	{
465 	}
466 
467 	template <typename T>
Variablegl4cts::EnhancedLayouts::Utils::Variable468 	Variable(const glw::GLchar* name, const glw::GLchar* qualifiers, glw::GLint expected_component,
469 			 glw::GLint expected_location, Interface* interface, glw::GLuint n_array_elements,
470 			 glw::GLint expected_stride_of_element, glw::GLuint offset, const T* data, size_t data_size,
471 			 STORAGE storage)
472 		: m_data((glw::GLvoid*)data)
473 		, m_data_size(data_size)
474 		, m_descriptor(name, qualifiers, expected_component, expected_location, interface, n_array_elements,
475 					   expected_stride_of_element, offset)
476 		, m_storage(storage)
477 	{
478 	}
479 
480 	Variable(const Variable& var);
481 
482 	/* Functionality */
483 	std::string GetDefinition(FLAVOUR flavour) const;
484 	glw::GLuint GetSize() const;
485 	glw::GLuint GetStride() const;
486 	bool		IsBlock() const;
487 	bool		IsStruct() const;
488 	/* Static routines */
489 	static FLAVOUR GetFlavour(Shader::STAGES stage, VARYING_DIRECTION direction);
490 	static std::string GetReference(const std::string& parent_name, const Descriptor& variable, FLAVOUR flavour,
491 									glw::GLuint array_index);
492 
493 	/* Fields */
494 	glw::GLvoid* m_data;
495 	size_t		 m_data_size;
496 	Descriptor   m_descriptor;
497 	STORAGE		 m_storage;
498 
499 	/* Constants */
500 	static const glw::GLint m_automatic_location;
501 };
502 
503 /* Define the methods NAME, that will add new variable to VECTOR with STORAGE set		*/
504 #define DEFINE_VARIABLE_CLASS(NAME, STORAGE, VECTOR)                                                                  \
505 	template <typename T>                                                                                             \
506 	Variable* NAME(const glw::GLchar* name, const glw::GLchar* qualifiers, glw::GLint expected_component,             \
507 				   glw::GLint expected_location, const Type& type, glw::GLboolean normalized,                         \
508 				   glw::GLuint n_array_elements, glw::GLint expected_stride_of_element, glw::GLuint offset,           \
509 				   const T* data, size_t data_size)                                                                   \
510 	{                                                                                                                 \
511 		Variable* var = new Variable(name, qualifiers, expected_component, expected_location, type, normalized,       \
512 									 n_array_elements, expected_stride_of_element, offset, data, data_size, STORAGE); \
513 		if (0 == var)                                                                                                 \
514 		{                                                                                                             \
515 			TCU_FAIL("Memory allocation");                                                                            \
516 		}                                                                                                             \
517 		VECTOR.push_back(var);                                                                                        \
518 		return VECTOR.back();                                                                                         \
519 	}                                                                                                                 \
520                                                                                                                       \
521 	template <typename T>                                                                                             \
522 	Variable* NAME(const glw::GLchar* name, const glw::GLchar* qualifiers, glw::GLint expected_component,             \
523 				   glw::GLint expected_location, Interface* interface, glw::GLuint n_array_elements,                  \
524 				   glw::GLint expected_stride_of_element, glw::GLuint offset, const T* data, size_t data_size)        \
525 	{                                                                                                                 \
526 		Variable* var = new Variable(name, qualifiers, expected_component, expected_location, interface,              \
527 									 n_array_elements, expected_stride_of_element, offset, data, data_size, STORAGE); \
528 		if (0 == var)                                                                                                 \
529 		{                                                                                                             \
530 			TCU_FAIL("Memory allocation");                                                                            \
531 		}                                                                                                             \
532 		VECTOR.push_back(var);                                                                                        \
533 		return VECTOR.back();                                                                                         \
534 	}
535 
536 /** Represents structures and block
537  *
538  **/
539 struct Interface
540 {
541 public:
542 	/* Typedefs */
543 	typedef std::vector<Interface>  Vector;
544 	typedef std::vector<Interface*> PtrVector;
545 
546 	/**/
547 	enum TYPE
548 	{
549 		STRUCT,
550 		BLOCK
551 	};
552 
553 	/* Constructor */
554 	Interface(const glw::GLchar* name, TYPE type);
555 
556 	/*  */
557 	Variable::Descriptor* Member(const glw::GLchar* name, const glw::GLchar* qualifiers, glw::GLint expected_component,
558 								 glw::GLint expected_location, const Type& type, glw::GLboolean normalized,
559 								 glw::GLuint n_array_elements, glw::GLint expected_stride_of_element,
560 								 glw::GLuint offset);
561 	Variable::Descriptor* Member(const glw::GLchar* name, const glw::GLchar* qualifiers, glw::GLint expected_component,
562 								 glw::GLint expected_location, Interface* interface, glw::GLuint n_array_elements,
563 								 glw::GLint expected_stride_of_element, glw::GLuint offset);
564 
565 	/**/
566 	Variable::Descriptor* AddMember(const Variable::Descriptor& member);
567 
568 	std::string GetDefinition() const;
569 
570 	/**/
571 	Variable::Descriptor::Vector m_members;
572 	std::string					 m_name;
573 	TYPE						 m_type;
574 };
575 
576 struct ShaderInterface
577 {
578 	ShaderInterface(Shader::STAGES stage);
579 
580 	DEFINE_VARIABLE_CLASS(Input, Variable::VARYING_INPUT, m_inputs);
581 	DEFINE_VARIABLE_CLASS(Output, Variable::VARYING_OUTPUT, m_outputs);
582 	DEFINE_VARIABLE_CLASS(Uniform, Variable::UNIFORM, m_uniforms);
583 	DEFINE_VARIABLE_CLASS(SSB, Variable::SSB, m_ssb_blocks);
584 
585 	/**/
586 	std::string GetDefinitionsGlobals() const;
587 	std::string GetDefinitionsInputs() const;
588 	std::string GetDefinitionsOutputs() const;
589 	std::string GetDefinitionsSSBs() const;
590 	std::string GetDefinitionsUniforms() const;
591 
592 	std::string			m_globals;
593 	Variable::PtrVector m_inputs;
594 	Variable::PtrVector m_outputs;
595 	Variable::PtrVector m_uniforms;
596 	Variable::PtrVector m_ssb_blocks;
597 
598 	Shader::STAGES m_stage;
599 };
600 
601 struct VaryingConnection
602 {
603 	/* */
604 	typedef std::vector<VaryingConnection> Vector;
605 
606 	/* */
607 	VaryingConnection(Variable* in, Variable* out);
608 
609 	/* */
610 	Variable* m_in;
611 	Variable* m_out;
612 };
613 
614 struct VaryingPassthrough
615 {
616 	/* */
617 	void Add(Shader::STAGES stage, Variable* in, Variable* out);
618 
619 	VaryingConnection::Vector& Get(Shader::STAGES stage);
620 
621 	/**/
622 	VaryingConnection::Vector m_fragment;
623 	VaryingConnection::Vector m_geometry;
624 	VaryingConnection::Vector m_tess_ctrl;
625 	VaryingConnection::Vector m_tess_eval;
626 	VaryingConnection::Vector m_vertex;
627 };
628 
629 struct ProgramInterface
630 {
631 
632 	/* */
633 	ProgramInterface();
634 	~ProgramInterface();
635 
636 	/* */
637 	Interface* AddInterface(const glw::GLchar* name, Interface::TYPE type);
638 	Interface* Block(const glw::GLchar* name);
639 	Interface* GetBlock(const glw::GLchar* name);
640 	ShaderInterface& GetShaderInterface(Shader::STAGES stage);
641 	const ShaderInterface& GetShaderInterface(Shader::STAGES stage) const;
642 	Interface* GetStructure(const glw::GLchar* name);
643 	Interface* Structure(const glw::GLchar* name);
644 
645 	/**/
646 	std::string GetDefinitionsStructures() const;
647 	std::string GetInterfaceForStage(Shader::STAGES stage) const;
648 
649 	/* */
650 	Interface* CloneBlockForStage(const Interface& block, Shader::STAGES stage, Variable::STORAGE storage,
651 								  const glw::GLchar* prefix);
652 	void CloneVertexInterface(VaryingPassthrough& variable_pass);
653 
654 	/* */
655 	static const glw::GLchar* GetStagePrefix(Shader::STAGES stage, Variable::STORAGE storage);
656 
657 	/* */
658 	Interface::PtrVector m_structures;
659 	Interface::PtrVector m_blocks;
660 
661 	ShaderInterface m_compute;
662 	ShaderInterface m_vertex;
663 	ShaderInterface m_tess_ctrl;
664 	ShaderInterface m_tess_eval;
665 	ShaderInterface m_geometry;
666 	ShaderInterface m_fragment;
667 
668 	//Variable::Vector     m_fragment_outputs;
669 	//Variable::PtrVector  m_captured_varyings;
670 
671 private:
672 	/* */
673 	void cloneVariableForStage(const Variable& variable, Shader::STAGES stage, const glw::GLchar* prefix,
674 							   VaryingPassthrough& varying_passthrough);
675 	Variable* cloneVariableForStage(const Variable& variable, Shader::STAGES stage, Variable::STORAGE storage,
676 									const glw::GLchar* prefix);
677 	void replaceBinding(Variable& variable, Shader::STAGES stage);
678 };
679 
680 /** Represents program pipeline
681  *
682  **/
683 class Pipeline
684 {
685 public:
686 	/* Public methods */
687 	/* Ctr & Dtr */
688 	Pipeline(deqp::Context& context);
689 	~Pipeline();
690 
691 	/* Init & Release */
692 	void Init();
693 	void Release();
694 
695 	/* Functionality */
696 	void Bind();
697 	void UseProgramStages(glw::GLuint program_id, glw::GLenum stages);
698 
699 	/* Public static routines */
700 	/* Functionality */
701 	void Bind(const glw::Functions& gl, glw::GLuint id);
702 	void UseProgramStages(const glw::Functions& gl, glw::GLuint id, glw::GLuint program_id, glw::GLenum stages);
703 
704 	/* Public fields */
705 	glw::GLuint m_id;
706 
707 	/* Public constants */
708 	static const glw::GLuint m_invalid_id;
709 
710 private:
711 	/* Private fields */
712 	deqp::Context& m_context;
713 };
714 
715 /** Represents program instance.
716  * Provides basic functionality
717  **/
718 class Program
719 {
720 public:
721 	/* Public types */
722 	class BuildException : public std::exception
723 	{
724 	public:
725 		BuildException(const glw::GLchar* error_message, const std::string compute_shader,
726 					   const std::string fragment_shader, const std::string geometry_shader,
727 					   const std::string tess_ctrl_shader, const std::string tess_eval_shader,
728 					   const std::string vertex_shader);
~BuildException()729 		virtual ~BuildException() throw()
730 		{
731 		}
732 
733 		virtual const char* what() const throw();
734 
735 		void log(deqp::Context& context) const;
736 
737 		std::string m_error_message;
738 		std::string m_compute_shader;
739 		std::string m_fragment_shader;
740 		std::string m_geometry_shader;
741 		std::string m_tess_ctrl_shader;
742 		std::string m_tess_eval_shader;
743 		std::string m_vertex_shader;
744 	};
745 
746 	typedef std::vector<std::string> NameVector;
747 
748 	/* Public methods */
749 	/* Ctr & Dtr */
750 	Program(deqp::Context& context);
751 	~Program();
752 
753 	/* Init & Release */
754 	void Init(const std::string& compute_shader, const std::string& fragment_shader, const std::string& geometry_shader,
755 			  const std::string& tessellation_control_shader, const std::string& tessellation_evaluation_shader,
756 			  const std::string& vertex_shader, const NameVector& captured_varyings, bool capture_interleaved,
757 			  bool is_separable);
758 
759 	void Init(const std::string& compute_shader, const std::string& fragment_shader, const std::string& geometry_shader,
760 			  const std::string& tessellation_control_shader, const std::string& tessellation_evaluation_shader,
761 			  const std::string& vertex_shader, bool is_separable);
762 
763 	void Release();
764 
765 	/* Functionality */
766 	void GetActiveUniformsiv(glw::GLsizei count, const glw::GLuint* indices, glw::GLenum pname,
767 							 glw::GLint* params) const;
768 
769 	glw::GLint GetAttribLocation(const std::string& name) const;
770 
771 	void GetResource(glw::GLenum interface, glw::GLuint index, glw::GLenum property, glw::GLsizei buf_size,
772 					 glw::GLint* params) const;
773 
774 	glw::GLuint GetResourceIndex(const std::string& name, glw::GLenum interface) const;
775 
776 	void GetUniformIndices(glw::GLsizei count, const glw::GLchar** names, glw::GLuint* indices) const;
777 
778 	glw::GLint GetUniformLocation(const std::string& name) const;
779 	void Use() const;
780 
781 	/* Public static routines */
782 	/* Functionality */
783 	static void Attach(const glw::Functions& gl, glw::GLuint program_id, glw::GLuint shader_id);
784 
785 	static void Capture(const glw::Functions& gl, glw::GLuint id, const NameVector& captured_varyings,
786 						bool capture_interleaved);
787 
788 	static void Create(const glw::Functions& gl, glw::GLuint& out_id);
789 
790 	static void GetActiveUniformsiv(const glw::Functions& gl, glw::GLuint program_id, glw::GLsizei count,
791 									const glw::GLuint* indices, glw::GLenum pname, glw::GLint* params);
792 
793 	static void GetUniformIndices(const glw::Functions& gl, glw::GLuint program_id, glw::GLsizei count,
794 								  const glw::GLchar** names, glw::GLuint* indices);
795 
796 	static void Link(const glw::Functions& gl, glw::GLuint id);
797 
798 	static void Uniform(const glw::Functions& gl, const Type& type, glw::GLsizei count, glw::GLint location,
799 						const glw::GLvoid* data);
800 
801 	static void Use(const glw::Functions& gl, glw::GLuint id);
802 
803 	/* Get locations */
804 	static glw::GLint GetAttribLocation(const glw::Functions& gl, glw::GLuint id, const std::string& name);
805 
806 	static void GetResource(const glw::Functions& gl, glw::GLuint id, glw::GLenum interface, glw::GLuint index,
807 							glw::GLenum property, glw::GLsizei buf_size, glw::GLint* params);
808 
809 	static glw::GLuint GetResourceIndex(const glw::Functions& gl, glw::GLuint id, const std::string& name,
810 										glw::GLenum interface);
811 
812 	static glw::GLint GetUniformLocation(const glw::Functions& gl, glw::GLuint id, const std::string& name);
813 
814 	/* Public fields */
815 	glw::GLuint m_id;
816 
817 	Shader m_compute;
818 	Shader m_fragment;
819 	Shader m_geometry;
820 	Shader m_tess_ctrl;
821 	Shader m_tess_eval;
822 	Shader m_vertex;
823 
824 	/* Public constants */
825 	static const glw::GLuint m_invalid_id;
826 
827 private:
828 	/* Private types */
829 	class LinkageException : public std::exception
830 	{
831 	public:
832 		LinkageException(const glw::GLchar* error_message);
833 
~LinkageException()834 		virtual ~LinkageException() throw()
835 		{
836 		}
837 
838 		virtual const char* what() const throw();
839 
840 		std::string m_error_message;
841 	};
842 
843 	/* Private fields */
844 	deqp::Context& m_context;
845 };
846 
847 class Texture
848 {
849 public:
850 	/* Public enums */
851 	enum TYPES
852 	{
853 		TEX_BUFFER,
854 		TEX_2D,
855 		TEX_2D_RECT,
856 		TEX_2D_ARRAY,
857 		TEX_3D,
858 		TEX_CUBE,
859 		TEX_1D,
860 		TEX_1D_ARRAY,
861 	};
862 
863 	/* Public methods */
864 	/* Ctr & Dtr */
865 	Texture(deqp::Context& context);
866 	~Texture();
867 
868 	/* Init & Release */
869 	void Init(TYPES tex_type, glw::GLuint width, glw::GLuint height, glw::GLuint depth, glw::GLenum internal_format,
870 			  glw::GLenum format, glw::GLenum type, glw::GLvoid* data);
871 
872 	void Init(glw::GLenum internal_format, glw::GLuint buffer_id);
873 
874 	void Release();
875 
876 	/* Functionality */
877 	void Bind() const;
878 	void Get(glw::GLenum format, glw::GLenum type, glw::GLvoid* out_data) const;
879 
880 	/* Public static routines */
881 	/* Functionality */
882 	static void Bind(const glw::Functions& gl, glw::GLuint id, TYPES tex_type);
883 
884 	static void Generate(const glw::Functions& gl, glw::GLuint& out_id);
885 
886 	static void Get(const glw::Functions& gl, TYPES tex_type, glw::GLenum format, glw::GLenum type,
887 					glw::GLvoid* out_data);
888 
889 	static void Storage(const glw::Functions& gl, TYPES tex_type, glw::GLuint width, glw::GLuint height,
890 						glw::GLuint depth, glw::GLenum internal_format);
891 
892 	static void TexBuffer(const glw::Functions& gl, glw::GLenum internal_format, glw::GLuint& buffer_id);
893 
894 	static void Update(const glw::Functions& gl, TYPES tex_type, glw::GLuint width, glw::GLuint height,
895 					   glw::GLuint depth, glw::GLenum format, glw::GLenum type, glw::GLvoid* data);
896 
897 	/* GL gets */
898 	static glw::GLenum GetTargetGLenum(TYPES tex_type);
899 
900 	/* Public fields */
901 	glw::GLuint m_id;
902 
903 	/* Public constants */
904 	static const glw::GLuint m_invalid_id;
905 
906 private:
907 	deqp::Context& m_context;
908 	TYPES		   m_type;
909 };
910 
911 /** Represents Vertex array object
912  * Provides basic functionality
913  **/
914 class VertexArray
915 {
916 public:
917 	/* Public methods */
918 	/* Ctr & Dtr */
919 	VertexArray(deqp::Context& Context);
920 	~VertexArray();
921 
922 	/* Init & Release */
923 	void Init();
924 	//void Init(const ProgramInterface& program_interface,
925 	//                glw::GLuint       vertex_buffer,
926 	//                glw::GLuint       index_buffer);
927 	void Release();
928 
929 	void Attribute(glw::GLuint index, const Type& type, glw::GLuint n_array_elements, glw::GLboolean normalized,
930 				   glw::GLsizei stride, const glw::GLvoid* pointer);
931 
932 	void Bind();
933 
934 	/* Public static methods */
935 	static void AttribPointer(const glw::Functions& gl, glw::GLuint index, const Type& type,
936 							  glw::GLuint n_array_elements, glw::GLboolean normalized, glw::GLsizei stride,
937 							  const glw::GLvoid* pointer);
938 
939 	static void Bind(const glw::Functions& gl, glw::GLuint id);
940 
941 	static void Disable(const glw::Functions& gl, glw::GLuint index, const Type& type, glw::GLuint n_array_elements);
942 
943 	static void Divisor(const glw::Functions& gl, glw::GLuint index, glw::GLuint divisor);
944 
945 	static void Enable(const glw::Functions& gl, glw::GLuint index, const Type& type, glw::GLuint n_array_elements);
946 
947 	static void Generate(const glw::Functions& gl, glw::GLuint& out_id);
948 
949 	/* Public fields */
950 	glw::GLuint m_id;
951 
952 	/* Public constants */
953 	static const glw::GLuint m_invalid_id;
954 
955 private:
956 	deqp::Context& m_context;
957 };
958 
959 /* UniformN*v prototypes */
960 typedef GLW_APICALL void(GLW_APIENTRY* uniformNdv)(glw::GLint, glw::GLsizei, const glw::GLdouble*);
961 typedef GLW_APICALL void(GLW_APIENTRY* uniformNfv)(glw::GLint, glw::GLsizei, const glw::GLfloat*);
962 typedef GLW_APICALL void(GLW_APIENTRY* uniformNiv)(glw::GLint, glw::GLsizei, const glw::GLint*);
963 typedef GLW_APICALL void(GLW_APIENTRY* uniformNuiv)(glw::GLint, glw::GLsizei, const glw::GLuint*);
964 typedef GLW_APICALL void(GLW_APIENTRY* uniformMatrixNdv)(glw::GLint, glw::GLsizei, glw::GLboolean,
965 														 const glw::GLdouble*);
966 typedef GLW_APICALL void(GLW_APIENTRY* uniformMatrixNfv)(glw::GLint, glw::GLsizei, glw::GLboolean, const glw::GLfloat*);
967 
968 /* Public static methods */
969 /* UniformN*v routine getters */
970 uniformNdv getUniformNdv(const glw::Functions& gl, glw::GLuint n_rows);
971 uniformNfv getUniformNfv(const glw::Functions& gl, glw::GLuint n_rows);
972 uniformNiv getUniformNiv(const glw::Functions& gl, glw::GLuint n_rows);
973 uniformNuiv getUniformNuiv(const glw::Functions& gl, glw::GLuint n_rows);
974 uniformMatrixNdv getUniformMatrixNdv(const glw::Functions& gl, glw::GLuint n_columns, glw::GLuint n_rows);
975 uniformMatrixNfv getUniformMatrixNfv(const glw::Functions& gl, glw::GLuint n_columns, glw::GLuint n_rows);
976 
977 /* Stuff */
978 bool checkProgramInterface(const ProgramInterface& program_interface, Program& program, std::stringstream& stream);
979 
980 bool isExtensionSupported(deqp::Context& context, const glw::GLchar* extension_name);
981 
982 bool isGLVersionAtLeast(const glw::Functions& gl, glw::GLint required_major, glw::GLint required_minor);
983 
984 void replaceToken(const glw::GLchar* token, size_t& search_position, const glw::GLchar* text, std::string& string);
985 
986 void replaceAllTokens(const glw::GLchar* token, const glw::GLchar* text, std::string& string);
987 
988 glw::GLuint roundUpToPowerOf2(glw::GLuint value);
989 
990 void insertElementOfList(const glw::GLchar* element, const glw::GLchar* separator, size_t& search_position,
991 						 std::string& string);
992 
993 void endList(const glw::GLchar* separator, size_t& search_position, std::string& string);
994 } /* Utils namespace */
995 
996 /** Base class for tests **/
997 class TestBase : public deqp::TestCase
998 {
999 public:
1000 	/* Public methods */
1001 	TestBase(deqp::Context& context, const glw::GLchar* test_name, const glw::GLchar* test_description);
1002 
~TestBase()1003 	virtual ~TestBase()
1004 	{
1005 	}
1006 
1007 	/* Public methods inherited from TestCase */
1008 	virtual tcu::TestNode::IterateResult iterate(void);
1009 
1010 protected:
1011 	/* Methods to be implemented by child class */
1012 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
1013 	virtual glw::GLuint getTestCaseNumber();
1014 	virtual bool testCase(glw::GLuint test_case_index) = 0;
1015 	virtual void testInit();
1016 
1017 	/* Routines avaiable for children */
1018 	glw::GLuint calculateStride(const Utils::Interface& interface) const;
1019 	void generateData(const Utils::Interface& interface, glw::GLuint offset, std::vector<glw::GLubyte>& out_data) const;
1020 
1021 	glw::GLint getLastInputLocation(Utils::Shader::STAGES stage, const Utils::Type& type, glw::GLuint array_lenth);
1022 
1023 	glw::GLint getLastOutputLocation(Utils::Shader::STAGES stage, const Utils::Type& type, glw::GLuint array_lenth);
1024 
1025 	Utils::Type getType(glw::GLuint index) const;
1026 	std::string getTypeName(glw::GLuint index) const;
1027 	glw::GLuint getTypesNumber() const;
1028 
1029 	bool isFlatRequired(Utils::Shader::STAGES stage, const Utils::Type& type, Utils::Variable::STORAGE storage) const;
1030 
1031 private:
1032 	/* Private methods */
1033 	bool test();
1034 };
1035 
1036 /** Base class for test doing Buffer alghorithm **/
1037 class BufferTestBase : public TestBase
1038 {
1039 public:
1040 	/* Public methods */
1041 	BufferTestBase(deqp::Context& context, const glw::GLchar* test_name, const glw::GLchar* test_description);
1042 
~BufferTestBase()1043 	virtual ~BufferTestBase()
1044 	{
1045 	}
1046 
1047 protected:
1048 	/* */
1049 	struct bufferDescriptor
1050 	{
1051 		/* Typedefs */
1052 		typedef std::vector<bufferDescriptor> Vector;
1053 
1054 		/* Fileds */
1055 		std::vector<glw::GLubyte> m_expected_data;
1056 		std::vector<glw::GLubyte> m_initial_data;
1057 		glw::GLuint				  m_index;
1058 		Utils::Buffer::BUFFERS	m_target;
1059 
1060 		/* Constants */
1061 		static const glw::GLuint m_non_indexed;
1062 	};
1063 
1064 	class bufferCollection
1065 	{
1066 	public:
1067 		struct pair
1068 		{
1069 			Utils::Buffer*	m_buffer;
1070 			bufferDescriptor* m_descriptor;
1071 		};
1072 
1073 		~bufferCollection();
1074 
1075 		typedef std::vector<pair> Vector;
1076 
1077 		Vector m_vector;
1078 	};
1079 
1080 	virtual bool executeDrawCall(bool tesEnabled, glw::GLuint test_case_index);
1081 
1082 	virtual void getBufferDescriptors(glw::GLuint test_case_index, bufferDescriptor::Vector& out_descriptors);
1083 
1084 	virtual void getCapturedVaryings(glw::GLuint test_case_index, Utils::Program::NameVector& captured_varyings);
1085 
1086 	virtual void getShaderBody(glw::GLuint test_case_index, Utils::Shader::STAGES stage, std::string& out_assignments,
1087 							   std::string& out_calculations);
1088 
1089 	virtual void getShaderInterface(glw::GLuint test_case_index, Utils::Shader::STAGES stage,
1090 									std::string& out_interface);
1091 
1092 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
1093 
1094 	virtual bool inspectProgram(glw::GLuint test_case_index, Utils::Program& program, std::stringstream& out_stream);
1095 
1096 	virtual bool testCase(glw::GLuint test_case_index);
1097 	virtual bool verifyBuffers(bufferCollection& buffers);
1098 
1099 private:
1100 	void		cleanBuffers();
1101 	std::string getShaderTemplate(Utils::Shader::STAGES stage);
1102 	void prepareBuffer(Utils::Buffer& buffer, bufferDescriptor& descriptor);
1103 	void prepareBuffers(bufferDescriptor::Vector& descriptors, bufferCollection& out_buffers);
1104 
1105 	/* */
1106 };
1107 
1108 class NegativeTestBase : public TestBase
1109 {
1110 public:
1111 	/* Public methods */
1112 	NegativeTestBase(deqp::Context& context, const glw::GLchar* test_name, const glw::GLchar* test_description);
1113 
~NegativeTestBase()1114 	virtual ~NegativeTestBase()
1115 	{
1116 	}
1117 
1118 protected:
1119 	/* Methods to be implemented by child class */
1120 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage) = 0;
1121 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
1122 	virtual bool isFailureExpected(glw::GLuint test_case_index);
1123 	virtual bool testCase(glw::GLuint test_case_index);
1124 };
1125 
1126 /** Base class for test doing Texture alghorithm **/
1127 class TextureTestBase : public TestBase
1128 {
1129 public:
1130 	/* Public methods */
1131 	TextureTestBase(deqp::Context& context, const glw::GLchar* test_name, const glw::GLchar* test_description);
1132 
~TextureTestBase()1133 	virtual ~TextureTestBase()
1134 	{
1135 	}
1136 
1137 protected:
1138 	/* Methods to be implemented by child class */
1139 	virtual bool checkResults(glw::GLuint test_case_index, Utils::Texture& color_0);
1140 
1141 	virtual void executeDispatchCall(glw::GLuint test_case_index);
1142 	virtual void executeDrawCall(glw::GLuint test_case_index);
1143 
1144 	virtual void getProgramInterface(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
1145 									 Utils::VaryingPassthrough& varying_passthrough);
1146 
1147 	virtual std::string getPassSnippet(glw::GLuint test_case_index, Utils::VaryingPassthrough& varying_passthrough,
1148 									   Utils::Shader::STAGES stage);
1149 
1150 	virtual std::string getVerificationSnippet(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
1151 											   Utils::Shader::STAGES stage);
1152 
1153 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
1154 	virtual bool isDrawRelevant(glw::GLuint test_case_index);
1155 
1156 	virtual void prepareAttributes(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
1157 								   Utils::Buffer& buffer, Utils::VertexArray& vao);
1158 
1159 	virtual void prepareAttribLocation(Utils::Program& program, Utils::ProgramInterface& program_interface);
1160 
1161 	virtual void prepareFragmentDataLoc(Utils::Program& program, Utils::ProgramInterface& program_interface);
1162 
1163 	virtual void prepareFramebuffer(Utils::Framebuffer& framebuffer, Utils::Texture& color_0_texture);
1164 
1165 	virtual void prepareImage(glw::GLint location, Utils::Texture& image_texture) const;
1166 
1167 	virtual void prepareSSBs(glw::GLuint test_case_index, Utils::ShaderInterface& si, Utils::Program& program,
1168 							 Utils::Buffer& buffer);
1169 
1170 	virtual void prepareSSBs(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
1171 							 Utils::Program& program, Utils::Buffer& cs_buffer);
1172 
1173 	virtual void prepareSSBs(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
1174 							 Utils::Program& program, Utils::Buffer& fs_buffer, Utils::Buffer& gs_buffer,
1175 							 Utils::Buffer& tcs_buffer, Utils::Buffer& tes_buffer, Utils::Buffer& vs_buffer);
1176 
1177 	virtual void prepareUniforms(glw::GLuint test_case_index, Utils::ShaderInterface& si, Utils::Program& program,
1178 								 Utils::Buffer& buffer);
1179 
1180 	virtual void prepareUniforms(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
1181 								 Utils::Program& program, Utils::Buffer& cs_buffer);
1182 
1183 	virtual void prepareUniforms(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
1184 								 Utils::Program& program, Utils::Buffer& fs_buffer, Utils::Buffer& gs_buffer,
1185 								 Utils::Buffer& tcs_buffer, Utils::Buffer& tes_buffer, Utils::Buffer& vs_buffer);
1186 
1187 	virtual void prepareUniforms(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
1188 								 Utils::Program& fs_program, Utils::Program& gs_program, Utils::Program& tcs_program,
1189 								 Utils::Program& tes_program, Utils::Program& vs_program, Utils::Buffer& fs_buffer,
1190 								 Utils::Buffer& gs_buffer, Utils::Buffer& tcs_buffer, Utils::Buffer& tes_buffer,
1191 								 Utils::Buffer& vs_buffer);
1192 	//virtual void        prepareDrawPrograms   (glw::GLuint                 test_case_index,
1193 	//                                           Utils::Program&             fragment,
1194 	//                                           Utils::Program&             geometry,
1195 	//                                           Utils::Program&             tess_ctrl,
1196 	//                                           Utils::Program&             tess_eval,
1197 	//                                           Utils::Program&             vertex);
1198 	virtual bool testCase(glw::GLuint test_case_index);
1199 	virtual bool testMonolithic(glw::GLuint test_case_index);
1200 	virtual bool testSeparable(glw::GLuint test_case_index);
1201 	virtual bool useComponentQualifier(glw::GLuint test_case_index);
1202 	virtual bool useMonolithicProgram(glw::GLuint test_case_index);
1203 
1204 	/* Protected constants */
1205 	static const glw::GLuint m_width;
1206 	static const glw::GLuint m_height;
1207 
1208 private:
1209 	std::string getShaderSource(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
1210 								Utils::VaryingPassthrough& varying_passthrough, Utils::Shader::STAGES stage);
1211 
1212 	const glw::GLchar* getShaderTemplate(Utils::Shader::STAGES stage);
1213 
1214 	std::string getVariablePassthrough(const std::string&				  in_parent_name,
1215 									   const Utils::Variable::Descriptor& in_variable,
1216 									   Utils::Variable::FLAVOUR in_flavour, const std::string& out_parent_name,
1217 									   const Utils::Variable::Descriptor& out_variable,
1218 									   Utils::Variable::FLAVOUR			  out_flavour);
1219 
1220 	std::string getVariableVerification(const std::string& parent_name, const glw::GLvoid* data,
1221 										const Utils::Variable::Descriptor& variable, Utils::Variable::FLAVOUR flavour);
1222 
1223 	void prepareSSB(Utils::Program& program, Utils::Variable& variable, Utils::Buffer& buffer);
1224 
1225 	void prepareUniform(Utils::Program& program, Utils::Variable& variable, Utils::Buffer& buffer);
1226 };
1227 
1228 /** Implementation of test APIConstantValues. Description follows:
1229  *
1230  *  Test verifies values of the following constants are at least as specified:
1231  * - MAX_TRANSFORM_FEEDBACK_BUFFERS                - 4,
1232  * - MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS - 64.
1233  **/
1234 class APIConstantValuesTest : public deqp::TestCase
1235 {
1236 public:
1237 	/* Public methods */
1238 	APIConstantValuesTest(deqp::Context& context);
~APIConstantValuesTest()1239 	virtual ~APIConstantValuesTest()
1240 	{
1241 	}
1242 
1243 	/* Public methods inherited from TestCase */
1244 	virtual tcu::TestNode::IterateResult iterate(void);
1245 };
1246 
1247 /** Implementation of test APIErrors. Description follows:
1248  *
1249  * Test verifies that errors are generated as specified:
1250  * - GetProgramInterfaceiv should generate INVALID_OPERATION when
1251  * <programInterface> is TRANSFORM_FEEDBACK_BUFFER and <pname> is
1252  * MAX_NAME_LENGTH;
1253  * - GetProgramResourceIndex should generate INVALID_ENUM when
1254  * <programInterface> is TRANSFORM_FEEDBACK_BUFFER;
1255  * - GetProgramResourceName should generate INVALID_ENUM when
1256  * <programInterface> is TRANSFORM_FEEDBACK_BUFFER;
1257  **/
1258 class APIErrorsTest : public deqp::TestCase
1259 {
1260 public:
1261 	/* Public methods */
1262 	APIErrorsTest(deqp::Context& context);
~APIErrorsTest()1263 	virtual ~APIErrorsTest()
1264 	{
1265 	}
1266 
1267 	/* Public methods inherited from TestCase */
1268 	virtual tcu::TestNode::IterateResult iterate(void);
1269 
1270 private:
1271 	void checkError(glw::GLenum expected_error, const glw::GLchar* message, bool& test_result);
1272 };
1273 
1274 /** Implementation of test GLSLContantValues. Description follows:
1275  *
1276  * Test verifies values of the following symbols:
1277  *
1278  *     GL_ARB_enhanced_layouts,
1279  *     gl_MaxTransformFeedbackBuffers,
1280  *     gl_MaxTransformFeedbackInterleavedComponents.
1281  *
1282  * This test implements Texture algorithm. Test following code snippet:
1283  *
1284  *     if (1 != GL_ARB_enhanced_layouts)
1285  *     {
1286  *         result = 0;
1287  *     }
1288  *     else if (MAX_TRANSFORM_FEEDBACK_BUFFERS
1289  *         != gl_MaxTransformFeedbackBuffers)
1290  *     {
1291  *         result = 0;
1292  *     }
1293  *     else if (MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS
1294  *         != gl_MaxTransformFeedbackInterleavedComponents)
1295  *     {
1296  *         result = 0;
1297  *     }
1298  **/
1299 class GLSLContantValuesTest : public TextureTestBase
1300 {
1301 public:
1302 	GLSLContantValuesTest(deqp::Context& context);
~GLSLContantValuesTest()1303 	~GLSLContantValuesTest()
1304 	{
1305 	}
1306 
1307 protected:
1308 	virtual std::string getVerificationSnippet(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
1309 											   Utils::Shader::STAGES stage);
1310 
1311 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
1312 };
1313 
1314 /** Implementation of test GLSLContantImmutablity. Description follows:
1315  *
1316  * Test verifies that values of the following symbols cannot be changed in
1317  * shader:
1318  *
1319  *     GL_ARB_enhanced_layouts,
1320  *     gl_MaxTransformFeedbackBuffers,
1321  *     gl_MaxTransformFeedbackInterleavedComponents.
1322  *
1323  * Compile following code snippet:
1324  *
1325  *     CONSTANT = 3;
1326  *
1327  * It is expected that compilation will fail. Test each shader stage
1328  * separately. Test each constant separately.
1329  **/
1330 class GLSLContantImmutablityTest : public NegativeTestBase
1331 {
1332 public:
1333 	/* Public methods */
1334 	GLSLContantImmutablityTest(deqp::Context& context);
1335 
~GLSLContantImmutablityTest()1336 	virtual ~GLSLContantImmutablityTest()
1337 	{
1338 	}
1339 
1340 protected:
1341 	/* Methods to be implemented by child class */
1342 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
1343 
1344 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
1345 	virtual glw::GLuint getTestCaseNumber();
1346 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
1347 	virtual void testInit();
1348 
1349 private:
1350 	/* Private enums */
1351 	enum CONSTANTS
1352 	{
1353 		GL_ARB_ENHANCED_LAYOUTS,
1354 		GL_MAX_XFB,
1355 		GL_MAX_XFB_INT_COMP,
1356 
1357 		/* */
1358 		CONSTANTS_MAX,
1359 	};
1360 
1361 	/* Private types */
1362 	struct testCase
1363 	{
1364 		CONSTANTS			  m_constant;
1365 		Utils::Shader::STAGES m_stage;
1366 	};
1367 
1368 	/* Private methods */
1369 	const glw::GLchar* getConstantName(CONSTANTS constant);
1370 
1371 	/* Private fields */
1372 	std::vector<testCase> m_test_cases;
1373 };
1374 
1375 /** Implementation of test GLSLConstantIntegralExpression. Description follows:
1376  *
1377  * Check that following symbols can be used as integral constant expressions:
1378  *
1379  *     GL_ARB_enhanced_layouts,
1380  *     gl_MaxTransformFeedbackBuffers,
1381  *     gl_MaxTransformFeedbackInterleavedComponents.
1382  *
1383  * Test implement Texture algorithm. Test following code snippet:
1384  *
1385  *     uniform uint goku [GL_ARB_enhanced_layouts / GOKU_DIV];
1386  *     uniform uint gohan[gl_MaxTransformFeedbackBuffers / GOHAN_DIV];
1387  *     uniform uint goten[gl_MaxTransformFeedbackInterleavedComponents /
1388  *                         GOTEN_DIV];
1389  *
1390  *     for (i = 0; i < goku.length; ++i)
1391  *         goku_sum += goku[i];
1392  *
1393  *     for (i = 0; i < gohan.length; ++i)
1394  *         gohan_sum += gohan[i];
1395  *
1396  *     for (i = 0; i < goten.length; ++i)
1397  *         goten_sum += goten[i];
1398  *
1399  *     if ( (expected_goku_sum  == goku_sum)  &&
1400  *          (expected_gohan_sum == gohan_sum) &&
1401  *          (expected_goten_sum == goten_sum) )
1402  *         result = 1;
1403  *     else
1404  *         result = 0;
1405  *
1406  * Select DIV values so as array lengths are below 16.
1407  **/
1408 class GLSLConstantIntegralExpressionTest : public TextureTestBase
1409 {
1410 public:
1411 	/* Public methods */
1412 	GLSLConstantIntegralExpressionTest(deqp::Context& context);
1413 
~GLSLConstantIntegralExpressionTest()1414 	virtual ~GLSLConstantIntegralExpressionTest()
1415 	{
1416 	}
1417 
1418 protected:
1419 	/* Protected methods */
1420 	virtual void getProgramInterface(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
1421 									 Utils::VaryingPassthrough& varying_passthrough);
1422 
1423 	virtual std::string getVerificationSnippet(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
1424 											   Utils::Shader::STAGES stage);
1425 
1426 	virtual void prepareUniforms(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
1427 								 Utils::Program& program, Utils::Buffer& cs_buffer);
1428 
1429 	virtual void prepareUniforms(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
1430 								 Utils::Program& program, Utils::Buffer& fs_buffer, Utils::Buffer& gs_buffer,
1431 								 Utils::Buffer& tcs_buffer, Utils::Buffer& tes_buffer, Utils::Buffer& vs_buffer);
1432 
1433 private:
1434 	glw::GLint m_gohan_length;
1435 	glw::GLint m_goten_length;
1436 };
1437 
1438 /** Implementation of test UniformBlockMemberOffsetAndAlign. Description follows:
1439  *
1440  * Test verifies that:
1441  *     - offset and align qualifiers are respected for uniform block members,
1442  *     - align qualifier is ignored if value is too small,
1443  *     - align qualifier accepts values bigger than size of base type,
1444  *     - manual and automatic offsets and alignments can be mixed.
1445  *
1446  * This test implement Texture algorithm. Test following code snippet:
1447  *
1448  *     const int basic_size = sizeof(basic_type_of(type));
1449  *     const int type_size  = sizeof(type);
1450  *     const int type_align = roundUpToPowerOf2(type_size);
1451  *
1452  *     layout (std140, offset = 0) uniform Block {
1453  *         layout(align = 8 * basic_size)  type at_first_offset;
1454  *         layout(offset = type_size, align = basic_size / 2)
1455  *                                         type at_second_offset;
1456  *         layout(align = 2 * type_align)  type at_third_offset;
1457  *         layout(offset = 3 * type_align + type_size)
1458  *                                         type at_fourth_offset;
1459  *                                         type at_fifth_offset;
1460  *                                         type at_sixth_offset[2];
1461  *         layout(align = 8 * basic_size)  type at_eight_offset;
1462  *     };
1463  *
1464  *     if ( (at_first_offset  == at_eight_offset   ) &&
1465  *          (at_second_offset == at_sixth_offset[1]) &&
1466  *          (at_third_offset  == at_sixth_offset[0]) &&
1467  *          (at_fourth_offset == at_fifth_offset   ) )
1468  *         result = 1;
1469  *     else
1470  *         result = 0;
1471  *
1472  * Additionally inspect program to verify that all block members:
1473  * - are reported,
1474  * - have correct offsets.
1475  *
1476  * Test should be executed for all types.
1477  **/
1478 class UniformBlockMemberOffsetAndAlignTest : public TextureTestBase
1479 {
1480 public:
1481 	/* Public methods */
1482 	UniformBlockMemberOffsetAndAlignTest(deqp::Context& context);
1483 
~UniformBlockMemberOffsetAndAlignTest()1484 	virtual ~UniformBlockMemberOffsetAndAlignTest()
1485 	{
1486 	}
1487 
1488 protected:
1489 	/* Protected methods */
1490 	virtual void getProgramInterface(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
1491 									 Utils::VaryingPassthrough& varying_passthrough);
1492 
1493 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
1494 	virtual glw::GLuint getTestCaseNumber();
1495 
1496 	virtual std::string getVerificationSnippet(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
1497 											   Utils::Shader::STAGES stage);
1498 
1499 private:
1500 	std::vector<glw::GLubyte> m_data;
1501 };
1502 
1503 /** Implementation of test UniformBlockLayoutQualifierConflict. Description follows:
1504  *
1505  * Test verifies that offset and align can only be used on members of blocks
1506  * declared as std140.
1507  *
1508  * Test following code snippet with all shader stages:
1509  *
1510  *     layout(QUALIFIER) uniform Block {
1511  *         layout(offset = 16) vec4 boy;
1512  *         layout(align  = 48) vec4 man;
1513  *     };
1514  *
1515  * Test following block qualifiers and all types:
1516  *
1517  *     default - meaning not declared by shader
1518  *     std140,
1519  *     shared,
1520  *     packed.
1521  *
1522  * Qualifier std430 is not allowed for uniform blocks.
1523  *
1524  * Test expect that only case using std140 will compile and link successfully,
1525  * while the rest will fail to compile or link.
1526  **/
1527 class UniformBlockLayoutQualifierConflictTest : public NegativeTestBase
1528 {
1529 public:
1530 	/* Public methods */
1531 	UniformBlockLayoutQualifierConflictTest(deqp::Context& context);
1532 
~UniformBlockLayoutQualifierConflictTest()1533 	virtual ~UniformBlockLayoutQualifierConflictTest()
1534 	{
1535 	}
1536 
1537 protected:
1538 	/* Methods to be implemented by child class */
1539 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
1540 
1541 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
1542 	virtual glw::GLuint getTestCaseNumber();
1543 
1544 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
1545 	virtual bool isFailureExpected(glw::GLuint test_case_index);
1546 	virtual void testInit();
1547 
1548 private:
1549 	/* Private enums */
1550 	enum QUALIFIERS
1551 	{
1552 		DEFAULT,
1553 		STD140,
1554 		SHARED,
1555 		PACKED,
1556 
1557 		/* */
1558 		QUALIFIERS_MAX,
1559 	};
1560 
1561 	/* Private types */
1562 	struct testCase
1563 	{
1564 		QUALIFIERS			  m_qualifier;
1565 		Utils::Shader::STAGES m_stage;
1566 	};
1567 
1568 	/* Private methods */
1569 	const glw::GLchar* getQualifierName(QUALIFIERS qualifier);
1570 
1571 	/* Private fields */
1572 	std::vector<testCase> m_test_cases;
1573 };
1574 
1575 /** Implementation of test UniformBlockMemberInvalidOffsetAlignment. Description follows:
1576  *
1577  * Test verifies that offset alignment rules are enforced.
1578  *
1579  * Declare uniform block, which contains following member declaration:
1580  *
1581  *     layout(offset = X) type block_member
1582  *
1583  * Shader compilation is expected to fail for any X that is not a multiple of
1584  * the base alignment of type.
1585  * Test all offsets covering locations first and one before last:
1586  *
1587  *     <0, sizeof(type)>
1588  *     <MAX_UNIFORM_BLOCK_SIZE - 2 * sizeof(type),
1589  *         MAX_UNIFORM_BLOCK_SIZE - sizeof(type)>
1590  *
1591  * Test all shader stages. Test all types. Each case should be tested
1592  * separately.
1593  **/
1594 class UniformBlockMemberInvalidOffsetAlignmentTest : public NegativeTestBase
1595 {
1596 public:
1597 	/* Public methods */
1598 	UniformBlockMemberInvalidOffsetAlignmentTest(deqp::Context& context);
1599 
1600 	UniformBlockMemberInvalidOffsetAlignmentTest(deqp::Context& context, const glw::GLchar* name,
1601 												 const glw::GLchar* description);
1602 
~UniformBlockMemberInvalidOffsetAlignmentTest()1603 	virtual ~UniformBlockMemberInvalidOffsetAlignmentTest()
1604 	{
1605 	}
1606 
1607 protected:
1608 	/* Methods to be implemented by child class */
1609 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
1610 
1611 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
1612 	virtual glw::GLuint getTestCaseNumber();
1613 	virtual glw::GLint  getMaxBlockSize();
1614 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
1615 	virtual bool isFailureExpected(glw::GLuint test_case_index);
1616 	virtual bool isStageSupported(Utils::Shader::STAGES stage);
1617 	virtual void testInit();
1618 
1619 protected:
1620 	/* Protected types */
1621 	struct testCase
1622 	{
1623 		glw::GLuint			  m_offset;
1624 		bool				  m_should_fail;
1625 		Utils::Shader::STAGES m_stage;
1626 		Utils::Type			  m_type;
1627 	};
1628 
1629 	/* Protected fields */
1630 	std::vector<testCase> m_test_cases;
1631 };
1632 
1633 /** Implementation of test UniformBlockMemberOverlappingOffsets. Description follows:
1634  *
1635  * Test verifies that block members cannot overlap.
1636  *
1637  * Use following code snippet:
1638  *
1639  *     layout (std140) uniform Block {
1640  *         layout (offset = boy_offset) boy_type boy;
1641  *         layout (offset = man_offset) man_type man;
1642  *     };
1643  *
1644  * It is expected that overlapping members will cause compilation failure.
1645  *
1646  * There are three cases to test:
1647  *
1648  *     - when member is declared with the same offset as already declared
1649  *     member,
1650  *     - when member is declared with offset that lay in the middle of already
1651  *     declared member,
1652  *     - when member is declared with offset just before already declared
1653  *     member and there is not enough space.
1654  *
1655  * Test all shader stages. Test all types. Test cases separately.
1656  *
1657  * Note that not all type combinations let to test all three cases, e.g.
1658  * vec4 and float.
1659  **/
1660 class UniformBlockMemberOverlappingOffsetsTest : public NegativeTestBase
1661 {
1662 public:
1663 	/* Public methods */
1664 	UniformBlockMemberOverlappingOffsetsTest(deqp::Context& context);
1665 
1666 	UniformBlockMemberOverlappingOffsetsTest(deqp::Context& context, const glw::GLchar* name,
1667 											 const glw::GLchar* description);
1668 
~UniformBlockMemberOverlappingOffsetsTest()1669 	virtual ~UniformBlockMemberOverlappingOffsetsTest()
1670 	{
1671 	}
1672 
1673 protected:
1674 	/* Methods to be implemented by child class */
1675 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
1676 
1677 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
1678 	virtual glw::GLuint getTestCaseNumber();
1679 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
1680 	virtual bool isStageSupported(Utils::Shader::STAGES stage);
1681 	virtual void testInit();
1682 
1683 protected:
1684 	/* Protected types */
1685 	struct testCase
1686 	{
1687 		glw::GLuint			  m_boy_offset;
1688 		Utils::Type			  m_boy_type;
1689 		glw::GLuint			  m_man_offset;
1690 		Utils::Type			  m_man_type;
1691 		Utils::Shader::STAGES m_stage;
1692 	};
1693 
1694 	/* Protected methods */
1695 	glw::GLuint gcd(glw::GLuint a, glw::GLuint b);
1696 	glw::GLuint lcm(glw::GLuint a, glw::GLuint b);
1697 
1698 	/* Protected fields */
1699 	std::vector<testCase> m_test_cases;
1700 };
1701 
1702 /** Implementation of test UniformBlockMemberAlignNonPowerOf2. Description follows:
1703  *
1704  * Test verifies that align qualifier must use power of 2.
1705  *
1706  * Test following code snippet:
1707  *
1708  *     layout (std140, offset = 8) uniform Block {
1709  *         vec4 boy;
1710  *         layout (align = man_alignment) type man;
1711  *     };
1712  *
1713  * It is expected that compilation will fail whenever man_alignment is not
1714  * a power of 2.
1715  *
1716  * Test all alignment in range <0, sizeof(dmat4)>. Test all shader stages.
1717  * Test all types.
1718  **/
1719 class UniformBlockMemberAlignNonPowerOf2Test : public NegativeTestBase
1720 {
1721 public:
1722 	/* Public methods */
1723 	UniformBlockMemberAlignNonPowerOf2Test(deqp::Context& context);
1724 
1725 	UniformBlockMemberAlignNonPowerOf2Test(deqp::Context& context, const glw::GLchar* name,
1726 										   const glw::GLchar* description);
1727 
~UniformBlockMemberAlignNonPowerOf2Test()1728 	virtual ~UniformBlockMemberAlignNonPowerOf2Test()
1729 	{
1730 	}
1731 
1732 protected:
1733 	/* Methods to be implemented by child class */
1734 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
1735 
1736 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
1737 	virtual glw::GLuint getTestCaseNumber();
1738 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
1739 	virtual bool isFailureExpected(glw::GLuint test_case_index);
1740 	virtual bool isStageSupported(Utils::Shader::STAGES stage);
1741 	virtual void testInit();
1742 
1743 protected:
1744 	/* Protected types */
1745 	struct testCase
1746 	{
1747 		glw::GLuint			  m_alignment;
1748 		Utils::Type			  m_type;
1749 		bool				  m_should_fail;
1750 		Utils::Shader::STAGES m_stage;
1751 	};
1752 
1753 	/* Protected methods */
1754 	bool isPowerOf2(glw::GLuint val);
1755 
1756 	/* Protected fields */
1757 	std::vector<testCase> m_test_cases;
1758 };
1759 
1760 /** Implementation of test UniformBlockAlignment. Description follows:
1761  *
1762  * UniformBlockAlignment
1763  *
1764  *   Test verifies that align qualifier is applied to block members as specified.
1765  *
1766  *   This test implements Texture algorithm. Test following code snippet:
1767  *
1768  *       struct Data {
1769  *           vec4  vector;
1770  *           float scalar;
1771  *       };
1772  *
1773  *       layout (std140, offset = 8, align = 64) uniform Block {
1774  *                               vec4 first;
1775  *                               Data second;
1776  *                               Data third[2];
1777  *                               vec4 fourth[3];
1778  *           layout (align = 16) vec4 fifth[2];
1779  *                               Data sixth;
1780  *       };
1781  *
1782  *   Verify that all uniforms have correct values. Additionally inspect program
1783  *   to check that all offsets are as expected.
1784  **/
1785 class UniformBlockAlignmentTest : public TextureTestBase
1786 {
1787 public:
1788 	/* Public methods */
1789 	UniformBlockAlignmentTest(deqp::Context& context);
1790 
~UniformBlockAlignmentTest()1791 	virtual ~UniformBlockAlignmentTest()
1792 	{
1793 	}
1794 
1795 protected:
1796 	/* Protected methods */
1797 	virtual void getProgramInterface(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
1798 									 Utils::VaryingPassthrough& varying_passthrough);
1799 
1800 private:
1801 	std::vector<glw::GLubyte> m_data;
1802 };
1803 
1804 /** Implementation of test SSBMemberOffsetAndAlign. Description follows:
1805  *
1806  * Test verifies that:
1807  *     - offset and align qualifiers are respected for shader storage block
1808  *     members,
1809  *     - align qualifier is ignored if value is too small,
1810  *     - align qualifier accepts values bigger than size of base type,
1811  *     - manual and automatic offsets and alignments can be mixed.
1812  *
1813  * Modify UniformBlockMemberOffsetAndAlign to test shader storage block instead
1814  * of uniform block.
1815  **/
1816 class SSBMemberOffsetAndAlignTest : public TextureTestBase
1817 {
1818 public:
1819 	/* Public methods */
1820 	SSBMemberOffsetAndAlignTest(deqp::Context& context);
~SSBMemberOffsetAndAlignTest()1821 	virtual ~SSBMemberOffsetAndAlignTest()
1822 	{
1823 	}
1824 
1825 protected:
1826 	/* Protected methods */
1827 	virtual void getProgramInterface(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
1828 									 Utils::VaryingPassthrough& varying_passthrough);
1829 
1830 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
1831 	virtual glw::GLuint getTestCaseNumber();
1832 
1833 	virtual std::string getVerificationSnippet(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
1834 											   Utils::Shader::STAGES stage);
1835 
1836 	virtual bool isDrawRelevant(glw::GLuint test_case_index);
1837 
1838 private:
1839 	std::vector<glw::GLubyte> m_data;
1840 };
1841 
1842 /** Implementation of test SSBLayoutQualifierConflict. Description follows:
1843  *
1844  * Test verifies that offset and align can only be used on members of blocks
1845  * declared as std140 or std430.
1846  *
1847  * Modify UniformBlockMemberOffsetAndAlign to test shader storage block instead
1848  * of uniform block.
1849  *
1850  * Qualifier std430 is allowed for shader storage blocks, it should be included
1851  * in test. It is expected that std430 case will build successfully.
1852  **/
1853 class SSBLayoutQualifierConflictTest : public NegativeTestBase
1854 {
1855 public:
1856 	/* Public methods */
1857 	SSBLayoutQualifierConflictTest(deqp::Context& context);
1858 
~SSBLayoutQualifierConflictTest()1859 	virtual ~SSBLayoutQualifierConflictTest()
1860 	{
1861 	}
1862 
1863 protected:
1864 	/* Methods to be implemented by child class */
1865 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
1866 
1867 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
1868 	virtual glw::GLuint getTestCaseNumber();
1869 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
1870 	virtual bool isFailureExpected(glw::GLuint test_case_index);
1871 	virtual void testInit();
1872 
1873 private:
1874 	/* Private enums */
1875 	enum QUALIFIERS
1876 	{
1877 		DEFAULT,
1878 		STD140,
1879 		STD430,
1880 		SHARED,
1881 		PACKED,
1882 
1883 		/* */
1884 		QUALIFIERS_MAX,
1885 	};
1886 
1887 	/* Private types */
1888 	struct testCase
1889 	{
1890 		QUALIFIERS			  m_qualifier;
1891 		Utils::Shader::STAGES m_stage;
1892 	};
1893 
1894 	/* Private methods */
1895 	const glw::GLchar* getQualifierName(QUALIFIERS qualifier);
1896 	bool isStageSupported(Utils::Shader::STAGES stage);
1897 
1898 	/* Private fields */
1899 	std::vector<testCase> m_test_cases;
1900 };
1901 
1902 /** Implementation of test SSBMemberInvalidOffsetAlignment. Description follows:
1903  *
1904  * Test verifies that offset alignment rules are enforced.
1905  *
1906  * Modify UniformBlockMemberInvalidOffsetAlignment to test shader
1907  * storage block against MAX_SHADER_STORAGE_BLOCK_SIZE instead of
1908  * uniform block
1909  **/
1910 class SSBMemberInvalidOffsetAlignmentTest : public UniformBlockMemberInvalidOffsetAlignmentTest
1911 {
1912 public:
1913 	/* Public methods */
1914 	SSBMemberInvalidOffsetAlignmentTest(deqp::Context& context);
1915 
~SSBMemberInvalidOffsetAlignmentTest()1916 	virtual ~SSBMemberInvalidOffsetAlignmentTest()
1917 	{
1918 	}
1919 
1920 protected:
1921 	/* Methods to be implemented by child class */
1922 	virtual glw::GLint  getMaxBlockSize();
1923 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
1924 
1925 	virtual bool isStageSupported(Utils::Shader::STAGES stage);
1926 };
1927 
1928 /** Implementation of test SSBMemberOverlappingOffsets. Description follows:
1929  *
1930  * Test verifies that block members cannot overlap.
1931  *
1932  * Modify UniformBlockMemberOverlappingOffsets to test shader storage block
1933  * instead of uniform block.
1934  **/
1935 class SSBMemberOverlappingOffsetsTest : public UniformBlockMemberOverlappingOffsetsTest
1936 {
1937 public:
1938 	/* Public methods */
1939 	SSBMemberOverlappingOffsetsTest(deqp::Context& context);
~SSBMemberOverlappingOffsetsTest()1940 	virtual ~SSBMemberOverlappingOffsetsTest()
1941 	{
1942 	}
1943 
1944 protected:
1945 	/* Methods to be implemented by child class */
1946 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
1947 
1948 	virtual bool isStageSupported(Utils::Shader::STAGES stage);
1949 };
1950 
1951 /** Implementation of test SSBMemberAlignNonPowerOf2. Description follows:
1952  *
1953  * Test verifies that align qualifier must use power of 2.
1954  *
1955  * Modify UniformBlockMemberAlignNonPowerOf2 to test shader storage block
1956  * instead of uniform block.
1957  **/
1958 class SSBMemberAlignNonPowerOf2Test : public UniformBlockMemberAlignNonPowerOf2Test
1959 {
1960 public:
1961 	/* Public methods */
1962 	SSBMemberAlignNonPowerOf2Test(deqp::Context& context);
1963 
~SSBMemberAlignNonPowerOf2Test()1964 	virtual ~SSBMemberAlignNonPowerOf2Test()
1965 	{
1966 	}
1967 
1968 protected:
1969 	/* Methods to be implemented by child class */
1970 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
1971 
1972 	virtual bool isStageSupported(Utils::Shader::STAGES stage);
1973 };
1974 
1975 /** Implementation of test SSBAlignment. Description follows:
1976  *
1977  * Test verifies that align qualifier is applied to block members as specified.
1978  *
1979  * Modify UniformBlockAlignment to test shader storage block instead
1980  * of uniform block.
1981  **/
1982 class SSBAlignmentTest : public TextureTestBase
1983 {
1984 public:
1985 	/* Public methods */
1986 	SSBAlignmentTest(deqp::Context& context);
1987 
~SSBAlignmentTest()1988 	virtual ~SSBAlignmentTest()
1989 	{
1990 	}
1991 
1992 protected:
1993 	/* Protected methods */
1994 	virtual void getProgramInterface(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
1995 									 Utils::VaryingPassthrough& varying_passthrough);
1996 
1997 	virtual bool isDrawRelevant(glw::GLuint test_case_index);
1998 
1999 private:
2000 	std::vector<glw::GLubyte> m_data;
2001 };
2002 
2003 /** Implementation of test VaryingLocations. Description follows:
2004  *
2005  * Test verifies that "varying" locations are assigned as declared in shader.
2006  *
2007  * This test implements Texture algorithm. Use separate shader objects instead
2008  * of monolithic program. Test following code snippet:
2009  *
2010  *     layout(location = 0)           in  type input_at_first_location;
2011  *     layout(location = last_input)  in  type input_at_last_location;
2012  *     layout(location = 1)           out type output_at_first_location;
2013  *     layout(location = last_output) out type output_at_last_location;
2014  *
2015  *     output_at_first_location = input_at_first_location;
2016  *     output_at_last_location  = input_at_last_location;
2017  *
2018  *     if ( (EXPECTED_VALUE == input_at_first_location) &&
2019  *          (EXPECTED_VALUE == input_at_last_location)  )
2020  *     {
2021  *         result = 1;
2022  *     }
2023  *
2024  * Additionally inspect program to check that all locations are as expected.
2025  *
2026  * Test all types. Test all shader stages.
2027  **/
2028 class VaryingLocationsTest : public TextureTestBase
2029 {
2030 public:
2031 	VaryingLocationsTest(deqp::Context& context);
2032 
2033 	VaryingLocationsTest(deqp::Context& context, const glw::GLchar* test_name, const glw::GLchar* test_description);
2034 
~VaryingLocationsTest()2035 	~VaryingLocationsTest()
2036 	{
2037 	}
2038 
2039 protected:
2040 	/* Protected methods */
2041 	virtual void getProgramInterface(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
2042 									 Utils::VaryingPassthrough& varying_passthrough);
2043 
2044 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
2045 	virtual glw::GLuint getTestCaseNumber();
2046 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
2047 	virtual bool useMonolithicProgram(glw::GLuint test_case_index);
2048 
2049 	/* To be implemented by children */
2050 	virtual void prepareShaderStage(Utils::Shader::STAGES stage, const Utils::Type& type,
2051 									Utils::ProgramInterface&   program_interface,
2052 									Utils::VaryingPassthrough& varying_passthrough);
2053 
2054 	/* Protected methods */
2055 	std::string prepareGlobals(glw::GLint last_in_loc, glw::GLint last_out_loc);
2056 
2057 	/* Protected fields */
2058 	std::vector<glw::GLubyte> m_first_data;
2059 	std::vector<glw::GLubyte> m_last_data;
2060 };
2061 
2062 /** Implementation of test VertexAttribLocations. Description follows:
2063  *
2064  * Test verifies that drawing operations provide vertex attributes at expected
2065  * locations.
2066  *
2067  * This test implements Texture algorithm. Use separate shader objects instead
2068  * of monolithic program. Tessellation stages are not necessary and can be
2069  * omitted. Test following code snippet:
2070  *
2071  *     layout (location = 2) in uint vertex_index;
2072  *     layout (location = 5) in uint instance_index;
2073  *
2074  *     if ( (gl_VertexID   == vertex_index)   &&
2075  *          (gl_InstanceID == instance_index) )
2076  *     {
2077  *         result = 1;
2078  *     }
2079  *
2080  * Test following Draw* operations:
2081  *     - DrawArrays,
2082  *     - DrawArraysInstanced,
2083  *     - DrawElements,
2084  *     - DrawElementsBaseVertex,
2085  *     - DrawElementsInstanced,
2086  *     - DrawElementsInstancedBaseInstance,
2087  *     - DrawElementsInstancedBaseVertex,
2088  *     - DrawElementsInstancedBaseVertexBaseInstance.
2089  *
2090  * Number of drawn instances should be equal 4. base_vertex parameter should be
2091  * set to 4. base_instance should be set to 2.
2092  *
2093  * Values provided for "vertex_index" should match index of vertex. Values
2094  * provided for "instance_index" should match index of instance
2095  * (use VertexAttribDivisor).
2096  **/
2097 class VertexAttribLocationsTest : public TextureTestBase
2098 {
2099 public:
2100 	VertexAttribLocationsTest(deqp::Context& context);
2101 
~VertexAttribLocationsTest()2102 	~VertexAttribLocationsTest()
2103 	{
2104 	}
2105 
2106 protected:
2107 	/* Protected methods */
2108 	virtual void executeDrawCall(glw::GLuint test_case_index);
2109 
2110 	virtual void getProgramInterface(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
2111 									 Utils::VaryingPassthrough& varying_passthrough);
2112 
2113 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
2114 	virtual glw::GLuint getTestCaseNumber();
2115 
2116 	virtual std::string getVerificationSnippet(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
2117 											   Utils::Shader::STAGES stage);
2118 
2119 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
2120 
2121 	virtual void prepareAttributes(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
2122 								   Utils::Buffer& buffer, Utils::VertexArray& vao);
2123 
2124 	virtual bool useMonolithicProgram(glw::GLuint test_case_index);
2125 
2126 private:
2127 	/* Private enums */
2128 	enum TESTCASES
2129 	{
2130 		DRAWARRAYS,
2131 		DRAWARRAYSINSTANCED,
2132 		DRAWELEMENTS,
2133 		DRAWELEMENTSBASEVERTEX,
2134 		DRAWELEMENTSINSTANCED,
2135 		DRAWELEMENTSINSTANCEDBASEINSTANCE,
2136 		DRAWELEMENTSINSTANCEDBASEVERTEX,
2137 		DRAWELEMENTSINSTANCEDBASEVERTEXBASEINSTANCE,
2138 
2139 		/* */
2140 		TESTCASES_MAX
2141 	};
2142 
2143 	/* Private constants */
2144 	static const glw::GLuint m_base_vertex;
2145 	static const glw::GLuint m_base_instance;
2146 	static const glw::GLuint m_loc_vertex;
2147 	static const glw::GLuint m_loc_instance;
2148 	static const glw::GLuint m_n_instances;
2149 };
2150 
2151 /** Implementation of test VaryingArrayLocations. Description follows:
2152  *
2153  * VaryingArrayLocations
2154  *
2155  *   Test verifies that locations of arrays of "varying" are assigned as declared
2156  *   in shader.
2157  *
2158  *   This test implements Texture algorithm. Use separate shader objects instead
2159  *   of monolithic program. Test following code snippet:
2160  *
2161  *       layout(location = 0)           in  type in_at_first_loc[FIRST_LENGTH];
2162  *       layout(location = last_input)  in  type in_at_last_loc[LAST_LENGTH];
2163  *       layout(location = 1)           out type out_at_first_loc[FIRST_LENGTH];
2164  *       layout(location = last_output) out type out_at_last_loc[LAST_LENGTH];
2165  *
2166  *       for (uint i = 0u; i < in_at_first_loc.length(); ++i)
2167  *       {
2168  *           out_at_first_loc[i] = in_at_first_loc[i];
2169  *
2170  *           if (EXPECTED_VALUE[i] != in_at_first_loc[i])
2171  *           {
2172  *               result = 0;
2173  *           }
2174  *       }
2175  *
2176  *       for (uint i = 0u; i < in_at_last_loc.length(); ++i)
2177  *       {
2178  *           out_at_last_loc[i] = in_at_last_loc[i];
2179  *
2180  *           if (EXPECTED_VALUE[i] != in_at_last_loc[i])
2181  *           {
2182  *               result = 0;
2183  *           }
2184  *       }
2185  *
2186  *   FIRST_LENGTH and LAST_LENGTH values should be selected so as not to exceed
2187  *   limits.
2188  *
2189  *   Additionally inspect program to check that all locations are as expected.
2190  *
2191  *   Test all types. Test all shader stages.
2192  **/
2193 class VaryingArrayLocationsTest : public VaryingLocationsTest
2194 {
2195 public:
2196 	VaryingArrayLocationsTest(deqp::Context& context);
2197 
~VaryingArrayLocationsTest()2198 	~VaryingArrayLocationsTest()
2199 	{
2200 	}
2201 
2202 protected:
2203 	/* Protected methods */
2204 	virtual void prepareShaderStage(Utils::Shader::STAGES stage, const Utils::Type& type,
2205 									Utils::ProgramInterface&   program_interface,
2206 									Utils::VaryingPassthrough& varying_passthrough);
2207 };
2208 
2209 /** Implementation of test VaryingStructureLocations. Description follows:
2210  *
2211  * Test verifies that structures locations are as expected.
2212  *
2213  * This test implements Texture algorithm. Use separate shader objects instead
2214  * of monolithic program. Test following code snippet:
2215  *
2216  *     struct Data
2217  *     {
2218  *         type single;
2219  *         type array[ARRAY_LENGTH];
2220  *     };
2221  *
2222  *     layout (location = INPUT_LOCATION)  in  Data input[VARYING_LENGTH];
2223  *     layout (location = OUTPUT_LOCATION) out Data output[VARYING_LENGTH];
2224  *
2225  *     if ( (EXPECTED_VALUE == input[0].single)         &&
2226  *          (EXPECTED_VALUE == input[0].array[0])       &&
2227  *          (EXPECTED_VALUE == input[0].array[last])    &&
2228  *          (EXPECTED_VALUE == input[last].single)      &&
2229  *          (EXPECTED_VALUE == input[last].array[0])    &&
2230  *          (EXPECTED_VALUE == input[last].array[last]) )
2231  *     {
2232  *         result = 1;
2233  *     }
2234  *
2235  *     output[0].single         = input[0].single;
2236  *     output[0].array[0]       = input[0].array[0];
2237  *     output[0].array[last]    = input[0].array[last];
2238  *     output[last].single      = input[last].single;
2239  *     output[last].array[0]    = input[last].array[0];
2240  *     output[last].array[last] = input[last].array[last];
2241  *
2242  * Select array lengths and locations so as no limits are exceeded.
2243  **/
2244 
2245 class VaryingStructureLocationsTest : public TextureTestBase
2246 {
2247 public:
2248 	VaryingStructureLocationsTest(deqp::Context& context);
2249 
~VaryingStructureLocationsTest()2250 	~VaryingStructureLocationsTest()
2251 	{
2252 	}
2253 
2254 protected:
2255 	/* Protected methods */
2256 	virtual std::string getPassSnippet(glw::GLuint test_case_index, Utils::VaryingPassthrough& varying_passthrough,
2257 									   Utils::Shader::STAGES stage);
2258 
2259 	virtual void getProgramInterface(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
2260 									 Utils::VaryingPassthrough& varying_passthrough);
2261 
2262 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
2263 	virtual glw::GLuint getTestCaseNumber();
2264 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
2265 	virtual bool useMonolithicProgram(glw::GLuint test_case_index);
2266 
2267 	/* Protected fields */
2268 	std::vector<glw::GLubyte> m_single_data;
2269 	std::vector<glw::GLubyte> m_array_data;
2270 	std::vector<glw::GLubyte> m_data;
2271 };
2272 
2273 /** Implementation of test VaryingStructureMemberLocation. Description follows:
2274  *
2275  * Test verifies that it is not allowed to declare structure member at specific
2276  * location.
2277  *
2278  * Test following code snippet:
2279  *
2280  *     struct Data
2281  *     {
2282  *         vec4 gohan;
2283  *         layout (location = LOCATION) vec4 goten;
2284  *     }
2285  *
2286  *     in Data goku;
2287  *
2288  * Select LOCATION so as not to exceed limits. Test all shader stages. Test
2289  * both in and out varyings.
2290  *
2291  * It is expected that compilation will fail.
2292  **/
2293 class VaryingStructureMemberLocationTest : public NegativeTestBase
2294 {
2295 public:
2296 	VaryingStructureMemberLocationTest(deqp::Context& context);
2297 
~VaryingStructureMemberLocationTest()2298 	~VaryingStructureMemberLocationTest()
2299 	{
2300 	}
2301 
2302 protected:
2303 	/* Methods to be implemented by child class */
2304 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
2305 
2306 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
2307 	virtual glw::GLuint getTestCaseNumber();
2308 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
2309 	virtual void testInit();
2310 
2311 private:
2312 	/* Private types */
2313 	struct testCase
2314 	{
2315 		bool				  m_is_input;
2316 		Utils::Shader::STAGES m_stage;
2317 	};
2318 
2319 	/* Private fields */
2320 	std::vector<testCase> m_test_cases;
2321 };
2322 
2323 /** Implementation of test VaryingBlockLocations. Description follows:
2324  *
2325  * Test verifies that "block varyings" locations are as expected.
2326  *
2327  * This test implements Texture algorithm. Use separate shader objects instead
2328  * of monolithic program. Test following code snippet:
2329  *
2330  *     layout (location = GOKU_LOCATION) in Goku
2331  *     {
2332  *                                            vec4 gohan;
2333  *         layout (location = GOTEN_LOCATION) vec4 goten;
2334  *                                            vec4 chichi;
2335  *     };
2336  *
2337  *     layout (location = VEGETA_LOCATION) out Vegeta
2338  *     {
2339  *                                          vec4 trunks;
2340  *         layout (location = BRA_LOCATION) vec4 bra;
2341  *                                          vec4 bulma;
2342  *     };
2343  *
2344  *     if ( (EXPECTED_VALUE == gohan) &&
2345  *          (EXPECTED_VALUE == goten) &&
2346  *          (EXPECTED_VALUE == chichi) )
2347  *     {
2348  *         result = 1;
2349  *     }
2350  *
2351  *     trunks = gohan;
2352  *     bra    = goten;
2353  *     bulma  = chichi;
2354  *
2355  * Select all locations so as not to cause any conflicts or exceed limits.
2356  **/
2357 class VaryingBlockLocationsTest : public TextureTestBase
2358 {
2359 public:
2360 	VaryingBlockLocationsTest(deqp::Context& context);
~VaryingBlockLocationsTest()2361 	~VaryingBlockLocationsTest()
2362 	{
2363 	}
2364 
2365 protected:
2366 	/* Protected methods */
2367 	virtual std::string getPassSnippet(glw::GLuint test_case_index, Utils::VaryingPassthrough& varying_passthrough,
2368 									   Utils::Shader::STAGES stage);
2369 
2370 	virtual void getProgramInterface(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
2371 									 Utils::VaryingPassthrough& varying_passthrough);
2372 
2373 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
2374 	virtual bool useMonolithicProgram(glw::GLuint test_case_index);
2375 
2376 	/* Protected fields */
2377 	std::vector<glw::GLubyte> m_third_data;
2378 	std::vector<glw::GLubyte> m_fourth_data;
2379 	std::vector<glw::GLubyte> m_fifth_data;
2380 	std::vector<glw::GLubyte> m_data;
2381 };
2382 
2383 /** Implementation of test VaryingBlockMemberLocations. Description follows:
2384  *
2385  * Test verifies that it is a compilation error to declare some of block
2386  * members with location qualifier, but not all, when there is no "block level"
2387  * location qualifier.
2388  *
2389  * Test following code snippets:
2390  *
2391  *     in Goku
2392  *     {
2393  *         vec4 gohan;
2394  *         layout (location = GOTEN_LOCATION) vec4 goten;
2395  *         vec4 chichi;
2396  *     };
2397  *
2398  * ,
2399  *
2400  *     in Goku
2401  *     {
2402  *         layout (location = GOHAN_LOCATION)  vec4 gohan;
2403  *         layout (location = GOTEN_LOCATION)  vec4 goten;
2404  *         layout (location = CHICHI_LOCATION) vec4 chichi;
2405  *     };
2406  *
2407  * Select all locations so as not to exceed any limits.
2408  *
2409  * It is expected that compilation of first snippet will fail. Compilation of
2410  * second snippet should be successful.
2411  *
2412  * Test all shader stages. Test both in and out blocks.
2413  **/
2414 class VaryingBlockMemberLocationsTest : public NegativeTestBase
2415 {
2416 public:
2417 	/* Public methods */
2418 	VaryingBlockMemberLocationsTest(deqp::Context& context);
2419 
~VaryingBlockMemberLocationsTest()2420 	virtual ~VaryingBlockMemberLocationsTest()
2421 	{
2422 	}
2423 
2424 protected:
2425 	/* Methods to be implemented by child class */
2426 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
2427 
2428 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
2429 	virtual glw::GLuint getTestCaseNumber();
2430 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
2431 	virtual bool isFailureExpected(glw::GLuint test_case_index);
2432 	virtual void testInit();
2433 
2434 private:
2435 	/* Private types */
2436 	struct testCase
2437 	{
2438 		bool				  m_is_input;
2439 		bool				  m_qualify_all;
2440 		Utils::Shader::STAGES m_stage;
2441 	};
2442 
2443 	/* Private fields */
2444 	std::vector<testCase> m_test_cases;
2445 };
2446 
2447 /** Implementation of test VaryingBlockAutomaticMemberLocations. Description follows:
2448  *
2449  * Test verifies that compiler will assign subsequent locations to block
2450  * members.
2451  *
2452  * Test following code snippet:
2453  *
2454  *     layout (location = 2) in DBZ
2455  *     {
2456  *         vec4 goku;                         // 2
2457  *         vec4 gohan[GOHAN_LENGTH];          // 3
2458  *         vec4 goten;                        // 3 + GOHAN_LENGTH
2459  *         layout (location = 1) vec4 chichi; // 1
2460  *         vec4 pan;                          // 2; ERROR location 2 used twice
2461  *     };
2462  *
2463  * Test all shader stages. Test both in and out blocks.
2464  *
2465  * It is expected that build process will fail.
2466  **/
2467 class VaryingBlockAutomaticMemberLocationsTest : public NegativeTestBase
2468 {
2469 public:
2470 	/* Public methods */
2471 	VaryingBlockAutomaticMemberLocationsTest(deqp::Context& context);
2472 
~VaryingBlockAutomaticMemberLocationsTest()2473 	virtual ~VaryingBlockAutomaticMemberLocationsTest()
2474 	{
2475 	}
2476 
2477 protected:
2478 	/* Methods to be implemented by child class */
2479 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
2480 
2481 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
2482 	virtual glw::GLuint getTestCaseNumber();
2483 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
2484 	virtual void testInit();
2485 
2486 private:
2487 	/* Private types */
2488 	struct testCase
2489 	{
2490 		bool				  m_is_input;
2491 		Utils::Shader::STAGES m_stage;
2492 	};
2493 
2494 	/* Private fields */
2495 	std::vector<testCase> m_test_cases;
2496 };
2497 
2498 /** Implementation of test VaryingLocationLimit. Description follows:
2499  *
2500  * Test verifies that "location" qualifier cannot exceed limits.
2501  *
2502  * Test following code snippet:
2503  *
2504  *     layout (location = LAST + 1) in type goku;
2505  *
2506  * LAST should be set to index of last available location.
2507  *
2508  * Test all types. Test all shader stages. Test both in and out varyings.
2509  *
2510  * It is expected that shader compilation will fail.
2511  **/
2512 class VaryingLocationLimitTest : public NegativeTestBase
2513 {
2514 public:
2515 	/* Public methods */
2516 	VaryingLocationLimitTest(deqp::Context& context);
2517 
~VaryingLocationLimitTest()2518 	virtual ~VaryingLocationLimitTest()
2519 	{
2520 	}
2521 
2522 protected:
2523 	/* Methods to be implemented by child class */
2524 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
2525 
2526 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
2527 	virtual glw::GLuint getTestCaseNumber();
2528 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
2529 	virtual void testInit();
2530 
2531 private:
2532 	/* Private types */
2533 	struct testCase
2534 	{
2535 		bool				  m_is_input;
2536 		Utils::Type			  m_type;
2537 		Utils::Shader::STAGES m_stage;
2538 	};
2539 
2540 	/* Private fields */
2541 	std::vector<testCase> m_test_cases;
2542 };
2543 
2544 /** Implementation of test VaryingComponents. Description follows:
2545  *
2546  * VaryingComponents
2547  *
2548  *   Test verifies that "varying" can be assigned to specific components.
2549  *
2550  *   Modify VaryingLocations to test all possible combinations of components
2551  *   layout:
2552  *       - gvec4
2553  *       - scalar, gvec3
2554  *       - gvec3, scalar
2555  *       - gvec2, gvec2
2556  *       - gvec2, scalar, scalar
2557  *       - scalar, gvec2, scalar
2558  *       - scalar, scalar, gvec2
2559  *       - scalar, scalar, scalar, scalar.
2560  *
2561  *   Additionally inspect program to check that all locations and components are
2562  *   as expected.
2563  **/
2564 class VaryingComponentsTest : public VaryingLocationsTest
2565 {
2566 public:
2567 	VaryingComponentsTest(deqp::Context& context);
2568 
2569 	VaryingComponentsTest(deqp::Context& context, const glw::GLchar* test_name, const glw::GLchar* test_description);
2570 
~VaryingComponentsTest()2571 	~VaryingComponentsTest()
2572 	{
2573 	}
2574 
2575 protected:
2576 	/* Protected methods */
2577 	virtual void getProgramInterface(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
2578 									 Utils::VaryingPassthrough& varying_passthrough);
2579 
2580 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
2581 	virtual glw::GLuint getTestCaseNumber();
2582 	virtual void		testInit();
2583 	virtual bool useComponentQualifier(glw::GLuint test_case_index);
2584 
2585 	/* To be implemented by children */
2586 	virtual glw::GLuint getArrayLength();
2587 
2588 private:
2589 	/* Private enums */
2590 	enum COMPONENTS_LAYOUT
2591 	{
2592 		GVEC4,
2593 		SCALAR_GVEC3,
2594 		GVEC3_SCALAR,
2595 		GVEC2_GVEC2,
2596 		GVEC2_SCALAR_SCALAR,
2597 		SCALAR_GVEC2_SCALAR,
2598 		SCALAR_SCALAR_GVEC2,
2599 		SCALAR_SCALAR_SCALAR_SCALAR,
2600 	};
2601 
2602 	/* Private struct */
2603 	struct descriptor
2604 	{
2605 		void assign(glw::GLint component, const glw::GLchar* component_str, glw::GLint location,
2606 					const glw::GLchar* location_str, glw::GLuint n_rows, const glw::GLchar* name);
2607 
2608 		glw::GLint		   m_component;
2609 		const glw::GLchar* m_component_str;
2610 		glw::GLint		   m_location;
2611 		const glw::GLchar* m_location_str;
2612 		glw::GLuint		   m_n_rows;
2613 		const glw::GLchar* m_name;
2614 	};
2615 
2616 	struct testCase
2617 	{
2618 		testCase(COMPONENTS_LAYOUT layout, Utils::Type::TYPES type);
2619 
2620 		COMPONENTS_LAYOUT  m_layout;
2621 		Utils::Type::TYPES m_type;
2622 	};
2623 
2624 	/* Private routines */
2625 	std::string prepareGlobals(glw::GLuint last_in_location, glw::GLuint last_out_location);
2626 
2627 	std::string prepareName(const glw::GLchar* name, glw::GLint location, glw::GLint component,
2628 							Utils::Shader::STAGES stage, Utils::Variable::STORAGE storage);
2629 
2630 	std::string prepareQualifiers(const glw::GLchar* location, const glw::GLchar* component,
2631 								  const glw::GLchar* interpolation);
2632 
2633 	using VaryingLocationsTest::prepareShaderStage;
2634 
2635 	void prepareShaderStage(Utils::Shader::STAGES stage, const Utils::Type& vector_type,
2636 							Utils::ProgramInterface& program_interface, const testCase& test_case,
2637 							Utils::VaryingPassthrough& varying_passthrough);
2638 
2639 	Utils::Variable* prepareVarying(const Utils::Type& basic_type, const descriptor& desc,
2640 									const glw::GLchar* interpolation, Utils::ShaderInterface& si,
2641 									Utils::Shader::STAGES stage, Utils::Variable::STORAGE storage);
2642 
2643 	/* Private fields */
2644 	std::vector<testCase>	 m_test_cases;
2645 	std::vector<glw::GLubyte> m_data;
2646 };
2647 
2648 /** Implementation of test VaryingArrayComponents. Description follows:
2649  *
2650  * Test verifies that arrays of "varyings" can be assigned to specific
2651  * components.
2652  *
2653  * Modify VaryingComponents similarly to VaryingArrayLocations.
2654  **/
2655 class VaryingArrayComponentsTest : public VaryingComponentsTest
2656 {
2657 public:
2658 	VaryingArrayComponentsTest(deqp::Context& context);
2659 
~VaryingArrayComponentsTest()2660 	~VaryingArrayComponentsTest()
2661 	{
2662 	}
2663 
2664 protected:
2665 	/* Protected methods */
2666 	virtual glw::GLuint getArrayLength();
2667 };
2668 
2669 /** Implementation of test VaryingExceedingComponents. Description follows:
2670  *
2671  * Test verifies that it is not allowed to exceed components.
2672  *
2673  * Test following code snippets:
2674  *
2675  *     layout (location = 1, component = COMPONENT) in type gohan;
2676  *
2677  * and
2678  *
2679  *     layout (location = 1, component = COMPONENT) in type gohan[LENGTH];
2680  *
2681  * Select COMPONENT so as to exceed space available at location, eg. 2 for
2682  * vec4. Select array length so as to not exceed limits of available locations.
2683  *
2684  * Test all types. Test all shader stages. Test both in and out varyings.
2685  *
2686  * It is expected that build process will fail.
2687  **/
2688 class VaryingExceedingComponentsTest : public NegativeTestBase
2689 {
2690 public:
2691 	/* Public methods */
2692 	VaryingExceedingComponentsTest(deqp::Context& context);
2693 
~VaryingExceedingComponentsTest()2694 	virtual ~VaryingExceedingComponentsTest()
2695 	{
2696 	}
2697 
2698 protected:
2699 	/* Methods to be implemented by child class */
2700 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
2701 
2702 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
2703 	virtual glw::GLuint getTestCaseNumber();
2704 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
2705 	virtual void testInit();
2706 
2707 private:
2708 	/* Private types */
2709 	struct testCase
2710 	{
2711 		glw::GLuint			  m_component;
2712 		bool				  m_is_input;
2713 		bool				  m_is_array;
2714 		Utils::Shader::STAGES m_stage;
2715 		Utils::Type			  m_type;
2716 	};
2717 
2718 	/* Private fields */
2719 	std::vector<testCase> m_test_cases;
2720 };
2721 
2722 /** Implementation of test VaryingComponentWithoutLocation. Description follows:
2723  *
2724  * Test verifies that "component" qualifier cannot be used without "location"
2725  * qualifier.
2726  *
2727  * Test following code snippet:
2728  *
2729  *     layout (component = COMPONENT) in type goku;
2730  *
2731  * Test all types. Test all valid COMPONENT values. Test all shader stages.
2732  * Test both in and out varyings.
2733  *
2734  * It is expected that shader compilation will fail.
2735  **/
2736 class VaryingComponentWithoutLocationTest : public NegativeTestBase
2737 {
2738 public:
2739 	/* Public methods */
2740 	VaryingComponentWithoutLocationTest(deqp::Context& context);
2741 
~VaryingComponentWithoutLocationTest()2742 	virtual ~VaryingComponentWithoutLocationTest()
2743 	{
2744 	}
2745 
2746 protected:
2747 	/* Methods to be implemented by child class */
2748 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
2749 
2750 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
2751 	virtual glw::GLuint getTestCaseNumber();
2752 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
2753 	virtual void testInit();
2754 
2755 private:
2756 	/* Private types */
2757 	struct testCase
2758 	{
2759 		glw::GLuint			  m_component;
2760 		bool				  m_is_input;
2761 		Utils::Shader::STAGES m_stage;
2762 		Utils::Type			  m_type;
2763 	};
2764 
2765 	/* Private fields */
2766 	std::vector<testCase> m_test_cases;
2767 };
2768 
2769 /** Implementation of test VaryingComponentOfInvalidType. Description follows:
2770  *
2771  * Test verifies that it is not allowed to declare matrix, struct, block and
2772  * array of those at specific component.
2773  *
2774  * Test following code snippets:
2775  *
2776  *     layout (location = 0, component = COMPONENT) in matrix_type varying;
2777  *
2778  * ,
2779  *
2780  *     layout (location = 0, component = COMPONENT)
2781  *         in matrix_type varying[LENGTH];
2782  *
2783  * ,
2784  *
2785  *     layout (location = 0, component = COMPONENT) in Block
2786  *     {
2787  *         type member;
2788  *     };
2789  *
2790  * ,
2791  *
2792  *     layout (location = 0, component = COMPONENT) in Block
2793  *     {
2794  *         type member;
2795  *     } block[LENGTH];
2796  *
2797  * ,
2798  *
2799  *     struct Data
2800  *     {
2801  *         type member;
2802  *     };
2803  *
2804  *     layout (location = 0, component = COMPONENT) in Data varying;
2805  *
2806  * and
2807  *
2808  *     struct Data
2809  *     {
2810  *         type member;
2811  *     };
2812  *
2813  *     layout (location = 0, component = COMPONENT) in Data varying[LENGTH];
2814  *
2815  * Test all types. Test all shader stages. Test both in and out varyings.
2816  *
2817  * It is expected that build process will fail.
2818  **/
2819 class VaryingComponentOfInvalidTypeTest : public NegativeTestBase
2820 {
2821 public:
2822 	/* Public methods */
2823 	VaryingComponentOfInvalidTypeTest(deqp::Context& context);
2824 
~VaryingComponentOfInvalidTypeTest()2825 	virtual ~VaryingComponentOfInvalidTypeTest()
2826 	{
2827 	}
2828 
2829 protected:
2830 	/* Methods to be implemented by child class */
2831 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
2832 
2833 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
2834 	virtual glw::GLuint getTestCaseNumber();
2835 
2836 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
2837 	virtual void testInit();
2838 
2839 private:
2840 	/* Private enums */
2841 	enum CASES
2842 	{
2843 		MATRIX = 0,
2844 		BLOCK,
2845 		STRUCT,
2846 
2847 		/* */
2848 		MAX_CASES
2849 	};
2850 
2851 	/* Private types */
2852 	struct testCase
2853 	{
2854 		CASES				  m_case;
2855 		glw::GLuint			  m_component;
2856 		bool				  m_is_array;
2857 		bool				  m_is_input;
2858 		Utils::Shader::STAGES m_stage;
2859 		Utils::Type			  m_type;
2860 	};
2861 
2862 	/* Private fields */
2863 	std::vector<testCase> m_test_cases;
2864 };
2865 
2866 /** Implementation of test InputComponentAliasing. Description follows:
2867  *
2868  * Test verifies that component aliasing cause compilation or linking error.
2869  *
2870  * Test following code snippet:
2871  *
2872  *     layout (location = 1, component = GOHAN_COMPONENT) in type gohan;
2873  *     layout (location = 1, component = GOTEN_COMPONENT) in type goten;
2874  *
2875  *     if (EXPECTED_VALUE == gohan)
2876  *     {
2877  *         result = 1;
2878  *     }
2879  *
2880  * Test all components combinations that cause aliasing. Test all types. Test
2881  * all shader stages. It is expected that build process will fail.
2882  *
2883  * Vertex shader allows component aliasing on input as long as only one of the
2884  * attributes is used in each execution path. Test vertex shader stage with two
2885  * variants:
2886  *     - first as presented above,
2887  *     - second, where "result = 1;" is replaced with "result = goten;".
2888  * In first case build process should succeed, in the second case build process
2889  * should fail.
2890  **/
2891 class InputComponentAliasingTest : public NegativeTestBase
2892 {
2893 public:
2894 	/* Public methods */
2895 	InputComponentAliasingTest(deqp::Context& context);
2896 
~InputComponentAliasingTest()2897 	virtual ~InputComponentAliasingTest()
2898 	{
2899 	}
2900 
2901 protected:
2902 	/* Methods to be implemented by child class */
2903 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
2904 
2905 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
2906 	virtual glw::GLuint getTestCaseNumber();
2907 
2908 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
2909 	virtual bool isFailureExpected(glw::GLuint test_case_index);
2910 	virtual void testInit();
2911 
2912 private:
2913 	/* Private types */
2914 	struct testCase
2915 	{
2916 		glw::GLuint			  m_component_gohan;
2917 		glw::GLuint			  m_component_goten;
2918 		Utils::Shader::STAGES m_stage;
2919 		Utils::Type			  m_type;
2920 	};
2921 
2922 	/* Private fields */
2923 	std::vector<testCase> m_test_cases;
2924 };
2925 
2926 /** Implementation of test OutputComponentAliasing. Description follows:
2927  *
2928  * Test verifies that component aliasing cause compilation or linking error.
2929  *
2930  * Test following code snippet:
2931  *
2932  *     layout (location = 1, component = GOHAN_COMPONENT) out type gohan;
2933  *     layout (location = 1, component = GOTEN_COMPONENT) out type goten;
2934  *
2935  *     gohan = GOHAN_VALUE;
2936  *     goten = GOTEN_VALUE;
2937  *
2938  * Test all components combinations that cause aliasing. Test all types. Test
2939  * all shader stages. It is expected that build process will fail.
2940  **/
2941 class OutputComponentAliasingTest : public NegativeTestBase
2942 {
2943 public:
2944 	/* Public methods */
2945 	OutputComponentAliasingTest(deqp::Context& context);
2946 
~OutputComponentAliasingTest()2947 	virtual ~OutputComponentAliasingTest()
2948 	{
2949 	}
2950 
2951 protected:
2952 	/* Methods to be implemented by child class */
2953 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
2954 
2955 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
2956 	virtual glw::GLuint getTestCaseNumber();
2957 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
2958 	virtual void testInit();
2959 
2960 private:
2961 	/* Private types */
2962 	struct testCase
2963 	{
2964 		glw::GLuint			  m_component_gohan;
2965 		glw::GLuint			  m_component_goten;
2966 		Utils::Shader::STAGES m_stage;
2967 		Utils::Type			  m_type;
2968 	};
2969 
2970 	/* Private fields */
2971 	std::vector<testCase> m_test_cases;
2972 };
2973 
2974 /** Implementation of test VaryingLocationAliasingWithMixedTypes. Description follows:
2975  *
2976  * Test verifies that it is not allowed to mix integer and float base types at
2977  * aliased location.
2978  *
2979  * Test following code snippet:
2980  *
2981  *     layout (location = 1, component = GOHAN_COMPONENT) in gohan_type gohan;
2982  *     layout (location = 1, component = GOTEN_COMPONENT) in goten_type goten;
2983  *
2984  * Test all components combinations that do not cause component aliasing. Test
2985  * all types combinations that cause float/integer conflict. Test all shader
2986  * stages. Test both in and out varyings.
2987  *
2988  * It is expected that build process will fail.
2989  **/
2990 class VaryingLocationAliasingWithMixedTypesTest : public NegativeTestBase
2991 {
2992 public:
2993 	/* Public methods */
2994 	VaryingLocationAliasingWithMixedTypesTest(deqp::Context& context);
2995 
~VaryingLocationAliasingWithMixedTypesTest()2996 	virtual ~VaryingLocationAliasingWithMixedTypesTest()
2997 	{
2998 	}
2999 
3000 protected:
3001 	/* Methods to be implemented by child class */
3002 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
3003 
3004 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
3005 	virtual glw::GLuint getTestCaseNumber();
3006 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
3007 	virtual void testInit();
3008 
3009 private:
3010 	/* Private types */
3011 	struct testCase
3012 	{
3013 		glw::GLuint			  m_component_gohan;
3014 		glw::GLuint			  m_component_goten;
3015 		bool				  m_is_input;
3016 		Utils::Shader::STAGES m_stage;
3017 		Utils::Type			  m_type_gohan;
3018 		Utils::Type			  m_type_goten;
3019 	};
3020 
3021 	/* Private routines */
3022 	bool isFloatType(const Utils::Type& type);
3023 
3024 	/* Private fields */
3025 	std::vector<testCase> m_test_cases;
3026 };
3027 
3028 /** Implementation of test VaryingLocationAliasingWithMixedInterpolation. Description follows:
3029  *
3030  * Test verifies that it is not allowed to mix interpolation methods at aliased
3031  * location.
3032  *
3033  * Test following code snippet:
3034  *
3035  *     layout (location = 1, component = GOHAN_COMPONENT)
3036  *         GOHAN_INTERPOLATION in type gohan;
3037  *     layout (location = 1, component = GOTEN_COMPONENT)
3038  *         GOTEN_INTERPOLATION in type goten;
3039  *
3040  * Test all interpolation combinations that cause conflict. Select components
3041  * so as not to cause component aliasing. Test all types. Test all shader
3042  * stages. Test both in and out varyings.
3043  *
3044  * Note, that vertex shader's input and fragment shader's output cannot be
3045  * qualified with interpolation method.
3046  *
3047  * It is expected that build process will fail.
3048  **/
3049 class VaryingLocationAliasingWithMixedInterpolationTest : public NegativeTestBase
3050 {
3051 public:
3052 	/* Public methods */
3053 	VaryingLocationAliasingWithMixedInterpolationTest(deqp::Context& context);
3054 
~VaryingLocationAliasingWithMixedInterpolationTest()3055 	virtual ~VaryingLocationAliasingWithMixedInterpolationTest()
3056 	{
3057 	}
3058 
3059 protected:
3060 	/* Methods to be implemented by child class */
3061 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
3062 
3063 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
3064 	virtual glw::GLuint getTestCaseNumber();
3065 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
3066 	virtual void testInit();
3067 
3068 private:
3069 	enum INTERPOLATIONS
3070 	{
3071 		SMOOTH = 0,
3072 		FLAT,
3073 		NO_PERSPECTIVE,
3074 
3075 		/* */
3076 		INTERPOLATION_MAX
3077 	};
3078 
3079 	/* Private types */
3080 	struct testCase
3081 	{
3082 		glw::GLuint			  m_component_gohan;
3083 		glw::GLuint			  m_component_goten;
3084 		INTERPOLATIONS		  m_interpolation_gohan;
3085 		INTERPOLATIONS		  m_interpolation_goten;
3086 		bool				  m_is_input;
3087 		Utils::Shader::STAGES m_stage;
3088 		Utils::Type			  m_type_gohan;
3089 		Utils::Type			  m_type_goten;
3090 	};
3091 
3092 	/* Private routines */
3093 	const glw::GLchar* getInterpolationQualifier(INTERPOLATIONS interpolation);
3094 	bool isFloatType(const Utils::Type& type);
3095 
3096 	/* Private fields */
3097 	std::vector<testCase> m_test_cases;
3098 };
3099 
3100 /** Implementation of test VaryingLocationAliasingWithMixedAuxiliaryStorage. Description follows:
3101  *
3102  * Test verifies that it is not allowed to mix auxiliary storage at aliased
3103  * location.
3104  *
3105  * Test following code snippet:
3106  *
3107  * layout (location = 1, component = GOHAN_COMPONENT)
3108  *     GOHAN_AUXILIARY in type gohan;
3109  * layout (location = 1, component = GOTEN_COMPONENT)
3110  *     GOTEN_AUXILIARY in type goten;
3111  *
3112  * Test all auxiliary storage combinations that cause conflict. Select
3113  * components so as not to cause component aliasing. Test all types. Test all
3114  * shader stages. Test both in and out varyings.
3115  *
3116  * It is expected that build process will fail.
3117  **/
3118 class VaryingLocationAliasingWithMixedAuxiliaryStorageTest : public NegativeTestBase
3119 {
3120 public:
3121 	/* Public methods */
3122 	VaryingLocationAliasingWithMixedAuxiliaryStorageTest(deqp::Context& context);
3123 
~VaryingLocationAliasingWithMixedAuxiliaryStorageTest()3124 	virtual ~VaryingLocationAliasingWithMixedAuxiliaryStorageTest()
3125 	{
3126 	}
3127 
3128 protected:
3129 	/* Methods to be implemented by child class */
3130 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
3131 
3132 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
3133 	virtual glw::GLuint getTestCaseNumber();
3134 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
3135 	virtual void testInit();
3136 
3137 private:
3138 	enum AUXILIARIES
3139 	{
3140 		NONE = 0,
3141 		PATCH,
3142 		CENTROID,
3143 		SAMPLE,
3144 
3145 		/* */
3146 		AUXILIARY_MAX
3147 	};
3148 
3149 	/* Private types */
3150 	struct testCase
3151 	{
3152 		glw::GLuint			  m_component_gohan;
3153 		glw::GLuint			  m_component_goten;
3154 		AUXILIARIES			  m_aux_gohan;
3155 		AUXILIARIES			  m_aux_goten;
3156 		const glw::GLchar*	m_int_gohan;
3157 		const glw::GLchar*	m_int_goten;
3158 		bool				  m_is_input;
3159 		Utils::Shader::STAGES m_stage;
3160 		Utils::Type			  m_type_gohan;
3161 		Utils::Type			  m_type_goten;
3162 	};
3163 
3164 	/* Private routines */
3165 	const glw::GLchar* getAuxiliaryQualifier(AUXILIARIES aux);
3166 	bool isFloatType(const Utils::Type& type);
3167 
3168 	/* Private fields */
3169 	std::vector<testCase> m_test_cases;
3170 };
3171 
3172 /** Implementation of test VertexAttribLocationAPI. Description follows:
3173  *
3174  * Test verifies that vertex attribute location API works as expected.
3175  *
3176  * This test implements Texture algorithm. Tessellation shaders are not
3177  * necessary and can be omitted. Test following code snippet in vertex shader:
3178  *
3179  *     layout (location = GOKU_LOCATION) in vec4 goku;
3180  *                                       in vec4 gohan;
3181  *                                       in vec4 goten;
3182  *                                       in vec4 chichi;
3183  *
3184  *     if ( (EXPECTED_VALUE == goku)   &&
3185  *          (EXPECTED_VALUE == gohan)  &&
3186  *          (EXPECTED_VALUE == gotan)  &&
3187  *          (EXPECTED_VALUE == chichi) )
3188  *     {
3189  *         result = 1;
3190  *     }
3191  *
3192  * After compilation, before program is linked, specify locations for goku,
3193  * and goten with glBindAttribLocation. Specify different location than the one
3194  * used in shader.
3195  *
3196  * Select all locations so as not to exceed any limits.
3197  *
3198  * Additionally inspect program to verify that:
3199  *     - goku location is as specified in shader text,
3200  *     - goten location is as specified with API.
3201  **/
3202 class VertexAttribLocationAPITest : public TextureTestBase
3203 {
3204 public:
3205 	VertexAttribLocationAPITest(deqp::Context& context);
3206 
~VertexAttribLocationAPITest()3207 	~VertexAttribLocationAPITest()
3208 	{
3209 	}
3210 
3211 protected:
3212 	/* Protected methods */
3213 	virtual void prepareAttribLocation(Utils::Program& program, Utils::ProgramInterface& program_interface);
3214 
3215 	virtual void getProgramInterface(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
3216 									 Utils::VaryingPassthrough& varying_passthrough);
3217 
3218 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
3219 
3220 private:
3221 	/* Private fields */
3222 	std::vector<glw::GLubyte> m_goku_data;
3223 	std::vector<glw::GLubyte> m_gohan_data;
3224 	std::vector<glw::GLubyte> m_goten_data;
3225 	std::vector<glw::GLubyte> m_chichi_data;
3226 
3227 	/* Private constants */
3228 	static const glw::GLuint m_goten_location;
3229 };
3230 /** Implementation of test FragmentDataLocationAPI. Description follows:
3231  *
3232  * Test verifies that fragment data location API works as expected.
3233  *
3234  * This test implements Texture algorithm. Tessellation shaders are not
3235  * necessary and can be omitted. "result" is not necessary and can be omitted.
3236  * Test following code snippet in fragment shader:
3237  *
3238  *     layout (location = GOKU_LOCATION)  out vec4 goku;
3239  *                                        out vec4 gohan;
3240  *                                        out vec4 goten;
3241  *                                        out vec4 chichi;
3242  *
3243  *     goku   = EXPECTED_VALUE;
3244  *     gohan  = EXPECTED_VALUE;
3245  *     goten  = EXPECTED_VALUE;
3246  *     chichi = EXPECTED_VALUE;
3247  *
3248  * After compilation, before program is linked, specify locations for goku,
3249  * and goten with glBindFragDataLocation. Specify different location than the
3250  * one used in shader.
3251  *
3252  * Select all locations so as not to exceed any limits.
3253  *
3254  * Additionally inspect program to verify that:
3255  *     - goku location is as specified in shader text,
3256  *     - goten location is as specified with API.
3257  **/
3258 class FragmentDataLocationAPITest : public TextureTestBase
3259 {
3260 public:
3261 	FragmentDataLocationAPITest(deqp::Context& context);
3262 
~FragmentDataLocationAPITest()3263 	~FragmentDataLocationAPITest()
3264 	{
3265 	}
3266 
3267 protected:
3268 	/* Protected methods */
3269 	virtual bool checkResults(glw::GLuint test_case_index, Utils::Texture& color_0);
3270 
3271 	virtual std::string getPassSnippet(glw::GLuint test_case_index, Utils::VaryingPassthrough& varying_passthrough,
3272 									   Utils::Shader::STAGES stage);
3273 
3274 	virtual void getProgramInterface(glw::GLuint test_case_index, Utils::ProgramInterface& program_interface,
3275 									 Utils::VaryingPassthrough& varying_passthrough);
3276 
3277 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
3278 
3279 	virtual void prepareFragmentDataLoc(Utils::Program& program, Utils::ProgramInterface& program_interface);
3280 
3281 	virtual void prepareFramebuffer(Utils::Framebuffer& framebuffer, Utils::Texture& color_0_texture);
3282 
3283 private:
3284 	/* Private fields */
3285 	Utils::Texture m_goku;
3286 	Utils::Texture m_gohan;
3287 	Utils::Texture m_goten;
3288 	Utils::Texture m_chichi;
3289 
3290 	glw::GLint m_goku_location;
3291 	glw::GLint m_gohan_location;
3292 	glw::GLint m_chichi_location;
3293 
3294 	/* Private constants */
3295 	static const glw::GLuint m_goten_location;
3296 };
3297 
3298 /** Implementation of test XFBInput. Description follows:
3299  *
3300  * Test verifies that using xfb_buffer, xfb_stride or xfb_offset qualifiers on
3301  * input variables will cause failure of build process.
3302  *
3303  * Test all shader stages.
3304  **/
3305 class XFBInputTest : public NegativeTestBase
3306 {
3307 public:
3308 	/* Public methods */
3309 	XFBInputTest(deqp::Context& context);
~XFBInputTest()3310 	virtual ~XFBInputTest()
3311 	{
3312 	}
3313 
3314 protected:
3315 	/* Methods to be implemented by child class */
3316 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
3317 
3318 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
3319 	virtual glw::GLuint getTestCaseNumber();
3320 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
3321 	virtual void testInit();
3322 
3323 private:
3324 	enum QUALIFIERS
3325 	{
3326 		BUFFER = 0,
3327 		STRIDE,
3328 		OFFSET,
3329 
3330 		/* */
3331 		QUALIFIERS_MAX
3332 	};
3333 
3334 	/* Private types */
3335 	struct testCase
3336 	{
3337 		QUALIFIERS			  m_qualifier;
3338 		Utils::Shader::STAGES m_stage;
3339 	};
3340 
3341 	/* Private fields */
3342 	std::vector<testCase> m_test_cases;
3343 };
3344 
3345 /** Implementation of test XFBAllStages. Description follows:
3346  *
3347  * Test verifies that only outputs from last stage processing primitives can be
3348  * captured with XFB.
3349  *
3350  * This test implements Buffer algorithm. Rasterization can be discarded.
3351  *
3352  * At each stage declare a single active output variable qualified with
3353  * xfb_buffer and xfb_offset = 0. Use separate buffers for each stage.
3354  *
3355  * Test pass if outputs from geometry shader are captured, while outputs from:
3356  * vertex and tessellation stages are ignored.
3357  **/
3358 class XFBAllStagesTest : public BufferTestBase
3359 {
3360 public:
3361 	XFBAllStagesTest(deqp::Context& context);
3362 
~XFBAllStagesTest()3363 	~XFBAllStagesTest()
3364 	{
3365 	}
3366 
3367 protected:
3368 	/* Protected methods */
3369 	virtual void getBufferDescriptors(glw::GLuint test_case_index, bufferDescriptor::Vector& out_descriptors);
3370 
3371 	virtual void getShaderBody(glw::GLuint test_case_index, Utils::Shader::STAGES stage, std::string& out_assignments,
3372 							   std::string& out_calculations);
3373 
3374 	virtual void getShaderInterface(glw::GLuint test_case_index, Utils::Shader::STAGES stage,
3375 									std::string& out_interface);
3376 
3377 private:
3378 	/* Constants */
3379 	static const glw::GLuint m_gs_index;
3380 };
3381 
3382 /** Implementation of test XFBStrideOfEmptyList. Description follows:
3383  *
3384  * Test verifies that xfb_stride directive is respected even if there are no
3385  * variables qualified with xfb_offset.
3386  *
3387  * Test implements Buffer algorithm. Rasterization can be discarded.
3388  *
3389  * Test following code snippet:
3390  *
3391  *     layout (xfb_buffer = 1, xfb_stride = 64) out;
3392  *
3393  * Moreover program should output something to xfb at index 0
3394  *
3395  * Test following cases:
3396  *     1 Provide buffers to XFB at index 0 and 1
3397  *     2 Provide buffer to XFB at index 1, index 0 should be missing
3398  *     3 Provide buffer to XFB at index 0, index 1 should be missing
3399  *
3400  * It is expected that:
3401  *     - BeginTransformFeedback operation will report GL_INVALID_OPERATION in cases
3402  *     2 and 3,
3403  *     - XFB at index 1 will not be modified in case 1.
3404  **/
3405 class XFBStrideOfEmptyListTest : public BufferTestBase
3406 {
3407 public:
3408 	XFBStrideOfEmptyListTest(deqp::Context& context);
3409 
~XFBStrideOfEmptyListTest()3410 	~XFBStrideOfEmptyListTest()
3411 	{
3412 	}
3413 
3414 protected:
3415 	/* Protected methods */
3416 	using BufferTestBase::executeDrawCall;
3417 	virtual bool executeDrawCall(bool tesEnabled, glw::GLuint test_case_index);
3418 
3419 	virtual void getBufferDescriptors(glw::GLuint test_case_index, bufferDescriptor::Vector& out_descriptors);
3420 
3421 	virtual void getShaderBody(glw::GLuint test_case_index, Utils::Shader::STAGES stage, std::string& out_assignments,
3422 							   std::string& out_calculations);
3423 
3424 	virtual void getShaderInterface(glw::GLuint test_case_index, Utils::Shader::STAGES stage,
3425 									std::string& out_interface);
3426 
3427 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
3428 	virtual glw::GLuint getTestCaseNumber();
3429 
3430 private:
3431 	enum CASES
3432 	{
3433 		VALID = 0,
3434 		FIRST_MISSING,
3435 		SECOND_MISSING,
3436 	};
3437 
3438 	/* Private constants */
3439 	static const glw::GLuint m_stride;
3440 };
3441 
3442 /** Implementation of test XFBStrideOfEmptyListAndAPI. Description follows:
3443  *
3444  * Test verifies that xfb_stride qualifier is not overridden by API.
3445  *
3446  * Test implements Buffer algorithm. Rasterization can be discarded.
3447  *
3448  * Test following code snippet:
3449  *
3450  *     layout (xfb_buffer = 0, xfb_stride = 64) out;
3451  *
3452  * Moreover program should output something to xfb at index 1
3453 
3454  * Use TransformFeedbackVaryings to declare a single vec4 output variable to be
3455  * captured.
3456  *
3457  * Test following cases:
3458  *     1 Provide buffers to XFB at index 0 and 1
3459  *     2 Provide buffer to XFB at index 1, index 0 should be missing
3460  *     3 Provide buffer to XFB at index 0, index 1 should be missing
3461  *
3462  * It is expected that:
3463  *     - BeginTransformFeedback operation will report GL_INVALID_OPERATION in cases
3464  *     2 and 3,
3465  *     - XFB at index 0 will not be modified in case 1.
3466  **/
3467 class XFBStrideOfEmptyListAndAPITest : public BufferTestBase
3468 {
3469 public:
3470 	XFBStrideOfEmptyListAndAPITest(deqp::Context& context);
3471 
~XFBStrideOfEmptyListAndAPITest()3472 	~XFBStrideOfEmptyListAndAPITest()
3473 	{
3474 	}
3475 
3476 protected:
3477 	/* Protected methods */
3478 	using BufferTestBase::executeDrawCall;
3479 	virtual bool executeDrawCall(bool tesEnabled, glw::GLuint test_case_index);
3480 	virtual void getBufferDescriptors(glw::GLuint test_case_index, bufferDescriptor::Vector& out_descriptors);
3481 
3482 	virtual void getCapturedVaryings(glw::GLuint test_case_index, Utils::Program::NameVector& captured_varyings);
3483 
3484 	virtual void getShaderBody(glw::GLuint test_case_index, Utils::Shader::STAGES stage, std::string& out_assignments,
3485 							   std::string& out_calculations);
3486 
3487 	virtual void getShaderInterface(glw::GLuint test_case_index, Utils::Shader::STAGES stage,
3488 									std::string& out_interface);
3489 
3490 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
3491 	virtual glw::GLuint getTestCaseNumber();
3492 
3493 private:
3494 	enum CASES
3495 	{
3496 		VALID = 0,
3497 		FIRST_MISSING,
3498 		SECOND_MISSING,
3499 	};
3500 
3501 	/* Private constants */
3502 	static const glw::GLuint m_stride;
3503 };
3504 
3505 /** Implementation of test XFBTooSmallStride. Description follows:
3506  *
3507  * Test verifies that build process fails when xfb_stride qualifier sets not
3508  * enough space for all variables.
3509  *
3510  * Test following code snippets:
3511  *
3512  *     layout (xfb_buffer = 0, xfb_stride = 40) out;
3513  *
3514  *     layout (xfb_offset = 32) out vec4 goku;
3515  *
3516  *     goku = EXPECTED_VALUE.
3517  *
3518  * ,
3519  *
3520  *     layout (xfb_buffer = 0, xfb_stride = 32) out;
3521  *
3522  *     layout (xfb_offset = 16, xfb_stride = 32) out vec4 goku;
3523  *
3524  *     goku = EXPECTED_VALUE.
3525  *
3526  * ,
3527  *
3528  *     layout (xfb_buffer = 0, xfb_stride = 32) out;
3529  *
3530  *     layout (xfb_offset = 0) out Goku {
3531  *         vec4 gohan;
3532  *         vec4 goten;
3533  *         vec4 chichi;
3534  *     };
3535  *
3536  *     gohan  = EXPECTED_VALUE;
3537  *     goten  = EXPECTED_VALUE;
3538  *     chichi = EXPECTED_VALUE;
3539  *
3540  * ,
3541  *
3542  *     layout (xfb_buffer = 0, xfb_stride = 32) out;
3543  *
3544  *     layout (xfb_offset = 16) out vec4 goku[4];
3545  *
3546  *     goku[0] = EXPECTED_VALUE.
3547  *     goku[1] = EXPECTED_VALUE.
3548  *     goku[2] = EXPECTED_VALUE.
3549  *     goku[3] = EXPECTED_VALUE.
3550  *
3551  * It is expected that build process will fail.
3552  *
3553  * Test all shader stages.
3554  **/
3555 class XFBTooSmallStrideTest : public NegativeTestBase
3556 {
3557 public:
3558 	/* Public methods */
3559 	XFBTooSmallStrideTest(deqp::Context& context);
3560 
~XFBTooSmallStrideTest()3561 	virtual ~XFBTooSmallStrideTest()
3562 	{
3563 	}
3564 
3565 protected:
3566 	/* Methods to be implemented by child class */
3567 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
3568 
3569 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
3570 	virtual glw::GLuint getTestCaseNumber();
3571 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
3572 	virtual void testInit();
3573 
3574 private:
3575 	enum CASES
3576 	{
3577 		OFFSET = 0,
3578 		STRIDE,
3579 		BLOCK,
3580 		ARRAY,
3581 
3582 		/* */
3583 		CASE_MAX
3584 	};
3585 
3586 	/* Private types */
3587 	struct testCase
3588 	{
3589 		CASES				  m_case;
3590 		Utils::Shader::STAGES m_stage;
3591 	};
3592 
3593 	/* Private fields */
3594 	std::vector<testCase> m_test_cases;
3595 };
3596 
3597 /** Implementation of test XFBVariableStride. Description follows:
3598  *
3599  * Test verifies that xfb_stride qualifier change stride of output variable.
3600  *
3601  * Test following code snippets:
3602  *
3603  *     layout (xfb_offset = 0, xfb_stride = 2 * sizeof(type)) out type goku;
3604  *
3605  * and
3606  *
3607  *     layout (xfb_offset = 0, xfb_stride = 2 * sizeof(type)) out type goku;
3608  *     layout (xfb_offset = sizeof(type))                     out type vegeta;
3609  *
3610  * It is expected that:
3611  *     - first snippet will build successfully,
3612  *     - second snippet will fail to build.
3613  *
3614  * Test all types. Test all shader stages.
3615  **/
3616 class XFBVariableStrideTest : public NegativeTestBase
3617 {
3618 public:
3619 	/* Public methods */
3620 	XFBVariableStrideTest(deqp::Context& context);
~XFBVariableStrideTest()3621 	virtual ~XFBVariableStrideTest()
3622 	{
3623 	}
3624 
3625 protected:
3626 	/* Methods to be implemented by child class */
3627 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
3628 
3629 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
3630 	virtual glw::GLuint getTestCaseNumber();
3631 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
3632 	virtual bool isFailureExpected(glw::GLuint test_case_index);
3633 	virtual void testInit();
3634 
3635 private:
3636 	enum CASES
3637 	{
3638 		VALID = 0,
3639 		INVALID,
3640 
3641 		/* */
3642 		CASE_MAX
3643 	};
3644 
3645 	/* Private types */
3646 	struct testCase
3647 	{
3648 		CASES				  m_case;
3649 		Utils::Shader::STAGES m_stage;
3650 		Utils::Type			  m_type;
3651 	};
3652 
3653 	/* Private fields */
3654 	std::vector<testCase> m_test_cases;
3655 };
3656 
3657 /** Implementation of test XFBBlockStride. Description follows:
3658  *
3659  * Test verifies that xfb_stride qualifier change stride of output block.
3660  *
3661  * Test following code snippet:
3662  *
3663  *     layout (xfb_offset = 0, xfb_stride = 128) out Goku {
3664  *         vec4 gohan;
3665  *         vec4 goten;
3666  *         vec4 chichi;
3667  *     };
3668  *
3669  * Inspect program to check if Goku stride is 128 units.
3670  *
3671  * Test all shader stages.
3672  **/
3673 class XFBBlockStrideTest : public TestBase
3674 {
3675 public:
3676 	/* Public methods */
3677 	XFBBlockStrideTest(deqp::Context& context);
3678 
~XFBBlockStrideTest()3679 	virtual ~XFBBlockStrideTest()
3680 	{
3681 	}
3682 
3683 protected:
3684 	/* Methods to be implemented by child class */
3685 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
3686 	virtual glw::GLuint getTestCaseNumber();
3687 	virtual bool testCase(glw::GLuint test_case_index);
3688 	virtual void testInit();
3689 
3690 private:
3691 	/* Private methods */
3692 	std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
3693 
3694 	bool inspectProgram(Utils::Program& program);
3695 
3696 	/* Private fields */
3697 	std::vector<Utils::Shader::STAGES> m_test_cases;
3698 };
3699 
3700 /** Implementation of test XFBBlockMemberStride. Description follows:
3701  *
3702  * Test verifies that xfb_stride qualifier change stride of output block
3703  * member.
3704  *
3705  * This test implements Buffer algorithm. Rasterization can be discarded. Test
3706  * following code snippet:
3707  *
3708  *     layout (xfb_offset = 0) out Goku {
3709  *                                  vec4 gohan;
3710  *         layout (xfb_stride = 32) vec4 goten;
3711  *                                  vec4 chichi;
3712  *     };
3713  *
3714  *     gohan  = EXPECTED_VALUE;
3715  *     goten  = EXPECTED_VALUE;
3716  *     chichi = EXPECTED_VALUE;
3717  *
3718  * Test pass if:
3719  *     - goten stride is reported as 32,
3720  *     - chichi offset is reported as 48,
3721  *     - values captured for all members match expected values,
3722  *     - part of memory reserved for goten, that is not used, is not modified.
3723  **/
3724 class XFBBlockMemberStrideTest : public BufferTestBase
3725 {
3726 public:
3727 	XFBBlockMemberStrideTest(deqp::Context& context);
~XFBBlockMemberStrideTest()3728 	~XFBBlockMemberStrideTest()
3729 	{
3730 	}
3731 
3732 protected:
3733 	/* Protected methods */
3734 	virtual void getBufferDescriptors(glw::GLuint test_case_index, bufferDescriptor::Vector& out_descriptors);
3735 
3736 	virtual void getShaderBody(glw::GLuint test_case_index, Utils::Shader::STAGES stage, std::string& out_assignments,
3737 							   std::string& out_calculations);
3738 
3739 	virtual void getShaderInterface(glw::GLuint test_case_index, Utils::Shader::STAGES stage,
3740 									std::string& out_interface);
3741 
3742 	virtual bool inspectProgram(glw::GLuint test_case_index, Utils::Program& program, std::stringstream& out_stream);
3743 };
3744 
3745 /** Implementation of test XFBDuplicatedStride. Description follows:
3746  *
3747  * Test verifies that conflicting xfb_stride qualifiers cause build process
3748  * failure.
3749  *
3750  * Test following code snippets:
3751  *
3752  *     layout (xfb_buffer = 0, xfb_stride = 64) out;
3753  *     layout (xfb_buffer = 0, xfb_stride = 64) out;
3754  *
3755  * and
3756  *
3757  *     layout (xfb_buffer = 0, xfb_stride = 64)  out;
3758  *     layout (xfb_buffer = 0, xfb_stride = 128) out;
3759  *
3760  * It is expected that:
3761  *     - first snippet will build successfully,
3762  *     - second snippet will fail to build.
3763  **/
3764 class XFBDuplicatedStrideTest : public NegativeTestBase
3765 {
3766 public:
3767 	/* Public methods */
3768 	XFBDuplicatedStrideTest(deqp::Context& context);
3769 
~XFBDuplicatedStrideTest()3770 	virtual ~XFBDuplicatedStrideTest()
3771 	{
3772 	}
3773 
3774 protected:
3775 	/* Methods to be implemented by child class */
3776 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
3777 
3778 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
3779 	virtual glw::GLuint getTestCaseNumber();
3780 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
3781 	virtual bool isFailureExpected(glw::GLuint test_case_index);
3782 	virtual void testInit();
3783 
3784 private:
3785 	enum CASES
3786 	{
3787 		VALID = 0,
3788 		INVALID,
3789 
3790 		/* */
3791 		CASE_MAX
3792 	};
3793 
3794 	/* Private types */
3795 	struct testCase
3796 	{
3797 		CASES				  m_case;
3798 		Utils::Shader::STAGES m_stage;
3799 	};
3800 
3801 	/* Private fields */
3802 	std::vector<testCase> m_test_cases;
3803 };
3804 
3805 /** Implementation of test XFBGetProgramResourceAPI. Description follows:
3806  *
3807  * Test verifies that GetProgramResource* API work as expected for transform
3808  * feedback.
3809  *
3810  * Test results of following queries:
3811  *     - OFFSET,
3812  *     - TRANSFORM_FEEDBACK_BUFFER_INDEX,
3813  *     - TRANSFORM_FEEDBACK_BUFFER_STRIDE,
3814  *     - TYPE.
3815  *
3816  * Test following cases:
3817  *     - captured varyings are declared with API, TransformFeedbackVaryings
3818  *     with INTERLEAVED_ATTRIBS,
3819  *     - captured varyings are declared with API, TransformFeedbackVaryings
3820  *     with SEPARATE_ATTRIBS,
3821  *     - captured varyings are declared with "xfb" qualifiers.
3822  *
3823  * Following layout should be used in cases of INTERLEAVED_ATTRIBS and "xfb"
3824  * qualifiers:
3825  *              | var 0 | var 1 | var 2 | var 3
3826  *     buffer 0 | used  | used  | empty | used
3827  *     buffer 1 | empty | used  | empty | empty
3828  *
3829  * In "xfb" qualifiers case, use following snippet:
3830  *
3831  *     layout (xfb_buffer = 1, xfb_stride = 4 * sizeof(type)) out;
3832  *
3833  * Declaration in shader should use following order:
3834  *     buffer_0_var_1
3835  *     buffer_1_var_1
3836  *     buffer_0_var_3
3837  *     buffer_0_var_0
3838  *
3839  * To make sure that captured varyings are active, they should be assigned.
3840  *
3841  * Test all types. Test all shader stages.
3842  **/
3843 class XFBGetProgramResourceAPITest : public TestBase
3844 {
3845 public:
3846 	/* Public methods */
3847 	XFBGetProgramResourceAPITest(deqp::Context& context);
3848 
~XFBGetProgramResourceAPITest()3849 	virtual ~XFBGetProgramResourceAPITest()
3850 	{
3851 	}
3852 
3853 protected:
3854 	/* Methods to be implemented by child class */
3855 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
3856 	virtual glw::GLuint getTestCaseNumber();
3857 	virtual bool testCase(glw::GLuint test_case_index);
3858 	virtual void testInit();
3859 	virtual void insertSkipComponents(int num_components, Utils::Program::NameVector& varyings);
3860 
3861 private:
3862 	/* Private enums */
3863 	enum CASES
3864 	{
3865 		INTERLEAVED,
3866 		SEPARATED,
3867 		XFB,
3868 	};
3869 
3870 	/* Private types */
3871 	struct test_Case
3872 	{
3873 		CASES				  m_case;
3874 		Utils::Shader::STAGES m_stage;
3875 		Utils::Type			  m_type;
3876 	};
3877 
3878 	/* Private methods */
3879 	std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
3880 
3881 	bool inspectProgram(glw::GLuint test_case_index, Utils::Program& program);
3882 
3883 	/* Private fields */
3884 	std::vector<test_Case> m_test_cases;
3885 };
3886 
3887 /** Implementation of test XFBOverrideQualifiersWithAPI. Description follows:
3888  *
3889  * Test verifies that API is ignored, when qualifiers are in use.
3890  *
3891  * This test follows Buffer algorithm. Rasterization can disabled. Test
3892  * following code snippet:
3893  *
3894  *     layout (xfb_offset = 2 * sizeof(type)) out type vegeta;
3895  *                                            out type trunks;
3896  *     layout (xfb_offset = 0)                out type goku;
3897  *                                            out type gohan;
3898  *
3899  *     vegeta = EXPECTED_VALUE;
3900  *     trunks = EXPECTED_VALUE;
3901  *     goku   = EXPECTED_VALUE;
3902  *     gohan  = EXPECTED_VALUE;
3903  *
3904  * Use API, TransformFeedbackVaryings, to specify trunks and gohan as outputs
3905  * to be captured.
3906  *
3907  * Test pass if:
3908  *     - correct values are captured for vegeta and goku,
3909  *     - trunks and gohan are not captured,
3910  *     - correct stride is reported.
3911  *
3912  * Test all types. Test all shader stages.
3913  **/
3914 class XFBOverrideQualifiersWithAPITest : public BufferTestBase
3915 {
3916 public:
3917 	XFBOverrideQualifiersWithAPITest(deqp::Context& context);
3918 
~XFBOverrideQualifiersWithAPITest()3919 	~XFBOverrideQualifiersWithAPITest()
3920 	{
3921 	}
3922 
3923 protected:
3924 	/* Protected methods */
3925 	virtual void getBufferDescriptors(glw::GLuint test_case_index, bufferDescriptor::Vector& out_descriptors);
3926 
3927 	virtual void getCapturedVaryings(glw::GLuint test_case_index, Utils::Program::NameVector& captured_varyings);
3928 
3929 	virtual void getShaderBody(glw::GLuint test_case_index, Utils::Shader::STAGES stage, std::string& out_assignments,
3930 							   std::string& out_calculations);
3931 
3932 	virtual void getShaderInterface(glw::GLuint test_case_index, Utils::Shader::STAGES stage,
3933 									std::string& out_interface);
3934 
3935 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
3936 	virtual glw::GLuint getTestCaseNumber();
3937 
3938 	virtual bool inspectProgram(glw::GLuint test_case_index, Utils::Program& program, std::stringstream& out_stream);
3939 };
3940 
3941 /** Implementation of test XFBVertexStreams. Description follows:
3942  *
3943  * Test verifies that "xfb" qualifiers work as expected with multiple output
3944  * streams.
3945  *
3946  * Test implements Buffer algorithm. Rasterization can be discarded.
3947  *
3948  * Test following code snippet:
3949  *
3950  *     layout (xfb_buffer = 1, xfb_stride = 64) out;
3951  *     layout (xfb_buffer = 2, xfb_stride = 64) out;
3952  *     layout (xfb_buffer = 3, xfb_stride = 64) out;
3953  *
3954  *     layout (stream = 0, xfb_buffer = 1, xfb_offset = 48) out vec4 goku;
3955  *     layout (stream = 0, xfb_buffer = 1, xfb_offset = 32) out vec4 gohan;
3956  *     layout (stream = 0, xfb_buffer = 1, xfb_offset = 16) out vec4 goten;
3957  *     layout (stream = 1, xfb_buffer = 3, xfb_offset = 48) out vec4 picolo;
3958  *     layout (stream = 1, xfb_buffer = 3, xfb_offset = 32) out vec4 vegeta;
3959  *     layout (stream = 2, xfb_buffer = 2, xfb_offset = 32) out vec4 bulma;
3960  *
3961  *     goku   = EXPECTED_VALUE;
3962  *     gohan  = EXPECTED_VALUE;
3963  *     goten  = EXPECTED_VALUE;
3964  *     picolo = EXPECTED_VALUE;
3965  *     vegeta = EXPECTED_VALUE;
3966  *     bulma  = EXPECTED_VALUE;
3967  *
3968  * Test pass if all captured outputs have expected values.
3969  **/
3970 class XFBVertexStreamsTest : public BufferTestBase
3971 {
3972 public:
3973 	XFBVertexStreamsTest(deqp::Context& context);
3974 
~XFBVertexStreamsTest()3975 	~XFBVertexStreamsTest()
3976 	{
3977 	}
3978 
3979 protected:
3980 	/* Protected methods */
3981 	virtual void getBufferDescriptors(glw::GLuint test_case_index, bufferDescriptor::Vector& out_descriptors);
3982 
3983 	virtual void getShaderBody(glw::GLuint test_case_index, Utils::Shader::STAGES stage, std::string& out_assignments,
3984 							   std::string& out_calculations);
3985 
3986 	virtual void getShaderInterface(glw::GLuint test_case_index, Utils::Shader::STAGES stage,
3987 									std::string& out_interface);
3988 };
3989 
3990 /** Implementation of test XFBMultipleVertexStreams. Description follows:
3991  *
3992  * Test verifies that outputs from single stream must be captured with single
3993  * xfb binding.
3994  *
3995  * Test following code snippet:
3996  *
3997  *     layout (xfb_buffer = 1, xfb_stride = 64) out;
3998  *     layout (xfb_buffer = 3, xfb_stride = 64) out;
3999  *
4000  *     layout (stream = 0, xfb_buffer = 1, xfb_offset = 48) out vec4 goku;
4001  *     layout (stream = 1, xfb_buffer = 1, xfb_offset = 32) out vec4 gohan;
4002  *     layout (stream = 2, xfb_buffer = 1, xfb_offset = 16) out vec4 goten;
4003  *
4004  * It is expected that linking of program will fail.
4005  **/
4006 class XFBMultipleVertexStreamsTest : public NegativeTestBase
4007 {
4008 public:
4009 	/* Public methods */
4010 	XFBMultipleVertexStreamsTest(deqp::Context& context);
4011 
~XFBMultipleVertexStreamsTest()4012 	virtual ~XFBMultipleVertexStreamsTest()
4013 	{
4014 	}
4015 
4016 protected:
4017 	/* Methods to be implemented by child class */
4018 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
4019 
4020 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
4021 };
4022 
4023 /** Implementation of test XFBExceedBufferLimit. Description follows:
4024  *
4025  * Test verifies that MAX_TRANSFORM_FEEDBACK_BUFFERS limit is respected.
4026  *
4027  * Test following code snippets:
4028  *
4029  *     layout (xfb_buffer = MAX_TRANSFORM_FEEDBACK_BUFFERS) out;
4030  *
4031  * ,
4032  *
4033  *     layout (xfb_buffer = MAX_TRANSFORM_FEEDBACK_BUFFERS) out vec4 output;
4034  *
4035  * and
4036  *
4037  *     layout (xfb_buffer = MAX_TRANSFORM_FEEDBACK_BUFFERS) out Block {
4038  *         vec4 member;
4039  *     };
4040  *
4041  * It is expected that build process will fail.
4042  *
4043  * Test all shader stages.
4044  **/
4045 class XFBExceedBufferLimitTest : public NegativeTestBase
4046 {
4047 public:
4048 	/* Public methods */
4049 	XFBExceedBufferLimitTest(deqp::Context& context);
~XFBExceedBufferLimitTest()4050 	virtual ~XFBExceedBufferLimitTest()
4051 	{
4052 	}
4053 
4054 protected:
4055 	/* Methods to be implemented by child class */
4056 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
4057 
4058 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
4059 	virtual glw::GLuint getTestCaseNumber();
4060 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
4061 	virtual void testInit();
4062 
4063 private:
4064 	enum CASES
4065 	{
4066 		BLOCK = 0,
4067 		GLOBAL,
4068 		VECTOR,
4069 
4070 		/* */
4071 		CASE_MAX
4072 	};
4073 
4074 	/* Private types */
4075 	struct testCase
4076 	{
4077 		CASES				  m_case;
4078 		Utils::Shader::STAGES m_stage;
4079 	};
4080 
4081 	/* Private fields */
4082 	std::vector<testCase> m_test_cases;
4083 };
4084 
4085 /** Implementation of test XFBExceedOffsetLimit. Description follows:
4086  *
4087  * Test verifies that MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS limit is
4088  * respected.
4089  *
4090  * Test following code snippets:
4091  *
4092  *     layout (xfb_buffer = 0, xfb_stride = MAX_SIZE + 16) out;
4093  *
4094  * ,
4095  *
4096  *     layout (xfb_buffer = 0, xfb_offset = MAX_SIZE) out vec4 output;
4097  *
4098  * and
4099  *
4100  *     layout (xfb_buffer = 0, xfb_offset = MAX_SIZE) out Block
4101  *     {
4102  *         vec4 member;
4103  *     };
4104  *
4105  * where MAX_SIZE is the maximum supported size of transform feedback buffer,
4106  * which should be equal to:
4107  *
4108  *     MAX_TRANSFORM_FEEDBACK_INTERLEAVED_COMPONENTS * sizeof(float)
4109  *
4110  * It is expected that build process will fail.
4111  *
4112  * Test all shader stages.
4113  **/
4114 class XFBExceedOffsetLimitTest : public NegativeTestBase
4115 {
4116 public:
4117 	/* Public methods */
4118 	XFBExceedOffsetLimitTest(deqp::Context& context);
~XFBExceedOffsetLimitTest()4119 	virtual ~XFBExceedOffsetLimitTest()
4120 	{
4121 	}
4122 
4123 protected:
4124 	/* Methods to be implemented by child class */
4125 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
4126 
4127 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
4128 	virtual glw::GLuint getTestCaseNumber();
4129 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
4130 	virtual void testInit();
4131 
4132 private:
4133 	enum CASES
4134 	{
4135 		BLOCK = 0,
4136 		GLOBAL,
4137 		VECTOR,
4138 
4139 		/* */
4140 		CASE_MAX
4141 	};
4142 
4143 	/* Private types */
4144 	struct testCase
4145 	{
4146 		CASES				  m_case;
4147 		Utils::Shader::STAGES m_stage;
4148 	};
4149 
4150 	/* Private fields */
4151 	std::vector<testCase> m_test_cases;
4152 };
4153 
4154 /** Implementation of test XFBGlobalBuffer. Description follows:
4155  *
4156  * Test verifies that global setting of xfb_buffer qualifier work as expected.
4157  *
4158  * This test implements Buffer algorithm. Rasterization can be discarded. Test
4159  * following code snippet:
4160  *
4161  *     layout (xfb_buffer = 3) out;
4162  *
4163  *     layout (                xfb_offset = 2 * sizeof(type)) out type chichi;
4164  *     layout (xfb_buffer = 1, xfb_offset = 0)                out type bulma;
4165  *     layout (xfb_buffer = 1, xfb_offset = sizeof(type))     out Vegeta {
4166  *         type trunks;
4167  *         type bra;
4168  *     };
4169  *     layout (                xfb_offset = 0)                out Goku {
4170  *         type gohan;
4171  *         type goten;
4172  *     };
4173  *
4174  *     chichi = EXPECTED_VALUE;
4175  *     bulma  = EXPECTED_VALUE;
4176  *     trunks = EXPECTED_VALUE;
4177  *     bra    = EXPECTED_VALUE;
4178  *     gohan  = EXPECTED_VALUE;
4179  *     goten  = EXPECTED_VALUE;
4180  *
4181  * Test pass if all captured outputs have expected values.
4182  *
4183  * Test all shader stages. Test all types.
4184  **/
4185 class XFBGlobalBufferTest : public BufferTestBase
4186 {
4187 public:
4188 	XFBGlobalBufferTest(deqp::Context& context);
4189 
~XFBGlobalBufferTest()4190 	~XFBGlobalBufferTest()
4191 	{
4192 	}
4193 
4194 protected:
4195 	/* Protected methods */
4196 	virtual void getBufferDescriptors(glw::GLuint test_case_index, bufferDescriptor::Vector& out_descriptors);
4197 
4198 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
4199 
4200 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
4201 	virtual glw::GLuint getTestCaseNumber();
4202 	virtual void		testInit();
4203 
4204 private:
4205 	/* Private types */
4206 	struct _testCase
4207 	{
4208 		Utils::Shader::STAGES m_stage;
4209 		Utils::Type			  m_type;
4210 	};
4211 
4212 	/* Private fields */
4213 	std::vector<_testCase> m_test_cases;
4214 };
4215 
4216 /** Implementation of test XFBStride. Description follows:
4217  *
4218  * Test verifies that expected stride values are used.
4219  *
4220  * Test following code snippet:
4221  *
4222  *     layout (xfb_offset = 0) out type output;
4223  *
4224  *     output = EXPECTED_VALUE;
4225  *
4226  * Test all types. Test all shader stages.
4227  **/
4228 class XFBStrideTest : public BufferTestBase
4229 {
4230 public:
4231 	XFBStrideTest(deqp::Context& context);
~XFBStrideTest()4232 	~XFBStrideTest()
4233 	{
4234 	}
4235 
4236 protected:
4237 	/* Protected methods */
4238 	using BufferTestBase::executeDrawCall;
4239 
4240 	virtual bool executeDrawCall(bool tesEnabled, glw::GLuint test_case_index);
4241 	virtual void getBufferDescriptors(glw::GLuint test_case_index, bufferDescriptor::Vector& out_descriptors);
4242 
4243 	virtual void getShaderBody(glw::GLuint test_case_index, Utils::Shader::STAGES stage, std::string& out_assignments,
4244 							   std::string& out_calculations);
4245 
4246 	virtual void getShaderInterface(glw::GLuint test_case_index, Utils::Shader::STAGES stage,
4247 									std::string& out_interface);
4248 
4249 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
4250 
4251 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
4252 	virtual glw::GLuint getTestCaseNumber();
4253 	virtual void		testInit();
4254 
4255 private:
4256 	/* Private types */
4257 	struct testCase
4258 	{
4259 		Utils::Shader::STAGES m_stage;
4260 		Utils::Type			  m_type;
4261 	};
4262 
4263 	/* Private fields */
4264 	std::vector<testCase> m_test_cases;
4265 };
4266 
4267 /** Implementation of test XFBBlockMemberBuffer. Description follows:
4268  *
4269  * Test verifies that member of block have to use same buffer as block.
4270  *
4271  * Test following code snippet:
4272  *
4273  *     layout (xfb_offset = 0) out Goku
4274  *     {
4275  *                                 vec4 gohan;
4276  *         layout (xfb_buffer = 1) vec4 goten;
4277  *     };
4278  *
4279  * It is expected that compilation will fail.
4280  *
4281  * Test all shader stages.
4282  **/
4283 class XFBBlockMemberBufferTest : public NegativeTestBase
4284 {
4285 public:
4286 	/* Public methods */
4287 	XFBBlockMemberBufferTest(deqp::Context& context);
4288 
~XFBBlockMemberBufferTest()4289 	virtual ~XFBBlockMemberBufferTest()
4290 	{
4291 	}
4292 
4293 protected:
4294 	/* Methods to be implemented by child class */
4295 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
4296 
4297 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
4298 	virtual glw::GLuint getTestCaseNumber();
4299 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
4300 	virtual void testInit();
4301 
4302 private:
4303 	/* Private types */
4304 	struct testCase
4305 	{
4306 		Utils::Shader::STAGES m_stage;
4307 	};
4308 
4309 	/* Private fields */
4310 	std::vector<testCase> m_test_cases;
4311 };
4312 
4313 /** Implementation of test XFBOutputOverlapping. Description follows:
4314  *
4315  * Test verifies that overlapped outputs are reported as errors by compiler.
4316  *
4317  * Test following code snippet:
4318  *
4319  *     layout (xfb_offset = sizeof(type))       out type gohan;
4320  *     layout (xfb_offset = 1.5 * sizeof(type)) out type goten;
4321  *
4322  *     gohan = EXPECTED_VALUE;
4323  *     goten = EXPECTED_VALUE;
4324  *
4325  * It is expected that compilation will fail.
4326  *
4327  * Test all shader stages. Test all types.
4328  **/
4329 class XFBOutputOverlappingTest : public NegativeTestBase
4330 {
4331 public:
4332 	/* Public methods */
4333 	XFBOutputOverlappingTest(deqp::Context& context);
4334 
~XFBOutputOverlappingTest()4335 	virtual ~XFBOutputOverlappingTest()
4336 	{
4337 	}
4338 
4339 protected:
4340 	/* Methods to be implemented by child class */
4341 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
4342 
4343 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
4344 	virtual glw::GLuint getTestCaseNumber();
4345 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
4346 	virtual void testInit();
4347 
4348 private:
4349 	/* Private types */
4350 	struct testCase
4351 	{
4352 		glw::GLuint			  m_offset_gohan;
4353 		glw::GLuint			  m_offset_goten;
4354 		Utils::Shader::STAGES m_stage;
4355 		Utils::Type			  m_type;
4356 	};
4357 
4358 	/* Private fields */
4359 	std::vector<testCase> m_test_cases;
4360 };
4361 
4362 /** Implementation of test XFBInvalidOffsetAlignment. Description follows:
4363  *
4364  * Test verifies that invalidly aligned outputs cause a failure to build
4365  * process.
4366  *
4367  * Test following code snippet:
4368  *
4369  *     layout (xfb_offset = OFFSET) out type goku;
4370  *
4371  *     goku = EXPECTED_VALUE;
4372  *
4373  * Select OFFSET values so as to cause invalid alignment. Inspect program to
4374  * verify offset of goku.
4375  *
4376  * Test all shader stages. Test all types. Test all offsets in range:
4377  * (sizeof(type), 2 * sizeof(type)).
4378  **/
4379 class XFBInvalidOffsetAlignmentTest : public NegativeTestBase
4380 {
4381 public:
4382 	/* Public methods */
4383 	XFBInvalidOffsetAlignmentTest(deqp::Context& context);
4384 
~XFBInvalidOffsetAlignmentTest()4385 	virtual ~XFBInvalidOffsetAlignmentTest()
4386 	{
4387 	}
4388 
4389 protected:
4390 	/* Methods to be implemented by child class */
4391 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
4392 
4393 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
4394 	virtual glw::GLuint getTestCaseNumber();
4395 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
4396 	virtual void testInit();
4397 
4398 private:
4399 	/* Private types */
4400 	struct testCase
4401 	{
4402 		glw::GLuint			  m_offset;
4403 		Utils::Shader::STAGES m_stage;
4404 		Utils::Type			  m_type;
4405 	};
4406 
4407 	/* Private fields */
4408 	std::vector<testCase> m_test_cases;
4409 };
4410 
4411 /** Implementation of test XFBCaptureInactiveOutputVariable. Description follows:
4412  *
4413  * Test verifies behaviour of inactive outputs.
4414  *
4415  * This test implements Buffer algorithm. Rasterization can be disabled. Draw
4416  * two vertices instead of one. Test following code snippet:
4417  *
4418  *     layout (xfb_offset = 16) out vec4 goku;
4419  *     layout (xfb_offset = 32) out vec4 gohan;
4420  *     layout (xfb_offset = 0)  out vec4 goten;
4421  *
4422  *     gohan = EXPECTED_VALUE;
4423  *     goten = EXPECTED_VALUE;
4424  *
4425  * Test pass if:
4426  *     - values captured for goten and gohan are as expected,
4427  *     - goku value is undefined
4428  *     - stride is 3 * sizeof(vec4) - 48
4429  *
4430  * Test all shader stages.
4431  **/
4432 class XFBCaptureInactiveOutputVariableTest : public BufferTestBase
4433 {
4434 public:
4435 	XFBCaptureInactiveOutputVariableTest(deqp::Context& context);
~XFBCaptureInactiveOutputVariableTest()4436 	~XFBCaptureInactiveOutputVariableTest()
4437 	{
4438 	}
4439 
4440 protected:
4441 	/* Protected methods */
4442 	using BufferTestBase::executeDrawCall;
4443 	virtual bool executeDrawCall(bool tesEnabled, glw::GLuint test_case_index);
4444 	virtual void getBufferDescriptors(glw::GLuint test_case_index, bufferDescriptor::Vector& out_descriptors);
4445 
4446 	virtual void getShaderBody(glw::GLuint test_case_index, Utils::Shader::STAGES stage, std::string& out_assignments,
4447 							   std::string& out_calculations);
4448 
4449 	virtual void getShaderInterface(glw::GLuint test_case_index, Utils::Shader::STAGES stage,
4450 									std::string& out_interface);
4451 
4452 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
4453 
4454 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
4455 	virtual glw::GLuint getTestCaseNumber();
4456 
4457 	virtual bool inspectProgram(glw::GLuint test_case_index, Utils::Program& program, std::stringstream& out_stream);
4458 
4459 	virtual bool verifyBuffers(bufferCollection& buffers);
4460 
4461 private:
4462 	enum test_cases
4463 	{
4464 		TEST_VS = 0,
4465 		TEST_TES,
4466 		TEST_GS,
4467 
4468 		/* */
4469 		TEST_MAX
4470 	};
4471 };
4472 
4473 /** Implementation of test XFBCaptureInactiveOutputComponent. Description follows:
4474  *
4475  * Test verifies behaviour of inactive component.
4476  *
4477  * This test implements Buffer algorithm. Rasterization can be disabled. Draw
4478  * two vertices instead of one. Test following code snippet:
4479  *
4480  *     layout (xfb_offset = 32)  out vec4 goku;
4481  *     layout (xfb_offset = 0)   out vec4 gohan;
4482  *     layout (xfb_offset = 16)  out vec4 goten;
4483  *     layout (xfb_offset = 48)  out vec4 chichi;
4484  *     layout (xfb_offset = 112) out vec4 vegeta;
4485  *     layout (xfb_offset = 96)  out vec4 trunks;
4486  *     layout (xfb_offset = 80)  out vec4 bra;
4487  *     layout (xfb_offset = 64)  out vec4 bulma;
4488  *
4489  *     goku.x   = EXPECTED_VALUE;
4490  *     goku.z   = EXPECTED_VALUE;
4491  *     gohan.y  = EXPECTED_VALUE;
4492  *     gohan.w  = EXPECTED_VALUE;
4493  *     goten.x  = EXPECTED_VALUE;
4494  *     goten.y  = EXPECTED_VALUE;
4495  *     chichi.z = EXPECTED_VALUE;
4496  *     chichi.w = EXPECTED_VALUE;
4497  *     vegeta.x = EXPECTED_VALUE;
4498  *     trunks.y = EXPECTED_VALUE;
4499  *     bra.z    = EXPECTED_VALUE;
4500  *     bulma.w  = EXPECTED_VALUE;
4501  *
4502  * Test pass when captured values of all assigned components match expected
4503  * values, while not assigned ones are undefined.
4504  *
4505  * Test all shader stages.
4506  **/
4507 class XFBCaptureInactiveOutputComponentTest : public BufferTestBase
4508 {
4509 public:
4510 	XFBCaptureInactiveOutputComponentTest(deqp::Context& context);
~XFBCaptureInactiveOutputComponentTest()4511 	~XFBCaptureInactiveOutputComponentTest()
4512 	{
4513 	}
4514 
4515 protected:
4516 	/* Protected methods */
4517 	using BufferTestBase::executeDrawCall;
4518 	virtual bool executeDrawCall(bool tesEnabled, glw::GLuint test_case_index);
4519 
4520 	virtual void getBufferDescriptors(glw::GLuint test_case_index, bufferDescriptor::Vector& out_descriptors);
4521 
4522 	virtual void getShaderBody(glw::GLuint test_case_index, Utils::Shader::STAGES stage, std::string& out_assignments,
4523 							   std::string& out_calculations);
4524 
4525 	virtual void getShaderInterface(glw::GLuint test_case_index, Utils::Shader::STAGES stage,
4526 									std::string& out_interface);
4527 
4528 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
4529 
4530 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
4531 	virtual glw::GLuint getTestCaseNumber();
4532 	virtual bool verifyBuffers(bufferCollection& buffers);
4533 
4534 private:
4535 	enum test_cases
4536 	{
4537 		TEST_VS = 0,
4538 		TEST_TES,
4539 		TEST_GS,
4540 
4541 		/* */
4542 		TEST_MAX
4543 	};
4544 };
4545 
4546 /** Implementation of test XFBCaptureInactiveOutputBlockMember. Description follows:
4547  *
4548  * Test verifies behaviour of inactive block member.
4549  *
4550  * This test implements Buffer algorithm. Rasterization can be disabled. Draw
4551  * two vertices instead of one. Test following code snippet:
4552  *
4553  *     layout (xfb_offset = 16)  out Goku {
4554  *         vec4 gohan;
4555  *         vec4 goten;
4556  *         vec4 chichi;
4557  *     };
4558  *
4559  *     gohan  = EXPECTED_VALUE;
4560  *     chichi = EXPECTED_VALUE;
4561  *
4562  * Test pass when captured values of gohan and chichi match expected values.
4563  * It is expected that goten will receive undefined value.
4564  *
4565  * Test all shader stages.
4566  **/
4567 class XFBCaptureInactiveOutputBlockMemberTest : public BufferTestBase
4568 {
4569 public:
4570 	XFBCaptureInactiveOutputBlockMemberTest(deqp::Context& context);
4571 
~XFBCaptureInactiveOutputBlockMemberTest()4572 	~XFBCaptureInactiveOutputBlockMemberTest()
4573 	{
4574 	}
4575 
4576 protected:
4577 	/* Protected methods */
4578 	using BufferTestBase::executeDrawCall;
4579 	virtual bool executeDrawCall(bool tesEnabled, glw::GLuint test_case_index);
4580 	virtual void getBufferDescriptors(glw::GLuint test_case_index, bufferDescriptor::Vector& out_descriptors);
4581 
4582 	virtual void getShaderBody(glw::GLuint test_case_index, Utils::Shader::STAGES stage, std::string& out_assignments,
4583 							   std::string& out_calculations);
4584 
4585 	virtual void getShaderInterface(glw::GLuint test_case_index, Utils::Shader::STAGES stage,
4586 									std::string& out_interface);
4587 
4588 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
4589 
4590 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
4591 	virtual glw::GLuint getTestCaseNumber();
4592 	virtual bool verifyBuffers(bufferCollection& buffers);
4593 
4594 private:
4595 	enum test_cases
4596 	{
4597 		TEST_VS = 0,
4598 		TEST_TES,
4599 		TEST_GS,
4600 
4601 		/* */
4602 		TEST_MAX
4603 	};
4604 };
4605 
4606 /** Implementation of test XFBCaptureStruct. Description follows:
4607  *
4608  * Test verifies that structures are captured as expected.
4609  *
4610  * This test implements Buffer algorithm. Rasterization can be disabled. Draw
4611  * two vertices instead of one. Test following code snippet:
4612  *
4613  *     struct Goku {
4614  *         vec4 gohan;
4615  *         vec4 goten;
4616  *         vec4 chichi;
4617  *     };
4618  *
4619  *     layout (xfb_offset = 16) out Goku goku;
4620  *
4621  *     goku.gohan  = EXPECTED_VALUE;
4622  *     goku.chichi = EXPECTED_VALUE;
4623  *
4624  * Test pass when captured values of gohan and chichi match expected values.
4625  * It is expected that goten will receive undefined value.
4626  *
4627  * Test all shader stages.
4628  **/
4629 class XFBCaptureStructTest : public BufferTestBase
4630 {
4631 public:
4632 	XFBCaptureStructTest(deqp::Context& context);
4633 
~XFBCaptureStructTest()4634 	~XFBCaptureStructTest()
4635 	{
4636 	}
4637 
4638 protected:
4639 	/* Protected methods */
4640 	using BufferTestBase::executeDrawCall;
4641 	virtual bool executeDrawCall(bool tesEnabled, glw::GLuint test_case_index);
4642 
4643 	virtual void getBufferDescriptors(glw::GLuint test_case_index, bufferDescriptor::Vector& out_descriptors);
4644 
4645 	virtual void getShaderBody(glw::GLuint test_case_index, Utils::Shader::STAGES stage, std::string& out_assignments,
4646 							   std::string& out_calculations);
4647 
4648 	virtual void getShaderInterface(glw::GLuint test_case_index, Utils::Shader::STAGES stage,
4649 									std::string& out_interface);
4650 
4651 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
4652 
4653 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
4654 	virtual glw::GLuint getTestCaseNumber();
4655 	virtual bool verifyBuffers(bufferCollection& buffers);
4656 
4657 private:
4658 	enum test_cases
4659 	{
4660 		TEST_VS = 0,
4661 		TEST_TES,
4662 		TEST_GS,
4663 
4664 		/* */
4665 		TEST_MAX
4666 	};
4667 };
4668 
4669 /** Implementation of test XFBCaptureUnsizedArray. Description follows:
4670  *
4671  * Test verifies this is not allowed to qualify unsized array with "xfb".
4672  *
4673  * Test following code snippet:
4674  *
4675  *     layout (xfb_offset = 0) out vec4 goku[];
4676  *
4677  *     goku[0] = EXPECTED_VALUE;
4678  *
4679  * It is expected that compilation will fail.
4680  *
4681  * Test all shader stages.
4682  **/
4683 class XFBCaptureUnsizedArrayTest : public NegativeTestBase
4684 {
4685 public:
4686 	/* Public methods */
4687 	XFBCaptureUnsizedArrayTest(deqp::Context& context);
~XFBCaptureUnsizedArrayTest()4688 	virtual ~XFBCaptureUnsizedArrayTest()
4689 	{
4690 	}
4691 
4692 protected:
4693 	/* Methods to be implemented by child class */
4694 	virtual std::string getShaderSource(glw::GLuint test_case_index, Utils::Shader::STAGES stage);
4695 
4696 	virtual std::string getTestCaseName(glw::GLuint test_case_index);
4697 	virtual glw::GLuint getTestCaseNumber();
4698 	virtual bool isComputeRelevant(glw::GLuint test_case_index);
4699 	virtual void testInit();
4700 
4701 private:
4702 	/* Private types */
4703 	struct testCase
4704 	{
4705 		Utils::Shader::STAGES m_stage;
4706 	};
4707 
4708 	/* Private fields */
4709 	std::vector<testCase> m_test_cases;
4710 };
4711 
4712 } /* EnhancedLayouts namespace */
4713 
4714 /** Group class for Shader Language 420Pack conformance tests */
4715 class EnhancedLayoutsTests : public deqp::TestCaseGroup
4716 {
4717 public:
4718 	/* Public methods */
4719 	EnhancedLayoutsTests(deqp::Context& context);
4720 
~EnhancedLayoutsTests(void)4721 	virtual ~EnhancedLayoutsTests(void)
4722 	{
4723 	}
4724 
4725 	virtual void init(void);
4726 
4727 private:
4728 	/* Private methods */
4729 	EnhancedLayoutsTests(const EnhancedLayoutsTests& other);
4730 	EnhancedLayoutsTests& operator=(const EnhancedLayoutsTests& other);
4731 };
4732 
4733 } // gl4cts
4734 
4735 #endif // _GL4CENHANCEDLAYOUTSTESTS_HPP
4736