mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-12-28 20:53:54 +02:00
eb325324aa
Matroska generally requires timestamps to be nonnegative, but there is an exception: Data that corresponds to encoder delay and is not supposed to be output anyway can have a negative timestamp. This is achieved by using the CodecDelay header field: The demuxer has to subtract this value from the raw (nonnegative) timestamps of the corresponding track. Therefore the muxer has to add this value first to write this raw timestamp. Support for writing CodecDelay has been added in FFmpeg commitd92b1b1bab
and in Libav commita1aa37dd0b
. The former simply wrote the header field and did not apply any timestamp offsets, leading to desynchronisation (if one uses multiple tracks). The latter applied it at two places, but not at the one where it actually matters, namely in mkv_write_block(), leading to the same desynchronisation as with the former commit. It furthermore used the wrong stream timebase to convert the delay to the stream's timebase, as the conversion used the timebase from before avpriv_set_pts_info(). When the latter was merged in82e4f39883
, it was only done in a deactivated state that still did not offset the timestamps when muxing due to "assertion failures and av sync errors".a1aa37dd0b
made it definitely more likely to run into assertion failures (namely if the relative block timestamp doesn't fit into an int16_t). Yet all of the above issues have been fixed (in commits962d631573
,5d3953a5dc
and4ebeab15b0
. This commit therefore enables applying CodecDelay, fixing ticket #7182. There is just one slight regression from this: If one has input with encoder delay where the first timestamp is negative, but the pts of the part of the data that is actually intended to be output is nonnegative, then the timestamps will currently by default be shifted to make them nonnegative before they reach the muxer; the muxer will then ensure that the shifted timestamps are retained. Before this commit, the muxer did not ensure this; instead the timestamps that the demuxer will output were shifted and if the first timestamp of the actually intended output was zero before shifting, then this unintentional shift just cancels the shift performed before the packet reached the muxer. (But notice that this only applies if all the tracks use the same CodecDelay, or the relative sync between tracks will be impaired.) This happens in the matroska-opus-remux and matroska-ogg-opus-remux FATE tests. Future commits will forward the information that the Matroska muxer has a limited capability to handle negative timestamps so that the shifting in libavformat can take advantage of it. Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@outlook.com>
93 lines
3.1 KiB
Plaintext
93 lines
3.1 KiB
Plaintext
47b6b69c2ffdf5729557e90c72d241e9 *tests/data/fate/matroska-ogg-opus-remux.matroska
|
|
10200 tests/data/fate/matroska-ogg-opus-remux.matroska
|
|
#extradata 0: 19, 0x399c0471
|
|
#tb 0: 1/1000
|
|
#media_type 0: audio
|
|
#codec_id 0: opus
|
|
#sample_rate 0: 48000
|
|
#channel_layout_name 0: stereo
|
|
0, 0, 0, 20, 402, 0x89b1c40f
|
|
0, 20, 20, 20, 216, 0x7bf97146
|
|
0, 40, 40, 20, 215, 0x6cb86d8b
|
|
0, 60, 60, 20, 218, 0x9cfd691c
|
|
0, 80, 80, 20, 218, 0xd7fe6a94
|
|
0, 100, 100, 20, 194, 0x35735de6
|
|
0, 120, 120, 20, 216, 0x3ee6705a
|
|
0, 140, 140, 20, 218, 0x67eb6cb1
|
|
0, 160, 160, 20, 218, 0x32d0700d
|
|
0, 180, 180, 20, 219, 0xcb7f6c60
|
|
0, 200, 200, 20, 218, 0x9c866b33
|
|
0, 220, 220, 20, 217, 0xfe3e6a53
|
|
0, 240, 240, 20, 218, 0x13586833
|
|
0, 260, 260, 20, 222, 0xbcb2669e
|
|
0, 280, 280, 20, 218, 0x8dfc6e33
|
|
0, 300, 300, 20, 217, 0xf5957051
|
|
0, 320, 320, 20, 210, 0xed126e6b
|
|
0, 340, 340, 20, 216, 0xbf947249
|
|
0, 360, 360, 20, 203, 0x6c7e680a
|
|
0, 380, 380, 20, 209, 0xf78f6af4
|
|
0, 400, 400, 20, 217, 0xd60c684d
|
|
0, 420, 420, 20, 218, 0x89056a7a
|
|
0, 440, 440, 20, 219, 0x0bc674ad
|
|
0, 460, 460, 20, 217, 0xb1d86d1a
|
|
0, 480, 480, 20, 220, 0x433d685a
|
|
0, 500, 500, 20, 364, 0x0c88be84
|
|
0, 520, 520, 20, 221, 0x804a733d
|
|
0, 540, 540, 20, 215, 0x6e9d6e9b
|
|
0, 560, 560, 20, 215, 0x63016a83
|
|
0, 580, 580, 20, 218, 0xf9a46fbe
|
|
0, 600, 600, 20, 216, 0xa0d66c08
|
|
0, 620, 620, 20, 216, 0xa2ca6d0a
|
|
0, 640, 640, 20, 216, 0xf50e6f1d
|
|
0, 660, 660, 20, 215, 0x6aaa70b6
|
|
0, 680, 680, 20, 219, 0x7ceb6ba0
|
|
0, 700, 700, 20, 220, 0x398d6ca9
|
|
0, 720, 720, 20, 218, 0x7bd06ed5
|
|
0, 740, 740, 20, 219, 0xe2906c62
|
|
0, 760, 760, 20, 217, 0xcf316ba1
|
|
0, 780, 780, 20, 217, 0x470b6eea
|
|
0, 800, 800, 20, 359, 0x36c2a18a, S=1, 10
|
|
[PACKET]
|
|
codec_type=audio
|
|
stream_index=0
|
|
pts=0
|
|
pts_time=0.000000
|
|
dts=0
|
|
dts_time=0.000000
|
|
duration=20
|
|
duration_time=0.020000
|
|
size=402
|
|
pos=540
|
|
flags=K_
|
|
[/PACKET]
|
|
[PACKET]
|
|
codec_type=audio
|
|
stream_index=0
|
|
pts=20
|
|
pts_time=0.020000
|
|
dts=20
|
|
dts_time=0.020000
|
|
duration=20
|
|
duration_time=0.020000
|
|
size=216
|
|
pos=949
|
|
flags=K_
|
|
[/PACKET]
|
|
[PACKET]
|
|
codec_type=audio
|
|
stream_index=0
|
|
pts=40
|
|
pts_time=0.040000
|
|
dts=40
|
|
dts_time=0.040000
|
|
duration=20
|
|
duration_time=0.020000
|
|
size=215
|
|
pos=1172
|
|
flags=K_
|
|
[/PACKET]
|
|
[STREAM]
|
|
codec_name=opus
|
|
initial_padding=356
|
|
[/STREAM]
|