From 8ed364337be93e5e8c4362427e029e6696d52fe2 Mon Sep 17 00:00:00 2001 From: Vlad Zahorodnii Date: Thu, 3 Jun 2021 09:13:47 +0300 Subject: [PATCH] scenes/opengl: Allow setting external global share context This is needed to initialize global share context on X11. --- .../scenes/opengl/abstract_egl_backend.cpp | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/src/platformsupport/scenes/opengl/abstract_egl_backend.cpp b/src/platformsupport/scenes/opengl/abstract_egl_backend.cpp index b404dac578..68a222047e 100644 --- a/src/platformsupport/scenes/opengl/abstract_egl_backend.cpp +++ b/src/platformsupport/scenes/opengl/abstract_egl_backend.cpp @@ -37,13 +37,13 @@ static bool isOpenGLES_helper() return QOpenGLContext::openGLModuleType() == QOpenGLContext::LibGLES; } -static bool ensureGlobalShareContext() +static EGLContext ensureGlobalShareContext() { const EGLDisplay eglDisplay = kwinApp()->platform()->sceneEglDisplay(); const EGLConfig eglConfig = kwinApp()->platform()->sceneEglConfig(); - if (s_globalShareContext != EGL_NO_CONTEXT) { - return true; + if (kwinApp()->platform()->sceneEglGlobalShareContext() != EGL_NO_CONTEXT) { + return kwinApp()->platform()->sceneEglGlobalShareContext(); } std::vector attribs; @@ -62,8 +62,7 @@ static bool ensureGlobalShareContext() } kwinApp()->platform()->setSceneEglGlobalShareContext(s_globalShareContext); - - return s_globalShareContext != EGL_NO_CONTEXT; + return s_globalShareContext; } static void destroyGlobalShareContext() @@ -255,7 +254,8 @@ bool AbstractEglBackend::isOpenGLES() const bool AbstractEglBackend::createContext() { - if (!ensureGlobalShareContext()) { + EGLContext globalShareContext = ensureGlobalShareContext(); + if (globalShareContext == EGL_NO_CONTEXT) { return false; } @@ -329,7 +329,7 @@ bool AbstractEglBackend::createContext() EGLContext ctx = EGL_NO_CONTEXT; for (auto it = candidates.begin(); it != candidates.end(); it++) { const auto attribs = (*it)->build(); - ctx = eglCreateContext(m_display, config(), s_globalShareContext, attribs.data()); + ctx = eglCreateContext(m_display, config(), globalShareContext, attribs.data()); if (ctx != EGL_NO_CONTEXT) { qCDebug(KWIN_OPENGL) << "Created EGL context with attributes:" << (*it).get(); break;