1 /*-------------------------------------------------------------------------
2 * drawElements Quality Program EGL Module
3 * ---------------------------------------
5 * Copyright 2017 The Android Open Source Project
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
11 * http://www.apache.org/licenses/LICENSE-2.0
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.
21 * \brief Test KHR_wide_color
22 *//*--------------------------------------------------------------------*/
24 #include "teglWideColorTests.hpp"
26 #include "tcuImageCompare.hpp"
27 #include "tcuTestLog.hpp"
28 #include "tcuSurface.hpp"
29 #include "tcuTextureUtil.hpp"
31 #include "egluNativeWindow.hpp"
32 #include "egluStrUtil.hpp"
33 #include "egluUtil.hpp"
34 #include "egluConfigFilter.hpp"
36 #include "eglwLibrary.hpp"
37 #include "eglwEnums.hpp"
39 #include "gluDefs.hpp"
40 #include "gluRenderContext.hpp"
41 #include "gluShaderProgram.hpp"
43 #include "glwDefs.hpp"
44 #include "glwEnums.hpp"
45 #include "glwFunctions.hpp"
48 #include "deRandom.hpp"
50 #include "deStringUtil.hpp"
71 typedef tcu::Vec4 Color;
75 class ReferenceRenderer;
77 class WideColorTests : public TestCaseGroup
80 WideColorTests (EglTestContext& eglTestCtx);
84 WideColorTests (const WideColorTests&);
85 WideColorTests& operator= (const WideColorTests&);
88 class WideColorTest : public TestCase
97 WideColorTest (EglTestContext& eglTestCtx, const char* name, const char* description);
98 ~WideColorTest (void);
102 void checkPixelFloatSupport (void);
103 void checkColorSpaceSupport (void);
104 void checkDisplayP3Support (void);
105 void check1010102Support (void);
106 void checkFP16Support (void);
107 void checkSCRGBSupport (void);
108 void checkSCRGBLinearSupport (void);
109 void checkbt2020linear (void);
110 void checkbt2020pq (void);
111 void checkSMPTE2086 (void);
112 void checkCTA861_3 (void);
115 void initEGLSurface (EGLConfig config);
116 void initEGLContext (EGLConfig config);
118 EGLDisplay m_eglDisplay;
125 ColoredRect (const IVec2& bottomLeft_, const IVec2& topRight_, const Color& color_);
131 ColoredRect::ColoredRect (const IVec2& bottomLeft_, const IVec2& topRight_, const Color& color_)
132 : bottomLeft (bottomLeft_)
133 , topRight (topRight_)
138 void clearColorScreen (const glw::Functions& gl, const Color& clearColor)
140 gl.clearColor(clearColor.x(), clearColor.y(), clearColor.z(), clearColor.w());
141 gl.clear(GL_COLOR_BUFFER_BIT);
144 float windowToDeviceCoordinates (int x, int length)
146 return (2.0f * float(x) / float(length)) - 1.0f;
152 GLES2Renderer (const glw::Functions& gl, int width, int height);
153 ~GLES2Renderer (void);
154 void render (const ColoredRect& coloredRect) const;
157 GLES2Renderer (const GLES2Renderer&);
158 GLES2Renderer& operator= (const GLES2Renderer&);
160 const glw::Functions& m_gl;
161 glu::ShaderProgram m_glProgram;
162 glw::GLuint m_coordLoc;
163 glw::GLuint m_colorLoc;
164 glw::GLuint m_bufWidth;
165 glw::GLuint m_bufHeight;
168 // generate sources for vertex and fragment buffer
169 glu::ProgramSources getSources (void)
171 const char* const vertexShaderSource =
172 "attribute mediump vec2 a_pos;\n"
173 "attribute mediump vec4 a_color;\n"
174 "varying mediump vec4 v_color;\n"
177 "\tv_color = a_color;\n"
178 "\tgl_Position = vec4(a_pos, 0.0, 1.0);\n"
181 const char* const fragmentShaderSource =
182 "varying mediump vec4 v_color;\n"
185 "\tgl_FragColor = v_color;\n"
188 return glu::makeVtxFragSources(vertexShaderSource, fragmentShaderSource);
191 GLES2Renderer::GLES2Renderer (const glw::Functions& gl, int width, int height)
193 , m_glProgram (gl, getSources())
194 , m_coordLoc ((glw::GLuint)-1)
195 , m_colorLoc ((glw::GLuint)-1)
197 , m_bufHeight (height)
199 m_colorLoc = m_gl.getAttribLocation(m_glProgram.getProgram(), "a_color");
200 m_coordLoc = m_gl.getAttribLocation(m_glProgram.getProgram(), "a_pos");
201 GLU_EXPECT_NO_ERROR(m_gl.getError(), "Failed to get attribute locations");
204 GLES2Renderer::~GLES2Renderer (void)
208 void GLES2Renderer::render (const struct ColoredRect &coloredRect) const
210 const float x1 = windowToDeviceCoordinates(coloredRect.bottomLeft.x(), m_bufWidth);
211 const float y1 = windowToDeviceCoordinates(coloredRect.bottomLeft.y(), m_bufHeight);
212 const float x2 = windowToDeviceCoordinates(coloredRect.topRight.x(), m_bufWidth);
213 const float y2 = windowToDeviceCoordinates(coloredRect.topRight.y(), m_bufHeight);
215 const glw::GLfloat coords[] =
226 const glw::GLfloat colors[] =
228 coloredRect.color.x(), coloredRect.color.y(), coloredRect.color.z(), coloredRect.color.w(),
229 coloredRect.color.x(), coloredRect.color.y(), coloredRect.color.z(), coloredRect.color.w(),
230 coloredRect.color.x(), coloredRect.color.y(), coloredRect.color.z(), coloredRect.color.w(),
232 coloredRect.color.x(), coloredRect.color.y(), coloredRect.color.z(), coloredRect.color.w(),
233 coloredRect.color.x(), coloredRect.color.y(), coloredRect.color.z(), coloredRect.color.w(),
234 coloredRect.color.x(), coloredRect.color.y(), coloredRect.color.z(), coloredRect.color.w(),
237 m_gl.useProgram(m_glProgram.getProgram());
238 GLU_EXPECT_NO_ERROR(m_gl.getError(), "glUseProgram() failed");
240 m_gl.enableVertexAttribArray(m_coordLoc);
241 m_gl.enableVertexAttribArray(m_colorLoc);
242 GLU_EXPECT_NO_ERROR(m_gl.getError(), "Failed to enable attributes");
244 m_gl.vertexAttribPointer(m_coordLoc, 4, GL_FLOAT, GL_FALSE, 0, coords);
245 m_gl.vertexAttribPointer(m_colorLoc, 4, GL_FLOAT, GL_TRUE, 0, colors);
246 GLU_EXPECT_NO_ERROR(m_gl.getError(), "Failed to set attribute pointers");
248 m_gl.drawArrays(GL_TRIANGLES, 0, DE_LENGTH_OF_ARRAY(coords)/4);
249 GLU_EXPECT_NO_ERROR(m_gl.getError(), "glDrawArrays(), failed");
251 m_gl.disableVertexAttribArray(m_coordLoc);
252 m_gl.disableVertexAttribArray(m_colorLoc);
253 GLU_EXPECT_NO_ERROR(m_gl.getError(), "Failed to disable attributes");
256 GLU_EXPECT_NO_ERROR(m_gl.getError(), "glUseProgram() failed");
259 class ReferenceRenderer
262 ReferenceRenderer (void);
264 ReferenceRenderer (const ReferenceRenderer&);
265 ReferenceRenderer& operator= (const ReferenceRenderer&);
268 WideColorTest::WideColorTest (EglTestContext& eglTestCtx, const char* name, const char* description)
269 : TestCase (eglTestCtx, name, description)
270 , m_eglDisplay (EGL_NO_DISPLAY)
274 WideColorTest::~WideColorTest (void)
279 void WideColorTest::init (void)
281 m_eglDisplay = eglu::getAndInitDisplay(m_eglTestCtx.getNativeDisplay());
283 m_eglTestCtx.initGLFunctions(&m_gl, glu::ApiType::es(2,0));
286 void WideColorTest::checkPixelFloatSupport (void)
288 const Library& egl = m_eglTestCtx.getLibrary();
290 if (!eglu::hasExtension(egl, m_eglDisplay, "EGL_EXT_pixel_format_float"))
291 TCU_THROW(NotSupportedError, "EGL_EXT_pixel_format_float is not supported");
294 void WideColorTest::checkColorSpaceSupport (void)
296 const Library& egl = m_eglTestCtx.getLibrary();
298 if (!eglu::hasExtension(egl, m_eglDisplay, "EGL_KHR_gl_colorspace"))
299 TCU_THROW(NotSupportedError, "EGL_KHR_gl_colorspace is not supported");
302 void WideColorTest::checkDisplayP3Support (void)
304 const Library& egl = m_eglTestCtx.getLibrary();
306 if (!eglu::hasExtension(egl, m_eglDisplay, "EGL_EXT_gl_colorspace_display_p3"))
307 TCU_THROW(NotSupportedError, "EGL_EXT_gl_colorspace_display_p3 is not supported");
310 void WideColorTest::checkSCRGBSupport (void)
312 const Library& egl = m_eglTestCtx.getLibrary();
314 if (!eglu::hasExtension(egl, m_eglDisplay, "EGL_EXT_gl_colorspace_scrgb"))
315 TCU_THROW(NotSupportedError, "EGL_EXT_gl_colorspace_scrgb is not supported");
318 void WideColorTest::checkSCRGBLinearSupport (void)
320 const Library& egl = m_eglTestCtx.getLibrary();
322 if (!eglu::hasExtension(egl, m_eglDisplay, "EGL_EXT_gl_colorspace_scrgb_linear"))
323 TCU_THROW(NotSupportedError, "EGL_EXT_gl_colorspace_scrgb_linear is not supported");
326 void WideColorTest::checkbt2020linear (void)
328 const Library& egl = m_eglTestCtx.getLibrary();
330 if (!eglu::hasExtension(egl, m_eglDisplay, "EGL_EXT_gl_colorspace_bt2020_linear"))
331 TCU_THROW(NotSupportedError, "EGL_EXT_gl_colorspace_bt2020_linear is not supported");
334 void WideColorTest::checkbt2020pq (void)
336 const Library& egl = m_eglTestCtx.getLibrary();
338 if (!eglu::hasExtension(egl, m_eglDisplay, "EGL_EXT_gl_colorspace_bt2020_pq"))
339 TCU_THROW(NotSupportedError, "EGL_EXT_gl_colorspace_bt2020_pq is not supported");
342 void WideColorTest::checkSMPTE2086 (void)
344 const Library& egl = m_eglTestCtx.getLibrary();
346 if (!eglu::hasExtension(egl, m_eglDisplay, "EGL_EXT_surface_SMPTE2086_metadata"))
347 TCU_THROW(NotSupportedError, "EGL_EXT_surface_SMPTE2086_metadata is not supported");
350 void WideColorTest::checkCTA861_3 (void)
352 const Library& egl = m_eglTestCtx.getLibrary();
354 if (!eglu::hasExtension(egl, m_eglDisplay, "EGL_EXT_surface_CTA861_3_metadata"))
355 TCU_THROW(NotSupportedError, "EGL_EXT_surface_CTA861_3_metadata is not supported");
358 void WideColorTest::check1010102Support (void)
360 const Library& egl = m_eglTestCtx.getLibrary();
361 tcu::TestLog& log = m_testCtx.getLog();
363 const EGLint attribList[] =
365 EGL_SURFACE_TYPE, EGL_WINDOW_BIT,
366 EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT,
373 EGLint numConfigs = 0;
376 // Query from EGL implementation
377 EGLU_CHECK_CALL(egl, chooseConfig(m_eglDisplay, &attribList[0], DE_NULL, 0, &numConfigs));
381 log << tcu::TestLog::Message << "No configs returned." << tcu::TestLog::EndMessage;
382 TCU_THROW(NotSupportedError, "10:10:10:2 pixel format is not supported");
385 log << tcu::TestLog::Message << numConfigs << " configs returned" << tcu::TestLog::EndMessage;
387 EGLU_CHECK_CALL(egl, chooseConfig(m_eglDisplay, &attribList[0], &config, 1, &numConfigs));
390 log << tcu::TestLog::Message << "Fail, more configs returned than requested." << tcu::TestLog::EndMessage;
391 TCU_FAIL("Too many configs returned");
394 EGLint components[4];
396 EGLU_CHECK_CALL(egl, getConfigAttrib(m_eglDisplay, config, EGL_RED_SIZE, &components[0]));
397 EGLU_CHECK_CALL(egl, getConfigAttrib(m_eglDisplay, config, EGL_GREEN_SIZE, &components[1]));
398 EGLU_CHECK_CALL(egl, getConfigAttrib(m_eglDisplay, config, EGL_BLUE_SIZE, &components[2]));
399 EGLU_CHECK_CALL(egl, getConfigAttrib(m_eglDisplay, config, EGL_ALPHA_SIZE, &components[3]));
401 TCU_CHECK_MSG(components[0] == 10, "Missing 10bit deep red channel");
402 TCU_CHECK_MSG(components[1] == 10, "Missing 10bit deep green channel");
403 TCU_CHECK_MSG(components[2] == 10, "Missing 10bit deep blue channel");
404 TCU_CHECK_MSG(components[3] == 2, "Missing 2bit deep alpha channel");
407 void WideColorTest::checkFP16Support (void)
409 const Library& egl = m_eglTestCtx.getLibrary();
410 tcu::TestLog& log = m_testCtx.getLog();
411 EGLint numConfigs = 0;
414 const EGLint attribList[] =
416 EGL_SURFACE_TYPE, EGL_WINDOW_BIT,
417 EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT,
422 EGL_COLOR_COMPONENT_TYPE_EXT, EGL_COLOR_COMPONENT_TYPE_FLOAT_EXT,
426 // Query from EGL implementation
427 EGLU_CHECK_CALL(egl, chooseConfig(m_eglDisplay, &attribList[0], DE_NULL, 0, &numConfigs));
431 log << tcu::TestLog::Message << "No configs returned." << tcu::TestLog::EndMessage;
432 TCU_THROW(NotSupportedError, "16:16:16:16 pixel format is not supported");
435 log << tcu::TestLog::Message << numConfigs << " configs returned" << tcu::TestLog::EndMessage;
437 EGLBoolean success = egl.chooseConfig(m_eglDisplay, &attribList[0], &config, 1, &numConfigs);
438 if (success != EGL_TRUE)
440 log << tcu::TestLog::Message << "Fail, eglChooseConfig returned an error." << tcu::TestLog::EndMessage;
441 TCU_FAIL("eglChooseConfig failed");
445 log << tcu::TestLog::Message << "Fail, more configs returned than requested." << tcu::TestLog::EndMessage;
446 TCU_FAIL("Too many configs returned");
449 EGLint components[4];
451 success = egl.getConfigAttrib(m_eglDisplay, config, EGL_RED_SIZE, &components[0]);
452 TCU_CHECK_MSG(success == EGL_TRUE, "eglGetConfigAttrib failed");
454 success = egl.getConfigAttrib(m_eglDisplay, config, EGL_GREEN_SIZE, &components[1]);
455 TCU_CHECK_MSG(success == EGL_TRUE, "eglGetConfigAttrib failed");
457 success = egl.getConfigAttrib(m_eglDisplay, config, EGL_BLUE_SIZE, &components[2]);
458 TCU_CHECK_MSG(success == EGL_TRUE, "eglGetConfigAttrib failed");
460 success = egl.getConfigAttrib(m_eglDisplay, config, EGL_ALPHA_SIZE, &components[3]);
461 TCU_CHECK_MSG(success == EGL_TRUE, "eglGetConfigAttrib failed");
464 TCU_CHECK_MSG(components[0] == 16, "Missing 16bit deep red channel");
465 TCU_CHECK_MSG(components[1] == 16, "Missing 16bit deep green channel");
466 TCU_CHECK_MSG(components[2] == 16, "Missing 16bit deep blue channel");
467 TCU_CHECK_MSG(components[3] == 16, "Missing 16bit deep alpha channel");
470 void WideColorTest::deinit (void)
472 const Library& egl = m_eglTestCtx.getLibrary();
474 if (m_eglDisplay != EGL_NO_DISPLAY)
476 egl.terminate(m_eglDisplay);
477 m_eglDisplay = EGL_NO_DISPLAY;
481 class WideColorFP16Test : public WideColorTest
484 WideColorFP16Test (EglTestContext& eglTestCtx, const char* name, const char* description);
487 void executeTest (void);
488 IterateResult iterate (void);
491 WideColorFP16Test::WideColorFP16Test (EglTestContext& eglTestCtx,
493 const char* description)
494 : WideColorTest(eglTestCtx, name, description)
499 void WideColorFP16Test::executeTest (void)
501 checkPixelFloatSupport();
505 TestCase::IterateResult WideColorFP16Test::iterate (void)
507 m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass");
512 void WideColorFP16Test::init (void)
514 WideColorTest::init();
517 class WideColor1010102Test : public WideColorTest
520 WideColor1010102Test (EglTestContext& eglTestCtx,
522 const char* description);
524 void executeTest (void);
525 IterateResult iterate (void);
528 WideColor1010102Test::WideColor1010102Test (EglTestContext& eglTestCtx, const char* name, const char* description)
529 : WideColorTest(eglTestCtx, name, description)
533 void WideColor1010102Test::executeTest (void)
535 check1010102Support();
538 TestCase::IterateResult WideColor1010102Test::iterate (void)
540 m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass");
550 Iteration(float s, float i, int c)
551 : start(s), increment(i), iterationCount(c) {}
554 class WideColorSurfaceTest : public WideColorTest
557 WideColorSurfaceTest (EglTestContext& eglTestCtx,
559 const char* description,
560 const EGLint* attribList,
562 const std::vector<Iteration>& iterations);
565 void executeTest (void);
566 IterateResult iterate (void);
567 void addTestAttributes (const EGLint* attributes);
570 void readPixels (const glw::Functions& gl, float* dataPtr);
571 void readPixels (const glw::Functions& gl, deUint32* dataPtr);
572 void readPixels (const glw::Functions& gl, deUint8* dataPtr);
573 deUint32 expectedUint10 (float reference);
574 deUint32 expectedUint2 (float reference);
575 deUint8 expectedUint8 (float reference);
576 deUint8 expectedAlpha8 (float reference);
577 bool checkWithThreshold8 (deUint8 value, deUint8 reference, deUint8 threshold = 1);
578 bool checkWithThreshold10 (deUint32 value, deUint32 reference, deUint32 threshold = 1);
579 bool checkWithThresholdFloat (float value, float reference, float threshold);
580 void doClearTest (EGLSurface surface);
581 void testPixels (float reference, float increment);
582 void writeEglConfig (EGLConfig config);
585 std::vector<EGLint> m_attribList;
586 std::vector<EGLint> m_testAttribList;
587 EGLConfig m_eglConfig;
588 EGLint m_surfaceType;
589 EGLint m_componentType;
592 const std::vector<struct Iteration> m_iterations;
593 std::stringstream m_debugLog;
596 WideColorSurfaceTest::WideColorSurfaceTest (EglTestContext& eglTestCtx, const char* name, const char* description, const EGLint* attribList, EGLint colorSpace, const std::vector<struct Iteration>& iterations)
597 : WideColorTest (eglTestCtx, name, description)
598 , m_colorSpace (colorSpace)
599 , m_iterations (iterations)
602 while (attribList[idx] != EGL_NONE)
604 if (attribList[idx] == EGL_COLOR_COMPONENT_TYPE_EXT)
606 m_componentType = attribList[idx + 1];
608 else if (attribList[idx] == EGL_SURFACE_TYPE)
610 m_surfaceType = attribList[idx+1];
612 else if (attribList[idx] == EGL_RED_SIZE)
614 m_redSize = attribList[idx + 1];
616 m_attribList.push_back(attribList[idx++]);
617 m_attribList.push_back(attribList[idx++]);
619 m_attribList.push_back(EGL_NONE);
622 void WideColorSurfaceTest::addTestAttributes(const EGLint *attributes)
625 if (attributes == DE_NULL) return;
627 while (attributes[idx] != EGL_NONE)
629 m_testAttribList.push_back(attributes[idx++]);
630 m_testAttribList.push_back(attributes[idx++]);
634 void WideColorSurfaceTest::init (void)
636 const Library& egl = m_eglTestCtx.getLibrary();
637 tcu::TestLog& log = m_testCtx.getLog();
639 WideColorTest::init();
641 // Only check for pixel format required for this specific run
642 // If not available, check will abort test with "NotSupported"
646 check1010102Support();
649 checkPixelFloatSupport();
654 if (m_colorSpace != EGL_NONE && !eglu::hasExtension(egl, m_eglDisplay, "EGL_KHR_gl_colorspace"))
655 TCU_THROW(NotSupportedError, "EGL_KHR_gl_colorspace is not supported");
657 switch (m_colorSpace) {
658 case EGL_GL_COLORSPACE_SRGB_KHR:
659 checkColorSpaceSupport();
661 case EGL_GL_COLORSPACE_DISPLAY_P3_EXT:
662 checkDisplayP3Support();
664 case EGL_GL_COLORSPACE_SCRGB_EXT:
667 case EGL_GL_COLORSPACE_SCRGB_LINEAR_EXT:
668 checkSCRGBLinearSupport();
670 case EGL_GL_COLORSPACE_BT2020_LINEAR_EXT:
673 case EGL_GL_COLORSPACE_BT2020_PQ_EXT:
680 EGLint numConfigs = 0;
682 // Query from EGL implementation
683 EGLU_CHECK_CALL(egl, chooseConfig(m_eglDisplay, &m_attribList[0], DE_NULL, 0, &numConfigs));
687 log << tcu::TestLog::Message << "No configs returned." << tcu::TestLog::EndMessage;
688 TCU_FAIL("No configs returned");
691 log << tcu::TestLog::Message << numConfigs << " configs returned" << tcu::TestLog::EndMessage;
693 EGLBoolean success = egl.chooseConfig(m_eglDisplay, &m_attribList[0], &m_eglConfig, 1, &numConfigs);
694 if (success != EGL_TRUE)
696 log << tcu::TestLog::Message << "Fail, eglChooseConfig returned an error." << tcu::TestLog::EndMessage;
697 TCU_FAIL("eglChooseConfig failed");
701 log << tcu::TestLog::Message << "Fail, more configs returned than requested." << tcu::TestLog::EndMessage;
702 TCU_FAIL("Too many configs returned");
705 m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass");
707 writeEglConfig(m_eglConfig);
711 void WideColorSurfaceTest::readPixels (const glw::Functions& gl, float* dataPtr)
713 gl.readPixels(0, 0, 1, 1, GL_RGBA, GL_FLOAT, dataPtr);
714 GLU_EXPECT_NO_ERROR(m_gl.getError(), "glReadPixels with floats");
717 void WideColorSurfaceTest::readPixels (const glw::Functions& gl, deUint32 *dataPtr)
719 gl.readPixels(0, 0, 1, 1, GL_RGBA, GL_UNSIGNED_INT_2_10_10_10_REV, dataPtr);
720 GLU_EXPECT_NO_ERROR(m_gl.getError(), "glReadPixels with RGBA_1010102 (32bits)");
723 void WideColorSurfaceTest::readPixels (const glw::Functions& gl, deUint8 *dataPtr)
725 gl.readPixels(0, 0, 1, 1, GL_RGBA, GL_UNSIGNED_BYTE, dataPtr);
726 GLU_EXPECT_NO_ERROR(m_gl.getError(), "glReadPixels with RGBA_8888 (8 bit components)");
729 void WideColorSurfaceTest::writeEglConfig (EGLConfig config)
731 const Library& egl = m_eglTestCtx.getLibrary();
732 tcu::TestLog& log = m_testCtx.getLog();
733 qpEglConfigInfo info;
736 info.bufferSize = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_BUFFER_SIZE);
738 info.redSize = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_RED_SIZE);
740 info.greenSize = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_GREEN_SIZE);
742 info.blueSize = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_BLUE_SIZE);
744 info.luminanceSize = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_LUMINANCE_SIZE);
746 info.alphaSize = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_ALPHA_SIZE);
748 info.alphaMaskSize = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_ALPHA_MASK_SIZE);
750 val = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_BIND_TO_TEXTURE_RGB);
751 info.bindToTextureRGB = val == EGL_TRUE ? true : false;
753 val = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_BIND_TO_TEXTURE_RGBA);
754 info.bindToTextureRGBA = val == EGL_TRUE ? true : false;
756 val = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_COLOR_BUFFER_TYPE);
757 std::string colorBufferType = de::toString(eglu::getColorBufferTypeStr(val));
758 info.colorBufferType = colorBufferType.c_str();
760 val = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_CONFIG_CAVEAT);
761 std::string caveat = de::toString(eglu::getConfigCaveatStr(val));
762 info.configCaveat = caveat.c_str();
764 info.configID = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_CONFIG_ID);
766 val = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_CONFORMANT);
767 std::string conformant = de::toString(eglu::getAPIBitsStr(val));
768 info.conformant = conformant.c_str();
770 info.depthSize = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_DEPTH_SIZE);
772 info.level = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_LEVEL);
774 info.maxPBufferWidth = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_MAX_PBUFFER_WIDTH);
776 info.maxPBufferHeight = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_MAX_PBUFFER_HEIGHT);
778 info.maxPBufferPixels = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_MAX_PBUFFER_PIXELS);
780 info.maxSwapInterval = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_MAX_SWAP_INTERVAL);
782 info.minSwapInterval = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_MIN_SWAP_INTERVAL);
784 val = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_NATIVE_RENDERABLE);
785 info.nativeRenderable = val == EGL_TRUE ? true : false;
787 val = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_RENDERABLE_TYPE);
788 std::string renderableTypes = de::toString(eglu::getAPIBitsStr(val));
789 info.renderableType = renderableTypes.c_str();
791 info.sampleBuffers = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_SAMPLE_BUFFERS);
793 info.samples = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_SAMPLES);
795 info.stencilSize = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_STENCIL_SIZE);
797 val = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_SURFACE_TYPE);
798 std::string surfaceTypes = de::toString(eglu::getSurfaceBitsStr(val));
799 info.surfaceTypes = surfaceTypes.c_str();
801 val = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_TRANSPARENT_TYPE);
802 std::string transparentType = de::toString(eglu::getTransparentTypeStr(val));
803 info.transparentType = transparentType.c_str();
805 info.transparentRedValue = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_TRANSPARENT_RED_VALUE);
807 info.transparentGreenValue = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_TRANSPARENT_GREEN_VALUE);
809 info.transparentBlueValue = eglu::getConfigAttribInt(egl, m_eglDisplay, config, EGL_TRANSPARENT_BLUE_VALUE);
811 log.writeEglConfig(&info);
814 deUint32 WideColorSurfaceTest::expectedUint10 (float reference)
822 else if (reference > 1.0)
828 expected = static_cast<deUint32>(deRound(reference * 1023.0));
834 deUint32 WideColorSurfaceTest::expectedUint2 (float reference)
842 else if (reference > 1.0)
848 expected = static_cast<deUint32>(deRound(reference * 3.0));
854 deUint8 WideColorSurfaceTest::expectedUint8 (float reference)
861 else if (reference >= 1.0)
867 // Apply sRGB transfer function when colorspace is sRGB and pixel component
868 // size is 8 bits (which is why we are here in expectedUint8).
869 if (m_colorSpace == EGL_GL_COLORSPACE_SRGB_KHR)
873 if (reference <= 0.0031308)
875 srgbReference = 12.92f * reference;
879 float powRef = deFloatPow(reference, (1.0f/2.4f));
880 srgbReference = (1.055f * powRef) - 0.055f;
882 expected = static_cast<deUint8>(deRound(srgbReference * 255.0));
886 expected = static_cast<deUint8>(deRound(reference * 255.0));
892 deUint8 WideColorSurfaceTest::expectedAlpha8 (float reference)
899 else if (reference >= 1.0)
905 // The sRGB transfer function is not applied to alpha
906 expected = static_cast<deUint8>(deRound(reference * 255.0));
911 // Return true for value out of range (fail)
912 bool WideColorSurfaceTest::checkWithThreshold8(deUint8 value, deUint8 reference, deUint8 threshold)
914 const deUint8 low = reference >= threshold ? static_cast<deUint8>(reference - threshold) : 0;
915 const deUint8 high = reference <= (255 - threshold) ? static_cast<deUint8>(reference + threshold) : 255;
916 return !((value >= low) && (value <= high));
919 bool WideColorSurfaceTest::checkWithThreshold10(deUint32 value, deUint32 reference, deUint32 threshold)
921 const deUint32 low = reference >= threshold ? reference - threshold : 0;
922 const deUint32 high = reference <= (1023 - threshold) ? reference + threshold : 1023;
923 return !((value >= low) && (value <= high));
926 bool WideColorSurfaceTest::checkWithThresholdFloat(float value, float reference, float threshold)
928 const float low = reference - threshold;
929 const float high = reference + threshold;
930 return !((value >= low) && (value <= high));
933 void WideColorSurfaceTest::testPixels (float reference, float increment)
935 tcu::TestLog& log = m_testCtx.getLog();
937 if (m_componentType == EGL_COLOR_COMPONENT_TYPE_FLOAT_EXT)
940 const float expected[4] =
943 reference + increment,
944 reference - increment,
945 reference + 2 * increment
947 readPixels(m_gl, pixels);
949 if (checkWithThresholdFloat(pixels[0], expected[0], increment) ||
950 checkWithThresholdFloat(pixels[1], expected[1], increment) ||
951 checkWithThresholdFloat(pixels[2], expected[2], increment) ||
952 checkWithThresholdFloat(pixels[3], expected[3], increment))
954 if (m_debugLog.str().size() > 0)
956 log << tcu::TestLog::Message
957 << "Prior passing tests\n"
959 << tcu::TestLog::EndMessage;
962 log << tcu::TestLog::Message
963 << "Image comparison failed: "
964 << "reference = " << reference
965 << ", expected = " << expected[0]
966 << ":" << expected[1]
967 << ":" << expected[2]
968 << ":" << expected[3]
969 << ", result = " << pixels[0]
973 << tcu::TestLog::EndMessage;
974 m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Color test failed");
978 // Pixel matches expected value
979 m_debugLog << "Image comparison passed: "
980 << "reference = " << reference
981 << ", result = " << pixels[0]
988 else if (m_redSize > 8)
991 readPixels(m_gl, buffer);
993 deUint32 expected[4];
995 pixels[0] = buffer[0] & 0x3ff;
996 pixels[1] = (buffer[0] >> 10) & 0x3ff;
997 pixels[2] = (buffer[0] >> 20) & 0x3ff;
998 pixels[3] = (buffer[0] >> 30) & 0x3;
1000 expected[0] = expectedUint10(reference);
1001 expected[1] = expectedUint10(reference + increment);
1002 expected[2] = expectedUint10(reference - increment);
1003 expected[3] = expectedUint2(reference + 2 * increment);
1004 if (checkWithThreshold10(pixels[0], expected[0]) || checkWithThreshold10(pixels[1], expected[1])
1005 || checkWithThreshold10(pixels[2], expected[2]) || checkWithThreshold10(pixels[3], expected[3]))
1007 if (m_debugLog.str().size() > 0) {
1008 log << tcu::TestLog::Message
1009 << "Prior passing tests\n"
1011 << tcu::TestLog::EndMessage;
1014 log << tcu::TestLog::Message
1015 << "Image comparison failed: "
1016 << "reference = " << reference
1017 << ", expected = " << static_cast<deUint32>(expected[0])
1018 << ":" << static_cast<deUint32>(expected[1])
1019 << ":" << static_cast<deUint32>(expected[2])
1020 << ":" << static_cast<deUint32>(expected[3])
1021 << ", result = " << static_cast<deUint32>(pixels[0])
1022 << ":" << static_cast<deUint32>(pixels[1])
1023 << ":" << static_cast<deUint32>(pixels[2])
1024 << ":" << static_cast<deUint32>(pixels[3])
1025 << tcu::TestLog::EndMessage;
1026 m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Color test failed");
1030 // Pixel matches expected value
1031 m_debugLog << "Image comparison passed: "
1032 << "reference = " << reference
1033 << ", result = " << static_cast<deUint32>(pixels[0])
1034 << ":" << static_cast<deUint32>(pixels[1])
1035 << ":" << static_cast<deUint32>(pixels[2])
1036 << ":" << static_cast<deUint32>(pixels[3])
1043 deUint8 expected[4];
1044 readPixels(m_gl, pixels);
1046 expected[0] = expectedUint8(reference);
1047 expected[1] = expectedUint8(reference + increment);
1048 expected[2] = expectedUint8(reference - increment);
1049 expected[3] = expectedAlpha8(reference + 2 * increment);
1050 if (checkWithThreshold8(pixels[0], expected[0]) || checkWithThreshold8(pixels[1], expected[1])
1051 || checkWithThreshold8(pixels[2], expected[2]) || checkWithThreshold8(pixels[3], expected[3]))
1053 if (m_debugLog.str().size() > 0) {
1054 log << tcu::TestLog::Message
1055 << "(C)Prior passing tests\n"
1057 << tcu::TestLog::EndMessage;
1060 log << tcu::TestLog::Message
1061 << "Image comparison failed: "
1062 << "reference = " << reference
1063 << ", expected = " << static_cast<deUint32>(expected[0])
1064 << ":" << static_cast<deUint32>(expected[1])
1065 << ":" << static_cast<deUint32>(expected[2])
1066 << ":" << static_cast<deUint32>(expected[3])
1067 << ", result = " << static_cast<deUint32>(pixels[0])
1068 << ":" << static_cast<deUint32>(pixels[1])
1069 << ":" << static_cast<deUint32>(pixels[2])
1070 << ":" << static_cast<deUint32>(pixels[3])
1071 << tcu::TestLog::EndMessage;
1072 m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Color test failed");
1076 // Pixel matches expected value
1077 m_debugLog << "Image comparison passed: "
1078 << "reference = " << reference
1079 << ", result = " << static_cast<deUint32>(pixels[0])
1080 << ":" << static_cast<deUint32>(pixels[1])
1081 << ":" << static_cast<deUint32>(pixels[2])
1082 << ":" << static_cast<deUint32>(pixels[3])
1088 void WideColorSurfaceTest::doClearTest (EGLSurface surface)
1090 tcu::TestLog& log = m_testCtx.getLog();
1091 const Library& egl = m_eglTestCtx.getLibrary();
1092 const EGLint attribList[] =
1094 EGL_CONTEXT_CLIENT_VERSION, 2,
1097 EGLContext eglContext = egl.createContext(m_eglDisplay, m_eglConfig, EGL_NO_CONTEXT, attribList);
1098 EGLU_CHECK_MSG(egl, "eglCreateContext");
1100 egl.makeCurrent(m_eglDisplay, surface, surface, eglContext);
1101 EGLU_CHECK_MSG(egl, "eglMakeCurrent");
1104 // put gles2Renderer inside it's own scope so that it's cleaned
1105 // up before we hit the destroyContext
1106 const GLES2Renderer gles2Renderer(m_gl, 128, 128);
1108 std::vector<Iteration>::const_iterator it; // declare an Iterator to a vector of strings
1109 log << tcu::TestLog::Message << "m_iterations.count = " << m_iterations.size() << tcu::TestLog::EndMessage;
1110 for(it = m_iterations.begin() ; it < m_iterations.end(); it++)
1112 float reference = it->start;
1113 log << tcu::TestLog::Message << "start = " << it->start
1114 << tcu::TestLog::EndMessage;
1115 log << tcu::TestLog::Message
1116 << "increment = " << it->increment
1117 << tcu::TestLog::EndMessage;
1118 log << tcu::TestLog::Message
1119 << "count = " << it->iterationCount
1120 << tcu::TestLog::EndMessage;
1122 for (int iterationCount = 0; iterationCount < it->iterationCount; iterationCount++)
1124 const Color clearColor(reference, reference + it->increment, reference - it->increment, reference + 2 * it->increment);
1126 clearColorScreen(m_gl, clearColor);
1127 GLU_EXPECT_NO_ERROR(m_gl.getError(), "Clear to test value");
1129 testPixels(reference, it->increment);
1131 // reset buffer contents so that we know render below did something
1132 const Color clearColor2(1.0f - reference, 1.0f, 1.0f, 1.0f);
1133 clearColorScreen(m_gl, clearColor2);
1134 GLU_EXPECT_NO_ERROR(m_gl.getError(), "Clear to 1.0f - reference value");
1136 const ColoredRect coloredRect (IVec2(0.0f, 0.0f), IVec2(1.0f, 1.0f), clearColor);
1137 gles2Renderer.render(coloredRect);
1138 testPixels(reference, it->increment);
1140 reference += it->increment;
1143 EGLU_CHECK_CALL(egl, swapBuffers(m_eglDisplay, surface));
1147 // disconnect surface & context so they can be destroyed when
1148 // this function exits.
1149 EGLU_CHECK_CALL(egl, makeCurrent(m_eglDisplay, EGL_NO_SURFACE, EGL_NO_SURFACE, EGL_NO_CONTEXT));
1151 egl.destroyContext(m_eglDisplay, eglContext);
1154 void WideColorSurfaceTest::executeTest (void)
1156 tcu::TestLog& log = m_testCtx.getLog();
1157 const Library& egl = m_eglTestCtx.getLibrary();
1158 const eglu::NativeDisplayFactory& displayFactory = m_eglTestCtx.getNativeDisplayFactory();
1159 eglu::NativeDisplay& nativeDisplay = m_eglTestCtx.getNativeDisplay();
1160 egl.bindAPI(EGL_OPENGL_ES_API);
1162 if (m_surfaceType & EGL_PBUFFER_BIT)
1164 log << tcu::TestLog::Message << "Test Pbuffer" << tcu::TestLog::EndMessage;
1166 std::vector<EGLint> attribs;
1167 attribs.push_back(EGL_WIDTH);
1168 attribs.push_back(128);
1169 attribs.push_back(EGL_HEIGHT);
1170 attribs.push_back(128);
1171 if (m_colorSpace != EGL_NONE)
1173 attribs.push_back(EGL_GL_COLORSPACE_KHR);
1174 attribs.push_back(m_colorSpace);
1176 attribs.push_back(EGL_NONE);
1177 attribs.push_back(EGL_NONE);
1178 const EGLSurface surface = egl.createPbufferSurface(m_eglDisplay, m_eglConfig, attribs.data());
1179 if ((surface == EGL_NO_SURFACE) && (egl.getError() == EGL_BAD_MATCH))
1181 TCU_THROW(NotSupportedError, "Colorspace is not supported with this format");
1183 TCU_CHECK(surface != EGL_NO_SURFACE);
1184 EGLU_CHECK_MSG(egl, "eglCreatePbufferSurface()");
1186 doClearTest(surface);
1188 egl.destroySurface(m_eglDisplay, surface);
1189 EGLU_CHECK_MSG(egl, "eglDestroySurface()");
1191 else if (m_surfaceType & EGL_WINDOW_BIT)
1193 log << tcu::TestLog::Message << "Test Window" << tcu::TestLog::EndMessage;
1195 const eglu::NativeWindowFactory& windowFactory = eglu::selectNativeWindowFactory(displayFactory, m_testCtx.getCommandLine());
1197 de::UniquePtr<eglu::NativeWindow> window (windowFactory.createWindow(&nativeDisplay, m_eglDisplay, m_eglConfig, DE_NULL, eglu::WindowParams(128, 128, eglu::parseWindowVisibility(m_testCtx.getCommandLine()))));
1198 std::vector<EGLAttrib> attribs;
1199 if (m_colorSpace != EGL_NONE)
1201 attribs.push_back(EGL_GL_COLORSPACE_KHR);
1202 attribs.push_back(m_colorSpace);
1204 attribs.push_back(EGL_NONE);
1205 attribs.push_back(EGL_NONE);
1210 surface = eglu::createWindowSurface(nativeDisplay, *window, m_eglDisplay, m_eglConfig, attribs.data());
1212 catch (const eglu::Error& error)
1214 if (error.getError() == EGL_BAD_MATCH)
1215 TCU_THROW(NotSupportedError, "createWindowSurface is not supported for this config");
1219 TCU_CHECK(surface != EGL_NO_SURFACE);
1220 EGLU_CHECK_MSG(egl, "eglCreateWindowSurface()");
1222 doClearTest(surface);
1224 if (m_testAttribList.size() > 0)
1226 for (deUint32 i = 0; i < m_testAttribList.size(); i +=2)
1228 if (!egl.surfaceAttrib(m_eglDisplay, surface, m_testAttribList[i], m_testAttribList[i+1]))
1230 // Implementation can return EGL_BAD_PARAMETER if given value is not supported.
1231 EGLint error = egl.getError();
1232 if (error != EGL_BAD_PARAMETER)
1233 TCU_FAIL("Unable to set HDR metadata on surface");
1235 log << tcu::TestLog::Message <<
1236 "Warning: Metadata value " << m_testAttribList[i+1] << " for attrib 0x" <<
1237 std::hex << m_testAttribList[i] << std::dec <<
1238 " not supported by the implementation." << tcu::TestLog::EndMessage;
1239 m_testAttribList[i+1] = EGL_BAD_PARAMETER;
1242 for (deUint32 i = 0; i < m_testAttribList.size(); i +=2)
1244 // Skip unsupported values.
1245 if (m_testAttribList[i+1] == EGL_BAD_PARAMETER)
1249 egl.querySurface(m_eglDisplay, surface, m_testAttribList[i], &value);
1250 TCU_CHECK(value == m_testAttribList[i+1]);
1254 egl.destroySurface(m_eglDisplay, surface);
1255 EGLU_CHECK_MSG(egl, "eglDestroySurface()");
1257 else if (m_surfaceType & EGL_PIXMAP_BIT)
1259 log << tcu::TestLog::Message << "Test Pixmap" << tcu::TestLog::EndMessage;
1261 const eglu::NativePixmapFactory& pixmapFactory = eglu::selectNativePixmapFactory(displayFactory, m_testCtx.getCommandLine());
1263 de::UniquePtr<eglu::NativePixmap> pixmap (pixmapFactory.createPixmap(&nativeDisplay, m_eglDisplay, m_eglConfig, DE_NULL, 128, 128));
1264 const EGLSurface surface = eglu::createPixmapSurface(nativeDisplay, *pixmap, m_eglDisplay, m_eglConfig, DE_NULL);
1265 TCU_CHECK(surface != EGL_NO_SURFACE);
1266 EGLU_CHECK_MSG(egl, "eglCreatePixmapSurface()");
1268 doClearTest(surface);
1270 egl.destroySurface(m_eglDisplay, surface);
1271 EGLU_CHECK_MSG(egl, "eglDestroySurface()");
1274 TCU_FAIL("No valid surface types supported in config");
1277 TestCase::IterateResult WideColorSurfaceTest::iterate (void)
1279 m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass");
1286 WideColorTests::WideColorTests (EglTestContext& eglTestCtx)
1287 : TestCaseGroup(eglTestCtx, "wide_color", "Wide Color tests")
1291 void WideColorTests::init (void)
1293 addChild(new WideColorFP16Test(m_eglTestCtx, "fp16", "Verify that FP16 pixel format is present"));
1294 addChild(new WideColor1010102Test(m_eglTestCtx, "1010102", "Check if 1010102 pixel format is present"));
1296 // This is an increment FP16 can do between -1.0 to 1.0
1297 const float fp16Increment1 = deFloatPow(2.0, -11.0);
1298 // This is an increment FP16 can do between 1.0 to 2.0
1299 const float fp16Increment2 = deFloatPow(2.0, -10.0);
1301 const EGLint windowAttribListFP16[] =
1303 EGL_SURFACE_TYPE, EGL_WINDOW_BIT,
1304 EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT,
1309 EGL_COLOR_COMPONENT_TYPE_EXT, EGL_COLOR_COMPONENT_TYPE_FLOAT_EXT,
1313 std::vector<Iteration> fp16Iterations;
1314 // -0.333251953125f ~ -1/3 as seen in FP16
1315 fp16Iterations.push_back(Iteration(-0.333251953125f, fp16Increment1, 10));
1317 fp16Iterations.push_back( Iteration(-fp16Increment1 * 5.0f, fp16Increment1, 10));
1318 // test crossing 1.0
1319 fp16Iterations.push_back( Iteration(1.0f - fp16Increment2 * 5.0f, fp16Increment2, 10));
1320 addChild(new WideColorSurfaceTest(m_eglTestCtx, "window_fp16_default_colorspace", "FP16 window surface has FP16 pixels in it", windowAttribListFP16, EGL_NONE, fp16Iterations));
1321 addChild(new WideColorSurfaceTest(m_eglTestCtx, "window_fp16_colorspace_srgb", "FP16 window surface, explicit sRGB colorspace", windowAttribListFP16, EGL_GL_COLORSPACE_SRGB_KHR, fp16Iterations));
1322 addChild(new WideColorSurfaceTest(m_eglTestCtx, "window_fp16_colorspace_p3", "FP16 window surface, explicit Display-P3 colorspace", windowAttribListFP16, EGL_GL_COLORSPACE_DISPLAY_P3_EXT, fp16Iterations));
1323 addChild(new WideColorSurfaceTest(m_eglTestCtx, "window_fp16_colorspace_scrgb", "FP16 window surface, explicit scRGB colorspace", windowAttribListFP16, EGL_GL_COLORSPACE_SCRGB_EXT, fp16Iterations));
1324 addChild(new WideColorSurfaceTest(m_eglTestCtx, "window_fp16_colorspace_scrgb_linear", "FP16 window surface, explicit scRGB linear colorspace", windowAttribListFP16, EGL_GL_COLORSPACE_SCRGB_LINEAR_EXT, fp16Iterations));
1326 const EGLint pbufferAttribListFP16[] =
1328 EGL_SURFACE_TYPE, EGL_PBUFFER_BIT,
1329 EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT,
1334 EGL_COLOR_COMPONENT_TYPE_EXT, EGL_COLOR_COMPONENT_TYPE_FLOAT_EXT,
1337 addChild(new WideColorSurfaceTest(m_eglTestCtx, "pbuffer_fp16_default_colorspace", "FP16 pbuffer surface has FP16 pixels in it", pbufferAttribListFP16, EGL_NONE, fp16Iterations));
1338 addChild(new WideColorSurfaceTest(m_eglTestCtx, "pbuffer_fp16_colorspace_srgb", "FP16 pbuffer surface, explicit sRGB colorspace", pbufferAttribListFP16, EGL_GL_COLORSPACE_SRGB_KHR, fp16Iterations));
1339 addChild(new WideColorSurfaceTest(m_eglTestCtx, "pbuffer_fp16_colorspace_p3", "FP16 pbuffer surface, explicit Display-P3 colorspace", pbufferAttribListFP16, EGL_GL_COLORSPACE_DISPLAY_P3_EXT, fp16Iterations));
1340 addChild(new WideColorSurfaceTest(m_eglTestCtx, "pbuffer_fp16_colorspace_scrgb", "FP16 pbuffer surface, explicit scRGB colorspace", pbufferAttribListFP16, EGL_GL_COLORSPACE_SCRGB_EXT, fp16Iterations));
1341 addChild(new WideColorSurfaceTest(m_eglTestCtx, "pbuffer_fp16_colorspace_scrgb_linear", "FP16 pbuffer surface, explicit scRGB linear colorspace", pbufferAttribListFP16, EGL_GL_COLORSPACE_SCRGB_LINEAR_EXT, fp16Iterations));
1343 const EGLint windowAttribList1010102[] =
1345 EGL_SURFACE_TYPE, EGL_WINDOW_BIT,
1346 EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT,
1354 std::vector<Iteration> int1010102Iterations;
1355 // -0.333251953125f ~ -1/3 as seen in fp16
1356 // Negative values will be 0 on read with fixed point pixel formats
1357 int1010102Iterations.push_back(Iteration(-0.333251953125f, fp16Increment1, 10));
1359 int1010102Iterations.push_back(Iteration(-fp16Increment1 * 5.0f, fp16Increment1, 10));
1360 // test crossing 1.0
1361 // Values > 1.0 will be truncated to 1.0 with fixed point pixel formats
1362 int1010102Iterations.push_back(Iteration(1.0f - fp16Increment2 * 5.0f, fp16Increment2, 10));
1363 addChild(new WideColorSurfaceTest(m_eglTestCtx, "window_1010102_colorspace_default", "1010102 Window surface, default (sRGB) colorspace", windowAttribList1010102, EGL_NONE, int1010102Iterations));
1364 addChild(new WideColorSurfaceTest(m_eglTestCtx, "window_1010102_colorspace_srgb", "1010102 Window surface, explicit sRGB colorspace", windowAttribList1010102, EGL_GL_COLORSPACE_SRGB_KHR, int1010102Iterations));
1365 addChild(new WideColorSurfaceTest(m_eglTestCtx, "window_1010102_colorspace_p3", "1010102 Window surface, explicit Display-P3 colorspace", windowAttribList1010102, EGL_GL_COLORSPACE_DISPLAY_P3_EXT, int1010102Iterations));
1367 const EGLint pbufferAttribList1010102[] =
1369 EGL_SURFACE_TYPE, EGL_PBUFFER_BIT,
1370 EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT,
1377 addChild(new WideColorSurfaceTest(m_eglTestCtx, "pbuffer_1010102_colorspace_default", "1010102 pbuffer surface, default (sRGB) colorspace", pbufferAttribList1010102, EGL_NONE, int1010102Iterations));
1378 addChild(new WideColorSurfaceTest(m_eglTestCtx, "pbuffer_1010102_colorspace_srgb", "1010102 pbuffer surface, explicit sRGB colorspace", pbufferAttribList1010102, EGL_GL_COLORSPACE_SRGB_KHR, int1010102Iterations));
1379 addChild(new WideColorSurfaceTest(m_eglTestCtx, "pbuffer_1010102_colorspace_p3", "1010102 pbuffer surface, explicit Display-P3 colorspace", pbufferAttribList1010102, EGL_GL_COLORSPACE_DISPLAY_P3_EXT, int1010102Iterations));
1381 const EGLint windowAttribList8888[] =
1383 EGL_SURFACE_TYPE, EGL_WINDOW_BIT,
1384 EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT,
1392 std::vector<Iteration> int8888Iterations;
1393 // -0.333251953125f ~ -1/3 as seen in fp16
1394 // Negative values will be 0 on read with fixed point pixel formats
1395 int8888Iterations.push_back(Iteration(-0.333251953125f, fp16Increment1, 10));
1397 int8888Iterations.push_back(Iteration(-fp16Increment1 * 5.0f, fp16Increment1, 10));
1398 // test crossing 1.0
1399 // Values > 1.0 will be truncated to 1.0 with fixed point pixel formats
1400 int8888Iterations.push_back(Iteration(1.0f - fp16Increment2 * 5.0f, fp16Increment2, 10));
1401 addChild(new WideColorSurfaceTest(m_eglTestCtx, "window_8888_colorspace_default", "8888 window surface, default (sRGB) colorspace", windowAttribList8888, EGL_NONE, int8888Iterations));
1402 addChild(new WideColorSurfaceTest(m_eglTestCtx, "window_8888_colorspace_srgb", "8888 window surface, explicit sRGB colorspace", windowAttribList8888, EGL_GL_COLORSPACE_SRGB_KHR, int8888Iterations));
1403 addChild(new WideColorSurfaceTest(m_eglTestCtx, "window_8888_colorspace_p3", "8888 window surface, explicit Display-P3 colorspace", windowAttribList8888, EGL_GL_COLORSPACE_DISPLAY_P3_EXT, int8888Iterations));
1405 const EGLint pbufferAttribList8888[] =
1407 EGL_SURFACE_TYPE, EGL_PBUFFER_BIT,
1408 EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT,
1415 addChild(new WideColorSurfaceTest(m_eglTestCtx, "pbuffer_8888_colorspace_default", "8888 pbuffer surface, default (sRGB) colorspace", pbufferAttribList8888, EGL_NONE, int8888Iterations));
1416 addChild(new WideColorSurfaceTest(m_eglTestCtx, "pbuffer_8888_colorspace_srgb", "8888 pbuffer surface, explicit sRGB colorspace", pbufferAttribList8888, EGL_GL_COLORSPACE_SRGB_KHR, int8888Iterations));
1417 addChild(new WideColorSurfaceTest(m_eglTestCtx, "pbuffer_8888_colorspace_p3", "8888 pbuffer surface, explicit Display-P3 colorspace", pbufferAttribList8888, EGL_GL_COLORSPACE_DISPLAY_P3_EXT, int8888Iterations));
1420 TestCaseGroup* createWideColorTests (EglTestContext& eglTestCtx)
1422 return new WideColorTests(eglTestCtx);
1425 class Smpte2086ColorTest : public WideColorTest
1428 Smpte2086ColorTest (EglTestContext& eglTestCtx,
1430 const char* description);
1432 void executeTest (void);
1433 IterateResult iterate (void);
1436 Smpte2086ColorTest::Smpte2086ColorTest (EglTestContext& eglTestCtx, const char* name, const char* description)
1437 : WideColorTest(eglTestCtx, name, description)
1441 #define METADATA_SCALE(x) (static_cast<EGLint>(x * EGL_METADATA_SCALING_EXT))
1443 void Smpte2086ColorTest::executeTest (void)
1445 tcu::TestLog& log = m_testCtx.getLog();
1446 const Library& egl = m_eglTestCtx.getLibrary();
1447 egl.bindAPI(EGL_OPENGL_ES_API);
1449 log << tcu::TestLog::Message << "Test SMPTE 2086 Metadata on Window" << tcu::TestLog::EndMessage;
1453 // This is an increment FP16 can do between -1.0 to 1.0
1454 const float fp16Increment1 = deFloatPow(2.0, -11.0);
1455 // This is an increment FP16 can do between 1.0 to 2.0
1456 const float fp16Increment2 = deFloatPow(2.0, -10.0);
1458 std::vector<Iteration> int8888Iterations;
1459 // -0.333251953125f ~ -1/3 as seen in fp16
1460 // Negative values will be 0 on read with fixed point pixel formats
1461 int8888Iterations.push_back(Iteration(-0.333251953125f, fp16Increment1, 10));
1463 int8888Iterations.push_back(Iteration(-fp16Increment1 * 5.0f, fp16Increment1, 10));
1464 // test crossing 1.0
1465 // Values > 1.0 will be truncated to 1.0 with fixed point pixel formats
1466 int8888Iterations.push_back(Iteration(1.0f - fp16Increment2 * 5.0f, fp16Increment2, 10));
1468 const EGLint windowAttribList8888[] =
1470 EGL_SURFACE_TYPE, EGL_WINDOW_BIT,
1471 EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT,
1479 WideColorSurfaceTest testObj(m_eglTestCtx, "window_8888_colorspace_default", "8888 window surface, default (sRGB) colorspace", windowAttribList8888, EGL_NONE, int8888Iterations);
1481 const EGLint testAttrs[] =
1483 EGL_SMPTE2086_DISPLAY_PRIMARY_RX_EXT, METADATA_SCALE(0.680),
1484 EGL_SMPTE2086_DISPLAY_PRIMARY_RY_EXT, METADATA_SCALE(0.320),
1485 EGL_SMPTE2086_DISPLAY_PRIMARY_GX_EXT, METADATA_SCALE(0.265),
1486 EGL_SMPTE2086_DISPLAY_PRIMARY_GY_EXT, METADATA_SCALE(0.690),
1487 EGL_SMPTE2086_DISPLAY_PRIMARY_BX_EXT, METADATA_SCALE(0.440),
1488 EGL_SMPTE2086_DISPLAY_PRIMARY_BY_EXT, METADATA_SCALE(0.320),
1489 EGL_SMPTE2086_WHITE_POINT_X_EXT, METADATA_SCALE(0.2200),
1490 EGL_SMPTE2086_WHITE_POINT_Y_EXT, METADATA_SCALE(0.2578),
1491 EGL_SMPTE2086_MAX_LUMINANCE_EXT, METADATA_SCALE(1.31),
1492 EGL_SMPTE2086_MIN_LUMINANCE_EXT, METADATA_SCALE(0.123),
1495 testObj.addTestAttributes(testAttrs);
1498 testObj.executeTest();
1501 TestCase::IterateResult Smpte2086ColorTest::iterate (void)
1503 m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass");
1508 class Cta8613ColorTest : public WideColorTest
1511 Cta8613ColorTest (EglTestContext& eglTestCtx,
1513 const char* description);
1515 void executeTest (void);
1516 IterateResult iterate (void);
1519 Cta8613ColorTest::Cta8613ColorTest (EglTestContext& eglTestCtx, const char* name, const char* description)
1520 : WideColorTest(eglTestCtx, name, description)
1524 #define METADATA_SCALE(x) (static_cast<EGLint>(x * EGL_METADATA_SCALING_EXT))
1526 void Cta8613ColorTest::executeTest (void)
1528 tcu::TestLog& log = m_testCtx.getLog();
1529 const Library& egl = m_eglTestCtx.getLibrary();
1530 egl.bindAPI(EGL_OPENGL_ES_API);
1532 log << tcu::TestLog::Message << "Test CTA 861.3 Metadata on Window" << tcu::TestLog::EndMessage;
1536 // This is an increment FP16 can do between -1.0 to 1.0
1537 const float fp16Increment1 = deFloatPow(2.0, -11.0);
1538 // This is an increment FP16 can do between 1.0 to 2.0
1539 const float fp16Increment2 = deFloatPow(2.0, -10.0);
1541 std::vector<Iteration> int8888Iterations;
1542 // -0.333251953125f ~ -1/3 as seen in fp16
1543 // Negative values will be 0 on read with fixed point pixel formats
1544 int8888Iterations.push_back(Iteration(-0.333251953125f, fp16Increment1, 10));
1546 int8888Iterations.push_back(Iteration(-fp16Increment1 * 5.0f, fp16Increment1, 10));
1547 // test crossing 1.0
1548 // Values > 1.0 will be truncated to 1.0 with fixed point pixel formats
1549 int8888Iterations.push_back(Iteration(1.0f - fp16Increment2 * 5.0f, fp16Increment2, 10));
1551 const EGLint windowAttribList8888[] =
1553 EGL_SURFACE_TYPE, EGL_WINDOW_BIT,
1554 EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT,
1562 WideColorSurfaceTest testObj(m_eglTestCtx, "window_8888_colorspace_default", "8888 window surface, default (sRGB) colorspace", windowAttribList8888, EGL_NONE, int8888Iterations);
1564 const EGLint testAttrs[] =
1566 EGL_CTA861_3_MAX_CONTENT_LIGHT_LEVEL_EXT, METADATA_SCALE(1.31),
1567 EGL_CTA861_3_MAX_FRAME_AVERAGE_LEVEL_EXT, METADATA_SCALE(0.6),
1570 testObj.addTestAttributes(testAttrs);
1573 testObj.executeTest();
1576 TestCase::IterateResult Cta8613ColorTest::iterate (void)
1578 m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass");
1583 class HdrColorTests : public TestCaseGroup
1586 HdrColorTests (EglTestContext& eglTestCtx);
1590 HdrColorTests (const HdrColorTests&);
1591 HdrColorTests& operator= (const HdrColorTests&);
1594 HdrColorTests::HdrColorTests (EglTestContext& eglTestCtx)
1595 : TestCaseGroup(eglTestCtx, "hdr_metadata", "HDR Metadata tests")
1599 void HdrColorTests::init (void)
1601 addChild(new Smpte2086ColorTest(m_eglTestCtx, "smpte2086", "Verify that SMPTE 2086 extension exists"));
1602 addChild(new Cta8613ColorTest(m_eglTestCtx, "cta861_3", "Verify that CTA 861.3 extension exists"));
1605 TestCaseGroup* createHdrColorTests (EglTestContext& eglTestCtx)
1607 return new HdrColorTests(eglTestCtx);