diff options
author | Thibault Saunier <thibault.saunier@collabora.com> | 2013-04-28 20:07:47 +0200 |
---|---|---|
committer | Thibault Saunier <thibault.saunier@collabora.com> | 2013-05-02 12:29:48 +0100 |
commit | 372eddf00e9496a558472e197ec6880663092c14 (patch) | |
tree | 6644a60c26adcadc6610de53730c6bd43b7672a5 /gst/adder | |
parent | 04a70ea8355287189be3937368fde032329b288b (diff) |
adder: Get collectpad stream lock when fowarding flush events
Fixes #698410
Diffstat (limited to 'gst/adder')
-rw-r--r-- | gst/adder/gstadder.c | 24 |
1 files changed, 17 insertions, 7 deletions
diff --git a/gst/adder/gstadder.c b/gst/adder/gstadder.c index 2da4ef35b..bf5b11d70 100644 --- a/gst/adder/gstadder.c +++ b/gst/adder/gstadder.c @@ -728,7 +728,9 @@ gst_adder_src_event (GstPad * pad, GstObject * parent, GstEvent * event) * forwarding the seek upstream or from gst_adder_collected, * whichever happens first. */ - g_atomic_int_set (&adder->flush_stop_pending, TRUE); + GST_COLLECT_PADS_STREAM_LOCK (adder->collect); + adder->flush_stop_pending = TRUE; + GST_COLLECT_PADS_STREAM_UNLOCK (adder->collect); GST_DEBUG_OBJECT (adder, "mark pending flush stop event"); } GST_DEBUG_OBJECT (adder, "handling seek event: %" GST_PTR_FORMAT, event); @@ -819,20 +821,27 @@ gst_adder_sink_event (GstCollectPads * pads, GstCollectData * pad, } case GST_EVENT_FLUSH_START: /* ensure that we will send a flush stop */ - g_atomic_int_set (&adder->flush_stop_pending, TRUE); + GST_COLLECT_PADS_STREAM_LOCK (adder->collect); + adder->flush_stop_pending = TRUE; + res = gst_collect_pads_event_default (pads, pad, event, discard); + event = NULL; + GST_COLLECT_PADS_STREAM_UNLOCK (adder->collect); break; case GST_EVENT_FLUSH_STOP: /* we received a flush-stop. We will only forward it when * flush_stop_pending is set, and we will unset it then. */ - if (g_atomic_int_compare_and_exchange (&adder->flush_stop_pending, - TRUE, FALSE)) { - g_atomic_int_set (&adder->new_segment_pending, TRUE); + GST_COLLECT_PADS_STREAM_LOCK (adder->collect); + if (adder->flush_stop_pending) { GST_DEBUG_OBJECT (pad->pad, "forwarding flush stop"); + res = gst_collect_pads_event_default (pads, pad, event, discard); + adder->flush_stop_pending = FALSE; + event = NULL; } else { discard = TRUE; GST_DEBUG_OBJECT (pad->pad, "eating flush stop"); } + GST_COLLECT_PADS_STREAM_UNLOCK (adder->collect); /* Clear pending tags */ if (adder->pending_events) { g_list_foreach (adder->pending_events, (GFunc) gst_event_unref, NULL); @@ -1116,12 +1125,13 @@ gst_adder_collected (GstCollectPads * pads, gpointer user_data) if (G_UNLIKELY (adder->func == NULL)) goto not_negotiated; - if (g_atomic_int_compare_and_exchange (&adder->flush_stop_pending, - TRUE, FALSE)) { + if (adder->flush_stop_pending == TRUE) { GST_INFO_OBJECT (adder->srcpad, "send pending flush stop event"); if (!gst_pad_push_event (adder->srcpad, gst_event_new_flush_stop (TRUE))) { GST_WARNING_OBJECT (adder->srcpad, "Sending flush stop event failed"); } + + adder->flush_stop_pending = FALSE; } if (adder->send_stream_start) { |