Ignore video streams with frame rates over 1000 (work-around/fix for #1585).
authorCarl Hetherington <cth@carlh.net>
Sun, 21 Jul 2019 23:34:10 +0000 (23:34 +0000)
committerCarl Hetherington <cth@carlh.net>
Sun, 21 Jul 2019 23:34:10 +0000 (23:34 +0000)
Backported from f4f6a2504e5fedb67513689eaeac9dd88ee38ca9 in 2.15.x.

src/lib/ffmpeg.cc

index 8a0dcb5930afaad11cff0706d9ab3df7c199b814..fb34379106c72b8c5ae15756812e86e56dcdc9b7 100644 (file)
@@ -159,6 +159,11 @@ FFmpeg::setup_general ()
                _video_stream = video_stream_undefined_frame_rate.get();
        }
 
                _video_stream = video_stream_undefined_frame_rate.get();
        }
 
+       /* Ignore video streams with crazy frame rates.  These are usually things like album art on MP3s. */
+       if (_video_stream && av_q2d(av_guess_frame_rate(_format_context, _format_context->streams[_video_stream.get()], 0)) > 1000) {
+               _video_stream = optional<int>();
+       }
+
        /* Hack: if the AVStreams have duplicate IDs, replace them with our
           own.  We use the IDs so that we can cope with VOBs, in which streams
           move about in index but remain with the same ID in different
        /* Hack: if the AVStreams have duplicate IDs, replace them with our
           own.  We use the IDs so that we can cope with VOBs, in which streams
           move about in index but remain with the same ID in different