mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-03 14:08:56 +00:00
isomp4: Fix (E)AC-3 channel count handling
The muxer used a fixed value of 2 channels because the TR 102 366 spec says they're to be ignored. However, the demuxer still trusted them, resulting in bad caps. Make the muxer fill in the correct channel count anyway (FFmpeg already does) and make the demuxer ignore the value. Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/4739>
This commit is contained in:
parent
7fd1145419
commit
93699123b4
2 changed files with 13 additions and 3 deletions
|
@ -6087,9 +6087,9 @@ gst_qt_mux_audio_sink_set_caps (GstQTMuxPad * qtpad, GstCaps * caps)
|
|||
} else if (strcmp (mimetype, "audio/x-ac3") == 0) {
|
||||
entry.fourcc = FOURCC_ac_3;
|
||||
|
||||
/* Fixed values according to TS 102 366 but it also mentions that
|
||||
* they should be ignored */
|
||||
entry.channels = 2;
|
||||
/* TS 102 366 mentions that these fields should be ignored,
|
||||
* but be friendly and fill in the channel count like FFmpeg does */
|
||||
entry.channels = channels;
|
||||
entry.sample_size = 16;
|
||||
|
||||
/* AC-3 needs an extension atom but its data can only be obtained from
|
||||
|
|
|
@ -13205,6 +13205,16 @@ qtdemux_parse_trak (GstQTDemux * qtdemux, GNode * trak)
|
|||
entry->bytes_per_packet = entry->bytes_per_sample;
|
||||
break;
|
||||
}
|
||||
|
||||
/* According to TS 102 366, the channel count in
|
||||
* a (E)AC3SampleEntry box is to be ignored */
|
||||
case 0x20736d:
|
||||
case GST_MAKE_FOURCC ('e', 'c', '-', '3'):
|
||||
case GST_MAKE_FOURCC ('s', 'a', 'c', '3'): // Nero Recode
|
||||
case FOURCC_ac_3:
|
||||
entry->n_channels = 0;
|
||||
break;
|
||||
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue