From: agathah Date: Wed, 7 Jan 2015 09:19:32 +0000 (+0800) Subject: avcodec/nvenc: fix b frame settings X-Git-Tag: android-x86-6.0-r1~914 X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=72c61c272c527ff4744d2b69253bf3f70d6a20f2;p=android-x86%2Fexternal-ffmpeg.git avcodec/nvenc: fix b frame settings Reviewed-by: Timo Rothenpieler Signed-off-by: Michael Niedermayer --- diff --git a/libavcodec/nvenc.c b/libavcodec/nvenc.c index 345fb78087..5cd7727d10 100644 --- a/libavcodec/nvenc.c +++ b/libavcodec/nvenc.c @@ -657,7 +657,12 @@ static av_cold int nvenc_encode_init(AVCodecContext *avctx) } if (ctx->gobpattern >= 0) { - ctx->encode_config.frameIntervalP = 1; + ctx->encode_config.frameIntervalP = ctx->gobpattern; + } + + // when there're b frames, set dts offset + if (ctx->encode_config.frameIntervalP >= 2) { + ctx->last_dts = -2; } ctx->encode_config.encodeCodecConfig.h264Config.h264VUIParameters.colourDescriptionPresentFlag = 1; @@ -905,6 +910,10 @@ static int process_output_surface(AVCodecContext *avctx, AVPacket *pkt, AVFrame pkt->pts = lock_params.outputTimeStamp; pkt->dts = timestamp_queue_dequeue(&ctx->timestamp_list); + // when there're b frame(s), set dts offset + if (ctx->encode_config.frameIntervalP >= 2) + pkt->dts -= 1; + if (pkt->dts > pkt->pts) pkt->dts = pkt->pts;