aggregator: Only send events up to CAPS event from gst_aggregator_set_src_caps()

Otherwise setting the srcpad caps based on the sinkpad caps event will
already push a segment event downstream before the upstream segment is
known.

If the upstream segments are just forwarded when the upstream segment
event arrives this would result in two segment events being sent
downstream, of which the first one will usually be simply wrong.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/2381>
This commit is contained in:
Sebastian Dröge 2022-05-05 15:05:43 +03:00 committed by Tim-Philipp Müller
parent cae6b67822
commit 9eee0dcc73

View file

@ -598,7 +598,7 @@ gst_aggregator_reset_flow_values (GstAggregator * self)
}
static inline void
gst_aggregator_push_mandatory_events (GstAggregator * self)
gst_aggregator_push_mandatory_events (GstAggregator * self, gboolean up_to_caps)
{
GstAggregatorPrivate *priv = self->priv;
GstEvent *segment = NULL;
@ -618,7 +618,6 @@ gst_aggregator_push_mandatory_events (GstAggregator * self)
}
if (self->priv->srccaps) {
GST_INFO_OBJECT (self, "pushing caps: %" GST_PTR_FORMAT,
self->priv->srccaps);
if (!gst_pad_push_event (GST_PAD (self->srcpad),
@ -629,6 +628,9 @@ gst_aggregator_push_mandatory_events (GstAggregator * self)
self->priv->srccaps = NULL;
}
if (up_to_caps)
return;
GST_OBJECT_LOCK (self);
if (self->priv->send_segment && !self->priv->flushing) {
segment =
@ -655,7 +657,6 @@ gst_aggregator_push_mandatory_events (GstAggregator * self)
gst_pad_push_event (self->srcpad, segment);
if (tags)
gst_pad_push_event (self->srcpad, tags);
}
/**
@ -670,14 +671,14 @@ gst_aggregator_set_src_caps (GstAggregator * self, GstCaps * caps)
{
GST_PAD_STREAM_LOCK (self->srcpad);
gst_caps_replace (&self->priv->srccaps, caps);
gst_aggregator_push_mandatory_events (self);
gst_aggregator_push_mandatory_events (self, TRUE);
GST_PAD_STREAM_UNLOCK (self->srcpad);
}
static GstFlowReturn
gst_aggregator_default_finish_buffer (GstAggregator * self, GstBuffer * buffer)
{
gst_aggregator_push_mandatory_events (self);
gst_aggregator_push_mandatory_events (self, FALSE);
GST_OBJECT_LOCK (self);
if (!self->priv->flushing && gst_pad_is_active (self->srcpad)) {
@ -716,7 +717,7 @@ static GstFlowReturn
gst_aggregator_default_finish_buffer_list (GstAggregator * self,
GstBufferList * bufferlist)
{
gst_aggregator_push_mandatory_events (self);
gst_aggregator_push_mandatory_events (self, FALSE);
GST_OBJECT_LOCK (self);
if (!self->priv->flushing && gst_pad_is_active (self->srcpad)) {
@ -758,7 +759,7 @@ static void
gst_aggregator_push_eos (GstAggregator * self)
{
GstEvent *event;
gst_aggregator_push_mandatory_events (self);
gst_aggregator_push_mandatory_events (self, FALSE);
event = gst_event_new_eos ();