mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-25 00:28:21 +00:00
gst/gstbin.c: Don't forget about the fact that some element went ASYNC even after a resync. This makes us post the AS...
Original commit message from CVS: * gst/gstbin.c: (gst_bin_change_state_func), (bin_handle_async_done), (gst_bin_handle_message_func): Don't forget about the fact that some element went ASYNC even after a resync. This makes us post the ASYNC_DONE message correctly. Fixes #462558.
This commit is contained in:
parent
0bc0a5a622
commit
d405a6dc4f
2 changed files with 27 additions and 5 deletions
|
@ -1,3 +1,11 @@
|
||||||
|
2007-08-02 Wim Taymans <wim.taymans@gmail.com>
|
||||||
|
|
||||||
|
* gst/gstbin.c: (gst_bin_change_state_func),
|
||||||
|
(bin_handle_async_done), (gst_bin_handle_message_func):
|
||||||
|
Don't forget about the fact that some element went ASYNC even after a
|
||||||
|
resync. This makes us post the ASYNC_DONE message correctly.
|
||||||
|
Fixes #462558.
|
||||||
|
|
||||||
2007-07-31 Jan Schmidt <thaytan@mad.scientist.com>
|
2007-07-31 Jan Schmidt <thaytan@mad.scientist.com>
|
||||||
|
|
||||||
* gst/gstregistry.c: (gst_registry_add_feature):
|
* gst/gstregistry.c: (gst_registry_add_feature):
|
||||||
|
|
24
gst/gstbin.c
24
gst/gstbin.c
|
@ -191,6 +191,10 @@ GST_ELEMENT_DETAILS ("Generic bin",
|
||||||
"Simple container object",
|
"Simple container object",
|
||||||
"Erik Walthinsen <omega@cse.ogi.edu>," "Wim Taymans <wim@fluendo.com>");
|
"Erik Walthinsen <omega@cse.ogi.edu>," "Wim Taymans <wim@fluendo.com>");
|
||||||
|
|
||||||
|
/* a bin is toplevel if it has no parent or when it is configured to behave like
|
||||||
|
* a toplevel bin */
|
||||||
|
#define BIN_IS_TOPLEVEL(bin) ((GST_OBJECT_PARENT (bin) == NULL) || bin->priv->asynchandling)
|
||||||
|
|
||||||
struct _GstBinPrivate
|
struct _GstBinPrivate
|
||||||
{
|
{
|
||||||
gboolean asynchandling;
|
gboolean asynchandling;
|
||||||
|
@ -2020,11 +2024,16 @@ gst_bin_change_state_func (GstElement * element, GstStateChange transition)
|
||||||
/* iterate in state change order */
|
/* iterate in state change order */
|
||||||
it = gst_bin_iterate_sorted (bin);
|
it = gst_bin_iterate_sorted (bin);
|
||||||
|
|
||||||
|
/* mark if we've seen an ASYNC element in the bin when we did a state change.
|
||||||
|
* Note how we don't reset this value when a resync happens, the reason being
|
||||||
|
* that the async element posted ASYNC_START and we want to post ASYNC_DONE
|
||||||
|
* even after a resync when the async element is gone */
|
||||||
|
have_async = FALSE;
|
||||||
|
|
||||||
restart:
|
restart:
|
||||||
/* take base_time */
|
/* take base_time */
|
||||||
base_time = gst_element_get_base_time (element);
|
base_time = gst_element_get_base_time (element);
|
||||||
|
|
||||||
have_async = FALSE;
|
|
||||||
have_no_preroll = FALSE;
|
have_no_preroll = FALSE;
|
||||||
|
|
||||||
done = FALSE;
|
done = FALSE;
|
||||||
|
@ -2105,10 +2114,13 @@ done:
|
||||||
GST_OBJECT_LOCK (bin);
|
GST_OBJECT_LOCK (bin);
|
||||||
bin->polling = FALSE;
|
bin->polling = FALSE;
|
||||||
if (ret != GST_STATE_CHANGE_ASYNC) {
|
if (ret != GST_STATE_CHANGE_ASYNC) {
|
||||||
|
/* no element returned ASYNC, we can just complete. */
|
||||||
GST_DEBUG_OBJECT (bin, "no async elements");
|
GST_DEBUG_OBJECT (bin, "no async elements");
|
||||||
goto state_end;
|
goto state_end;
|
||||||
}
|
}
|
||||||
|
/* when we get here an ASYNC element was found */
|
||||||
if (GST_STATE_TARGET (bin) <= GST_STATE_READY) {
|
if (GST_STATE_TARGET (bin) <= GST_STATE_READY) {
|
||||||
|
/* we ignore ASYNC state changes when we go to READY or NULL */
|
||||||
GST_DEBUG_OBJECT (bin, "target state %s <= READY",
|
GST_DEBUG_OBJECT (bin, "target state %s <= READY",
|
||||||
gst_element_state_get_name (GST_STATE_TARGET (bin)));
|
gst_element_state_get_name (GST_STATE_TARGET (bin)));
|
||||||
goto state_end;
|
goto state_end;
|
||||||
|
@ -2117,7 +2129,10 @@ done:
|
||||||
GST_DEBUG_OBJECT (bin, "check async elements");
|
GST_DEBUG_OBJECT (bin, "check async elements");
|
||||||
/* check if all elements managed to commit their state already */
|
/* check if all elements managed to commit their state already */
|
||||||
if (!find_message (bin, NULL, GST_MESSAGE_ASYNC_START)) {
|
if (!find_message (bin, NULL, GST_MESSAGE_ASYNC_START)) {
|
||||||
/* nothing found, remove all old ASYNC_DONE messages */
|
/* nothing found, remove all old ASYNC_DONE messages. This can happen when
|
||||||
|
* all the elements commited their state while we were doing the state
|
||||||
|
* change. We will still return ASYNC for consistency but we commit the
|
||||||
|
* state already so that a _get_state() will return immediatly. */
|
||||||
bin_remove_messages (bin, NULL, GST_MESSAGE_ASYNC_DONE);
|
bin_remove_messages (bin, NULL, GST_MESSAGE_ASYNC_DONE);
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (bin, "async elements commited");
|
GST_DEBUG_OBJECT (bin, "async elements commited");
|
||||||
|
@ -2395,7 +2410,7 @@ bin_handle_async_done (GstBin * bin, GstStateChangeReturn ret)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* get our toplevel state */
|
/* get our toplevel state */
|
||||||
toplevel = ((GST_OBJECT_PARENT (bin) == NULL) || bin->priv->asynchandling);
|
toplevel = BIN_IS_TOPLEVEL (bin);
|
||||||
|
|
||||||
/* see if we reached the final state. If we are not toplevel, we also have to
|
/* see if we reached the final state. If we are not toplevel, we also have to
|
||||||
* stop here, the parent will continue our state. */
|
* stop here, the parent will continue our state. */
|
||||||
|
@ -2687,8 +2702,7 @@ gst_bin_handle_message_func (GstBin * bin, GstMessage * message)
|
||||||
bin_handle_async_start (bin);
|
bin_handle_async_start (bin);
|
||||||
|
|
||||||
/* get our toplevel state */
|
/* get our toplevel state */
|
||||||
toplevel = ((GST_OBJECT_PARENT (bin) == NULL)
|
toplevel = BIN_IS_TOPLEVEL (bin);
|
||||||
|| bin->priv->asynchandling);
|
|
||||||
|
|
||||||
/* prepare an ASYNC_START message */
|
/* prepare an ASYNC_START message */
|
||||||
if (!toplevel) {
|
if (!toplevel) {
|
||||||
|
|
Loading…
Reference in a new issue