aboutsummaryrefslogtreecommitdiffstats
path: root/libavcodec
diff options
context:
space:
mode:
authorKyle Manning <tt2468@irltoolkit.com>2023-04-02 16:19:44 -0700
committerTimo Rothenpieler <timo@rothenpieler.org>2023-04-03 12:03:56 +0200
commita6dc92968a325d331bb6dcf9b3b2248026cd1d6c (patch)
tree676c3b449dcfad32ff6c91ea67e15d40aa791438 /libavcodec
parent3980415627a187d188dc25669cea6b12912eb178 (diff)
downloadffmpeg-a6dc92968a325d331bb6dcf9b3b2248026cd1d6c.tar.gz
avcodec/nvenc: fix b-frame DTS behavior with fractional framerates
When using fractional framerates (or any fraction with a numerator != 1), DTS values for packets would be calculated incorrectly. Signed-off-by: Kyle Manning <tt2468@irltoolkit.com> Signed-off-by: Timo Rothenpieler <timo@rothenpieler.org>
Diffstat (limited to 'libavcodec')
-rw-r--r--libavcodec/nvenc.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/libavcodec/nvenc.c b/libavcodec/nvenc.c
index 9acf3e8697..50a4fa6f69 100644
--- a/libavcodec/nvenc.c
+++ b/libavcodec/nvenc.c
@@ -2266,7 +2266,8 @@ static int nvenc_set_timestamp(AVCodecContext *avctx,
dts = reorder_queue_dequeue(ctx->reorder_queue, avctx, pkt);
if (avctx->codec_descriptor->props & AV_CODEC_PROP_REORDER) {
- pkt->dts = dts - FFMAX(ctx->encode_config.frameIntervalP - 1, 0) * FFMAX(avctx->ticks_per_frame, 1);
+ pkt->dts = dts -
+ FFMAX(ctx->encode_config.frameIntervalP - 1, 0) * FFMAX(avctx->ticks_per_frame, 1) * FFMAX(avctx->time_base.num, 1);
} else {
pkt->dts = pkt->pts;
}