From: Edward Hervey Date: Tue, 5 Jun 2018 15:24:55 +0000 (+0200) Subject: rtpbasedepayload: Properly propagate segment seqnum X-Git-Tag: 1.19.3~511^2~1647 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=924eb8d8a7a8f1521b6c376a06f94c42f65fd8cb;p=platform%2Fupstream%2Fgstreamer.git rtpbasedepayload: Properly propagate segment seqnum This wasn't done previously and the outgoing SEGMENT events had seqnums which weren't consistent with the upstream ones --- diff --git a/gst-libs/gst/rtp/gstrtpbasedepayload.c b/gst-libs/gst/rtp/gstrtpbasedepayload.c index 76228b142b..09a4f25945 100644 --- a/gst-libs/gst/rtp/gstrtpbasedepayload.c +++ b/gst-libs/gst/rtp/gstrtpbasedepayload.c @@ -56,6 +56,7 @@ struct _GstRTPBaseDepayloadPrivate GstCaps *last_caps; GstEvent *segment_event; + guint32 segment_seqnum; /* Note: this is a GstEvent seqnum */ }; /* Filter signals and args */ @@ -583,6 +584,7 @@ gst_rtp_base_depayload_handle_event (GstRTPBaseDepayload * filter, GST_ERROR_OBJECT (filter, "Segment with non-TIME format not supported"); res = FALSE; } + filter->priv->segment_seqnum = gst_event_get_seqnum (event); filter->segment = segment; GST_OBJECT_UNLOCK (filter); @@ -703,6 +705,8 @@ create_segment_event (GstRTPBaseDepayload * filter, guint rtptime, GST_DEBUG_OBJECT (filter, "Creating segment event %" GST_SEGMENT_FORMAT, &segment); event = gst_event_new_segment (&segment); + if (filter->priv->segment_seqnum != GST_SEQNUM_INVALID) + gst_event_set_seqnum (event, filter->priv->segment_seqnum); return event; } @@ -877,6 +881,7 @@ gst_rtp_base_depayload_change_state (GstElement * element, priv->next_seqnum = -1; priv->negotiated = FALSE; priv->discont = FALSE; + priv->segment_seqnum = GST_SEQNUM_INVALID; break; case GST_STATE_CHANGE_PAUSED_TO_PLAYING: break;