From 6dd2ec06f4a7f50c10225c44a50f9b00b9bd08b6 Mon Sep 17 00:00:00 2001 From: Rohan Chacko Date: Wed, 15 Jul 2020 11:54:42 +0400 Subject: [PATCH] Modified code to loop through devices to check if context can be created. --- lib/renderer/gl/glcontext.py | 26 ++++++++++++++++++++++++-- 1 file changed, 24 insertions(+), 2 deletions(-) diff --git a/lib/renderer/gl/glcontext.py b/lib/renderer/gl/glcontext.py index 0d4cb7d7..f55156b5 100755 --- a/lib/renderer/gl/glcontext.py +++ b/lib/renderer/gl/glcontext.py @@ -66,6 +66,9 @@ def _find_library_new(name): util.find_library = _find_library_new import OpenGL.GL as gl import OpenGL.EGL as egl + from OpenGL import error + from OpenGL.EGL.EXT.device_base import egl_get_devices + from OpenGL.raw.EGL.EXT.platform_device import EGL_PLATFORM_DEVICE_EXT except: print('Unable to load OpenGL libraries. ' 'Make sure you use GPU-enabled backend.') @@ -75,6 +78,23 @@ def _find_library_new(name): finally: util.find_library = _find_library_old +def create_initialized_headless_egl_display(): + """Creates an initialized EGL display directly on a device.""" + for device in egl_get_devices(): + display = egl.eglGetPlatformDisplayEXT(EGL_PLATFORM_DEVICE_EXT, device, None) + + if display != egl.EGL_NO_DISPLAY and egl.eglGetError() == egl.EGL_SUCCESS: + # `eglInitialize` may or may not raise an exception on failure depending + # on how PyOpenGL is configured. We therefore catch a `GLError` and also + # manually check the output of `eglGetError()` here. + try: + initialized = egl.eglInitialize(display, None, None) + except error.GLError: + pass + else: + if initialized == egl.EGL_TRUE and egl.eglGetError() == egl.EGL_SUCCESS: + return display + return egl.EGL_NO_DISPLAY def create_opengl_context(surface_size=(640, 480)): """Create offscreen OpenGL context and make it current. @@ -85,7 +105,9 @@ def create_opengl_context(surface_size=(640, 480)): Args: surface_size: (width, height), size of the offscreen rendering surface. """ - egl_display = egl.eglGetDisplay(egl.EGL_DEFAULT_DISPLAY) + egl_display = create_initialized_headless_egl_display() + if egl_display == egl.EGL_NO_DISPLAY: + raise ImportError('Cannot initialize a headless EGL display.') major, minor = egl.EGLint(), egl.EGLint() egl.eglInitialize(egl_display, pointer(major), pointer(minor)) @@ -117,4 +139,4 @@ def create_opengl_context(surface_size=(640, 480)): egl_context = egl.eglCreateContext(egl_display, egl_cfg, egl.EGL_NO_CONTEXT, None) - egl.eglMakeCurrent(egl_display, egl_surf, egl_surf, egl_context) \ No newline at end of file + egl.eglMakeCurrent(egl_display, egl_surf, egl_surf, egl_context)