1 /*-------------------------------------------------------------------------
2 * OpenGL Conformance Test Suite
3 * -----------------------------
4 *
5 * Copyright (c) 2015-2016 The Khronos Group Inc.
6 *
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
10 *
11 * http://www.apache.org/licenses/LICENSE-2.0
12 *
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 *
19 */ /*!
20 * \file
21 * \brief
22 */ /*-------------------------------------------------------------------*/
23
24 /**
25 */ /*!
26 * \file gl4cGetTextureSubImageTests.cpp
27 * \brief Get Texture Sub Image Tests Suite Implementation
28 */ /*-------------------------------------------------------------------*/
29
30 /* Includes. */
31 #include "gl4cGetTextureSubImageTests.hpp"
32 #include "gluContextInfo.hpp"
33 #include "gluDefs.hpp"
34 #include "gluRenderContext.hpp"
35 #include "gluStrUtil.hpp"
36 #include "tcuTestLog.hpp"
37 #include <cstdlib>
38
39 /* Implementation */
40
41 /**************************************************************************************************
42 * Tests Group Implementation *
43 **************************************************************************************************/
44
Tests(deqp::Context & context)45 gl4cts::GetTextureSubImage::Tests::Tests(deqp::Context& context)
46 : TestCaseGroup(context, "get_texture_sub_image", "Get Texture Sub Image Tests Suite")
47 {
48 addChild(new GetTextureSubImage::Errors(m_context));
49 addChild(new GetTextureSubImage::Functional(m_context));
50 }
51
~Tests(void)52 gl4cts::GetTextureSubImage::Tests::~Tests(void)
53 {
54 }
55
init(void)56 void gl4cts::GetTextureSubImage::Tests::init(void)
57 {
58 }
59
60 /**************************************************************************************************
61 * Errors Tests Implementation *
62 **************************************************************************************************/
63
64 /** Constructor of API Errors tests.
65 *
66 * @return [in] context OpenGL context in which test shall run.
67 */
Errors(deqp::Context & context)68 gl4cts::GetTextureSubImage::Errors::Errors(deqp::Context& context)
69 : deqp::TestCase(context, "errors_test", "Get Texture SubImage Errors Test")
70 , m_context(context)
71 , m_texture_1D(0)
72 , m_texture_1D_array(0)
73 , m_texture_2D(0)
74 , m_texture_rectangle(0)
75 , m_texture_2D_compressed(0)
76 , m_texture_2D_multisampled(0)
77 , m_destination_buffer(DE_NULL)
78 , m_gl_GetTextureSubImage(DE_NULL)
79 , m_gl_GetCompressedTextureSubImage(DE_NULL)
80 {
81 }
82
83 /** Destructor of API Errors tests.
84 */
~Errors(void)85 gl4cts::GetTextureSubImage::Errors::~Errors(void)
86 {
87 }
88
89 /** This function iterate over API Errors tests.
90 */
iterate(void)91 tcu::TestNode::IterateResult gl4cts::GetTextureSubImage::Errors::iterate(void)
92 {
93 bool is_ok = true;
94 bool test_error = false;
95
96 bool is_at_least_gl_45 = (glu::contextSupports(m_context.getRenderContext().getType(), glu::ApiType::core(4, 5)));
97 bool is_arb_get_texture_sub_image = m_context.getContextInfo().isExtensionSupported("GL_ARB_get_texture_sub_image");
98
99 try
100 {
101 if (is_at_least_gl_45 || is_arb_get_texture_sub_image)
102 {
103 /* Prepare texture objects */
104 prepare();
105
106 /* Do tests. */
107 is_ok &= testExistingTextureObjectError();
108
109 is_ok &= testBufferOrMultisampledTargetError();
110
111 is_ok &= testNegativeOffsetError();
112
113 is_ok &= testBoundsError();
114
115 is_ok &= testOneDimmensionalTextureErrors();
116
117 is_ok &= testTwoDimmensionalTextureErrors();
118
119 is_ok &= testBufferSizeError();
120 }
121 }
122 catch (...)
123 {
124 is_ok = false;
125 test_error = true;
126 }
127
128 /* Clean up */
129 clean();
130
131 /* Result's setup. */
132 if (is_ok)
133 {
134 m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass");
135 }
136 else
137 {
138 if (test_error)
139 {
140 m_testCtx.setTestResult(QP_TEST_RESULT_INTERNAL_ERROR, "Error");
141 }
142 else
143 {
144 m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail");
145 }
146 }
147
148 return STOP;
149 }
150
151 /** Preparation of source textures and destination buffer.
152 */
prepare()153 void gl4cts::GetTextureSubImage::Errors::prepare()
154 {
155 /* OpenGL functions access point. */
156 const glw::Functions& gl = m_context.getRenderContext().getFunctions();
157
158 /* If already initialized throw exception. */
159 if (m_texture_1D || m_texture_1D_array || m_texture_2D || m_texture_rectangle || m_texture_2D_compressed ||
160 m_texture_2D_multisampled)
161 {
162 throw 0;
163 }
164
165 /* Generate texture ids. */
166 gl.genTextures(1, &m_texture_1D);
167 gl.genTextures(1, &m_texture_1D_array);
168 gl.genTextures(1, &m_texture_2D);
169 gl.genTextures(1, &m_texture_rectangle);
170 gl.genTextures(1, &m_texture_2D_compressed);
171 gl.genTextures(1, &m_texture_2D_multisampled);
172
173 GLU_EXPECT_NO_ERROR(gl.getError(), "glGenTextures call failed.");
174
175 /* If one is not initialized throw exception. */
176 if (!(m_texture_1D && m_texture_1D_array && m_texture_2D))
177 {
178 throw 0;
179 }
180
181 /* Upload texture data. */
182 gl.bindTexture(GL_TEXTURE_1D, m_texture_1D);
183 GLU_EXPECT_NO_ERROR(gl.getError(), "glBindTexture call failed.");
184
185 gl.texImage1D(GL_TEXTURE_1D, 0, GL_RGBA8, s_texture_data_width, 0, GL_RGBA, GL_UNSIGNED_BYTE, s_texture_data);
186 GLU_EXPECT_NO_ERROR(gl.getError(), "glTexImage1D call failed.");
187
188 gl.bindTexture(GL_TEXTURE_1D_ARRAY, m_texture_1D_array);
189 GLU_EXPECT_NO_ERROR(gl.getError(), "glBindTexture call failed.");
190
191 gl.texImage2D(GL_TEXTURE_1D_ARRAY, 0, GL_RGBA8, s_texture_data_width, s_texture_data_height, 0, GL_RGBA,
192 GL_UNSIGNED_BYTE, s_texture_data);
193 GLU_EXPECT_NO_ERROR(gl.getError(), "glTexImage1D call failed.");
194
195 gl.bindTexture(GL_TEXTURE_2D, m_texture_2D);
196 GLU_EXPECT_NO_ERROR(gl.getError(), "glBindTexture call failed.");
197
198 gl.texImage2D(GL_TEXTURE_2D, 0, GL_RGBA8, s_texture_data_width, s_texture_data_height, 0, GL_RGBA, GL_UNSIGNED_BYTE,
199 s_texture_data);
200 GLU_EXPECT_NO_ERROR(gl.getError(), "glTexImage1D call failed.");
201
202 gl.bindTexture(GL_TEXTURE_RECTANGLE, m_texture_rectangle);
203 GLU_EXPECT_NO_ERROR(gl.getError(), "glBindTexture call failed.");
204
205 gl.texImage2D(GL_TEXTURE_RECTANGLE, 0, GL_RGBA8, s_texture_data_width, s_texture_data_height, 0, GL_RGBA,
206 GL_UNSIGNED_BYTE, s_texture_data);
207 GLU_EXPECT_NO_ERROR(gl.getError(), "glTexImage1D call failed.");
208
209 /* Upload compressed texture data. */
210 gl.bindTexture(GL_TEXTURE_2D, m_texture_2D_compressed);
211 GLU_EXPECT_NO_ERROR(gl.getError(), "glBindTexture call failed.");
212
213 gl.compressedTexImage2D(GL_TEXTURE_2D, 0, GL_COMPRESSED_RGB8_ETC2, s_texture_data_compressed_width,
214 s_texture_data_compressed_height, 0, s_texture_data_compressed_size,
215 s_texture_data_compressed);
216 GLU_EXPECT_NO_ERROR(gl.getError(), "glTexImage1D call failed.");
217
218 /* Prepare multisampled texture storage. */
219 gl.bindTexture(GL_TEXTURE_2D_MULTISAMPLE, m_texture_2D_multisampled);
220 GLU_EXPECT_NO_ERROR(gl.getError(), "glBindTexture call failed.");
221
222 gl.texImage2DMultisample(GL_TEXTURE_2D_MULTISAMPLE, 1, GL_R8, s_texture_data_width, s_texture_data_height, GL_TRUE);
223 GLU_EXPECT_NO_ERROR(gl.getError(), "glTexImage1D call failed.");
224
225 /* Prepare function pointers. */
226 m_gl_GetTextureSubImage =
227 (PFNGLGETTEXTURESUBIMAGEPROC)m_context.getRenderContext().getProcAddress("glGetTextureSubImage");
228 m_gl_GetCompressedTextureSubImage =
229 (PFNGLGETCOMPRESSEDTEXTURESUBIMAGEPROC)m_context.getRenderContext().getProcAddress(
230 "glGetCompressedTextureSubImage");
231
232 if ((DE_NULL == m_gl_GetTextureSubImage) || (DE_NULL == m_gl_GetCompressedTextureSubImage))
233 {
234 throw 0;
235 }
236
237 /* Allocate destination buffer. */
238 m_destination_buffer = (glw::GLubyte*)malloc(s_destination_buffer_size);
239
240 if (DE_NULL == m_destination_buffer)
241 {
242 throw 0;
243 }
244 }
245
246 /** The function checks that GL_INVALID_OPERATION error is generated by GetTextureSubImage if
247 * texture is not the name of an existing texture object. It also checks that
248 * GL_INVALID_OPERATION error is generated by GetCompressedTextureSubImage if texture is not
249 * the name of an existing texture object. For reference see the OpenGL 4.5 Core Specification
250 * chapter 8.11.4.
251 *
252 * @return True if proper error values are generated, false otherwise.
253 */
testExistingTextureObjectError()254 bool gl4cts::GetTextureSubImage::Errors::testExistingTextureObjectError()
255 {
256 /* OpenGL functions access point. */
257 const glw::Functions& gl = m_context.getRenderContext().getFunctions();
258
259 /* Prepare invalid texture name. */
260 glw::GLuint invalid_texture = m_texture_2D_multisampled;
261
262 while (gl.isTexture(++invalid_texture))
263 ;
264
265 m_gl_GetTextureSubImage(invalid_texture, 0, 0, 0, 0, s_texture_data_width, s_texture_data_height, 1, GL_RGBA,
266 GL_UNSIGNED_BYTE, s_destination_buffer_size, m_destination_buffer);
267
268 glw::GLint error_value = gl.getError();
269 glw::GLint is_proper_error = (GL_INVALID_OPERATION == error_value);
270
271 if (!is_proper_error)
272 {
273 m_testCtx.getLog() << tcu::TestLog::Message << "GL_INVALID_OPERATION error is expected to be generated by "
274 "glGetTextureSubImage if texture is not the name of an existing "
275 "texture object (OpenGL 4.5 Core Specification chapter 8.11.4)."
276 << " However, the error value " << glu::getErrorName(error_value) << " was generated."
277 << tcu::TestLog::EndMessage;
278 }
279
280 m_gl_GetCompressedTextureSubImage(invalid_texture, 0, 0, 0, 0, s_texture_data_compressed_width,
281 s_texture_data_compressed_height, 1, s_destination_buffer_size,
282 m_destination_buffer);
283
284 error_value = gl.getError();
285
286 glw::GLint is_proper_error_compressed = (GL_INVALID_OPERATION == error_value);
287
288 if (!is_proper_error_compressed)
289 {
290 m_testCtx.getLog() << tcu::TestLog::Message
291 << "GL_INVALID_OPERATION error is expected to be generated by glGetCompressedTextureSubImage "
292 "if texture is not the name of an existing texture object (OpenGL 4.5 Core Specification "
293 "chapter 8.11.4)."
294 << " However, the error value " << glu::getErrorName(error_value) << " was generated."
295 << tcu::TestLog::EndMessage;
296 }
297
298 if (is_proper_error && is_proper_error_compressed)
299 {
300 return true;
301 }
302
303 return false;
304 }
305
306 /** The function checks that GL_INVALID_OPERATION error is generated if texture is the
307 * name of a buffer or multisample texture. For reference see OpenGL 4.5 Core Specification
308 * chapter 8.11.4.
309 *
310 * @return True if proper error values are generated, false otherwise.
311 */
testBufferOrMultisampledTargetError()312 bool gl4cts::GetTextureSubImage::Errors::testBufferOrMultisampledTargetError()
313 {
314 /* OpenGL functions access point. */
315 const glw::Functions& gl = m_context.getRenderContext().getFunctions();
316
317 /* Test. */
318 m_gl_GetTextureSubImage(m_texture_2D_multisampled, 0, 0, 0, 0, s_texture_data_width, s_texture_data_height, 1,
319 GL_RGBA, GL_UNSIGNED_BYTE, s_destination_buffer_size, m_destination_buffer);
320
321 glw::GLint error_value = gl.getError();
322 glw::GLint is_proper_error = (GL_INVALID_OPERATION == error_value);
323
324 if (!is_proper_error)
325 {
326 m_testCtx.getLog() << tcu::TestLog::Message << "GL_INVALID_OPERATION error is expected to be generated by "
327 "glGetTextureSubImage if texture is the name of multisample "
328 "texture (OpenGL 4.5 Core Specification chapter 8.11.4)."
329 << " However, the error value " << glu::getErrorName(error_value) << " was generated."
330 << tcu::TestLog::EndMessage;
331 }
332
333 if (is_proper_error)
334 {
335 return true;
336 }
337
338 return false;
339 }
340
341 /** The functions checks that GL_INVALID_VALUE is generated if xoffset, yoffset or
342 * zoffset are negative. For reference see OpenGL 4.5 Core Specification
343 * chapter 8.11.4.
344 *
345 * @return True if proper error values are generated, false otherwise.
346 */
testNegativeOffsetError()347 bool gl4cts::GetTextureSubImage::Errors::testNegativeOffsetError()
348 {
349 /* OpenGL functions access point. */
350 const glw::Functions& gl = m_context.getRenderContext().getFunctions();
351
352 /* Test. */
353 m_gl_GetTextureSubImage(m_texture_2D, 0, -1, 0, 0, s_texture_data_width, s_texture_data_height, 1, GL_RGBA,
354 GL_UNSIGNED_BYTE, s_destination_buffer_size, m_destination_buffer);
355
356 glw::GLint error_value = gl.getError();
357 glw::GLint is_proper_error = (GL_INVALID_VALUE == error_value);
358
359 if (!is_proper_error)
360 {
361 m_testCtx.getLog() << tcu::TestLog::Message
362 << "GL_INVALID_VALUE error is expected to be generated by glGetTextureSubImage if xoffset, "
363 "yoffset or zoffset are negative (OpenGL 4.5 Core Specification chapter 8.11.4)."
364 << " However, the error value " << glu::getErrorName(error_value) << " was generated."
365 << tcu::TestLog::EndMessage;
366 }
367
368 m_gl_GetCompressedTextureSubImage(m_texture_2D_compressed, 0, -1, 0, 0, s_texture_data_compressed_width,
369 s_texture_data_compressed_height, 1, s_destination_buffer_size,
370 m_destination_buffer);
371
372 error_value = gl.getError();
373
374 glw::GLint is_proper_error_compressed = (GL_INVALID_VALUE == error_value);
375
376 if (!is_proper_error_compressed)
377 {
378 m_testCtx.getLog() << tcu::TestLog::Message
379 << "GL_INVALID_VALUE error is expected to be generated by glGetCompressedTextureSubImage if "
380 "xoffset, yoffset or zoffset are negative (OpenGL 4.5 Core Specification chapter 8.11.4)."
381 << " However, the error value " << glu::getErrorName(error_value) << " was generated."
382 << tcu::TestLog::EndMessage;
383 }
384
385 if (is_proper_error && is_proper_error_compressed)
386 {
387 return true;
388 }
389
390 return false;
391 }
392
393 /** The functions checks that GL_INVALID_VALUE is generated if xoffset + width is
394 * greater than the texture's width, yoffset + height is greater than
395 * the texture's height, or zoffset + depth is greater than the
396 * texture's depth. For reference see OpenGL 4.5 Core Specification
397 * chapter 8.11.4.
398 *
399 * @return True if proper error values are generated, false otherwise.
400 */
testBoundsError()401 bool gl4cts::GetTextureSubImage::Errors::testBoundsError()
402 {
403 /* OpenGL functions access point. */
404 const glw::Functions& gl = m_context.getRenderContext().getFunctions();
405
406 /* Uncompresse texture test. */
407 m_gl_GetTextureSubImage(m_texture_2D, 0, s_texture_data_width, s_texture_data_height, 0, s_texture_data_width * 2,
408 s_texture_data_height * 2, 1, GL_RGBA, GL_UNSIGNED_BYTE, s_destination_buffer_size,
409 m_destination_buffer);
410
411 glw::GLint error_value = gl.getError();
412 glw::GLint is_proper_error = (GL_INVALID_VALUE == error_value);
413
414 if (!is_proper_error)
415 {
416 m_testCtx.getLog()
417 << tcu::TestLog::Message
418 << "GL_INVALID_VALUE error is expected to be generated by glGetTextureSubImage if xoffset + width is"
419 " greater than the texture's width, yoffset + height is greater than"
420 " the texture's height, or zoffset + depth is greater than the"
421 " texture's depth. (OpenGL 4.5 Core Specification chapter 8.11.4)."
422 " However, the error value "
423 << glu::getErrorName(error_value) << " was generated." << tcu::TestLog::EndMessage;
424 }
425
426 /* Compresse texture test. */
427 m_gl_GetCompressedTextureSubImage(m_texture_2D_compressed, 0, s_texture_data_compressed_width,
428 s_texture_data_compressed_height, 0, s_texture_data_compressed_width * 2,
429 s_texture_data_compressed_height * 2, 1, s_destination_buffer_size,
430 m_destination_buffer);
431
432 error_value = gl.getError();
433
434 glw::GLint is_proper_error_compressed = (GL_INVALID_VALUE == error_value);
435
436 if (!is_proper_error_compressed)
437 {
438 m_testCtx.getLog() << tcu::TestLog::Message
439 << "GL_INVALID_VALUE error is expected to be generated by glGetCompressedTextureSubImage if "
440 "xoffset + width is"
441 " greater than the texture's width, yoffset + height is greater than"
442 " the texture's height, or zoffset + depth is greater than the"
443 " texture's depth. (OpenGL 4.5 Core Specification chapter 8.11.4)."
444 " However, the error value "
445 << glu::getErrorName(error_value) << " was generated." << tcu::TestLog::EndMessage;
446 }
447
448 if (is_proper_error && is_proper_error_compressed)
449 {
450 return true;
451 }
452
453 return false;
454 }
455
456 /** The functions checks that GL_INVALID_VALUE error is generated if the effective
457 * target is GL_TEXTURE_1D and either yoffset is not zero, or height
458 * is not one. For reference see OpenGL 4.5 Core Specification
459 * chapter 8.11.4.
460 *
461 * @return True if proper error values are generated, false otherwise.
462 */
testOneDimmensionalTextureErrors()463 bool gl4cts::GetTextureSubImage::Errors::testOneDimmensionalTextureErrors()
464 {
465 /* OpenGL functions access point. */
466 const glw::Functions& gl = m_context.getRenderContext().getFunctions();
467
468 /* Test. */
469 m_gl_GetTextureSubImage(m_texture_1D, 0, 0, 1, 0, s_texture_data_width, 2, 1, GL_RGBA, GL_UNSIGNED_BYTE,
470 s_destination_buffer_size, m_destination_buffer);
471
472 glw::GLint error_value = gl.getError();
473 glw::GLint is_proper_error = (GL_INVALID_VALUE == error_value);
474
475 if (!is_proper_error)
476 {
477 m_testCtx.getLog()
478 << tcu::TestLog::Message
479 << "GL_INVALID_VALUE error is expected to be generated by glGetTextureSubImage if the effective"
480 " target is GL_TEXTURE_1D and either yoffset is not zero, or height"
481 " is not one (OpenGL 4.5 Core Specification chapter 8.11.4)."
482 " However, the error value "
483 << glu::getErrorName(error_value) << " was generated." << tcu::TestLog::EndMessage;
484 }
485
486 if (is_proper_error)
487 {
488 return true;
489 }
490
491 return false;
492 }
493
494 /** The functions checks that GL_INVALID_VALUE error is generated if the effective
495 * target is GL_TEXTURE_1D, GL_TEXTURE_1D_ARRAY, GL_TEXTURE_2D or
496 * GL_TEXTURE_RECTANGLE and either zoffset is not zero, or depth
497 * is not one. For reference see OpenGL 4.5 Core Specification
498 * chapter 8.11.4.
499 *
500 * @return True if proper error values are generated, false otherwise.
501 */
testTwoDimmensionalTextureErrors()502 bool gl4cts::GetTextureSubImage::Errors::testTwoDimmensionalTextureErrors()
503 {
504 /* OpenGL functions access point. */
505 const glw::Functions& gl = m_context.getRenderContext().getFunctions();
506
507 /* Test. */
508 const struct
509 {
510 glw::GLuint id;
511 const glw::GLchar* target_name;
512 } test_textures[] = { { m_texture_1D, "GL_TEXTURE_1D" },
513 { m_texture_1D_array, "GL_TEXTURE_1D_ARRAY" },
514 { m_texture_2D, "GL_TEXTURE_2D" } };
515
516 static const glw::GLuint test_textures_size = sizeof(test_textures) / sizeof(test_textures[0]);
517
518 glw::GLint is_error = true;
519
520 for (glw::GLuint i = 0; i < test_textures_size; ++i)
521 {
522 m_gl_GetTextureSubImage(test_textures[i].id, 0, 0, 0, 1, s_texture_data_width,
523 (test_textures[i].id == m_texture_1D) ? 1 : s_texture_data_height, 2, GL_RGBA,
524 GL_UNSIGNED_BYTE, s_destination_buffer_size, m_destination_buffer);
525
526 glw::GLint error_value = gl.getError();
527 glw::GLint is_proper_error = (GL_INVALID_VALUE == error_value);
528
529 if (!is_proper_error)
530 {
531 is_error = false;
532
533 m_testCtx.getLog()
534 << tcu::TestLog::Message
535 << "GL_INVALID_VALUE error is expected to be generated by glGetTextureSubImage if the effective"
536 " target is "
537 << test_textures[i].target_name << " and either zoffset is not zero, or depth"
538 " is not one. (OpenGL 4.5 Core Specification chapter 8.11.4)."
539 " However, the error value "
540 << glu::getErrorName(error_value) << " was generated." << tcu::TestLog::EndMessage;
541 }
542 }
543
544 /* Test (compressed textures). */
545 const struct
546 {
547 glw::GLuint id;
548 const glw::GLchar* target_name;
549 } test_compressed_textures[] = { { m_texture_2D_compressed, "GL_TEXTURE_2D" } };
550
551 static const glw::GLuint test_compressed_textures_size =
552 sizeof(test_compressed_textures) / sizeof(test_compressed_textures[0]);
553
554 for (glw::GLuint i = 0; i < test_compressed_textures_size; ++i)
555 {
556 m_gl_GetCompressedTextureSubImage(test_compressed_textures[i].id, 0, 0, 0, 1, s_texture_data_compressed_width,
557 s_texture_data_compressed_height, 2, s_destination_buffer_size,
558 m_destination_buffer);
559
560 glw::GLint error_value = gl.getError();
561
562 glw::GLint is_proper_error_compressed = (GL_INVALID_VALUE == error_value);
563
564 if (!is_proper_error_compressed)
565 {
566 is_error = false;
567
568 m_testCtx.getLog() << tcu::TestLog::Message << "GL_INVALID_VALUE error is expected to be generated by "
569 "glGetCompressedTextureSubImage if the effective"
570 " target is "
571 << test_compressed_textures[i].target_name
572 << " and either zoffset is not zero, or depth"
573 " is not one. (OpenGL 4.5 Core Specification chapter 8.11.4)."
574 " However, the error value "
575 << glu::getErrorName(error_value) << " was generated." << tcu::TestLog::EndMessage;
576 }
577 }
578
579 if (is_error)
580 {
581 return true;
582 }
583
584 return false;
585 }
586
587 /** The functions checks that GL_INVALID_OPERATION error is generated if the buffer
588 * size required to store the requested data is greater than bufSize.
589 * For reference see OpenGL 4.5 Core Specification chapter 8.11.4.
590 *
591 * @return True if proper error values are generated, false otherwise.
592 */
testBufferSizeError()593 bool gl4cts::GetTextureSubImage::Errors::testBufferSizeError()
594 {
595 /* OpenGL functions access point. */
596 const glw::Functions& gl = m_context.getRenderContext().getFunctions();
597
598 /* Test for uncompressed texture. */
599 m_gl_GetTextureSubImage(m_texture_2D, 0, 0, 0, 0, s_texture_data_width, s_texture_data_height, 1, GL_RGBA,
600 GL_UNSIGNED_BYTE, 1, m_destination_buffer);
601
602 glw::GLint error_value = gl.getError();
603 glw::GLint is_proper_error = (GL_INVALID_OPERATION == error_value);
604
605 if (!is_proper_error)
606 {
607 m_testCtx.getLog()
608 << tcu::TestLog::Message
609 << "GL_INVALID_OPERATION error is expected to be generated by glGetTextureSubImage if the buffer"
610 " size required to store the requested data is greater than bufSize. (OpenGL 4.5 Core Specification "
611 "chapter 8.11.4)."
612 " However, the error value "
613 << glu::getErrorName(error_value) << " was generated." << tcu::TestLog::EndMessage;
614 }
615
616 /* Test for compressed texture. */
617 m_gl_GetCompressedTextureSubImage(m_texture_2D_compressed, 0, 0, 0, 0, s_texture_data_compressed_width,
618 s_texture_data_compressed_height, 1, 1, m_destination_buffer);
619
620 error_value = gl.getError();
621
622 glw::GLint is_proper_error_compressed = (GL_INVALID_OPERATION == error_value);
623
624 if (!is_proper_error_compressed)
625 {
626 m_testCtx.getLog()
627 << tcu::TestLog::Message
628 << "GL_INVALID_OPERATION error is expected to be generated by glGetCompressedTextureSubImage if the buffer"
629 " size required to store the requested data is greater than bufSize. (OpenGL 4.5 Core Specification "
630 "chapter 8.11.4)."
631 " However, the error value "
632 << glu::getErrorName(error_value) << " was generated." << tcu::TestLog::EndMessage;
633 }
634
635 /* Return results. */
636 if (is_proper_error && is_proper_error_compressed)
637 {
638 return true;
639 }
640
641 return false;
642 }
643
clean()644 void gl4cts::GetTextureSubImage::Errors::clean()
645 {
646 /* OpenGL functions access point. */
647 const glw::Functions& gl = m_context.getRenderContext().getFunctions();
648
649 /*Textures cleanup. */
650 if (m_texture_1D)
651 {
652 gl.deleteTextures(1, &m_texture_1D);
653 m_texture_1D = 0;
654 }
655
656 if (m_texture_1D_array)
657 {
658 gl.deleteTextures(1, &m_texture_1D_array);
659 m_texture_1D_array = 0;
660 }
661
662 if (m_texture_2D)
663 {
664 gl.deleteTextures(1, &m_texture_2D);
665 m_texture_2D = 0;
666 }
667 if (m_texture_rectangle)
668 {
669 gl.deleteTextures(1, &m_texture_rectangle);
670 m_texture_rectangle = 0;
671 }
672
673 if (m_texture_2D_compressed)
674 {
675 gl.deleteTextures(1, &m_texture_2D_compressed);
676 m_texture_2D_compressed = 0;
677 }
678
679 if (m_texture_2D_multisampled)
680 {
681 gl.deleteTextures(1, &m_texture_2D_multisampled);
682 m_texture_2D_multisampled = 0;
683 }
684
685 /* CPU buffers */
686 if (m_destination_buffer)
687 {
688 free(m_destination_buffer);
689 m_destination_buffer = DE_NULL;
690 }
691 }
692
693 /* Uncompressed source texture 2x2 pixels */
694
695 const glw::GLubyte gl4cts::GetTextureSubImage::Errors::s_texture_data[] = {
696 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15
697 }; //<! uncompressed texture
698
699 const glw::GLuint gl4cts::GetTextureSubImage::Errors::s_texture_data_size =
700 sizeof(s_texture_data); //<! uncompressed texture size
701
702 const glw::GLuint gl4cts::GetTextureSubImage::Errors::s_texture_data_width = 2; //<! uncompressed texture width
703
704 const glw::GLuint gl4cts::GetTextureSubImage::Errors::s_texture_data_height = 2; //<! uncompressed texture height
705
706 /* ETC2 compressed texture (4x4 pixels === 1 block) */
707
708 const glw::GLubyte gl4cts::GetTextureSubImage::Errors::s_texture_data_compressed[] = {
709 0x15, 0x90, 0x33, 0x6f, 0xaf, 0xcc, 0x16, 0x98
710 }; //<! ETC2 compressed texture
711
712 const glw::GLuint gl4cts::GetTextureSubImage::Errors::s_texture_data_compressed_size =
713 sizeof(s_texture_data_compressed); //<! ETC2 compressed texture size
714
715 const glw::GLuint gl4cts::GetTextureSubImage::Errors::s_texture_data_compressed_width =
716 4; //<! ETC2 compressed texture width
717
718 const glw::GLuint gl4cts::GetTextureSubImage::Errors::s_texture_data_compressed_height =
719 4; //<! ETC2 compressed texture height
720
721 const glw::GLuint gl4cts::GetTextureSubImage::Errors::s_destination_buffer_size =
722 (s_texture_data_size > s_texture_data_compressed_size) ?
723 s_texture_data_size :
724 s_texture_data_compressed_size; //<! size of the destination buffer (for fetched data)
725
726 /*****************************************************************************************************
727 * Functional Test Implementation *
728 *****************************************************************************************************/
729
730 /** Constructor of the functional test.
731 *
732 * @param [in] context OpenGL context in which test shall run.
733 */
Functional(deqp::Context & context)734 gl4cts::GetTextureSubImage::Functional::Functional(deqp::Context& context)
735 : deqp::TestCase(context, "functional_test", "Get Texture SubImage Functional Test")
736 , m_context(context)
737 , m_texture(0)
738 {
739 }
740
741 /** Destructor of the functional test.
742 */
~Functional(void)743 gl4cts::GetTextureSubImage::Functional::~Functional(void)
744 {
745 }
746
747 /** Iterate over functional test cases.
748 */
iterate(void)749 tcu::TestNode::IterateResult gl4cts::GetTextureSubImage::Functional::iterate(void)
750 {
751 bool is_ok = true;
752 bool test_error = false;
753
754 bool is_at_least_gl_45 = (glu::contextSupports(m_context.getRenderContext().getType(), glu::ApiType::core(4, 5)));
755 bool is_arb_get_texture_sub_image = m_context.getContextInfo().isExtensionSupported("GL_ARB_get_texture_sub_image");
756
757 /* Bind function pointers. */
758 m_gl_GetCompressedTextureSubImage =
759 (PFNGLGETCOMPRESSEDTEXTURESUBIMAGEPROC)m_context.getRenderContext().getProcAddress(
760 "glGetCompressedTextureSubImage");
761 m_gl_GetTextureSubImage =
762 (PFNGLGETTEXTURESUBIMAGEPROC)m_context.getRenderContext().getProcAddress("glGetTextureSubImage");
763
764 try
765 {
766 /* Report error when function pointers are not available. */
767 if ((DE_NULL == m_gl_GetCompressedTextureSubImage) || (DE_NULL == m_gl_GetTextureSubImage))
768 {
769 m_testCtx.getLog()
770 << tcu::TestLog::Message
771 << "Cannot obtain glGetCompressedTextureSubImage or glGetTextureSubImage function pointer."
772 << tcu::TestLog::EndMessage;
773 throw 0;
774 }
775
776 /* Run tests. */
777 if (is_at_least_gl_45 || is_arb_get_texture_sub_image)
778 {
779 /* Tested targets. */
780 glw::GLenum targets[] = { GL_TEXTURE_1D, GL_TEXTURE_1D_ARRAY, GL_TEXTURE_2D,
781 GL_TEXTURE_RECTANGLE, GL_TEXTURE_CUBE_MAP, GL_TEXTURE_CUBE_MAP_ARRAY,
782 GL_TEXTURE_2D_ARRAY, GL_TEXTURE_3D };
783
784 glw::GLuint targets_count = sizeof(targets) / sizeof(targets[0]);
785
786 for (glw::GLuint i = 0; i < targets_count; ++i)
787 {
788 prepare(targets[i], false);
789
790 is_ok &= check(targets[i], false);
791
792 clean();
793 }
794
795 /* Compressed textures tested targets. */
796 glw::GLenum compressed_targets[] = { GL_TEXTURE_2D, GL_TEXTURE_CUBE_MAP, GL_TEXTURE_CUBE_MAP_ARRAY,
797 GL_TEXTURE_2D_ARRAY };
798
799 glw::GLuint compressed_targets_count = sizeof(compressed_targets) / sizeof(compressed_targets[0]);
800
801 for (glw::GLuint i = 0; i < compressed_targets_count; ++i)
802 {
803 prepare(compressed_targets[i], true);
804
805 is_ok &= check(compressed_targets[i], true);
806
807 clean();
808 }
809 }
810 }
811 catch (...)
812 {
813 m_testCtx.getLog() << tcu::TestLog::Message << "Test error has occured." << tcu::TestLog::EndMessage;
814
815 is_ok = false;
816 test_error = true;
817
818 clean();
819 }
820
821 /* Result's setup. */
822 if (is_ok)
823 {
824 m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass");
825 }
826 else
827 {
828 if (test_error)
829 {
830 m_testCtx.setTestResult(QP_TEST_RESULT_INTERNAL_ERROR, "Error");
831 }
832 else
833 {
834 m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail");
835 }
836 }
837
838 return STOP;
839 }
840
841 /** Prepare source texture for the test.
842 *
843 * @param [in] target Target of the texture to be prepared.
844 * @param [in] is_compressed Flag indicating that texture shall be compressed (true) or uncompressed (false).
845 */
prepare(glw::GLenum target,bool is_compressed)846 void gl4cts::GetTextureSubImage::Functional::prepare(glw::GLenum target, bool is_compressed)
847 {
848 /* OpenGL functions access point. */
849 const glw::Functions& gl = m_context.getRenderContext().getFunctions();
850
851 /* Generate and bind texture. */
852 gl.genTextures(1, &m_texture);
853 GLU_EXPECT_NO_ERROR(gl.getError(), "glGenTextures call failed.");
854
855 gl.bindTexture(target, m_texture);
856 GLU_EXPECT_NO_ERROR(gl.getError(), "glBindTexture call failed.");
857
858 /* Upload data to the texture. */
859 if (is_compressed)
860 {
861 /* Upload compressed texture. */
862 switch (target)
863 {
864 case GL_TEXTURE_2D:
865 gl.compressedTexImage2D(target, 0, GL_COMPRESSED_RGBA_BPTC_UNORM, s_texture_data_width, s_texture_data_height, 0,
866 s_texture_data_compressed_size / s_texture_data_depth, s_texture_data_compressed);
867 GLU_EXPECT_NO_ERROR(gl.getError(), "glCompressedTexImage2D call failed.");
868 break;
869 case GL_TEXTURE_CUBE_MAP:
870 gl.compressedTexImage2D(
871 GL_TEXTURE_CUBE_MAP_POSITIVE_X, 0, GL_COMPRESSED_RGBA_BPTC_UNORM, s_texture_data_width, s_texture_data_height,
872 0, s_texture_data_compressed_size / s_texture_data_depth,
873 &s_texture_data_compressed[0 * s_texture_data_compressed_size / s_texture_data_depth]);
874 gl.compressedTexImage2D(
875 GL_TEXTURE_CUBE_MAP_NEGATIVE_X, 0, GL_COMPRESSED_RGBA_BPTC_UNORM, s_texture_data_width, s_texture_data_height,
876 0, s_texture_data_compressed_size / s_texture_data_depth,
877 &s_texture_data_compressed[1 * s_texture_data_compressed_size / s_texture_data_depth]);
878 gl.compressedTexImage2D(
879 GL_TEXTURE_CUBE_MAP_POSITIVE_Y, 0, GL_COMPRESSED_RGBA_BPTC_UNORM, s_texture_data_width, s_texture_data_height,
880 0, s_texture_data_compressed_size / s_texture_data_depth,
881 &s_texture_data_compressed[2 * s_texture_data_compressed_size / s_texture_data_depth]);
882 gl.compressedTexImage2D(
883 GL_TEXTURE_CUBE_MAP_NEGATIVE_Y, 0, GL_COMPRESSED_RGBA_BPTC_UNORM, s_texture_data_width, s_texture_data_height,
884 0, s_texture_data_compressed_size / s_texture_data_depth,
885 &s_texture_data_compressed[3 * s_texture_data_compressed_size / s_texture_data_depth]);
886 gl.compressedTexImage2D(
887 GL_TEXTURE_CUBE_MAP_POSITIVE_Z, 0, GL_COMPRESSED_RGBA_BPTC_UNORM, s_texture_data_width, s_texture_data_height,
888 0, s_texture_data_compressed_size / s_texture_data_depth,
889 &s_texture_data_compressed[4 * s_texture_data_compressed_size / s_texture_data_depth]);
890 gl.compressedTexImage2D(
891 GL_TEXTURE_CUBE_MAP_NEGATIVE_Z, 0, GL_COMPRESSED_RGBA_BPTC_UNORM, s_texture_data_width, s_texture_data_height,
892 0, s_texture_data_compressed_size / s_texture_data_depth,
893 &s_texture_data_compressed[5 * s_texture_data_compressed_size / s_texture_data_depth]);
894 GLU_EXPECT_NO_ERROR(gl.getError(), "glCompressedTexImage2D call failed.");
895 break;
896 case GL_TEXTURE_CUBE_MAP_ARRAY:
897 gl.compressedTexImage3D(target, 0, GL_COMPRESSED_RGBA_BPTC_UNORM, s_texture_data_width, s_texture_data_height, 6,
898 0, s_texture_data_compressed_size / s_texture_data_depth * 6,
899 s_texture_data_compressed);
900 GLU_EXPECT_NO_ERROR(gl.getError(), "glCompressedTexImage3D call failed.");
901 break;
902 case GL_TEXTURE_2D_ARRAY:
903 gl.compressedTexImage3D(target, 0, GL_COMPRESSED_RGBA_BPTC_UNORM, s_texture_data_width, s_texture_data_height,
904 s_texture_data_depth, 0, s_texture_data_compressed_size, s_texture_data_compressed);
905 GLU_EXPECT_NO_ERROR(gl.getError(), "glCompressedTexImage3D call failed.");
906 break;
907 default:
908 throw 0;
909 };
910 }
911 else
912 {
913 /* Upload uncompressed texture. */
914 switch (target)
915 {
916 case GL_TEXTURE_1D:
917 gl.texImage1D(target, 0, GL_RGBA8, s_texture_data_width, 0, GL_RGBA, GL_UNSIGNED_BYTE, s_texture_data);
918 GLU_EXPECT_NO_ERROR(gl.getError(), "glTexImage1D call failed.");
919 break;
920 case GL_TEXTURE_1D_ARRAY:
921 case GL_TEXTURE_2D:
922 case GL_TEXTURE_RECTANGLE:
923 gl.texImage2D(target, 0, GL_RGBA8, s_texture_data_width, s_texture_data_height, 0, GL_RGBA,
924 GL_UNSIGNED_BYTE, s_texture_data);
925 GLU_EXPECT_NO_ERROR(gl.getError(), "glTexImage2D call failed.");
926 break;
927 case GL_TEXTURE_CUBE_MAP:
928 gl.texImage2D(GL_TEXTURE_CUBE_MAP_POSITIVE_X, 0, GL_RGBA8, s_texture_data_width, s_texture_data_height, 0,
929 GL_RGBA, GL_UNSIGNED_BYTE,
930 &s_texture_data[0 * s_texture_data_width * s_texture_data_height * 4 /* RGBA */]);
931 gl.texImage2D(GL_TEXTURE_CUBE_MAP_NEGATIVE_X, 0, GL_RGBA8, s_texture_data_width, s_texture_data_height, 0,
932 GL_RGBA, GL_UNSIGNED_BYTE,
933 &s_texture_data[1 * s_texture_data_width * s_texture_data_height * 4 /* RGBA */]);
934 gl.texImage2D(GL_TEXTURE_CUBE_MAP_POSITIVE_Y, 0, GL_RGBA8, s_texture_data_width, s_texture_data_height, 0,
935 GL_RGBA, GL_UNSIGNED_BYTE,
936 &s_texture_data[2 * s_texture_data_width * s_texture_data_height * 4 /* RGBA */]);
937 gl.texImage2D(GL_TEXTURE_CUBE_MAP_NEGATIVE_Y, 0, GL_RGBA8, s_texture_data_width, s_texture_data_height, 0,
938 GL_RGBA, GL_UNSIGNED_BYTE,
939 &s_texture_data[3 * s_texture_data_width * s_texture_data_height * 4 /* RGBA */]);
940 gl.texImage2D(GL_TEXTURE_CUBE_MAP_POSITIVE_Z, 0, GL_RGBA8, s_texture_data_width, s_texture_data_height, 0,
941 GL_RGBA, GL_UNSIGNED_BYTE,
942 &s_texture_data[4 * s_texture_data_width * s_texture_data_height * 4 /* RGBA */]);
943 gl.texImage2D(GL_TEXTURE_CUBE_MAP_NEGATIVE_Z, 0, GL_RGBA8, s_texture_data_width, s_texture_data_height, 0,
944 GL_RGBA, GL_UNSIGNED_BYTE,
945 &s_texture_data[5 * s_texture_data_width * s_texture_data_height * 4 /* RGBA */]);
946 GLU_EXPECT_NO_ERROR(gl.getError(), "glTexImage2D call failed.");
947 break;
948 case GL_TEXTURE_CUBE_MAP_ARRAY:
949 gl.texImage3D(target, 0, GL_RGBA8, s_texture_data_width, s_texture_data_height, 6, 0, GL_RGBA,
950 GL_UNSIGNED_BYTE, s_texture_data);
951 GLU_EXPECT_NO_ERROR(gl.getError(), "glTexImage3D call failed.");
952 break;
953 case GL_TEXTURE_2D_ARRAY:
954 case GL_TEXTURE_3D:
955 gl.texImage3D(target, 0, GL_RGBA8, s_texture_data_width, s_texture_data_height, s_texture_data_depth, 0,
956 GL_RGBA, GL_UNSIGNED_BYTE, s_texture_data);
957 GLU_EXPECT_NO_ERROR(gl.getError(), "glTexImage3D call failed.");
958 break;
959 default:
960 throw 0;
961 };
962 }
963 }
964
965 /** Test that Get(Compressed)TextureSubImage resturns expected texture data.
966 *
967 * @param [in] target Target of the texture to be prepared.
968 * @param [in] is_compressed Flag indicating that texture shall be compressed (true) or uncompressed (false).
969 *
970 * @return True if test succeeded, false otherwise.
971 */
check(glw::GLenum target,bool is_compressed)972 bool gl4cts::GetTextureSubImage::Functional::check(glw::GLenum target, bool is_compressed)
973 {
974 /* OpenGL functions access point. */
975 const glw::Functions& gl = m_context.getRenderContext().getFunctions();
976
977 /* Arguments setup (depends on dimmension) */
978 glw::GLint x_offset = s_texture_data_width / 2 /* half */;
979 glw::GLint width = s_texture_data_width / 2 /* half */;
980
981 glw::GLint y_offset = 0;
982 glw::GLint height = 1;
983
984 glw::GLint z_offset = 0;
985 glw::GLint depth = 1;
986
987 /* For 2 and 3 -dimensional textures setup y-direction. */
988 if (GL_TEXTURE_1D != target)
989 {
990 y_offset = s_texture_data_height / 2 /* half */;
991 height = s_texture_data_height / 2 /* half */;
992 }
993
994 /* For 3-dimensional textures setup z-direction. */
995 if ((GL_TEXTURE_3D == target) || (GL_TEXTURE_2D_ARRAY == target))
996 {
997 z_offset = s_texture_data_depth / 2 /* half */;
998 depth = s_texture_data_depth / 2 /* half */;
999 }
1000
1001 /* For cube-map texture stup 6-cube faces. */
1002 if ((GL_TEXTURE_CUBE_MAP == target) || (GL_TEXTURE_CUBE_MAP_ARRAY == target))
1003 {
1004 z_offset = 3; /* half of cube map */
1005 depth = 3; /* half of cube map */
1006 }
1007
1008 /* Setup number of components. */
1009 glw::GLint number_of_components = 0;
1010
1011 if (is_compressed)
1012 {
1013 number_of_components = 16; /* 128 bit block of 4x4 compressed pixels. */
1014 }
1015 else
1016 {
1017 number_of_components = 4; /* RGBA components. */
1018 }
1019
1020 /* Setup size. */
1021 glw::GLsizei size = 0;
1022
1023 /* Iterate over pixels. */
1024 glw::GLint x_block = 1;
1025 glw::GLint y_block = 1;
1026
1027 if (is_compressed)
1028 {
1029 /* Iterate over 4x4 compressed pixel block. */
1030 x_block = 4;
1031 y_block = 4;
1032
1033 size = static_cast<glw::GLsizei>((width / x_block) * (height / y_block) * depth * number_of_components *
1034 sizeof(glw::GLubyte));
1035 }
1036 else
1037 {
1038 size = static_cast<glw::GLsizei>(width * height * depth * number_of_components * sizeof(glw::GLubyte));
1039 }
1040
1041 /* Storage for fetched texturte. */
1042 glw::GLubyte* texture_data = new glw::GLubyte[size];
1043
1044 if (DE_NULL == texture_data)
1045 {
1046 throw 0;
1047 }
1048
1049 /* Fetching texture. */
1050 if (is_compressed)
1051 {
1052 m_gl_GetCompressedTextureSubImage(m_texture, 0, x_offset, y_offset, z_offset, width, height, depth, size,
1053 texture_data);
1054 }
1055 else
1056 {
1057 m_gl_GetTextureSubImage(m_texture, 0, x_offset, y_offset, z_offset, width, height, depth, GL_RGBA,
1058 GL_UNSIGNED_BYTE, size, texture_data);
1059 }
1060
1061 /* Comprae fetched texture with reference. */
1062 glw::GLint error = gl.getError();
1063
1064 bool is_ok = true;
1065
1066 if (GL_NO_ERROR == error)
1067 {
1068 for (glw::GLint k = 0; k < depth; ++k)
1069 {
1070 for (glw::GLint j = 0; j < height / y_block; ++j)
1071 {
1072 for (glw::GLint i = 0; i < width / x_block; ++i)
1073 {
1074 for (glw::GLint c = 0; c < number_of_components; ++c) /* RGBA components iterating */
1075 {
1076 glw::GLuint reference_data_position =
1077 (i + (x_offset / x_block)) * number_of_components +
1078 (j + (y_offset / y_block)) * s_texture_data_width / x_block * number_of_components +
1079 (k + z_offset) * s_texture_data_width / x_block * s_texture_data_height / y_block *
1080 number_of_components +
1081 c;
1082
1083 glw::GLuint tested_data_position =
1084 i * number_of_components + j * width / x_block * number_of_components +
1085 k * width / x_block * height / y_block * number_of_components + c;
1086
1087 glw::GLubyte reference_value = (is_compressed) ?
1088 s_texture_data_compressed[reference_data_position] :
1089 s_texture_data[reference_data_position];
1090 glw::GLubyte tested_value = texture_data[tested_data_position];
1091
1092 if (reference_value != tested_value)
1093 {
1094 is_ok = false;
1095 break;
1096 }
1097 }
1098 }
1099 }
1100 }
1101 }
1102 else
1103 {
1104 /* GL error. */
1105 delete[] texture_data;
1106 throw 0;
1107 }
1108
1109 /* Cleanup. */
1110 delete[] texture_data;
1111
1112 /* Error reporting. */
1113 if (!is_ok)
1114 {
1115 m_testCtx.getLog() << tcu::TestLog::Message << "Functional test of "
1116 << ((is_compressed) ? "glGetCompressedTextureSubImage " : "glGetTextureSubImage ")
1117 << "function has failed with target " << glu::getTextureTargetStr(target) << "."
1118 << tcu::TestLog::EndMessage;
1119 }
1120
1121 /* Return result. */
1122 return is_ok;
1123 }
1124
1125 /** Clean texture. */
clean()1126 void gl4cts::GetTextureSubImage::Functional::clean()
1127 {
1128 /* OpenGL functions access point. */
1129 const glw::Functions& gl = m_context.getRenderContext().getFunctions();
1130
1131 if (m_texture)
1132 {
1133 gl.deleteTextures(1, &m_texture);
1134
1135 m_texture = 0;
1136 }
1137 }
1138
1139 /** RGBA 8x8x8 pixels in size source texture for testing GetTextureSubImage. */
1140 const glw::GLubyte gl4cts::GetTextureSubImage::Functional::s_texture_data[] = {
1141 0, 0, 0, 0, 0, 0, 32, 1, 0, 0, 64, 2, 0, 0, 96, 3,
1142 0, 0, 128, 4, 0, 0, 160, 5, 0, 0, 192, 6, 0, 0, 224, 7,
1143
1144 0, 32, 0, 1, 0, 32, 32, 2, 0, 32, 64, 3, 0, 32, 96, 4,
1145 0, 32, 128, 5, 0, 32, 160, 6, 0, 32, 192, 7, 0, 32, 224, 8,
1146
1147 0, 64, 0, 2, 0, 64, 32, 3, 0, 64, 64, 4, 0, 64, 96, 5,
1148 0, 64, 128, 6, 0, 64, 160, 7, 0, 64, 192, 8, 0, 64, 224, 9,
1149
1150 0, 96, 0, 3, 0, 96, 32, 4, 0, 96, 64, 5, 0, 96, 96, 6,
1151 0, 96, 128, 7, 0, 96, 160, 8, 0, 96, 192, 9, 0, 96, 224, 10,
1152
1153 0, 128, 0, 4, 0, 128, 32, 5, 0, 128, 64, 6, 0, 128, 96, 7,
1154 0, 128, 128, 8, 0, 128, 160, 9, 0, 128, 192, 10, 0, 128, 224, 11,
1155
1156 0, 160, 0, 5, 0, 160, 32, 6, 0, 160, 64, 7, 0, 160, 96, 8,
1157 0, 160, 128, 9, 0, 160, 160, 10, 0, 160, 192, 11, 0, 160, 224, 12,
1158
1159 0, 192, 0, 6, 0, 192, 32, 7, 0, 192, 64, 8, 0, 192, 96, 9,
1160 0, 192, 128, 10, 0, 192, 160, 11, 0, 192, 192, 12, 0, 192, 224, 13,
1161
1162 0, 224, 0, 7, 0, 224, 32, 8, 0, 224, 64, 9, 0, 224, 96, 10,
1163 0, 224, 128, 11, 0, 224, 160, 12, 0, 224, 192, 13, 0, 224, 224, 14,
1164
1165 32, 0, 0, 1, 32, 0, 32, 2, 32, 0, 64, 3, 32, 0, 96, 4,
1166 32, 0, 128, 5, 32, 0, 160, 6, 32, 0, 192, 7, 32, 0, 224, 8,
1167
1168 32, 32, 0, 2, 32, 32, 32, 3, 32, 32, 64, 4, 32, 32, 96, 5,
1169 32, 32, 128, 6, 32, 32, 160, 7, 32, 32, 192, 8, 32, 32, 224, 9,
1170
1171 32, 64, 0, 3, 32, 64, 32, 4, 32, 64, 64, 5, 32, 64, 96, 6,
1172 32, 64, 128, 7, 32, 64, 160, 8, 32, 64, 192, 9, 32, 64, 224, 10,
1173
1174 32, 96, 0, 4, 32, 96, 32, 5, 32, 96, 64, 6, 32, 96, 96, 7,
1175 32, 96, 128, 8, 32, 96, 160, 9, 32, 96, 192, 10, 32, 96, 224, 11,
1176
1177 32, 128, 0, 5, 32, 128, 32, 6, 32, 128, 64, 7, 32, 128, 96, 8,
1178 32, 128, 128, 9, 32, 128, 160, 10, 32, 128, 192, 11, 32, 128, 224, 12,
1179
1180 32, 160, 0, 6, 32, 160, 32, 7, 32, 160, 64, 8, 32, 160, 96, 9,
1181 32, 160, 128, 10, 32, 160, 160, 11, 32, 160, 192, 12, 32, 160, 224, 13,
1182
1183 32, 192, 0, 7, 32, 192, 32, 8, 32, 192, 64, 9, 32, 192, 96, 10,
1184 32, 192, 128, 11, 32, 192, 160, 12, 32, 192, 192, 13, 32, 192, 224, 14,
1185
1186 32, 224, 0, 8, 32, 224, 32, 9, 32, 224, 64, 10, 32, 224, 96, 11,
1187 32, 224, 128, 12, 32, 224, 160, 13, 32, 224, 192, 14, 32, 224, 224, 15,
1188
1189 64, 0, 0, 2, 64, 0, 32, 3, 64, 0, 64, 4, 64, 0, 96, 5,
1190 64, 0, 128, 6, 64, 0, 160, 7, 64, 0, 192, 8, 64, 0, 224, 9,
1191
1192 64, 32, 0, 3, 64, 32, 32, 4, 64, 32, 64, 5, 64, 32, 96, 6,
1193 64, 32, 128, 7, 64, 32, 160, 8, 64, 32, 192, 9, 64, 32, 224, 10,
1194
1195 64, 64, 0, 4, 64, 64, 32, 5, 64, 64, 64, 6, 64, 64, 96, 7,
1196 64, 64, 128, 8, 64, 64, 160, 9, 64, 64, 192, 10, 64, 64, 224, 11,
1197
1198 64, 96, 0, 5, 64, 96, 32, 6, 64, 96, 64, 7, 64, 96, 96, 8,
1199 64, 96, 128, 9, 64, 96, 160, 10, 64, 96, 192, 11, 64, 96, 224, 12,
1200
1201 64, 128, 0, 6, 64, 128, 32, 7, 64, 128, 64, 8, 64, 128, 96, 9,
1202 64, 128, 128, 10, 64, 128, 160, 11, 64, 128, 192, 12, 64, 128, 224, 13,
1203
1204 64, 160, 0, 7, 64, 160, 32, 8, 64, 160, 64, 9, 64, 160, 96, 10,
1205 64, 160, 128, 11, 64, 160, 160, 12, 64, 160, 192, 13, 64, 160, 224, 14,
1206
1207 64, 192, 0, 8, 64, 192, 32, 9, 64, 192, 64, 10, 64, 192, 96, 11,
1208 64, 192, 128, 12, 64, 192, 160, 13, 64, 192, 192, 14, 64, 192, 224, 15,
1209
1210 64, 224, 0, 9, 64, 224, 32, 10, 64, 224, 64, 11, 64, 224, 96, 12,
1211 64, 224, 128, 13, 64, 224, 160, 14, 64, 224, 192, 15, 64, 224, 224, 16,
1212
1213 96, 0, 0, 3, 96, 0, 32, 4, 96, 0, 64, 5, 96, 0, 96, 6,
1214 96, 0, 128, 7, 96, 0, 160, 8, 96, 0, 192, 9, 96, 0, 224, 10,
1215
1216 96, 32, 0, 4, 96, 32, 32, 5, 96, 32, 64, 6, 96, 32, 96, 7,
1217 96, 32, 128, 8, 96, 32, 160, 9, 96, 32, 192, 10, 96, 32, 224, 11,
1218
1219 96, 64, 0, 5, 96, 64, 32, 6, 96, 64, 64, 7, 96, 64, 96, 8,
1220 96, 64, 128, 9, 96, 64, 160, 10, 96, 64, 192, 11, 96, 64, 224, 12,
1221
1222 96, 96, 0, 6, 96, 96, 32, 7, 96, 96, 64, 8, 96, 96, 96, 9,
1223 96, 96, 128, 10, 96, 96, 160, 11, 96, 96, 192, 12, 96, 96, 224, 13,
1224
1225 96, 128, 0, 7, 96, 128, 32, 8, 96, 128, 64, 9, 96, 128, 96, 10,
1226 96, 128, 128, 11, 96, 128, 160, 12, 96, 128, 192, 13, 96, 128, 224, 14,
1227
1228 96, 160, 0, 8, 96, 160, 32, 9, 96, 160, 64, 10, 96, 160, 96, 11,
1229 96, 160, 128, 12, 96, 160, 160, 13, 96, 160, 192, 14, 96, 160, 224, 15,
1230
1231 96, 192, 0, 9, 96, 192, 32, 10, 96, 192, 64, 11, 96, 192, 96, 12,
1232 96, 192, 128, 13, 96, 192, 160, 14, 96, 192, 192, 15, 96, 192, 224, 16,
1233
1234 96, 224, 0, 10, 96, 224, 32, 11, 96, 224, 64, 12, 96, 224, 96, 13,
1235 96, 224, 128, 14, 96, 224, 160, 15, 96, 224, 192, 16, 96, 224, 224, 17,
1236
1237 128, 0, 0, 4, 128, 0, 32, 5, 128, 0, 64, 6, 128, 0, 96, 7,
1238 128, 0, 128, 8, 128, 0, 160, 9, 128, 0, 192, 10, 128, 0, 224, 11,
1239
1240 128, 32, 0, 5, 128, 32, 32, 6, 128, 32, 64, 7, 128, 32, 96, 8,
1241 128, 32, 128, 9, 128, 32, 160, 10, 128, 32, 192, 11, 128, 32, 224, 12,
1242
1243 128, 64, 0, 6, 128, 64, 32, 7, 128, 64, 64, 8, 128, 64, 96, 9,
1244 128, 64, 128, 10, 128, 64, 160, 11, 128, 64, 192, 12, 128, 64, 224, 13,
1245
1246 128, 96, 0, 7, 128, 96, 32, 8, 128, 96, 64, 9, 128, 96, 96, 10,
1247 128, 96, 128, 11, 128, 96, 160, 12, 128, 96, 192, 13, 128, 96, 224, 14,
1248
1249 128, 128, 0, 8, 128, 128, 32, 9, 128, 128, 64, 10, 128, 128, 96, 11,
1250 128, 128, 128, 12, 128, 128, 160, 13, 128, 128, 192, 14, 128, 128, 224, 15,
1251
1252 128, 160, 0, 9, 128, 160, 32, 10, 128, 160, 64, 11, 128, 160, 96, 12,
1253 128, 160, 128, 13, 128, 160, 160, 14, 128, 160, 192, 15, 128, 160, 224, 16,
1254
1255 128, 192, 0, 10, 128, 192, 32, 11, 128, 192, 64, 12, 128, 192, 96, 13,
1256 128, 192, 128, 14, 128, 192, 160, 15, 128, 192, 192, 16, 128, 192, 224, 17,
1257
1258 128, 224, 0, 11, 128, 224, 32, 12, 128, 224, 64, 13, 128, 224, 96, 14,
1259 128, 224, 128, 15, 128, 224, 160, 16, 128, 224, 192, 17, 128, 224, 224, 18,
1260
1261 160, 0, 0, 5, 160, 0, 32, 6, 160, 0, 64, 7, 160, 0, 96, 8,
1262 160, 0, 128, 9, 160, 0, 160, 10, 160, 0, 192, 11, 160, 0, 224, 12,
1263
1264 160, 32, 0, 6, 160, 32, 32, 7, 160, 32, 64, 8, 160, 32, 96, 9,
1265 160, 32, 128, 10, 160, 32, 160, 11, 160, 32, 192, 12, 160, 32, 224, 13,
1266
1267 160, 64, 0, 7, 160, 64, 32, 8, 160, 64, 64, 9, 160, 64, 96, 10,
1268 160, 64, 128, 11, 160, 64, 160, 12, 160, 64, 192, 13, 160, 64, 224, 14,
1269
1270 160, 96, 0, 8, 160, 96, 32, 9, 160, 96, 64, 10, 160, 96, 96, 11,
1271 160, 96, 128, 12, 160, 96, 160, 13, 160, 96, 192, 14, 160, 96, 224, 15,
1272
1273 160, 128, 0, 9, 160, 128, 32, 10, 160, 128, 64, 11, 160, 128, 96, 12,
1274 160, 128, 128, 13, 160, 128, 160, 14, 160, 128, 192, 15, 160, 128, 224, 16,
1275
1276 160, 160, 0, 10, 160, 160, 32, 11, 160, 160, 64, 12, 160, 160, 96, 13,
1277 160, 160, 128, 14, 160, 160, 160, 15, 160, 160, 192, 16, 160, 160, 224, 17,
1278
1279 160, 192, 0, 11, 160, 192, 32, 12, 160, 192, 64, 13, 160, 192, 96, 14,
1280 160, 192, 128, 15, 160, 192, 160, 16, 160, 192, 192, 17, 160, 192, 224, 18,
1281
1282 160, 224, 0, 12, 160, 224, 32, 13, 160, 224, 64, 14, 160, 224, 96, 15,
1283 160, 224, 128, 16, 160, 224, 160, 17, 160, 224, 192, 18, 160, 224, 224, 19,
1284
1285 192, 0, 0, 6, 192, 0, 32, 7, 192, 0, 64, 8, 192, 0, 96, 9,
1286 192, 0, 128, 10, 192, 0, 160, 11, 192, 0, 192, 12, 192, 0, 224, 13,
1287
1288 192, 32, 0, 7, 192, 32, 32, 8, 192, 32, 64, 9, 192, 32, 96, 10,
1289 192, 32, 128, 11, 192, 32, 160, 12, 192, 32, 192, 13, 192, 32, 224, 14,
1290
1291 192, 64, 0, 8, 192, 64, 32, 9, 192, 64, 64, 10, 192, 64, 96, 11,
1292 192, 64, 128, 12, 192, 64, 160, 13, 192, 64, 192, 14, 192, 64, 224, 15,
1293
1294 192, 96, 0, 9, 192, 96, 32, 10, 192, 96, 64, 11, 192, 96, 96, 12,
1295 192, 96, 128, 13, 192, 96, 160, 14, 192, 96, 192, 15, 192, 96, 224, 16,
1296
1297 192, 128, 0, 10, 192, 128, 32, 11, 192, 128, 64, 12, 192, 128, 96, 13,
1298 192, 128, 128, 14, 192, 128, 160, 15, 192, 128, 192, 16, 192, 128, 224, 17,
1299
1300 192, 160, 0, 11, 192, 160, 32, 12, 192, 160, 64, 13, 192, 160, 96, 14,
1301 192, 160, 128, 15, 192, 160, 160, 16, 192, 160, 192, 17, 192, 160, 224, 18,
1302
1303 192, 192, 0, 12, 192, 192, 32, 13, 192, 192, 64, 14, 192, 192, 96, 15,
1304 192, 192, 128, 16, 192, 192, 160, 17, 192, 192, 192, 18, 192, 192, 224, 19,
1305
1306 192, 224, 0, 13, 192, 224, 32, 14, 192, 224, 64, 15, 192, 224, 96, 16,
1307 192, 224, 128, 17, 192, 224, 160, 18, 192, 224, 192, 19, 192, 224, 224, 20,
1308
1309 224, 0, 0, 7, 224, 0, 32, 8, 224, 0, 64, 9, 224, 0, 96, 10,
1310 224, 0, 128, 11, 224, 0, 160, 12, 224, 0, 192, 13, 224, 0, 224, 14,
1311
1312 224, 32, 0, 8, 224, 32, 32, 9, 224, 32, 64, 10, 224, 32, 96, 11,
1313 224, 32, 128, 12, 224, 32, 160, 13, 224, 32, 192, 14, 224, 32, 224, 15,
1314
1315 224, 64, 0, 9, 224, 64, 32, 10, 224, 64, 64, 11, 224, 64, 96, 12,
1316 224, 64, 128, 13, 224, 64, 160, 14, 224, 64, 192, 15, 224, 64, 224, 16,
1317
1318 224, 96, 0, 10, 224, 96, 32, 11, 224, 96, 64, 12, 224, 96, 96, 13,
1319 224, 96, 128, 14, 224, 96, 160, 15, 224, 96, 192, 16, 224, 96, 224, 17,
1320
1321 224, 128, 0, 11, 224, 128, 32, 12, 224, 128, 64, 13, 224, 128, 96, 14,
1322 224, 128, 128, 15, 224, 128, 160, 16, 224, 128, 192, 17, 224, 128, 224, 18,
1323
1324 224, 160, 0, 12, 224, 160, 32, 13, 224, 160, 64, 14, 224, 160, 96, 15,
1325 224, 160, 128, 16, 224, 160, 160, 17, 224, 160, 192, 18, 224, 160, 224, 19,
1326
1327 224, 192, 0, 13, 224, 192, 32, 14, 224, 192, 64, 15, 224, 192, 96, 16,
1328 224, 192, 128, 17, 224, 192, 160, 18, 224, 192, 192, 19, 224, 192, 224, 20,
1329
1330 224, 224, 0, 14, 224, 224, 32, 15, 224, 224, 64, 16, 224, 224, 96, 17,
1331 224, 224, 128, 18, 224, 224, 160, 19, 224, 224, 192, 20, 224, 224, 224, 21
1332 };
1333
1334 const glw::GLsizei gl4cts::GetTextureSubImage::Functional::s_texture_data_size =
1335 sizeof(s_texture_data); //!< Size of the uncompressed texture.
1336
1337 const glw::GLsizei gl4cts::GetTextureSubImage::Functional::s_texture_data_width =
1338 8; //!< Width of compressed and uncompressed textures.
1339 const glw::GLsizei gl4cts::GetTextureSubImage::Functional::s_texture_data_height =
1340 8; //!< Height of compressed and uncompressed textures.
1341 const glw::GLsizei gl4cts::GetTextureSubImage::Functional::s_texture_data_depth =
1342 8; //!< Depth of compressed and uncompressed textures.
1343
1344 /** ETC2 8x8x8(layers) pixels in size source texture for testing GetCompressedTextureSubImage. */
1345 const glw::GLubyte gl4cts::GetTextureSubImage::Functional::s_texture_data_compressed[] = {
1346 /* Layer 0 */
1347 0x80, 0x80, 0x4, 0x2, 0x1, 0x0, 0x10, 0x0, 0x80, 0x81, 0x4, 0x2, 0x1, 0xf8, 0x10, 0x20,
1348 0x81, 0x80, 0x4, 0x2, 0x81, 0x0, 0x1f, 0xc0, 0x81, 0x81, 0x4, 0x2, 0x81, 0xf8, 0x1f, 0xe0,
1349 0x80, 0x80, 0x5, 0x2, 0x1, 0x0, 0x10, 0x0, 0x80, 0x81, 0x5, 0x2, 0x1, 0xf8, 0x10, 0x20,
1350 0x81, 0x80, 0x5, 0x2, 0x81, 0x0, 0x1f, 0xc0, 0x81, 0x81, 0x5, 0x2, 0x81, 0xf8, 0x1f, 0xe0,
1351
1352 /* Layer 1 */
1353 0x90, 0x80, 0x4, 0x12, 0x1, 0x1, 0x10, 0x0, 0x90, 0x81, 0x4, 0x12, 0x1, 0xf9, 0x10, 0x20,
1354 0x91, 0x80, 0x4, 0x12, 0x81, 0x1, 0x1f, 0xc0, 0x91, 0x81, 0x4, 0x12, 0x81, 0xf9, 0x1f, 0xe0,
1355 0x90, 0x80, 0x5, 0x12, 0x1, 0x1, 0x10, 0x0, 0x90, 0x81, 0x5, 0x12, 0x1, 0xf9, 0x10, 0x20,
1356 0x91, 0x80, 0x5, 0x12, 0x81, 0x1, 0x1f, 0xc0, 0x91, 0x81, 0x5, 0x12, 0x81, 0xf9, 0x1f, 0xe0,
1357
1358 /* Layer 2 */
1359 0xa0, 0x80, 0x4, 0x22, 0x1, 0x2, 0x10, 0x0, 0xa0, 0x81, 0x4, 0x22, 0x1, 0xfa, 0x10, 0x20,
1360 0xa1, 0x80, 0x4, 0x22, 0x81, 0x2, 0x1f, 0xc0, 0xa1, 0x81, 0x4, 0x22, 0x81, 0xfa, 0x1f, 0xe0,
1361 0xa0, 0x80, 0x5, 0x22, 0x1, 0x2, 0x10, 0x0, 0xa0, 0x81, 0x5, 0x22, 0x1, 0xfa, 0x10, 0x20,
1362 0xa1, 0x80, 0x5, 0x22, 0x81, 0x2, 0x1f, 0xc0, 0xa1, 0x81, 0x5, 0x22, 0x81, 0xfa, 0x1f, 0xe0,
1363
1364 /* Layer 3 */
1365 0xb0, 0x80, 0x4, 0x32, 0x1, 0x3, 0x10, 0x0, 0xb0, 0x81, 0x4, 0x32, 0x1, 0xfb, 0x10, 0x20,
1366 0xb1, 0x80, 0x4, 0x32, 0x81, 0x3, 0x1f, 0xc0, 0xb1, 0x81, 0x4, 0x32, 0x81, 0xfb, 0x1f, 0xe0,
1367 0xb0, 0x80, 0x5, 0x32, 0x1, 0x3, 0x10, 0x0, 0xb0, 0x81, 0x5, 0x32, 0x1, 0xfb, 0x10, 0x20,
1368 0xb1, 0x80, 0x5, 0x32, 0x81, 0x3, 0x1f, 0xc0, 0xb1, 0x81, 0x5, 0x32, 0x81, 0xfb, 0x1f, 0xe0,
1369
1370 /* Layer 4 */
1371 0x40, 0x80, 0x4, 0x42, 0x1, 0x4, 0x10, 0x0, 0x40, 0x81, 0x4, 0x42, 0x1, 0xfc, 0x10, 0x20,
1372 0x41, 0x80, 0x4, 0x42, 0x81, 0x4, 0x1f, 0xc0, 0x41, 0x81, 0x4, 0x42, 0x81, 0xfc, 0x1f, 0xe0,
1373 0x40, 0x80, 0x5, 0x42, 0x1, 0x4, 0x10, 0x0, 0x40, 0x81, 0x5, 0x42, 0x1, 0xfc, 0x10, 0x20,
1374 0x41, 0x80, 0x5, 0x42, 0x81, 0x4, 0x1f, 0xc0, 0x41, 0x81, 0x5, 0x42, 0x81, 0xfc, 0x1f, 0xe0,
1375
1376 /* Layer 5 */
1377 0x50, 0x80, 0x4, 0x52, 0x1, 0x5, 0x10, 0x0, 0x50, 0x81, 0x4, 0x52, 0x1, 0xfd, 0x10, 0x20,
1378 0x51, 0x80, 0x4, 0x52, 0x81, 0x5, 0x1f, 0xc0, 0x51, 0x81, 0x4, 0x52, 0x81, 0xfd, 0x1f, 0xe0,
1379 0x50, 0x80, 0x5, 0x52, 0x1, 0x5, 0x10, 0x0, 0x50, 0x81, 0x5, 0x52, 0x1, 0xfd, 0x10, 0x20,
1380 0x51, 0x80, 0x5, 0x52, 0x81, 0x5, 0x1f, 0xc0, 0x51, 0x81, 0x5, 0x52, 0x81, 0xfd, 0x1f, 0xe0,
1381
1382 /* Layer 6 */
1383 0x5e, 0x80, 0x4, 0x5f, 0x1, 0x5, 0xf0, 0x0, 0x5e, 0x81, 0x4, 0x5f, 0x1, 0xfd, 0xf0, 0x20,
1384 0x5f, 0x80, 0x4, 0x5f, 0x81, 0x5, 0xff, 0xc0, 0x5f, 0x81, 0x4, 0x5f, 0x81, 0xfd, 0xff, 0xe0,
1385 0x5e, 0x80, 0x5, 0x5f, 0x1, 0x5, 0xf0, 0x0, 0x5e, 0x81, 0x5, 0x5f, 0x1, 0xfd, 0xf0, 0x20,
1386 0x5f, 0x80, 0x5, 0x5f, 0x81, 0x5, 0xff, 0xc0, 0x5f, 0x81, 0x5, 0x5f, 0x81, 0xfd, 0xff, 0xe0,
1387
1388 /* Layer 7 */
1389 0x6e, 0x80, 0x4, 0x6f, 0x1, 0x6, 0xf0, 0x0, 0x6e, 0x81, 0x4, 0x6f, 0x1, 0xfe, 0xf0, 0x20,
1390 0x6f, 0x80, 0x4, 0x6f, 0x81, 0x6, 0xff, 0xc0, 0x6f, 0x81, 0x4, 0x6f, 0x81, 0xfe, 0xff, 0xe0,
1391 0x6e, 0x80, 0x5, 0x6f, 0x1, 0x6, 0xf0, 0x0, 0x6e, 0x81, 0x5, 0x6f, 0x1, 0xfe, 0xf0, 0x20,
1392 0x6f, 0x80, 0x5, 0x6f, 0x81, 0x6, 0xff, 0xc0, 0x6f, 0x81, 0x5, 0x6f, 0x81, 0xfe, 0xff, 0xe0
1393 };
1394
1395 const glw::GLsizei gl4cts::GetTextureSubImage::Functional::s_texture_data_compressed_size =
1396 sizeof(s_texture_data_compressed); //!< Size of compressed texture.
1397