Call the oddly labelled button on the gigabeat remote "Menu" in the
[kugel-rb.git] / apps / codecs / libfaad / mp4.c
blobfb0999fb0152523d9ce2b5ea2b6a2d0dc624e3e8
1 /*
2 ** FAAD2 - Freeware Advanced Audio (AAC) Decoder including SBR decoding
3 ** Copyright (C) 2003-2004 M. Bakker, Ahead Software AG, http://www.nero.com
4 **
5 ** This program is free software; you can redistribute it and/or modify
6 ** it under the terms of the GNU General Public License as published by
7 ** the Free Software Foundation; either version 2 of the License, or
8 ** (at your option) any later version.
9 **
10 ** This program is distributed in the hope that it will be useful,
11 ** but WITHOUT ANY WARRANTY; without even the implied warranty of
12 ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 ** GNU General Public License for more details.
14 **
15 ** You should have received a copy of the GNU General Public License
16 ** along with this program; if not, write to the Free Software
17 ** Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
19 ** Any non-GPL usage of this software or parts of this software is strictly
20 ** forbidden.
22 ** Commercial non-GPL licensing of this software is possible.
23 ** For more info contact Ahead Software through Mpeg4AAClicense@nero.com.
25 ** $Id$
26 **/
28 #include "common.h"
29 #include "structs.h"
31 #include <stdlib.h>
33 #include "bits.h"
34 #include "mp4.h"
35 #include "syntax.h"
37 /* defines if an object type can be decoded by this library or not */
38 static uint8_t ObjectTypesTable[32] = {
39 0, /* 0 NULL */
40 #ifdef MAIN_DEC
41 1, /* 1 AAC Main */
42 #else
43 0, /* 1 AAC Main */
44 #endif
45 1, /* 2 AAC LC */
46 #ifdef SSR_DEC
47 1, /* 3 AAC SSR */
48 #else
49 0, /* 3 AAC SSR */
50 #endif
51 #ifdef LTP_DEC
52 1, /* 4 AAC LTP */
53 #else
54 0, /* 4 AAC LTP */
55 #endif
56 #ifdef SBR_DEC
57 1, /* 5 SBR */
58 #else
59 0, /* 5 SBR */
60 #endif
61 #ifdef SCALABLE_DEC
62 1, /* 6 AAC Scalable */
63 #else
64 0, /* 6 AAC Scalable */
65 #endif
66 0, /* 7 TwinVQ */
67 0, /* 8 CELP */
68 0, /* 9 HVXC */
69 0, /* 10 Reserved */
70 0, /* 11 Reserved */
71 0, /* 12 TTSI */
72 0, /* 13 Main synthetic */
73 0, /* 14 Wavetable synthesis */
74 0, /* 15 General MIDI */
75 0, /* 16 Algorithmic Synthesis and Audio FX */
77 /* MPEG-4 Version 2 */
78 #ifdef ERROR_RESILIENCE
79 1, /* 17 ER AAC LC */
80 0, /* 18 (Reserved) */
81 #ifdef LTP_DEC
82 1, /* 19 ER AAC LTP */
83 #else
84 0, /* 19 ER AAC LTP */
85 #endif
86 #ifdef SCALABLE_DEC
87 1, /* 20 ER AAC scalable */
88 #else
89 0, /* 20 ER AAC scalable */
90 #endif
91 0, /* 21 ER TwinVQ */
92 0, /* 22 ER BSAC */
93 #ifdef LD_DEC
94 1, /* 23 ER AAC LD */
95 #else
96 0, /* 23 ER AAC LD */
97 #endif
98 0, /* 24 ER CELP */
99 0, /* 25 ER HVXC */
100 0, /* 26 ER HILN */
101 0, /* 27 ER Parametric */
102 #else /* No ER defined */
103 0, /* 17 ER AAC LC */
104 0, /* 18 (Reserved) */
105 0, /* 19 ER AAC LTP */
106 0, /* 20 ER AAC scalable */
107 0, /* 21 ER TwinVQ */
108 0, /* 22 ER BSAC */
109 0, /* 23 ER AAC LD */
110 0, /* 24 ER CELP */
111 0, /* 25 ER HVXC */
112 0, /* 26 ER HILN */
113 0, /* 27 ER Parametric */
114 #endif
115 0, /* 28 (Reserved) */
116 0, /* 29 (Reserved) */
117 0, /* 30 (Reserved) */
118 0 /* 31 (Reserved) */
121 /* Table 1.6.1 */
122 int8_t NEAACDECAPI NeAACDecAudioSpecificConfig(uint8_t *pBuffer,
123 uint32_t buffer_size,
124 mp4AudioSpecificConfig *mp4ASC)
126 return AudioSpecificConfig2(pBuffer, buffer_size, mp4ASC, NULL);
129 int8_t AudioSpecificConfig2(uint8_t *pBuffer,
130 uint32_t buffer_size,
131 mp4AudioSpecificConfig *mp4ASC,
132 program_config *pce)
134 bitfile ld;
135 int8_t result = 0;
136 #ifdef SBR_DEC
137 int8_t bits_to_decode = 0;
138 #endif
140 if (pBuffer == NULL)
141 return -7;
142 if (mp4ASC == NULL)
143 return -8;
145 memset(mp4ASC, 0, sizeof(mp4AudioSpecificConfig));
147 faad_initbits(&ld, pBuffer, buffer_size);
148 faad_byte_align(&ld);
150 mp4ASC->objectTypeIndex = (uint8_t)faad_getbits(&ld, 5
151 DEBUGVAR(1,1,"parse_audio_decoder_specific_info(): ObjectTypeIndex"));
153 mp4ASC->samplingFrequencyIndex = (uint8_t)faad_getbits(&ld, 4
154 DEBUGVAR(1,2,"parse_audio_decoder_specific_info(): SamplingFrequencyIndex"));
156 mp4ASC->channelsConfiguration = (uint8_t)faad_getbits(&ld, 4
157 DEBUGVAR(1,3,"parse_audio_decoder_specific_info(): ChannelsConfiguration"));
159 mp4ASC->samplingFrequency = get_sample_rate(mp4ASC->samplingFrequencyIndex);
161 if (ObjectTypesTable[mp4ASC->objectTypeIndex] != 1)
163 faad_endbits(&ld);
164 return -1;
167 if (mp4ASC->samplingFrequency == 0)
169 faad_endbits(&ld);
170 return -2;
173 if (mp4ASC->channelsConfiguration > 7)
175 faad_endbits(&ld);
176 return -3;
179 #if (defined(PS_DEC) || defined(DRM_PS))
180 /* check if we have a mono file */
181 if (mp4ASC->channelsConfiguration == 1)
183 /* upMatrix to 2 channels for implicit signalling of PS */
184 mp4ASC->channelsConfiguration = 2;
186 #endif
188 #ifdef SBR_DEC
189 mp4ASC->sbr_present_flag = -1;
190 if (mp4ASC->objectTypeIndex == 5)
192 uint8_t tmp;
194 mp4ASC->sbr_present_flag = 1;
195 tmp = (uint8_t)faad_getbits(&ld, 4
196 DEBUGVAR(1,5,"parse_audio_decoder_specific_info(): extensionSamplingFrequencyIndex"));
197 /* check for downsampled SBR */
198 if (tmp == mp4ASC->samplingFrequencyIndex)
199 mp4ASC->downSampledSBR = 1;
200 mp4ASC->samplingFrequencyIndex = tmp;
201 if (mp4ASC->samplingFrequencyIndex == 15)
203 mp4ASC->samplingFrequency = (uint32_t)faad_getbits(&ld, 24
204 DEBUGVAR(1,6,"parse_audio_decoder_specific_info(): extensionSamplingFrequencyIndex"));
205 } else {
206 mp4ASC->samplingFrequency = get_sample_rate(mp4ASC->samplingFrequencyIndex);
208 mp4ASC->objectTypeIndex = (uint8_t)faad_getbits(&ld, 5
209 DEBUGVAR(1,7,"parse_audio_decoder_specific_info(): ObjectTypeIndex"));
211 #endif
213 /* get GASpecificConfig */
214 if (mp4ASC->objectTypeIndex == 1 || mp4ASC->objectTypeIndex == 2 ||
215 mp4ASC->objectTypeIndex == 3 || mp4ASC->objectTypeIndex == 4 ||
216 mp4ASC->objectTypeIndex == 6 || mp4ASC->objectTypeIndex == 7)
218 result = GASpecificConfig(&ld, mp4ASC, pce);
220 #ifdef ERROR_RESILIENCE
221 } else if (mp4ASC->objectTypeIndex >= ER_OBJECT_START) { /* ER */
222 result = GASpecificConfig(&ld, mp4ASC, pce);
223 mp4ASC->epConfig = (uint8_t)faad_getbits(&ld, 2
224 DEBUGVAR(1,143,"parse_audio_decoder_specific_info(): epConfig"));
226 if (mp4ASC->epConfig != 0)
227 result = -5;
228 #endif
230 } else {
231 result = -4;
234 #ifdef SSR_DEC
235 /* shorter frames not allowed for SSR */
236 if ((mp4ASC->objectTypeIndex == 4) && mp4ASC->frameLengthFlag)
237 return -6;
238 #endif
241 #ifdef SBR_DEC
242 bits_to_decode = (int8_t)(buffer_size*8 - faad_get_processed_bits(&ld));
244 if ((mp4ASC->objectTypeIndex != 5) && (bits_to_decode >= 16))
246 int16_t syncExtensionType = (int16_t)faad_getbits(&ld, 11
247 DEBUGVAR(1,9,"parse_audio_decoder_specific_info(): syncExtensionType"));
249 if (syncExtensionType == 0x2b7)
251 mp4ASC->objectTypeIndex = (uint8_t)faad_getbits(&ld, 5
252 DEBUGVAR(1,10,"parse_audio_decoder_specific_info(): extensionAudioObjectType"));
254 if (mp4ASC->objectTypeIndex == 5)
256 mp4ASC->sbr_present_flag = (uint8_t)faad_get1bit(&ld
257 DEBUGVAR(1,11,"parse_audio_decoder_specific_info(): sbr_present_flag"));
259 if (mp4ASC->sbr_present_flag)
261 uint8_t tmp;
262 tmp = (uint8_t)faad_getbits(&ld, 4
263 DEBUGVAR(1,12,"parse_audio_decoder_specific_info(): extensionSamplingFrequencyIndex"));
265 /* check for downsampled SBR */
266 if (tmp == mp4ASC->samplingFrequencyIndex)
267 mp4ASC->downSampledSBR = 1;
268 mp4ASC->samplingFrequencyIndex = tmp;
270 if (mp4ASC->samplingFrequencyIndex == 15)
272 mp4ASC->samplingFrequency = (uint32_t)faad_getbits(&ld, 24
273 DEBUGVAR(1,13,"parse_audio_decoder_specific_info(): extensionSamplingFrequencyIndex"));
274 } else {
275 mp4ASC->samplingFrequency = get_sample_rate(mp4ASC->samplingFrequencyIndex);
282 /* no SBR signalled, this could mean either implicit signalling or no SBR in this file */
283 /* MPEG specification states: assume SBR on files with samplerate <= 24000 Hz */
284 if (mp4ASC->sbr_present_flag == -1)
286 if (mp4ASC->samplingFrequency <= 24000)
288 mp4ASC->samplingFrequency *= 2;
289 mp4ASC->forceUpSampling = 1;
290 } else /* > 24000*/ {
291 mp4ASC->downSampledSBR = 1;
294 #endif
296 faad_endbits(&ld);
298 return result;