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])) {
1229 TCU_FAIL("Unable to set HDR metadata on surface");
1232 for (deUint32 i = 0; i < m_testAttribList.size(); i +=2)
1235 egl.querySurface(m_eglDisplay, surface, m_testAttribList[i], &value);
1236 TCU_CHECK(value == m_testAttribList[i+1]);
1240 egl.destroySurface(m_eglDisplay, surface);
1241 EGLU_CHECK_MSG(egl, "eglDestroySurface()");
1243 else if (m_surfaceType & EGL_PIXMAP_BIT)
1245 log << tcu::TestLog::Message << "Test Pixmap" << tcu::TestLog::EndMessage;
1247 const eglu::NativePixmapFactory& pixmapFactory = eglu::selectNativePixmapFactory(displayFactory, m_testCtx.getCommandLine());
1249 de::UniquePtr<eglu::NativePixmap> pixmap (pixmapFactory.createPixmap(&nativeDisplay, m_eglDisplay, m_eglConfig, DE_NULL, 128, 128));
1250 const EGLSurface surface = eglu::createPixmapSurface(nativeDisplay, *pixmap, m_eglDisplay, m_eglConfig, DE_NULL);
1251 TCU_CHECK(surface != EGL_NO_SURFACE);
1252 EGLU_CHECK_MSG(egl, "eglCreatePixmapSurface()");
1254 doClearTest(surface);
1256 egl.destroySurface(m_eglDisplay, surface);
1257 EGLU_CHECK_MSG(egl, "eglDestroySurface()");
1260 TCU_FAIL("No valid surface types supported in config");
1263 TestCase::IterateResult WideColorSurfaceTest::iterate (void)
1265 m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass");
1272 WideColorTests::WideColorTests (EglTestContext& eglTestCtx)
1273 : TestCaseGroup(eglTestCtx, "wide_color", "Wide Color tests")
1277 void WideColorTests::init (void)
1279 addChild(new WideColorFP16Test(m_eglTestCtx, "fp16", "Verify that FP16 pixel format is present"));
1280 addChild(new WideColor1010102Test(m_eglTestCtx, "1010102", "Check if 1010102 pixel format is present"));
1282 // This is an increment FP16 can do between -1.0 to 1.0
1283 const float fp16Increment1 = deFloatPow(2.0, -11.0);
1284 // This is an increment FP16 can do between 1.0 to 2.0
1285 const float fp16Increment2 = deFloatPow(2.0, -10.0);
1287 const EGLint windowAttribListFP16[] =
1289 EGL_SURFACE_TYPE, EGL_WINDOW_BIT,
1290 EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT,
1295 EGL_COLOR_COMPONENT_TYPE_EXT, EGL_COLOR_COMPONENT_TYPE_FLOAT_EXT,
1299 std::vector<Iteration> fp16Iterations;
1300 // -0.333251953125f ~ -1/3 as seen in FP16
1301 fp16Iterations.push_back(Iteration(-0.333251953125f, fp16Increment1, 10));
1303 fp16Iterations.push_back( Iteration(-fp16Increment1 * 5.0f, fp16Increment1, 10));
1304 // test crossing 1.0
1305 fp16Iterations.push_back( Iteration(1.0f - fp16Increment2 * 5.0f, fp16Increment2, 10));
1306 addChild(new WideColorSurfaceTest(m_eglTestCtx, "window_fp16_default_colorspace", "FP16 window surface has FP16 pixels in it", windowAttribListFP16, EGL_NONE, fp16Iterations));
1307 addChild(new WideColorSurfaceTest(m_eglTestCtx, "window_fp16_colorspace_srgb", "FP16 window surface, explicit sRGB colorspace", windowAttribListFP16, EGL_GL_COLORSPACE_SRGB_KHR, fp16Iterations));
1308 addChild(new WideColorSurfaceTest(m_eglTestCtx, "window_fp16_colorspace_p3", "FP16 window surface, explicit Display-P3 colorspace", windowAttribListFP16, EGL_GL_COLORSPACE_DISPLAY_P3_EXT, fp16Iterations));
1309 addChild(new WideColorSurfaceTest(m_eglTestCtx, "window_fp16_colorspace_scrgb", "FP16 window surface, explicit scRGB colorspace", windowAttribListFP16, EGL_GL_COLORSPACE_SCRGB_EXT, fp16Iterations));
1310 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));
1312 const EGLint pbufferAttribListFP16[] =
1314 EGL_SURFACE_TYPE, EGL_PBUFFER_BIT,
1315 EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT,
1320 EGL_COLOR_COMPONENT_TYPE_EXT, EGL_COLOR_COMPONENT_TYPE_FLOAT_EXT,
1323 addChild(new WideColorSurfaceTest(m_eglTestCtx, "pbuffer_fp16_default_colorspace", "FP16 pbuffer surface has FP16 pixels in it", pbufferAttribListFP16, EGL_NONE, fp16Iterations));
1324 addChild(new WideColorSurfaceTest(m_eglTestCtx, "pbuffer_fp16_colorspace_srgb", "FP16 pbuffer surface, explicit sRGB colorspace", pbufferAttribListFP16, EGL_GL_COLORSPACE_SRGB_KHR, fp16Iterations));
1325 addChild(new WideColorSurfaceTest(m_eglTestCtx, "pbuffer_fp16_colorspace_p3", "FP16 pbuffer surface, explicit Display-P3 colorspace", pbufferAttribListFP16, EGL_GL_COLORSPACE_DISPLAY_P3_EXT, fp16Iterations));
1326 addChild(new WideColorSurfaceTest(m_eglTestCtx, "pbuffer_fp16_colorspace_scrgb", "FP16 pbuffer surface, explicit scRGB colorspace", pbufferAttribListFP16, EGL_GL_COLORSPACE_SCRGB_EXT, fp16Iterations));
1327 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));
1329 const EGLint windowAttribList1010102[] =
1331 EGL_SURFACE_TYPE, EGL_WINDOW_BIT,
1332 EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT,
1340 std::vector<Iteration> int1010102Iterations;
1341 // -0.333251953125f ~ -1/3 as seen in fp16
1342 // Negative values will be 0 on read with fixed point pixel formats
1343 int1010102Iterations.push_back(Iteration(-0.333251953125f, fp16Increment1, 10));
1345 int1010102Iterations.push_back(Iteration(-fp16Increment1 * 5.0f, fp16Increment1, 10));
1346 // test crossing 1.0
1347 // Values > 1.0 will be truncated to 1.0 with fixed point pixel formats
1348 int1010102Iterations.push_back(Iteration(1.0f - fp16Increment2 * 5.0f, fp16Increment2, 10));
1349 addChild(new WideColorSurfaceTest(m_eglTestCtx, "window_1010102_colorspace_default", "1010102 Window surface, default (sRGB) colorspace", windowAttribList1010102, EGL_NONE, int1010102Iterations));
1350 addChild(new WideColorSurfaceTest(m_eglTestCtx, "window_1010102_colorspace_srgb", "1010102 Window surface, explicit sRGB colorspace", windowAttribList1010102, EGL_GL_COLORSPACE_SRGB_KHR, int1010102Iterations));
1351 addChild(new WideColorSurfaceTest(m_eglTestCtx, "window_1010102_colorspace_p3", "1010102 Window surface, explicit Display-P3 colorspace", windowAttribList1010102, EGL_GL_COLORSPACE_DISPLAY_P3_EXT, int1010102Iterations));
1353 const EGLint pbufferAttribList1010102[] =
1355 EGL_SURFACE_TYPE, EGL_PBUFFER_BIT,
1356 EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT,
1363 addChild(new WideColorSurfaceTest(m_eglTestCtx, "pbuffer_1010102_colorspace_default", "1010102 pbuffer surface, default (sRGB) colorspace", pbufferAttribList1010102, EGL_NONE, int1010102Iterations));
1364 addChild(new WideColorSurfaceTest(m_eglTestCtx, "pbuffer_1010102_colorspace_srgb", "1010102 pbuffer surface, explicit sRGB colorspace", pbufferAttribList1010102, EGL_GL_COLORSPACE_SRGB_KHR, int1010102Iterations));
1365 addChild(new WideColorSurfaceTest(m_eglTestCtx, "pbuffer_1010102_colorspace_p3", "1010102 pbuffer surface, explicit Display-P3 colorspace", pbufferAttribList1010102, EGL_GL_COLORSPACE_DISPLAY_P3_EXT, int1010102Iterations));
1367 const EGLint windowAttribList8888[] =
1369 EGL_SURFACE_TYPE, EGL_WINDOW_BIT,
1370 EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT,
1378 std::vector<Iteration> int8888Iterations;
1379 // -0.333251953125f ~ -1/3 as seen in fp16
1380 // Negative values will be 0 on read with fixed point pixel formats
1381 int8888Iterations.push_back(Iteration(-0.333251953125f, fp16Increment1, 10));
1383 int8888Iterations.push_back(Iteration(-fp16Increment1 * 5.0f, fp16Increment1, 10));
1384 // test crossing 1.0
1385 // Values > 1.0 will be truncated to 1.0 with fixed point pixel formats
1386 int8888Iterations.push_back(Iteration(1.0f - fp16Increment2 * 5.0f, fp16Increment2, 10));
1387 addChild(new WideColorSurfaceTest(m_eglTestCtx, "window_8888_colorspace_default", "8888 window surface, default (sRGB) colorspace", windowAttribList8888, EGL_NONE, int8888Iterations));
1388 addChild(new WideColorSurfaceTest(m_eglTestCtx, "window_8888_colorspace_srgb", "8888 window surface, explicit sRGB colorspace", windowAttribList8888, EGL_GL_COLORSPACE_SRGB_KHR, int8888Iterations));
1389 addChild(new WideColorSurfaceTest(m_eglTestCtx, "window_8888_colorspace_p3", "8888 window surface, explicit Display-P3 colorspace", windowAttribList8888, EGL_GL_COLORSPACE_DISPLAY_P3_EXT, int8888Iterations));
1391 const EGLint pbufferAttribList8888[] =
1393 EGL_SURFACE_TYPE, EGL_PBUFFER_BIT,
1394 EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT,
1401 addChild(new WideColorSurfaceTest(m_eglTestCtx, "pbuffer_8888_colorspace_default", "8888 pbuffer surface, default (sRGB) colorspace", pbufferAttribList8888, EGL_NONE, int8888Iterations));
1402 addChild(new WideColorSurfaceTest(m_eglTestCtx, "pbuffer_8888_colorspace_srgb", "8888 pbuffer surface, explicit sRGB colorspace", pbufferAttribList8888, EGL_GL_COLORSPACE_SRGB_KHR, int8888Iterations));
1403 addChild(new WideColorSurfaceTest(m_eglTestCtx, "pbuffer_8888_colorspace_p3", "8888 pbuffer surface, explicit Display-P3 colorspace", pbufferAttribList8888, EGL_GL_COLORSPACE_DISPLAY_P3_EXT, int8888Iterations));
1406 TestCaseGroup* createWideColorTests (EglTestContext& eglTestCtx)
1408 return new WideColorTests(eglTestCtx);
1411 class HdrColorTest : public WideColorTest
1414 HdrColorTest (EglTestContext& eglTestCtx,
1416 const char* description);
1418 void executeTest (void);
1419 IterateResult iterate (void);
1422 HdrColorTest::HdrColorTest (EglTestContext& eglTestCtx, const char* name, const char* description)
1423 : WideColorTest(eglTestCtx, name, description)
1427 #define METADATA_SCALE(x) (static_cast<EGLint>(x * EGL_METADATA_SCALING_EXT))
1429 void HdrColorTest::executeTest (void)
1431 tcu::TestLog& log = m_testCtx.getLog();
1432 const Library& egl = m_eglTestCtx.getLibrary();
1433 egl.bindAPI(EGL_OPENGL_ES_API);
1435 log << tcu::TestLog::Message << "Test HDR Metadata on Window" << tcu::TestLog::EndMessage;
1440 // This is an increment FP16 can do between -1.0 to 1.0
1441 const float fp16Increment1 = deFloatPow(2.0, -11.0);
1442 // This is an increment FP16 can do between 1.0 to 2.0
1443 const float fp16Increment2 = deFloatPow(2.0, -10.0);
1445 std::vector<Iteration> int8888Iterations;
1446 // -0.333251953125f ~ -1/3 as seen in fp16
1447 // Negative values will be 0 on read with fixed point pixel formats
1448 int8888Iterations.push_back(Iteration(-0.333251953125f, fp16Increment1, 10));
1450 int8888Iterations.push_back(Iteration(-fp16Increment1 * 5.0f, fp16Increment1, 10));
1451 // test crossing 1.0
1452 // Values > 1.0 will be truncated to 1.0 with fixed point pixel formats
1453 int8888Iterations.push_back(Iteration(1.0f - fp16Increment2 * 5.0f, fp16Increment2, 10));
1455 const EGLint windowAttribList8888[] =
1457 EGL_SURFACE_TYPE, EGL_WINDOW_BIT,
1458 EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT,
1466 WideColorSurfaceTest testObj(m_eglTestCtx, "window_8888_colorspace_default", "8888 window surface, default (sRGB) colorspace", windowAttribList8888, EGL_NONE, int8888Iterations);
1468 const EGLint testAttrs[] =
1470 EGL_SMPTE2086_DISPLAY_PRIMARY_RX_EXT, METADATA_SCALE(0.680),
1471 EGL_SMPTE2086_DISPLAY_PRIMARY_RY_EXT, METADATA_SCALE(0.320),
1472 EGL_SMPTE2086_DISPLAY_PRIMARY_GX_EXT, METADATA_SCALE(0.265),
1473 EGL_SMPTE2086_DISPLAY_PRIMARY_GY_EXT, METADATA_SCALE(0.690),
1474 EGL_SMPTE2086_DISPLAY_PRIMARY_BX_EXT, METADATA_SCALE(0.440),
1475 EGL_SMPTE2086_DISPLAY_PRIMARY_BY_EXT, METADATA_SCALE(0.320),
1476 EGL_SMPTE2086_WHITE_POINT_X_EXT, METADATA_SCALE(0.2200),
1477 EGL_SMPTE2086_WHITE_POINT_Y_EXT, METADATA_SCALE(0.2578),
1478 EGL_SMPTE2086_MAX_LUMINANCE_EXT, METADATA_SCALE(123.0),
1479 EGL_SMPTE2086_MIN_LUMINANCE_EXT, METADATA_SCALE(0.123),
1480 EGL_CTA861_3_MAX_CONTENT_LIGHT_LEVEL_EXT, METADATA_SCALE(234),
1481 EGL_CTA861_3_MAX_FRAME_AVERAGE_LEVEL_EXT, METADATA_SCALE(67),
1484 testObj.addTestAttributes(testAttrs);
1487 testObj.executeTest();
1490 TestCase::IterateResult HdrColorTest::iterate (void)
1492 m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass");
1497 class HdrColorTests : public TestCaseGroup
1500 HdrColorTests (EglTestContext& eglTestCtx);
1504 HdrColorTests (const HdrColorTests&);
1505 HdrColorTests& operator= (const HdrColorTests&);
1508 HdrColorTests::HdrColorTests (EglTestContext& eglTestCtx)
1509 : TestCaseGroup(eglTestCtx, "hdr_color", "HDR Color tests")
1513 void HdrColorTests::init (void)
1515 addChild(new HdrColorTest(m_eglTestCtx, "8888", "Verify that SMPTE 2086 extension exists"));
1518 TestCaseGroup* createHdrColorTests (EglTestContext& eglTestCtx)
1520 return new HdrColorTests(eglTestCtx);