diff mbox

[FFmpeg-devel] libavcodec/opus: Add channel mapping 2 to extradata parser

Message ID 1472593687-2407-1-git-send-email-mgraczyk@google.com
State Superseded
Headers show

Commit Message

Michael Graczyk Aug. 30, 2016, 9:48 p.m. UTC
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
---
 libavcodec/opus.c | 13 +++++++++++--
 1 file changed, 11 insertions(+), 2 deletions(-)

Comments

Michael Niedermayer Aug. 31, 2016, 9:08 p.m. UTC | #1
On Tue, Aug 30, 2016 at 02:48:07PM -0700, Michael Graczyk wrote:
> 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
> ---
>  libavcodec/opus.c | 13 +++++++++++--
>  1 file changed, 11 insertions(+), 2 deletions(-)
> 
> diff --git a/libavcodec/opus.c b/libavcodec/opus.c
> index 703d2e8..db758e9 100644
> --- a/libavcodec/opus.c
> +++ b/libavcodec/opus.c
> @@ -328,7 +328,7 @@ av_cold int ff_opus_parse_extradata(AVCodecContext *avctx,
>  
>      channels = avctx->extradata ? extradata[9] : (avctx->channels == 1) ? 1 : 2;
>      if (!channels) {
> -        av_log(avctx, AV_LOG_ERROR, "Zero channel count specified in the extadata\n");
> +        av_log(avctx, AV_LOG_ERROR, "Zero channel count specified in the extradata\n");
>          return AVERROR_INVALIDDATA;
>      }
>  

unrelated change, please put this in a separate patch


> @@ -347,7 +347,7 @@ av_cold int ff_opus_parse_extradata(AVCodecContext *avctx,
>          streams        = 1;
>          stereo_streams = channels - 1;
>          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) {
>              av_log(avctx, AV_LOG_ERROR, "Invalid extradata size: %d\n",
>                     extradata_size);
> @@ -371,6 +371,15 @@ av_cold int ff_opus_parse_extradata(AVCodecContext *avctx,
>              }
>              layout = ff_vorbis_channel_layouts[channels - 1];
>              channel_reorder = channel_reorder_vorbis;
> +        } else if (map_type == 2) {

> +            int ambisonic_order = ((int)sqrt(channels)) - 1;

ff_sqrt() to avoid float rounding

thx
[...]
Michael Graczyk Sept. 1, 2016, 6:17 p.m. UTC | #2
Thanks for reviewing! I have made the suggested changes and will send the
spelling correction in another patch.
diff mbox

Patch

diff --git a/libavcodec/opus.c b/libavcodec/opus.c
index 703d2e8..db758e9 100644
--- a/libavcodec/opus.c
+++ b/libavcodec/opus.c
@@ -328,7 +328,7 @@  av_cold int ff_opus_parse_extradata(AVCodecContext *avctx,
 
     channels = avctx->extradata ? extradata[9] : (avctx->channels == 1) ? 1 : 2;
     if (!channels) {
-        av_log(avctx, AV_LOG_ERROR, "Zero channel count specified in the extadata\n");
+        av_log(avctx, AV_LOG_ERROR, "Zero channel count specified in the extradata\n");
         return AVERROR_INVALIDDATA;
     }
 
@@ -347,7 +347,7 @@  av_cold int ff_opus_parse_extradata(AVCodecContext *avctx,
         streams        = 1;
         stereo_streams = channels - 1;
         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) {
             av_log(avctx, AV_LOG_ERROR, "Invalid extradata size: %d\n",
                    extradata_size);
@@ -371,6 +371,15 @@  av_cold int ff_opus_parse_extradata(AVCodecContext *avctx,
             }
             layout = ff_vorbis_channel_layouts[channels - 1];
             channel_reorder = channel_reorder_vorbis;
+        } else if (map_type == 2) {
+            int ambisonic_order = ((int)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
             layout = 0;