annotate liba52/a52.h @ 15546:4ac9c227d758

preinit audio filters in order to determine the final samplerate and number of channels, or audio encoders will be initialized with the wrong parameters
author nicodvb
date Sun, 22 May 2005 15:34:23 +0000
parents 07f1e7669772
children 4bad7f00556e
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
3394
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
1 /*
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
2 * a52.h
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
3 * Copyright (C) 2000-2001 Michel Lespinasse <walken@zoy.org>
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
4 * Copyright (C) 1999-2000 Aaron Holtzman <aholtzma@ess.engr.uvic.ca>
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
5 *
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
6 * This file is part of a52dec, a free ATSC A-52 stream decoder.
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
7 * See http://liba52.sourceforge.net/ for updates.
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
8 *
14991
07f1e7669772 Mark modified files as such to comply more closely with GPL ¡ø2a.
diego
parents: 3909
diff changeset
9 * Modified for use with MPlayer, changes contained in liba52_changes.diff.
07f1e7669772 Mark modified files as such to comply more closely with GPL ¡ø2a.
diego
parents: 3909
diff changeset
10 * detailed CVS changelog at http://www.mplayerhq.hu/cgi-bin/cvsweb.cgi/main/
07f1e7669772 Mark modified files as such to comply more closely with GPL ¡ø2a.
diego
parents: 3909
diff changeset
11 * $Id$
07f1e7669772 Mark modified files as such to comply more closely with GPL ¡ø2a.
diego
parents: 3909
diff changeset
12 *
3394
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
13 * a52dec is free software; you can redistribute it and/or modify
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
14 * it under the terms of the GNU General Public License as published by
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
15 * the Free Software Foundation; either version 2 of the License, or
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
16 * (at your option) any later version.
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
17 *
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
18 * a52dec is distributed in the hope that it will be useful,
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
21 * GNU General Public License for more details.
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
22 *
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
23 * You should have received a copy of the GNU General Public License
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
24 * along with this program; if not, write to the Free Software
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
25 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
26 */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
27
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
28 #ifndef A52_H
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
29 #define A52_H
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
30
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
31 #ifndef LIBA52_DOUBLE
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
32 typedef float sample_t;
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
33 #else
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
34 typedef double sample_t;
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
35 #endif
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
36
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
37 typedef struct a52_ba_s {
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
38 uint16_t fsnroffst; /* fine SNR offset */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
39 uint16_t fgaincod; /* fast gain */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
40 uint16_t deltbae; /* delta bit allocation exists */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
41 int8_t deltba[50]; /* per-band delta bit allocation */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
42 } a52_ba_t;
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
43
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
44 typedef struct a52_state_s {
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
45 uint8_t fscod; /* sample rate */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
46 uint8_t halfrate; /* halfrate factor */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
47 uint8_t acmod; /* coded channels */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
48 sample_t clev; /* centre channel mix level */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
49 sample_t slev; /* surround channels mix level */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
50 uint8_t lfeon; /* coded lfe channel */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
51
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
52 int output; /* type of output */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
53 sample_t level; /* output level */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
54 sample_t bias; /* output bias */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
55
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
56 int dynrnge; /* apply dynamic range */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
57 sample_t dynrng; /* dynamic range */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
58 void * dynrngdata; /* dynamic range callback funtion and data */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
59 sample_t (* dynrngcall) (sample_t range, void * dynrngdata);
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
60
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
61 uint16_t cplinu; /* coupling in use */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
62 uint16_t chincpl[5]; /* channel coupled */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
63 uint16_t phsflginu; /* phase flags in use (stereo only) */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
64 uint16_t cplbndstrc[18]; /* coupling band structure */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
65 uint16_t cplstrtmant; /* coupling channel start mantissa */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
66 uint16_t cplendmant; /* coupling channel end mantissa */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
67 sample_t cplco[5][18]; /* coupling coordinates */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
68
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
69 /* derived information */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
70 uint16_t cplstrtbnd; /* coupling start band (for bit allocation) */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
71 uint16_t ncplbnd; /* number of coupling bands */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
72
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
73 uint16_t rematflg[4]; /* stereo rematrixing */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
74
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
75 uint16_t endmant[5]; /* channel end mantissa */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
76
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
77 uint8_t cpl_exp[256]; /* decoded coupling channel exponents */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
78 uint8_t fbw_exp[5][256]; /* decoded channel exponents */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
79 uint8_t lfe_exp[7]; /* decoded lfe channel exponents */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
80
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
81 uint16_t sdcycod; /* slow decay */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
82 uint16_t fdcycod; /* fast decay */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
83 uint16_t sgaincod; /* slow gain */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
84 uint16_t dbpbcod; /* dB per bit - encodes the dbknee value */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
85 uint16_t floorcod; /* masking floor */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
86
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
87 uint16_t csnroffst; /* coarse SNR offset */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
88 a52_ba_t cplba; /* coupling bit allocation parameters */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
89 a52_ba_t ba[5]; /* channel bit allocation parameters */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
90 a52_ba_t lfeba; /* lfe bit allocation parameters */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
91
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
92 uint16_t cplfleak; /* coupling fast leak init */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
93 uint16_t cplsleak; /* coupling slow leak init */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
94
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
95 /* derived bit allocation information */
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
96 int8_t fbw_bap[5][256];
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
97 int8_t cpl_bap[256];
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
98 int8_t lfe_bap[7];
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
99 } a52_state_t;
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
100
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
101 #define A52_CHANNEL 0
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
102 #define A52_MONO 1
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
103 #define A52_STEREO 2
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
104 #define A52_3F 3
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
105 #define A52_2F1R 4
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
106 #define A52_3F1R 5
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
107 #define A52_2F2R 6
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
108 #define A52_3F2R 7
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
109 #define A52_CHANNEL1 8
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
110 #define A52_CHANNEL2 9
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
111 #define A52_DOLBY 10
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
112 #define A52_CHANNEL_MASK 15
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
113
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
114 #define A52_LFE 16
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
115 #define A52_ADJUST_LEVEL 32
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
116
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
117 sample_t * a52_init (uint32_t mm_accel);
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
118 int a52_syncinfo (uint8_t * buf, int * flags,
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
119 int * sample_rate, int * bit_rate);
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
120 int a52_frame (a52_state_t * state, uint8_t * buf, int * flags,
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
121 sample_t * level, sample_t bias);
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
122 void a52_dynrng (a52_state_t * state,
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
123 sample_t (* call) (sample_t, void *), void * data);
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
124 int a52_block (a52_state_t * state, sample_t * samples);
3890
c3e62caf9ec6 CRC code ported from libac3
arpi
parents: 3626
diff changeset
125
3909
ef32c8bdee81 c, mmx versions separated. a52 style runtime stuff
arpi
parents: 3907
diff changeset
126 void* a52_resample_init(uint32_t mm_accel,int flags,int chans);
3626
e22ff7ebdc05 runtime cpu detection for the resample stuff
michael
parents: 3394
diff changeset
127 extern int (* a52_resample) (float * _f, int16_t * s16);
3394
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
128
3890
c3e62caf9ec6 CRC code ported from libac3
arpi
parents: 3626
diff changeset
129 uint16_t crc16_block(uint8_t *data,uint32_t num_bytes);
c3e62caf9ec6 CRC code ported from libac3
arpi
parents: 3626
diff changeset
130
3394
35b18ed357c2 imported from liba52 CVS
arpi
parents:
diff changeset
131 #endif /* A52_H */