]> git.sesse.net Git - vlc/commitdiff
RTP: apply de-jitter from last dequeuing rather than last queuing
authorRémi Denis-Courmont <remi@remlab.net>
Mon, 7 Sep 2009 16:09:35 +0000 (19:09 +0300)
committerRémi Denis-Courmont <remi@remlab.net>
Mon, 7 Sep 2009 16:13:49 +0000 (19:13 +0300)
Previously, if the absolute delay dropped by a longer interval than the
packetization time, we could end up repeatedly waiting into the future,
and never dequeue anything.

modules/access/rtp/session.c

index 5b7dccb5461a5e7a04e0a5cbb393fd5e86a8faef..7d1fef5e199aed4e6fbbf37e0f6689e0c49a8c2e 100644 (file)
@@ -146,6 +146,7 @@ struct rtp_source_t
 
     uint16_t last_seq; /* sequence of the next dequeued packet */
     block_t *blocks; /* re-ordered blocks queue */
+    mtime_t  last_dq; /* last dequeued (decoded) packet local timestamp */
     void    *opaque[0]; /* Per-source private payload data */
 };
 
@@ -314,6 +315,7 @@ rtp_queue (demux_t *demux, rtp_session_t *session, block_t *block)
         }
     }
     src->last_rx = now;
+    block->i_pts = now;
     src->last_ts = rtp_timestamp (block);
 
     /* Check sequence number */
@@ -410,6 +412,7 @@ rtp_decode (demux_t *demux, const rtp_session_t *session, rtp_source_t *src)
     /* FIXME: handle timestamp wrap properly */
     /* TODO: inter-medias/sessions sync (using RTCP-SR) */
     const uint32_t timestamp = rtp_timestamp (block);
+    src->last_dq = block->i_pts;
     block->i_pts = CLOCK_FREQ * timestamp / pt->frequency;
 
     /* CSRC count */
@@ -489,7 +492,7 @@ bool rtp_dequeue (demux_t *demux, const rtp_session_t *session,
              * match for random gaussian jitter). Additionnaly, we implicitly
              * wait for misordering times the packetization time.
              */
-            mtime_t deadline = src->last_rx;
+            mtime_t deadline = src->last_dq;
             const rtp_pt_t *pt = rtp_find_ptype (session, src, block, NULL);
             if (pt)
                 deadline += CLOCK_FREQ * 3 * src->jitter / pt->frequency;