summaryrefslogtreecommitdiffstats
path: root/gst/qtdemux/gstrtpxqtdepay.c
diff options
context:
space:
mode:
authorWim Taymans <wim.taymans@gmail.com>2007-04-05 15:05:24 +0000
committerWim Taymans <wim.taymans@gmail.com>2007-04-05 15:05:24 +0000
commit86b40a1c70dddd25487fc0153dcc29af55a22799 (patch)
tree1e16f1355bdc5bb82b2b5f318bdb9ab3f836539e /gst/qtdemux/gstrtpxqtdepay.c
parentf70206175fb43c6640ca439ec138a9c6de6735fe (diff)
gst/qtdemux/gstrtpxqtdepay.*: Try to recover from packet loss a little better.
Original commit message from CVS: * gst/qtdemux/gstrtpxqtdepay.c: (gst_rtp_xqt_depay_process), (gst_rtp_xqt_depay_change_state): * gst/qtdemux/gstrtpxqtdepay.h: Try to recover from packet loss a little better.
Diffstat (limited to 'gst/qtdemux/gstrtpxqtdepay.c')
-rw-r--r--gst/qtdemux/gstrtpxqtdepay.c25
1 files changed, 24 insertions, 1 deletions
diff --git a/gst/qtdemux/gstrtpxqtdepay.c b/gst/qtdemux/gstrtpxqtdepay.c
index 30e4ce3b..0a147ef4 100644
--- a/gst/qtdemux/gstrtpxqtdepay.c
+++ b/gst/qtdemux/gstrtpxqtdepay.c
@@ -278,9 +278,10 @@ gst_rtp_xqt_depay_process (GstBaseRTPDepayload * depayload, GstBuffer * buf)
if (!gst_rtp_buffer_validate (buf))
goto bad_packet;
- /* discont, clear adapter */
if (GST_BUFFER_IS_DISCONT (buf)) {
+ /* discont, clear adapter and try to find a new packet start */
gst_adapter_clear (rtpxqtdepay->adapter);
+ rtpxqtdepay->need_resync = TRUE;
}
m = gst_rtp_buffer_get_marker (buf);
@@ -325,6 +326,22 @@ gst_rtp_xqt_depay_process (GstBaseRTPDepayload * depayload, GstBuffer * buf)
"VER: %d, PCK: %d, S: %d, Q: %d, L: %d, D: %d, ID: %d", ver, pck, s, q,
l, d, rtpxqtdepay->current_id);
+ if (rtpxqtdepay->need_resync) {
+ /* we need to find the boundary of a new packet after a DISCONT */
+ if (pck != 3 || q) {
+ /* non-fragmented packet or payload description present, packet starts
+ * here. */
+ rtpxqtdepay->need_resync = FALSE;
+ } else {
+ /* fragmented packet without description */
+ if (m) {
+ /* marker bit set, next packet is start of new one */
+ rtpxqtdepay->need_resync = FALSE;
+ }
+ goto need_resync;
+ }
+ }
+
payload += 4;
payload_len -= 4;
@@ -625,6 +642,11 @@ bad_packet:
("Packet did not validate."), (NULL));
return NULL;
}
+need_resync:
+ {
+ GST_DEBUG_OBJECT (rtpxqtdepay, "waiting for marker");
+ return NULL;
+ }
wrong_version:
{
GST_ELEMENT_WARNING (rtpxqtdepay, STREAM, DECODE,
@@ -688,6 +710,7 @@ gst_rtp_xqt_depay_change_state (GstElement * element, GstStateChange transition)
gst_adapter_clear (rtpxqtdepay->adapter);
rtpxqtdepay->previous_id = -1;
rtpxqtdepay->current_id = -1;
+ rtpxqtdepay->need_resync = FALSE;
break;
default:
break;