diff mbox series

[FFmpeg-devel,1/4] lavf/demux: use avg_frame_rate for packet durations for notimestamps formats

Message ID 20230502093755.9139-1-anton@khirnov.net
State Accepted
Commit e38e9f3d54f1bf7402748fba19edcaea19afd060
Headers show
Series [FFmpeg-devel,1/4] lavf/demux: use avg_frame_rate for packet durations for notimestamps formats | expand

Checks

Context Check Description
andriy/make_x86 success Make finished
andriy/make_fate_x86 success Make fate finished

Commit Message

Anton Khirnov May 2, 2023, 9:37 a.m. UTC
avg_frame_rate, if set, should be more reliable than stream timebase in
this case.
---
 libavformat/demux.c | 5 +++++
 1 file changed, 5 insertions(+)
diff mbox series

Patch

diff --git a/libavformat/demux.c b/libavformat/demux.c
index 06de71cd6e..45e5f5c4c2 100644
--- a/libavformat/demux.c
+++ b/libavformat/demux.c
@@ -668,6 +668,11 @@  static void compute_frame_duration(AVFormatContext *s, int *pnum, int *pden,
         if (st->r_frame_rate.num && (!pc || !codec_framerate.num)) {
             *pnum = st->r_frame_rate.den;
             *pden = st->r_frame_rate.num;
+        } else if ((s->iformat->flags & AVFMT_NOTIMESTAMPS) &&
+                   !codec_framerate.num &&
+                   st->avg_frame_rate.num && st->avg_frame_rate.den) {
+            *pnum = st->avg_frame_rate.den;
+            *pden = st->avg_frame_rate.num;
         } else if (st->time_base.num * 1000LL > st->time_base.den) {
             *pnum = st->time_base.num;
             *pden = st->time_base.den;