[SCM] libav/experimental: fix parsing of RealAudio AC-3/DolbyNet

siretart at users.alioth.debian.org siretart at users.alioth.debian.org
Sun Jun 30 15:56:08 UTC 2013


The following commit has been merged in the experimental branch:
commit f7a49547de2c26f858114d8fec634e6662389efb
Author: Justin Ruggles <justin.ruggles at gmail.com>
Date:   Fri Feb 9 02:02:09 2007 +0000

    fix parsing of RealAudio AC-3/DolbyNet
    
    Originally committed as revision 7888 to svn://svn.ffmpeg.org/ffmpeg/trunk

diff --git a/libavcodec/parser.c b/libavcodec/parser.c
index 62a95c1..1ef7339 100644
--- a/libavcodec/parser.c
+++ b/libavcodec/parser.c
@@ -657,7 +657,7 @@ static const int aac_channels[8] = {
 static int ac3_sync(const uint8_t *buf, int *channels, int *sample_rate,
                     int *bit_rate, int *samples)
 {
-    unsigned int fscod, frmsizecod, acmod, bsid, lfeon;
+    unsigned int fscod, frmsizecod, acmod, bsid, lfeon, halfratecod;
     unsigned int strmtyp, substreamid, frmsiz, fscod2, numblkscod;
     GetBitContext bits;
 
@@ -667,7 +667,7 @@ static int ac3_sync(const uint8_t *buf, int *channels, int *sample_rate,
         return 0;
 
     bsid = show_bits_long(&bits, 29) & 0x1f;
-    if(bsid <= 8) {             /* Normal AC-3 */
+    if(bsid <= 10) {             /* Normal AC-3 */
         skip_bits(&bits, 16);       /* crc */
         fscod = get_bits(&bits, 2);
         frmsizecod = get_bits(&bits, 6);
@@ -686,13 +686,14 @@ static int ac3_sync(const uint8_t *buf, int *channels, int *sample_rate,
             skip_bits(&bits, 2);    /* dsurmod */
         lfeon = get_bits1(&bits);
 
-        *sample_rate = ac3_sample_rates[fscod];
-        *bit_rate = ac3_bitrates[frmsizecod] * 1000;
+        halfratecod = FFMAX(bsid, 8) - 8;
+        *sample_rate = ac3_sample_rates[fscod] >> halfratecod;
+        *bit_rate = (ac3_bitrates[frmsizecod] * 1000) >> halfratecod;
         *channels = ac3_channels[acmod] + lfeon;
         *samples = 6 * 256;
 
         return ac3_frame_sizes[frmsizecod][fscod] * 2;
-    } else if (bsid >= 10 && bsid <= 16) { /* Enhanced AC-3 */
+    } else if (bsid > 10 && bsid <= 16) { /* Enhanced AC-3 */
         strmtyp = get_bits(&bits, 2);
         substreamid = get_bits(&bits, 3);
 

-- 
Libav/FFmpeg packaging



More information about the pkg-multimedia-commits mailing list