Commit a132d75c authored by Sam Hocevar's avatar Sam Hocevar

 . this is a coding style patch which removes all "foo(bar){" constructions
   and most of the tabulations.
 . also, fixed a bug in the default subtitle track.
 . and made a few error messages more explicit, ie. changed "error: %s" to
   "foo error: couldn't initialize bar (%s)"
parent df5793c2
...@@ -137,7 +137,7 @@ ...@@ -137,7 +137,7 @@
#define INTF_CHANNELS_DEFAULT "vlc.channels" #define INTF_CHANNELS_DEFAULT "vlc.channels"
/* Base delay in micro second for interface sleeps */ /* Base delay in micro second for interface sleeps */
#define INTF_IDLE_SLEEP ((int)(0.100*CLOCK_FREQ)) #define INTF_IDLE_SLEEP ((int)(0.050*CLOCK_FREQ))
/* Step for changing gamma, and minimum and maximum values */ /* Step for changing gamma, and minimum and maximum values */
#define INTF_GAMMA_STEP .1 #define INTF_GAMMA_STEP .1
......
...@@ -212,7 +212,7 @@ static __inline__ int vlc_mutex_init( vlc_mutex_t *p_mutex ) ...@@ -212,7 +212,7 @@ static __inline__ int vlc_mutex_init( vlc_mutex_t *p_mutex )
#elif defined(HAVE_KERNEL_SCHEDULER_H) && defined(HAVE_KERNEL_OS_H) #elif defined(HAVE_KERNEL_SCHEDULER_H) && defined(HAVE_KERNEL_OS_H)
// check the arguments and whether it's already been initialized /* check the arguments and whether it's already been initialized */
if( p_mutex == NULL ) return B_BAD_VALUE; if( p_mutex == NULL ) return B_BAD_VALUE;
if( p_mutex->init == 9999 ) if( p_mutex->init == 9999 )
{ {
......
...@@ -23,7 +23,8 @@ ...@@ -23,7 +23,8 @@
static __inline__ u8 GetByte (ac3_byte_stream_t * p_byte_stream) static __inline__ u8 GetByte (ac3_byte_stream_t * p_byte_stream)
{ {
/* Are there some bytes left in the current buffer ? */ /* Are there some bytes left in the current buffer ? */
if (p_byte_stream->p_byte >= p_byte_stream->p_end) { if (p_byte_stream->p_byte >= p_byte_stream->p_end)
{
/* no, switch to next buffer */ /* no, switch to next buffer */
ac3_byte_stream_next (p_byte_stream); ac3_byte_stream_next (p_byte_stream);
} }
...@@ -33,7 +34,8 @@ static __inline__ u8 GetByte (ac3_byte_stream_t * p_byte_stream) ...@@ -33,7 +34,8 @@ static __inline__ u8 GetByte (ac3_byte_stream_t * p_byte_stream)
static __inline__ void NeedBits (ac3_bit_stream_t * p_bit_stream, int i_bits) static __inline__ void NeedBits (ac3_bit_stream_t * p_bit_stream, int i_bits)
{ {
while (p_bit_stream->i_available < i_bits) { while (p_bit_stream->i_available < i_bits)
{
p_bit_stream->buffer |= p_bit_stream->buffer |=
((u32)GetByte (&p_bit_stream->byte_stream)) << (24 - p_bit_stream->i_available); ((u32)GetByte (&p_bit_stream->byte_stream)) << (24 - p_bit_stream->i_available);
p_bit_stream->i_available += 8; p_bit_stream->i_available += 8;
......
...@@ -335,16 +335,19 @@ typedef struct audblk_s { ...@@ -335,16 +335,19 @@ typedef struct audblk_s {
* approximate a 1/6 octave scale. * approximate a 1/6 octave scale.
*/ */
typedef struct stream_coeffs_s { typedef struct stream_coeffs_s
{
float fbw[5][256]; float fbw[5][256];
float lfe[256]; float lfe[256];
} stream_coeffs_t; } stream_coeffs_t;
typedef struct stream_samples_s { typedef struct stream_samples_s
{
float channel[6][256]; float channel[6][256];
} stream_samples_t; } stream_samples_t;
typedef struct ac3_bit_stream_s { typedef struct ac3_bit_stream_s
{
u32 buffer; u32 buffer;
int i_available; int i_available;
ac3_byte_stream_t byte_stream; ac3_byte_stream_t byte_stream;
...@@ -352,7 +355,8 @@ typedef struct ac3_bit_stream_s { ...@@ -352,7 +355,8 @@ typedef struct ac3_bit_stream_s {
unsigned int total_bits_read; /* temporary */ unsigned int total_bits_read; /* temporary */
} ac3_bit_stream_t; } ac3_bit_stream_t;
struct ac3dec_s { struct ac3dec_s
{
/* /*
* Input properties * Input properties
*/ */
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* ac3_decoder_thread.h : ac3 decoder thread interface * ac3_decoder_thread.h : ac3 decoder thread interface
***************************************************************************** *****************************************************************************
* Copyright (C) 1999, 2000 VideoLAN * Copyright (C) 1999, 2000 VideoLAN
* $Id: ac3_decoder_thread.h,v 1.2 2000/12/21 13:25:50 massiot Exp $ * $Id: ac3_decoder_thread.h,v 1.3 2001/01/05 14:45:47 sam Exp $
* *
* Authors: * Authors:
* Michel Kaempf <maxx@via.ecp.fr> * Michel Kaempf <maxx@via.ecp.fr>
......
...@@ -27,7 +27,8 @@ ...@@ -27,7 +27,8 @@
#define NORM 16384 #define NORM 16384
typedef struct prefs_s { typedef struct prefs_s
{
u16 use_dolby_surround; u16 use_dolby_surround;
u16 dual_mono_channel_select; u16 dual_mono_channel_select;
} prefs_t; } prefs_t;
...@@ -56,8 +57,10 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf) ...@@ -56,8 +57,10 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf)
*/ */
/* There are two main cases, with or without Dolby Surround */ /* There are two main cases, with or without Dolby Surround */
if (global_prefs.use_dolby_surround) { if (global_prefs.use_dolby_surround)
switch(p_ac3dec->bsi.acmod) { {
switch(p_ac3dec->bsi.acmod)
{
case 7: /* 3/2 */ case 7: /* 3/2 */
left = p_ac3dec->samples.channel[0]; left = p_ac3dec->samples.channel[0];
centre = p_ac3dec->samples.channel[1]; centre = p_ac3dec->samples.channel[1];
...@@ -65,7 +68,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf) ...@@ -65,7 +68,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf)
left_sur = p_ac3dec->samples.channel[3]; left_sur = p_ac3dec->samples.channel[3];
right_sur = p_ac3dec->samples.channel[4]; right_sur = p_ac3dec->samples.channel[4];
for (j = 0; j < 256; j++) { for (j = 0; j < 256; j++)
{
right_tmp = 0.2265f * *left_sur++ + 0.2265f * *right_sur++; right_tmp = 0.2265f * *left_sur++ + 0.2265f * *right_sur++;
left_tmp = -1 * right_tmp; left_tmp = -1 * right_tmp;
right_tmp += 0.3204f * *right++ + 0.2265f * *centre; right_tmp += 0.3204f * *right++ + 0.2265f * *centre;
...@@ -82,7 +86,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf) ...@@ -82,7 +86,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf)
left_sur = p_ac3dec->samples.channel[2]; left_sur = p_ac3dec->samples.channel[2];
right_sur = p_ac3dec->samples.channel[3]; right_sur = p_ac3dec->samples.channel[3];
for (j = 0; j < 256; j++) { for (j = 0; j < 256; j++)
{
right_tmp = 0.2265f * *left_sur++ + 0.2265f * *right_sur++; right_tmp = 0.2265f * *left_sur++ + 0.2265f * *right_sur++;
left_tmp = -1 * right_tmp; left_tmp = -1 * right_tmp;
right_tmp += 0.3204f * *right++; right_tmp += 0.3204f * *right++;
...@@ -100,7 +105,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf) ...@@ -100,7 +105,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf)
/* Mono surround */ /* Mono surround */
right_sur = p_ac3dec->samples.channel[3]; right_sur = p_ac3dec->samples.channel[3];
for (j = 0; j < 256; j++) { for (j = 0; j < 256; j++)
{
right_tmp = 0.2265f * *right_sur++; right_tmp = 0.2265f * *right_sur++;
left_tmp = - right_tmp; left_tmp = - right_tmp;
right_tmp += 0.3204f * *right++ + 0.2265f * *centre; right_tmp += 0.3204f * *right++ + 0.2265f * *centre;
...@@ -117,7 +123,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf) ...@@ -117,7 +123,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf)
/* Mono surround */ /* Mono surround */
right_sur = p_ac3dec->samples.channel[2]; right_sur = p_ac3dec->samples.channel[2];
for (j = 0; j < 256; j++) { for (j = 0; j < 256; j++)
{
right_tmp = 0.2265f * *right_sur++; right_tmp = 0.2265f * *right_sur++;
left_tmp = - right_tmp; left_tmp = - right_tmp;
right_tmp += 0.3204f * *right++; right_tmp += 0.3204f * *right++;
...@@ -133,7 +140,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf) ...@@ -133,7 +140,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf)
centre = p_ac3dec->samples.channel[1]; centre = p_ac3dec->samples.channel[1];
right = p_ac3dec->samples.channel[2]; right = p_ac3dec->samples.channel[2];
for (j = 0; j < 256; j++) { for (j = 0; j < 256; j++)
{
right_tmp = 0.3204f * *right++ + 0.2265f * *centre; right_tmp = 0.3204f * *right++ + 0.2265f * *centre;
left_tmp = 0.3204f * *left++ + 0.2265f * *centre++; left_tmp = 0.3204f * *left++ + 0.2265f * *centre++;
...@@ -146,7 +154,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf) ...@@ -146,7 +154,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf)
left = p_ac3dec->samples.channel[0]; left = p_ac3dec->samples.channel[0];
right = p_ac3dec->samples.channel[1]; right = p_ac3dec->samples.channel[1];
for (j = 0; j < 256; j++) { for (j = 0; j < 256; j++)
{
*(out_buf++) = *(left++) * NORM; *(out_buf++) = *(left++) * NORM;
*(out_buf++) = *(right++) * NORM; *(out_buf++) = *(right++) * NORM;
} }
...@@ -156,7 +165,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf) ...@@ -156,7 +165,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf)
/* Mono program! */ /* Mono program! */
right = p_ac3dec->samples.channel[0]; right = p_ac3dec->samples.channel[0];
for (j = 0; j < 256; j++) { for (j = 0; j < 256; j++)
{
right_tmp = 0.7071f * *right++; right_tmp = 0.7071f * *right++;
*(out_buf++) = right_tmp * NORM; *(out_buf++) = right_tmp * NORM;
...@@ -168,7 +178,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf) ...@@ -168,7 +178,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf)
/* Dual mono, output selected by user */ /* Dual mono, output selected by user */
right = p_ac3dec->samples.channel[global_prefs.dual_mono_channel_select]; right = p_ac3dec->samples.channel[global_prefs.dual_mono_channel_select];
for (j = 0; j < 256; j++) { for (j = 0; j < 256; j++)
{
right_tmp = 0.7071f * *right++; right_tmp = 0.7071f * *right++;
*(out_buf++) = right_tmp * NORM; *(out_buf++) = right_tmp * NORM;
...@@ -178,7 +189,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf) ...@@ -178,7 +189,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf)
} }
} else { } else {
/* Non-Dolby surround downmixes */ /* Non-Dolby surround downmixes */
switch(p_ac3dec->bsi.acmod) { switch(p_ac3dec->bsi.acmod)
{
case 7: /* 3/2 */ case 7: /* 3/2 */
left = p_ac3dec->samples.channel[0]; left = p_ac3dec->samples.channel[0];
centre = p_ac3dec->samples.channel[1]; centre = p_ac3dec->samples.channel[1];
...@@ -189,7 +201,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf) ...@@ -189,7 +201,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf)
clev = cmixlev_lut[p_ac3dec->bsi.cmixlev]; clev = cmixlev_lut[p_ac3dec->bsi.cmixlev];
slev = smixlev_lut[p_ac3dec->bsi.surmixlev]; slev = smixlev_lut[p_ac3dec->bsi.surmixlev];
for (j = 0; j < 256; j++) { for (j = 0; j < 256; j++)
{
right_tmp= 0.4142f * *right++ + clev * *centre + slev * *right_sur++; right_tmp= 0.4142f * *right++ + clev * *centre + slev * *right_sur++;
left_tmp = 0.4142f * *left++ + clev * *centre++ + slev * *left_sur++; left_tmp = 0.4142f * *left++ + clev * *centre++ + slev * *left_sur++;
...@@ -206,7 +219,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf) ...@@ -206,7 +219,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf)
slev = smixlev_lut[p_ac3dec->bsi.surmixlev]; slev = smixlev_lut[p_ac3dec->bsi.surmixlev];
for (j = 0; j < 256; j++) { for (j = 0; j < 256; j++)
{
right_tmp= 0.4142f * *right++ + slev * *right_sur++; right_tmp= 0.4142f * *right++ + slev * *right_sur++;
left_tmp = 0.4142f * *left++ + slev * *left_sur++; left_tmp = 0.4142f * *left++ + slev * *left_sur++;
...@@ -225,7 +239,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf) ...@@ -225,7 +239,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf)
clev = cmixlev_lut[p_ac3dec->bsi.cmixlev]; clev = cmixlev_lut[p_ac3dec->bsi.cmixlev];
slev = smixlev_lut[p_ac3dec->bsi.surmixlev]; slev = smixlev_lut[p_ac3dec->bsi.surmixlev];
for (j = 0; j < 256; j++) { for (j = 0; j < 256; j++)
{
right_tmp= 0.4142f * *right++ + clev * *centre + slev * *right_sur; right_tmp= 0.4142f * *right++ + clev * *centre + slev * *right_sur;
left_tmp = 0.4142f * *left++ + clev * *centre++ + slev * *right_sur++; left_tmp = 0.4142f * *left++ + clev * *centre++ + slev * *right_sur++;
...@@ -242,7 +257,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf) ...@@ -242,7 +257,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf)
slev = smixlev_lut[p_ac3dec->bsi.surmixlev]; slev = smixlev_lut[p_ac3dec->bsi.surmixlev];
for (j = 0; j < 256; j++) { for (j = 0; j < 256; j++)
{
right_tmp= 0.4142f * *right++ + slev * *right_sur; right_tmp= 0.4142f * *right++ + slev * *right_sur;
left_tmp = 0.4142f * *left++ + slev * *right_sur++; left_tmp = 0.4142f * *left++ + slev * *right_sur++;
...@@ -258,7 +274,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf) ...@@ -258,7 +274,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf)
clev = cmixlev_lut[p_ac3dec->bsi.cmixlev]; clev = cmixlev_lut[p_ac3dec->bsi.cmixlev];
for (j = 0; j < 256; j++) { for (j = 0; j < 256; j++)
{
right_tmp= 0.4142f * *right++ + clev * *centre; right_tmp= 0.4142f * *right++ + clev * *centre;
left_tmp = 0.4142f * *left++ + clev * *centre++; left_tmp = 0.4142f * *left++ + clev * *centre++;
...@@ -271,7 +288,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf) ...@@ -271,7 +288,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf)
left = p_ac3dec->samples.channel[0]; left = p_ac3dec->samples.channel[0];
right = p_ac3dec->samples.channel[1]; right = p_ac3dec->samples.channel[1];
for (j = 0; j < 256; j++) { for (j = 0; j < 256; j++)
{
*(out_buf++) = *(left++) * NORM; *(out_buf++) = *(left++) * NORM;
*(out_buf++) = *(right++) * NORM; *(out_buf++) = *(right++) * NORM;
} }
...@@ -281,7 +299,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf) ...@@ -281,7 +299,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf)
/* Mono program! */ /* Mono program! */
right = p_ac3dec->samples.channel[0]; right = p_ac3dec->samples.channel[0];
for (j = 0; j < 256; j++) { for (j = 0; j < 256; j++)
{
right_tmp = 0.7071f * *right++; right_tmp = 0.7071f * *right++;
*(out_buf++) = right_tmp * NORM; *(out_buf++) = right_tmp * NORM;
...@@ -293,7 +312,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf) ...@@ -293,7 +312,8 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf)
/* Dual mono, output selected by user */ /* Dual mono, output selected by user */
right = p_ac3dec->samples.channel[global_prefs.dual_mono_channel_select]; right = p_ac3dec->samples.channel[global_prefs.dual_mono_channel_select];
for (j = 0; j < 256; j++) { for (j = 0; j < 256; j++)
{
right_tmp = 0.7071f * *right++; right_tmp = 0.7071f * *right++;
*(out_buf++) = right_tmp * NORM; *(out_buf++) = right_tmp * NORM;
...@@ -303,3 +323,4 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf) ...@@ -303,3 +323,4 @@ void downmix (ac3dec_t * p_ac3dec, s16 * out_buf)
} }
} }
} }
...@@ -36,28 +36,34 @@ ...@@ -36,28 +36,34 @@
#include "ac3_internal.h" #include "ac3_internal.h"
static const s16 exps_1[128] = static const s16 exps_1[128] =
{ -2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2, {
-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,-2,
-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1, -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
0, 0, 0 }; 0, 0, 0
};
static const s16 exps_2[128] = static const s16 exps_2[128] =
{ -2,-2,-2,-2,-2,-1,-1,-1,-1,-1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2, {
-2,-2,-2,-2,-2,-1,-1,-1,-1,-1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2,
-2,-2,-2,-2,-2,-1,-1,-1,-1,-1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2, -2,-2,-2,-2,-2,-1,-1,-1,-1,-1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2,
-2,-2,-2,-2,-2,-1,-1,-1,-1,-1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2, -2,-2,-2,-2,-2,-1,-1,-1,-1,-1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2,
-2,-2,-2,-2,-2,-1,-1,-1,-1,-1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2, -2,-2,-2,-2,-2,-1,-1,-1,-1,-1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2,
-2,-2,-2,-2,-2,-1,-1,-1,-1,-1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2, -2,-2,-2,-2,-2,-1,-1,-1,-1,-1, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2,
0, 0, 0 }; 0, 0, 0
};
static const s16 exps_3[128] = static const s16 exps_3[128] =
{ -2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2, {
-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,
-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2, -2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,
-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2, -2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,
-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2, -2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,
-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2, -2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,-2,-1, 0, 1, 2,
0, 0, 0 }; 0, 0, 0
};
#define UNPACK_FBW 1 #define UNPACK_FBW 1
#define UNPACK_CPL 2 #define UNPACK_CPL 2
...@@ -70,7 +76,8 @@ static __inline__ int exp_unpack_ch (ac3dec_t * p_ac3dec, u16 type, ...@@ -70,7 +76,8 @@ static __inline__ int exp_unpack_ch (ac3dec_t * p_ac3dec, u16 type,
u16 i,j; u16 i,j;
s16 exp_acc; s16 exp_acc;
if (expstr == EXP_REUSE) { if (expstr == EXP_REUSE)
{
return 0; return 0;
} }
...@@ -80,15 +87,19 @@ static __inline__ int exp_unpack_ch (ac3dec_t * p_ac3dec, u16 type, ...@@ -80,15 +87,19 @@ static __inline__ int exp_unpack_ch (ac3dec_t * p_ac3dec, u16 type,
/* In the case of a fbw channel then the initial absolute values is /* In the case of a fbw channel then the initial absolute values is
* also an exponent */ * also an exponent */
if (type != UNPACK_CPL) { if (type != UNPACK_CPL)
{
dest[j++] = exp_acc; dest[j++] = exp_acc;
} }
/* Loop through the groups and fill the dest array appropriately */ /* Loop through the groups and fill the dest array appropriately */
switch (expstr) { switch (expstr)
{
case EXP_D15: /* 1 */ case EXP_D15: /* 1 */
for (i = 0; i < ngrps; i++) { for (i = 0; i < ngrps; i++)
if (exps[i] > 124) { {
if (exps[i] > 124)
{
intf_ErrMsg ( "ac3dec error: invalid exponent" ); intf_ErrMsg ( "ac3dec error: invalid exponent" );
return 1; return 1;
} }
...@@ -102,8 +113,10 @@ static __inline__ int exp_unpack_ch (ac3dec_t * p_ac3dec, u16 type, ...@@ -102,8 +113,10 @@ static __inline__ int exp_unpack_ch (ac3dec_t * p_ac3dec, u16 type,
break; break;
case EXP_D25: /* 2 */ case EXP_D25: /* 2 */
for (i = 0; i < ngrps; i++) { for (i = 0; i < ngrps; i++)
if (exps[i] > 124) { {
if (exps[i] > 124)
{
intf_ErrMsg ( "ac3dec error: invalid exponent" ); intf_ErrMsg ( "ac3dec error: invalid exponent" );
return 1; return 1;
} }
...@@ -120,8 +133,10 @@ static __inline__ int exp_unpack_ch (ac3dec_t * p_ac3dec, u16 type, ...@@ -120,8 +133,10 @@ static __inline__ int exp_unpack_ch (ac3dec_t * p_ac3dec, u16 type,
break; break;
case EXP_D45: /* 3 */ case EXP_D45: /* 3 */
for (i = 0; i < ngrps; i++) { for (i = 0; i < ngrps; i++)
if (exps[i] > 124) { {
if (exps[i] > 124)
{
intf_ErrMsg ( "ac3dec error: invalid exponent" ); intf_ErrMsg ( "ac3dec error: invalid exponent" );
return 1; return 1;
} }
...@@ -151,31 +166,41 @@ int exponent_unpack (ac3dec_t * p_ac3dec) ...@@ -151,31 +166,41 @@ int exponent_unpack (ac3dec_t * p_ac3dec)
{ {
u16 i; u16 i;
for (i = 0; i < p_ac3dec->bsi.nfchans; i++) { for (i = 0; i < p_ac3dec->bsi.nfchans; i++)
{
if (exp_unpack_ch (p_ac3dec, UNPACK_FBW, p_ac3dec->audblk.chexpstr[i], if (exp_unpack_ch (p_ac3dec, UNPACK_FBW, p_ac3dec->audblk.chexpstr[i],
p_ac3dec->audblk.nchgrps[i], p_ac3dec->audblk.nchgrps[i],
p_ac3dec->audblk.exps[i][0], p_ac3dec->audblk.exps[i][0],
&p_ac3dec->audblk.exps[i][1], &p_ac3dec->audblk.exps[i][1],
p_ac3dec->audblk.fbw_exp[i])) p_ac3dec->audblk.fbw_exp[i]))
{
return 1; return 1;
} }
}
if (p_ac3dec->audblk.cplinu) { if (p_ac3dec->audblk.cplinu)
{
if (exp_unpack_ch (p_ac3dec, UNPACK_CPL, p_ac3dec->audblk.cplexpstr, if (exp_unpack_ch (p_ac3dec, UNPACK_CPL, p_ac3dec->audblk.cplexpstr,
p_ac3dec->audblk.ncplgrps, p_ac3dec->audblk.ncplgrps,
p_ac3dec->audblk.cplabsexp << 1, p_ac3dec->audblk.cplabsexp << 1,
p_ac3dec->audblk.cplexps, p_ac3dec->audblk.cplexps,
&p_ac3dec->audblk.cpl_exp[p_ac3dec->audblk.cplstrtmant])) &p_ac3dec->audblk.cpl_exp[p_ac3dec->audblk.cplstrtmant]))
{
return 1; return 1;
} }
}
if (p_ac3dec->bsi.lfeon) { if (p_ac3dec->bsi.lfeon)
{
if (exp_unpack_ch (p_ac3dec, UNPACK_LFE, p_ac3dec->audblk.lfeexpstr, if (exp_unpack_ch (p_ac3dec, UNPACK_LFE, p_ac3dec->audblk.lfeexpstr,
2, p_ac3dec->audblk.lfeexps[0], 2, p_ac3dec->audblk.lfeexps[0],
&p_ac3dec->audblk.lfeexps[1], &p_ac3dec->audblk.lfeexps[1],
p_ac3dec->audblk.lfe_exp)) p_ac3dec->audblk.lfe_exp))
{
return 1; return 1;
} }
}
return 0; return 0;
} }
...@@ -34,18 +34,27 @@ ...@@ -34,18 +34,27 @@
#define Q0 ((-2 << 15) / 3.0) #define Q0 ((-2 << 15) / 3.0)
#define Q1 (0) #define Q1 (0)
#define Q2 ((2 << 15) / 3.0) #define Q2 ((2 << 15) / 3.0)
static float q_1_0[ 32 ] = { Q0, Q0, Q0, Q0, Q0, Q0, Q0, Q0, Q0, static float q_1_0[ 32 ] =
{
Q0, Q0, Q0, Q0, Q0, Q0, Q0, Q0, Q0,
Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1,
Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2,
0, 0, 0, 0, 0 }; 0, 0, 0, 0, 0
static float q_1_1[ 32 ] = { Q0, Q0, Q0, Q1, Q1, Q1, Q2, Q2, Q2, };
static float q_1_1[ 32 ] =
{
Q0, Q0, Q0, Q1, Q1, Q1, Q2, Q2, Q2, Q0, Q0, Q0, Q1, Q1, Q1, Q2, Q2, Q2,
Q0, Q0, Q0, Q1, Q1, Q1, Q2, Q2, Q2, Q0, Q0, Q0, Q1, Q1, Q1, Q2, Q2, Q2,
0, 0, 0, 0, 0 }; Q0, Q0, Q0, Q1, Q1, Q1, Q2, Q2, Q2,
static float q_1_2[ 32 ] = { Q0, Q1, Q2, Q0, Q1, Q2, Q0, Q1, Q2, 0, 0, 0, 0, 0
};
static float q_1_2[ 32 ] =
{
Q0, Q1, Q2, Q0, Q1, Q2, Q0, Q1, Q2,
Q0, Q1, Q2, Q0, Q1, Q2, Q0, Q1, Q2, Q0, Q1, Q2, Q0, Q1, Q2, Q0, Q1, Q2,
Q0, Q1, Q2, Q0, Q1, Q2, Q0, Q1, Q2, Q0, Q1, Q2, Q0, Q1, Q2, Q0, Q1, Q2,
0, 0, 0, 0, 0 }; 0, 0, 0, 0, 0
};
#undef Q0 #undef Q0
#undef Q1 #undef Q1
#undef Q2 #undef Q2
...@@ -56,26 +65,32 @@ static float q_1_2[ 32 ] = { Q0, Q1, Q2, Q0, Q1, Q2, Q0, Q1, Q2, ...@@ -56,26 +65,32 @@ static float q_1_2[ 32 ] = { Q0, Q1, Q2, Q0, Q1, Q2, Q0, Q1, Q2,
#define Q3 ((2 << 15) / 5.0) #define Q3 ((2 << 15) / 5.0)
#define Q4 ((4 << 15) / 5.0) #define Q4 ((4 << 15) / 5.0)
static float q_2_0[ 128 ] = static float q_2_0[ 128 ] =
{ Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0, {
Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,Q0,
Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1, Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,Q1,
Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2, Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,Q2,
Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3, Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,Q3,
Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4, Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,Q4,
0, 0, 0 }; 0, 0, 0
};
static float q_2_1[ 128 ] = static float q_2_1[ 128 ] =
{ Q0,Q0,Q0,Q0,Q0,Q1,Q1,Q1,Q1,Q1,Q2,Q2,Q2,Q2,Q2,Q3,Q3,Q3,Q3,Q3,Q4,Q4,Q4,Q4,Q4, {
Q0,Q0,Q0,Q0,Q0,Q1,Q1,Q1,Q1,Q1,Q2,Q2,Q2,Q2,Q2,Q3,Q3,Q3,Q3,Q3,Q4,Q4,Q4,Q4,Q4, Q0,Q0,Q0,Q0,Q0,Q1,Q1,Q1,Q1,Q1,Q2,Q2,Q2,Q2,Q2,Q3,Q3,Q3,Q3,Q3,Q4,Q4,Q4,Q4,Q4,
Q0,Q0,Q0,Q0,Q0,Q1,Q1,Q1,Q1,Q1,Q2,Q2,Q2,Q2,Q2,Q3,Q3,Q3,Q3,Q3,Q4,Q4,Q4,Q4,Q4, Q0,Q0,Q0,Q0,Q0,Q1,Q1,Q1,Q1,Q1,Q2,Q2,Q2,Q2,Q2,Q3,Q3,Q3,Q3,Q3,Q4,Q4,Q4,Q4,Q4,
Q0,Q0,Q0,Q0,Q0,Q1,Q1,Q1,Q1,Q1,Q2,Q2,Q2,Q2,Q2,Q3,Q3,Q3,Q3,Q3,Q4,Q4,Q4,Q4,Q4, Q0,Q0,Q0,Q0,Q0,Q1,Q1,Q1,Q1,Q1,Q2,Q2,Q2,Q2,Q2,Q3,Q3,Q3,Q3,Q3,Q4,Q4,Q4,Q4,Q4,
Q0,Q0,Q0,Q0,Q0,Q1,Q1,Q1,Q1,Q1,Q2,Q2,Q2,Q2,Q2,Q3,Q3,Q3,Q3,Q3,Q4,Q4,Q4,Q4,Q4, Q0,Q0,Q0,Q0,Q0,Q1,Q1,Q1,Q1,Q1,Q2,Q2,Q2,Q2,Q2,Q3,Q3,Q3,Q3,Q3,Q4,Q4,Q4,Q4,Q4,
0, 0, 0 }; Q0,Q0,Q0,Q0,Q0,Q1,Q1,Q1,Q1,Q1,Q2,Q2,Q2,Q2,Q2,Q3,Q3,Q3,Q3,Q3,Q4,Q4,Q4,Q4,Q4,
0, 0, 0
};
static float q_2_2[ 128 ] = static float q_2_2[ 128 ] =
{ Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4, {
Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,
Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4, Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,
Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4, Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,
Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4, Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,
Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4, Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,Q0,Q1,Q2,Q3,Q4,
0, 0, 0 }; 0, 0, 0
};
#undef Q0 #undef Q0
#undef Q1 #undef Q1
#undef Q2 #undef Q2
...@@ -93,7 +108,9 @@ static float q_2_2[ 128 ] = ...@@ -93,7 +108,9 @@ static float q_2_2[ 128 ] =
#define Q8 ((6 << 15) / 11.0) #define Q8 ((6 << 15) / 11.0)
#define Q9 ((8 << 15) / 11.0) #define Q9 ((8 << 15) / 11.0)
#define QA ((10 << 15) / 11.0) #define QA ((10 << 15) / 11.0)
static float q_4_0[ 128 ] = { Q0, Q0, Q0, Q0, Q0, Q0, Q0, Q0, Q0, Q0, Q0, static float q_4_0[ 128 ] =
{
Q0, Q0, Q0, Q0, Q0, Q0, Q0, Q0, Q0, Q0, Q0,
Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1, Q1,
Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2, Q2,
Q3, Q3, Q3, Q3, Q3, Q3, Q3, Q3, Q3, Q3, Q3, Q3, Q3, Q3, Q3, Q3, Q3, Q3, Q3, Q3, Q3, Q3,
...@@ -104,8 +121,10 @@ static float q_4_0[ 128 ] = { Q0, Q0, Q0, Q0, Q0, Q0, Q0, Q0, Q0, Q0, Q0, ...@@ -104,8 +121,10 @@ static float q_4_0[ 128 ] = { Q0, Q0, Q0, Q0, Q0, Q0, Q0, Q0, Q0, Q0, Q0,
Q8, Q8, Q8, Q8, Q8, Q8, Q8, Q8, Q8, Q8, Q8, Q8, Q8, Q8, Q8, Q8, Q8, Q8, Q8, Q8, Q8, Q8,
Q9, Q9, Q9, Q9, Q9, Q9, Q9, Q9, Q9, Q9, Q9, Q9, Q9, Q9, Q9, Q9, Q9, Q9, Q9, Q9, Q9, Q9,
QA, QA, QA, QA, QA, QA, QA, QA, QA, QA, QA, QA, QA, QA, QA, QA, QA, QA, QA, QA, QA, QA,
0, 0, 0, 0, 0, 0, 0}; 0, 0, 0, 0, 0, 0, 0
static float q_4_1[ 128 ] = { Q0, Q1, Q2, Q3, Q4, Q5, Q6, Q7, Q8, Q9, QA, };
static float q_4_1[ 128 ] =
{
Q0, Q1, Q2, Q3, Q4, Q5, Q6, Q7, Q8, Q9, QA, Q0, Q1, Q2, Q3, Q4, Q5, Q6, Q7, Q8, Q9, QA,
Q0, Q1, Q2, Q3, Q4, Q5, Q6, Q7, Q8, Q9, QA, Q0, Q1, Q2, Q3, Q4, Q5, Q6, Q7, Q8, Q9, QA,
Q0, Q1, Q2, Q3, Q4, Q5, Q6, Q7, Q8, Q9, QA, Q0, Q1, Q2, Q3, Q4, Q5, Q6, Q7, Q8, Q9, QA,
...@@ -116,7 +135,9 @@ static float q_4_1[ 128 ] = { Q0, Q1, Q2, Q3, Q4, Q5, Q6, Q7, Q8, Q9, QA, ...@@ -116,7 +135,9 @@ static float q_4_1[ 128 ] = { Q0, Q1, Q2, Q3, Q4, Q5, Q6, Q7, Q8, Q9, QA,
Q0, Q1, Q2, Q3, Q4, Q5, Q6, Q7, Q8, Q9, QA, Q0, Q1, Q2, Q3, Q4, Q5, Q6, Q7, Q8, Q9, QA,
Q0, Q1, Q2, Q3, Q4, Q5, Q6, Q7, Q8, Q9, QA, Q0, Q1, Q2, Q3, Q4, Q5, Q6, Q7, Q8, Q9, QA,
Q0, Q1, Q2, Q3, Q4, Q5, Q6, Q7, Q8, Q9, QA, Q0, Q1, Q2, Q3, Q4, Q5, Q6, Q7, Q8, Q9, QA,
0, 0, 0, 0, 0, 0, 0}; Q0, Q1, Q2, Q3, Q4, Q5, Q6, Q7, Q8, Q9, QA,
0, 0, 0, 0, 0, 0, 0
};
#undef Q0 #undef Q0
#undef Q1 #undef Q1
#undef Q2 #undef Q2
...@@ -131,16 +152,22 @@ static float q_4_1[ 128 ] = { Q0, Q1, Q2, Q3, Q4, Q5, Q6, Q7, Q8, Q9, QA, ...@@ -131,16 +152,22 @@ static float q_4_1[ 128 ] = { Q0, Q1, Q2, Q3, Q4, Q5, Q6, Q7, Q8, Q9, QA,
/* Lookup tables of 0.16 two's complement quantization values */ /* Lookup tables of 0.16 two's complement quantization values */
static float q_3[8] = { (-6 << 15)/7.0, (-4 << 15)/7.0, (-2 << 15)/7.0, static float q_3[8] =
{
(-6 << 15)/7.0, (-4 << 15)/7.0, (-2 << 15)/7.0,
0 , (2 << 15)/7.0, (4 << 15)/7.0, 0 , (2 << 15)/7.0, (4 << 15)/7.0,
(6 << 15)/7.0, 0 }; (6 << 15)/7.0, 0
};
static float q_5[16] = { (-14 << 15)/15.0, (-12 << 15)/15.0, (-10 << 15)/15.0, static float q_5[16] =
{
(-14 << 15)/15.0, (-12 << 15)/15.0, (-10 << 15)/15.0,
(-8 << 15)/15.0, (-6 << 15)/15.0, (-4 << 15)/15.0, (-8 << 15)/15.0, (-6 << 15)/15.0, (-4 << 15)/15.0,
(-2 << 15)/15.0, 0 , (2 << 15)/15.0, (-2 << 15)/15.0, 0 , (2 << 15)/15.0,
(4 << 15)/15.0, (6 << 15)/15.0, (8 << 15)/15.0, (4 << 15)/15.0, (6 << 15)/15.0, (8 << 15)/15.0,
(10 << 15)/15.0, (12 << 15)/15.0, (14 << 15)/15.0, (10 << 15)/15.0, (12 << 15)/15.0, (14 << 15)/15.0,
0 }; 0
};
/* These store the persistent state of the packed mantissas */ /* These store the persistent state of the packed mantissas */
static float q_1[2]; static float q_1[2];
...@@ -152,7 +179,10 @@ static s32 q_4_pointer; ...@@ -152,7 +179,10 @@ static s32 q_4_pointer;
/* Conversion from bap to number of bits in the mantissas /* Conversion from bap to number of bits in the mantissas
* zeros account for cases 0,1,2,4 which are special cased */ * zeros account for cases 0,1,2,4 which are special cased */
static u16 qnttztab[16] = { 0, 0, 0, 3, 0, 4, 5, 6, 7, 8, 9, 10, 11, 12, 14, 16}; static u16 qnttztab[16] =
{
0, 0, 0, 3, 0, 4, 5, 6, 7, 8, 9, 10, 11, 12, 14, 16
};
static float exp_lut[ 25 ] = static float exp_lut[ 25 ] =
{ {
...@@ -189,19 +219,22 @@ static __inline__ float float_get (ac3dec_t * p_ac3dec, u16 bap, u16 exp) ...@@ -189,19 +219,22 @@ static __inline__ float float_get (ac3dec_t * p_ac3dec, u16 bap, u16 exp)
u32 group_code; u32 group_code;
/* If the bap is 0-5 then we have special cases to take care of */ /* If the bap is 0-5 then we have special cases to take care of */
switch (bap) { switch (bap)
{
case 0: case 0:
return (0); /* FIXME dither */ return (0); /* FIXME dither */
case 1: case 1:
if (q_1_pointer >= 0) { if (q_1_pointer >= 0)
{
return (q_1[q_1_pointer--] * exp_lut[exp]); return (q_1[q_1_pointer--] * exp_lut[exp]);
} }
NeedBits (&(p_ac3dec->bit_stream), 5); NeedBits (&(p_ac3dec->bit_stream), 5);
group_code = p_ac3dec->bit_stream.buffer >> (32 - 5); group_code = p_ac3dec->bit_stream.buffer >> (32 - 5);
DumpBits (&(p_ac3dec->bit_stream), 5); DumpBits (&(p_ac3dec->bit_stream), 5);
if (group_code >= 27) { if (group_code >= 27)
{
intf_ErrMsg ( "ac3dec error: invalid mantissa" ); intf_ErrMsg ( "ac3dec error: invalid mantissa" );
} }
...@@ -213,14 +246,16 @@ static __inline__ float float_get (ac3dec_t * p_ac3dec, u16 bap, u16 exp) ...@@ -213,14 +246,16 @@ static __inline__ float float_get (ac3dec_t * p_ac3dec, u16 bap, u16 exp)
return (q_1_0[group_code] * exp_lut[exp]); return (q_1_0[group_code] * exp_lut[exp]);
case 2: case 2:
if (q_2_pointer >= 0) { if (q_2_pointer >= 0)
{
return (q_2[q_2_pointer--] * exp_lut[exp]); return (q_2[q_2_pointer--] * exp_lut[exp]);
} }
NeedBits (&(p_ac3dec->bit_stream), 7); NeedBits (&(p_ac3dec->bit_stream), 7);
group_code = p_ac3dec->bit_stream.buffer >> (32 - 7); group_code = p_ac3dec->bit_stream.buffer >> (32 - 7);
DumpBits (&(p_ac3dec->bit_stream), 7); DumpBits (&(p_ac3dec->bit_stream), 7);
if (group_code >= 125) { if (group_code >= 125)
{
intf_ErrMsg ( "ac3dec error: invalid mantissa" ); intf_ErrMsg ( "ac3dec error: invalid mantissa" );
} }
...@@ -236,21 +271,24 @@ static __inline__ float float_get (ac3dec_t * p_ac3dec, u16 bap, u16 exp) ...@@ -236,21 +271,24 @@ static __inline__ float float_get (ac3dec_t * p_ac3dec, u16 bap, u16 exp)
group_code = p_ac3dec->bit_stream.buffer >> (32 - 3); group_code = p_ac3dec->bit_stream.buffer >> (32 - 3);
DumpBits (&(p_ac3dec->bit_stream), 3); DumpBits (&(p_ac3dec->bit_stream), 3);
if (group_code >= 7) { if (group_code >= 7)
{
intf_ErrMsg ( "ac3dec error: invalid mantissa" ); intf_ErrMsg ( "ac3dec error: invalid mantissa" );
} }
return (q_3[group_code] * exp_lut[exp]); return (q_3[group_code] * exp_lut[exp]);
case 4: case 4:
if (q_4_pointer >= 0) { if (q_4_pointer >= 0)
{
return (q_4[q_4_pointer--] * exp_lut[exp]); return (q_4[q_4_pointer--] * exp_lut[exp]);
} }
NeedBits (&(p_ac3dec->bit_stream), 7); NeedBits (&(p_ac3dec->bit_stream), 7);
group_code = p_ac3dec->bit_stream.buffer >> (32 - 7); group_code = p_ac3dec->bit_stream.buffer >> (32 - 7);
DumpBits (&(p_ac3dec->bit_stream), 7); DumpBits (&(p_ac3dec->bit_stream), 7);
if (group_code >= 121) { if (group_code >= 121)
{
intf_ErrMsg ( "ac3dec error: invalid mantissa" ); intf_ErrMsg ( "ac3dec error: invalid mantissa" );
} }
...@@ -265,7 +303,8 @@ static __inline__ float float_get (ac3dec_t * p_ac3dec, u16 bap, u16 exp) ...@@ -265,7 +303,8 @@ static __inline__ float float_get (ac3dec_t * p_ac3dec, u16 bap, u16 exp)
group_code = p_ac3dec->bit_stream.buffer >> (32 - 4); group_code = p_ac3dec->bit_stream.buffer >> (32 - 4);
DumpBits (&(p_ac3dec->bit_stream), 4); DumpBits (&(p_ac3dec->bit_stream), 4);
if (group_code >= 15) { if (group_code >= 15)
{
intf_ErrMsg ( "ac3dec error: invalid mantissa" ); intf_ErrMsg ( "ac3dec error: invalid mantissa" );
} }
...@@ -288,19 +327,25 @@ static __inline__ void uncouple_channel (ac3dec_t * p_ac3dec, u32 ch) ...@@ -288,19 +327,25 @@ static __inline__ void uncouple_channel (ac3dec_t * p_ac3dec, u32 ch)
u32 cpl_exp_tmp; u32 cpl_exp_tmp;
u32 cpl_mant_tmp; u32 cpl_mant_tmp;
for (i = p_ac3dec->audblk.cplstrtmant; i < p_ac3dec->audblk.cplendmant;) { for (i = p_ac3dec->audblk.cplstrtmant; i < p_ac3dec->audblk.cplendmant;)
if (!p_ac3dec->audblk.cplbndstrc[bnd]) { {
if (!p_ac3dec->audblk.cplbndstrc[bnd])
{
cpl_exp_tmp = p_ac3dec->audblk.cplcoexp[ch][bnd] + 3 * p_ac3dec->audblk.mstrcplco[ch]; cpl_exp_tmp = p_ac3dec->audblk.cplcoexp[ch][bnd] + 3 * p_ac3dec->audblk.mstrcplco[ch];
if (p_ac3dec->audblk.cplcoexp[ch][bnd] == 15) if (p_ac3dec->audblk.cplcoexp[ch][bnd] == 15)
{
cpl_mant_tmp = (p_ac3dec->audblk.cplcomant[ch][bnd]) << 12; cpl_mant_tmp = (p_ac3dec->audblk.cplcomant[ch][bnd]) << 12;
}
else else
{
cpl_mant_tmp = ((0x10) | p_ac3dec->audblk.cplcomant[ch][bnd]) << 11; cpl_mant_tmp = ((0x10) | p_ac3dec->audblk.cplcomant[ch][bnd]) << 11;
}
cpl_coord = ((s16)cpl_mant_tmp) * exp_lut[cpl_exp_tmp]; cpl_coord = ((s16)cpl_mant_tmp) * exp_lut[cpl_exp_tmp];
} }
bnd++; bnd++;
for (j=0;j < 12; j++) { for (j=0;j < 12; j++)
{
p_ac3dec->coeffs.fbw[ch][i] = cpl_coord * p_ac3dec->audblk.cplfbw[i]; p_ac3dec->coeffs.fbw[ch][i] = cpl_coord * p_ac3dec->audblk.cplfbw[i];
i++; i++;
} }
...@@ -315,44 +360,59 @@ void mantissa_unpack (ac3dec_t * p_ac3dec) ...@@ -315,44 +360,59 @@ void mantissa_unpack (ac3dec_t * p_ac3dec)
q_2_pointer = -1; q_2_pointer = -1;
q_4_pointer = -1; q_4_pointer = -1;
if (p_ac3dec->audblk.cplinu) { if (p_ac3dec->audblk.cplinu)
{
/* 1 */ /* 1 */
for (i = 0; !p_ac3dec->audblk.chincpl[i]; i++) { for (i = 0; !p_ac3dec->audblk.chincpl[i]; i++)
for (j = 0; j < p_ac3dec->audblk.endmant[i]; j++) { {
for (j = 0; j < p_ac3dec->audblk.endmant[i]; j++)
{
p_ac3dec->coeffs.fbw[i][j] = float_get (p_ac3dec, p_ac3dec->audblk.fbw_bap[i][j], p_ac3dec->audblk.fbw_exp[i][j]); p_ac3dec->coeffs.fbw[i][j] = float_get (p_ac3dec, p_ac3dec->audblk.fbw_bap[i][j], p_ac3dec->audblk.fbw_exp[i][j]);
} }
} }
/* 2 */ /* 2 */
for (j = 0; j < p_ac3dec->audblk.endmant[i]; j++) { for (j = 0; j < p_ac3dec->audblk.endmant[i]; j++)
{
p_ac3dec->coeffs.fbw[i][j] = float_get (p_ac3dec, p_ac3dec->audblk.fbw_bap[i][j], p_ac3dec->audblk.fbw_exp[i][j]); p_ac3dec->coeffs.fbw[i][j] = float_get (p_ac3dec, p_ac3dec->audblk.fbw_bap[i][j], p_ac3dec->audblk.fbw_exp[i][j]);
} }
for (j = p_ac3dec->audblk.cplstrtmant; j < p_ac3dec->audblk.cplendmant; j++) { for (j = p_ac3dec->audblk.cplstrtmant; j < p_ac3dec->audblk.cplendmant; j++)
{
p_ac3dec->audblk.cplfbw[j] = float_get (p_ac3dec, p_ac3dec->audblk.cpl_bap[j], p_ac3dec->audblk.cpl_exp[j]); p_ac3dec->audblk.cplfbw[j] = float_get (p_ac3dec, p_ac3dec->audblk.cpl_bap[j], p_ac3dec->audblk.cpl_exp[j]);
} }
uncouple_channel (p_ac3dec, i); uncouple_channel (p_ac3dec, i);
/* 3 */ /* 3 */
for (i++; i < p_ac3dec->bsi.nfchans; i++) { for (i++; i < p_ac3dec->bsi.nfchans; i++)
for (j = 0; j < p_ac3dec->audblk.endmant[i]; j++) { {
for (j = 0; j < p_ac3dec->audblk.endmant[i]; j++)
{
p_ac3dec->coeffs.fbw[i][j] = float_get (p_ac3dec, p_ac3dec->audblk.fbw_bap[i][j], p_ac3dec->audblk.fbw_exp[i][j]); p_ac3dec->coeffs.fbw[i][j] = float_get (p_ac3dec, p_ac3dec->audblk.fbw_bap[i][j], p_ac3dec->audblk.fbw_exp[i][j]);
} }
if (p_ac3dec->audblk.chincpl[i]) { if (p_ac3dec->audblk.chincpl[i])
{
uncouple_channel (p_ac3dec, i); uncouple_channel (p_ac3dec, i);
} }
} }
} else { }
for (i = 0; i < p_ac3dec->bsi.nfchans; i++) { else
for (j = 0; j < p_ac3dec->audblk.endmant[i]; j++) { {
for (i = 0; i < p_ac3dec->bsi.nfchans; i++)
{
for (j = 0; j < p_ac3dec->audblk.endmant[i]; j++)
{
p_ac3dec->coeffs.fbw[i][j] = float_get (p_ac3dec, p_ac3dec->audblk.fbw_bap[i][j], p_ac3dec->audblk.fbw_exp[i][j]); p_ac3dec->coeffs.fbw[i][j] = float_get (p_ac3dec, p_ac3dec->audblk.fbw_bap[i][j], p_ac3dec->audblk.fbw_exp[i][j]);
} }
} }
} }
if (p_ac3dec->bsi.lfeon) { if (p_ac3dec->bsi.lfeon)
{
/* There are always 7 mantissas for lfe, no dither for lfe */ /* There are always 7 mantissas for lfe, no dither for lfe */
for (j = 0; j < 7; j++) { for (j = 0; j < 7; j++)
{
p_ac3dec->coeffs.lfe[j] = float_get (p_ac3dec, p_ac3dec->audblk.lfe_bap[j], p_ac3dec->audblk.lfe_exp[j]); p_ac3dec->coeffs.lfe[j] = float_get (p_ac3dec, p_ac3dec->audblk.lfe_bap[j], p_ac3dec->audblk.lfe_exp[j]);
} }
} }
} }
...@@ -29,12 +29,14 @@ ...@@ -29,12 +29,14 @@
/* Misc LUT */ /* Misc LUT */
static u16 nfchans[] = { 2, 1, 2, 3, 3, 4, 4, 5 }; static u16 nfchans[] = { 2, 1, 2, 3, 3, 4, 4, 5 };
struct frmsize_s { struct frmsize_s
{
u16 bit_rate; u16 bit_rate;
u16 frm_size[3]; u16 frm_size[3];
}; };
static struct frmsize_s frmsizecod_tbl[] = { static struct frmsize_s frmsizecod_tbl[] =
{
{ 32 ,{64 ,69 ,96 } }, { 32 ,{64 ,69 ,96 } },
{ 32 ,{64 ,70 ,96 } }, { 32 ,{64 ,70 ,96 } },
{ 40 ,{80 ,87 ,120 } }, { 40 ,{80 ,87 ,120 } },
...@@ -89,7 +91,9 @@ int ac3_sync_frame (ac3dec_t * p_ac3dec, ac3_sync_info_t * p_sync_info) ...@@ -89,7 +91,9 @@ int ac3_sync_frame (ac3dec_t * p_ac3dec, ac3_sync_info_t * p_sync_info)
buf = p_ac3dec->bit_stream.buffer >> (32 - 16); buf = p_ac3dec->bit_stream.buffer >> (32 - 16);
DumpBits (&(p_ac3dec->bit_stream), 16); DumpBits (&(p_ac3dec->bit_stream), 16);
if (buf != 0x0b77) if (buf != 0x0b77)
{
return 1; return 1;
}
/* Get crc1 - we don't actually use this data though */ /* Get crc1 - we don't actually use this data though */
NeedBits (&(p_ac3dec->bit_stream), 16); NeedBits (&(p_ac3dec->bit_stream), 16);
...@@ -101,15 +105,20 @@ int ac3_sync_frame (ac3dec_t * p_ac3dec, ac3_sync_info_t * p_sync_info) ...@@ -101,15 +105,20 @@ int ac3_sync_frame (ac3dec_t * p_ac3dec, ac3_sync_info_t * p_sync_info)
DumpBits (&(p_ac3dec->bit_stream), 2); DumpBits (&(p_ac3dec->bit_stream), 2);
if (p_ac3dec->syncinfo.fscod >= 3) if (p_ac3dec->syncinfo.fscod >= 3)
{
return 1; return 1;
}
/* Get the frame size code */ /* Get the frame size code */
NeedBits (&(p_ac3dec->bit_stream), 6); NeedBits (&(p_ac3dec->bit_stream), 6);
p_ac3dec->syncinfo.frmsizecod = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 6)); p_ac3dec->syncinfo.frmsizecod =
(u16)(p_ac3dec->bit_stream.buffer >> (32 - 6));
DumpBits (&(p_ac3dec->bit_stream), 6); DumpBits (&(p_ac3dec->bit_stream), 6);
if (p_ac3dec->syncinfo.frmsizecod >= 38) if (p_ac3dec->syncinfo.frmsizecod >= 38)
{
return 1; return 1;
}
p_sync_info->bit_rate = frmsizecod_tbl[p_ac3dec->syncinfo.frmsizecod].bit_rate; p_sync_info->bit_rate = frmsizecod_tbl[p_ac3dec->syncinfo.frmsizecod].bit_rate;
...@@ -134,7 +143,9 @@ int parse_bsi (ac3dec_t * p_ac3dec) ...@@ -134,7 +143,9 @@ int parse_bsi (ac3dec_t * p_ac3dec)
DumpBits (&(p_ac3dec->bit_stream), 5); DumpBits (&(p_ac3dec->bit_stream), 5);
if (p_ac3dec->bsi.bsid > 8) if (p_ac3dec->bsi.bsid > 8)
{
return 1; return 1;
}
/* Get the audio service provided by the steram */ /* Get the audio service provided by the steram */
NeedBits (&(p_ac3dec->bit_stream), 3); NeedBits (&(p_ac3dec->bit_stream), 3);
...@@ -150,21 +161,24 @@ int parse_bsi (ac3dec_t * p_ac3dec) ...@@ -150,21 +161,24 @@ int parse_bsi (ac3dec_t * p_ac3dec)
p_ac3dec->bsi.nfchans = nfchans[p_ac3dec->bsi.acmod]; p_ac3dec->bsi.nfchans = nfchans[p_ac3dec->bsi.acmod];
/* If it is in use, get the centre channel mix level */ /* If it is in use, get the centre channel mix level */
if ((p_ac3dec->bsi.acmod & 0x1) && (p_ac3dec->bsi.acmod != 0x1)) { if ((p_ac3dec->bsi.acmod & 0x1) && (p_ac3dec->bsi.acmod != 0x1))
{
NeedBits (&(p_ac3dec->bit_stream), 2); NeedBits (&(p_ac3dec->bit_stream), 2);
p_ac3dec->bsi.cmixlev = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 2)); p_ac3dec->bsi.cmixlev = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 2));
DumpBits (&(p_ac3dec->bit_stream), 2); DumpBits (&(p_ac3dec->bit_stream), 2);
} }
/* If it is in use, get the surround channel mix level */ /* If it is in use, get the surround channel mix level */
if (p_ac3dec->bsi.acmod & 0x4) { if (p_ac3dec->bsi.acmod & 0x4)
{
NeedBits (&(p_ac3dec->bit_stream), 2); NeedBits (&(p_ac3dec->bit_stream), 2);
p_ac3dec->bsi.surmixlev = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 2)); p_ac3dec->bsi.surmixlev = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 2));
DumpBits (&(p_ac3dec->bit_stream), 2); DumpBits (&(p_ac3dec->bit_stream), 2);
} }
/* Get the dolby surround mode if in 2/0 mode */ /* Get the dolby surround mode if in 2/0 mode */
if (p_ac3dec->bsi.acmod == 0x2) { if (p_ac3dec->bsi.acmod == 0x2)
{
NeedBits (&(p_ac3dec->bit_stream), 2); NeedBits (&(p_ac3dec->bit_stream), 2);
p_ac3dec->bsi.dsurmod = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 2)); p_ac3dec->bsi.dsurmod = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 2));
DumpBits (&(p_ac3dec->bit_stream), 2); DumpBits (&(p_ac3dec->bit_stream), 2);
...@@ -184,7 +198,8 @@ int parse_bsi (ac3dec_t * p_ac3dec) ...@@ -184,7 +198,8 @@ int parse_bsi (ac3dec_t * p_ac3dec)
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
p_ac3dec->bsi.compre = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->bsi.compre = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
if (p_ac3dec->bsi.compre) { if (p_ac3dec->bsi.compre)
{
/* Get compression gain */ /* Get compression gain */
NeedBits (&(p_ac3dec->bit_stream), 8); NeedBits (&(p_ac3dec->bit_stream), 8);
p_ac3dec->bsi.compr = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 8)); p_ac3dec->bsi.compr = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 8));
...@@ -195,7 +210,8 @@ int parse_bsi (ac3dec_t * p_ac3dec) ...@@ -195,7 +210,8 @@ int parse_bsi (ac3dec_t * p_ac3dec)
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
p_ac3dec->bsi.langcode = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->bsi.langcode = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
if (p_ac3dec->bsi.langcode) { if (p_ac3dec->bsi.langcode)
{
/* Get langauge code */ /* Get langauge code */
NeedBits (&(p_ac3dec->bit_stream), 8); NeedBits (&(p_ac3dec->bit_stream), 8);
p_ac3dec->bsi.langcod = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 8)); p_ac3dec->bsi.langcod = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 8));
...@@ -206,7 +222,8 @@ int parse_bsi (ac3dec_t * p_ac3dec) ...@@ -206,7 +222,8 @@ int parse_bsi (ac3dec_t * p_ac3dec)
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
p_ac3dec->bsi.audprodie = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->bsi.audprodie = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
if (p_ac3dec->bsi.audprodie) { if (p_ac3dec->bsi.audprodie)
{
/* Get mix level */ /* Get mix level */
NeedBits (&(p_ac3dec->bit_stream), 5); NeedBits (&(p_ac3dec->bit_stream), 5);
p_ac3dec->bsi.mixlevel = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 5)); p_ac3dec->bsi.mixlevel = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 5));
...@@ -219,7 +236,8 @@ int parse_bsi (ac3dec_t * p_ac3dec) ...@@ -219,7 +236,8 @@ int parse_bsi (ac3dec_t * p_ac3dec)
} }
/* If we're in dual mono mode then get some extra info */ /* If we're in dual mono mode then get some extra info */
if (p_ac3dec->bsi.acmod ==0) { if (p_ac3dec->bsi.acmod ==0)
{
/* Get the dialogue normalization level two */ /* Get the dialogue normalization level two */
NeedBits (&(p_ac3dec->bit_stream), 5); NeedBits (&(p_ac3dec->bit_stream), 5);
p_ac3dec->bsi.dialnorm2 = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 5)); p_ac3dec->bsi.dialnorm2 = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 5));
...@@ -229,7 +247,8 @@ int parse_bsi (ac3dec_t * p_ac3dec) ...@@ -229,7 +247,8 @@ int parse_bsi (ac3dec_t * p_ac3dec)
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
p_ac3dec->bsi.compr2e = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->bsi.compr2e = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
if (p_ac3dec->bsi.compr2e) { if (p_ac3dec->bsi.compr2e)
{
/* Get compression gain two */ /* Get compression gain two */
NeedBits (&(p_ac3dec->bit_stream), 8); NeedBits (&(p_ac3dec->bit_stream), 8);
p_ac3dec->bsi.compr2 = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 8)); p_ac3dec->bsi.compr2 = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 8));
...@@ -240,7 +259,8 @@ int parse_bsi (ac3dec_t * p_ac3dec) ...@@ -240,7 +259,8 @@ int parse_bsi (ac3dec_t * p_ac3dec)
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
p_ac3dec->bsi.langcod2e = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->bsi.langcod2e = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
if (p_ac3dec->bsi.langcod2e) { if (p_ac3dec->bsi.langcod2e)
{
/* Get langauge code two */ /* Get langauge code two */
NeedBits (&(p_ac3dec->bit_stream), 8); NeedBits (&(p_ac3dec->bit_stream), 8);
p_ac3dec->bsi.langcod2 = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 8)); p_ac3dec->bsi.langcod2 = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 8));
...@@ -251,7 +271,8 @@ int parse_bsi (ac3dec_t * p_ac3dec) ...@@ -251,7 +271,8 @@ int parse_bsi (ac3dec_t * p_ac3dec)
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
p_ac3dec->bsi.audprodi2e = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->bsi.audprodi2e = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
if (p_ac3dec->bsi.audprodi2e) { if (p_ac3dec->bsi.audprodi2e)
{
/* Get mix level two */ /* Get mix level two */
NeedBits (&(p_ac3dec->bit_stream), 5); NeedBits (&(p_ac3dec->bit_stream), 5);
p_ac3dec->bsi.mixlevel2 = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 5)); p_ac3dec->bsi.mixlevel2 = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 5));
...@@ -279,7 +300,8 @@ int parse_bsi (ac3dec_t * p_ac3dec) ...@@ -279,7 +300,8 @@ int parse_bsi (ac3dec_t * p_ac3dec)
p_ac3dec->bsi.timecod1e = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->bsi.timecod1e = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
if (p_ac3dec->bsi.timecod1e) { if (p_ac3dec->bsi.timecod1e)
{
NeedBits (&(p_ac3dec->bit_stream), 14); NeedBits (&(p_ac3dec->bit_stream), 14);
p_ac3dec->bsi.timecod1 = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 14)); p_ac3dec->bsi.timecod1 = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 14));
DumpBits (&(p_ac3dec->bit_stream), 14); DumpBits (&(p_ac3dec->bit_stream), 14);
...@@ -290,7 +312,8 @@ int parse_bsi (ac3dec_t * p_ac3dec) ...@@ -290,7 +312,8 @@ int parse_bsi (ac3dec_t * p_ac3dec)
p_ac3dec->bsi.timecod2e = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->bsi.timecod2e = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
if (p_ac3dec->bsi.timecod2e) { if (p_ac3dec->bsi.timecod2e)
{
NeedBits (&(p_ac3dec->bit_stream), 14); NeedBits (&(p_ac3dec->bit_stream), 14);
p_ac3dec->bsi.timecod2 = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 14)); p_ac3dec->bsi.timecod2 = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 14));
DumpBits (&(p_ac3dec->bit_stream), 14); DumpBits (&(p_ac3dec->bit_stream), 14);
...@@ -301,14 +324,16 @@ int parse_bsi (ac3dec_t * p_ac3dec) ...@@ -301,14 +324,16 @@ int parse_bsi (ac3dec_t * p_ac3dec)
p_ac3dec->bsi.addbsie = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->bsi.addbsie = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
if (p_ac3dec->bsi.addbsie) { if (p_ac3dec->bsi.addbsie)
{
/* Get how much info is there */ /* Get how much info is there */
NeedBits (&(p_ac3dec->bit_stream), 6); NeedBits (&(p_ac3dec->bit_stream), 6);
p_ac3dec->bsi.addbsil = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 6)); p_ac3dec->bsi.addbsil = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 6));
DumpBits (&(p_ac3dec->bit_stream), 6); DumpBits (&(p_ac3dec->bit_stream), 6);
/* Get the additional info */ /* Get the additional info */
for (i=0;i<(p_ac3dec->bsi.addbsil + 1);i++) { for (i=0;i<(p_ac3dec->bsi.addbsil + 1);i++)
{
NeedBits (&(p_ac3dec->bit_stream), 8); NeedBits (&(p_ac3dec->bit_stream), 8);
p_ac3dec->bsi.addbsi[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 8)); p_ac3dec->bsi.addbsi[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 8));
DumpBits (&(p_ac3dec->bit_stream), 8); DumpBits (&(p_ac3dec->bit_stream), 8);
...@@ -323,14 +348,16 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum) ...@@ -323,14 +348,16 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum)
{ {
int i, j; int i, j;
for (i=0; i < p_ac3dec->bsi.nfchans; i++) { for (i=0; i < p_ac3dec->bsi.nfchans; i++)
{
/* Is this channel an interleaved 256 + 256 block ? */ /* Is this channel an interleaved 256 + 256 block ? */
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
p_ac3dec->audblk.blksw[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->audblk.blksw[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
} }
for (i=0; i < p_ac3dec->bsi.nfchans; i++) { for (i=0; i < p_ac3dec->bsi.nfchans; i++)
{
/* Should we dither this channel? */ /* Should we dither this channel? */
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
p_ac3dec->audblk.dithflag[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->audblk.dithflag[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
...@@ -341,7 +368,8 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum) ...@@ -341,7 +368,8 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum)
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
p_ac3dec->audblk.dynrnge = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->audblk.dynrnge = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
if (p_ac3dec->audblk.dynrnge) { if (p_ac3dec->audblk.dynrnge)
{
/* Get dynamic range info */ /* Get dynamic range info */
NeedBits (&(p_ac3dec->bit_stream), 8); NeedBits (&(p_ac3dec->bit_stream), 8);
p_ac3dec->audblk.dynrng = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 8)); p_ac3dec->audblk.dynrng = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 8));
...@@ -349,12 +377,14 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum) ...@@ -349,12 +377,14 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum)
} }
/* If we're in dual mono mode then get the second channel DR info */ /* If we're in dual mono mode then get the second channel DR info */
if (p_ac3dec->bsi.acmod == 0) { if (p_ac3dec->bsi.acmod == 0)
{
/* Does dynamic range control two exist? */ /* Does dynamic range control two exist? */
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
p_ac3dec->audblk.dynrng2e = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->audblk.dynrng2e = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
if (p_ac3dec->audblk.dynrng2e) { if (p_ac3dec->audblk.dynrng2e)
{
/* Get dynamic range info */ /* Get dynamic range info */
NeedBits (&(p_ac3dec->bit_stream), 8); NeedBits (&(p_ac3dec->bit_stream), 8);
p_ac3dec->audblk.dynrng2 = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 8)); p_ac3dec->audblk.dynrng2 = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 8));
...@@ -368,28 +398,38 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum) ...@@ -368,28 +398,38 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum)
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
if ((!blknum) && (!p_ac3dec->audblk.cplstre)) if ((!blknum) && (!p_ac3dec->audblk.cplstre))
{
return 1; return 1;
}
if (p_ac3dec->audblk.cplstre) { if (p_ac3dec->audblk.cplstre)
{
/* Is coupling turned on? */ /* Is coupling turned on? */
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
p_ac3dec->audblk.cplinu = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->audblk.cplinu = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
if (p_ac3dec->audblk.cplinu) { if (p_ac3dec->audblk.cplinu)
{
int nb_coupled_channels; int nb_coupled_channels;
nb_coupled_channels = 0; nb_coupled_channels = 0;
for (i=0; i < p_ac3dec->bsi.nfchans; i++) { for (i=0; i < p_ac3dec->bsi.nfchans; i++)
{
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
p_ac3dec->audblk.chincpl[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->audblk.chincpl[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
if (p_ac3dec->audblk.chincpl[i]) if (p_ac3dec->audblk.chincpl[i])
{
nb_coupled_channels++; nb_coupled_channels++;
} }
}
if (nb_coupled_channels < 2) if (nb_coupled_channels < 2)
{
return 1; return 1;
}
if (p_ac3dec->bsi.acmod == 0x2) { if (p_ac3dec->bsi.acmod == 0x2)
{
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
p_ac3dec->audblk.phsflginu = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->audblk.phsflginu = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
...@@ -402,7 +442,9 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum) ...@@ -402,7 +442,9 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum)
DumpBits (&(p_ac3dec->bit_stream), 4); DumpBits (&(p_ac3dec->bit_stream), 4);
if (p_ac3dec->audblk.cplbegf > p_ac3dec->audblk.cplendf + 2) if (p_ac3dec->audblk.cplbegf > p_ac3dec->audblk.cplendf + 2)
{
return 1; return 1;
}
p_ac3dec->audblk.ncplsubnd = (p_ac3dec->audblk.cplendf + 2) - p_ac3dec->audblk.cplbegf + 1; p_ac3dec->audblk.ncplsubnd = (p_ac3dec->audblk.cplendf + 2) - p_ac3dec->audblk.cplbegf + 1;
...@@ -414,7 +456,8 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum) ...@@ -414,7 +456,8 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum)
* band */ * band */
p_ac3dec->audblk.ncplbnd = p_ac3dec->audblk.ncplsubnd; p_ac3dec->audblk.ncplbnd = p_ac3dec->audblk.ncplsubnd;
for (i=1; i< p_ac3dec->audblk.ncplsubnd; i++) { for (i=1; i< p_ac3dec->audblk.ncplsubnd; i++)
{
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
p_ac3dec->audblk.cplbndstrc[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->audblk.cplbndstrc[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
...@@ -423,11 +466,15 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum) ...@@ -423,11 +466,15 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum)
} }
} }
if (p_ac3dec->audblk.cplinu) { if (p_ac3dec->audblk.cplinu)
{
/* Loop through all the channels and get their coupling co-ords */ /* Loop through all the channels and get their coupling co-ords */
for (i=0; i < p_ac3dec->bsi.nfchans;i++) { for (i=0; i < p_ac3dec->bsi.nfchans;i++)
{
if (!p_ac3dec->audblk.chincpl[i]) if (!p_ac3dec->audblk.chincpl[i])
{
continue; continue;
}
/* Is there new coupling co-ordinate info? */ /* Is there new coupling co-ordinate info? */
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
...@@ -435,13 +482,17 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum) ...@@ -435,13 +482,17 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum)
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
if ((!blknum) && (!p_ac3dec->audblk.cplcoe[i])) if ((!blknum) && (!p_ac3dec->audblk.cplcoe[i]))
{
return 1; return 1;
}
if (p_ac3dec->audblk.cplcoe[i]) { if (p_ac3dec->audblk.cplcoe[i])
{
NeedBits (&(p_ac3dec->bit_stream), 2); NeedBits (&(p_ac3dec->bit_stream), 2);
p_ac3dec->audblk.mstrcplco[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 2)); p_ac3dec->audblk.mstrcplco[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 2));
DumpBits (&(p_ac3dec->bit_stream), 2); DumpBits (&(p_ac3dec->bit_stream), 2);
for (j=0;j < p_ac3dec->audblk.ncplbnd; j++) { for (j=0;j < p_ac3dec->audblk.ncplbnd; j++)
{
NeedBits (&(p_ac3dec->bit_stream), 4); NeedBits (&(p_ac3dec->bit_stream), 4);
p_ac3dec->audblk.cplcoexp[i][j] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 4)); p_ac3dec->audblk.cplcoexp[i][j] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 4));
DumpBits (&(p_ac3dec->bit_stream), 4); DumpBits (&(p_ac3dec->bit_stream), 4);
...@@ -454,8 +505,10 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum) ...@@ -454,8 +505,10 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum)
/* If we're in dual mono mode, there's going to be some phase info */ /* If we're in dual mono mode, there's going to be some phase info */
if ((p_ac3dec->bsi.acmod == 0x2) && p_ac3dec->audblk.phsflginu && if ((p_ac3dec->bsi.acmod == 0x2) && p_ac3dec->audblk.phsflginu &&
(p_ac3dec->audblk.cplcoe[0] || p_ac3dec->audblk.cplcoe[1])) { (p_ac3dec->audblk.cplcoe[0] || p_ac3dec->audblk.cplcoe[1]))
for (j=0; j < p_ac3dec->audblk.ncplbnd; j++) { {
for (j=0; j < p_ac3dec->audblk.ncplbnd; j++)
{
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
p_ac3dec->audblk.phsflg[j] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->audblk.phsflg[j] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
...@@ -465,44 +518,57 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum) ...@@ -465,44 +518,57 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum)
} }
/* If we're in dual mono mode, there may be a rematrix strategy */ /* If we're in dual mono mode, there may be a rematrix strategy */
if (p_ac3dec->bsi.acmod == 0x2) { if (p_ac3dec->bsi.acmod == 0x2)
{
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
p_ac3dec->audblk.rematstr = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->audblk.rematstr = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
if ((!blknum) && (!p_ac3dec->audblk.rematstr)) if ((!blknum) && (!p_ac3dec->audblk.rematstr))
{
return 1; return 1;
}
if (p_ac3dec->audblk.rematstr) { if (p_ac3dec->audblk.rematstr)
if (p_ac3dec->audblk.cplinu == 0) { {
for (i = 0; i < 4; i++) { if (p_ac3dec->audblk.cplinu == 0)
{
for (i = 0; i < 4; i++)
{
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
p_ac3dec->audblk.rematflg[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->audblk.rematflg[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
} }
} }
if ((p_ac3dec->audblk.cplbegf > 2) && p_ac3dec->audblk.cplinu) { if ((p_ac3dec->audblk.cplbegf > 2) && p_ac3dec->audblk.cplinu)
for (i = 0; i < 4; i++) { {
for (i = 0; i < 4; i++)
{
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
p_ac3dec->audblk.rematflg[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->audblk.rematflg[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
} }
} }
if ((p_ac3dec->audblk.cplbegf <= 2) && p_ac3dec->audblk.cplinu) { if ((p_ac3dec->audblk.cplbegf <= 2) && p_ac3dec->audblk.cplinu)
for (i = 0; i < 3; i++) { {
for (i = 0; i < 3; i++)
{
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
p_ac3dec->audblk.rematflg[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->audblk.rematflg[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
} }
} }
if ((p_ac3dec->audblk.cplbegf == 0) && p_ac3dec->audblk.cplinu) if ((p_ac3dec->audblk.cplbegf == 0) && p_ac3dec->audblk.cplinu)
for (i = 0; i < 2; i++) { {
for (i = 0; i < 2; i++)
{
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
p_ac3dec->audblk.rematflg[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->audblk.rematflg[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
} }
} }
} }
}
if (p_ac3dec->audblk.cplinu) if (p_ac3dec->audblk.cplinu)
{ {
...@@ -512,49 +578,68 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum) ...@@ -512,49 +578,68 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum)
DumpBits (&(p_ac3dec->bit_stream), 2); DumpBits (&(p_ac3dec->bit_stream), 2);
if ((!blknum) && (p_ac3dec->audblk.cplexpstr == EXP_REUSE)) if ((!blknum) && (p_ac3dec->audblk.cplexpstr == EXP_REUSE))
{
return 1; return 1;
}
if (p_ac3dec->audblk.cplexpstr==0) if (p_ac3dec->audblk.cplexpstr==0)
{
p_ac3dec->audblk.ncplgrps = 0; p_ac3dec->audblk.ncplgrps = 0;
}
else else
{
p_ac3dec->audblk.ncplgrps = (p_ac3dec->audblk.cplendmant - p_ac3dec->audblk.cplstrtmant) / p_ac3dec->audblk.ncplgrps = (p_ac3dec->audblk.cplendmant - p_ac3dec->audblk.cplstrtmant) /
(3 << (p_ac3dec->audblk.cplexpstr-1)); (3 << (p_ac3dec->audblk.cplexpstr-1));
}
} }
for (i = 0; i < p_ac3dec->bsi.nfchans; i++) { for (i = 0; i < p_ac3dec->bsi.nfchans; i++)
{
NeedBits (&(p_ac3dec->bit_stream), 2); NeedBits (&(p_ac3dec->bit_stream), 2);
p_ac3dec->audblk.chexpstr[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 2)); p_ac3dec->audblk.chexpstr[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 2));
DumpBits (&(p_ac3dec->bit_stream), 2); DumpBits (&(p_ac3dec->bit_stream), 2);
if ((!blknum) && (p_ac3dec->audblk.chexpstr[i] == EXP_REUSE)) if ((!blknum) && (p_ac3dec->audblk.chexpstr[i] == EXP_REUSE))
{
return 1; return 1;
} }
}
/* Get the exponent strategy for lfe channel */ /* Get the exponent strategy for lfe channel */
if (p_ac3dec->bsi.lfeon) { if (p_ac3dec->bsi.lfeon)
{
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
p_ac3dec->audblk.lfeexpstr = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->audblk.lfeexpstr = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
if ((!blknum) && (p_ac3dec->audblk.lfeexpstr == EXP_REUSE)) if ((!blknum) && (p_ac3dec->audblk.lfeexpstr == EXP_REUSE))
{
return 1; return 1;
} }
}
/* Determine the bandwidths of all the fbw channels */ /* Determine the bandwidths of all the fbw channels */
for (i = 0; i < p_ac3dec->bsi.nfchans; i++) { for (i = 0; i < p_ac3dec->bsi.nfchans; i++)
{
u16 grp_size; u16 grp_size;
if (p_ac3dec->audblk.chexpstr[i] != EXP_REUSE) { if (p_ac3dec->audblk.chexpstr[i] != EXP_REUSE)
if (p_ac3dec->audblk.cplinu && p_ac3dec->audblk.chincpl[i]) { {
if (p_ac3dec->audblk.cplinu && p_ac3dec->audblk.chincpl[i])
{
p_ac3dec->audblk.endmant[i] = p_ac3dec->audblk.cplstrtmant; p_ac3dec->audblk.endmant[i] = p_ac3dec->audblk.cplstrtmant;
} else { }
else
{
NeedBits (&(p_ac3dec->bit_stream), 6); NeedBits (&(p_ac3dec->bit_stream), 6);
p_ac3dec->audblk.chbwcod[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 6)); p_ac3dec->audblk.chbwcod[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 6));
DumpBits (&(p_ac3dec->bit_stream), 6); DumpBits (&(p_ac3dec->bit_stream), 6);
if (p_ac3dec->audblk.chbwcod[i] > 60) if (p_ac3dec->audblk.chbwcod[i] > 60)
{
return 1; return 1;
}
p_ac3dec->audblk.endmant[i] = ((p_ac3dec->audblk.chbwcod[i] + 12) * 3) + 37; p_ac3dec->audblk.endmant[i] = ((p_ac3dec->audblk.chbwcod[i] + 12) * 3) + 37;
} }
...@@ -566,33 +651,42 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum) ...@@ -566,33 +651,42 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum)
} }
/* Get the coupling exponents if they exist */ /* Get the coupling exponents if they exist */
if (p_ac3dec->audblk.cplinu && (p_ac3dec->audblk.cplexpstr != EXP_REUSE)) { if (p_ac3dec->audblk.cplinu && (p_ac3dec->audblk.cplexpstr != EXP_REUSE))
{
NeedBits (&(p_ac3dec->bit_stream), 4); NeedBits (&(p_ac3dec->bit_stream), 4);
p_ac3dec->audblk.cplabsexp = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 4)); p_ac3dec->audblk.cplabsexp = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 4));
DumpBits (&(p_ac3dec->bit_stream), 4); DumpBits (&(p_ac3dec->bit_stream), 4);
for (i=0; i< p_ac3dec->audblk.ncplgrps;i++) { for (i=0; i< p_ac3dec->audblk.ncplgrps;i++)
{
NeedBits (&(p_ac3dec->bit_stream), 7); NeedBits (&(p_ac3dec->bit_stream), 7);
p_ac3dec->audblk.cplexps[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 7)); p_ac3dec->audblk.cplexps[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 7));
DumpBits (&(p_ac3dec->bit_stream), 7); DumpBits (&(p_ac3dec->bit_stream), 7);
if (p_ac3dec->audblk.cplexps[i] >= 125) if (p_ac3dec->audblk.cplexps[i] >= 125)
{
return 1; return 1;
} }
} }
}
/* Get the fwb channel exponents */ /* Get the fwb channel exponents */
for (i=0; i < p_ac3dec->bsi.nfchans; i++) { for (i=0; i < p_ac3dec->bsi.nfchans; i++)
if (p_ac3dec->audblk.chexpstr[i] != EXP_REUSE) { {
if (p_ac3dec->audblk.chexpstr[i] != EXP_REUSE)
{
NeedBits (&(p_ac3dec->bit_stream), 4); NeedBits (&(p_ac3dec->bit_stream), 4);
p_ac3dec->audblk.exps[i][0] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 4)); p_ac3dec->audblk.exps[i][0] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 4));
DumpBits (&(p_ac3dec->bit_stream), 4); DumpBits (&(p_ac3dec->bit_stream), 4);
for (j=1; j<=p_ac3dec->audblk.nchgrps[i];j++) { for (j=1; j<=p_ac3dec->audblk.nchgrps[i];j++)
{
NeedBits (&(p_ac3dec->bit_stream), 7); NeedBits (&(p_ac3dec->bit_stream), 7);
p_ac3dec->audblk.exps[i][j] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 7)); p_ac3dec->audblk.exps[i][j] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 7));
DumpBits (&(p_ac3dec->bit_stream), 7); DumpBits (&(p_ac3dec->bit_stream), 7);
if (p_ac3dec->audblk.exps[i][j] >= 125) if (p_ac3dec->audblk.exps[i][j] >= 125)
{
return 1; return 1;
} }
}
NeedBits (&(p_ac3dec->bit_stream), 2); NeedBits (&(p_ac3dec->bit_stream), 2);
p_ac3dec->audblk.gainrng[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 2)); p_ac3dec->audblk.gainrng[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 2));
DumpBits (&(p_ac3dec->bit_stream), 2); DumpBits (&(p_ac3dec->bit_stream), 2);
...@@ -600,7 +694,8 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum) ...@@ -600,7 +694,8 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum)
} }
/* Get the lfe channel exponents */ /* Get the lfe channel exponents */
if (p_ac3dec->bsi.lfeon && (p_ac3dec->audblk.lfeexpstr != EXP_REUSE)) { if (p_ac3dec->bsi.lfeon && (p_ac3dec->audblk.lfeexpstr != EXP_REUSE))
{
NeedBits (&(p_ac3dec->bit_stream), 4); NeedBits (&(p_ac3dec->bit_stream), 4);
p_ac3dec->audblk.lfeexps[0] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 4)); p_ac3dec->audblk.lfeexps[0] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 4));
DumpBits (&(p_ac3dec->bit_stream), 4); DumpBits (&(p_ac3dec->bit_stream), 4);
...@@ -608,13 +703,17 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum) ...@@ -608,13 +703,17 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum)
p_ac3dec->audblk.lfeexps[1] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 7)); p_ac3dec->audblk.lfeexps[1] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 7));
DumpBits (&(p_ac3dec->bit_stream), 7); DumpBits (&(p_ac3dec->bit_stream), 7);
if (p_ac3dec->audblk.lfeexps[1] >= 125) if (p_ac3dec->audblk.lfeexps[1] >= 125)
{
return 1; return 1;
}
NeedBits (&(p_ac3dec->bit_stream), 7); NeedBits (&(p_ac3dec->bit_stream), 7);
p_ac3dec->audblk.lfeexps[2] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 7)); p_ac3dec->audblk.lfeexps[2] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 7));
DumpBits (&(p_ac3dec->bit_stream), 7); DumpBits (&(p_ac3dec->bit_stream), 7);
if (p_ac3dec->audblk.lfeexps[2] >= 125) if (p_ac3dec->audblk.lfeexps[2] >= 125)
{
return 1; return 1;
} }
}
/* Get the parametric bit allocation parameters */ /* Get the parametric bit allocation parameters */
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
...@@ -622,9 +721,12 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum) ...@@ -622,9 +721,12 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum)
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
if ((!blknum) && (!p_ac3dec->audblk.baie)) if ((!blknum) && (!p_ac3dec->audblk.baie))
{
return 1; return 1;
}
if (p_ac3dec->audblk.baie) { if (p_ac3dec->audblk.baie)
{
NeedBits (&(p_ac3dec->bit_stream), 2); NeedBits (&(p_ac3dec->bit_stream), 2);
p_ac3dec->audblk.sdcycod = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 2)); p_ac3dec->audblk.sdcycod = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 2));
DumpBits (&(p_ac3dec->bit_stream), 2); DumpBits (&(p_ac3dec->bit_stream), 2);
...@@ -647,14 +749,18 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum) ...@@ -647,14 +749,18 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum)
p_ac3dec->audblk.snroffste = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->audblk.snroffste = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
if ((!blknum) && (!p_ac3dec->audblk.snroffste)) if ((!blknum) && (!p_ac3dec->audblk.snroffste))
{
return 1; return 1;
}
if (p_ac3dec->audblk.snroffste) { if (p_ac3dec->audblk.snroffste)
{
NeedBits (&(p_ac3dec->bit_stream), 6); NeedBits (&(p_ac3dec->bit_stream), 6);
p_ac3dec->audblk.csnroffst = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 6)); p_ac3dec->audblk.csnroffst = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 6));
DumpBits (&(p_ac3dec->bit_stream), 6); DumpBits (&(p_ac3dec->bit_stream), 6);
if (p_ac3dec->audblk.cplinu) { if (p_ac3dec->audblk.cplinu)
{
NeedBits (&(p_ac3dec->bit_stream), 4); NeedBits (&(p_ac3dec->bit_stream), 4);
p_ac3dec->audblk.cplfsnroffst = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 4)); p_ac3dec->audblk.cplfsnroffst = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 4));
DumpBits (&(p_ac3dec->bit_stream), 4); DumpBits (&(p_ac3dec->bit_stream), 4);
...@@ -663,7 +769,8 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum) ...@@ -663,7 +769,8 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum)
DumpBits (&(p_ac3dec->bit_stream), 3); DumpBits (&(p_ac3dec->bit_stream), 3);
} }
for (i = 0;i < p_ac3dec->bsi.nfchans; i++) { for (i = 0;i < p_ac3dec->bsi.nfchans; i++)
{
NeedBits (&(p_ac3dec->bit_stream), 4); NeedBits (&(p_ac3dec->bit_stream), 4);
p_ac3dec->audblk.fsnroffst[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 4)); p_ac3dec->audblk.fsnroffst[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 4));
DumpBits (&(p_ac3dec->bit_stream), 4); DumpBits (&(p_ac3dec->bit_stream), 4);
...@@ -671,7 +778,8 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum) ...@@ -671,7 +778,8 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum)
p_ac3dec->audblk.fgaincod[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 3)); p_ac3dec->audblk.fgaincod[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 3));
DumpBits (&(p_ac3dec->bit_stream), 3); DumpBits (&(p_ac3dec->bit_stream), 3);
} }
if (p_ac3dec->bsi.lfeon) { if (p_ac3dec->bsi.lfeon)
{
NeedBits (&(p_ac3dec->bit_stream), 4); NeedBits (&(p_ac3dec->bit_stream), 4);
p_ac3dec->audblk.lfefsnroffst = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 4)); p_ac3dec->audblk.lfefsnroffst = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 4));
DumpBits (&(p_ac3dec->bit_stream), 4); DumpBits (&(p_ac3dec->bit_stream), 4);
...@@ -682,14 +790,18 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum) ...@@ -682,14 +790,18 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum)
} }
/* Get coupling leakage info if it exists */ /* Get coupling leakage info if it exists */
if (p_ac3dec->audblk.cplinu) { if (p_ac3dec->audblk.cplinu)
{
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
p_ac3dec->audblk.cplleake = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->audblk.cplleake = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
if ((!blknum) && (!p_ac3dec->audblk.cplleake)) if ((!blknum) && (!p_ac3dec->audblk.cplleake))
{
return 1; return 1;
}
if (p_ac3dec->audblk.cplleake) { if (p_ac3dec->audblk.cplleake)
{
NeedBits (&(p_ac3dec->bit_stream), 3); NeedBits (&(p_ac3dec->bit_stream), 3);
p_ac3dec->audblk.cplfleak = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 3)); p_ac3dec->audblk.cplfleak = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 3));
DumpBits (&(p_ac3dec->bit_stream), 3); DumpBits (&(p_ac3dec->bit_stream), 3);
...@@ -704,28 +816,37 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum) ...@@ -704,28 +816,37 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum)
p_ac3dec->audblk.deltbaie = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->audblk.deltbaie = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
if (p_ac3dec->audblk.deltbaie) { if (p_ac3dec->audblk.deltbaie)
if (p_ac3dec->audblk.cplinu) { {
if (p_ac3dec->audblk.cplinu)
{
NeedBits (&(p_ac3dec->bit_stream), 2); NeedBits (&(p_ac3dec->bit_stream), 2);
p_ac3dec->audblk.cpldeltbae = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 2)); p_ac3dec->audblk.cpldeltbae = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 2));
DumpBits (&(p_ac3dec->bit_stream), 2); DumpBits (&(p_ac3dec->bit_stream), 2);
if (p_ac3dec->audblk.cpldeltbae == 3) if (p_ac3dec->audblk.cpldeltbae == 3)
{
return 1; return 1;
} }
}
for (i = 0;i < p_ac3dec->bsi.nfchans; i++) { for (i = 0;i < p_ac3dec->bsi.nfchans; i++)
{
NeedBits (&(p_ac3dec->bit_stream), 2); NeedBits (&(p_ac3dec->bit_stream), 2);
p_ac3dec->audblk.deltbae[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 2)); p_ac3dec->audblk.deltbae[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 2));
DumpBits (&(p_ac3dec->bit_stream), 2); DumpBits (&(p_ac3dec->bit_stream), 2);
if (p_ac3dec->audblk.deltbae[i] == 3) if (p_ac3dec->audblk.deltbae[i] == 3)
{
return 1; return 1;
} }
}
if (p_ac3dec->audblk.cplinu && (p_ac3dec->audblk.cpldeltbae == DELTA_BIT_NEW)) { if (p_ac3dec->audblk.cplinu && (p_ac3dec->audblk.cpldeltbae == DELTA_BIT_NEW))
{
NeedBits (&(p_ac3dec->bit_stream), 3); NeedBits (&(p_ac3dec->bit_stream), 3);
p_ac3dec->audblk.cpldeltnseg = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 3)); p_ac3dec->audblk.cpldeltnseg = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 3));
DumpBits (&(p_ac3dec->bit_stream), 3); DumpBits (&(p_ac3dec->bit_stream), 3);
for (i = 0;i < p_ac3dec->audblk.cpldeltnseg + 1; i++) { for (i = 0;i < p_ac3dec->audblk.cpldeltnseg + 1; i++)
{
NeedBits (&(p_ac3dec->bit_stream), 5); NeedBits (&(p_ac3dec->bit_stream), 5);
p_ac3dec->audblk.cpldeltoffst[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 5)); p_ac3dec->audblk.cpldeltoffst[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 5));
DumpBits (&(p_ac3dec->bit_stream), 5); DumpBits (&(p_ac3dec->bit_stream), 5);
...@@ -738,14 +859,17 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum) ...@@ -738,14 +859,17 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum)
} }
} }
for (i = 0; i < p_ac3dec->bsi.nfchans; i++) { for (i = 0; i < p_ac3dec->bsi.nfchans; i++)
if (p_ac3dec->audblk.deltbae[i] == DELTA_BIT_NEW) { {
if (p_ac3dec->audblk.deltbae[i] == DELTA_BIT_NEW)
{
NeedBits (&(p_ac3dec->bit_stream), 3); NeedBits (&(p_ac3dec->bit_stream), 3);
p_ac3dec->audblk.deltnseg[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 3)); p_ac3dec->audblk.deltnseg[i] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 3));
DumpBits (&(p_ac3dec->bit_stream), 3); DumpBits (&(p_ac3dec->bit_stream), 3);
// if (p_ac3dec->audblk.deltnseg[i] >= 8) // if (p_ac3dec->audblk.deltnseg[i] >= 8)
// fprintf (stderr, "parse debug: p_ac3dec->audblk.deltnseg[%i] == %i\n", i, p_ac3dec->audblk.deltnseg[i]); // fprintf (stderr, "parse debug: p_ac3dec->audblk.deltnseg[%i] == %i\n", i, p_ac3dec->audblk.deltnseg[i]);
for (j = 0; j < p_ac3dec->audblk.deltnseg[i] + 1; j++) { for (j = 0; j < p_ac3dec->audblk.deltnseg[i] + 1; j++)
{
NeedBits (&(p_ac3dec->bit_stream), 5); NeedBits (&(p_ac3dec->bit_stream), 5);
p_ac3dec->audblk.deltoffst[i][j] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 5)); p_ac3dec->audblk.deltoffst[i][j] = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 5));
DumpBits (&(p_ac3dec->bit_stream), 5); DumpBits (&(p_ac3dec->bit_stream), 5);
...@@ -765,12 +889,14 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum) ...@@ -765,12 +889,14 @@ int parse_audblk (ac3dec_t * p_ac3dec, int blknum)
p_ac3dec->audblk.skiple = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1)); p_ac3dec->audblk.skiple = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 1));
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
if (p_ac3dec->audblk.skiple) { if (p_ac3dec->audblk.skiple)
{
NeedBits (&(p_ac3dec->bit_stream), 9); NeedBits (&(p_ac3dec->bit_stream), 9);
p_ac3dec->audblk.skipl = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 9)); p_ac3dec->audblk.skipl = (u16)(p_ac3dec->bit_stream.buffer >> (32 - 9));
DumpBits (&(p_ac3dec->bit_stream), 9); DumpBits (&(p_ac3dec->bit_stream), 9);
for (i = 0; i < p_ac3dec->audblk.skipl ; i++) { for (i = 0; i < p_ac3dec->audblk.skipl ; i++)
{
NeedBits (&(p_ac3dec->bit_stream), 8); NeedBits (&(p_ac3dec->bit_stream), 8);
DumpBits (&(p_ac3dec->bit_stream), 8); DumpBits (&(p_ac3dec->bit_stream), 8);
} }
...@@ -787,7 +913,8 @@ void parse_auxdata (ac3dec_t * p_ac3dec) ...@@ -787,7 +913,8 @@ void parse_auxdata (ac3dec_t * p_ac3dec)
skip_length = (p_ac3dec->syncinfo.frame_size * 16) - p_ac3dec->bit_stream.total_bits_read - 17 - 1; skip_length = (p_ac3dec->syncinfo.frame_size * 16) - p_ac3dec->bit_stream.total_bits_read - 17 - 1;
// fprintf (stderr, "parse debug: skip_length == %i\n", skip_length); // fprintf (stderr, "parse debug: skip_length == %i\n", skip_length);
for (i = 0; i < skip_length; i++) { for (i = 0; i < skip_length; i++)
{
NeedBits (&(p_ac3dec->bit_stream), 1); NeedBits (&(p_ac3dec->bit_stream), 1);
DumpBits (&(p_ac3dec->bit_stream), 1); DumpBits (&(p_ac3dec->bit_stream), 1);
} }
...@@ -804,3 +931,4 @@ void parse_auxdata (ac3dec_t * p_ac3dec) ...@@ -804,3 +931,4 @@ void parse_auxdata (ac3dec_t * p_ac3dec)
NeedBits (&(p_ac3dec->bit_stream), 16); NeedBits (&(p_ac3dec->bit_stream), 16);
DumpBits (&(p_ac3dec->bit_stream), 16); DumpBits (&(p_ac3dec->bit_stream), 16);
} }
...@@ -51,7 +51,9 @@ int main (void) ...@@ -51,7 +51,9 @@ int main (void)
memset (&decoder, 0, sizeof (decoder)); memset (&decoder, 0, sizeof (decoder));
if (adec_init (&decoder)) if (adec_init (&decoder))
{
return 1; return 1;
}
stream = adec_byte_stream (&decoder); stream = adec_byte_stream (&decoder);
stream->p_byte = NULL; stream->p_byte = NULL;
...@@ -60,17 +62,24 @@ int main (void) ...@@ -60,17 +62,24 @@ int main (void)
framenum = 0; framenum = 0;
while (1) { while (1)
{
int i; int i;
if (adec_sync_frame (&decoder, &sync_info)) if (adec_sync_frame (&decoder, &sync_info))
{
return 1; return 1;
}
if (adec_decode_frame (&decoder, buffer)) if (adec_decode_frame (&decoder, buffer))
{
return 1; return 1;
}
#if 1 #if 1
for (i = 0; i < (2*1152); i++) for (i = 0; i < (2*1152); i++)
{
fprintf ( stderr, "%04X\n",(u16)buffer[i] ); fprintf ( stderr, "%04X\n",(u16)buffer[i] );
}
#endif #endif
} }
...@@ -86,10 +95,13 @@ void adec_byte_stream_next (adec_byte_stream_t * p_byte_stream) ...@@ -86,10 +95,13 @@ void adec_byte_stream_next (adec_byte_stream_t * p_byte_stream)
fd = p_byte_stream->info; fd = p_byte_stream->info;
size = fread (buffer, 1, 1024, fd); size = fread (buffer, 1, 1024, fd);
if (size) { if (size)
{
p_byte_stream->p_byte = buffer; p_byte_stream->p_byte = buffer;
p_byte_stream->p_end = buffer + size; p_byte_stream->p_end = buffer + size;
} else { /* end of stream, read dummy zeroes */ }
else
{ /* end of stream, read dummy zeroes */
p_byte_stream->p_byte = &dummy; p_byte_stream->p_byte = &dummy;
p_byte_stream->p_end = &dummy + 1; p_byte_stream->p_end = &dummy + 1;
} }
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* audio_decoder.h : audio decoder thread interface * audio_decoder.h : audio decoder thread interface
***************************************************************************** *****************************************************************************
* Copyright (C) 1999, 2000 VideoLAN * Copyright (C) 1999, 2000 VideoLAN
* $Id: audio_decoder.h,v 1.3 2000/12/21 13:25:50 massiot Exp $ * $Id: audio_decoder.h,v 1.4 2001/01/05 14:45:47 sam Exp $
* *
* Authors: * Authors:
* Michel Kaempf <maxx@via.ecp.fr> * Michel Kaempf <maxx@via.ecp.fr>
......
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
* decoders. * decoders.
***************************************************************************** *****************************************************************************
* Copyright (C) 1998, 1999, 2000 VideoLAN * Copyright (C) 1998, 1999, 2000 VideoLAN
* $Id: input.c,v 1.64 2000/12/22 13:04:44 sam Exp $ * $Id: input.c,v 1.65 2001/01/05 14:45:47 sam Exp $
* *
* Authors: * Authors:
* *
...@@ -80,7 +80,8 @@ input_thread_t *input_CreateThread ( input_config_t * p_config, int *pi_status ) ...@@ -80,7 +80,8 @@ input_thread_t *input_CreateThread ( input_config_t * p_config, int *pi_status )
p_input = (input_thread_t *)malloc( sizeof(input_thread_t) ); p_input = (input_thread_t *)malloc( sizeof(input_thread_t) );
if( p_input == NULL ) if( p_input == NULL )
{ {
intf_ErrMsg("error: %s", strerror(errno)); intf_ErrMsg( "input error: can't allocate input thread (%s)",
strerror(errno) );
free( p_config ); free( p_config );
return( NULL ); return( NULL );
} }
...@@ -112,7 +113,8 @@ input_thread_t *input_CreateThread ( input_config_t * p_config, int *pi_status ) ...@@ -112,7 +113,8 @@ input_thread_t *input_CreateThread ( input_config_t * p_config, int *pi_status )
if( vlc_thread_create( &p_input->thread_id, "input", (void *) RunThread, if( vlc_thread_create( &p_input->thread_id, "input", (void *) RunThread,
(void *) p_input ) ) (void *) p_input ) )
{ {
intf_ErrMsg("error: %s", strerror(errno) ); intf_ErrMsg( "input error: can't create input thread (%s)",
strerror(errno) );
free( p_input ); free( p_input );
free( p_config ); free( p_config );
return( NULL ); return( NULL );
...@@ -245,7 +247,7 @@ static void InitThread( input_thread_t * p_input ) ...@@ -245,7 +247,7 @@ static void InitThread( input_thread_t * p_input )
case INPUT_METHOD_VLAN_BCAST: /* vlan network method */ case INPUT_METHOD_VLAN_BCAST: /* vlan network method */
/* if( !p_main->b_vlans ) /* if( !p_main->b_vlans )
{ {
intf_ErrMsg("error: vlans are not activated"); intf_ErrMsg("input error: vlans are not activated");
free( p_input ); free( p_input );
return( NULL ); return( NULL );
} */ /* la-lala */ } */ /* la-lala */
...@@ -257,7 +259,8 @@ static void InitThread( input_thread_t * p_input ) ...@@ -257,7 +259,8 @@ static void InitThread( input_thread_t * p_input )
break; break;
#ifdef DEBUG #ifdef DEBUG
default: default:
intf_ErrMsg("Unknow input method"); intf_ErrMsg( "input error: unknow method 0x%.4x",
p_input->p_config->i_method );
free( p_input->p_config ); free( p_input->p_config );
p_input->b_error = 1; p_input->b_error = 1;
break; break;
...@@ -344,24 +347,10 @@ static void FileOpen( input_thread_t * p_input ) ...@@ -344,24 +347,10 @@ static void FileOpen( input_thread_t * p_input )
#define p_config p_input->p_config #define p_config p_input->p_config
if( !strncmp( p_config->p_source, "-", 1 ) )
{
/* stdin */
p_input->i_handle = 0;
vlc_mutex_lock( &p_input->stream.stream_lock );
p_input->stream.b_pace_control = 1;
p_input->stream.b_seekable = 0;
p_input->stream.i_size = 0;
p_input->stream.i_tell = 0;
vlc_mutex_unlock( &p_input->stream.stream_lock );
}
else
{
if( stat( p_config->p_source, &stat_info ) == (-1) ) if( stat( p_config->p_source, &stat_info ) == (-1) )
{ {
intf_ErrMsg("Cannot stat() file %s (%s)", p_config->p_source, intf_ErrMsg( "input error: cannot stat() file %s (%s)",
strerror(errno)); p_config->p_source, strerror(errno));
p_input->b_error = 1; p_input->b_error = 1;
return; return;
} }
...@@ -385,7 +374,8 @@ static void FileOpen( input_thread_t * p_input ) ...@@ -385,7 +374,8 @@ static void FileOpen( input_thread_t * p_input )
else else
{ {
vlc_mutex_unlock( &p_input->stream.stream_lock ); vlc_mutex_unlock( &p_input->stream.stream_lock );
intf_ErrMsg("Unknown file type"); intf_ErrMsg( "input error: unknown file type for %s",
p_config->p_source );
p_input->b_error = 1; p_input->b_error = 1;
return; return;
} }
...@@ -397,11 +387,10 @@ static void FileOpen( input_thread_t * p_input ) ...@@ -397,11 +387,10 @@ static void FileOpen( input_thread_t * p_input )
if( (p_input->i_handle = open( p_config->p_source, if( (p_input->i_handle = open( p_config->p_source,
/*O_NONBLOCK | O_LARGEFILE*/0 )) == (-1) ) /*O_NONBLOCK | O_LARGEFILE*/0 )) == (-1) )
{ {
intf_ErrMsg("Cannot open file (%s)", strerror(errno)); intf_ErrMsg( "input error: cannot open file %s", strerror(errno) );
p_input->b_error = 1; p_input->b_error = 1;
return; return;
} }
}
#undef p_config #undef p_config
} }
...@@ -100,7 +100,8 @@ intf_thread_t* intf_Create( void ) ...@@ -100,7 +100,8 @@ intf_thread_t* intf_Create( void )
p_intf = malloc( sizeof( intf_thread_t ) ); p_intf = malloc( sizeof( intf_thread_t ) );
if( !p_intf ) if( !p_intf )
{ {
intf_ErrMsg("error: %s", strerror( ENOMEM ) ); intf_ErrMsg( "intf error: cannot create interface thread (%s)",
strerror( ENOMEM ) );
return( NULL ); return( NULL );
} }
...@@ -127,7 +128,7 @@ intf_thread_t* intf_Create( void ) ...@@ -127,7 +128,7 @@ intf_thread_t* intf_Create( void )
if( i_best_score == 0 ) if( i_best_score == 0 )
{ {
free( p_intf ); free( p_intf );
intf_ErrMsg( "error: no suitable plugin to create interface" ); intf_ErrMsg( "intf error: no suitable plugin" );
return( NULL ); return( NULL );
} }
...@@ -153,13 +154,13 @@ intf_thread_t* intf_Create( void ) ...@@ -153,13 +154,13 @@ intf_thread_t* intf_Create( void )
p_intf->p_console = intf_ConsoleCreate(); p_intf->p_console = intf_ConsoleCreate();
if( p_intf->p_console == NULL ) if( p_intf->p_console == NULL )
{ {
intf_ErrMsg("error: can't create control console"); intf_ErrMsg( "intf error: cannot create control console" );
free( p_intf ); free( p_intf );
return( NULL ); return( NULL );
} }
if( p_intf->p_sys_create( p_intf ) ) if( p_intf->p_sys_create( p_intf ) )
{ {
intf_ErrMsg("error: can't create interface"); intf_ErrMsg("intf error: cannot create interface");
intf_ConsoleDestroy( p_intf->p_console ); intf_ConsoleDestroy( p_intf->p_console );
free( p_intf ); free( p_intf );
return( NULL ); return( NULL );
...@@ -188,7 +189,7 @@ void intf_Run( intf_thread_t *p_intf ) ...@@ -188,7 +189,7 @@ void intf_Run( intf_thread_t *p_intf )
if( (p_input_config = if( (p_input_config =
(input_config_t *)malloc( sizeof(input_config_t) )) == NULL ) (input_config_t *)malloc( sizeof(input_config_t) )) == NULL )
{ {
intf_ErrMsg("Out of memory"); intf_ErrMsg( "intf error: cannot create input_config_t" );
} }
else else
{ {
...@@ -206,7 +207,7 @@ void intf_Run( intf_thread_t *p_intf ) ...@@ -206,7 +207,7 @@ void intf_Run( intf_thread_t *p_intf )
if( (p_input_config = if( (p_input_config =
(input_config_t *)malloc( sizeof(input_config_t) )) == NULL ) (input_config_t *)malloc( sizeof(input_config_t) )) == NULL )
{ {
intf_ErrMsg("Out of memory"); intf_ErrMsg( "intf error: cannot create input_config_t" );
} }
else else
{ {
...@@ -222,7 +223,7 @@ void intf_Run( intf_thread_t *p_intf ) ...@@ -222,7 +223,7 @@ void intf_Run( intf_thread_t *p_intf )
* the script could be executed but failed */ * the script could be executed but failed */
else if( intf_ExecScript( main_GetPszVariable( INTF_INIT_SCRIPT_VAR, INTF_INIT_SCRIPT_DEFAULT ) ) > 0 ) else if( intf_ExecScript( main_GetPszVariable( INTF_INIT_SCRIPT_VAR, INTF_INIT_SCRIPT_DEFAULT ) ) > 0 )
{ {
intf_ErrMsg("warning: error(s) during startup script"); intf_ErrMsg( "intf error: errors occured during startup script" );
} }
/* Main loop */ /* Main loop */
...@@ -562,7 +563,8 @@ static int LoadChannels( intf_thread_t *p_intf, char *psz_filename ) ...@@ -562,7 +563,8 @@ static int LoadChannels( intf_thread_t *p_intf, char *psz_filename )
p_file = fopen( psz_filename, "r" ); p_file = fopen( psz_filename, "r" );
if( p_file == NULL ) if( p_file == NULL )
{ {
intf_ErrMsg("error: can't open %s (%s)", psz_filename, strerror(errno)); intf_ErrMsg( "intf error: cannot open %s (%s)",
psz_filename, strerror(errno) );
return( 1 ); return( 1 );
} }
...@@ -580,7 +582,8 @@ static int LoadChannels( intf_thread_t *p_intf, char *psz_filename ) ...@@ -580,7 +582,8 @@ static int LoadChannels( intf_thread_t *p_intf, char *psz_filename )
p_intf->p_channel = malloc( sizeof( intf_channel_t ) * i_index ); p_intf->p_channel = malloc( sizeof( intf_channel_t ) * i_index );
if( p_intf->p_channel == NULL ) if( p_intf->p_channel == NULL )
{ {
intf_ErrMsg("error: %s", strerror(ENOMEM)); intf_ErrMsg( "intf error: cannot create intf_channel_t (%s)",
strerror(ENOMEM) );
fclose( p_file ); fclose( p_file );
return( 1 ); return( 1 );
} }
...@@ -689,7 +692,8 @@ static int ParseChannel( intf_channel_t *p_channel, char *psz_str ) ...@@ -689,7 +692,8 @@ static int ParseChannel( intf_channel_t *p_channel, char *psz_str )
p_channel->psz_description = malloc( i_field_length + 1 ); p_channel->psz_description = malloc( i_field_length + 1 );
if( p_channel->psz_description == NULL ) if( p_channel->psz_description == NULL )
{ {
intf_ErrMsg("error: %s", strerror( ENOMEM )); intf_ErrMsg( "intf error: cannot create channel "
"description (%s)", strerror( ENOMEM ) );
i_field = -1; i_field = -1;
} }
else else
...@@ -712,7 +716,8 @@ static int ParseChannel( intf_channel_t *p_channel, char *psz_str ) ...@@ -712,7 +716,8 @@ static int ParseChannel( intf_channel_t *p_channel, char *psz_str )
p_channel->psz_input_source = malloc( i_field_length + 1 ); p_channel->psz_input_source = malloc( i_field_length + 1 );
if( p_channel->psz_input_source == NULL ) if( p_channel->psz_input_source == NULL )
{ {
intf_ErrMsg("error: %s", strerror( ENOMEM )); intf_ErrMsg( "intf error: cannot create input "
"source (%s)", strerror( ENOMEM ) );
i_field = -1; i_field = -1;
} }
else else
......
...@@ -121,7 +121,7 @@ int intf_ExecCommand( char *psz_cmd ) ...@@ -121,7 +121,7 @@ int intf_ExecCommand( char *psz_cmd )
{ {
case INTF_FATAL_ERROR: /* fatal error */ case INTF_FATAL_ERROR: /* fatal error */
/* Print message and terminates the interface thread */ /* Print message and terminates the interface thread */
intf_ErrMsg( "fatal error in command `%s'", psz_argv[0] ); intf_ErrMsg( "intf error: fatal error in command `%s'", psz_argv[0] );
p_main->p_intf->b_die = 1; p_main->p_intf->b_die = 1;
break; break;
...@@ -129,9 +129,8 @@ int intf_ExecCommand( char *psz_cmd ) ...@@ -129,9 +129,8 @@ int intf_ExecCommand( char *psz_cmd )
/* Print message, flush messages queue and exit. Note that this /* Print message, flush messages queue and exit. Note that this
* error should be very rare since it does not even try to cancel * error should be very rare since it does not even try to cancel
* other threads... */ * other threads... */
intf_ErrMsg( "critical error in command `%s', " intf_ErrMsgImm( "intf error: critical error in command `%s', "
"please report this error !", psz_argv[0] ); "please report this error !", psz_argv[0] );
intf_FlushMsg();
exit( INTF_CRITICAL_ERROR ); exit( INTF_CRITICAL_ERROR );
break; break;
...@@ -203,7 +202,7 @@ int intf_ExecScript( char *psz_filename ) ...@@ -203,7 +202,7 @@ int intf_ExecScript( char *psz_filename )
} }
if( !feof( p_file ) ) if( !feof( p_file ) )
{ {
intf_ErrMsg("error: %s: %s", psz_vlcrc, strerror(errno)); intf_ErrMsg( "intf error: %s: %s", psz_vlcrc, strerror(errno));
return( -1 ); return( -1 );
} }
...@@ -500,7 +499,8 @@ static int ConvertArgument( intf_arg_t *p_arg, int i_flags, char *psz_str ) ...@@ -500,7 +499,8 @@ static int ConvertArgument( intf_arg_t *p_arg, int i_flags, char *psz_str )
#ifdef DEBUG #ifdef DEBUG
else /* error: missing type specifier */ else /* error: missing type specifier */
{ {
intf_ErrMsg("error: missing type specifier for `%s' (0x%x)", psz_str, i_flags); intf_ErrMsg( "intf error: missing type specifier for `%s' (0x%x)",
psz_str, i_flags );
return( 1 ); return( 1 );
} }
#endif #endif
......
...@@ -392,14 +392,15 @@ void main_PutPszVariable( char *psz_name, char *psz_value ) ...@@ -392,14 +392,15 @@ void main_PutPszVariable( char *psz_name, char *psz_value )
psz_env = malloc( strlen(psz_name) + strlen(psz_value) + 2 ); psz_env = malloc( strlen(psz_name) + strlen(psz_value) + 2 );
if( psz_env == NULL ) if( psz_env == NULL )
{ {
intf_ErrMsg( "error: %s", strerror(ENOMEM) ); intf_ErrMsg( "intf error: cannot create psz_env (%s)",
strerror(ENOMEM) );
} }
else else
{ {
sprintf( psz_env, "%s=%s", psz_name, psz_value ); sprintf( psz_env, "%s=%s", psz_name, psz_value );
if( putenv( psz_env ) ) if( putenv( psz_env ) )
{ {
intf_ErrMsg( "error: %s", strerror(errno) ); intf_ErrMsg( "intf error: cannot putenv (%s)", strerror(errno) );
} }
} }
} }
...@@ -437,9 +438,6 @@ static void SetDefaultConfiguration( void ) ...@@ -437,9 +438,6 @@ static void SetDefaultConfiguration( void )
p_main->b_audio = 1; p_main->b_audio = 1;
p_main->b_video = 1; p_main->b_video = 1;
p_main->b_vlans = 0; p_main->b_vlans = 0;
/* This is |_|lt1m4t3 |<l|_|d63 */
main_PutIntVariable( INPUT_DVD_SUBTITLE_VAR, -1 );
} }
/***************************************************************************** /*****************************************************************************
...@@ -757,7 +755,7 @@ static void FatalSignalHandler( int i_signal ) ...@@ -757,7 +755,7 @@ static void FatalSignalHandler( int i_signal )
signal( SIGQUIT, SIG_IGN ); signal( SIGQUIT, SIG_IGN );
/* Acknowledge the signal received */ /* Acknowledge the signal received */
intf_ErrMsgImm("intf: signal %d received, exiting", i_signal ); intf_ErrMsgImm("intf error: signal %d received, exiting", i_signal );
/* Try to terminate everything - this is done by requesting the end of the /* Try to terminate everything - this is done by requesting the end of the
* interface thread */ * interface thread */
......
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