display: egl: create VaapiDisplayEGL with native EGL display

gst_vaapi_display_egl_new_with_native_display() has been broken since
it wasn't used.

Currently it's needed to call this API to create a display providing
the EGL display, so it could avoid duplicated calls to the native
display (eg. eglTerminate).

Signed-off-by: Victor Jaquez <vjaquez@igalia.com>

https://bugzilla.gnome.org/show_bug.cgi?id=795391
This commit is contained in:
Hyunjun Ko 2018-04-24 18:17:24 +09:00 committed by Víctor Manuel Jáquez Leal
parent bb8894aaf9
commit 50470ae89f
2 changed files with 60 additions and 22 deletions

View file

@ -50,6 +50,7 @@ typedef struct
gpointer display; gpointer display;
guint display_type; guint display_type;
guint gles_version; guint gles_version;
gpointer gl_display;
} InitParams; } InitParams;
static gboolean static gboolean
@ -97,27 +98,36 @@ static gboolean
gst_vaapi_display_egl_bind_display (GstVaapiDisplay * base_display, gst_vaapi_display_egl_bind_display (GstVaapiDisplay * base_display,
gpointer native_params) gpointer native_params)
{ {
GstVaapiDisplay *native_display = NULL; GstVaapiDisplay *native_vaapi_display;
GstVaapiDisplayEGL *display = GST_VAAPI_DISPLAY_EGL (base_display); GstVaapiDisplayEGL *display = GST_VAAPI_DISPLAY_EGL (base_display);
EglDisplay *egl_display; EglDisplay *egl_display;
EGLDisplay *native_egl_display;
guint gl_platform = EGL_PLATFORM_UNKNOWN; guint gl_platform = EGL_PLATFORM_UNKNOWN;
const InitParams *params = (InitParams *) native_params; const InitParams *params = (InitParams *) native_params;
if (params->display) { native_vaapi_display = params->display;
native_display = params->display; native_egl_display = params->gl_display;
} else {
if (!native_vaapi_display) {
#if USE_X11 #if USE_X11
native_display = gst_vaapi_display_x11_new (NULL); if (params->display_type == GST_VAAPI_DISPLAY_TYPE_ANY
|| params->display_type == GST_VAAPI_DISPLAY_TYPE_X11
|| params->display_type == GST_VAAPI_DISPLAY_TYPE_EGL)
native_vaapi_display = gst_vaapi_display_x11_new (NULL);
#endif #endif
#if USE_WAYLAND #if USE_WAYLAND
if (!native_display) if (!native_vaapi_display)
native_display = gst_vaapi_display_wayland_new (NULL); native_vaapi_display = gst_vaapi_display_wayland_new (NULL);
#endif #endif
} else {
/* thus it could be unrefed */
gst_object_ref (native_vaapi_display);
} }
if (!native_display) if (!native_vaapi_display)
return FALSE; return FALSE;
gst_vaapi_display_replace (&display->display, native_display); gst_vaapi_display_replace (&display->display, native_vaapi_display);
gst_object_unref (native_vaapi_display);
switch (GST_VAAPI_DISPLAY_GET_CLASS_TYPE (display->display)) { switch (GST_VAAPI_DISPLAY_GET_CLASS_TYPE (display->display)) {
case GST_VAAPI_DISPLAY_TYPE_X11: case GST_VAAPI_DISPLAY_TYPE_X11:
@ -130,8 +140,12 @@ gst_vaapi_display_egl_bind_display (GstVaapiDisplay * base_display,
break; break;
} }
if (native_egl_display) {
egl_display = egl_display_new_wrapped (native_egl_display);
} else {
egl_display = egl_display_new (GST_VAAPI_DISPLAY_NATIVE (display->display), egl_display = egl_display_new (GST_VAAPI_DISPLAY_NATIVE (display->display),
gl_platform); gl_platform);
}
if (!egl_display) if (!egl_display)
return FALSE; return FALSE;
@ -385,13 +399,14 @@ GstVaapiDisplay *
gst_vaapi_display_egl_new_with_native_display (gpointer native_display, gst_vaapi_display_egl_new_with_native_display (gpointer native_display,
GstVaapiDisplayType display_type, guint gles_version) GstVaapiDisplayType display_type, guint gles_version)
{ {
InitParams params; InitParams params = { NULL, };
g_return_val_if_fail (native_display != NULL, NULL); g_return_val_if_fail (native_display != NULL, NULL);
params.display = native_display;
params.display_type = display_type; params.display_type = display_type;
params.gles_version = gles_version; params.gles_version = gles_version;
params.gl_display = native_display;
return gst_vaapi_display_new (g_object_new (GST_TYPE_VAAPI_DISPLAY_EGL, NULL), return gst_vaapi_display_new (g_object_new (GST_TYPE_VAAPI_DISPLAY_EGL, NULL),
GST_VAAPI_DISPLAY_INIT_FROM_NATIVE_DISPLAY, &params); GST_VAAPI_DISPLAY_INIT_FROM_NATIVE_DISPLAY, &params);
} }

View file

@ -41,6 +41,9 @@
#endif #endif
#if USE_GST_GL_HELPERS #if USE_GST_GL_HELPERS
# include <gst/gl/gl.h> # include <gst/gl/gl.h>
#if USE_EGL && GST_GL_HAVE_PLATFORM_EGL
# include <gst/gl/egl/gstgldisplay_egl.h>
#endif
#endif #endif
#include "gstvaapipluginutil.h" #include "gstvaapipluginutil.h"
#include "gstvaapipluginbase.h" #include "gstvaapipluginbase.h"
@ -140,7 +143,7 @@ gst_vaapi_create_display_from_gl_context (GstObject * gl_context_object)
gpointer native_display = gpointer native_display =
GSIZE_TO_POINTER (gst_gl_display_get_handle (gl_display)); GSIZE_TO_POINTER (gst_gl_display_get_handle (gl_display));
GstGLPlatform platform = gst_gl_context_get_gl_platform (gl_context); GstGLPlatform platform = gst_gl_context_get_gl_platform (gl_context);
GstVaapiDisplay *display, *out_display; GstVaapiDisplay *display, *out_display = NULL;
GstVaapiDisplayType display_type; GstVaapiDisplayType display_type;
switch (gst_gl_display_get_handle_type (gl_display)) { switch (gst_gl_display_get_handle_type (gl_display)) {
@ -195,16 +198,25 @@ gst_vaapi_create_display_from_gl_context (GstObject * gl_context_object)
display_type = GST_VAAPI_DISPLAY_TYPE_ANY; display_type = GST_VAAPI_DISPLAY_TYPE_ANY;
break; break;
} }
gst_object_unref (gl_display);
display = gst_vaapi_create_display_from_handle (display_type, native_display); display = gst_vaapi_create_display_from_handle (display_type, native_display);
if (!display) if (!display)
return NULL; goto bail;
switch (platform) { switch (platform) {
#if USE_EGL #if USE_EGL
case GST_GL_PLATFORM_EGL:{ case GST_GL_PLATFORM_EGL:{
guint gles_version; guint gles_version;
guintptr egl_handle = 0;
#if GST_GL_HAVE_PLATFORM_EGL
GstGLDisplayEGL *egl_display;
egl_display = gst_gl_display_egl_from_gl_display (gl_display);
if (egl_display) {
egl_handle = gst_gl_display_get_handle (GST_GL_DISPLAY (egl_display));
gst_object_unref (egl_display);
}
#endif
switch (gst_gl_context_get_gl_api (gl_context)) { switch (gst_gl_context_get_gl_api (gl_context)) {
case GST_GL_API_GLES1: case GST_GL_API_GLES1:
@ -217,16 +229,21 @@ gst_vaapi_create_display_from_gl_context (GstObject * gl_context_object)
case GST_GL_API_OPENGL3: case GST_GL_API_OPENGL3:
gles_version = 0; gles_version = 0;
create_egl_display: create_egl_display:
if (egl_handle != 0) {
out_display =
gst_vaapi_display_egl_new_with_native_display
(GSIZE_TO_POINTER (egl_handle), display_type, gles_version);
} else {
out_display = gst_vaapi_display_egl_new (display, gles_version); out_display = gst_vaapi_display_egl_new (display, gles_version);
}
break; break;
default: default:
out_display = NULL; out_display = NULL;
break; break;
} }
if (!out_display) { if (!out_display)
gst_vaapi_display_unref (display); goto bail;
return NULL;
}
gst_vaapi_display_egl_set_gl_context (GST_VAAPI_DISPLAY_EGL (out_display), gst_vaapi_display_egl_set_gl_context (GST_VAAPI_DISPLAY_EGL (out_display),
GSIZE_TO_POINTER (gst_gl_context_get_gl_context (gl_context))); GSIZE_TO_POINTER (gst_gl_context_get_gl_context (gl_context)));
break; break;
@ -236,7 +253,13 @@ gst_vaapi_create_display_from_gl_context (GstObject * gl_context_object)
out_display = gst_vaapi_display_ref (display); out_display = gst_vaapi_display_ref (display);
break; break;
} }
bail:
if (display)
gst_vaapi_display_unref (display); gst_vaapi_display_unref (display);
if (gl_display)
gst_object_unref (gl_display);
return out_display; return out_display;
#endif #endif
GST_ERROR ("unsupported GStreamer version %s", GST_API_VERSION_S); GST_ERROR ("unsupported GStreamer version %s", GST_API_VERSION_S);