[FFmpeg-cvslog] r26233 - trunk/libavformat/rtspdec.c

mstorsjo subversion
Wed Jan 5 22:22:15 CET 2011


Author: mstorsjo
Date: Wed Jan  5 22:22:15 2011
New Revision: 26233

Log:
rtsp: Move resetting of rtpdec parameters to before sending the PLAY request

Modified:
   trunk/libavformat/rtspdec.c

Modified: trunk/libavformat/rtspdec.c
==============================================================================
--- trunk/libavformat/rtspdec.c	Wed Jan  5 21:35:36 2011	(r26232)
+++ trunk/libavformat/rtspdec.c	Wed Jan  5 22:22:15 2011	(r26233)
@@ -43,6 +43,19 @@ static int rtsp_read_play(AVFormatContex
     rt->nb_byes = 0;
 
     if (!(rt->server_type == RTSP_SERVER_REAL && rt->need_subscription)) {
+        if (rt->transport == RTSP_TRANSPORT_RTP) {
+            for (i = 0; i < rt->nb_rtsp_streams; i++) {
+                RTSPStream *rtsp_st = rt->rtsp_streams[i];
+                RTPDemuxContext *rtpctx = rtsp_st->transport_priv;
+                if (!rtpctx)
+                    continue;
+                ff_rtp_reset_packet_queue(rtpctx);
+                rtpctx->last_rtcp_ntp_time  = AV_NOPTS_VALUE;
+                rtpctx->first_rtcp_ntp_time = AV_NOPTS_VALUE;
+                rtpctx->base_timestamp      = 0;
+                rtpctx->rtcp_ts_offset      = 0;
+            }
+        }
         if (rt->state == RTSP_STATE_PAUSED) {
             cmd[0] = 0;
         } else {
@@ -63,12 +76,7 @@ static int rtsp_read_play(AVFormatContex
                     continue;
                 if (rtsp_st->stream_index >= 0)
                     st = s->streams[rtsp_st->stream_index];
-                ff_rtp_reset_packet_queue(rtpctx);
                 if (reply->range_start != AV_NOPTS_VALUE) {
-                    rtpctx->last_rtcp_ntp_time  = AV_NOPTS_VALUE;
-                    rtpctx->first_rtcp_ntp_time = AV_NOPTS_VALUE;
-                    rtpctx->base_timestamp      = 0;
-                    rtpctx->rtcp_ts_offset      = 0;
                     if (st)
                         rtpctx->range_start_offset =
                             av_rescale_q(reply->range_start, AV_TIME_BASE_Q,



More information about the ffmpeg-cvslog mailing list