mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-12-11 19:06:33 +00:00
omxvideodec: use new libgstgl API since libgstegl has been removed
There is no point to retrieve a ref/unref type instead of an EGLDisplay directly. It's like for EGLImage. https://bugzilla.gnome.org/show_bug.cgi?id=703343
This commit is contained in:
parent
d4bb7cb4c7
commit
499fb23e9c
1 changed files with 6 additions and 12 deletions
|
@ -37,7 +37,8 @@
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined (USE_OMX_TARGET_RPI) && defined (HAVE_GST_GL)
|
#if defined (USE_OMX_TARGET_RPI) && defined (HAVE_GST_GL)
|
||||||
#include <gst/egl/egl.h>
|
#include <gst/gl/gl.h>
|
||||||
|
#include <gst/gl/egl/gsteglimagememory.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined (USE_OMX_TARGET_RPI) && defined(__GNUC__)
|
#if defined (USE_OMX_TARGET_RPI) && defined(__GNUC__)
|
||||||
|
@ -611,7 +612,7 @@ gst_omx_video_dec_allocate_output_buffers (GstOMXVideoDec * self)
|
||||||
GList *images = NULL;
|
GList *images = NULL;
|
||||||
gint i;
|
gint i;
|
||||||
GstBufferPoolAcquireParams params = { 0, };
|
GstBufferPoolAcquireParams params = { 0, };
|
||||||
GstEGLDisplay *display = NULL;
|
EGLDisplay egl_display = EGL_NO_DISPLAY;
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (self, "Trying to allocate %d EGLImages", min);
|
GST_DEBUG_OBJECT (self, "Trying to allocate %d EGLImages", min);
|
||||||
|
|
||||||
|
@ -629,9 +630,6 @@ gst_omx_video_dec_allocate_output_buffers (GstOMXVideoDec * self)
|
||||||
g_list_free (images);
|
g_list_free (images);
|
||||||
buffers = NULL;
|
buffers = NULL;
|
||||||
images = NULL;
|
images = NULL;
|
||||||
if (display)
|
|
||||||
gst_egl_display_unref (display);
|
|
||||||
display = NULL;
|
|
||||||
/* TODO: For non-RPi targets we want to use the normal memory code below */
|
/* TODO: For non-RPi targets we want to use the normal memory code below */
|
||||||
/* Retry without EGLImage */
|
/* Retry without EGLImage */
|
||||||
err = OMX_ErrorUndefined;
|
err = OMX_ErrorUndefined;
|
||||||
|
@ -642,8 +640,8 @@ gst_omx_video_dec_allocate_output_buffers (GstOMXVideoDec * self)
|
||||||
gst_egl_image_memory_set_orientation (mem,
|
gst_egl_image_memory_set_orientation (mem,
|
||||||
GST_VIDEO_GL_TEXTURE_ORIENTATION_X_NORMAL_Y_FLIP);
|
GST_VIDEO_GL_TEXTURE_ORIENTATION_X_NORMAL_Y_FLIP);
|
||||||
images = g_list_append (images, gst_egl_image_memory_get_image (mem));
|
images = g_list_append (images, gst_egl_image_memory_get_image (mem));
|
||||||
if (!display)
|
if (egl_display == EGL_NO_DISPLAY)
|
||||||
display = gst_egl_image_memory_get_display (mem);
|
egl_display = gst_egl_image_memory_get_display (mem);
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (self, "Allocated %d EGLImages successfully", min);
|
GST_DEBUG_OBJECT (self, "Allocated %d EGLImages successfully", min);
|
||||||
|
@ -651,14 +649,10 @@ gst_omx_video_dec_allocate_output_buffers (GstOMXVideoDec * self)
|
||||||
/* Everything went fine? */
|
/* Everything went fine? */
|
||||||
if (eglimage) {
|
if (eglimage) {
|
||||||
GST_DEBUG_OBJECT (self, "Setting EGLDisplay");
|
GST_DEBUG_OBJECT (self, "Setting EGLDisplay");
|
||||||
self->egl_out_port->port_def.format.video.pNativeWindow =
|
self->egl_out_port->port_def.format.video.pNativeWindow = egl_display;
|
||||||
gst_egl_display_get (display);
|
|
||||||
err =
|
err =
|
||||||
gst_omx_port_update_port_definition (self->egl_out_port,
|
gst_omx_port_update_port_definition (self->egl_out_port,
|
||||||
&self->egl_out_port->port_def);
|
&self->egl_out_port->port_def);
|
||||||
if (display)
|
|
||||||
gst_egl_display_unref (display);
|
|
||||||
display = NULL;
|
|
||||||
if (err != OMX_ErrorNone) {
|
if (err != OMX_ErrorNone) {
|
||||||
GST_INFO_OBJECT (self,
|
GST_INFO_OBJECT (self,
|
||||||
"Failed to set EGLDisplay on port: %s (0x%08x)",
|
"Failed to set EGLDisplay on port: %s (0x%08x)",
|
||||||
|
|
Loading…
Reference in a new issue