0004-Properly-handle-drain-requests-while-flushing.patch 1.0 KB

1234567891011121314151617181920212223242526272829303132
  1. From 140bf8548843a98b0af2ddc1765ab59c16c8994c 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. Without this commit the decoder streaming thread stops without ever attending
  6. the drain request, leaving the decoder input thread waiting forever.
  7. ---
  8. Upstream-Status: Pending
  9. omx/gstomx.c | 7 +++++++
  10. 1 file changed, 7 insertions(+)
  11. diff --git a/omx/gstomx.c b/omx/gstomx.c
  12. index 038ce32..5202d33 100644
  13. --- a/omx/gstomx.c
  14. +++ b/omx/gstomx.c
  15. @@ -1011,6 +1011,13 @@ gst_omx_component_new (GstObject * parent, const gchar * core_name,
  16. g_mutex_lock (&comp->lock);
  17. gst_omx_component_handle_messages (comp);
  18. +
  19. + if (err != OMX_ErrorNone && comp->last_error == OMX_ErrorNone) {
  20. + GST_ERROR_OBJECT (comp->parent,
  21. + "Last operation returned an error. Setting last_error manually.");
  22. + comp->last_error = err;
  23. + }
  24. +
  25. g_mutex_unlock (&comp->lock);
  26. return comp;