Commit f7a49547 authored by Justin Ruggles's avatar Justin Ruggles

fix parsing of RealAudio AC-3/DolbyNet

Originally committed as revision 7888 to svn://svn.ffmpeg.org/ffmpeg/trunk
parent 7156aeb9
...@@ -657,7 +657,7 @@ static const int aac_channels[8] = { ...@@ -657,7 +657,7 @@ static const int aac_channels[8] = {
static int ac3_sync(const uint8_t *buf, int *channels, int *sample_rate, static int ac3_sync(const uint8_t *buf, int *channels, int *sample_rate,
int *bit_rate, int *samples) 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; unsigned int strmtyp, substreamid, frmsiz, fscod2, numblkscod;
GetBitContext bits; GetBitContext bits;
...@@ -667,7 +667,7 @@ static int ac3_sync(const uint8_t *buf, int *channels, int *sample_rate, ...@@ -667,7 +667,7 @@ static int ac3_sync(const uint8_t *buf, int *channels, int *sample_rate,
return 0; return 0;
bsid = show_bits_long(&bits, 29) & 0x1f; bsid = show_bits_long(&bits, 29) & 0x1f;
if(bsid <= 8) { /* Normal AC-3 */ if(bsid <= 10) { /* Normal AC-3 */
skip_bits(&bits, 16); /* crc */ skip_bits(&bits, 16); /* crc */
fscod = get_bits(&bits, 2); fscod = get_bits(&bits, 2);
frmsizecod = get_bits(&bits, 6); frmsizecod = get_bits(&bits, 6);
...@@ -686,13 +686,14 @@ static int ac3_sync(const uint8_t *buf, int *channels, int *sample_rate, ...@@ -686,13 +686,14 @@ static int ac3_sync(const uint8_t *buf, int *channels, int *sample_rate,
skip_bits(&bits, 2); /* dsurmod */ skip_bits(&bits, 2); /* dsurmod */
lfeon = get_bits1(&bits); lfeon = get_bits1(&bits);
*sample_rate = ac3_sample_rates[fscod]; halfratecod = FFMAX(bsid, 8) - 8;
*bit_rate = ac3_bitrates[frmsizecod] * 1000; *sample_rate = ac3_sample_rates[fscod] >> halfratecod;
*bit_rate = (ac3_bitrates[frmsizecod] * 1000) >> halfratecod;
*channels = ac3_channels[acmod] + lfeon; *channels = ac3_channels[acmod] + lfeon;
*samples = 6 * 256; *samples = 6 * 256;
return ac3_frame_sizes[frmsizecod][fscod] * 2; 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); strmtyp = get_bits(&bits, 2);
substreamid = get_bits(&bits, 3); substreamid = get_bits(&bits, 3);
......
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