Brad Bishop | 6e60e8b | 2018-02-01 10:27:11 -0500 | [diff] [blame] | 1 | From 80dddfd13aaf2fe7272765f8cf291215fe375e28 Mon Sep 17 00:00:00 2001 |
| 2 | From: =?UTF-8?q?Enrique=20Oca=C3=B1a=20Gonz=C3=A1lez?= <eocanha@igalia.com> |
| 3 | Date: Tue, 17 Nov 2015 16:51:27 +0000 |
| 4 | Subject: [PATCH] Properly handle drain requests while flushing |
| 5 | |
| 6 | Without this commit the decoder streaming thread stops without ever attending |
| 7 | the drain request, leaving the decoder input thread waiting forever. |
| 8 | --- |
| 9 | omx/gstomx.c | 7 +++++++ |
| 10 | omx/gstomxvideodec.c | 13 +++++++++++++ |
| 11 | 2 files changed, 20 insertions(+) |
| 12 | |
| 13 | Index: gst-omx-1.10.2/omx/gstomx.c |
| 14 | =================================================================== |
| 15 | --- gst-omx-1.10.2.orig/omx/gstomx.c |
| 16 | +++ gst-omx-1.10.2/omx/gstomx.c |
| 17 | @@ -737,6 +737,13 @@ gst_omx_component_new (GstObject * paren |
| 18 | |
| 19 | g_mutex_lock (&comp->lock); |
| 20 | gst_omx_component_handle_messages (comp); |
| 21 | + |
| 22 | + if (err != OMX_ErrorNone && comp->last_error == OMX_ErrorNone) { |
| 23 | + GST_ERROR_OBJECT (comp->parent, |
| 24 | + "Last operation returned an error. Setting last_error manually."); |
| 25 | + comp->last_error = err; |
| 26 | + } |
| 27 | + |
| 28 | g_mutex_unlock (&comp->lock); |
| 29 | |
| 30 | return comp; |