mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-24 13:56:33 +02:00
Merge commit '9cfa68c560bdec82d2d5ec079f9c5b0f9ca37af0'
* commit '9cfa68c560bdec82d2d5ec079f9c5b0f9ca37af0': mpegts: add support for Opus Conflicts: libavcodec/opus_parser.c libavformat/mpegts.c See: 74141f693ded2fbf75af56fff309d2db35183635 Merged-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
commit
5318cf521f
@ -26,9 +26,9 @@
|
||||
*/
|
||||
|
||||
#include "avcodec.h"
|
||||
#include "bytestream.h"
|
||||
#include "opus.h"
|
||||
#include "parser.h"
|
||||
#include "bytestream.h"
|
||||
|
||||
typedef struct OpusParseContext {
|
||||
OpusContext ctx;
|
||||
|
@ -1515,6 +1515,10 @@ static const uint8_t opus_coupled_stream_cnt[9] = {
|
||||
1, 0, 1, 1, 2, 2, 2, 3, 3
|
||||
};
|
||||
|
||||
static const uint8_t opus_stream_cnt[9] = {
|
||||
1, 1, 1, 2, 2, 3, 4, 4, 5,
|
||||
};
|
||||
|
||||
static const uint8_t opus_channel_map[8][8] = {
|
||||
{ 0 },
|
||||
{ 0,1 },
|
||||
@ -1760,11 +1764,8 @@ int ff_parse_mpeg2_descriptor(AVFormatContext *fc, AVStream *st, int stream_type
|
||||
return AVERROR_INVALIDDATA;
|
||||
if (channel_config_code <= 0x8) {
|
||||
st->codec->extradata[9] = channels = channel_config_code ? channel_config_code : 2;
|
||||
st->codec->extradata[18] = channels > 2;
|
||||
st->codec->extradata[19] = channels - opus_coupled_stream_cnt[channel_config_code];
|
||||
if (channel_config_code == 0) { /* Dual Mono */
|
||||
st->codec->extradata[18] = 255; /* Mapping */
|
||||
}
|
||||
st->codec->extradata[18] = channel_config_code ? (channels > 2) : /* Dual Mono */ 255;
|
||||
st->codec->extradata[19] = opus_stream_cnt[channel_config_code];
|
||||
st->codec->extradata[20] = opus_coupled_stream_cnt[channel_config_code];
|
||||
memcpy(&st->codec->extradata[21], opus_channel_map[channels - 1], channels);
|
||||
} else {
|
||||
|
Loading…
x
Reference in New Issue
Block a user