mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-18 05:16:05 +00:00
ges-track: Set gnlobject state to NULL before disposing it
Work around a deadlock if setting state to NULL right before removing the gnlobject from the composition. https://bugzilla.gnome.org/show_bug.cgi?id=672751
This commit is contained in:
parent
9f6bbb8bab
commit
1dcb142307
1 changed files with 10 additions and 1 deletions
|
@ -302,7 +302,7 @@ ges_track_init (GESTrack * self)
|
||||||
*
|
*
|
||||||
* Creates a new #GESTrack with the given @type and @caps.
|
* Creates a new #GESTrack with the given @type and @caps.
|
||||||
*
|
*
|
||||||
* The newly created track will steal a reference to the caps. If you wish to
|
* The newly created track will steal a reference to the caps. If you wish to
|
||||||
* use those caps elsewhere, you will have to take an extra reference.
|
* use those caps elsewhere, you will have to take an extra reference.
|
||||||
*
|
*
|
||||||
* Returns: A new #GESTrack.
|
* Returns: A new #GESTrack.
|
||||||
|
@ -552,10 +552,19 @@ ges_track_remove_object (GESTrack * track, GESTrackObject * object)
|
||||||
if ((gnlobject = ges_track_object_get_gnlobject (object))) {
|
if ((gnlobject = ges_track_object_get_gnlobject (object))) {
|
||||||
GST_DEBUG ("Removing GnlObject '%s' from composition '%s'",
|
GST_DEBUG ("Removing GnlObject '%s' from composition '%s'",
|
||||||
GST_ELEMENT_NAME (gnlobject), GST_ELEMENT_NAME (priv->composition));
|
GST_ELEMENT_NAME (gnlobject), GST_ELEMENT_NAME (priv->composition));
|
||||||
|
/* We can't just set state of gnlobject to GST_STATE_NULL, because it will
|
||||||
|
* result in deadlock. Adding a ref to the gnlobj so we finalize it after
|
||||||
|
* removing it from the composition */
|
||||||
|
gst_object_ref (gnlobject);
|
||||||
if (!gst_bin_remove (GST_BIN (priv->composition), gnlobject)) {
|
if (!gst_bin_remove (GST_BIN (priv->composition), gnlobject)) {
|
||||||
GST_WARNING ("Failed to remove gnlobject from composition");
|
GST_WARNING ("Failed to remove gnlobject from composition");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gst_element_set_state (gnlobject, GST_STATE_NULL);
|
||||||
|
/* Wait for the state change to actually happen */
|
||||||
|
gst_element_get_state (gnlobject, NULL, NULL, GST_CLOCK_TIME_NONE);
|
||||||
|
gst_object_unref (gnlobject);
|
||||||
}
|
}
|
||||||
|
|
||||||
g_signal_handlers_disconnect_by_func (object, sort_track_objects_cb, NULL);
|
g_signal_handlers_disconnect_by_func (object, sort_track_objects_cb, NULL);
|
||||||
|
|
Loading…
Reference in a new issue