Commit be07c258 authored by Michael Graczyk's avatar Michael Graczyk Committed by Michael Niedermayer

libavcodec/opus: Add channel mapping 2 to extradata parser

This allows libavcodec/opus to demux ambisonics in an ogg/opus container.
Channel mapping family 2 is being added in this standards track IETF draft:
tools.ietf.org/html/draft-ietf-codec-ambisonics-00
Signed-off-by: 's avatarMichael Niedermayer <michael@niedermayer.cc>
parent a2c912c3
...@@ -347,7 +347,7 @@ av_cold int ff_opus_parse_extradata(AVCodecContext *avctx, ...@@ -347,7 +347,7 @@ av_cold int ff_opus_parse_extradata(AVCodecContext *avctx,
streams = 1; streams = 1;
stereo_streams = channels - 1; stereo_streams = channels - 1;
channel_map = default_channel_map; channel_map = default_channel_map;
} else if (map_type == 1 || map_type == 255) { } else if (map_type == 1 || map_type == 2 || map_type == 255) {
if (extradata_size < 21 + channels) { if (extradata_size < 21 + channels) {
av_log(avctx, AV_LOG_ERROR, "Invalid extradata size: %d\n", av_log(avctx, AV_LOG_ERROR, "Invalid extradata size: %d\n",
extradata_size); extradata_size);
...@@ -371,6 +371,15 @@ av_cold int ff_opus_parse_extradata(AVCodecContext *avctx, ...@@ -371,6 +371,15 @@ av_cold int ff_opus_parse_extradata(AVCodecContext *avctx,
} }
layout = ff_vorbis_channel_layouts[channels - 1]; layout = ff_vorbis_channel_layouts[channels - 1];
channel_reorder = channel_reorder_vorbis; channel_reorder = channel_reorder_vorbis;
} else if (map_type == 2) {
int ambisonic_order = ff_sqrt(channels) - 1;
if (channels != (ambisonic_order + 1) * (ambisonic_order + 1)) {
av_log(avctx, AV_LOG_ERROR,
"Channel mapping 2 is only specified for channel counts"
" which can be written as (n + 1)^2 for nonnegative integer n\n");
return AVERROR_INVALIDDATA;
}
layout = 0;
} else } else
layout = 0; layout = 0;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment