mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-04 06:06:17 +00:00
comp: Use u_logging in some EGL code.
This commit is contained in:
parent
a6b6ab8e2c
commit
bf37b9d999
|
@ -21,6 +21,8 @@
|
||||||
#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"
|
||||||
#include "util/u_misc.h"
|
#include "util/u_misc.h"
|
||||||
|
#include "util/u_logging.h"
|
||||||
|
#include "util/u_debug.h"
|
||||||
#include "xrt/xrt_gfx_egl.h"
|
#include "xrt/xrt_gfx_egl.h"
|
||||||
#include "xrt/xrt_handles.h"
|
#include "xrt/xrt_handles.h"
|
||||||
|
|
||||||
|
@ -29,6 +31,16 @@
|
||||||
#error "This file shouldn't be compiled without EGL"
|
#error "This file shouldn't be compiled without EGL"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
static enum u_logging_level ll;
|
||||||
|
|
||||||
|
#define EGL_TRACE(...) U_LOG_IFL_T(ll, __VA_ARGS__)
|
||||||
|
#define EGL_DEBUG(...) U_LOG_IFL_D(ll, __VA_ARGS__)
|
||||||
|
#define EGL_INFO(...) U_LOG_IFL_I(ll, __VA_ARGS__)
|
||||||
|
#define EGL_WARN(...) U_LOG_IFL_W(ll, __VA_ARGS__)
|
||||||
|
#define EGL_ERROR(...) U_LOG_IFL_E(ll, __VA_ARGS__)
|
||||||
|
|
||||||
|
DEBUG_GET_ONCE_LOG_OPTION(egl_log, "EGL_LOG", U_LOGGING_WARN)
|
||||||
|
|
||||||
// Not forward declared by mesa
|
// Not forward declared by mesa
|
||||||
typedef EGLBoolean EGLAPIENTRY (*PFNEGLMAKECURRENTPROC)(EGLDisplay dpy,
|
typedef EGLBoolean EGLAPIENTRY (*PFNEGLMAKECURRENTPROC)(EGLDisplay dpy,
|
||||||
EGLSurface draw,
|
EGLSurface draw,
|
||||||
|
@ -51,10 +63,11 @@ xrt_gfx_provider_create_gl_egl(struct xrt_compositor_native *xcn,
|
||||||
EGLContext context,
|
EGLContext context,
|
||||||
PFNEGLGETPROCADDRESSPROC get_gl_procaddr)
|
PFNEGLGETPROCADDRESSPROC get_gl_procaddr)
|
||||||
{
|
{
|
||||||
|
ll = debug_get_log_option_egl_log();
|
||||||
|
|
||||||
gladLoadEGL(display, get_gl_procaddr);
|
gladLoadEGL(display, get_gl_procaddr);
|
||||||
if (!eglMakeCurrent(display, EGL_NO_SURFACE, EGL_NO_SURFACE, context)) {
|
if (!eglMakeCurrent(display, EGL_NO_SURFACE, EGL_NO_SURFACE, context)) {
|
||||||
fprintf(stderr, "Failed to make EGL context current\n");
|
EGL_ERROR("Failed to make EGL context current");
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -70,8 +83,7 @@ xrt_gfx_provider_create_gl_egl(struct xrt_compositor_native *xcn,
|
||||||
gladLoadGL(get_gl_procaddr);
|
gladLoadGL(get_gl_procaddr);
|
||||||
break;
|
break;
|
||||||
#else
|
#else
|
||||||
fprintf(stderr,
|
EGL_ERROR("OpenGL support not including in this runtime build");
|
||||||
"OpenGL support not including in this runtime build\n");
|
|
||||||
return NULL;
|
return NULL;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -81,33 +93,49 @@ xrt_gfx_provider_create_gl_egl(struct xrt_compositor_native *xcn,
|
||||||
gladLoadGLES2(get_gl_procaddr);
|
gladLoadGLES2(get_gl_procaddr);
|
||||||
break;
|
break;
|
||||||
#else
|
#else
|
||||||
fprintf(
|
EGL_ERROR(
|
||||||
stderr,
|
"OpenGL|ES support not including in this runtime build");
|
||||||
"OpenGL|ES support not including in this runtime build\n");
|
|
||||||
return NULL;
|
return NULL;
|
||||||
#endif
|
#endif
|
||||||
|
default: EGL_ERROR("Unsupported EGL client type"); return NULL;
|
||||||
}
|
}
|
||||||
struct client_gl_compositor *c =
|
struct client_gl_compositor *c =
|
||||||
U_TYPED_CALLOC(struct client_gl_compositor);
|
U_TYPED_CALLOC(struct client_gl_compositor);
|
||||||
|
|
||||||
client_gl_swapchain_create_func sc_create = NULL;
|
client_gl_swapchain_create_func sc_create = NULL;
|
||||||
|
|
||||||
|
EGL_INFO("Extension availability:");
|
||||||
|
#define DUMP_EXTENSION_STATUS(EXT) \
|
||||||
|
EGL_INFO(" - " #EXT ": %s", GLAD_##EXT ? "true" : "false")
|
||||||
|
|
||||||
|
DUMP_EXTENSION_STATUS(GL_EXT_memory_object);
|
||||||
|
DUMP_EXTENSION_STATUS(GL_EXT_memory_object_fd);
|
||||||
|
DUMP_EXTENSION_STATUS(GL_EXT_memory_object_win32);
|
||||||
|
DUMP_EXTENSION_STATUS(EGL_EXT_image_dma_buf_import);
|
||||||
|
DUMP_EXTENSION_STATUS(GL_OES_EGL_image_external);
|
||||||
|
DUMP_EXTENSION_STATUS(EGL_KHR_image);
|
||||||
|
// DUMP_EXTENSION_STATUS(EGL_KHR_image_base);
|
||||||
|
|
||||||
#if defined(XRT_GRAPHICS_BUFFER_HANDLE_IS_FD)
|
#if defined(XRT_GRAPHICS_BUFFER_HANDLE_IS_FD)
|
||||||
if (GLAD_GL_EXT_memory_object && GLAD_GL_EXT_memory_object_fd) {
|
if (GLAD_GL_EXT_memory_object && GLAD_GL_EXT_memory_object_fd) {
|
||||||
|
EGL_INFO("Using GL memory object swapchain implementation");
|
||||||
sc_create = client_gl_memobj_swapchain_create;
|
sc_create = client_gl_memobj_swapchain_create;
|
||||||
}
|
}
|
||||||
if (sc_create == NULL && GLAD_EGL_EXT_image_dma_buf_import) {
|
if (sc_create == NULL && GLAD_EGL_EXT_image_dma_buf_import) {
|
||||||
|
EGL_INFO("Using EGL_Image swapchain implementation");
|
||||||
sc_create = client_gl_eglimage_swapchain_create;
|
sc_create = client_gl_eglimage_swapchain_create;
|
||||||
}
|
}
|
||||||
if (sc_create == NULL) {
|
if (sc_create == NULL) {
|
||||||
free(c);
|
free(c);
|
||||||
fprintf(stderr,
|
EGL_ERROR(
|
||||||
"Could not find a required extension: need either "
|
"Could not find a required extension: need either "
|
||||||
"EGL_EXT_image_dma_buf_import or "
|
"EGL_EXT_image_dma_buf_import or "
|
||||||
"GL_EXT_memory_object_fd\n");
|
"GL_EXT_memory_object_fd");
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
#elif defined(XRT_GRAPHICS_BUFFER_HANDLE_IS_AHARDWAREBUFFER)
|
#elif defined(XRT_GRAPHICS_BUFFER_HANDLE_IS_AHARDWAREBUFFER)
|
||||||
|
EGL_INFO(
|
||||||
|
"Using EGL_Image swapchain implementation with AHardwareBuffer");
|
||||||
sc_create = client_gl_eglimage_swapchain_create;
|
sc_create = client_gl_eglimage_swapchain_create;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -15,23 +15,35 @@
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
#include "util/u_misc.h"
|
#include "util/u_misc.h"
|
||||||
|
#include "util/u_logging.h"
|
||||||
|
#include "util/u_debug.h"
|
||||||
|
|
||||||
#include <xrt/xrt_config_have.h>
|
#include <xrt/xrt_config_have.h>
|
||||||
#include <xrt/xrt_config_os.h>
|
#include <xrt/xrt_config_os.h>
|
||||||
#include <xrt/xrt_handles.h>
|
#include <xrt/xrt_handles.h>
|
||||||
|
|
||||||
#if defined(XRT_HAVE_EGL)
|
|
||||||
#include "ogl/egl_api.h"
|
#include "ogl/egl_api.h"
|
||||||
#endif
|
|
||||||
#if defined(XRT_HAVE_OPENGL) || defined(XRT_HAVE_OPENGLES)
|
|
||||||
#include "ogl/ogl_api.h"
|
#include "ogl/ogl_api.h"
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "client/comp_gl_client.h"
|
#include "client/comp_gl_client.h"
|
||||||
#include "client/comp_gl_eglimage_swapchain.h"
|
#include "client/comp_gl_eglimage_swapchain.h"
|
||||||
|
|
||||||
#include <inttypes.h>
|
#include <inttypes.h>
|
||||||
|
|
||||||
|
|
||||||
|
static enum u_logging_level ll;
|
||||||
|
|
||||||
|
#define EGL_SC_TRACE(...) U_LOG_IFL_T(ll, __VA_ARGS__)
|
||||||
|
#define EGL_SC_DEBUG(...) U_LOG_IFL_D(ll, __VA_ARGS__)
|
||||||
|
#define EGL_SC_INFO(...) U_LOG_IFL_I(ll, __VA_ARGS__)
|
||||||
|
#define EGL_SC_WARN(...) U_LOG_IFL_W(ll, __VA_ARGS__)
|
||||||
|
#define EGL_SC_ERROR(...) U_LOG_IFL_E(ll, __VA_ARGS__)
|
||||||
|
|
||||||
|
DEBUG_GET_ONCE_LOG_OPTION(egl_swapchain_log,
|
||||||
|
"EGL_SWAPCHAIN_LOG",
|
||||||
|
U_LOGGING_WARN)
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Down-cast helper.
|
* Down-cast helper.
|
||||||
* @private @memberof client_gl_eglimage_swapchain
|
* @private @memberof client_gl_eglimage_swapchain
|
||||||
|
@ -111,9 +123,9 @@ gl_format_to_drm_fourcc(uint64_t format)
|
||||||
case GL_RGBA16F:
|
case GL_RGBA16F:
|
||||||
#endif
|
#endif
|
||||||
default:
|
default:
|
||||||
printf("Cannot convert VK format 0x%016" PRIx64
|
EGL_SC_ERROR("Cannot convert GL format 0x%08" PRIx64
|
||||||
" to DRM FOURCC format!\n",
|
" to DRM FOURCC format!",
|
||||||
format);
|
format);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -130,9 +142,9 @@ gl_format_to_bpp(uint64_t format)
|
||||||
case GL_RGBA16F:
|
case GL_RGBA16F:
|
||||||
#endif
|
#endif
|
||||||
default:
|
default:
|
||||||
printf("Cannot convert VK format 0x%016" PRIx64
|
EGL_SC_ERROR("Cannot convert GL format 0x%08" PRIx64
|
||||||
" to DRM FOURCC format!\n",
|
" to DRM FOURCC format!",
|
||||||
format);
|
format);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -145,7 +157,10 @@ client_gl_eglimage_swapchain_create(
|
||||||
struct xrt_swapchain_native *xscn,
|
struct xrt_swapchain_native *xscn,
|
||||||
struct client_gl_swapchain **out_sc)
|
struct client_gl_swapchain **out_sc)
|
||||||
{
|
{
|
||||||
|
ll = debug_get_log_option_egl_swapchain_log();
|
||||||
|
|
||||||
if (xscn == NULL) {
|
if (xscn == NULL) {
|
||||||
|
EGL_SC_ERROR("Native compositor is null");
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -154,11 +169,18 @@ client_gl_eglimage_swapchain_create(
|
||||||
if (format == 0) {
|
if (format == 0) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
uint32_t row_bits = gl_format_to_bpp(info->format) * info->width;
|
uint32_t row_pitch = 0;
|
||||||
uint32_t row_pitch = row_bits / 8;
|
{
|
||||||
if (row_pitch * 8 < row_bits) {
|
uint32_t bpp = gl_format_to_bpp(info->format);
|
||||||
// round up
|
uint32_t row_bits = bpp * info->width;
|
||||||
row_pitch += 1;
|
row_pitch = row_bits / 8;
|
||||||
|
if (row_pitch * 8 < row_bits) {
|
||||||
|
// round up
|
||||||
|
row_pitch += 1;
|
||||||
|
}
|
||||||
|
EGL_SC_INFO("Computed row pitch is %" PRIu32 " bytes: %" PRIu32
|
||||||
|
" bpp, %" PRIu32 " pixels wide",
|
||||||
|
row_pitch, bpp, info->width);
|
||||||
}
|
}
|
||||||
#endif // defined(XRT_GRAPHICS_BUFFER_HANDLE_IS_FD)
|
#endif // defined(XRT_GRAPHICS_BUFFER_HANDLE_IS_FD)
|
||||||
|
|
||||||
|
@ -178,7 +200,6 @@ client_gl_eglimage_swapchain_create(
|
||||||
glGenTextures(native_xsc->num_images, xscgl->images);
|
glGenTextures(native_xsc->num_images, xscgl->images);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
for (uint32_t i = 0; i < native_xsc->num_images; i++) {
|
for (uint32_t i = 0; i < native_xsc->num_images; i++) {
|
||||||
#ifdef XRT_OS_ANDROID
|
#ifdef XRT_OS_ANDROID
|
||||||
glBindTexture(GL_TEXTURE_EXTERNAL_OES, xscgl->images[i]);
|
glBindTexture(GL_TEXTURE_EXTERNAL_OES, xscgl->images[i]);
|
||||||
|
@ -195,6 +216,7 @@ client_gl_eglimage_swapchain_create(
|
||||||
eglGetNativeClientBufferANDROID(xscn->images[i].handle);
|
eglGetNativeClientBufferANDROID(xscn->images[i].handle);
|
||||||
|
|
||||||
if (NULL == native_buffer) {
|
if (NULL == native_buffer) {
|
||||||
|
EGL_SC_ERROR("eglGetNativeClientBufferANDROID failed");
|
||||||
client_gl_eglimage_swapchain_teardown_storage(sc);
|
client_gl_eglimage_swapchain_teardown_storage(sc);
|
||||||
free(sc);
|
free(sc);
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -222,6 +244,7 @@ client_gl_eglimage_swapchain_create(
|
||||||
sc->egl_images[i] = eglCreateImageKHR(
|
sc->egl_images[i] = eglCreateImageKHR(
|
||||||
sc->display, EGL_NO_CONTEXT, target, native_buffer, attrs);
|
sc->display, EGL_NO_CONTEXT, target, native_buffer, attrs);
|
||||||
if (NULL == sc->egl_images[i]) {
|
if (NULL == sc->egl_images[i]) {
|
||||||
|
EGL_SC_ERROR("eglCreateImageKHR failed");
|
||||||
client_gl_eglimage_swapchain_teardown_storage(sc);
|
client_gl_eglimage_swapchain_teardown_storage(sc);
|
||||||
free(sc);
|
free(sc);
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -230,6 +253,7 @@ client_gl_eglimage_swapchain_create(
|
||||||
glEGLImageTargetTexture2DOES(GL_TEXTURE_EXTERNAL_OES,
|
glEGLImageTargetTexture2DOES(GL_TEXTURE_EXTERNAL_OES,
|
||||||
sc->egl_images[i]);
|
sc->egl_images[i]);
|
||||||
#else
|
#else
|
||||||
|
//! @todo this should be glTexImage2D I think.
|
||||||
glEGLImageTargetTexture2DOES(
|
glEGLImageTargetTexture2DOES(
|
||||||
info->array_size == 1 ? GL_TEXTURE_2D : GL_TEXTURE_2D_ARRAY,
|
info->array_size == 1 ? GL_TEXTURE_2D : GL_TEXTURE_2D_ARRAY,
|
||||||
sc->egl_images[i]);
|
sc->egl_images[i]);
|
||||||
|
|
Loading…
Reference in a new issue