[Ffmpeg-cvslog] r7888 - trunk/libavcodec/parser.c
jbr
subversion
Fri Feb 9 03:02:10 CET 2007
Author: jbr
Date: Fri Feb 9 03:02:09 2007
New Revision: 7888
Modified:
trunk/libavcodec/parser.c
Log:
fix parsing of RealAudio AC-3/DolbyNet
Modified: trunk/libavcodec/parser.c
==============================================================================
--- trunk/libavcodec/parser.c (original)
+++ trunk/libavcodec/parser.c Fri Feb 9 03:02:09 2007
@@ -657,7 +657,7 @@
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 @@
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 @@
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);
More information about the ffmpeg-cvslog
mailing list