mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-22 14:41:47 +00:00
comp/client: Use new texture target utility for OpenGL
This commit is contained in:
parent
e48f68deb6
commit
3250617dcb
|
@ -22,6 +22,8 @@
|
||||||
#include "ogl/ogl_api.h"
|
#include "ogl/ogl_api.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include "ogl/ogl_helpers.h"
|
||||||
|
|
||||||
#include "client/comp_gl_client.h"
|
#include "client/comp_gl_client.h"
|
||||||
|
|
||||||
#include <inttypes.h>
|
#include <inttypes.h>
|
||||||
|
@ -317,16 +319,13 @@ client_gl_swapchain_create(struct xrt_compositor *xc,
|
||||||
assert(xscn != NULL);
|
assert(xscn != NULL);
|
||||||
|
|
||||||
// Save texture binding
|
// Save texture binding
|
||||||
GLuint prev_texture = 0;
|
GLint prev_texture = 0;
|
||||||
#if defined(XRT_GRAPHICS_BUFFER_HANDLE_IS_AHARDWAREBUFFER)
|
GLuint binding_enum = 0;
|
||||||
const GLuint binding_enum = GL_TEXTURE_BINDING_EXTERNAL_OES;
|
GLuint tex_target = 0;
|
||||||
#else
|
ogl_texture_target_for_swapchain_info(&xinfo, &tex_target,
|
||||||
const GLuint binding_enum = info->array_size == 1
|
&binding_enum);
|
||||||
? GL_TEXTURE_BINDING_2D
|
|
||||||
: GL_TEXTURE_BINDING_2D_ARRAY;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
glGetIntegerv(binding_enum, (GLint *)&prev_texture);
|
glGetIntegerv(binding_enum, &prev_texture);
|
||||||
|
|
||||||
struct xrt_swapchain *xsc = &xscn->base;
|
struct xrt_swapchain *xsc = &xscn->base;
|
||||||
|
|
||||||
|
@ -348,13 +347,7 @@ client_gl_swapchain_create(struct xrt_compositor *xc,
|
||||||
sc->base.base.num_images = xsc->num_images;
|
sc->base.base.num_images = xsc->num_images;
|
||||||
sc->xscn = xscn;
|
sc->xscn = xscn;
|
||||||
|
|
||||||
#if defined(XRT_GRAPHICS_BUFFER_HANDLE_IS_AHARDWAREBUFFER)
|
glBindTexture(tex_target, prev_texture);
|
||||||
const GLuint binding_target_enum = GL_TEXTURE_EXTERNAL_OES;
|
|
||||||
#else
|
|
||||||
const GLuint binding_target_enum =
|
|
||||||
info->array_size == 1 ? GL_TEXTURE_2D : GL_TEXTURE_2D_ARRAY;
|
|
||||||
#endif
|
|
||||||
glBindTexture(binding_target_enum, prev_texture);
|
|
||||||
|
|
||||||
*out_xsc = &sc->base.base;
|
*out_xsc = &sc->base.base;
|
||||||
return XRT_SUCCESS;
|
return XRT_SUCCESS;
|
||||||
|
|
|
@ -36,6 +36,9 @@ struct client_gl_swapchain
|
||||||
struct xrt_swapchain_gl base;
|
struct xrt_swapchain_gl base;
|
||||||
|
|
||||||
struct xrt_swapchain_native *xscn;
|
struct xrt_swapchain_native *xscn;
|
||||||
|
|
||||||
|
//! The texture target of images in this swapchain.
|
||||||
|
uint32_t tex_target;
|
||||||
};
|
};
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
|
|
@ -24,6 +24,7 @@
|
||||||
|
|
||||||
#include "ogl/egl_api.h"
|
#include "ogl/egl_api.h"
|
||||||
#include "ogl/ogl_api.h"
|
#include "ogl/ogl_api.h"
|
||||||
|
#include "ogl/ogl_helpers.h"
|
||||||
|
|
||||||
#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"
|
||||||
|
@ -199,15 +200,15 @@ client_gl_eglimage_swapchain_create(
|
||||||
|
|
||||||
glGenTextures(native_xsc->num_images, xscgl->images);
|
glGenTextures(native_xsc->num_images, xscgl->images);
|
||||||
|
|
||||||
|
GLuint binding_enum = 0;
|
||||||
|
GLuint tex_target = 0;
|
||||||
|
ogl_texture_target_for_swapchain_info(info, &tex_target, &binding_enum);
|
||||||
|
sc->base.tex_target = tex_target;
|
||||||
|
|
||||||
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
|
|
||||||
glBindTexture(GL_TEXTURE_EXTERNAL_OES, xscgl->images[i]);
|
// Bind new texture name to the target.
|
||||||
#else
|
glBindTexture(tex_target, xscgl->images[i]);
|
||||||
glBindTexture(info->array_size == 1 ? GL_TEXTURE_2D
|
|
||||||
: GL_TEXTURE_2D_ARRAY,
|
|
||||||
xscgl->images[i]);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
EGLClientBuffer native_buffer = NULL;
|
EGLClientBuffer native_buffer = NULL;
|
||||||
|
|
||||||
|
@ -224,7 +225,7 @@ client_gl_eglimage_swapchain_create(
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
EGLint attrs[] = {EGL_NONE};
|
EGLint attrs[] = {EGL_NONE};
|
||||||
EGLenum target = EGL_NATIVE_BUFFER_ANDROID;
|
EGLenum source = EGL_NATIVE_BUFFER_ANDROID;
|
||||||
#elif defined(XRT_GRAPHICS_BUFFER_HANDLE_IS_FD)
|
#elif defined(XRT_GRAPHICS_BUFFER_HANDLE_IS_FD)
|
||||||
EGLint attrs[] = {EGL_WIDTH,
|
EGLint attrs[] = {EGL_WIDTH,
|
||||||
info->width,
|
info->width,
|
||||||
|
@ -239,27 +240,34 @@ client_gl_eglimage_swapchain_create(
|
||||||
EGL_DMA_BUF_PLANE0_PITCH_EXT,
|
EGL_DMA_BUF_PLANE0_PITCH_EXT,
|
||||||
row_pitch,
|
row_pitch,
|
||||||
EGL_NONE};
|
EGL_NONE};
|
||||||
EGLenum target = EGL_LINUX_DMA_BUF_EXT;
|
EGLenum source = EGL_LINUX_DMA_BUF_EXT;
|
||||||
#else
|
#else
|
||||||
#error "need port"
|
#error "need port"
|
||||||
#endif
|
#endif
|
||||||
sc->egl_images[i] = eglCreateImageKHR(
|
sc->egl_images[i] = eglCreateImageKHR(
|
||||||
sc->display, EGL_NO_CONTEXT, target, native_buffer, attrs);
|
sc->display, EGL_NO_CONTEXT, source, native_buffer, attrs);
|
||||||
if (NULL == sc->egl_images[i]) {
|
if (EGL_NO_IMAGE_KHR == sc->egl_images[i]) {
|
||||||
EGL_SC_ERROR("eglCreateImageKHR failed");
|
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;
|
||||||
}
|
}
|
||||||
#if defined(XRT_OS_ANDROID)
|
/*!
|
||||||
glEGLImageTargetTexture2DOES(GL_TEXTURE_EXTERNAL_OES,
|
* @todo this matches the behavior of the Google test, but is
|
||||||
|
* not itself tested or fully rationalized.
|
||||||
|
*
|
||||||
|
* Also, glEGLImageTargetTexStorageEXT was added in Android
|
||||||
|
* platform 28, so fairly recently.
|
||||||
|
*/
|
||||||
|
if (GLAD_GL_EXT_EGL_image_storage &&
|
||||||
|
glEGLImageTargetTexStorageEXT) {
|
||||||
|
glEGLImageTargetTexStorageEXT(tex_target,
|
||||||
|
sc->egl_images[i], NULL);
|
||||||
|
} else if (GLAD_GL_OES_EGL_image_external ||
|
||||||
|
GLAD_GL_OES_EGL_image_external_essl3) {
|
||||||
|
glEGLImageTargetTexture2DOES(tex_target,
|
||||||
sc->egl_images[i]);
|
sc->egl_images[i]);
|
||||||
#else
|
}
|
||||||
//! @todo this should be glTexImage2D I think.
|
|
||||||
glEGLImageTargetTexture2DOES(
|
|
||||||
info->array_size == 1 ? GL_TEXTURE_2D : GL_TEXTURE_2D_ARRAY,
|
|
||||||
sc->egl_images[i]);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return &sc->base.base.base;
|
return &sc->base.base.base;
|
||||||
|
|
|
@ -18,6 +18,7 @@
|
||||||
#include "util/u_misc.h"
|
#include "util/u_misc.h"
|
||||||
|
|
||||||
#include "ogl/ogl_api.h"
|
#include "ogl/ogl_api.h"
|
||||||
|
#include "ogl/ogl_helpers.h"
|
||||||
|
|
||||||
#include "client/comp_gl_client.h"
|
#include "client/comp_gl_client.h"
|
||||||
#include "client/comp_gl_memobj_swapchain.h"
|
#include "client/comp_gl_memobj_swapchain.h"
|
||||||
|
@ -72,6 +73,10 @@ client_gl_memobj_swapchain_create(struct xrt_compositor *xc,
|
||||||
if (xscn == NULL) {
|
if (xscn == NULL) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
GLuint binding_enum = 0;
|
||||||
|
GLuint tex_target = 0;
|
||||||
|
ogl_texture_target_for_swapchain_info(info, &tex_target, &binding_enum);
|
||||||
struct xrt_swapchain *native_xsc = &xscn->base;
|
struct xrt_swapchain *native_xsc = &xscn->base;
|
||||||
|
|
||||||
struct client_gl_memobj_swapchain *sc =
|
struct client_gl_memobj_swapchain *sc =
|
||||||
|
@ -82,12 +87,11 @@ client_gl_memobj_swapchain_create(struct xrt_compositor *xc,
|
||||||
// Fetch the number of images from the native swapchain.
|
// Fetch the number of images from the native swapchain.
|
||||||
client_xsc->num_images = native_xsc->num_images;
|
client_xsc->num_images = native_xsc->num_images;
|
||||||
sc->base.xscn = xscn;
|
sc->base.xscn = xscn;
|
||||||
|
sc->base.tex_target = tex_target;
|
||||||
|
|
||||||
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++) {
|
||||||
glBindTexture(info->array_size == 1 ? GL_TEXTURE_2D
|
glBindTexture(tex_target, xscgl->images[i]);
|
||||||
: GL_TEXTURE_2D_ARRAY,
|
|
||||||
xscgl->images[i]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
glCreateMemoryObjectsEXT(native_xsc->num_images, &sc->memory[0]);
|
glCreateMemoryObjectsEXT(native_xsc->num_images, &sc->memory[0]);
|
||||||
|
|
Loading…
Reference in a new issue