diff options
author | wm4 <wm4@nowhere> | 2013-11-27 20:54:56 +0100 |
---|---|---|
committer | wm4 <wm4@nowhere> | 2013-11-27 21:14:39 +0100 |
commit | f5219720f8917145cb2e0d9258b3233de1a6fb19 (patch) | |
tree | 418d0b147b51844c7982d58134ac9bceb751f1c8 /video/out/vo_null.c | |
parent | 1e96f5bcd98f41fa11d87f1a5236468f985327a9 (diff) | |
download | mpv-f5219720f8917145cb2e0d9258b3233de1a6fb19.tar.bz2 mpv-f5219720f8917145cb2e0d9258b3233de1a6fb19.tar.xz |
video: refactor PTS code, add fall back heuristic to DTS
Refactor the PTS handling code to make it cleaner, and to separate the
bits that use PTS sorting.
Add a heuristic to fall back to DTS if the PTS us non-monotonic. This
code is based on what FFmpeg/Libav use for ffplay/avplay and also
best_effort_timestamp (which is only in FFmpeg). Basically, this 1. just
uses the DTS if PTS is unset, and 2. ignores PTS entirely if PTS is non-
monotonic, but DTS is sorted.
The code is pretty much the same as in Libav [1]. I'm not sure if all of
it is really needed, or if it does more than what the paragraph above
mentions. But maybe it's fine to cargo-cult this.
This heuristic fixes playback of mpeg4 in ogm, which returns packets
with PTS==DTS, even though the PTS timestamps should follow codec
reordering. This is probably a libavformat demuxer bug, but good luck
trying to fix it.
The way vd_lavc.c returns the frame PTS and DTS to dec_video.c is a bit
inelegant, but maybe better than trying to mess the PTS back into the
decoder callback again.
[1] https://git.libav.org/?p=libav.git;a=blob;f=cmdutils.c;h=3f1c667075724c5cde69d840ed5ed7d992898334;hb=fa515c2088e1d082d45741bbd5c05e13b0500804#l1431
Diffstat (limited to 'video/out/vo_null.c')
0 files changed, 0 insertions, 0 deletions