]> git.sesse.net Git - ffmpeg/commitdiff
(e)ac3: clip surround mix level indexes.
authorTim Walker <tdskywalker@gmail.com>
Fri, 17 Jan 2014 15:06:34 +0000 (16:06 +0100)
committerTim Walker <tdskywalker@gmail.com>
Sun, 19 Jan 2014 18:12:52 +0000 (19:12 +0100)
Values 0-2 are reserved, 3 (-1.5dB) should be used instead.

libavcodec/ac3dec.c
libavcodec/eac3dec.c

index b6ee4014852db580aba6357c29b6ce43b797ceaf..2cceadc8781a2b7fdbfde21c3312dbd2bf2da421 100644 (file)
@@ -237,9 +237,9 @@ static int ac3_parse_header(AC3DecodeContext *s)
         if (get_bits1(gbc)) {
             s->preferred_downmix       = get_bits(gbc, 2);
             s->center_mix_level_ltrt   = get_bits(gbc, 3);
-            s->surround_mix_level_ltrt = get_bits(gbc, 3);
+            s->surround_mix_level_ltrt = av_clip(get_bits(gbc, 3), 3, 7);
             s->center_mix_level        = get_bits(gbc, 3);
-            s->surround_mix_level      = get_bits(gbc, 3);
+            s->surround_mix_level      = av_clip(get_bits(gbc, 3), 3, 7);
         }
         if (get_bits1(gbc)) {
             s->dolby_surround_ex_mode = get_bits(gbc, 2);
index dfd78c6ad717ce61a0e7339bc532dddfd8511e1c..95ee33f823353ace8a400c28598ac796854be6a0 100644 (file)
@@ -353,8 +353,8 @@ int ff_eac3_parse_header(AC3DecodeContext *s)
             }
             if (s->channel_mode & 4) {
                 /* if a surround channel exists */
-                s->surround_mix_level_ltrt = get_bits(gbc, 3);
-                s->surround_mix_level = get_bits(gbc, 3);
+                s->surround_mix_level_ltrt = av_clip(get_bits(gbc, 3), 3, 7);
+                s->surround_mix_level = av_clip(get_bits(gbc, 3), 3, 7);
             }
         }