| /*------------------------------------------------------------------------- |
| * 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 <vector> |
| #include <string> |
| #include <sstream> |
| #include <set> |
| |
| using std::vector; |
| using std::string; |
| using std::set; |
| |
| using tcu::TestLog; |
| |
| using namespace eglw; |
| using namespace glw; |
| |
| #define NO_ERROR 0 |
| #define ERROR -1 |
| |
| #if (DE_OS == DE_OS_ANDROID) |
| #define EGL_SYNC_NATIVE_FENCE_ANDROID 0x3144 |
| #endif |
| |
| 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"; |
| #if (DE_OS == DE_OS_ANDROID) |
| case EGL_SYNC_NATIVE_FENCE_ANDROID: |
| return "EGL_SYNC_NATIVE_FENCE_ANDROID"; |
| #endif |
| default: |
| DE_ASSERT(DE_FALSE); |
| return "<Unknown>"; |
| } |
| } |
| |
| 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); |
| |
| virtual void init(void); |
| virtual 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; |
| } |
| } |
| |
| static const char* const glsl_cs_long = R"( |
| layout(local_size_x = 1, local_size_y = 1) in; |
| layout(std430) buffer; |
| layout(binding = 0) buffer Output { |
| int elements[2]; |
| } output_data; |
| |
| void main() { |
| int temp = 0; |
| int value = output_data.elements[1]/100; |
| for (int i = 0; i < value; i++) { |
| for (int j = 0; j < output_data.elements[1]/value; j++) { |
| temp += 1; |
| } |
| } |
| atomicAdd(output_data.elements[0], temp); |
| } |
| )"; |
| |
| static const char* const kGLSLVer = "#version 310 es\n"; |
| |
| class CreateLongRunningSyncTest : public SyncTest { |
| GLuint m_buffer = 0; |
| volatile int* m_dataloadstoreptr = NULL; |
| eglw::EGLContext m_sharedcontext = NULL; |
| const int m_total_count = 5000000; |
| const int m_shorter_count = 50000; |
| |
| void init(void) override |
| { |
| const EGLint contextAttribList[] = {EGL_CONTEXT_CLIENT_VERSION, |
| 3, EGL_NONE}; |
| const EGLint displayAttribList[] = {EGL_RENDERABLE_TYPE, |
| EGL_OPENGL_ES3_BIT_KHR, |
| EGL_SURFACE_TYPE, |
| EGL_WINDOW_BIT, |
| EGL_ALPHA_SIZE, |
| 1, |
| EGL_NONE}; |
| const Library& egl = m_eglTestCtx.getLibrary(); |
| const eglu::NativeWindowFactory& windowFactory = |
| eglu::selectNativeWindowFactory( |
| m_eglTestCtx.getNativeDisplayFactory(), |
| m_testCtx.getCommandLine()); |
| TestLog& log = m_testCtx.getLog(); |
| |
| m_eglDisplay = |
| eglu::getAndInitDisplay(m_eglTestCtx.getNativeDisplay()); |
| m_eglConfig = eglu::chooseSingleConfig(egl, m_eglDisplay, |
| displayAttribList); |
| |
| m_eglTestCtx.initGLFunctions(&m_gl, glu::ApiType::es(3, 1)); |
| |
| m_extensions = (Extension)(m_extensions | getSyncTypeExtension(m_syncType)); |
| |
| // Create context |
| EGLU_CHECK_CALL(egl, bindAPI(EGL_OPENGL_ES_API)); |
| m_eglContext = egl.createContext(m_eglDisplay, m_eglConfig, EGL_NO_CONTEXT, contextAttribList); |
| if (egl.getError() != EGL_SUCCESS) |
| TCU_THROW(NotSupportedError, "GLES3 not supported"); |
| |
| 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); |
| |
| m_sharedcontext = egl.createContext(m_eglDisplay, m_eglConfig, m_eglContext, contextAttribList); |
| |
| if (m_sharedcontext == EGL_NO_CONTEXT || egl.getError() != EGL_SUCCESS) { |
| log << TestLog::Message << "Error creating a shared context" |
| << TestLog::EndMessage; |
| m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail"); |
| } |
| } |
| |
| void deinit(void) override |
| { |
| const Library& egl = m_eglTestCtx.getLibrary(); |
| |
| m_gl.useProgram(0); |
| if (m_buffer != 0) { |
| m_gl.deleteBuffers(2, &m_buffer); |
| m_buffer = 0; |
| } |
| |
| if (m_sharedcontext != EGL_NO_CONTEXT) { |
| EGLU_CHECK_CALL(egl, destroyContext(m_eglDisplay, m_sharedcontext)); |
| m_sharedcontext = EGL_NO_CONTEXT; |
| } |
| |
| SyncTest::deinit(); |
| } |
| |
| bool CheckProgram(GLuint program, bool* compile_error = NULL) { |
| GLint compile_status = GL_TRUE; |
| GLint status; |
| TestLog& logger = m_testCtx.getLog(); |
| |
| m_gl.getProgramiv(program, GL_LINK_STATUS, &status); |
| |
| if (status == GL_FALSE) |
| { |
| GLint attached_shaders = 0; |
| GLint length; |
| |
| m_gl.getProgramiv(program, GL_ATTACHED_SHADERS, &attached_shaders); |
| |
| if (attached_shaders > 0) |
| { |
| std::vector<GLuint> shaders(attached_shaders); |
| m_gl.getAttachedShaders(program, attached_shaders, NULL, &shaders[0]); |
| |
| for (GLint i = 0; i < attached_shaders; ++i) |
| { |
| GLint res; |
| GLenum type; |
| m_gl.getShaderiv(shaders[i], GL_SHADER_TYPE, |
| reinterpret_cast<GLint*>(&type)); |
| switch (type) { |
| case GL_VERTEX_SHADER: |
| logger << tcu::TestLog::Message |
| << "*** Vertex Shader ***" |
| << tcu::TestLog::EndMessage; |
| break; |
| case GL_FRAGMENT_SHADER: |
| logger << tcu::TestLog::Message |
| << "*** Fragment Shader ***" |
| << tcu::TestLog::EndMessage; |
| break; |
| case GL_COMPUTE_SHADER: |
| logger << tcu::TestLog::Message |
| << "*** Compute Shader ***" |
| << tcu::TestLog::EndMessage; |
| break; |
| default: |
| logger << tcu::TestLog::Message |
| << "*** Unknown Shader ***" |
| << tcu::TestLog::EndMessage; |
| break; |
| } |
| |
| m_gl.getShaderiv(shaders[i], GL_COMPILE_STATUS, &res); |
| if (res != GL_TRUE) |
| compile_status = res; |
| |
| length = 0; |
| m_gl.getShaderiv(shaders[i], GL_SHADER_SOURCE_LENGTH, &length); |
| if (length > 0) |
| { |
| std::vector<GLchar> source(length); |
| m_gl.getShaderSource(shaders[i], length, NULL, &source[0]); |
| logger << tcu::TestLog::Message << &source[0] |
| << tcu::TestLog::EndMessage; |
| } |
| |
| m_gl.getShaderiv(shaders[i], GL_INFO_LOG_LENGTH, &length); |
| if (length > 0) |
| { |
| std::vector<GLchar> log(length); |
| m_gl.getShaderInfoLog(shaders[i], length, NULL, &log[0]); |
| logger << tcu::TestLog::Message << &log[0] << tcu::TestLog::EndMessage; |
| } |
| } |
| } |
| |
| m_gl.getProgramiv(program, GL_INFO_LOG_LENGTH, &length); |
| if (length > 0) { |
| std::vector<GLchar> log(length); |
| m_gl.getProgramInfoLog(program, length, NULL, |
| &log[0]); |
| logger << tcu::TestLog::Message << &log[0] |
| << tcu::TestLog::EndMessage; |
| } |
| } |
| |
| if (compile_error) |
| *compile_error = (compile_status == GL_TRUE ? false : true); |
| |
| if (compile_status != GL_TRUE) |
| return false; |
| |
| return status == GL_TRUE ? true : false; |
| } |
| |
| GLuint CreateComputeProgram(const std::string& cs) { |
| const GLuint p = m_gl.createProgram(); |
| |
| if (!cs.empty()) |
| { |
| const GLuint sh = m_gl.createShader(GL_COMPUTE_SHADER); |
| m_gl.attachShader(p, sh); |
| m_gl.deleteShader(sh); |
| const char* const src[2] = {kGLSLVer, cs.c_str()}; |
| m_gl.shaderSource(sh, 2, src, NULL); |
| m_gl.compileShader(sh); |
| } |
| |
| return p; |
| } |
| |
| void RunComputePersistent() { |
| const Library& egl = m_eglTestCtx.getLibrary(); |
| TestLog& log = m_testCtx.getLog(); |
| GLbitfield flags = GL_MAP_READ_BIT | GL_MAP_WRITE_BIT | |
| GL_MAP_PERSISTENT_BIT | GL_MAP_COHERENT_BIT; |
| GLuint program = CreateComputeProgram(glsl_cs_long); |
| decltype(glw::Functions::bufferStorage) func; |
| |
| m_gl.linkProgram(program); |
| if (!CheckProgram(program)) |
| { |
| m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail"); |
| return; |
| } |
| |
| m_gl.useProgram(program); |
| m_gl.genBuffers(2, &m_buffer); |
| m_gl.bindBufferBase(GL_SHADER_STORAGE_BUFFER, 0, m_buffer); |
| |
| GLU_EXPECT_NO_ERROR(m_gl.getError(), "Buffer Creation Failed"); |
| |
| func = reinterpret_cast<decltype(glw::Functions::bufferStorage)>( |
| egl.getProcAddress("glBufferStorageEXT")); |
| if (!func) |
| { |
| log << TestLog::Message |
| << "Error getting the correct function" |
| << TestLog::EndMessage; |
| m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail"); |
| return; |
| } |
| |
| func(GL_SHADER_STORAGE_BUFFER, sizeof(int) * 2, NULL, flags); |
| GLU_EXPECT_NO_ERROR(m_gl.getError(), "Buffer Set Persistent Bits"); |
| |
| m_dataloadstoreptr = static_cast<int*>(m_gl.mapBufferRange( |
| GL_SHADER_STORAGE_BUFFER, 0, sizeof(int) * 2, flags)); |
| m_dataloadstoreptr[0] = 0; |
| m_dataloadstoreptr[1] = m_shorter_count; |
| |
| for (int i = 0; i < m_total_count/m_shorter_count; i++) |
| m_gl.dispatchCompute(1, 1, 1); |
| |
| m_gl.memoryBarrier(GL_ALL_BARRIER_BITS); |
| m_gl.flush(); |
| }; |
| |
| template <typename clientWaitSyncFuncType> |
| void PollClientWait(string funcNames[FUNC_NAME_NUM_NAMES], |
| clientWaitSyncFuncType clientWaitSyncFunc, |
| EGLint flags, const string& flagsName, |
| EGLTime eglTime, const string& eglTimeName, |
| EGLint condSatisfied) { |
| TestLog& log = m_testCtx.getLog(); |
| const Library& egl = m_eglTestCtx.getLibrary(); |
| EGLint status = (egl.*clientWaitSyncFunc)(m_eglDisplay, m_sync, flags, 0); |
| |
| log << TestLog::Message << status << " = " |
| << funcNames[FUNC_NAME_CLIENT_WAIT_SYNC] << "(" |
| << m_eglDisplay << ", " << m_sync << ", " << flagsName |
| << ", " << eglTimeName << ")" << TestLog::EndMessage; |
| |
| while (true) |
| { |
| switch (status) |
| { |
| case EGL_TIMEOUT_EXPIRED_KHR: |
| log << TestLog::Message |
| << "TAGTAG Wait --- GL_TIMEOUT_EXPIRED" |
| << TestLog::EndMessage; |
| break; |
| case EGL_CONDITION_SATISFIED_KHR: |
| log << TestLog::Message |
| << "TAGTAG Wait --- GL_CONDITION_SATISFIED" |
| << TestLog::EndMessage; |
| return; |
| case EGL_FALSE: |
| log << TestLog::Message |
| << "TAGTAG Wait --- EGL_FALSE" |
| << TestLog::EndMessage; |
| return; |
| default: |
| log << TestLog::Message |
| << "TAGTAG Wait --- SOMETHING ELSE" |
| << TestLog::EndMessage; |
| return; |
| } |
| status = (egl.*clientWaitSyncFunc)(m_eglDisplay, m_sync, flags, eglTime); |
| } |
| |
| TCU_CHECK(status == condSatisfied); |
| } |
| |
| template <typename createSyncFuncType, typename clientWaitSyncFuncType, |
| typename destroySyncFuncType> |
| void test(string funcNames[FUNC_NAME_NUM_NAMES], |
| createSyncFuncType createSyncFunc, |
| clientWaitSyncFuncType clientWaitSyncFunc, |
| destroySyncFuncType destroySyncFunc, EGLenum syncType, |
| EGLint flags, const string& flagsName, EGLTime eglTime, |
| const string& eglTimeName, EGLint condSatisfied) { |
| |
| const Library& egl = m_eglTestCtx.getLibrary(); |
| TestLog& log = m_testCtx.getLog(); |
| string createSyncMsgChk = |
| funcNames[FUNC_NAME_CREATE_SYNC] + "()"; |
| EGLBoolean result; |
| |
| // Reset before each test |
| deinit(); |
| init(); |
| |
| result = egl.makeCurrent(m_eglDisplay, m_eglSurface, m_eglSurface, |
| m_sharedcontext); |
| |
| if (!result || egl.getError() != EGL_SUCCESS) |
| { |
| log << TestLog::Message |
| << "Error making this context current" |
| << TestLog::EndMessage; |
| |
| m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail"); |
| |
| return; |
| } |
| |
| RunComputePersistent(); |
| |
| m_sync = (egl.*createSyncFunc)(m_eglDisplay, syncType, NULL); |
| log << TestLog::Message << m_sync << " = " |
| << funcNames[FUNC_NAME_CREATE_SYNC] << "(" << m_eglDisplay |
| << ", " << getSyncTypeName(syncType) << ", NULL)" |
| << TestLog::EndMessage; |
| |
| EGLU_CHECK_MSG(egl, createSyncMsgChk.c_str()); |
| |
| PollClientWait<clientWaitSyncFuncType>( |
| funcNames, clientWaitSyncFunc, flags, flagsName, eglTime, |
| eglTimeName, condSatisfied); |
| |
| 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 = EGL_NO_SYNC_KHR; |
| |
| if (*m_dataloadstoreptr != 5000000) { |
| log << TestLog::Message << "Invalid m_Dataloadstoreptr " |
| << *m_dataloadstoreptr << TestLog::EndMessage; |
| m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail"); |
| return; |
| } |
| |
| EGLU_CHECK_CALL(egl, makeCurrent(m_eglDisplay, m_eglSurface, |
| m_eglSurface, m_eglContext)); |
| } |
| |
| public: |
| CreateLongRunningSyncTest(EglTestContext& eglTestCtx, EGLenum syncType) |
| : SyncTest(eglTestCtx, syncType, SyncTest::EXTENSION_NONE, true, |
| "egl_fence_persistent_buffer", |
| "egl_fence_persistent_buffer") {} |
| |
| IterateResult iterate(void) override |
| { |
| m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass"); |
| |
| if (hasRequiredEGLVersion(1, 5)) |
| { |
| test<createSync, clientWaitSync, destroySync>( |
| m_funcNames, &Library::createSync, |
| &Library::clientWaitSync, &Library::destroySync, |
| EGL_SYNC_FENCE, EGL_SYNC_FLUSH_COMMANDS_BIT, |
| "EGL_SYNC_FLUSH_COMMANDS_BIT", EGL_FOREVER, |
| "EGL_FOREVER", EGL_CONDITION_SATISFIED); |
| } |
| |
| if (hasEGLFenceSyncExtension()) |
| { |
| test<createSyncKHR, clientWaitSyncKHR, destroySyncKHR>( |
| m_funcNames, &Library::createSyncKHR, |
| &Library::clientWaitSyncKHR, |
| &Library::destroySyncKHR, EGL_SYNC_FENCE_KHR, |
| EGL_SYNC_FLUSH_COMMANDS_BIT, |
| "EGL_SYNC_FLUSH_COMMANDS_BIT", EGL_FOREVER, |
| "EGL_FOREVER", EGL_CONDITION_SATISFIED); |
| |
| #if (DE_OS == DE_OS_ANDROID) |
| test<createSyncKHR, clientWaitSyncKHR, destroySyncKHR>( |
| m_funcNames, &Library::createSyncKHR, |
| &Library::clientWaitSyncKHR, |
| &Library::destroySyncKHR, |
| EGL_SYNC_NATIVE_FENCE_ANDROID, |
| EGL_SYNC_FLUSH_COMMANDS_BIT, |
| "EGL_SYNC_FLUSH_COMMANDS_BIT", EGL_FOREVER, |
| "EGL_FOREVER", EGL_CONDITION_SATISFIED); |
| #endif |
| |
| } else if (!hasRequiredEGLVersion(1, 5)) |
| { |
| TCU_THROW(NotSupportedError, |
| "Required extensions not supported"); |
| } |
| |
| return STOP; |
| } |
| }; |
| |
| 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 <typename createSyncFuncType> |
| 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<createSync>(m_funcNames, &Library::createSync); |
| } |
| if (hasEGLFenceSyncExtension()) |
| { |
| test<createSyncKHR>(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 <typename createSyncFuncType, typename attribType> |
| 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<createSync, EGLAttrib>(m_funcNames, &Library::createSync); |
| } |
| if (hasEGLFenceSyncExtension()) |
| { |
| test<createSyncKHR, EGLint>(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 <typename createSyncFuncType, typename syncType> |
| 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<createSync, EGLSync>(m_funcNames, &Library::createSync, EGL_NO_SYNC); |
| } |
| if (hasEGLFenceSyncExtension()) |
| { |
| test<createSyncKHR, EGLSyncKHR>(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 <typename createSyncFuncType> |
| 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<createSync>(m_funcNames, &Library::createSync, EGL_NO_SYNC, |
| EGL_BAD_PARAMETER, "EGL_BAD_PARAMETER"); |
| } |
| if (hasEGLFenceSyncExtension()) |
| { |
| test<createSyncKHR>(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 <typename createSyncFuncType, typename attribType> |
| 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<createSync, EGLAttrib>(m_funcNames, &Library::createSync, EGL_NO_SYNC); |
| } |
| if (hasEGLFenceSyncExtension()) |
| { |
| test<createSyncKHR, EGLint>(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 <typename createSyncFuncType> |
| 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<createSync>(m_funcNames, &Library::createSync, EGL_NO_SYNC); |
| } |
| if (hasEGLFenceSyncExtension()) |
| { |
| test<createSyncKHR>(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 <typename createSyncFuncType, typename clientWaitSyncFuncType> |
| 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<createSync, clientWaitSync>(m_funcNames, &Library::createSync, |
| &Library::clientWaitSync); |
| } |
| if (hasEGLFenceSyncExtension()) |
| { |
| test<createSyncKHR, clientWaitSyncKHR>(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 <typename createSyncFuncType, typename clientWaitSyncFuncType> |
| 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<createSync, clientWaitSync>(m_funcNames, &Library::createSync, |
| &Library::clientWaitSync, |
| EGL_FOREVER, "EGL_FOREVER", |
| EGL_CONDITION_SATISFIED); |
| } |
| if (hasEGLFenceSyncExtension()) |
| { |
| test<createSyncKHR, clientWaitSyncKHR>(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 <typename createSyncFuncType, typename clientWaitSyncFuncType> |
| 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<createSync, clientWaitSync>(m_funcNames, &Library::createSync, |
| &Library::clientWaitSync, |
| EGL_CONDITION_SATISFIED, EGL_FOREVER, "EGL_FOREVER"); |
| } |
| if (hasEGLFenceSyncExtension()) |
| { |
| test<createSyncKHR, clientWaitSyncKHR>(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 <typename createSyncFuncType, typename clientWaitSyncFuncType> |
| 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<createSync, clientWaitSync>(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<createSyncKHR, clientWaitSyncKHR>(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 <typename createSyncFuncType, typename clientWaitSyncFuncType> |
| 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<createSync, clientWaitSync>(m_funcNames, &Library::createSync, |
| &Library::clientWaitSync, |
| EGL_SYNC_FLUSH_COMMANDS_BIT, "EGL_SYNC_FLUSH_COMMANDS_BIT", |
| EGL_FOREVER, "EGL_FOREVER"); |
| } |
| if (hasEGLFenceSyncExtension()) |
| { |
| test<createSyncKHR, clientWaitSyncKHR>(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 <typename clientWaitSyncFuncType> |
| 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<clientWaitSync>(m_funcNames, &Library::clientWaitSync, |
| EGL_NO_SYNC, "EGL_NO_SYNC", |
| EGL_FOREVER, "EGL_FOREVER"); |
| } |
| if (hasEGLFenceSyncExtension()) |
| { |
| test<clientWaitSyncKHR>(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 <typename createSyncFuncType, typename getSyncAttribFuncType, typename getSyncAttribValueType> |
| 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<createSync, getSyncAttrib, EGLAttrib>(m_funcNames, &Library::createSync, |
| &Library::getSyncAttrib, |
| EGL_SYNC_TYPE, "EGL_SYNC_TYPE"); |
| } |
| if (hasEGLFenceSyncExtension()) |
| { |
| test<createSyncKHR, getSyncAttribKHR, EGLint>(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 <typename createSyncFuncType, typename getSyncAttribFuncType, typename getSyncAttribValueType> |
| 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<createSync, getSyncAttrib, EGLAttrib>(m_funcNames, &Library::createSync, |
| &Library::getSyncAttrib, |
| EGL_SYNC_STATUS, "EGL_SYNC_STATUS"); |
| } |
| if (hasEGLFenceSyncExtension()) |
| { |
| test<createSyncKHR, getSyncAttribKHR, EGLint>(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 <typename createSyncFuncType, |
| typename clientWaitSyncFuncType, |
| typename getSyncAttribFuncType, |
| typename getSyncAttribValueType> |
| 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<createSync, clientWaitSync, getSyncAttrib, EGLAttrib>(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<createSyncKHR, clientWaitSyncKHR, getSyncAttribKHR, EGLint>(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 <typename createSyncFuncType, |
| typename getSyncAttribFuncType, |
| typename getSyncAttribValueType> |
| 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<createSync, getSyncAttrib, EGLAttrib>(m_funcNames, &Library::createSync, |
| &Library::getSyncAttrib, |
| EGL_SYNC_CONDITION, "EGL_SYNC_CONDITION", |
| EGL_SYNC_PRIOR_COMMANDS_COMPLETE); |
| } |
| if (hasEGLFenceSyncExtension()) |
| { |
| test<createSyncKHR, getSyncAttribKHR, EGLint>(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 <typename createSyncFuncType, |
| typename getSyncAttribFuncType, |
| typename getSyncAttribValueType> |
| 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<createSync, getSyncAttrib, EGLAttrib>(m_funcNames, &Library::createSync, |
| &Library::getSyncAttrib, |
| EGL_SYNC_CONDITION, "EGL_SYNC_CONDITION"); |
| } |
| if (hasEGLFenceSyncExtension()) |
| { |
| test<createSyncKHR, getSyncAttribKHR, EGLint>(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 <typename getSyncAttribFuncType, |
| typename getSyncSyncValueType, |
| typename getSyncAttribValueType> |
| 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<getSyncAttrib, EGLSync, EGLAttrib>(m_funcNames, &Library::getSyncAttrib, |
| EGL_NO_SYNC, "EGL_NO_SYNC", |
| EGL_SYNC_CONDITION, "EGL_SYNC_CONDITION"); |
| } |
| if (hasEGLFenceSyncExtension()) |
| { |
| test<getSyncAttribKHR, EGLSyncKHR, EGLint>(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 <typename createSyncFuncType, |
| typename getSyncAttribFuncType, |
| typename getSyncAttribValueType> |
| 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<createSync, getSyncAttrib, EGLAttrib>(m_funcNames, |
| &Library::createSync, |
| &Library::getSyncAttrib); |
| } |
| if (hasEGLFenceSyncExtension()) |
| { |
| test<createSyncKHR, getSyncAttribKHR, EGLint>(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 <typename createSyncFuncType, |
| typename getSyncAttribFuncType, typename valueType> |
| 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<createSync, getSyncAttrib>(m_funcNames, &Library::createSync, |
| &Library::getSyncAttrib, |
| EGL_SYNC_TYPE, "EGL_SYNC_TYPE", value); |
| } |
| if (hasEGLFenceSyncExtension()) |
| { |
| EGLint value = 0; |
| test<createSyncKHR, getSyncAttribKHR>(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 <typename createSyncFuncType, |
| typename destroySyncFuncType, |
| typename getSyncSyncValueType> |
| 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<createSync, destroySync, EGLSync>(m_funcNames, |
| &Library::createSync, |
| &Library::destroySync, |
| EGL_NO_SYNC); |
| } |
| if (hasEGLFenceSyncExtension()) |
| { |
| test<createSyncKHR, destroySyncKHR, EGLSyncKHR>(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 <typename createSyncFuncType, typename destroySyncFuncType> |
| 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<createSync, destroySync>(m_funcNames, |
| &Library::createSync, |
| &Library::destroySync); |
| } |
| if (hasEGLFenceSyncExtension()) |
| { |
| test<createSyncKHR, destroySyncKHR>(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 <typename destroySyncFuncType, typename getSyncSyncValueType> |
| 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<destroySync, EGLSync>(m_funcNames, |
| &Library::destroySync, |
| EGL_NO_SYNC); |
| } |
| if (hasEGLFenceSyncExtension()) |
| { |
| test<destroySyncKHR, EGLSyncKHR>(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 <typename createSyncFuncType, |
| typename waitSyncFuncType, |
| typename waitSyncStatusType> |
| 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<createSync, waitSync, EGLBoolean>(m_funcNames, |
| &Library::createSync, |
| &Library::waitSync); |
| } |
| if (hasEGLWaitSyncExtension()) |
| { |
| test<createSyncKHR, waitSyncKHR, EGLint>(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 <typename createSyncFuncType, |
| typename waitSyncFuncType, |
| typename waitSyncStatusType> |
| 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<createSync, waitSync, EGLBoolean>(m_funcNames, |
| &Library::createSync, |
| &Library::waitSync); |
| } |
| if (hasEGLWaitSyncExtension()) |
| { |
| test<createSyncKHR, waitSyncKHR, EGLint>(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 <typename waitSyncFuncType, typename waitSyncSyncType> |
| 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<waitSync, EGLSync>(m_funcNames, |
| &Library::waitSync, |
| EGL_NO_SYNC); |
| } |
| if (hasEGLWaitSyncExtension()) |
| { |
| test<waitSyncKHR, EGLSyncKHR>(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 <typename createSyncFuncType, typename waitSyncFuncType> |
| 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<createSync, waitSync>(m_funcNames, |
| &Library::createSync, |
| &Library::waitSync); |
| } |
| if (hasEGLWaitSyncExtension()) |
| { |
| test<createSyncKHR, waitSyncKHR>(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)); |
| |
| // eglClientWaitSyncKHR tests |
| valid->addChild(new CreateLongRunningSyncTest(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 |
| |