[FFmpeg-cvslog] lavf/webm_chunk: Correct duration if start time > 0
Andreas Rheinhardt
git at videolan.org
Fri Jul 12 16:19:35 EEST 2019
ffmpeg | branch: master | Andreas Rheinhardt <andreas.rheinhardt at gmail.com> | Sat Apr 20 00:03:16 2019 +0200| [24a64e0462d5dad6f6cf629243abdbe975e33015] | committer: Paul B Mahol
lavf/webm_chunk: Correct duration if start time > 0
Up until now, it was simply presumed that the first packet had a pts of
zero; otherwise the duration of the first chunk was wrong.
Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt at gmail.com>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=24a64e0462d5dad6f6cf629243abdbe975e33015
---
libavformat/webm_chunk.c | 10 ++++++----
1 file changed, 6 insertions(+), 4 deletions(-)
diff --git a/libavformat/webm_chunk.c b/libavformat/webm_chunk.c
index 8196f3d096..4e2ce21a79 100644
--- a/libavformat/webm_chunk.c
+++ b/libavformat/webm_chunk.c
@@ -52,7 +52,7 @@ typedef struct WebMChunkContext {
int chunk_index;
char *http_method;
uint64_t duration_written;
- int prev_pts;
+ int64_t prev_pts;
ff_const59 AVOutputFormat *oformat;
AVFormatContext *avf;
} WebMChunkContext;
@@ -129,6 +129,7 @@ static int webm_chunk_write_header(AVFormatContext *s)
wc->oformat = av_guess_format("webm", s->url, "video/webm");
if (!wc->oformat)
return AVERROR_MUXER_NOT_FOUND;
+ wc->prev_pts = AV_NOPTS_VALUE;
ret = chunk_mux_init(s);
if (ret < 0)
@@ -216,9 +217,10 @@ static int webm_chunk_write_packet(AVFormatContext *s, AVPacket *pkt)
int ret;
if (st->codecpar->codec_type == AVMEDIA_TYPE_AUDIO) {
- wc->duration_written += av_rescale_q(pkt->pts - wc->prev_pts,
- st->time_base,
- (AVRational) {1, 1000});
+ if (wc->prev_pts != AV_NOPTS_VALUE)
+ wc->duration_written += av_rescale_q(pkt->pts - wc->prev_pts,
+ st->time_base,
+ (AVRational) {1, 1000});
wc->prev_pts = pkt->pts;
}
More information about the ffmpeg-cvslog
mailing list