c/client: Use the EGL compositor's display in swapchain

This commit is contained in:
Jakob Bornecrantz 2021-05-26 13:23:37 +01:00 committed by Ryan Pavlik
parent b7b469089c
commit f9b5097134
6 changed files with 58 additions and 31 deletions

View file

@ -0,0 +1,2 @@
client: Use the EGL compositor's display in swapchain, previously it tried to
use the current one, which when running on a new thread would explode.

View file

@ -88,6 +88,7 @@ endif()
if(XRT_HAVE_EGL) if(XRT_HAVE_EGL)
list(APPEND CLIENT_SOURCE_FILES list(APPEND CLIENT_SOURCE_FILES
client/comp_egl_client.c client/comp_egl_client.c
client/comp_egl_client.h
) )
endif() endif()

View file

@ -22,6 +22,7 @@
#include "ogl/ogl_api.h" #include "ogl/ogl_api.h"
#include "client/comp_gl_client.h" #include "client/comp_gl_client.h"
#include "client/comp_egl_client.h"
#include "client/comp_gl_memobj_swapchain.h" #include "client/comp_gl_memobj_swapchain.h"
#include "client/comp_gl_eglimage_swapchain.h" #include "client/comp_gl_eglimage_swapchain.h"
@ -116,42 +117,12 @@ old_restore(struct old_helper *old, EGLDisplay current_dpy)
} }
/*
*
* EGL compositor subclass.
*
*/
/*!
* EGL based compositor, carries the extra needed EGL information needed by the
* client side code and can handle both GL Desktop or GLES contexts.
*
* @ingroup comp_client
*/
struct client_egl_compositor
{
struct client_gl_compositor base;
EGLDisplay dpy;
};
/* /*
* *
* Helper functions. * Helper functions.
* *
*/ */
/*!
* Down-cast helper.
* @protected @memberof client_egl_compositor
*/
static inline struct client_egl_compositor *
client_egl_compositor(struct xrt_compositor *xc)
{
return (struct client_egl_compositor *)xc;
}
XRT_MAYBE_UNUSED static bool XRT_MAYBE_UNUSED static bool
has_extension(const char *extensions, const char *ext) has_extension(const char *extensions, const char *ext)
{ {

View file

@ -0,0 +1,50 @@
// Copyright 2019-2021, Collabora, Ltd.
// SPDX-License-Identifier: BSL-1.0
/*!
* @file
* @brief Glue code to EGL client side glue code.
* @author Jakob Bornecrantz <jakob@collabora.com>
* @ingroup comp_client
*/
#pragma once
#include "xrt/xrt_compositor.h"
#include "ogl/egl_api.h"
#include "client/comp_gl_client.h"
#ifdef __cplusplus
extern "C" {
#endif
/*!
* EGL based compositor, carries the extra needed EGL information needed by the
* client side code and can handle both GL Desktop or GLES contexts.
*
* @ingroup comp_client
*/
struct client_egl_compositor
{
struct client_gl_compositor base;
EGLDisplay dpy;
};
/*!
* Down-cast helper.
* @protected @memberof client_egl_compositor
*/
static inline struct client_egl_compositor *
client_egl_compositor(struct xrt_compositor *xc)
{
return (struct client_egl_compositor *)xc;
}
#ifdef __cplusplus
}
#endif

View file

@ -27,6 +27,7 @@
#include "ogl/ogl_helpers.h" #include "ogl/ogl_helpers.h"
#include "client/comp_gl_client.h" #include "client/comp_gl_client.h"
#include "client/comp_egl_client.h"
#include "client/comp_gl_eglimage_swapchain.h" #include "client/comp_gl_eglimage_swapchain.h"
#include <inttypes.h> #include <inttypes.h>
@ -164,6 +165,7 @@ client_gl_eglimage_swapchain_create(struct xrt_compositor *xc,
struct xrt_swapchain_native *xscn, struct xrt_swapchain_native *xscn,
struct client_gl_swapchain **out_sc) struct client_gl_swapchain **out_sc)
{ {
struct client_egl_compositor *ceglc = client_egl_compositor(xc);
ll = debug_get_log_option_egl_swapchain_log(); ll = debug_get_log_option_egl_swapchain_log();
if (xscn == NULL) { if (xscn == NULL) {
@ -197,7 +199,7 @@ client_gl_eglimage_swapchain_create(struct xrt_compositor *xc,
sc->base.base.base.reference.count = 1; sc->base.base.base.reference.count = 1;
sc->base.base.base.num_images = native_xsc->num_images; // Fetch the number of images from the native swapchain. sc->base.base.base.num_images = native_xsc->num_images; // Fetch the number of images from the native swapchain.
sc->base.xscn = xscn; sc->base.xscn = xscn;
sc->display = eglGetCurrentDisplay(); sc->display = ceglc->dpy;
struct xrt_swapchain_gl *xscgl = &sc->base.base; struct xrt_swapchain_gl *xscgl = &sc->base.base;

View file

@ -102,6 +102,7 @@ endif
if build_egl if build_egl
compositor_srcs += [ compositor_srcs += [
'client/comp_egl_client.c', 'client/comp_egl_client.c',
'client/comp_egl_client.h',
] ]
compositor_deps += [egl] compositor_deps += [egl]
endif endif