diff options
author | Devin Heitmueller <devin.heitmueller@ltnglobal.com> | 2023-03-03 16:08:13 -0500 |
---|---|---|
committer | Marton Balint <cus@passwd.hu> | 2023-03-08 23:53:15 +0100 |
commit | 8fd345f0180c655d18071d0445d797f27bb1efe7 (patch) | |
tree | e8531069e7ded2c0d314cbc450ecb4737365a0a3 /libavdevice/utils.c | |
parent | 6f1c00695973b48d5cb7ed574577634634f8a084 (diff) | |
download | ffmpeg-8fd345f0180c655d18071d0445d797f27bb1efe7.tar.gz |
avdevice/decklink_enc: don't take for granted that first frame to decklink output will be PTS 0
The existing code assumed that the first frame received by the decklink
output would always be PTS zero. However if running in other timing
modes than the default of CBR, items such as frame dropping at the
beginning may result in starting at a non-zero PTS.
For example, in our setup because we discard probing data and run
with "-vsync 2" the first video frame scheduled to the decklink
output will have a PTS around 170. Scheduling frames too far into
the future will either fail or cause a backlog of frames scheduled
far enough into the future that the entire pipeline will stall.
Issue can be reproduced with the following command-line:
./ffmpeg -copyts -i foo.ts -f decklink -vcodec v210 -ac 2 'DeckLink Duo (4)'
Keep track of the PTS of the first frame received, so that when
we enable start playback we can provide that value to the decklink
driver.
Thanks to Marton Balint for review and suggestion to use
AV_NOPTS_VALUE rather than zero for the initial value.
Signed-off-by: Devin Heitmueller <dheitmueller@ltnglobal.com>
Signed-off-by: Marton Balint <cus@passwd.hu>
Diffstat (limited to 'libavdevice/utils.c')
0 files changed, 0 insertions, 0 deletions