From: Wim Taymans Date: Fri, 5 Oct 2012 07:42:59 +0000 (+0200) Subject: pad: resend dropped events X-Git-Tag: 1.0.1~6 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=d630a115f9a35ea36bf7654164abb2f89ca6f4f7;p=platform%2Fupstream%2Fgstreamer.git pad: resend dropped events If we try to push sticky events but a probe dropped them, we don't mark the event as received and mark the pad as PENDING_EVENTS. This ensures that we resend the event the next time. For this we need to let the custom flow return from the probe trickle up to gst_pad_push_event_unchecked() so that we can differentiate between OK and DROPPED probe returns. --- diff --git a/gst/gstpad.c b/gst/gstpad.c index 82d43d1..92891fa 100644 --- a/gst/gstpad.c +++ b/gst/gstpad.c @@ -3291,15 +3291,24 @@ push_sticky (GstPad * pad, PadEvent * ev, gpointer user_data) GST_DEBUG_OBJECT (pad, "event %s marked received", GST_EVENT_TYPE_NAME (event)); break; + case GST_FLOW_CUSTOM_SUCCESS: + /* we can't assume the event is received when it was dropped */ + GST_DEBUG_OBJECT (pad, "event %s was dropped, mark pending", + GST_EVENT_TYPE_NAME (event)); + GST_OBJECT_FLAG_SET (pad, GST_PAD_FLAG_PENDING_EVENTS); + data->ret = GST_FLOW_OK; + break; case GST_FLOW_NOT_LINKED: /* not linked is not a problem, we are sticky so the event will be * sent later but only for non-EOS events */ - GST_DEBUG_OBJECT (pad, "pad was not linked"); + GST_DEBUG_OBJECT (pad, "pad was not linked, mark pending"); if (GST_EVENT_TYPE (event) != GST_EVENT_EOS) data->ret = GST_FLOW_OK; - /* fallthrough */ + GST_OBJECT_FLAG_SET (pad, GST_PAD_FLAG_PENDING_EVENTS); + break; default: - GST_DEBUG_OBJECT (pad, "mark pending events"); + GST_DEBUG_OBJECT (pad, "result %s, mark pending events", + gst_flow_get_name (data->ret)); GST_OBJECT_FLAG_SET (pad, GST_PAD_FLAG_PENDING_EVENTS); break; } @@ -3336,6 +3345,10 @@ check_sticky (GstPad * pad) if (ev && !ev->received) { data.ret = gst_pad_push_event_unchecked (pad, gst_event_ref (ev->event), GST_PAD_PROBE_TYPE_EVENT_DOWNSTREAM); + /* the event could have been dropped. Because this can only + * happen if the user asked for it, it's not an error */ + if (data.ret == GST_FLOW_CUSTOM_SUCCESS) + data.ret = GST_FLOW_OK; } } } @@ -4531,7 +4544,6 @@ probe_stopped: switch (ret) { case GST_FLOW_CUSTOM_SUCCESS: GST_DEBUG_OBJECT (pad, "dropped event"); - ret = GST_FLOW_OK; break; default: GST_DEBUG_OBJECT (pad, "an error occured %s", gst_flow_get_name (ret)); @@ -4623,8 +4635,12 @@ gst_pad_push_event (GstPad * pad, GstEvent * event) res = (check_sticky (pad) == GST_FLOW_OK); } if (!sticky) { + GstFlowReturn ret; + /* other events are pushed right away */ - res = (gst_pad_push_event_unchecked (pad, event, type) == GST_FLOW_OK); + ret = gst_pad_push_event_unchecked (pad, event, type); + /* dropped events by a probe are not an error */ + res = (ret == GST_FLOW_OK || ret == GST_FLOW_CUSTOM_SUCCESS); } else { /* Errors in sticky event pushing are no problem and ignored here * as they will cause more meaningful errors during data flow.