omx: Only disabling of a port is like flushing, enabling is like unflushing

This commit is contained in:
Sebastian Dröge 2011-11-17 14:38:54 -08:00
parent c144ebd054
commit 47d66cadfa

View file

@ -1494,10 +1494,12 @@ gst_omx_port_set_enabled_unlocked (GstOMXPort * port, gboolean enabled)
port->enabled_changed = FALSE; port->enabled_changed = FALSE;
/* This is also like flushing, i.e. all buffers are returned if (!enabled) {
* by the component and no new buffers should be passed to /* This is also like flushing, i.e. all buffers are returned
* the component anymore */ * by the component and no new buffers should be passed to
port->flushing = TRUE; * the component anymore */
port->flushing = TRUE;
}
g_mutex_unlock (port->port_lock); g_mutex_unlock (port->port_lock);
if (enabled) if (enabled)
@ -1584,8 +1586,6 @@ gst_omx_port_set_enabled_unlocked (GstOMXPort * port, gboolean enabled)
&port->port_def); &port->port_def);
} }
port->flushing = FALSE;
if (!signalled) { if (!signalled) {
GST_ERROR_OBJECT (comp->parent, GST_ERROR_OBJECT (comp->parent,
"Timeout waiting for port %u to be %s", port->index, "Timeout waiting for port %u to be %s", port->index,
@ -1599,6 +1599,9 @@ gst_omx_port_set_enabled_unlocked (GstOMXPort * port, gboolean enabled)
gst_omx_error_to_string (err), err); gst_omx_error_to_string (err), err);
err = last_error; err = last_error;
} else { } else {
if (enabled)
port->flushing = FALSE;
/* If everything went fine and we have an output port we /* If everything went fine and we have an output port we
* should provide all newly allocated buffers to the port * should provide all newly allocated buffers to the port
*/ */
@ -1638,7 +1641,6 @@ error:
* set_last_error() needs all port locks. * set_last_error() needs all port locks.
* This is safe here because we're just going * This is safe here because we're just going
* to error out anyway */ * to error out anyway */
port->flushing = FALSE;
g_mutex_unlock (port->port_lock); g_mutex_unlock (port->port_lock);
gst_omx_component_set_last_error (comp, err); gst_omx_component_set_last_error (comp, err);
g_mutex_lock (port->port_lock); g_mutex_lock (port->port_lock);