mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-13 21:28:01 +02:00
matroskaenc: factor ts_offset into block timecode computation
ts_offset was added to cluster timecode, but then effectively subtracted back off the block timecode When setting initial_padding for an audio stream, the timestamps are written incorrectly to the mkv file. cluster timecode gets written as pts0 + ts_offset which is correct, but then block timecode gets written as pts - cluster timecode which expanded is pts - (pts0 + ts_offset). Adding cluster and block tc back together: cluster + block = (pts0 + ts_offset) + (pts - (pts0 + ts_offset)) = pts But the result should be pts + ts_offset since demux will subtract the CodecDelay element from pts and set initial_padding to CodecDelay. This patch gives the correct result.
This commit is contained in:
parent
c95169f0ec
commit
5d3953a5dc
@ -1461,6 +1461,7 @@ static void mkv_write_block(AVFormatContext *s, AVIOContext *pb,
|
|||||||
uint8_t *data = NULL;
|
uint8_t *data = NULL;
|
||||||
int offset = 0, size = pkt->size;
|
int offset = 0, size = pkt->size;
|
||||||
int64_t ts = mkv->tracks[pkt->stream_index].write_dts ? pkt->dts : pkt->pts;
|
int64_t ts = mkv->tracks[pkt->stream_index].write_dts ? pkt->dts : pkt->pts;
|
||||||
|
ts += mkv->tracks[pkt->stream_index].ts_offset;
|
||||||
|
|
||||||
av_log(s, AV_LOG_DEBUG, "Writing block at offset %" PRIu64 ", size %d, "
|
av_log(s, AV_LOG_DEBUG, "Writing block at offset %" PRIu64 ", size %d, "
|
||||||
"pts %" PRId64 ", dts %" PRId64 ", duration %" PRId64 ", flags %d\n",
|
"pts %" PRId64 ", dts %" PRId64 ", duration %" PRId64 ", flags %d\n",
|
||||||
|
Loading…
Reference in New Issue
Block a user