[FFmpeg-devel] [PATCH V2 2/3] lavc/libkvazaar: Use avctx->frame_rate first for framerate setting
Jun Zhao
mypopydev at gmail.com
Sun Dec 16 05:08:21 EET 2018
perfer avctx->frame_rate first than use avctx->time_base when setting
the frame rate to encoder.
Signed-off-by: Jun Zhao <mypopydev at gmail.com>
---
libavcodec/libkvazaar.c | 22 ++++++++++++++++------
1 files changed, 16 insertions(+), 6 deletions(-)
diff --git a/libavcodec/libkvazaar.c b/libavcodec/libkvazaar.c
index 8f50bef..50910b7 100644
--- a/libavcodec/libkvazaar.c
+++ b/libavcodec/libkvazaar.c
@@ -79,13 +79,23 @@ static av_cold int libkvazaar_init(AVCodecContext *avctx)
cfg->width = avctx->width;
cfg->height = avctx->height;
- if (avctx->ticks_per_frame > INT_MAX / avctx->time_base.num) {
- av_log(avctx, AV_LOG_ERROR,
- "Could not set framerate for kvazaar: integer overflow\n");
- return AVERROR(EINVAL);
+ if (avctx->framerate.num > 0 && avctx->framerate.den > 0) {
+ if (avctx->ticks_per_frame > INT_MAX / avctx->framerate.den) {
+ av_log(avctx, AV_LOG_ERROR,
+ "Could not set framerate for kvazaar: integer overflow\n");
+ return AVERROR(EINVAL);
+ }
+ cfg->framerate_num = avctx->framerate.num;
+ cfg->framerate_denom = avctx->time_base.den * avctx->ticks_per_frame;
+ } else {
+ if (avctx->ticks_per_frame > INT_MAX / avctx->time_base.num) {
+ av_log(avctx, AV_LOG_ERROR,
+ "Could not set framerate for kvazaar: integer overflow\n");
+ return AVERROR(EINVAL);
+ }
+ cfg->framerate_num = avctx->time_base.den;
+ cfg->framerate_denom = avctx->time_base.num * avctx->ticks_per_frame;
}
- cfg->framerate_num = avctx->time_base.den;
- cfg->framerate_denom = avctx->time_base.num * avctx->ticks_per_frame;
cfg->target_bitrate = avctx->bit_rate;
cfg->vui.sar_width = avctx->sample_aspect_ratio.num;
cfg->vui.sar_height = avctx->sample_aspect_ratio.den;
--
1.7.1
More information about the ffmpeg-devel
mailing list