mirror of https://git.ffmpeg.org/ffmpeg.git
avformat/mpegts: detect synchronous metadata KLV more reliably
The mpegts code historically tries to strip (the first) metadata access unit
header from synchronous KLV metadata, but the detection for such streams was
unreliable causing strips of asynchronous metadata or ID3 as well.
MISB ST 1402 specifies required stream type, stream id and registration
descriptor (which eventually maps to the codec ID) so let's use all of these
for reliable detection.
Fixes a regression caused by 468615f204
.
Fixes ticket #10828, #10883.
Signed-off-by: Marton Balint <cus@passwd.hu>
This commit is contained in:
parent
c0a1ce1c40
commit
0aaee4741c
|
@ -1307,8 +1307,11 @@ skip:
|
||||||
p += sl_header_bytes;
|
p += sl_header_bytes;
|
||||||
buf_size -= sl_header_bytes;
|
buf_size -= sl_header_bytes;
|
||||||
}
|
}
|
||||||
if (pes->st->codecpar->codec_id == AV_CODEC_ID_SMPTE_KLV && buf_size >= 5) {
|
if (pes->stream_type == STREAM_TYPE_METADATA &&
|
||||||
/* skip metadata access unit header */
|
pes->stream_id == STREAM_ID_METADATA_STREAM &&
|
||||||
|
pes->st->codecpar->codec_id == AV_CODEC_ID_SMPTE_KLV &&
|
||||||
|
buf_size >= 5) {
|
||||||
|
/* skip metadata access unit header - see MISB ST 1402 */
|
||||||
pes->pes_header_size += 5;
|
pes->pes_header_size += 5;
|
||||||
p += 5;
|
p += 5;
|
||||||
buf_size -= 5;
|
buf_size -= 5;
|
||||||
|
|
Loading…
Reference in New Issue