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:
Julien Isorce 2014-04-15 17:11:08 +01:00
parent d4bb7cb4c7
commit 499fb23e9c

View file

@ -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)",