mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-25 16:48:11 +00:00
rtp: a marker bit should translate to RESYNC
A marker bit on an audio packet does not mean a DISCONT (in the GStreamer sense of missing data) but it means that the packet is the end of a talkspurt and thus a good opportunity to resync to the clock. Use the RESYNC buffer flag to note this. Real discontinuities are marked with DISCONT still when the seqnum has a GAP or when the input buffer has the DISCONT flag set. Fixes https://bugzilla.gnome.org/show_bug.cgi?id=627204
This commit is contained in:
parent
7000e3303b
commit
eac9efb92e
12 changed files with 22 additions and 22 deletions
|
@ -231,8 +231,8 @@ gst_rtp_L16_depay_process (GstRTPBaseDepayload * depayload, GstBuffer * buf)
|
||||||
marker = gst_rtp_buffer_get_marker (&rtp);
|
marker = gst_rtp_buffer_get_marker (&rtp);
|
||||||
|
|
||||||
if (marker) {
|
if (marker) {
|
||||||
/* mark talk spurt with DISCONT */
|
/* mark talk spurt with RESYNC */
|
||||||
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_DISCONT);
|
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_RESYNC);
|
||||||
}
|
}
|
||||||
|
|
||||||
outbuf = gst_buffer_make_writable (outbuf);
|
outbuf = gst_buffer_make_writable (outbuf);
|
||||||
|
|
|
@ -405,9 +405,9 @@ gst_rtp_amr_depay_process (GstRTPBaseDepayload * depayload, GstBuffer * buf)
|
||||||
GST_BUFFER_DURATION (outbuf) = num_packets * 20 * GST_MSECOND;
|
GST_BUFFER_DURATION (outbuf) = num_packets * 20 * GST_MSECOND;
|
||||||
|
|
||||||
if (gst_rtp_buffer_get_marker (&rtp)) {
|
if (gst_rtp_buffer_get_marker (&rtp)) {
|
||||||
/* marker bit marks a discont buffer after a talkspurt. */
|
/* marker bit marks a buffer after a talkspurt. */
|
||||||
GST_DEBUG_OBJECT (depayload, "marker bit was set");
|
GST_DEBUG_OBJECT (depayload, "marker bit was set");
|
||||||
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_DISCONT);
|
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_RESYNC);
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (depayload, "pushing buffer of size %" G_GSIZE_FORMAT,
|
GST_DEBUG_OBJECT (depayload, "pushing buffer of size %" G_GSIZE_FORMAT,
|
||||||
|
|
|
@ -165,8 +165,8 @@ gst_rtp_bv_depay_process (GstRTPBaseDepayload * depayload, GstBuffer * buf)
|
||||||
gst_rtp_buffer_unmap (&rtp);
|
gst_rtp_buffer_unmap (&rtp);
|
||||||
|
|
||||||
if (marker && outbuf) {
|
if (marker && outbuf) {
|
||||||
/* mark start of talkspurt with DISCONT */
|
/* mark start of talkspurt with RESYNC */
|
||||||
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_DISCONT);
|
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_RESYNC);
|
||||||
}
|
}
|
||||||
|
|
||||||
return outbuf;
|
return outbuf;
|
||||||
|
|
|
@ -238,8 +238,8 @@ gst_rtp_g722_depay_process (GstRTPBaseDepayload * depayload, GstBuffer * buf)
|
||||||
gst_rtp_buffer_unmap (&rtp);
|
gst_rtp_buffer_unmap (&rtp);
|
||||||
|
|
||||||
if (marker && outbuf) {
|
if (marker && outbuf) {
|
||||||
/* mark talk spurt with DISCONT */
|
/* mark talk spurt with RESYNC */
|
||||||
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_DISCONT);
|
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_RESYNC);
|
||||||
}
|
}
|
||||||
|
|
||||||
return outbuf;
|
return outbuf;
|
||||||
|
|
|
@ -197,7 +197,7 @@ gst_rtp_g723_depay_process (GstRTPBaseDepayload * depayload, GstBuffer * buf)
|
||||||
|
|
||||||
if (marker) {
|
if (marker) {
|
||||||
/* marker bit starts talkspurt */
|
/* marker bit starts talkspurt */
|
||||||
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_DISCONT);
|
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_RESYNC);
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_LOG_OBJECT (depayload, "pushing buffer of size %" G_GSIZE_FORMAT,
|
GST_LOG_OBJECT (depayload, "pushing buffer of size %" G_GSIZE_FORMAT,
|
||||||
|
|
|
@ -329,8 +329,8 @@ gst_rtp_g726_depay_process (GstRTPBaseDepayload * depayload, GstBuffer * buf)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (marker) {
|
if (marker) {
|
||||||
/* mark start of talkspurt with discont */
|
/* mark start of talkspurt with RESYNC */
|
||||||
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_DISCONT);
|
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_RESYNC);
|
||||||
}
|
}
|
||||||
|
|
||||||
return outbuf;
|
return outbuf;
|
||||||
|
|
|
@ -202,7 +202,7 @@ gst_rtp_g729_depay_process (GstRTPBaseDepayload * depayload, GstBuffer * buf)
|
||||||
|
|
||||||
if (marker) {
|
if (marker) {
|
||||||
/* marker bit starts talkspurt */
|
/* marker bit starts talkspurt */
|
||||||
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_DISCONT);
|
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_RESYNC);
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_LOG_OBJECT (depayload, "pushing buffer of size %" G_GSIZE_FORMAT,
|
GST_LOG_OBJECT (depayload, "pushing buffer of size %" G_GSIZE_FORMAT,
|
||||||
|
|
|
@ -136,8 +136,8 @@ gst_rtp_gsm_depay_process (GstRTPBaseDepayload * _depayload, GstBuffer * buf)
|
||||||
gst_rtp_buffer_unmap (&rtp);
|
gst_rtp_buffer_unmap (&rtp);
|
||||||
|
|
||||||
if (marker && outbuf) {
|
if (marker && outbuf) {
|
||||||
/* mark start of talkspurt with DISCONT */
|
/* mark start of talkspurt with RESYNC */
|
||||||
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_DISCONT);
|
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_RESYNC);
|
||||||
}
|
}
|
||||||
|
|
||||||
return outbuf;
|
return outbuf;
|
||||||
|
|
|
@ -190,8 +190,8 @@ gst_rtp_ilbc_depay_process (GstRTPBaseDepayload * depayload, GstBuffer * buf)
|
||||||
gst_rtp_buffer_unmap (&rtp);
|
gst_rtp_buffer_unmap (&rtp);
|
||||||
|
|
||||||
if (marker && outbuf) {
|
if (marker && outbuf) {
|
||||||
/* mark start of talkspurt with DISCONT */
|
/* mark start of talkspurt with RESYNC */
|
||||||
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_DISCONT);
|
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_RESYNC);
|
||||||
}
|
}
|
||||||
|
|
||||||
return outbuf;
|
return outbuf;
|
||||||
|
|
|
@ -150,8 +150,8 @@ gst_rtp_mpa_depay_process (GstRTPBaseDepayload * depayload, GstBuffer * buf)
|
||||||
marker = gst_rtp_buffer_get_marker (&rtp);
|
marker = gst_rtp_buffer_get_marker (&rtp);
|
||||||
|
|
||||||
if (marker) {
|
if (marker) {
|
||||||
/* mark start of talkspurt with discont */
|
/* mark start of talkspurt with RESYNC */
|
||||||
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_DISCONT);
|
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_RESYNC);
|
||||||
}
|
}
|
||||||
GST_DEBUG_OBJECT (rtpmpadepay,
|
GST_DEBUG_OBJECT (rtpmpadepay,
|
||||||
"gst_rtp_mpa_depay_chain: pushing buffer of size %" G_GSIZE_FORMAT "",
|
"gst_rtp_mpa_depay_chain: pushing buffer of size %" G_GSIZE_FORMAT "",
|
||||||
|
|
|
@ -148,8 +148,8 @@ gst_rtp_pcma_depay_process (GstRTPBaseDepayload * depayload, GstBuffer * buf)
|
||||||
gst_util_uint64_scale_int (len, GST_SECOND, depayload->clock_rate);
|
gst_util_uint64_scale_int (len, GST_SECOND, depayload->clock_rate);
|
||||||
|
|
||||||
if (marker) {
|
if (marker) {
|
||||||
/* mark start of talkspurt with DISCONT */
|
/* mark start of talkspurt with RESYNC */
|
||||||
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_DISCONT);
|
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_RESYNC);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -149,8 +149,8 @@ gst_rtp_pcmu_depay_process (GstRTPBaseDepayload * depayload, GstBuffer * buf)
|
||||||
gst_util_uint64_scale_int (len, GST_SECOND, depayload->clock_rate);
|
gst_util_uint64_scale_int (len, GST_SECOND, depayload->clock_rate);
|
||||||
|
|
||||||
if (marker) {
|
if (marker) {
|
||||||
/* mark start of talkspurt with DISCONT */
|
/* mark start of talkspurt with RESYNC */
|
||||||
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_DISCONT);
|
GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_RESYNC);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue