/*------------------------------------------------------------------------- * drawElements Quality Program EGL Module * --------------------------------------- * * Copyright 2014 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * *//*! * \file * \brief EGL EGL_KHR_fence_sync and EGL_KHR_reusable_sync tests *//*--------------------------------------------------------------------*/ #include "teglSyncTests.hpp" #include "deStringUtil.hpp" #include "egluNativeWindow.hpp" #include "egluStrUtil.hpp" #include "egluUtil.hpp" #include "eglwLibrary.hpp" #include "eglwEnums.hpp" #include "tcuTestLog.hpp" #include "tcuCommandLine.hpp" #include "gluDefs.hpp" #include "glwFunctions.hpp" #include "glwEnums.hpp" #include #include #include #include using std::vector; using std::string; using std::set; using tcu::TestLog; using namespace eglw; using namespace glw; namespace deqp { namespace egl { const char* getSyncTypeName (EGLenum syncType) { switch (syncType) { case EGL_SYNC_FENCE_KHR: return "EGL_SYNC_FENCE_KHR"; case EGL_SYNC_REUSABLE_KHR: return "EGL_SYNC_REUSABLE_KHR"; default: DE_ASSERT(DE_FALSE); return ""; } } class SyncTest : public TestCase { public: typedef EGLSync (Library::*createSync)(EGLDisplay, EGLenum, const EGLAttrib *) const ; typedef EGLSyncKHR (Library::*createSyncKHR)(EGLDisplay, EGLenum, const EGLint *) const ; typedef EGLint (Library::*clientWaitSync)(EGLDisplay, EGLSync, EGLint, EGLTime) const ; typedef EGLint (Library::*clientWaitSyncKHR)(EGLDisplay, EGLSyncKHR, EGLint, EGLTimeKHR) const ; typedef EGLBoolean (Library::*getSyncAttrib)(EGLDisplay, EGLSync, EGLint, EGLAttrib *) const ; typedef EGLBoolean (Library::*getSyncAttribKHR)(EGLDisplay, EGLSyncKHR, EGLint, EGLint *) const ; typedef EGLBoolean (Library::*destroySync)(EGLDisplay, EGLSync) const ; typedef EGLBoolean (Library::*destroySyncKHR)(EGLDisplay, EGLSyncKHR) const ; typedef EGLBoolean (Library::*waitSync)(EGLDisplay, EGLSync, EGLint) const ; typedef EGLint (Library::*waitSyncKHR)(EGLDisplay, EGLSyncKHR, EGLint) const ; enum FunctionName { FUNC_NAME_CREATE_SYNC, FUNC_NAME_CLIENT_WAIT_SYNC, FUNC_NAME_GET_SYNC_ATTRIB, FUNC_NAME_DESTROY_SYNC, FUNC_NAME_WAIT_SYNC, FUNC_NAME_NUM_NAMES }; enum Extension { EXTENSION_NONE = 0, EXTENSION_WAIT_SYNC = (0x1 << 0), EXTENSION_FENCE_SYNC = (0x1 << 1), EXTENSION_REUSABLE_SYNC = (0x1 << 2) }; SyncTest (EglTestContext& eglTestCtx, EGLenum syncType, Extension extensions, bool useCurrentContext, const char* name, const char* description); virtual ~SyncTest (void); void init (void); void deinit (void); bool hasRequiredEGLVersion(int requiredMajor, int requiredMinor); bool hasEGLFenceSyncExtension(void); bool hasEGLWaitSyncExtension(void); EGLDisplay getEglDisplay() {return m_eglDisplay;} protected: const EGLenum m_syncType; const bool m_useCurrentContext; glw::Functions m_gl; Extension m_extensions; EGLDisplay m_eglDisplay; EGLConfig m_eglConfig; EGLSurface m_eglSurface; eglu::NativeWindow* m_nativeWindow; EGLContext m_eglContext; EGLSyncKHR m_sync; string m_funcNames[FUNC_NAME_NUM_NAMES]; string m_funcNamesKHR[FUNC_NAME_NUM_NAMES]; }; SyncTest::SyncTest (EglTestContext& eglTestCtx, EGLenum syncType, Extension extensions, bool useCurrentContext, const char* name, const char* description) : TestCase (eglTestCtx, name, description) , m_syncType (syncType) , m_useCurrentContext (useCurrentContext) , m_extensions (extensions) , m_eglDisplay (EGL_NO_DISPLAY) , m_eglConfig (((eglw::EGLConfig)0)) // EGL_NO_CONFIG , m_eglSurface (EGL_NO_SURFACE) , m_nativeWindow (DE_NULL) , m_eglContext (EGL_NO_CONTEXT) , m_sync (EGL_NO_SYNC_KHR) { m_funcNames[FUNC_NAME_CREATE_SYNC] = "eglCreateSync"; m_funcNames[FUNC_NAME_CLIENT_WAIT_SYNC] = "eglClientWaitSync"; m_funcNames[FUNC_NAME_GET_SYNC_ATTRIB] = "eglGetSyncAttrib"; m_funcNames[FUNC_NAME_DESTROY_SYNC] = "eglDestroySync"; m_funcNames[FUNC_NAME_WAIT_SYNC] = "eglWaitSync"; m_funcNamesKHR[FUNC_NAME_CREATE_SYNC] = "eglCreateSyncKHR"; m_funcNamesKHR[FUNC_NAME_CLIENT_WAIT_SYNC] = "eglClientWaitSyncKHR"; m_funcNamesKHR[FUNC_NAME_GET_SYNC_ATTRIB] = "eglGetSyncAttribKHR"; m_funcNamesKHR[FUNC_NAME_DESTROY_SYNC] = "eglDestroySyncKHR"; m_funcNamesKHR[FUNC_NAME_WAIT_SYNC] = "eglWaitSyncKHR"; } SyncTest::~SyncTest (void) { SyncTest::deinit(); } bool SyncTest::hasRequiredEGLVersion (int requiredMajor, int requiredMinor) { const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); eglu::Version version = eglu::getVersion(egl, m_eglDisplay); if (version < eglu::Version(requiredMajor, requiredMinor)) { log << TestLog::Message << "Required EGL version is not supported. " "Has: " << version.getMajor() << "." << version.getMinor() << ", Required: " << requiredMajor << "." << requiredMinor << TestLog::EndMessage; return false; } return true; } bool SyncTest::hasEGLFenceSyncExtension (void) { TestLog& log = m_testCtx.getLog(); if (!eglu::hasExtension(m_eglTestCtx.getLibrary(), m_eglDisplay, "EGL_KHR_fence_sync")) { log << TestLog::Message << "EGL_KHR_fence_sync not supported" << TestLog::EndMessage; return false; } return true; } bool SyncTest::hasEGLWaitSyncExtension (void) { TestLog& log = m_testCtx.getLog(); if (!eglu::hasExtension(m_eglTestCtx.getLibrary(), m_eglDisplay, "EGL_KHR_wait_sync")) { log << TestLog::Message << "EGL_KHR_wait_sync not supported" << TestLog::EndMessage; return false; } return true; } void requiredGLESExtensions (const glw::Functions& gl) { bool found = false; std::istringstream extensionStream((const char*)gl.getString(GL_EXTENSIONS)); string extension; GLU_CHECK_GLW_MSG(gl, "glGetString(GL_EXTENSIONS)"); while (std::getline(extensionStream, extension, ' ')) { if (extension == "GL_OES_EGL_sync") found = true; } if (!found) TCU_THROW(NotSupportedError, "GL_OES_EGL_sync not supported"); } SyncTest::Extension getSyncTypeExtension (EGLenum syncType) { switch (syncType) { case EGL_SYNC_FENCE_KHR: return SyncTest::EXTENSION_FENCE_SYNC; case EGL_SYNC_REUSABLE_KHR: return SyncTest::EXTENSION_REUSABLE_SYNC; default: DE_ASSERT(DE_FALSE); return SyncTest::EXTENSION_NONE; } } void SyncTest::init (void) { const Library& egl = m_eglTestCtx.getLibrary(); const eglu::NativeWindowFactory& windowFactory = eglu::selectNativeWindowFactory(m_eglTestCtx.getNativeDisplayFactory(), m_testCtx.getCommandLine()); const EGLint displayAttribList[] = { EGL_RENDERABLE_TYPE, EGL_OPENGL_ES2_BIT, EGL_SURFACE_TYPE, EGL_WINDOW_BIT, EGL_ALPHA_SIZE, 1, EGL_NONE }; const EGLint contextAttribList[] = { EGL_CONTEXT_CLIENT_VERSION, 2, EGL_NONE }; m_eglDisplay = eglu::getAndInitDisplay(m_eglTestCtx.getNativeDisplay()); m_eglConfig = eglu::chooseSingleConfig(egl, m_eglDisplay, displayAttribList); m_eglTestCtx.initGLFunctions(&m_gl, glu::ApiType::es(2,0)); m_extensions = (Extension)(m_extensions | getSyncTypeExtension(m_syncType)); if (m_useCurrentContext) { // Create context EGLU_CHECK_CALL(egl, bindAPI(EGL_OPENGL_ES_API)); m_eglContext = egl.createContext(m_eglDisplay, m_eglConfig, EGL_NO_CONTEXT, contextAttribList); EGLU_CHECK_MSG(egl, "Failed to create GLES2 context"); // Create surface m_nativeWindow = windowFactory.createWindow(&m_eglTestCtx.getNativeDisplay(), m_eglDisplay, m_eglConfig, DE_NULL, eglu::WindowParams(480, 480, eglu::parseWindowVisibility(m_testCtx.getCommandLine()))); m_eglSurface = eglu::createWindowSurface(m_eglTestCtx.getNativeDisplay(), *m_nativeWindow, m_eglDisplay, m_eglConfig, DE_NULL); EGLU_CHECK_CALL(egl, makeCurrent(m_eglDisplay, m_eglSurface, m_eglSurface, m_eglContext)); requiredGLESExtensions(m_gl); } // Verify EXTENSION_REUSABLE_SYNC is supported before running the tests if (m_syncType == EGL_SYNC_REUSABLE_KHR) { if (!eglu::hasExtension(m_eglTestCtx.getLibrary(), m_eglDisplay, "EGL_KHR_reusable_sync")) { TCU_THROW(NotSupportedError, "EGL_KHR_reusable_sync not supported"); } } } void SyncTest::deinit (void) { const Library& egl = m_eglTestCtx.getLibrary(); if (m_eglDisplay != EGL_NO_DISPLAY) { if (m_sync != EGL_NO_SYNC_KHR) { EGLU_CHECK_CALL(egl, destroySyncKHR(m_eglDisplay, m_sync)); m_sync = EGL_NO_SYNC_KHR; } EGLU_CHECK_CALL(egl, makeCurrent(m_eglDisplay, EGL_NO_SURFACE, EGL_NO_SURFACE, EGL_NO_CONTEXT)); if (m_eglContext != EGL_NO_CONTEXT) { EGLU_CHECK_CALL(egl, destroyContext(m_eglDisplay, m_eglContext)); m_eglContext = EGL_NO_CONTEXT; } if (m_eglSurface != EGL_NO_SURFACE) { EGLU_CHECK_CALL(egl, destroySurface(m_eglDisplay, m_eglSurface)); m_eglSurface = EGL_NO_SURFACE; } delete m_nativeWindow; m_nativeWindow = DE_NULL; egl.terminate(m_eglDisplay); m_eglDisplay = EGL_NO_DISPLAY; } } class CreateNullAttribsTest : public SyncTest { public: CreateNullAttribsTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_NONE, syncType != EGL_SYNC_REUSABLE_KHR, "create_null_attribs", "create_null_attribs") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], createSyncFuncType createSyncFunc) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); string msgChk = funcNames[FUNC_NAME_CREATE_SYNC] + "()"; m_sync = (egl.*createSyncFunc)(m_eglDisplay, m_syncType, NULL); log << TestLog::Message << m_sync << " = " << funcNames[FUNC_NAME_CREATE_SYNC] << "(" << m_eglDisplay << ", " << getSyncTypeName(m_syncType) << ", NULL)" << TestLog::EndMessage; EGLU_CHECK_MSG(egl, msgChk.c_str()); } IterateResult iterate(void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::createSync); } if (hasEGLFenceSyncExtension()) { test(m_funcNamesKHR, &Library::createSyncKHR); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class CreateEmptyAttribsTest : public SyncTest { public: CreateEmptyAttribsTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_NONE, syncType != EGL_SYNC_REUSABLE_KHR, "create_empty_attribs", "create_empty_attribs") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], createSyncFuncType createSyncFunc) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); string msgChk = funcNames[FUNC_NAME_CREATE_SYNC] + "()"; const attribType attribList[] = { EGL_NONE }; m_sync = (egl.*createSyncFunc)(m_eglDisplay, m_syncType, attribList); log << TestLog::Message << m_sync << " = " << funcNames[FUNC_NAME_CREATE_SYNC] << "(" << m_eglDisplay << ", " << getSyncTypeName(m_syncType) << ", { EGL_NONE })" << TestLog::EndMessage; EGLU_CHECK_MSG(egl, msgChk.c_str()); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::createSync); } if (hasEGLFenceSyncExtension()) { test(m_funcNamesKHR, &Library::createSyncKHR); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class CreateInvalidDisplayTest : public SyncTest { public: CreateInvalidDisplayTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_NONE, syncType != EGL_SYNC_REUSABLE_KHR, "create_invalid_display", "create_invalid_display") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], createSyncFuncType createSyncFunc, syncType eglNoSync) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); m_sync = (egl.*createSyncFunc)(EGL_NO_DISPLAY, m_syncType, NULL); log << TestLog::Message << m_sync << " = " << funcNames[FUNC_NAME_CREATE_SYNC] << "(EGL_NO_DISPLAY, " << getSyncTypeName(m_syncType) << ", NULL)" << TestLog::EndMessage; EGLint error = egl.getError(); log << TestLog::Message << error << " = eglGetError()" << TestLog::EndMessage; if (error != EGL_BAD_DISPLAY) { log << TestLog::Message << "Unexpected error '" << eglu::getErrorStr(error) << "' expected EGL_BAD_DISPLAY" << TestLog::EndMessage; m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail"); return; } TCU_CHECK(m_sync == eglNoSync); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::createSync, EGL_NO_SYNC); } if (hasEGLFenceSyncExtension()) { test(m_funcNamesKHR, &Library::createSyncKHR, EGL_NO_SYNC_KHR); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class CreateInvalidTypeTest : public SyncTest { public: CreateInvalidTypeTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_NONE, syncType != EGL_SYNC_REUSABLE_KHR, "create_invalid_type", "create_invalid_type") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], createSyncFuncType createSyncFunc, EGLSyncKHR eglNoSync, EGLint syncError, string syncErrorName) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); m_sync = (egl.*createSyncFunc)(m_eglDisplay, EGL_NONE, NULL); log << TestLog::Message << m_sync << " = " << funcNames[FUNC_NAME_CREATE_SYNC] << "(" << m_eglDisplay << ", EGL_NONE, NULL)" << TestLog::EndMessage; EGLint error = egl.getError(); log << TestLog::Message << error << " = eglGetError()" << TestLog::EndMessage; if (error != syncError) { log << TestLog::Message << "Unexpected error '" << eglu::getErrorStr(error) << "' expected " << syncErrorName << " " << TestLog::EndMessage; m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail"); return; } TCU_CHECK(m_sync == eglNoSync); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::createSync, EGL_NO_SYNC, EGL_BAD_PARAMETER, "EGL_BAD_PARAMETER"); } if (hasEGLFenceSyncExtension()) { test(m_funcNamesKHR, &Library::createSyncKHR, EGL_NO_SYNC_KHR, EGL_BAD_ATTRIBUTE, "EGL_BAD_ATTRIBUTE"); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class CreateInvalidAttribsTest : public SyncTest { public: CreateInvalidAttribsTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_NONE, syncType != EGL_SYNC_REUSABLE_KHR, "create_invalid_attribs", "create_invalid_attribs") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], createSyncFuncType createSyncFunc, EGLSyncKHR eglNoSync) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); attribType attribs[] = { 2, 3, 4, 5, EGL_NONE }; m_sync = (egl.*createSyncFunc)(m_eglDisplay, m_syncType, attribs); log << TestLog::Message << m_sync << " = " << funcNames[FUNC_NAME_CREATE_SYNC] << "(" << m_eglDisplay << ", " << getSyncTypeName(m_syncType) << ", { 2, 3, 4, 5, EGL_NONE })" << TestLog::EndMessage; EGLint error = egl.getError(); log << TestLog::Message << error << " = eglGetError()" << TestLog::EndMessage; if (error != EGL_BAD_ATTRIBUTE) { log << TestLog::Message << "Unexpected error '" << eglu::getErrorStr(error) << "' expected EGL_BAD_ATTRIBUTE" << TestLog::EndMessage; m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail"); return; } TCU_CHECK(m_sync == eglNoSync); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::createSync, EGL_NO_SYNC); } if (hasEGLFenceSyncExtension()) { test(m_funcNamesKHR, &Library::createSyncKHR, EGL_NO_SYNC_KHR); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class CreateInvalidContextTest : public SyncTest { public: CreateInvalidContextTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_NONE, syncType != EGL_SYNC_REUSABLE_KHR, "create_invalid_context", "create_invalid_context") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], createSyncFuncType createSyncFunc, EGLSyncKHR eglNoSync) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); log << TestLog::Message << "eglMakeCurrent(" << m_eglDisplay << ", EGL_NO_SURFACE, EGL_NO_SURFACE, EGL_NO_CONTEXT)" << TestLog::EndMessage; EGLU_CHECK_CALL(egl, makeCurrent(m_eglDisplay, EGL_NO_SURFACE, EGL_NO_SURFACE, EGL_NO_CONTEXT)); m_sync = (egl.*createSyncFunc)(m_eglDisplay, m_syncType, NULL); log << TestLog::Message << m_sync << " = " << funcNames[FUNC_NAME_CREATE_SYNC] << "(" << m_eglDisplay << ", " << getSyncTypeName(m_syncType) << ", NULL)" << TestLog::EndMessage; EGLint error = egl.getError(); log << TestLog::Message << error << " = eglGetError()" << TestLog::EndMessage; if (error != EGL_BAD_MATCH) { log << TestLog::Message << "Unexpected error '" << eglu::getErrorStr(error) << "' expected EGL_BAD_MATCH" << TestLog::EndMessage; m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail"); return; } TCU_CHECK(m_sync == eglNoSync); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::createSync, EGL_NO_SYNC); } if (hasEGLFenceSyncExtension()) { test(m_funcNamesKHR, &Library::createSyncKHR, EGL_NO_SYNC_KHR); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class ClientWaitNoTimeoutTest : public SyncTest { public: ClientWaitNoTimeoutTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_NONE, syncType != EGL_SYNC_REUSABLE_KHR, "wait_no_timeout", "wait_no_timeout") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], createSyncFuncType createSyncFunc, clientWaitSyncFuncType clientWaitSyncFunc) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); string msgChk = funcNames[FUNC_NAME_CREATE_SYNC] + "()"; m_sync = (egl.*createSyncFunc)(m_eglDisplay, m_syncType, NULL); log << TestLog::Message << m_sync << " = " << funcNames[FUNC_NAME_CREATE_SYNC] << "(" << m_eglDisplay << ", " << getSyncTypeName(m_syncType) << ", NULL)" << TestLog::EndMessage; EGLU_CHECK_MSG(egl, msgChk.c_str()); EGLint status = (egl.*clientWaitSyncFunc)(m_eglDisplay, m_sync, 0, 0); log << TestLog::Message << status << " = " << funcNames[FUNC_NAME_CLIENT_WAIT_SYNC] << "(" << m_eglDisplay << ", " << m_sync << ", 0, 0)" << TestLog::EndMessage; if (m_syncType == EGL_SYNC_FENCE_KHR) TCU_CHECK(status == EGL_CONDITION_SATISFIED_KHR || status == EGL_TIMEOUT_EXPIRED_KHR); else if (m_syncType == EGL_SYNC_REUSABLE_KHR) TCU_CHECK(status == EGL_TIMEOUT_EXPIRED_KHR); else DE_ASSERT(DE_FALSE); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::createSync, &Library::clientWaitSync); } if (hasEGLFenceSyncExtension()) { test(m_funcNamesKHR, &Library::createSyncKHR, &Library::clientWaitSyncKHR); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class ClientWaitForeverTest : public SyncTest { public: ClientWaitForeverTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_NONE, syncType != EGL_SYNC_REUSABLE_KHR, "wait_forever", "wait_forever") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], createSyncFuncType createSyncFunc, clientWaitSyncFuncType clientWaitSyncFunc, EGLTime eglTime, const string &eglTimeName, EGLint condSatisfied) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); string createSyncMsgChk = funcNames[FUNC_NAME_CREATE_SYNC] + "()"; string clientWaitSyncMsgChk = funcNames[FUNC_NAME_CLIENT_WAIT_SYNC] + "()"; m_sync = (egl.*createSyncFunc)(m_eglDisplay, m_syncType, NULL); log << TestLog::Message << m_sync << " = " << funcNames[FUNC_NAME_CREATE_SYNC] << "(" << m_eglDisplay << ", " << getSyncTypeName(m_syncType) << ", NULL)" << TestLog::EndMessage; EGLU_CHECK_MSG(egl, createSyncMsgChk.c_str()); if (m_syncType == EGL_SYNC_REUSABLE_KHR) { EGLBoolean ret = egl.signalSyncKHR(m_eglDisplay, m_sync, EGL_SIGNALED_KHR); log << TestLog::Message << ret << " = eglSignalSyncKHR(" << m_eglDisplay << ", " << m_sync << ", EGL_SIGNALED_KHR)" << TestLog::EndMessage; EGLU_CHECK_MSG(egl, "eglSignalSyncKHR()"); } else if (m_syncType == EGL_SYNC_FENCE_KHR) { GLU_CHECK_GLW_CALL(m_gl, flush()); log << TestLog::Message << "glFlush()" << TestLog::EndMessage; } else DE_ASSERT(DE_FALSE); EGLint status = (egl.*clientWaitSyncFunc)(m_eglDisplay, m_sync, 0, eglTime); log << TestLog::Message << status << " = " << funcNames[FUNC_NAME_CLIENT_WAIT_SYNC] << "(" << m_eglDisplay << ", " << m_sync << ", 0, " << eglTimeName << ")" << TestLog::EndMessage; TCU_CHECK(status == condSatisfied); EGLU_CHECK_MSG(egl, clientWaitSyncMsgChk.c_str()); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::createSync, &Library::clientWaitSync, EGL_FOREVER, "EGL_FOREVER", EGL_CONDITION_SATISFIED); } if (hasEGLFenceSyncExtension()) { test(m_funcNamesKHR, &Library::createSyncKHR, &Library::clientWaitSyncKHR, EGL_FOREVER_KHR, "EGL_FOREVER_KHR", EGL_CONDITION_SATISFIED_KHR); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class ClientWaitNoContextTest : public SyncTest { public: ClientWaitNoContextTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_NONE, syncType != EGL_SYNC_REUSABLE_KHR, "wait_no_context", "wait_no_Context") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], createSyncFuncType createSyncFunc, clientWaitSyncFuncType clientWaitSyncFunc, EGLint condSatisfied, EGLTime eglTime, const string &eglTimeName) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); string createSyncMsgChk = funcNames[FUNC_NAME_CREATE_SYNC] + "()"; m_sync = (egl.*createSyncFunc)(m_eglDisplay, m_syncType, NULL); log << TestLog::Message << m_sync << " = " << funcNames[FUNC_NAME_CREATE_SYNC] << "(" << m_eglDisplay << ", " << getSyncTypeName(m_syncType) << ", NULL)" << TestLog::EndMessage; EGLU_CHECK_MSG(egl, createSyncMsgChk.c_str()); if (m_syncType == EGL_SYNC_REUSABLE_KHR) { EGLBoolean ret = egl.signalSyncKHR(m_eglDisplay, m_sync, EGL_SIGNALED_KHR); log << TestLog::Message << ret << " = eglSignalSyncKHR(" << m_eglDisplay << ", " << m_sync << ", EGL_SIGNALED_KHR)" << TestLog::EndMessage; EGLU_CHECK_MSG(egl, "eglSignalSyncKHR()"); } else if (m_syncType == EGL_SYNC_FENCE_KHR) { GLU_CHECK_GLW_CALL(m_gl, flush()); log << TestLog::Message << "glFlush()" << TestLog::EndMessage; } else DE_ASSERT(DE_FALSE); log << TestLog::Message << "eglMakeCurrent(" << m_eglDisplay << ", EGL_NO_SURFACE, EGL_NO_SURFACE, EGL_NO_CONTEXT)" << TestLog::EndMessage; EGLU_CHECK_CALL(egl, makeCurrent(m_eglDisplay, EGL_NO_SURFACE, EGL_NO_SURFACE, EGL_NO_CONTEXT)); EGLint result = (egl.*clientWaitSyncFunc)(m_eglDisplay, m_sync, 0, eglTime); log << TestLog::Message << result << " = " << funcNames[FUNC_NAME_CLIENT_WAIT_SYNC] << "(" << m_eglDisplay << ", " << m_sync << ", 0, " << eglTimeName << ")" << TestLog::EndMessage; TCU_CHECK(result == condSatisfied); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::createSync, &Library::clientWaitSync, EGL_CONDITION_SATISFIED, EGL_FOREVER, "EGL_FOREVER"); } if (hasEGLFenceSyncExtension()) { test(m_funcNamesKHR, &Library::createSyncKHR, &Library::clientWaitSyncKHR, EGL_CONDITION_SATISFIED_KHR, EGL_FOREVER_KHR, "EGL_FOREVER_KHR"); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class ClientWaitForeverFlushTest : public SyncTest { public: ClientWaitForeverFlushTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_NONE, syncType != EGL_SYNC_REUSABLE_KHR, "wait_forever_flush", "wait_forever_flush") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], createSyncFuncType createSyncFunc, clientWaitSyncFuncType clientWaitSyncFunc, EGLint flags, const string &flagsName, EGLTime eglTime, const string &eglTimeName, EGLint condSatisfied) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); string createSyncMsgChk = funcNames[FUNC_NAME_CREATE_SYNC] + "()"; m_sync = (egl.*createSyncFunc)(m_eglDisplay, m_syncType, NULL); log << TestLog::Message << m_sync << " = " << funcNames[FUNC_NAME_CREATE_SYNC] << "(" << m_eglDisplay << ", " << getSyncTypeName(m_syncType) << ", NULL)" << TestLog::EndMessage; EGLU_CHECK_MSG(egl, createSyncMsgChk.c_str()); if (m_syncType == EGL_SYNC_REUSABLE_KHR) { EGLBoolean ret = egl.signalSyncKHR(m_eglDisplay, m_sync, EGL_SIGNALED_KHR); log << TestLog::Message << ret << " = eglSignalSyncKHR(" << m_eglDisplay << ", " << m_sync << ", EGL_SIGNALED_KHR)" << TestLog::EndMessage; EGLU_CHECK_MSG(egl, "eglSignalSyncKHR()"); } EGLint status = (egl.*clientWaitSyncFunc)(m_eglDisplay, m_sync, flags, eglTime); log << TestLog::Message << status << " = " << funcNames[FUNC_NAME_CLIENT_WAIT_SYNC] << "(" << m_eglDisplay << ", " << m_sync << ", " << flagsName << ", " << eglTimeName << ")" << TestLog::EndMessage; TCU_CHECK(status == condSatisfied); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::createSync, &Library::clientWaitSync, EGL_SYNC_FLUSH_COMMANDS_BIT, "EGL_SYNC_FLUSH_COMMANDS_BIT", EGL_FOREVER, "EGL_FOREVER", EGL_CONDITION_SATISFIED); } if (hasEGLFenceSyncExtension()) { test(m_funcNamesKHR, &Library::createSyncKHR, &Library::clientWaitSyncKHR, EGL_SYNC_FLUSH_COMMANDS_BIT_KHR, "EGL_SYNC_FLUSH_COMMANDS_BIT_KHR", EGL_FOREVER_KHR, "EGL_FOREVER_KHR", EGL_CONDITION_SATISFIED_KHR); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class ClientWaitInvalidDisplayTest : public SyncTest { public: ClientWaitInvalidDisplayTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_NONE, syncType != EGL_SYNC_REUSABLE_KHR, "wait_invalid_display", "wait_invalid_display") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], createSyncFuncType createSyncFunc, clientWaitSyncFuncType clientWaitSyncFunc, EGLint flags, const string &flagsName, EGLTime eglTime, const string &eglTimeName) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); string createSyncMsgChk = funcNames[FUNC_NAME_CREATE_SYNC] + "()"; m_sync = (egl.*createSyncFunc)(m_eglDisplay, m_syncType, NULL); log << TestLog::Message << m_sync << " = " << funcNames[FUNC_NAME_CREATE_SYNC] << "(" << m_eglDisplay << ", " << getSyncTypeName(m_syncType) << ", NULL)" << TestLog::EndMessage; EGLU_CHECK_MSG(egl, createSyncMsgChk.c_str()); EGLint status = (egl.*clientWaitSyncFunc)(EGL_NO_DISPLAY, m_sync, flags, eglTime); log << TestLog::Message << status << " = " << funcNames[FUNC_NAME_CLIENT_WAIT_SYNC] << "(EGL_NO_DISPLAY, " << m_sync << ", " << flagsName << ", " << eglTimeName << ")" << TestLog::EndMessage; EGLint error = egl.getError(); log << TestLog::Message << error << " = eglGetError()" << TestLog::EndMessage; if (error != EGL_BAD_DISPLAY) { log << TestLog::Message << "Unexpected error '" << eglu::getErrorStr(error) << "' expected EGL_BAD_DISPLAY" << TestLog::EndMessage; m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail"); return; } TCU_CHECK(status == EGL_FALSE); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::createSync, &Library::clientWaitSync, EGL_SYNC_FLUSH_COMMANDS_BIT, "EGL_SYNC_FLUSH_COMMANDS_BIT", EGL_FOREVER, "EGL_FOREVER"); } if (hasEGLFenceSyncExtension()) { test(m_funcNamesKHR, &Library::createSyncKHR, &Library::clientWaitSyncKHR, EGL_SYNC_FLUSH_COMMANDS_BIT_KHR, "EGL_SYNC_FLUSH_COMMANDS_BIT_KHR", EGL_FOREVER_KHR, "EGL_FOREVER_KHR"); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class ClientWaitInvalidSyncTest : public SyncTest { public: ClientWaitInvalidSyncTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_NONE, syncType != EGL_SYNC_REUSABLE_KHR, "wait_invalid_sync", "wait_invalid_sync") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], clientWaitSyncFuncType clientWaitSyncFunc, EGLSync sync, const string &syncName, EGLTime eglTime, const string &eglTimeName) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); EGLint status = (egl.*clientWaitSyncFunc)(m_eglDisplay, sync, 0, eglTime); log << TestLog::Message << status << " = " << funcNames[FUNC_NAME_CLIENT_WAIT_SYNC] << "(" << m_eglDisplay << ", " << syncName << ", 0, " << eglTimeName << ")" << TestLog::EndMessage; EGLint error = egl.getError(); log << TestLog::Message << error << " = eglGetError()" << TestLog::EndMessage; if (error != EGL_BAD_PARAMETER) { log << TestLog::Message << "Unexpected error '" << eglu::getErrorStr(error) << "' expected EGL_BAD_PARAMETER" << TestLog::EndMessage; m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail"); return; } TCU_CHECK(status == EGL_FALSE); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::clientWaitSync, EGL_NO_SYNC, "EGL_NO_SYNC", EGL_FOREVER, "EGL_FOREVER"); } if (hasEGLFenceSyncExtension()) { test(m_funcNamesKHR, &Library::clientWaitSyncKHR, EGL_NO_SYNC_KHR, "EGL_NO_SYNC_KHR", EGL_FOREVER_KHR, "EGL_FOREVER_KHR"); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class GetSyncTypeTest : public SyncTest { public: GetSyncTypeTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_NONE, syncType != EGL_SYNC_REUSABLE_KHR, "get_type", "get_type") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], createSyncFuncType createSyncFunc, getSyncAttribFuncType getSyncAttribFunc, EGLint attribute, const string &attributeName) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); string createSyncMsgChk = funcNames[FUNC_NAME_CREATE_SYNC] + "()"; m_sync = (egl.*createSyncFunc)(m_eglDisplay, m_syncType, NULL); log << TestLog::Message << m_sync << " = " << funcNames[FUNC_NAME_CREATE_SYNC] << "(" << m_eglDisplay << ", " << getSyncTypeName(m_syncType) << ", NULL)" << TestLog::EndMessage; EGLU_CHECK_MSG(egl, createSyncMsgChk.c_str()); getSyncAttribValueType type = 0; EGLU_CHECK_CALL_FPTR(egl, (egl.*getSyncAttribFunc)(m_eglDisplay, m_sync, attribute, &type)); log << TestLog::Message << funcNames[FUNC_NAME_GET_SYNC_ATTRIB] << "(" << m_eglDisplay << ", " << m_sync << ", " << attributeName << ", {" << type << "})" << TestLog::EndMessage; TCU_CHECK(type == ((getSyncAttribValueType)m_syncType)); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::createSync, &Library::getSyncAttrib, EGL_SYNC_TYPE, "EGL_SYNC_TYPE"); } if (hasEGLFenceSyncExtension()) { test(m_funcNamesKHR, &Library::createSyncKHR, &Library::getSyncAttribKHR, EGL_SYNC_TYPE_KHR, "EGL_SYNC_TYPE_KHR"); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class GetSyncStatusTest : public SyncTest { public: GetSyncStatusTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_NONE, syncType != EGL_SYNC_REUSABLE_KHR, "get_status", "get_status") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], createSyncFuncType createSyncFunc, getSyncAttribFuncType getSyncAttribFunc, EGLint attribute, const string &attributeName) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); string createSyncMsgChk = funcNames[FUNC_NAME_CREATE_SYNC] + "()"; m_sync = (egl.*createSyncFunc)(m_eglDisplay, m_syncType, NULL); log << TestLog::Message << m_sync << " = " << funcNames[FUNC_NAME_CREATE_SYNC] << "(" << m_eglDisplay << ", " << getSyncTypeName(m_syncType) << ", NULL)" << TestLog::EndMessage; EGLU_CHECK_MSG(egl, createSyncMsgChk.c_str()); getSyncAttribValueType status = 0; EGLU_CHECK_CALL_FPTR(egl, (egl.*getSyncAttribFunc)(m_eglDisplay, m_sync, attribute, &status)); log << TestLog::Message << funcNames[FUNC_NAME_GET_SYNC_ATTRIB] << "(" << m_eglDisplay << ", " << m_sync << ", " << attributeName << ", {" << status << "})" << TestLog::EndMessage; if (m_syncType == EGL_SYNC_FENCE_KHR) TCU_CHECK(status == EGL_SIGNALED_KHR || status == EGL_UNSIGNALED_KHR); else if (m_syncType == EGL_SYNC_REUSABLE_KHR) TCU_CHECK(status == EGL_UNSIGNALED_KHR); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::createSync, &Library::getSyncAttrib, EGL_SYNC_STATUS, "EGL_SYNC_STATUS"); } if (hasEGLFenceSyncExtension()) { test(m_funcNamesKHR, &Library::createSyncKHR, &Library::getSyncAttribKHR, EGL_SYNC_STATUS_KHR, "EGL_SYNC_STATUS_KHR"); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class GetSyncStatusSignaledTest : public SyncTest { public: GetSyncStatusSignaledTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_NONE, syncType != EGL_SYNC_REUSABLE_KHR, "get_status_signaled", "get_status_signaled") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], createSyncFuncType createSyncFunc, clientWaitSyncFuncType clientWaitSyncFunc, EGLint flags, const string &flagsName, EGLTime eglTime, const string &eglTimeName, EGLint condSatisfied, getSyncAttribFuncType getSyncAttribFunc, EGLint attribute, const string &attributeName, getSyncAttribValueType statusVal) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); string createSyncMsgChk = funcNames[FUNC_NAME_CREATE_SYNC] + "()"; m_sync = (egl.*createSyncFunc)(m_eglDisplay, m_syncType, NULL); log << TestLog::Message << m_sync << " = " << funcNames[FUNC_NAME_CREATE_SYNC] << "(" << m_eglDisplay << ", " << getSyncTypeName(m_syncType) << ", NULL)" << TestLog::EndMessage; EGLU_CHECK_MSG(egl, createSyncMsgChk.c_str()); if (m_syncType == EGL_SYNC_REUSABLE_KHR) { EGLBoolean ret = egl.signalSyncKHR(m_eglDisplay, m_sync, EGL_SIGNALED_KHR); log << TestLog::Message << ret << " = eglSignalSyncKHR(" << m_eglDisplay << ", " << m_sync << ", EGL_SIGNALED_KHR)" << TestLog::EndMessage; EGLU_CHECK_MSG(egl, "eglSignalSyncKHR()"); } else if (m_syncType == EGL_SYNC_FENCE_KHR) { GLU_CHECK_GLW_CALL(m_gl, finish()); log << TestLog::Message << "glFinish()" << TestLog::EndMessage; } else DE_ASSERT(DE_FALSE); { EGLint status = (egl.*clientWaitSyncFunc)(m_eglDisplay, m_sync, flags, eglTime); log << TestLog::Message << status << " = " << funcNames[FUNC_NAME_CLIENT_WAIT_SYNC] << "(" << m_eglDisplay << ", " << m_sync << ", " << flagsName << ", " << eglTimeName << ")" << TestLog::EndMessage; TCU_CHECK(status == condSatisfied); } getSyncAttribValueType status = 0; EGLU_CHECK_CALL_FPTR(egl, (egl.*getSyncAttribFunc)(m_eglDisplay, m_sync, attribute, &status)); log << TestLog::Message << funcNames[FUNC_NAME_GET_SYNC_ATTRIB] << "(" << m_eglDisplay << ", " << m_sync << ", " << attributeName << ", {" << status << "})" << TestLog::EndMessage; TCU_CHECK(status == statusVal); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::createSync, &Library::clientWaitSync, EGL_SYNC_FLUSH_COMMANDS_BIT, "EGL_SYNC_FLUSH_COMMANDS_BIT", EGL_FOREVER, "EGL_FOREVER", EGL_CONDITION_SATISFIED, &Library::getSyncAttrib, EGL_SYNC_STATUS, "EGL_SYNC_STATUS", EGL_SIGNALED); } if (hasEGLFenceSyncExtension()) { test(m_funcNamesKHR, &Library::createSyncKHR, &Library::clientWaitSyncKHR, EGL_SYNC_FLUSH_COMMANDS_BIT_KHR, "EGL_SYNC_FLUSH_COMMANDS_BIT_KHR", EGL_FOREVER_KHR, "EGL_FOREVER_KHR", EGL_CONDITION_SATISFIED_KHR, &Library::getSyncAttribKHR, EGL_SYNC_STATUS_KHR, "EGL_SYNC_STATUS_KHR", EGL_SIGNALED_KHR); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class GetSyncConditionTest : public SyncTest { public: GetSyncConditionTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_NONE, syncType != EGL_SYNC_REUSABLE_KHR, "get_condition", "get_condition") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], createSyncFuncType createSyncFunc, getSyncAttribFuncType getSyncAttribFunc, EGLint attribute, const string &attributeName, getSyncAttribValueType statusVal) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); string createSyncMsgChk = funcNames[FUNC_NAME_CREATE_SYNC] + "()"; m_sync = (egl.*createSyncFunc)(m_eglDisplay, m_syncType, NULL); log << TestLog::Message << m_sync << " = " << funcNames[FUNC_NAME_CREATE_SYNC] << "(" << m_eglDisplay << ", " << getSyncTypeName(m_syncType) << ", NULL)" << TestLog::EndMessage; EGLU_CHECK_MSG(egl, createSyncMsgChk.c_str()); getSyncAttribValueType condition = 0; EGLU_CHECK_CALL_FPTR(egl, (egl.*getSyncAttribFunc)(m_eglDisplay, m_sync, attribute, &condition)); log << TestLog::Message << funcNames[FUNC_NAME_GET_SYNC_ATTRIB] << "(" << m_eglDisplay << ", " << m_sync << ", " << attributeName << ", {" << condition << "})" << TestLog::EndMessage; TCU_CHECK(condition == statusVal); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::createSync, &Library::getSyncAttrib, EGL_SYNC_CONDITION, "EGL_SYNC_CONDITION", EGL_SYNC_PRIOR_COMMANDS_COMPLETE); } if (hasEGLFenceSyncExtension()) { test(m_funcNamesKHR, &Library::createSyncKHR, &Library::getSyncAttribKHR, EGL_SYNC_CONDITION_KHR, "EGL_SYNC_CONDITION_KHR", EGL_SYNC_PRIOR_COMMANDS_COMPLETE_KHR); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class GetSyncInvalidDisplayTest : public SyncTest { public: GetSyncInvalidDisplayTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_NONE, syncType != EGL_SYNC_REUSABLE_KHR,"get_invalid_display", "get_invalid_display") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], createSyncFuncType createSyncFunc, getSyncAttribFuncType getSyncAttribFunc, EGLint attribute, const string &attributeName) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); string createSyncMsgChk = funcNames[FUNC_NAME_CREATE_SYNC] + "()"; m_sync = (egl.*createSyncFunc)(m_eglDisplay, m_syncType, NULL); log << TestLog::Message << m_sync << " = " << funcNames[FUNC_NAME_CREATE_SYNC] << "(" << m_eglDisplay << ", " << getSyncTypeName(m_syncType) << ", NULL)" << TestLog::EndMessage; EGLU_CHECK_MSG(egl, createSyncMsgChk.c_str()); getSyncAttribValueType condition = 0xF0F0F; EGLBoolean result = (egl.*getSyncAttribFunc)(EGL_NO_DISPLAY, m_sync, attribute, &condition); log << TestLog::Message << result << " = " << funcNames[FUNC_NAME_GET_SYNC_ATTRIB] << "(EGL_NO_DISPLAY, " << m_sync << ", " << attributeName << ", {" << condition << "})" << TestLog::EndMessage; EGLint error = egl.getError(); log << TestLog::Message << error << " = eglGetError()" << TestLog::EndMessage; if (error != EGL_BAD_DISPLAY) { log << TestLog::Message << "Unexpected error '" << eglu::getErrorStr(error) << "' expected EGL_BAD_DISPLAY" << TestLog::EndMessage; m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail"); return; } TCU_CHECK(result == EGL_FALSE); TCU_CHECK(condition == 0xF0F0F); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::createSync, &Library::getSyncAttrib, EGL_SYNC_CONDITION, "EGL_SYNC_CONDITION"); } if (hasEGLFenceSyncExtension()) { test(m_funcNamesKHR, &Library::createSyncKHR, &Library::getSyncAttribKHR, EGL_SYNC_CONDITION_KHR, "EGL_SYNC_CONDITION_KHR"); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class GetSyncInvalidSyncTest : public SyncTest { public: GetSyncInvalidSyncTest (EglTestContext& eglTestCtx, EGLenum syncType)\ : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_NONE, syncType != EGL_SYNC_REUSABLE_KHR, "get_invalid_sync", "get_invalid_sync") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], getSyncAttribFuncType getSyncAttribFunc, getSyncSyncValueType syncValue, const string &syncName, EGLint attribute, const string &attributeName) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); getSyncAttribValueType condition = 0xF0F0F; EGLBoolean result = (egl.*getSyncAttribFunc)(m_eglDisplay, syncValue, attribute, &condition); log << TestLog::Message << result << " = " << funcNames[FUNC_NAME_GET_SYNC_ATTRIB] << "(" << m_eglDisplay << ", " << syncName << ", " << attributeName << ", {" << condition << "})" << TestLog::EndMessage; EGLint error = egl.getError(); log << TestLog::Message << error << " = eglGetError()" << TestLog::EndMessage; if (error != EGL_BAD_PARAMETER) { log << TestLog::Message << "Unexpected error '" << eglu::getErrorStr(error) << "' expected EGL_BAD_PARAMETER" << TestLog::EndMessage; m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail"); return; } TCU_CHECK(result == EGL_FALSE); TCU_CHECK(condition == 0xF0F0F); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::getSyncAttrib, EGL_NO_SYNC, "EGL_NO_SYNC", EGL_SYNC_CONDITION, "EGL_SYNC_CONDITION"); } if (hasEGLFenceSyncExtension()) { test(m_funcNamesKHR, &Library::getSyncAttribKHR, EGL_NO_SYNC_KHR, "EGL_NO_SYNC_KHR", EGL_SYNC_CONDITION_KHR, "EGL_SYNC_CONDITION_KHR"); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class GetSyncInvalidAttributeTest : public SyncTest { public: GetSyncInvalidAttributeTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_NONE, syncType != EGL_SYNC_REUSABLE_KHR,"get_invalid_attribute", "get_invalid_attribute") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], createSyncFuncType createSyncFunc, getSyncAttribFuncType getSyncAttribFunc) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); string createSyncMsgChk = funcNames[FUNC_NAME_CREATE_SYNC] + "()"; m_sync = (egl.*createSyncFunc)(m_eglDisplay, m_syncType, NULL); log << TestLog::Message << m_sync << " = " << funcNames[FUNC_NAME_CREATE_SYNC] << "(" << m_eglDisplay << ", " << getSyncTypeName(m_syncType) << ", NULL)" << TestLog::EndMessage; EGLU_CHECK_MSG(egl, createSyncMsgChk.c_str()); getSyncAttribValueType condition = 0xF0F0F; EGLBoolean result = (egl.*getSyncAttribFunc)(m_eglDisplay, m_sync, EGL_NONE, &condition); log << TestLog::Message << result << " = " << funcNames[FUNC_NAME_GET_SYNC_ATTRIB] << "(" << m_eglDisplay << ", " << m_sync << ", EGL_NONE, {" << condition << "})" << TestLog::EndMessage; EGLint error = egl.getError(); log << TestLog::Message << error << " = eglGetError()" << TestLog::EndMessage; if (error != EGL_BAD_ATTRIBUTE) { log << TestLog::Message << "Unexpected error '" << eglu::getErrorStr(error) << "' expected EGL_BAD_ATTRIBUTE" << TestLog::EndMessage; m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail"); return; } TCU_CHECK(result == EGL_FALSE); TCU_CHECK(condition == 0xF0F0F); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::createSync, &Library::getSyncAttrib); } if (hasEGLFenceSyncExtension()) { test(m_funcNamesKHR, &Library::createSyncKHR, &Library::getSyncAttribKHR); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class GetSyncInvalidValueTest : public SyncTest { public: GetSyncInvalidValueTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_NONE, syncType != EGL_SYNC_REUSABLE_KHR,"get_invalid_value", "get_invalid_value") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], createSyncFuncType createSyncFunc, getSyncAttribFuncType getSyncAttribFunc, EGLint attribute, const string &attributeName, valueType value) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); string createSyncMsgChk = funcNames[FUNC_NAME_CREATE_SYNC] + "()"; m_sync = (egl.*createSyncFunc)(m_eglDisplay, m_syncType, NULL); log << TestLog::Message << m_sync << " = " << funcNames[FUNC_NAME_CREATE_SYNC] << "(" << m_eglDisplay << ", " << getSyncTypeName(m_syncType) << ", NULL)" << TestLog::EndMessage; EGLU_CHECK_MSG(egl, createSyncMsgChk.c_str()); EGLBoolean result = (egl.*getSyncAttribFunc)(m_eglDisplay, NULL, attribute, &value); log << TestLog::Message << result << " = " << funcNames[FUNC_NAME_GET_SYNC_ATTRIB] << "(" << m_eglDisplay << ", " << 0x0 << ", " << attributeName << ", " << &value << ")" << TestLog::EndMessage; EGLint error = egl.getError(); log << TestLog::Message << error << " = eglGetError()" << TestLog::EndMessage; if (error != EGL_BAD_PARAMETER) { log << TestLog::Message << "Unexpected error '" << eglu::getErrorStr(error) << "' expected EGL_BAD_PARAMETER" << TestLog::EndMessage; m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail"); return; } TCU_CHECK(result == EGL_FALSE); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { EGLAttrib value = 0; test(m_funcNames, &Library::createSync, &Library::getSyncAttrib, EGL_SYNC_TYPE, "EGL_SYNC_TYPE", value); } if (hasEGLFenceSyncExtension()) { EGLint value = 0; test(m_funcNamesKHR, &Library::createSyncKHR, &Library::getSyncAttribKHR, EGL_SYNC_TYPE_KHR, "EGL_SYNC_TYPE_KHR", value); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class DestroySyncTest : public SyncTest { public: DestroySyncTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_NONE, syncType != EGL_SYNC_REUSABLE_KHR,"destroy", "destroy") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], createSyncFuncType createSyncFunc, destroySyncFuncType destroySyncFunc, getSyncSyncValueType syncValue) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); string createSyncMsgChk = funcNames[FUNC_NAME_CREATE_SYNC] + "()"; m_sync = (egl.*createSyncFunc)(m_eglDisplay, m_syncType, NULL); log << TestLog::Message << funcNames[FUNC_NAME_CREATE_SYNC] << "(" << m_eglDisplay << ", " << getSyncTypeName(m_syncType) << ", NULL)" << TestLog::EndMessage; EGLU_CHECK_MSG(egl, createSyncMsgChk.c_str()); log << TestLog::Message << funcNames[FUNC_NAME_DESTROY_SYNC] << "(" << m_eglDisplay << ", " << m_sync << ")" << TestLog::EndMessage; EGLU_CHECK_CALL_FPTR(egl, (egl.*destroySyncFunc)(m_eglDisplay, m_sync)); m_sync = syncValue; } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::createSync, &Library::destroySync, EGL_NO_SYNC); } if (hasEGLFenceSyncExtension()) { test(m_funcNamesKHR, &Library::createSyncKHR, &Library::destroySyncKHR, EGL_NO_SYNC_KHR); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class DestroySyncInvalidDislayTest : public SyncTest { public: DestroySyncInvalidDislayTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest(eglTestCtx, syncType, SyncTest::EXTENSION_NONE, syncType != EGL_SYNC_REUSABLE_KHR,"destroy_invalid_display", "destroy_invalid_display") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], createSyncFuncType createSyncFunc, destroySyncFuncType destroySyncFunc) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); string createSyncMsgChk = funcNames[FUNC_NAME_CREATE_SYNC] + "()"; m_sync = (egl.*createSyncFunc)(m_eglDisplay, m_syncType, NULL); log << TestLog::Message << funcNames[FUNC_NAME_CREATE_SYNC] << "(" << m_eglDisplay << ", " << getSyncTypeName(m_syncType) << ", NULL)" << TestLog::EndMessage; EGLU_CHECK_MSG(egl, createSyncMsgChk.c_str()); EGLBoolean result = (egl.*destroySyncFunc)(EGL_NO_DISPLAY, m_sync); log << TestLog::Message << result << " = " << funcNames[FUNC_NAME_DESTROY_SYNC] << "(EGL_NO_DISPLAY, " << m_sync << ")" << TestLog::EndMessage; EGLint error = egl.getError(); log << TestLog::Message << error << " = eglGetError()" << TestLog::EndMessage; if (error != EGL_BAD_DISPLAY) { log << TestLog::Message << "Unexpected error '" << eglu::getErrorStr(error) << "' expected EGL_BAD_DISPLAY" << TestLog::EndMessage; m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail"); return; } TCU_CHECK(result == EGL_FALSE); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::createSync, &Library::destroySync); } if (hasEGLFenceSyncExtension()) { test(m_funcNamesKHR, &Library::createSyncKHR, &Library::destroySyncKHR); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class DestroySyncInvalidSyncTest : public SyncTest { public: DestroySyncInvalidSyncTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_NONE, syncType != EGL_SYNC_REUSABLE_KHR,"destroy_invalid_sync", "destroy_invalid_sync") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], destroySyncFuncType destroySyncFunc, getSyncSyncValueType syncValue) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); EGLBoolean result = (egl.*destroySyncFunc)(m_eglDisplay, syncValue); log << TestLog::Message << result << " = " << funcNames[FUNC_NAME_DESTROY_SYNC] << "(" << m_eglDisplay << ", " << syncValue << ")" << TestLog::EndMessage; EGLint error = egl.getError(); log << TestLog::Message << error << " = eglGetError()" << TestLog::EndMessage; if (error != EGL_BAD_PARAMETER) { log << TestLog::Message << "Unexpected error '" << eglu::getErrorStr(error) << "' expected EGL_BAD_PARAMETER" << TestLog::EndMessage; m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail"); return; } TCU_CHECK(result == EGL_FALSE); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::destroySync, EGL_NO_SYNC); } if (hasEGLFenceSyncExtension()) { test(m_funcNamesKHR, &Library::destroySyncKHR, EGL_NO_SYNC_KHR); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class WaitSyncTest : public SyncTest { public: WaitSyncTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_WAIT_SYNC, true, "wait_server", "wait_server") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], createSyncFuncType createSyncFunc, waitSyncFuncType waitSyncFunc) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); string msgChk = funcNames[FUNC_NAME_CREATE_SYNC] + "()"; m_sync = (egl.*createSyncFunc)(m_eglDisplay, m_syncType, NULL); log << TestLog::Message << m_sync << " = " << funcNames[FUNC_NAME_CREATE_SYNC] << "(" << m_eglDisplay << ", " << getSyncTypeName(m_syncType) << ", NULL)" << TestLog::EndMessage; EGLU_CHECK_MSG(egl, msgChk.c_str()); waitSyncStatusType status = (egl.*waitSyncFunc)(m_eglDisplay, m_sync, 0); log << TestLog::Message << status << " = " << funcNames[FUNC_NAME_WAIT_SYNC] << "(" << m_eglDisplay << ", " << m_sync << ", 0, 0)" << TestLog::EndMessage; TCU_CHECK(status == EGL_TRUE); GLU_CHECK_GLW_CALL(m_gl, finish()); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::createSync, &Library::waitSync); } if (hasEGLWaitSyncExtension()) { test(m_funcNamesKHR, &Library::createSyncKHR, &Library::waitSyncKHR); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class WaitSyncInvalidDisplayTest : public SyncTest { public: WaitSyncInvalidDisplayTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_WAIT_SYNC, true, "wait_server_invalid_display", "wait_server_invalid_display") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], createSyncFuncType createSyncFunc, waitSyncFuncType waitSyncFunc) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); string msgChk = funcNames[FUNC_NAME_CREATE_SYNC] + "()"; m_sync = (egl.*createSyncFunc)(m_eglDisplay, m_syncType, NULL); log << TestLog::Message << m_sync << " = " << funcNames[FUNC_NAME_CREATE_SYNC] << "(" << m_eglDisplay << ", " << getSyncTypeName(m_syncType) << ", NULL)" << TestLog::EndMessage; EGLU_CHECK_MSG(egl, msgChk.c_str()); waitSyncStatusType status = (egl.*waitSyncFunc)(EGL_NO_DISPLAY, m_sync, 0); log << TestLog::Message << status << " = " << funcNames[FUNC_NAME_WAIT_SYNC] << "(EGL_NO_DISPLAY, " << m_sync << ", 0)" << TestLog::EndMessage; EGLint error = egl.getError(); log << TestLog::Message << error << " = eglGetError()" << TestLog::EndMessage; if (error != EGL_BAD_DISPLAY) { log << TestLog::Message << "Unexpected error '" << eglu::getErrorStr(error) << "' expected EGL_BAD_DISPLAY" << TestLog::EndMessage; m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail"); return; } TCU_CHECK(status == EGL_FALSE); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::createSync, &Library::waitSync); } if (hasEGLWaitSyncExtension()) { test(m_funcNamesKHR, &Library::createSyncKHR, &Library::waitSyncKHR); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class WaitSyncInvalidSyncTest : public SyncTest { public: WaitSyncInvalidSyncTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_WAIT_SYNC, true, "wait_server_invalid_sync", "wait_server_invalid_sync") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], waitSyncFuncType waitSyncFunc, waitSyncSyncType syncValue) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); EGLint status = (egl.*waitSyncFunc)(m_eglDisplay, syncValue, 0); log << TestLog::Message << status << " = " << funcNames[FUNC_NAME_WAIT_SYNC] << "(" << m_eglDisplay << ", " << syncValue << ", 0)" << TestLog::EndMessage; EGLint error = egl.getError(); log << TestLog::Message << error << " = eglGetError()" << TestLog::EndMessage; if (error != EGL_BAD_PARAMETER) { log << TestLog::Message << "Unexpected error '" << eglu::getErrorStr(error) << "' expected EGL_BAD_PARAMETER" << TestLog::EndMessage; m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail"); return; } TCU_CHECK(status == EGL_FALSE); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::waitSync, EGL_NO_SYNC); } if (hasEGLWaitSyncExtension()) { test(m_funcNamesKHR, &Library::waitSyncKHR, EGL_NO_SYNC_KHR); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; class WaitSyncInvalidFlagTest : public SyncTest { public: WaitSyncInvalidFlagTest (EglTestContext& eglTestCtx, EGLenum syncType) : SyncTest (eglTestCtx, syncType, SyncTest::EXTENSION_WAIT_SYNC, true, "wait_server_invalid_flag", "wait_server_invalid_flag") { } template void test(string funcNames[FUNC_NAME_NUM_NAMES], createSyncFuncType createSyncFunc, waitSyncFuncType waitSyncFunc) { // Reset before each test deinit(); init(); const Library& egl = m_eglTestCtx.getLibrary(); TestLog& log = m_testCtx.getLog(); string createSyncMsgChk = funcNames[FUNC_NAME_CREATE_SYNC] + "()"; m_sync = (egl.*createSyncFunc)(m_eglDisplay, m_syncType, NULL); log << TestLog::Message << m_sync << " = " << funcNames[FUNC_NAME_CREATE_SYNC] << "(" << m_eglDisplay << ", " << getSyncTypeName(m_syncType) << ", NULL)" << TestLog::EndMessage; EGLU_CHECK_MSG(egl, createSyncMsgChk.c_str()); EGLint status = (egl.*waitSyncFunc)(m_eglDisplay, m_sync, 0xFFFFFFFF); log << TestLog::Message << status << " = " << funcNames[FUNC_NAME_WAIT_SYNC] << "(" << m_eglDisplay << ", " << m_sync << ", 0xFFFFFFFF)" << TestLog::EndMessage; EGLint error = egl.getError(); log << TestLog::Message << error << " = eglGetError()" << TestLog::EndMessage; if (error != EGL_BAD_PARAMETER) { log << TestLog::Message << "Unexpected error '" << eglu::getErrorStr(error) << "' expected EGL_BAD_PARAMETER" << TestLog::EndMessage; m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail"); return; } TCU_CHECK(status == EGL_FALSE); } IterateResult iterate (void) { m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); if (hasRequiredEGLVersion(1, 5)) { test(m_funcNames, &Library::createSync, &Library::waitSync); } if (hasEGLWaitSyncExtension()) { test(m_funcNamesKHR, &Library::createSyncKHR, &Library::waitSyncKHR); } else if (!hasRequiredEGLVersion(1, 5)) { TCU_THROW(NotSupportedError, "Required extensions not supported"); } return STOP; } }; FenceSyncTests::FenceSyncTests (EglTestContext& eglTestCtx) : TestCaseGroup (eglTestCtx, "fence_sync", "EGL_KHR_fence_sync extension tests") { } void FenceSyncTests::init (void) { // Add valid API test { TestCaseGroup* const valid = new TestCaseGroup(m_eglTestCtx, "valid", "Valid function calls"); // eglCreateSyncKHR tests valid->addChild(new CreateNullAttribsTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); valid->addChild(new CreateEmptyAttribsTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); // eglClientWaitSyncKHR tests valid->addChild(new ClientWaitNoTimeoutTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); valid->addChild(new ClientWaitForeverTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); valid->addChild(new ClientWaitNoContextTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); valid->addChild(new ClientWaitForeverFlushTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); // eglGetSyncAttribKHR tests valid->addChild(new GetSyncTypeTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); valid->addChild(new GetSyncStatusTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); valid->addChild(new GetSyncStatusSignaledTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); valid->addChild(new GetSyncConditionTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); // eglDestroySyncKHR tests valid->addChild(new DestroySyncTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); // eglWaitSyncKHR tests valid->addChild(new WaitSyncTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); addChild(valid); } // Add negative API tests { TestCaseGroup* const invalid = new TestCaseGroup(m_eglTestCtx, "invalid", "Invalid function calls"); // eglCreateSyncKHR tests invalid->addChild(new CreateInvalidDisplayTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); invalid->addChild(new CreateInvalidTypeTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); invalid->addChild(new CreateInvalidAttribsTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); invalid->addChild(new CreateInvalidContextTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); // eglClientWaitSyncKHR tests invalid->addChild(new ClientWaitInvalidDisplayTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); invalid->addChild(new ClientWaitInvalidSyncTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); // eglGetSyncAttribKHR tests invalid->addChild(new GetSyncInvalidDisplayTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); invalid->addChild(new GetSyncInvalidSyncTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); invalid->addChild(new GetSyncInvalidAttributeTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); invalid->addChild(new GetSyncInvalidValueTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); // eglDestroySyncKHR tests invalid->addChild(new DestroySyncInvalidDislayTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); invalid->addChild(new DestroySyncInvalidSyncTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); // eglWaitSyncKHR tests invalid->addChild(new WaitSyncInvalidDisplayTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); invalid->addChild(new WaitSyncInvalidSyncTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); invalid->addChild(new WaitSyncInvalidFlagTest(m_eglTestCtx, EGL_SYNC_FENCE_KHR)); addChild(invalid); } } ReusableSyncTests::ReusableSyncTests (EglTestContext& eglTestCtx) : TestCaseGroup (eglTestCtx, "reusable_sync", "EGL_KHR_reusable_sync extension tests") { } void ReusableSyncTests::init (void) { // Add valid API test { TestCaseGroup* const valid = new TestCaseGroup(m_eglTestCtx, "valid", "Valid function calls"); // eglCreateSyncKHR tests valid->addChild(new CreateNullAttribsTest(m_eglTestCtx, EGL_SYNC_REUSABLE_KHR)); valid->addChild(new CreateEmptyAttribsTest(m_eglTestCtx, EGL_SYNC_REUSABLE_KHR)); // eglClientWaitSyncKHR tests valid->addChild(new ClientWaitNoTimeoutTest(m_eglTestCtx, EGL_SYNC_REUSABLE_KHR)); valid->addChild(new ClientWaitForeverTest(m_eglTestCtx, EGL_SYNC_REUSABLE_KHR)); valid->addChild(new ClientWaitNoContextTest(m_eglTestCtx, EGL_SYNC_REUSABLE_KHR)); valid->addChild(new ClientWaitForeverFlushTest(m_eglTestCtx, EGL_SYNC_REUSABLE_KHR)); // eglGetSyncAttribKHR tests valid->addChild(new GetSyncTypeTest(m_eglTestCtx, EGL_SYNC_REUSABLE_KHR)); valid->addChild(new GetSyncStatusTest(m_eglTestCtx, EGL_SYNC_REUSABLE_KHR)); valid->addChild(new GetSyncStatusSignaledTest(m_eglTestCtx, EGL_SYNC_REUSABLE_KHR)); // eglDestroySyncKHR tests valid->addChild(new DestroySyncTest(m_eglTestCtx, EGL_SYNC_REUSABLE_KHR)); addChild(valid); } // Add negative API tests { TestCaseGroup* const invalid = new TestCaseGroup(m_eglTestCtx, "invalid", "Invalid function calls"); // eglCreateSyncKHR tests invalid->addChild(new CreateInvalidDisplayTest(m_eglTestCtx, EGL_SYNC_REUSABLE_KHR)); invalid->addChild(new CreateInvalidTypeTest(m_eglTestCtx, EGL_SYNC_REUSABLE_KHR)); invalid->addChild(new CreateInvalidAttribsTest(m_eglTestCtx, EGL_SYNC_REUSABLE_KHR)); // eglClientWaitSyncKHR tests invalid->addChild(new ClientWaitInvalidDisplayTest(m_eglTestCtx, EGL_SYNC_REUSABLE_KHR)); invalid->addChild(new ClientWaitInvalidSyncTest(m_eglTestCtx, EGL_SYNC_REUSABLE_KHR)); // eglGetSyncAttribKHR tests invalid->addChild(new GetSyncInvalidDisplayTest(m_eglTestCtx, EGL_SYNC_REUSABLE_KHR)); invalid->addChild(new GetSyncInvalidSyncTest(m_eglTestCtx, EGL_SYNC_REUSABLE_KHR)); invalid->addChild(new GetSyncInvalidAttributeTest(m_eglTestCtx, EGL_SYNC_REUSABLE_KHR)); invalid->addChild(new GetSyncInvalidValueTest(m_eglTestCtx, EGL_SYNC_REUSABLE_KHR)); // eglDestroySyncKHR tests invalid->addChild(new DestroySyncInvalidDislayTest(m_eglTestCtx, EGL_SYNC_REUSABLE_KHR)); invalid->addChild(new DestroySyncInvalidSyncTest(m_eglTestCtx, EGL_SYNC_REUSABLE_KHR)); // eglWaitSyncKHR tests invalid->addChild(new WaitSyncInvalidDisplayTest(m_eglTestCtx, EGL_SYNC_REUSABLE_KHR)); invalid->addChild(new WaitSyncInvalidSyncTest(m_eglTestCtx, EGL_SYNC_REUSABLE_KHR)); addChild(invalid); } } } // egl } // deqp