omxvideoenc: First set ports to flushing before waiting for the srcpad streaming...
authorSebastian Dröge <sebastian.droege@collabora.co.uk>
Fri, 18 Nov 2011 17:59:43 +0000 (09:59 -0800)
committerSebastian Dröge <sebastian.droege@collabora.co.uk>
Fri, 18 Nov 2011 17:59:43 +0000 (09:59 -0800)
omx/gstomxvideoenc.c

index 89ee30d..34ec8d9 100644 (file)
@@ -996,6 +996,11 @@ gst_omx_video_enc_stop (GstBaseVideoEncoder * encoder)
 
   self = GST_OMX_VIDEO_ENC (encoder);
 
+  GST_DEBUG_OBJECT (self, "Stopping encoder");
+
+  gst_omx_port_set_flushing (self->in_port, TRUE);
+  gst_omx_port_set_flushing (self->out_port, TRUE);
+
   gst_pad_stop_task (GST_BASE_VIDEO_CODEC_SRC_PAD (encoder));
 
   if (gst_omx_component_get_state (self->component, 0) > OMX_StateIdle)
@@ -1010,9 +1015,6 @@ gst_omx_video_enc_stop (GstBaseVideoEncoder * encoder)
   g_cond_broadcast (self->drain_cond);
   g_mutex_unlock (self->drain_lock);
 
-  gst_omx_port_set_flushing (self->in_port, TRUE);
-  gst_omx_port_set_flushing (self->out_port, TRUE);
-
   gst_omx_component_get_state (self->component, 5 * GST_SECOND);
 
   return TRUE;