From: Michael Niedermayer Date: Thu, 12 Jul 2012 20:18:36 +0000 (+0200) Subject: lavc: adjust timestamp in case of skiping initial samples X-Git-Tag: android-x86-4.4-r1~10671 X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=aa32971d2bd760228da1f3a6872731afda8d4523;p=android-x86%2Fexternal-ffmpeg.git lavc: adjust timestamp in case of skiping initial samples Signed-off-by: Michael Niedermayer --- diff --git a/libavcodec/utils.c b/libavcodec/utils.c index 3ef52728ff..d6c1e0066d 100644 --- a/libavcodec/utils.c +++ b/libavcodec/utils.c @@ -1658,6 +1658,12 @@ int attribute_align_arg avcodec_decode_audio4(AVCodecContext *avctx, } else { av_samples_copy(frame->extended_data, frame->extended_data, 0, avctx->internal->skip_samples, frame->nb_samples - avctx->internal->skip_samples, avctx->channels, frame->format); + if(avctx->pkt_timebase.num && avctx->sample_rate) { + if(frame->pkt_pts!=AV_NOPTS_VALUE) + frame->pkt_pts += av_rescale_q(avctx->internal->skip_samples,(AVRational){1, avctx->sample_rate}, avctx->pkt_timebase); + if(frame->pkt_dts!=AV_NOPTS_VALUE) + frame->pkt_dts += av_rescale_q(avctx->internal->skip_samples,(AVRational){1, avctx->sample_rate}, avctx->pkt_timebase); + } frame->nb_samples -= avctx->internal->skip_samples; avctx->internal->skip_samples = 0; }