Mercurial > mplayer.hg
annotate libfaad2/syntax.c @ 27808:2988c38b6620
Make sure that linker flags passed as configure parameters appear before
those detected by configure so that the former can override the latter.
patch by Giacomo Comes, comes naic edu
author | diego |
---|---|
date | Tue, 28 Oct 2008 18:00:11 +0000 |
parents | bc425ba00960 |
children | e83eef58b30a |
rev | line source |
---|---|
10725 | 1 /* |
2 ** FAAD2 - Freeware Advanced Audio (AAC) Decoder including SBR decoding | |
12527 | 3 ** Copyright (C) 2003-2004 M. Bakker, Ahead Software AG, http://www.nero.com |
10725 | 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. | |
18 ** | |
19 ** Any non-GPL usage of this software or parts of this software is strictly | |
20 ** forbidden. | |
21 ** | |
22 ** Commercial non-GPL licensing of this software is possible. | |
23 ** For more info contact Ahead Software through Mpeg4AAClicense@nero.com. | |
24 ** | |
18141 | 25 ** $Id: syntax.c,v 1.82 2004/09/04 14:56:29 menno Exp $ |
10725 | 26 **/ |
27 | |
28 /* | |
29 Reads the AAC bitstream as defined in 14496-3 (MPEG-4 Audio) | |
30 */ | |
31 | |
32 #include "common.h" | |
33 #include "structs.h" | |
34 | |
35 #include <stdlib.h> | |
36 #include <string.h> | |
37 | |
38 #include "decoder.h" | |
39 #include "syntax.h" | |
40 #include "specrec.h" | |
41 #include "huffman.h" | |
42 #include "bits.h" | |
43 #include "pulse.h" | |
44 #include "analysis.h" | |
45 #include "drc.h" | |
46 #ifdef ERROR_RESILIENCE | |
47 #include "rvlc.h" | |
48 #endif | |
49 #ifdef SBR_DEC | |
50 #include "sbr_syntax.h" | |
51 #endif | |
25833
ed27d1c01f93
in GASpecificConfig 1 bit (extensionflag3) wasn't being read and the comment was misplaced, too
nicodvb
parents:
18141
diff
changeset
|
52 #include "mp4.h" |
10725 | 53 |
54 | |
12527 | 55 /* static function declarations */ |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
56 static void decode_sce_lfe(NeAACDecHandle hDecoder, NeAACDecFrameInfo *hInfo, bitfile *ld, |
12527 | 57 uint8_t id_syn_ele); |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
58 static void decode_cpe(NeAACDecHandle hDecoder, NeAACDecFrameInfo *hInfo, bitfile *ld, |
12527 | 59 uint8_t id_syn_ele); |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
60 static uint8_t single_lfe_channel_element(NeAACDecHandle hDecoder, bitfile *ld, |
12527 | 61 uint8_t channel, uint8_t *tag); |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
62 static uint8_t channel_pair_element(NeAACDecHandle hDecoder, bitfile *ld, |
12527 | 63 uint8_t channel, uint8_t *tag); |
64 #ifdef COUPLING_DEC | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
65 static uint8_t coupling_channel_element(NeAACDecHandle hDecoder, bitfile *ld); |
12527 | 66 #endif |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
67 static uint16_t data_stream_element(NeAACDecHandle hDecoder, bitfile *ld); |
12527 | 68 static uint8_t program_config_element(program_config *pce, bitfile *ld); |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
69 static uint8_t fill_element(NeAACDecHandle hDecoder, bitfile *ld, drc_info *drc |
12527 | 70 #ifdef SBR_DEC |
71 ,uint8_t sbr_ele | |
72 #endif | |
73 ); | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
74 static uint8_t individual_channel_stream(NeAACDecHandle hDecoder, element *ele, |
12527 | 75 bitfile *ld, ic_stream *ics, uint8_t scal_flag, |
76 int16_t *spec_data); | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
77 static uint8_t ics_info(NeAACDecHandle hDecoder, ic_stream *ics, bitfile *ld, |
12527 | 78 uint8_t common_window); |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
79 static uint8_t section_data(NeAACDecHandle hDecoder, ic_stream *ics, bitfile *ld); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
80 static uint8_t scale_factor_data(NeAACDecHandle hDecoder, ic_stream *ics, bitfile *ld); |
12527 | 81 #ifdef SSR_DEC |
82 static void gain_control_data(bitfile *ld, ic_stream *ics); | |
83 #endif | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
84 static uint8_t spectral_data(NeAACDecHandle hDecoder, ic_stream *ics, bitfile *ld, |
12527 | 85 int16_t *spectral_data); |
86 static uint16_t extension_payload(bitfile *ld, drc_info *drc, uint16_t count); | |
87 static uint8_t pulse_data(ic_stream *ics, pulse_info *pul, bitfile *ld); | |
88 static void tns_data(ic_stream *ics, tns_info *tns, bitfile *ld); | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
89 #ifdef LTP_DEC |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
90 static uint8_t ltp_data(NeAACDecHandle hDecoder, ic_stream *ics, ltp_info *ltp, bitfile *ld); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
91 #endif |
12527 | 92 static uint8_t adts_fixed_header(adts_header *adts, bitfile *ld); |
93 static void adts_variable_header(adts_header *adts, bitfile *ld); | |
94 static void adts_error_check(adts_header *adts, bitfile *ld); | |
95 static uint8_t dynamic_range_info(bitfile *ld, drc_info *drc); | |
96 static uint8_t excluded_channels(bitfile *ld, drc_info *drc); | |
97 #ifdef SCALABLE_DEC | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
98 static int8_t aac_scalable_main_header(NeAACDecHandle hDecoder, ic_stream *ics1, ic_stream *ics2, |
12527 | 99 bitfile *ld, uint8_t this_layer_stereo); |
100 #endif | |
101 | |
102 | |
10725 | 103 /* Table 4.4.1 */ |
104 int8_t GASpecificConfig(bitfile *ld, mp4AudioSpecificConfig *mp4ASC, | |
105 program_config *pce_out) | |
106 { | |
107 program_config pce; | |
108 | |
109 /* 1024 or 960 */ | |
110 mp4ASC->frameLengthFlag = faad_get1bit(ld | |
111 DEBUGVAR(1,138,"GASpecificConfig(): FrameLengthFlag")); | |
12527 | 112 #ifndef ALLOW_SMALL_FRAMELENGTH |
113 if (mp4ASC->frameLengthFlag == 1) | |
114 return -3; | |
115 #endif | |
10725 | 116 |
117 mp4ASC->dependsOnCoreCoder = faad_get1bit(ld | |
118 DEBUGVAR(1,139,"GASpecificConfig(): DependsOnCoreCoder")); | |
119 if (mp4ASC->dependsOnCoreCoder == 1) | |
120 { | |
121 mp4ASC->coreCoderDelay = (uint16_t)faad_getbits(ld, 14 | |
122 DEBUGVAR(1,140,"GASpecificConfig(): CoreCoderDelay")); | |
123 } | |
124 | |
125 mp4ASC->extensionFlag = faad_get1bit(ld DEBUGVAR(1,141,"GASpecificConfig(): ExtensionFlag")); | |
126 if (mp4ASC->channelsConfiguration == 0) | |
127 { | |
12527 | 128 if (program_config_element(&pce, ld)) |
129 return -3; | |
10725 | 130 //mp4ASC->channelsConfiguration = pce.channels; |
131 | |
132 if (pce_out != NULL) | |
133 memcpy(pce_out, &pce, sizeof(program_config)); | |
134 | |
135 /* | |
136 if (pce.num_valid_cc_elements) | |
137 return -3; | |
138 */ | |
139 } | |
140 | |
141 #ifdef ERROR_RESILIENCE | |
142 if (mp4ASC->extensionFlag == 1) | |
143 { | |
144 /* Error resilience not supported yet */ | |
145 if (mp4ASC->objectTypeIndex >= ER_OBJECT_START) | |
146 { | |
147 mp4ASC->aacSectionDataResilienceFlag = faad_get1bit(ld | |
148 DEBUGVAR(1,144,"GASpecificConfig(): aacSectionDataResilienceFlag")); | |
149 mp4ASC->aacScalefactorDataResilienceFlag = faad_get1bit(ld | |
150 DEBUGVAR(1,145,"GASpecificConfig(): aacScalefactorDataResilienceFlag")); | |
151 mp4ASC->aacSpectralDataResilienceFlag = faad_get1bit(ld | |
152 DEBUGVAR(1,146,"GASpecificConfig(): aacSpectralDataResilienceFlag")); | |
153 } | |
25833
ed27d1c01f93
in GASpecificConfig 1 bit (extensionflag3) wasn't being read and the comment was misplaced, too
nicodvb
parents:
18141
diff
changeset
|
154 /* 1 bit: extensionFlag3 */ |
ed27d1c01f93
in GASpecificConfig 1 bit (extensionflag3) wasn't being read and the comment was misplaced, too
nicodvb
parents:
18141
diff
changeset
|
155 faad_getbits(ld, 1); |
10725 | 156 } |
157 #endif | |
158 | |
159 return 0; | |
160 } | |
161 | |
162 /* Table 4.4.2 */ | |
163 /* An MPEG-4 Audio decoder is only required to follow the Program | |
164 Configuration Element in GASpecificConfig(). The decoder shall ignore | |
165 any Program Configuration Elements that may occur in raw data blocks. | |
166 PCEs transmitted in raw data blocks cannot be used to convey decoder | |
167 configuration information. | |
168 */ | |
12527 | 169 static uint8_t program_config_element(program_config *pce, bitfile *ld) |
10725 | 170 { |
171 uint8_t i; | |
172 | |
173 memset(pce, 0, sizeof(program_config)); | |
174 | |
175 pce->channels = 0; | |
176 | |
177 pce->element_instance_tag = (uint8_t)faad_getbits(ld, 4 | |
178 DEBUGVAR(1,10,"program_config_element(): element_instance_tag")); | |
179 | |
180 pce->object_type = (uint8_t)faad_getbits(ld, 2 | |
181 DEBUGVAR(1,11,"program_config_element(): object_type")); | |
182 pce->sf_index = (uint8_t)faad_getbits(ld, 4 | |
183 DEBUGVAR(1,12,"program_config_element(): sf_index")); | |
184 pce->num_front_channel_elements = (uint8_t)faad_getbits(ld, 4 | |
185 DEBUGVAR(1,13,"program_config_element(): num_front_channel_elements")); | |
186 pce->num_side_channel_elements = (uint8_t)faad_getbits(ld, 4 | |
187 DEBUGVAR(1,14,"program_config_element(): num_side_channel_elements")); | |
188 pce->num_back_channel_elements = (uint8_t)faad_getbits(ld, 4 | |
189 DEBUGVAR(1,15,"program_config_element(): num_back_channel_elements")); | |
190 pce->num_lfe_channel_elements = (uint8_t)faad_getbits(ld, 2 | |
191 DEBUGVAR(1,16,"program_config_element(): num_lfe_channel_elements")); | |
192 pce->num_assoc_data_elements = (uint8_t)faad_getbits(ld, 3 | |
193 DEBUGVAR(1,17,"program_config_element(): num_assoc_data_elements")); | |
194 pce->num_valid_cc_elements = (uint8_t)faad_getbits(ld, 4 | |
195 DEBUGVAR(1,18,"program_config_element(): num_valid_cc_elements")); | |
196 | |
197 pce->mono_mixdown_present = faad_get1bit(ld | |
198 DEBUGVAR(1,19,"program_config_element(): mono_mixdown_present")); | |
199 if (pce->mono_mixdown_present == 1) | |
200 { | |
201 pce->mono_mixdown_element_number = (uint8_t)faad_getbits(ld, 4 | |
202 DEBUGVAR(1,20,"program_config_element(): mono_mixdown_element_number")); | |
203 } | |
204 | |
205 pce->stereo_mixdown_present = faad_get1bit(ld | |
206 DEBUGVAR(1,21,"program_config_element(): stereo_mixdown_present")); | |
207 if (pce->stereo_mixdown_present == 1) | |
208 { | |
209 pce->stereo_mixdown_element_number = (uint8_t)faad_getbits(ld, 4 | |
210 DEBUGVAR(1,22,"program_config_element(): stereo_mixdown_element_number")); | |
211 } | |
212 | |
213 pce->matrix_mixdown_idx_present = faad_get1bit(ld | |
214 DEBUGVAR(1,23,"program_config_element(): matrix_mixdown_idx_present")); | |
215 if (pce->matrix_mixdown_idx_present == 1) | |
216 { | |
217 pce->matrix_mixdown_idx = (uint8_t)faad_getbits(ld, 2 | |
218 DEBUGVAR(1,24,"program_config_element(): matrix_mixdown_idx")); | |
219 pce->pseudo_surround_enable = faad_get1bit(ld | |
220 DEBUGVAR(1,25,"program_config_element(): pseudo_surround_enable")); | |
221 } | |
222 | |
223 for (i = 0; i < pce->num_front_channel_elements; i++) | |
224 { | |
225 pce->front_element_is_cpe[i] = faad_get1bit(ld | |
226 DEBUGVAR(1,26,"program_config_element(): front_element_is_cpe")); | |
227 pce->front_element_tag_select[i] = (uint8_t)faad_getbits(ld, 4 | |
228 DEBUGVAR(1,27,"program_config_element(): front_element_tag_select")); | |
229 | |
230 if (pce->front_element_is_cpe[i] & 1) | |
231 { | |
232 pce->cpe_channel[pce->front_element_tag_select[i]] = pce->channels; | |
233 pce->num_front_channels += 2; | |
234 pce->channels += 2; | |
235 } else { | |
236 pce->sce_channel[pce->front_element_tag_select[i]] = pce->channels; | |
237 pce->num_front_channels++; | |
238 pce->channels++; | |
239 } | |
240 } | |
241 | |
242 for (i = 0; i < pce->num_side_channel_elements; i++) | |
243 { | |
244 pce->side_element_is_cpe[i] = faad_get1bit(ld | |
245 DEBUGVAR(1,28,"program_config_element(): side_element_is_cpe")); | |
246 pce->side_element_tag_select[i] = (uint8_t)faad_getbits(ld, 4 | |
247 DEBUGVAR(1,29,"program_config_element(): side_element_tag_select")); | |
248 | |
249 if (pce->side_element_is_cpe[i] & 1) | |
250 { | |
251 pce->cpe_channel[pce->side_element_tag_select[i]] = pce->channels; | |
252 pce->num_side_channels += 2; | |
253 pce->channels += 2; | |
254 } else { | |
255 pce->sce_channel[pce->side_element_tag_select[i]] = pce->channels; | |
256 pce->num_side_channels++; | |
257 pce->channels++; | |
258 } | |
259 } | |
260 | |
261 for (i = 0; i < pce->num_back_channel_elements; i++) | |
262 { | |
263 pce->back_element_is_cpe[i] = faad_get1bit(ld | |
264 DEBUGVAR(1,30,"program_config_element(): back_element_is_cpe")); | |
265 pce->back_element_tag_select[i] = (uint8_t)faad_getbits(ld, 4 | |
266 DEBUGVAR(1,31,"program_config_element(): back_element_tag_select")); | |
267 | |
268 if (pce->back_element_is_cpe[i] & 1) | |
269 { | |
270 pce->cpe_channel[pce->back_element_tag_select[i]] = pce->channels; | |
271 pce->channels += 2; | |
272 pce->num_back_channels += 2; | |
273 } else { | |
274 pce->sce_channel[pce->back_element_tag_select[i]] = pce->channels; | |
275 pce->num_back_channels++; | |
276 pce->channels++; | |
277 } | |
278 } | |
279 | |
280 for (i = 0; i < pce->num_lfe_channel_elements; i++) | |
281 { | |
282 pce->lfe_element_tag_select[i] = (uint8_t)faad_getbits(ld, 4 | |
283 DEBUGVAR(1,32,"program_config_element(): lfe_element_tag_select")); | |
284 | |
285 pce->sce_channel[pce->lfe_element_tag_select[i]] = pce->channels; | |
286 pce->num_lfe_channels++; | |
287 pce->channels++; | |
288 } | |
289 | |
290 for (i = 0; i < pce->num_assoc_data_elements; i++) | |
291 pce->assoc_data_element_tag_select[i] = (uint8_t)faad_getbits(ld, 4 | |
292 DEBUGVAR(1,33,"program_config_element(): assoc_data_element_tag_select")); | |
293 | |
294 for (i = 0; i < pce->num_valid_cc_elements; i++) | |
295 { | |
296 pce->cc_element_is_ind_sw[i] = faad_get1bit(ld | |
297 DEBUGVAR(1,34,"program_config_element(): cc_element_is_ind_sw")); | |
298 pce->valid_cc_element_tag_select[i] = (uint8_t)faad_getbits(ld, 4 | |
299 DEBUGVAR(1,35,"program_config_element(): valid_cc_element_tag_select")); | |
300 } | |
301 | |
302 faad_byte_align(ld); | |
303 | |
304 pce->comment_field_bytes = (uint8_t)faad_getbits(ld, 8 | |
305 DEBUGVAR(1,36,"program_config_element(): comment_field_bytes")); | |
306 | |
307 for (i = 0; i < pce->comment_field_bytes; i++) | |
308 { | |
309 pce->comment_field_data[i] = (uint8_t)faad_getbits(ld, 8 | |
310 DEBUGVAR(1,37,"program_config_element(): comment_field_data")); | |
311 } | |
312 pce->comment_field_data[i] = 0; | |
313 | |
12527 | 314 if (pce->channels > MAX_CHANNELS) |
315 return 22; | |
316 | |
10725 | 317 return 0; |
318 } | |
319 | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
320 static void decode_sce_lfe(NeAACDecHandle hDecoder, |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
321 NeAACDecFrameInfo *hInfo, bitfile *ld, |
12527 | 322 uint8_t id_syn_ele) |
10725 | 323 { |
324 uint8_t channels = hDecoder->fr_channels; | |
12527 | 325 uint8_t tag = 0; |
10725 | 326 |
327 if (channels+1 > MAX_CHANNELS) | |
328 { | |
329 hInfo->error = 12; | |
12527 | 330 return; |
10725 | 331 } |
332 if (hDecoder->fr_ch_ele+1 > MAX_SYNTAX_ELEMENTS) | |
333 { | |
334 hInfo->error = 13; | |
12527 | 335 return; |
10725 | 336 } |
337 | |
12527 | 338 /* for SCE hDecoder->element_output_channels[] is not set here because this |
339 can become 2 when some form of Parametric Stereo coding is used | |
340 */ | |
10725 | 341 |
12527 | 342 /* save the syntax element id */ |
343 hDecoder->element_id[hDecoder->fr_ch_ele] = id_syn_ele; | |
10725 | 344 |
12527 | 345 /* decode the element */ |
346 hInfo->error = single_lfe_channel_element(hDecoder, ld, channels, &tag); | |
10725 | 347 |
12527 | 348 /* map output channels position to internal data channels */ |
349 if (hDecoder->element_output_channels[hDecoder->fr_ch_ele] == 2) | |
350 { | |
351 /* this might be faulty when pce_set is true */ | |
10725 | 352 hDecoder->internal_channel[channels] = channels; |
12527 | 353 hDecoder->internal_channel[channels+1] = channels+1; |
354 } else { | |
355 if (hDecoder->pce_set) | |
356 hDecoder->internal_channel[hDecoder->pce.sce_channel[tag]] = channels; | |
357 else | |
358 hDecoder->internal_channel[channels] = channels; | |
359 } | |
10725 | 360 |
12527 | 361 hDecoder->fr_channels += hDecoder->element_output_channels[hDecoder->fr_ch_ele]; |
10725 | 362 hDecoder->fr_ch_ele++; |
363 } | |
364 | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
365 static void decode_cpe(NeAACDecHandle hDecoder, NeAACDecFrameInfo *hInfo, bitfile *ld, |
12527 | 366 uint8_t id_syn_ele) |
10725 | 367 { |
368 uint8_t channels = hDecoder->fr_channels; | |
12527 | 369 uint8_t tag = 0; |
10725 | 370 |
371 if (channels+2 > MAX_CHANNELS) | |
372 { | |
373 hInfo->error = 12; | |
12527 | 374 return; |
10725 | 375 } |
376 if (hDecoder->fr_ch_ele+1 > MAX_SYNTAX_ELEMENTS) | |
377 { | |
378 hInfo->error = 13; | |
12527 | 379 return; |
10725 | 380 } |
381 | |
12527 | 382 /* for CPE the number of output channels is always 2 */ |
383 if (hDecoder->element_output_channels[hDecoder->fr_ch_ele] == 0) | |
384 { | |
385 /* element_output_channels not set yet */ | |
386 hDecoder->element_output_channels[hDecoder->fr_ch_ele] = 2; | |
387 } else if (hDecoder->element_output_channels[hDecoder->fr_ch_ele] != 2) { | |
388 /* element inconsistency */ | |
389 hInfo->error = 21; | |
390 return; | |
391 } | |
10725 | 392 |
12527 | 393 /* save the syntax element id */ |
394 hDecoder->element_id[hDecoder->fr_ch_ele] = id_syn_ele; | |
10725 | 395 |
12527 | 396 /* decode the element */ |
397 hInfo->error = channel_pair_element(hDecoder, ld, channels, &tag); | |
10725 | 398 |
12527 | 399 /* map output channel position to internal data channels */ |
10725 | 400 if (hDecoder->pce_set) |
401 { | |
12527 | 402 hDecoder->internal_channel[hDecoder->pce.cpe_channel[tag]] = channels; |
403 hDecoder->internal_channel[hDecoder->pce.cpe_channel[tag]+1] = channels+1; | |
10725 | 404 } else { |
405 hDecoder->internal_channel[channels] = channels; | |
406 hDecoder->internal_channel[channels+1] = channels+1; | |
407 } | |
408 | |
409 hDecoder->fr_channels += 2; | |
410 hDecoder->fr_ch_ele++; | |
411 } | |
412 | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
413 void raw_data_block(NeAACDecHandle hDecoder, NeAACDecFrameInfo *hInfo, |
12527 | 414 bitfile *ld, program_config *pce, drc_info *drc) |
10725 | 415 { |
416 uint8_t id_syn_ele; | |
417 | |
418 hDecoder->fr_channels = 0; | |
419 hDecoder->fr_ch_ele = 0; | |
420 hDecoder->first_syn_ele = 25; | |
421 hDecoder->has_lfe = 0; | |
422 | |
423 #ifdef ERROR_RESILIENCE | |
424 if (hDecoder->object_type < ER_OBJECT_START) | |
425 { | |
426 #endif | |
427 /* Table 4.4.3: raw_data_block() */ | |
428 while ((id_syn_ele = (uint8_t)faad_getbits(ld, LEN_SE_ID | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
429 DEBUGVAR(1,4,"NeAACDecDecode(): id_syn_ele"))) != ID_END) |
10725 | 430 { |
431 switch (id_syn_ele) { | |
432 case ID_SCE: | |
433 if (hDecoder->first_syn_ele == 25) hDecoder->first_syn_ele = id_syn_ele; | |
12527 | 434 decode_sce_lfe(hDecoder, hInfo, ld, id_syn_ele); |
10725 | 435 if (hInfo->error > 0) |
12527 | 436 return; |
10725 | 437 break; |
438 case ID_CPE: | |
439 if (hDecoder->first_syn_ele == 25) hDecoder->first_syn_ele = id_syn_ele; | |
12527 | 440 decode_cpe(hDecoder, hInfo, ld, id_syn_ele); |
10725 | 441 if (hInfo->error > 0) |
12527 | 442 return; |
10725 | 443 break; |
444 case ID_LFE: | |
445 hDecoder->has_lfe++; | |
12527 | 446 decode_sce_lfe(hDecoder, hInfo, ld, id_syn_ele); |
10725 | 447 if (hInfo->error > 0) |
12527 | 448 return; |
10725 | 449 break; |
450 case ID_CCE: /* not implemented yet, but skip the bits */ | |
12527 | 451 #ifdef COUPLING_DEC |
10725 | 452 hInfo->error = coupling_channel_element(hDecoder, ld); |
12527 | 453 #else |
454 hInfo->error = 6; | |
455 #endif | |
10725 | 456 if (hInfo->error > 0) |
12527 | 457 return; |
10725 | 458 break; |
459 case ID_DSE: | |
460 data_stream_element(hDecoder, ld); | |
461 break; | |
462 case ID_PCE: | |
12527 | 463 /* 14496-4: 5.6.4.1.2.1.3: */ |
464 /* program_configuration_element()'s in access units shall be ignored */ | |
465 program_config_element(pce, ld); | |
466 //if ((hInfo->error = program_config_element(pce, ld)) > 0) | |
467 // return; | |
468 //hDecoder->pce_set = 1; | |
10725 | 469 break; |
470 case ID_FIL: | |
471 /* one sbr_info describes a channel_element not a channel! */ | |
12527 | 472 /* if we encounter SBR data here: error */ |
473 /* SBR data will be read directly in the SCE/LFE/CPE element */ | |
10725 | 474 if ((hInfo->error = fill_element(hDecoder, ld, drc |
475 #ifdef SBR_DEC | |
12527 | 476 , INVALID_SBR_ELEMENT |
10725 | 477 #endif |
478 )) > 0) | |
12527 | 479 return; |
10725 | 480 break; |
481 } | |
482 } | |
483 #ifdef ERROR_RESILIENCE | |
484 } else { | |
485 /* Table 262: er_raw_data_block() */ | |
486 switch (hDecoder->channelConfiguration) | |
487 { | |
488 case 1: | |
12527 | 489 decode_sce_lfe(hDecoder, hInfo, ld, ID_SCE); |
10725 | 490 if (hInfo->error > 0) |
12527 | 491 return; |
10725 | 492 break; |
493 case 2: | |
12527 | 494 decode_cpe(hDecoder, hInfo, ld, ID_CPE); |
10725 | 495 if (hInfo->error > 0) |
12527 | 496 return; |
10725 | 497 break; |
498 case 3: | |
12527 | 499 decode_sce_lfe(hDecoder, hInfo, ld, ID_SCE); |
500 decode_cpe(hDecoder, hInfo, ld, ID_CPE); | |
10725 | 501 if (hInfo->error > 0) |
12527 | 502 return; |
10725 | 503 break; |
504 case 4: | |
12527 | 505 decode_sce_lfe(hDecoder, hInfo, ld, ID_SCE); |
506 decode_cpe(hDecoder, hInfo, ld, ID_CPE); | |
507 decode_sce_lfe(hDecoder, hInfo, ld, ID_SCE); | |
10725 | 508 if (hInfo->error > 0) |
12527 | 509 return; |
10725 | 510 break; |
511 case 5: | |
12527 | 512 decode_sce_lfe(hDecoder, hInfo, ld, ID_SCE); |
513 decode_cpe(hDecoder, hInfo, ld, ID_CPE); | |
514 decode_cpe(hDecoder, hInfo, ld, ID_CPE); | |
10725 | 515 if (hInfo->error > 0) |
12527 | 516 return; |
10725 | 517 break; |
518 case 6: | |
12527 | 519 decode_sce_lfe(hDecoder, hInfo, ld, ID_SCE); |
520 decode_cpe(hDecoder, hInfo, ld, ID_CPE); | |
521 decode_cpe(hDecoder, hInfo, ld, ID_CPE); | |
522 decode_sce_lfe(hDecoder, hInfo, ld, ID_LFE); | |
10725 | 523 if (hInfo->error > 0) |
12527 | 524 return; |
10725 | 525 break; |
12527 | 526 case 7: /* 8 channels */ |
527 decode_sce_lfe(hDecoder, hInfo, ld, ID_SCE); | |
528 decode_cpe(hDecoder, hInfo, ld, ID_CPE); | |
529 decode_cpe(hDecoder, hInfo, ld, ID_CPE); | |
530 decode_cpe(hDecoder, hInfo, ld, ID_CPE); | |
531 decode_sce_lfe(hDecoder, hInfo, ld, ID_LFE); | |
10725 | 532 if (hInfo->error > 0) |
12527 | 533 return; |
10725 | 534 break; |
535 default: | |
536 hInfo->error = 7; | |
12527 | 537 return; |
10725 | 538 } |
539 #if 0 | |
540 cnt = bits_to_decode() / 8; | |
541 while (cnt >= 1) | |
542 { | |
543 cnt -= extension_payload(cnt); | |
544 } | |
545 #endif | |
546 } | |
547 #endif | |
548 | |
549 /* new in corrigendum 14496-3:2002 */ | |
10989 | 550 #ifdef DRM |
25836
bc425ba00960
added code to check and handle the presence of LATM streams in the init() and decode() functions
nicodvb
parents:
25834
diff
changeset
|
551 if (hDecoder->object_type != DRM_ER_LC && !hDecoder->latm_header_present) |
10989 | 552 #endif |
553 { | |
554 faad_byte_align(ld); | |
555 } | |
10725 | 556 |
12527 | 557 return; |
10725 | 558 } |
559 | |
560 /* Table 4.4.4 and */ | |
561 /* Table 4.4.9 */ | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
562 static uint8_t single_lfe_channel_element(NeAACDecHandle hDecoder, bitfile *ld, |
12527 | 563 uint8_t channel, uint8_t *tag) |
10725 | 564 { |
10989 | 565 uint8_t retval = 0; |
12527 | 566 element sce = {0}; |
567 ic_stream *ics = &(sce.ics1); | |
568 ALIGN int16_t spec_data[1024] = {0}; | |
10725 | 569 |
12527 | 570 sce.element_instance_tag = (uint8_t)faad_getbits(ld, LEN_TAG |
10725 | 571 DEBUGVAR(1,38,"single_lfe_channel_element(): element_instance_tag")); |
572 | |
12527 | 573 *tag = sce.element_instance_tag; |
574 sce.channel = channel; | |
575 sce.paired_channel = -1; | |
10725 | 576 |
12527 | 577 retval = individual_channel_stream(hDecoder, &sce, ld, ics, 0, spec_data); |
578 if (retval > 0) | |
579 return retval; | |
10725 | 580 |
12527 | 581 #ifdef SBR_DEC |
582 /* check if next bitstream element is a fill element */ | |
583 /* if so, read it now so SBR decoding can be done in case of a file with SBR */ | |
584 if (faad_showbits(ld, LEN_SE_ID) == ID_FIL) | |
585 { | |
586 faad_flushbits(ld, LEN_SE_ID); | |
587 | |
588 /* one sbr_info describes a channel_element not a channel! */ | |
589 if ((retval = fill_element(hDecoder, ld, hDecoder->drc, hDecoder->fr_ch_ele)) > 0) | |
10725 | 590 { |
12527 | 591 return retval; |
10725 | 592 } |
12527 | 593 } |
10725 | 594 #endif |
10989 | 595 |
596 /* noiseless coding is done, spectral reconstruction is done now */ | |
12527 | 597 retval = reconstruct_single_channel(hDecoder, ics, &sce, spec_data); |
598 if (retval > 0) | |
599 return retval; | |
10989 | 600 |
601 return 0; | |
10725 | 602 } |
603 | |
604 /* Table 4.4.5 */ | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
605 static uint8_t channel_pair_element(NeAACDecHandle hDecoder, bitfile *ld, |
12527 | 606 uint8_t channels, uint8_t *tag) |
10725 | 607 { |
12527 | 608 ALIGN int16_t spec_data1[1024] = {0}; |
609 ALIGN int16_t spec_data2[1024] = {0}; | |
610 element cpe = {0}; | |
611 ic_stream *ics1 = &(cpe.ics1); | |
612 ic_stream *ics2 = &(cpe.ics2); | |
10725 | 613 uint8_t result; |
12527 | 614 |
615 cpe.channel = channels; | |
616 cpe.paired_channel = channels+1; | |
10725 | 617 |
12527 | 618 cpe.element_instance_tag = (uint8_t)faad_getbits(ld, LEN_TAG |
10725 | 619 DEBUGVAR(1,39,"channel_pair_element(): element_instance_tag")); |
12527 | 620 *tag = cpe.element_instance_tag; |
10725 | 621 |
12527 | 622 if ((cpe.common_window = faad_get1bit(ld |
10725 | 623 DEBUGVAR(1,40,"channel_pair_element(): common_window"))) & 1) |
624 { | |
625 /* both channels have common ics information */ | |
12527 | 626 if ((result = ics_info(hDecoder, ics1, ld, cpe.common_window)) > 0) |
10725 | 627 return result; |
628 | |
629 ics1->ms_mask_present = (uint8_t)faad_getbits(ld, 2 | |
630 DEBUGVAR(1,41,"channel_pair_element(): ms_mask_present")); | |
631 if (ics1->ms_mask_present == 1) | |
632 { | |
633 uint8_t g, sfb; | |
634 for (g = 0; g < ics1->num_window_groups; g++) | |
635 { | |
636 for (sfb = 0; sfb < ics1->max_sfb; sfb++) | |
637 { | |
638 ics1->ms_used[g][sfb] = faad_get1bit(ld | |
639 DEBUGVAR(1,42,"channel_pair_element(): faad_get1bit")); | |
640 } | |
641 } | |
642 } | |
643 | |
644 #ifdef ERROR_RESILIENCE | |
645 if ((hDecoder->object_type >= ER_OBJECT_START) && (ics1->predictor_data_present)) | |
646 { | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
647 if (( |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
648 #ifdef LTP_DEC |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
649 ics1->ltp.data_present = |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
650 #endif |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
651 faad_get1bit(ld DEBUGVAR(1,50,"channel_pair_element(): ltp.data_present"))) & 1) |
10725 | 652 { |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
653 #ifdef LTP_DEC |
12527 | 654 if ((result = ltp_data(hDecoder, ics1, &(ics1->ltp), ld)) > 0) |
655 { | |
656 return result; | |
657 } | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
658 #else |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
659 return 26; |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
660 #endif |
10725 | 661 } |
662 } | |
663 #endif | |
664 | |
665 memcpy(ics2, ics1, sizeof(ic_stream)); | |
666 } else { | |
667 ics1->ms_mask_present = 0; | |
668 } | |
669 | |
12527 | 670 if ((result = individual_channel_stream(hDecoder, &cpe, ld, ics1, |
10725 | 671 0, spec_data1)) > 0) |
672 { | |
673 return result; | |
674 } | |
675 | |
676 #ifdef ERROR_RESILIENCE | |
12527 | 677 if (cpe.common_window && (hDecoder->object_type >= ER_OBJECT_START) && |
10725 | 678 (ics1->predictor_data_present)) |
679 { | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
680 if (( |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
681 #ifdef LTP_DEC |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
682 ics1->ltp2.data_present = |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
683 #endif |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
684 faad_get1bit(ld DEBUGVAR(1,50,"channel_pair_element(): ltp.data_present"))) & 1) |
10725 | 685 { |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
686 #ifdef LTP_DEC |
12527 | 687 if ((result = ltp_data(hDecoder, ics1, &(ics1->ltp2), ld)) > 0) |
688 { | |
689 return result; | |
690 } | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
691 #else |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
692 return 26; |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
693 #endif |
10725 | 694 } |
695 } | |
696 #endif | |
697 | |
12527 | 698 if ((result = individual_channel_stream(hDecoder, &cpe, ld, ics2, |
10725 | 699 0, spec_data2)) > 0) |
700 { | |
701 return result; | |
702 } | |
703 | |
12527 | 704 #ifdef SBR_DEC |
705 /* check if next bitstream element is a fill element */ | |
706 /* if so, read it now so SBR decoding can be done in case of a file with SBR */ | |
707 if (faad_showbits(ld, LEN_SE_ID) == ID_FIL) | |
10725 | 708 { |
12527 | 709 faad_flushbits(ld, LEN_SE_ID); |
10725 | 710 |
12527 | 711 /* one sbr_info describes a channel_element not a channel! */ |
712 if ((result = fill_element(hDecoder, ld, hDecoder->drc, hDecoder->fr_ch_ele)) > 0) | |
713 { | |
10725 | 714 return result; |
715 } | |
10989 | 716 } |
10725 | 717 #endif |
718 | |
10989 | 719 /* noiseless coding is done, spectral reconstruction is done now */ |
12527 | 720 if ((result = reconstruct_channel_pair(hDecoder, ics1, ics2, &cpe, |
721 spec_data1, spec_data2)) > 0) | |
722 { | |
723 return result; | |
724 } | |
10989 | 725 |
10725 | 726 return 0; |
727 } | |
728 | |
729 /* Table 4.4.6 */ | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
730 static uint8_t ics_info(NeAACDecHandle hDecoder, ic_stream *ics, bitfile *ld, |
10725 | 731 uint8_t common_window) |
732 { | |
733 uint8_t retval = 0; | |
734 | |
735 /* ics->ics_reserved_bit = */ faad_get1bit(ld | |
736 DEBUGVAR(1,43,"ics_info(): ics_reserved_bit")); | |
737 ics->window_sequence = (uint8_t)faad_getbits(ld, 2 | |
738 DEBUGVAR(1,44,"ics_info(): window_sequence")); | |
739 ics->window_shape = faad_get1bit(ld | |
740 DEBUGVAR(1,45,"ics_info(): window_shape")); | |
741 | |
742 if (ics->window_sequence == EIGHT_SHORT_SEQUENCE) | |
743 { | |
744 ics->max_sfb = (uint8_t)faad_getbits(ld, 4 | |
745 DEBUGVAR(1,46,"ics_info(): max_sfb (short)")); | |
746 ics->scale_factor_grouping = (uint8_t)faad_getbits(ld, 7 | |
747 DEBUGVAR(1,47,"ics_info(): scale_factor_grouping")); | |
748 } else { | |
749 ics->max_sfb = (uint8_t)faad_getbits(ld, 6 | |
750 DEBUGVAR(1,48,"ics_info(): max_sfb (long)")); | |
751 } | |
752 | |
753 /* get the grouping information */ | |
754 if ((retval = window_grouping_info(hDecoder, ics)) > 0) | |
755 return retval; | |
756 | |
757 /* should be an error */ | |
758 /* check the range of max_sfb */ | |
759 if (ics->max_sfb > ics->num_swb) | |
760 return 16; | |
761 | |
762 if (ics->window_sequence != EIGHT_SHORT_SEQUENCE) | |
763 { | |
764 if ((ics->predictor_data_present = faad_get1bit(ld | |
765 DEBUGVAR(1,49,"ics_info(): predictor_data_present"))) & 1) | |
766 { | |
767 if (hDecoder->object_type == MAIN) /* MPEG2 style AAC predictor */ | |
768 { | |
769 uint8_t sfb; | |
770 | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
771 uint8_t limit = min(ics->max_sfb, max_pred_sfb(hDecoder->sf_index)); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
772 #ifdef MAIN_DEC |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
773 ics->pred.limit = limit; |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
774 #endif |
10725 | 775 |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
776 if (( |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
777 #ifdef MAIN_DEC |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
778 ics->pred.predictor_reset = |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
779 #endif |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
780 faad_get1bit(ld DEBUGVAR(1,53,"ics_info(): pred.predictor_reset"))) & 1) |
10725 | 781 { |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
782 #ifdef MAIN_DEC |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
783 ics->pred.predictor_reset_group_number = |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
784 #endif |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
785 (uint8_t)faad_getbits(ld, 5 DEBUGVAR(1,54,"ics_info(): pred.predictor_reset_group_number")); |
10725 | 786 } |
787 | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
788 for (sfb = 0; sfb < limit; sfb++) |
10725 | 789 { |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
790 #ifdef MAIN_DEC |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
791 ics->pred.prediction_used[sfb] = |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
792 #endif |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
793 faad_get1bit(ld DEBUGVAR(1,55,"ics_info(): pred.prediction_used")); |
10725 | 794 } |
795 } | |
796 #ifdef LTP_DEC | |
797 else { /* Long Term Prediction */ | |
798 if (hDecoder->object_type < ER_OBJECT_START) | |
799 { | |
800 if ((ics->ltp.data_present = faad_get1bit(ld | |
801 DEBUGVAR(1,50,"ics_info(): ltp.data_present"))) & 1) | |
802 { | |
12527 | 803 if ((retval = ltp_data(hDecoder, ics, &(ics->ltp), ld)) > 0) |
804 { | |
805 return retval; | |
806 } | |
10725 | 807 } |
808 if (common_window) | |
809 { | |
810 if ((ics->ltp2.data_present = faad_get1bit(ld | |
811 DEBUGVAR(1,51,"ics_info(): ltp2.data_present"))) & 1) | |
812 { | |
12527 | 813 if ((retval = ltp_data(hDecoder, ics, &(ics->ltp2), ld)) > 0) |
814 { | |
815 return retval; | |
816 } | |
10725 | 817 } |
818 } | |
819 } | |
820 #ifdef ERROR_RESILIENCE | |
821 if (!common_window && (hDecoder->object_type >= ER_OBJECT_START)) | |
822 { | |
823 if ((ics->ltp.data_present = faad_get1bit(ld | |
824 DEBUGVAR(1,50,"ics_info(): ltp.data_present"))) & 1) | |
825 { | |
826 ltp_data(hDecoder, ics, &(ics->ltp), ld); | |
827 } | |
828 } | |
829 #endif | |
830 } | |
831 #endif | |
832 } | |
833 } | |
834 | |
835 return retval; | |
836 } | |
837 | |
838 /* Table 4.4.7 */ | |
839 static uint8_t pulse_data(ic_stream *ics, pulse_info *pul, bitfile *ld) | |
840 { | |
841 uint8_t i; | |
842 | |
843 pul->number_pulse = (uint8_t)faad_getbits(ld, 2 | |
844 DEBUGVAR(1,56,"pulse_data(): number_pulse")); | |
845 pul->pulse_start_sfb = (uint8_t)faad_getbits(ld, 6 | |
846 DEBUGVAR(1,57,"pulse_data(): pulse_start_sfb")); | |
847 | |
848 /* check the range of pulse_start_sfb */ | |
849 if (pul->pulse_start_sfb > ics->num_swb) | |
850 return 16; | |
851 | |
852 for (i = 0; i < pul->number_pulse+1; i++) | |
853 { | |
854 pul->pulse_offset[i] = (uint8_t)faad_getbits(ld, 5 | |
855 DEBUGVAR(1,58,"pulse_data(): pulse_offset")); | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
856 #if 0 |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
857 printf("%d\n", pul->pulse_offset[i]); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
858 #endif |
10725 | 859 pul->pulse_amp[i] = (uint8_t)faad_getbits(ld, 4 |
860 DEBUGVAR(1,59,"pulse_data(): pulse_amp")); | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
861 #if 0 |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
862 printf("%d\n", pul->pulse_amp[i]); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
863 #endif |
10725 | 864 } |
865 | |
866 return 0; | |
867 } | |
868 | |
12527 | 869 #ifdef COUPLING_DEC |
10725 | 870 /* Table 4.4.8: Currently just for skipping the bits... */ |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
871 static uint8_t coupling_channel_element(NeAACDecHandle hDecoder, bitfile *ld) |
10725 | 872 { |
873 uint8_t c, result = 0; | |
874 uint8_t ind_sw_cce_flag = 0; | |
875 uint8_t num_gain_element_lists = 0; | |
876 uint8_t num_coupled_elements = 0; | |
877 | |
12527 | 878 element el_empty = {0}; |
879 ic_stream ics_empty = {0}; | |
10725 | 880 int16_t sh_data[1024]; |
881 | |
882 c = faad_getbits(ld, LEN_TAG | |
883 DEBUGVAR(1,900,"coupling_channel_element(): element_instance_tag")); | |
884 | |
885 ind_sw_cce_flag = faad_get1bit(ld | |
886 DEBUGVAR(1,901,"coupling_channel_element(): ind_sw_cce_flag")); | |
887 num_coupled_elements = faad_getbits(ld, 3 | |
888 DEBUGVAR(1,902,"coupling_channel_element(): num_coupled_elements")); | |
889 | |
890 for (c = 0; c < num_coupled_elements + 1; c++) | |
891 { | |
892 uint8_t cc_target_is_cpe, cc_target_tag_select; | |
893 | |
894 num_gain_element_lists++; | |
895 | |
896 cc_target_is_cpe = faad_get1bit(ld | |
897 DEBUGVAR(1,903,"coupling_channel_element(): cc_target_is_cpe")); | |
898 cc_target_tag_select = faad_getbits(ld, 4 | |
899 DEBUGVAR(1,904,"coupling_channel_element(): cc_target_tag_select")); | |
900 | |
901 if (cc_target_is_cpe) | |
902 { | |
903 uint8_t cc_l = faad_get1bit(ld | |
904 DEBUGVAR(1,905,"coupling_channel_element(): cc_l")); | |
905 uint8_t cc_r = faad_get1bit(ld | |
906 DEBUGVAR(1,906,"coupling_channel_element(): cc_r")); | |
907 | |
908 if (cc_l && cc_r) | |
909 num_gain_element_lists++; | |
910 } | |
911 } | |
912 | |
913 faad_get1bit(ld | |
914 DEBUGVAR(1,907,"coupling_channel_element(): cc_domain")); | |
915 faad_get1bit(ld | |
916 DEBUGVAR(1,908,"coupling_channel_element(): gain_element_sign")); | |
917 faad_getbits(ld, 2 | |
918 DEBUGVAR(1,909,"coupling_channel_element(): gain_element_scale")); | |
919 | |
920 if ((result = individual_channel_stream(hDecoder, &el_empty, ld, &ics_empty, | |
921 0, sh_data)) > 0) | |
922 { | |
923 return result; | |
924 } | |
925 | |
926 for (c = 1; c < num_gain_element_lists; c++) | |
927 { | |
928 uint8_t cge; | |
929 | |
930 if (ind_sw_cce_flag) | |
931 { | |
932 cge = 1; | |
933 } else { | |
934 cge = faad_get1bit(ld | |
935 DEBUGVAR(1,910,"coupling_channel_element(): common_gain_element_present")); | |
936 } | |
937 | |
938 if (cge) | |
939 { | |
940 huffman_scale_factor(ld); | |
941 } else { | |
942 uint8_t g, sfb; | |
943 | |
944 for (g = 0; g < ics_empty.num_window_groups; g++) | |
945 { | |
946 for (sfb = 0; sfb < ics_empty.max_sfb; sfb++) | |
947 { | |
948 if (ics_empty.sfb_cb[g][sfb] != ZERO_HCB) | |
949 huffman_scale_factor(ld); | |
950 } | |
951 } | |
952 } | |
953 } | |
954 | |
955 return 0; | |
956 } | |
12527 | 957 #endif |
10725 | 958 |
959 /* Table 4.4.10 */ | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
960 static uint16_t data_stream_element(NeAACDecHandle hDecoder, bitfile *ld) |
10725 | 961 { |
962 uint8_t byte_aligned; | |
963 uint16_t i, count; | |
964 | |
965 /* element_instance_tag = */ faad_getbits(ld, LEN_TAG | |
966 DEBUGVAR(1,60,"data_stream_element(): element_instance_tag")); | |
967 byte_aligned = faad_get1bit(ld | |
968 DEBUGVAR(1,61,"data_stream_element(): byte_aligned")); | |
969 count = (uint16_t)faad_getbits(ld, 8 | |
970 DEBUGVAR(1,62,"data_stream_element(): count")); | |
971 if (count == 255) | |
972 { | |
973 count += (uint16_t)faad_getbits(ld, 8 | |
974 DEBUGVAR(1,63,"data_stream_element(): extra count")); | |
975 } | |
976 if (byte_aligned) | |
977 faad_byte_align(ld); | |
978 | |
979 for (i = 0; i < count; i++) | |
980 { | |
12527 | 981 faad_getbits(ld, LEN_BYTE |
10725 | 982 DEBUGVAR(1,64,"data_stream_element(): data_stream_byte")); |
983 } | |
984 | |
985 return count; | |
986 } | |
987 | |
988 /* Table 4.4.11 */ | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
989 static uint8_t fill_element(NeAACDecHandle hDecoder, bitfile *ld, drc_info *drc |
10725 | 990 #ifdef SBR_DEC |
991 ,uint8_t sbr_ele | |
992 #endif | |
993 ) | |
994 { | |
995 uint16_t count; | |
996 #ifdef SBR_DEC | |
997 uint8_t bs_extension_type; | |
998 #endif | |
999 | |
1000 count = (uint16_t)faad_getbits(ld, 4 | |
1001 DEBUGVAR(1,65,"fill_element(): count")); | |
1002 if (count == 15) | |
1003 { | |
1004 count += (uint16_t)faad_getbits(ld, 8 | |
1005 DEBUGVAR(1,66,"fill_element(): extra count")) - 1; | |
1006 } | |
1007 | |
1008 if (count > 0) | |
1009 { | |
1010 #ifdef SBR_DEC | |
1011 bs_extension_type = (uint8_t)faad_showbits(ld, 4); | |
1012 | |
1013 if ((bs_extension_type == EXT_SBR_DATA) || | |
1014 (bs_extension_type == EXT_SBR_DATA_CRC)) | |
1015 { | |
12527 | 1016 if (sbr_ele == INVALID_SBR_ELEMENT) |
1017 return 24; | |
10725 | 1018 |
1019 if (!hDecoder->sbr[sbr_ele]) | |
10989 | 1020 { |
12527 | 1021 hDecoder->sbr[sbr_ele] = sbrDecodeInit(hDecoder->frameLength, |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1022 hDecoder->element_id[sbr_ele], 2*get_sample_rate(hDecoder->sf_index), |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1023 hDecoder->downSampledSBR |
10989 | 1024 #ifdef DRM |
1025 , 0 | |
1026 #endif | |
1027 ); | |
1028 } | |
10725 | 1029 |
12527 | 1030 hDecoder->sbr_present_flag = 1; |
1031 | |
1032 /* parse the SBR data */ | |
1033 hDecoder->sbr[sbr_ele]->ret = sbr_extension_data(ld, hDecoder->sbr[sbr_ele], count); | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1034 |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1035 #if 0 |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1036 if (hDecoder->sbr[sbr_ele]->ret > 0) |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1037 { |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1038 printf("%s\n", NeAACDecGetErrorMessage(hDecoder->sbr[sbr_ele]->ret)); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1039 } |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1040 #endif |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1041 |
12527 | 1042 #if (defined(PS_DEC) || defined(DRM_PS)) |
1043 if (hDecoder->sbr[sbr_ele]->ps_used) | |
1044 { | |
1045 hDecoder->ps_used[sbr_ele] = 1; | |
18141 | 1046 |
1047 /* set element independent flag to 1 as well */ | |
1048 hDecoder->ps_used_global = 1; | |
12527 | 1049 } |
1050 #endif | |
10725 | 1051 } else { |
1052 #endif | |
1053 while (count > 0) | |
1054 { | |
1055 count -= extension_payload(ld, drc, count); | |
1056 } | |
1057 #ifdef SBR_DEC | |
1058 } | |
1059 #endif | |
1060 } | |
1061 | |
1062 return 0; | |
1063 } | |
1064 | |
1065 /* Table 4.4.12 */ | |
1066 #ifdef SSR_DEC | |
1067 static void gain_control_data(bitfile *ld, ic_stream *ics) | |
1068 { | |
1069 uint8_t bd, wd, ad; | |
1070 ssr_info *ssr = &(ics->ssr); | |
1071 | |
1072 ssr->max_band = (uint8_t)faad_getbits(ld, 2 | |
1073 DEBUGVAR(1,1000,"gain_control_data(): max_band")); | |
1074 | |
1075 if (ics->window_sequence == ONLY_LONG_SEQUENCE) | |
1076 { | |
1077 for (bd = 1; bd <= ssr->max_band; bd++) | |
1078 { | |
1079 for (wd = 0; wd < 1; wd++) | |
1080 { | |
1081 ssr->adjust_num[bd][wd] = (uint8_t)faad_getbits(ld, 3 | |
1082 DEBUGVAR(1,1001,"gain_control_data(): adjust_num")); | |
1083 | |
1084 for (ad = 0; ad < ssr->adjust_num[bd][wd]; ad++) | |
1085 { | |
1086 ssr->alevcode[bd][wd][ad] = (uint8_t)faad_getbits(ld, 4 | |
1087 DEBUGVAR(1,1002,"gain_control_data(): alevcode")); | |
1088 ssr->aloccode[bd][wd][ad] = (uint8_t)faad_getbits(ld, 5 | |
1089 DEBUGVAR(1,1003,"gain_control_data(): aloccode")); | |
1090 } | |
1091 } | |
1092 } | |
1093 } else if (ics->window_sequence == LONG_START_SEQUENCE) { | |
1094 for (bd = 1; bd <= ssr->max_band; bd++) | |
1095 { | |
1096 for (wd = 0; wd < 2; wd++) | |
1097 { | |
1098 ssr->adjust_num[bd][wd] = (uint8_t)faad_getbits(ld, 3 | |
1099 DEBUGVAR(1,1001,"gain_control_data(): adjust_num")); | |
1100 | |
1101 for (ad = 0; ad < ssr->adjust_num[bd][wd]; ad++) | |
1102 { | |
1103 ssr->alevcode[bd][wd][ad] = (uint8_t)faad_getbits(ld, 4 | |
1104 DEBUGVAR(1,1002,"gain_control_data(): alevcode")); | |
1105 if (wd == 0) | |
1106 { | |
1107 ssr->aloccode[bd][wd][ad] = (uint8_t)faad_getbits(ld, 4 | |
1108 DEBUGVAR(1,1003,"gain_control_data(): aloccode")); | |
1109 } else { | |
1110 ssr->aloccode[bd][wd][ad] = (uint8_t)faad_getbits(ld, 2 | |
1111 DEBUGVAR(1,1003,"gain_control_data(): aloccode")); | |
1112 } | |
1113 } | |
1114 } | |
1115 } | |
1116 } else if (ics->window_sequence == EIGHT_SHORT_SEQUENCE) { | |
1117 for (bd = 1; bd <= ssr->max_band; bd++) | |
1118 { | |
1119 for (wd = 0; wd < 8; wd++) | |
1120 { | |
1121 ssr->adjust_num[bd][wd] = (uint8_t)faad_getbits(ld, 3 | |
1122 DEBUGVAR(1,1001,"gain_control_data(): adjust_num")); | |
1123 | |
1124 for (ad = 0; ad < ssr->adjust_num[bd][wd]; ad++) | |
1125 { | |
1126 ssr->alevcode[bd][wd][ad] = (uint8_t)faad_getbits(ld, 4 | |
1127 DEBUGVAR(1,1002,"gain_control_data(): alevcode")); | |
1128 ssr->aloccode[bd][wd][ad] = (uint8_t)faad_getbits(ld, 2 | |
1129 DEBUGVAR(1,1003,"gain_control_data(): aloccode")); | |
1130 } | |
1131 } | |
1132 } | |
1133 } else if (ics->window_sequence == LONG_STOP_SEQUENCE) { | |
1134 for (bd = 1; bd <= ssr->max_band; bd++) | |
1135 { | |
1136 for (wd = 0; wd < 2; wd++) | |
1137 { | |
1138 ssr->adjust_num[bd][wd] = (uint8_t)faad_getbits(ld, 3 | |
1139 DEBUGVAR(1,1001,"gain_control_data(): adjust_num")); | |
1140 | |
1141 for (ad = 0; ad < ssr->adjust_num[bd][wd]; ad++) | |
1142 { | |
1143 ssr->alevcode[bd][wd][ad] = (uint8_t)faad_getbits(ld, 4 | |
1144 DEBUGVAR(1,1002,"gain_control_data(): alevcode")); | |
1145 | |
1146 if (wd == 0) | |
1147 { | |
1148 ssr->aloccode[bd][wd][ad] = (uint8_t)faad_getbits(ld, 4 | |
1149 DEBUGVAR(1,1003,"gain_control_data(): aloccode")); | |
1150 } else { | |
1151 ssr->aloccode[bd][wd][ad] = (uint8_t)faad_getbits(ld, 5 | |
1152 DEBUGVAR(1,1003,"gain_control_data(): aloccode")); | |
1153 } | |
1154 } | |
1155 } | |
1156 } | |
1157 } | |
1158 } | |
1159 #endif | |
1160 | |
12527 | 1161 #ifdef SCALABLE_DEC |
1162 /* Table 4.4.13 ASME */ | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1163 void aac_scalable_main_element(NeAACDecHandle hDecoder, NeAACDecFrameInfo *hInfo, |
12527 | 1164 bitfile *ld, program_config *pce, drc_info *drc) |
1165 { | |
1166 uint8_t retval = 0; | |
1167 uint8_t channels = hDecoder->fr_channels = 0; | |
1168 uint8_t ch; | |
1169 uint8_t this_layer_stereo = (hDecoder->channelConfiguration > 1) ? 1 : 0; | |
1170 element cpe = {0}; | |
1171 ic_stream *ics1 = &(cpe.ics1); | |
1172 ic_stream *ics2 = &(cpe.ics2); | |
1173 int16_t *spec_data; | |
1174 ALIGN int16_t spec_data1[1024] = {0}; | |
1175 ALIGN int16_t spec_data2[1024] = {0}; | |
1176 | |
1177 hDecoder->fr_ch_ele = 0; | |
1178 | |
1179 hInfo->error = aac_scalable_main_header(hDecoder, ics1, ics2, ld, this_layer_stereo); | |
1180 if (hInfo->error > 0) | |
1181 return; | |
1182 | |
1183 cpe.common_window = 1; | |
1184 if (this_layer_stereo) | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1185 { |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1186 hDecoder->element_id[0] = ID_CPE; |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1187 if (hDecoder->element_output_channels[hDecoder->fr_ch_ele] == 0) |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1188 hDecoder->element_output_channels[hDecoder->fr_ch_ele] = 2; |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1189 } else { |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1190 hDecoder->element_id[0] = ID_SCE; |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1191 } |
12527 | 1192 |
1193 for (ch = 0; ch < (this_layer_stereo ? 2 : 1); ch++) | |
1194 { | |
1195 ic_stream *ics; | |
1196 if (ch == 0) | |
1197 { | |
1198 ics = ics1; | |
1199 spec_data = spec_data1; | |
1200 } else { | |
1201 ics = ics2; | |
1202 spec_data = spec_data2; | |
1203 } | |
1204 | |
1205 hInfo->error = individual_channel_stream(hDecoder, &cpe, ld, ics, 1, spec_data); | |
1206 if (hInfo->error > 0) | |
1207 return; | |
1208 } | |
1209 | |
1210 #ifdef DRM | |
1211 #ifdef SBR_DEC | |
1212 /* In case of DRM we need to read the SBR info before channel reconstruction */ | |
1213 if ((hDecoder->sbr_present_flag == 1) && (hDecoder->object_type == DRM_ER_LC)) | |
1214 { | |
1215 bitfile ld_sbr = {0}; | |
1216 uint32_t i; | |
1217 uint16_t count = 0; | |
1218 uint8_t *revbuffer; | |
1219 uint8_t *prevbufstart; | |
1220 uint8_t *pbufend; | |
1221 | |
1222 /* all forward bitreading should be finished at this point */ | |
1223 uint32_t bitsconsumed = faad_get_processed_bits(ld); | |
1224 uint32_t buffer_size = faad_origbitbuffer_size(ld); | |
1225 uint8_t *buffer = (uint8_t*)faad_origbitbuffer(ld); | |
1226 | |
1227 if (bitsconsumed + 8 > buffer_size*8) | |
1228 { | |
1229 hInfo->error = 14; | |
1230 return; | |
1231 } | |
1232 | |
1233 if (!hDecoder->sbr[0]) | |
1234 { | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1235 hDecoder->sbr[0] = sbrDecodeInit(hDecoder->frameLength, hDecoder->element_id[0], |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1236 2*get_sample_rate(hDecoder->sf_index), 0 /* ds SBR */, 1); |
12527 | 1237 } |
1238 | |
1239 /* Reverse bit reading of SBR data in DRM audio frame */ | |
1240 revbuffer = (uint8_t*)faad_malloc(buffer_size*sizeof(uint8_t)); | |
1241 prevbufstart = revbuffer; | |
1242 pbufend = &buffer[buffer_size - 1]; | |
1243 for (i = 0; i < buffer_size; i++) | |
1244 *prevbufstart++ = tabFlipbits[*pbufend--]; | |
1245 | |
1246 /* Set SBR data */ | |
1247 /* consider 8 bits from AAC-CRC */ | |
1248 count = (uint16_t)bit2byte(buffer_size*8 - bitsconsumed); | |
1249 faad_initbits(&ld_sbr, revbuffer, count); | |
1250 | |
1251 hDecoder->sbr[0]->sample_rate = get_sample_rate(hDecoder->sf_index); | |
1252 hDecoder->sbr[0]->sample_rate *= 2; | |
1253 | |
1254 faad_getbits(&ld_sbr, 8); /* Skip 8-bit CRC */ | |
1255 | |
1256 hDecoder->sbr[0]->ret = sbr_extension_data(&ld_sbr, hDecoder->sbr[0], count); | |
1257 #if (defined(PS_DEC) || defined(DRM_PS)) | |
1258 if (hDecoder->sbr[0]->ps_used) | |
1259 { | |
1260 hDecoder->ps_used[0] = 1; | |
18141 | 1261 hDecoder->ps_used_global = 1; |
12527 | 1262 } |
1263 #endif | |
1264 | |
1265 /* check CRC */ | |
1266 /* no need to check it if there was already an error */ | |
18141 | 1267 if (hDecoder->sbr[0]->ret == 0) |
1268 hDecoder->sbr[0]->ret = (uint8_t)faad_check_CRC(&ld_sbr, (uint16_t)faad_get_processed_bits(&ld_sbr) - 8); | |
1269 | |
1270 /* SBR data was corrupted, disable it until the next header */ | |
1271 if (hDecoder->sbr[0]->ret != 0) | |
1272 { | |
1273 hDecoder->sbr[0]->header_count = 0; | |
1274 } | |
12527 | 1275 |
1276 faad_endbits(&ld_sbr); | |
1277 | |
1278 if (revbuffer) | |
1279 faad_free(revbuffer); | |
1280 } | |
1281 #endif | |
1282 #endif | |
1283 | |
1284 if (this_layer_stereo) | |
1285 { | |
1286 hInfo->error = reconstruct_channel_pair(hDecoder, ics1, ics2, &cpe, spec_data1, spec_data2); | |
1287 if (hInfo->error > 0) | |
1288 return; | |
1289 } else { | |
1290 hInfo->error = reconstruct_single_channel(hDecoder, ics1, &cpe, spec_data1); | |
1291 if (hInfo->error > 0) | |
1292 return; | |
1293 } | |
1294 | |
1295 /* map output channels position to internal data channels */ | |
1296 if (hDecoder->element_output_channels[hDecoder->fr_ch_ele] == 2) | |
1297 { | |
1298 /* this might be faulty when pce_set is true */ | |
1299 hDecoder->internal_channel[channels] = channels; | |
1300 hDecoder->internal_channel[channels+1] = channels+1; | |
1301 } else { | |
1302 hDecoder->internal_channel[channels] = channels; | |
1303 } | |
1304 | |
1305 hDecoder->fr_channels += hDecoder->element_output_channels[hDecoder->fr_ch_ele]; | |
1306 hDecoder->fr_ch_ele++; | |
1307 | |
1308 return; | |
1309 } | |
1310 | |
1311 /* Table 4.4.15 */ | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1312 static int8_t aac_scalable_main_header(NeAACDecHandle hDecoder, ic_stream *ics1, ic_stream *ics2, |
12527 | 1313 bitfile *ld, uint8_t this_layer_stereo) |
1314 { | |
1315 uint8_t retval = 0; | |
1316 uint8_t ch; | |
1317 ic_stream *ics; | |
1318 | |
1319 /* ics1->ics_reserved_bit = */ faad_get1bit(ld | |
1320 DEBUGVAR(1,300,"aac_scalable_main_header(): ics_reserved_bits")); | |
1321 ics1->window_sequence = (uint8_t)faad_getbits(ld, 2 | |
1322 DEBUGVAR(1,301,"aac_scalable_main_header(): window_sequence")); | |
1323 ics1->window_shape = faad_get1bit(ld | |
1324 DEBUGVAR(1,302,"aac_scalable_main_header(): window_shape")); | |
1325 | |
1326 if (ics1->window_sequence == EIGHT_SHORT_SEQUENCE) | |
1327 { | |
1328 ics1->max_sfb = (uint8_t)faad_getbits(ld, 4 | |
1329 DEBUGVAR(1,303,"aac_scalable_main_header(): max_sfb (short)")); | |
1330 ics1->scale_factor_grouping = (uint8_t)faad_getbits(ld, 7 | |
1331 DEBUGVAR(1,304,"aac_scalable_main_header(): scale_factor_grouping")); | |
1332 } else { | |
1333 ics1->max_sfb = (uint8_t)faad_getbits(ld, 6 | |
1334 DEBUGVAR(1,305,"aac_scalable_main_header(): max_sfb (long)")); | |
1335 } | |
1336 | |
1337 /* get the grouping information */ | |
1338 if ((retval = window_grouping_info(hDecoder, ics1)) > 0) | |
1339 return retval; | |
1340 | |
1341 /* should be an error */ | |
1342 /* check the range of max_sfb */ | |
1343 if (ics1->max_sfb > ics1->num_swb) | |
1344 return 16; | |
1345 | |
1346 if (this_layer_stereo) | |
1347 { | |
1348 ics1->ms_mask_present = (uint8_t)faad_getbits(ld, 2 | |
1349 DEBUGVAR(1,306,"aac_scalable_main_header(): ms_mask_present")); | |
1350 if (ics1->ms_mask_present == 1) | |
1351 { | |
1352 uint8_t g, sfb; | |
1353 for (g = 0; g < ics1->num_window_groups; g++) | |
1354 { | |
1355 for (sfb = 0; sfb < ics1->max_sfb; sfb++) | |
1356 { | |
1357 ics1->ms_used[g][sfb] = faad_get1bit(ld | |
1358 DEBUGVAR(1,307,"aac_scalable_main_header(): faad_get1bit")); | |
1359 } | |
1360 } | |
1361 } | |
1362 | |
1363 memcpy(ics2, ics1, sizeof(ic_stream)); | |
1364 } else { | |
1365 ics1->ms_mask_present = 0; | |
1366 } | |
1367 | |
1368 if (0) | |
1369 { | |
1370 faad_get1bit(ld | |
1371 DEBUGVAR(1,308,"aac_scalable_main_header(): tns_channel_mono_layer")); | |
1372 } | |
1373 | |
1374 for (ch = 0; ch < (this_layer_stereo ? 2 : 1); ch++) | |
1375 { | |
1376 if (ch == 0) | |
1377 ics = ics1; | |
1378 else | |
1379 ics = ics2; | |
1380 | |
1381 if ( 1 /*!tvq_layer_pesent || (tns_aac_tvq_en[ch] == 1)*/) | |
1382 { | |
1383 if ((ics->tns_data_present = faad_get1bit(ld | |
1384 DEBUGVAR(1,309,"aac_scalable_main_header(): tns_data_present"))) & 1) | |
1385 { | |
1386 #ifdef DRM | |
1387 /* different order of data units in DRM */ | |
1388 if (hDecoder->object_type != DRM_ER_LC) | |
1389 #endif | |
1390 { | |
1391 tns_data(ics, &(ics->tns), ld); | |
1392 } | |
1393 } | |
1394 } | |
1395 #if 0 | |
1396 if (0 /*core_flag || tvq_layer_pesent*/) | |
1397 { | |
1398 if ((ch==0) || ((ch==1) && (core_stereo || tvq_stereo)) | |
1399 diff_control_data(); | |
1400 if (mono_stereo_flag) | |
1401 diff_control_data_lr(); | |
1402 } else { | |
1403 #endif | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1404 if (( |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1405 #ifdef LTP_DEC |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1406 ics->ltp.data_present = |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1407 #endif |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1408 faad_get1bit(ld DEBUGVAR(1,310,"aac_scalable_main_header(): ltp.data_present"))) & 1) |
12527 | 1409 { |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1410 #ifdef LTP_DEC |
12527 | 1411 if ((retval = ltp_data(hDecoder, ics, &(ics->ltp), ld)) > 0) |
1412 { | |
1413 return retval; | |
1414 } | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1415 #else |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1416 return 26; |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1417 #endif |
12527 | 1418 } |
1419 #if 0 | |
1420 } | |
1421 #endif | |
1422 } | |
1423 | |
1424 return 0; | |
1425 } | |
1426 #endif | |
1427 | |
10725 | 1428 /* Table 4.4.24 */ |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1429 static uint8_t individual_channel_stream(NeAACDecHandle hDecoder, element *ele, |
10725 | 1430 bitfile *ld, ic_stream *ics, uint8_t scal_flag, |
1431 int16_t *spec_data) | |
1432 { | |
1433 uint8_t result; | |
1434 | |
1435 ics->global_gain = (uint8_t)faad_getbits(ld, 8 | |
1436 DEBUGVAR(1,67,"individual_channel_stream(): global_gain")); | |
1437 | |
1438 if (!ele->common_window && !scal_flag) | |
1439 { | |
1440 if ((result = ics_info(hDecoder, ics, ld, ele->common_window)) > 0) | |
1441 return result; | |
1442 } | |
1443 | |
1444 if ((result = section_data(hDecoder, ics, ld)) > 0) | |
1445 return result; | |
1446 | |
1447 if ((result = scale_factor_data(hDecoder, ics, ld)) > 0) | |
1448 return result; | |
1449 | |
1450 if (!scal_flag) | |
1451 { | |
1452 /** | |
1453 ** NOTE: It could be that pulse data is available in scalable AAC too, | |
1454 ** as said in Amendment 1, this could be only the case for ER AAC, | |
1455 ** though. (have to check this out later) | |
1456 **/ | |
1457 /* get pulse data */ | |
1458 if ((ics->pulse_data_present = faad_get1bit(ld | |
1459 DEBUGVAR(1,68,"individual_channel_stream(): pulse_data_present"))) & 1) | |
1460 { | |
1461 if ((result = pulse_data(ics, &(ics->pul), ld)) > 0) | |
1462 return result; | |
1463 } | |
1464 | |
1465 /* get tns data */ | |
1466 if ((ics->tns_data_present = faad_get1bit(ld | |
1467 DEBUGVAR(1,69,"individual_channel_stream(): tns_data_present"))) & 1) | |
1468 { | |
1469 #ifdef ERROR_RESILIENCE | |
1470 if (hDecoder->object_type < ER_OBJECT_START) | |
1471 #endif | |
1472 tns_data(ics, &(ics->tns), ld); | |
1473 } | |
1474 | |
1475 /* get gain control data */ | |
1476 if ((ics->gain_control_data_present = faad_get1bit(ld | |
1477 DEBUGVAR(1,70,"individual_channel_stream(): gain_control_data_present"))) & 1) | |
1478 { | |
1479 #ifdef SSR_DEC | |
1480 if (hDecoder->object_type != SSR) | |
1481 return 1; | |
1482 else | |
1483 gain_control_data(ld, ics); | |
1484 #else | |
1485 return 1; | |
1486 #endif | |
1487 } | |
1488 } | |
1489 | |
1490 #ifdef ERROR_RESILIENCE | |
1491 if (hDecoder->aacSpectralDataResilienceFlag) | |
1492 { | |
1493 ics->length_of_reordered_spectral_data = (uint16_t)faad_getbits(ld, 14 | |
1494 DEBUGVAR(1,147,"individual_channel_stream(): length_of_reordered_spectral_data")); | |
1495 | |
1496 if (hDecoder->channelConfiguration == 2) | |
1497 { | |
1498 if (ics->length_of_reordered_spectral_data > 6144) | |
1499 ics->length_of_reordered_spectral_data = 6144; | |
1500 } else { | |
1501 if (ics->length_of_reordered_spectral_data > 12288) | |
1502 ics->length_of_reordered_spectral_data = 12288; | |
1503 } | |
1504 | |
1505 ics->length_of_longest_codeword = (uint8_t)faad_getbits(ld, 6 | |
1506 DEBUGVAR(1,148,"individual_channel_stream(): length_of_longest_codeword")); | |
1507 if (ics->length_of_longest_codeword >= 49) | |
1508 ics->length_of_longest_codeword = 49; | |
1509 } | |
1510 | |
1511 /* RVLC spectral data is put here */ | |
1512 if (hDecoder->aacScalefactorDataResilienceFlag) | |
1513 { | |
1514 if ((result = rvlc_decode_scale_factors(ics, ld)) > 0) | |
1515 return result; | |
1516 } | |
1517 | |
1518 if (hDecoder->object_type >= ER_OBJECT_START) | |
1519 { | |
1520 if (ics->tns_data_present) | |
1521 tns_data(ics, &(ics->tns), ld); | |
1522 } | |
1523 | |
12527 | 1524 #ifdef DRM |
1525 /* CRC check */ | |
1526 if (hDecoder->object_type == DRM_ER_LC) | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1527 if ((result = (uint8_t)faad_check_CRC(ld, (uint16_t)faad_get_processed_bits(ld) - 8)) > 0) |
12527 | 1528 return result; |
1529 #endif | |
1530 | |
10725 | 1531 if (hDecoder->aacSpectralDataResilienceFlag) |
1532 { | |
1533 /* error resilient spectral data decoding */ | |
1534 if ((result = reordered_spectral_data(hDecoder, ics, ld, spec_data)) > 0) | |
1535 { | |
1536 return result; | |
1537 } | |
1538 } else { | |
1539 #endif | |
1540 /* decode the spectral data */ | |
1541 if ((result = spectral_data(hDecoder, ics, ld, spec_data)) > 0) | |
1542 { | |
1543 return result; | |
1544 } | |
1545 #ifdef ERROR_RESILIENCE | |
1546 } | |
1547 #endif | |
1548 | |
1549 /* pulse coding reconstruction */ | |
1550 if (ics->pulse_data_present) | |
1551 { | |
1552 if (ics->window_sequence != EIGHT_SHORT_SEQUENCE) | |
1553 { | |
1554 if ((result = pulse_decode(ics, spec_data, hDecoder->frameLength)) > 0) | |
1555 return result; | |
1556 } else { | |
1557 return 2; /* pulse coding not allowed for short blocks */ | |
1558 } | |
1559 } | |
1560 | |
1561 return 0; | |
1562 } | |
1563 | |
1564 /* Table 4.4.25 */ | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1565 static uint8_t section_data(NeAACDecHandle hDecoder, ic_stream *ics, bitfile *ld) |
10725 | 1566 { |
1567 uint8_t g; | |
1568 uint8_t sect_esc_val, sect_bits; | |
1569 | |
1570 if (ics->window_sequence == EIGHT_SHORT_SEQUENCE) | |
1571 sect_bits = 3; | |
1572 else | |
1573 sect_bits = 5; | |
1574 sect_esc_val = (1<<sect_bits) - 1; | |
1575 | |
1576 #if 0 | |
1577 printf("\ntotal sfb %d\n", ics->max_sfb); | |
1578 printf(" sect top cb\n"); | |
1579 #endif | |
1580 | |
1581 for (g = 0; g < ics->num_window_groups; g++) | |
1582 { | |
1583 uint8_t k = 0; | |
1584 uint8_t i = 0; | |
1585 | |
1586 while (k < ics->max_sfb) | |
1587 { | |
1588 #ifdef ERROR_RESILIENCE | |
1589 uint8_t vcb11 = 0; | |
1590 #endif | |
1591 uint8_t sfb; | |
1592 uint8_t sect_len_incr; | |
1593 uint16_t sect_len = 0; | |
1594 uint8_t sect_cb_bits = 4; | |
1595 | |
1596 /* if "faad_getbits" detects error and returns "0", "k" is never | |
1597 incremented and we cannot leave the while loop */ | |
1598 if ((ld->error != 0) || (ld->no_more_reading)) | |
1599 return 14; | |
1600 | |
1601 #ifdef ERROR_RESILIENCE | |
1602 if (hDecoder->aacSectionDataResilienceFlag) | |
1603 sect_cb_bits = 5; | |
1604 #endif | |
1605 | |
1606 ics->sect_cb[g][i] = (uint8_t)faad_getbits(ld, sect_cb_bits | |
1607 DEBUGVAR(1,71,"section_data(): sect_cb")); | |
1608 | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1609 #if 0 |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1610 printf("%d\n", ics->sect_cb[g][i]); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1611 #endif |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1612 |
10725 | 1613 if (ics->sect_cb[g][i] == NOISE_HCB) |
1614 ics->noise_used = 1; | |
1615 | |
1616 #ifdef ERROR_RESILIENCE | |
1617 if (hDecoder->aacSectionDataResilienceFlag) | |
1618 { | |
1619 if ((ics->sect_cb[g][i] == 11) || | |
1620 ((ics->sect_cb[g][i] >= 16) && (ics->sect_cb[g][i] <= 32))) | |
1621 { | |
1622 vcb11 = 1; | |
1623 } | |
1624 } | |
1625 if (vcb11) | |
1626 { | |
1627 sect_len_incr = 1; | |
1628 } else { | |
1629 #endif | |
1630 sect_len_incr = (uint8_t)faad_getbits(ld, sect_bits | |
1631 DEBUGVAR(1,72,"section_data(): sect_len_incr")); | |
1632 #ifdef ERROR_RESILIENCE | |
1633 } | |
1634 #endif | |
1635 while ((sect_len_incr == sect_esc_val) /* && | |
1636 (k+sect_len < ics->max_sfb)*/) | |
1637 { | |
1638 sect_len += sect_len_incr; | |
1639 sect_len_incr = (uint8_t)faad_getbits(ld, sect_bits | |
1640 DEBUGVAR(1,72,"section_data(): sect_len_incr")); | |
1641 } | |
1642 | |
1643 sect_len += sect_len_incr; | |
1644 | |
1645 ics->sect_start[g][i] = k; | |
1646 ics->sect_end[g][i] = k + sect_len; | |
1647 | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1648 #if 0 |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1649 printf("%d\n", ics->sect_start[g][i]); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1650 #endif |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1651 #if 0 |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1652 printf("%d\n", ics->sect_end[g][i]); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1653 #endif |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1654 |
10725 | 1655 if (k + sect_len >= 8*15) |
1656 return 15; | |
1657 if (i >= 8*15) | |
1658 return 15; | |
1659 | |
1660 for (sfb = k; sfb < k + sect_len; sfb++) | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1661 { |
10725 | 1662 ics->sfb_cb[g][sfb] = ics->sect_cb[g][i]; |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1663 #if 0 |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1664 printf("%d\n", ics->sfb_cb[g][sfb]); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1665 #endif |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1666 } |
10725 | 1667 |
1668 #if 0 | |
1669 printf(" %6d %6d %6d\n", | |
1670 i, | |
1671 ics->sect_end[g][i], | |
1672 ics->sect_cb[g][i]); | |
1673 #endif | |
1674 | |
1675 k += sect_len; | |
1676 i++; | |
1677 } | |
1678 ics->num_sec[g] = i; | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1679 #if 0 |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1680 printf("%d\n", ics->num_sec[g]); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1681 #endif |
10725 | 1682 } |
1683 | |
1684 #if 0 | |
1685 printf("\n"); | |
1686 #endif | |
1687 | |
1688 return 0; | |
1689 } | |
1690 | |
1691 /* | |
1692 * decode_scale_factors() | |
1693 * decodes the scalefactors from the bitstream | |
1694 */ | |
1695 /* | |
1696 * All scalefactors (and also the stereo positions and pns energies) are | |
1697 * transmitted using Huffman coded DPCM relative to the previous active | |
1698 * scalefactor (respectively previous stereo position or previous pns energy, | |
1699 * see subclause 4.6.2 and 4.6.3). The first active scalefactor is | |
1700 * differentially coded relative to the global gain. | |
1701 */ | |
1702 static uint8_t decode_scale_factors(ic_stream *ics, bitfile *ld) | |
1703 { | |
1704 uint8_t g, sfb; | |
1705 int16_t t; | |
1706 int8_t noise_pcm_flag = 1; | |
1707 | |
1708 int16_t scale_factor = ics->global_gain; | |
1709 int16_t is_position = 0; | |
1710 int16_t noise_energy = ics->global_gain - 90; | |
1711 | |
1712 for (g = 0; g < ics->num_window_groups; g++) | |
1713 { | |
1714 for (sfb = 0; sfb < ics->max_sfb; sfb++) | |
1715 { | |
1716 switch (ics->sfb_cb[g][sfb]) | |
1717 { | |
1718 case ZERO_HCB: /* zero book */ | |
1719 ics->scale_factors[g][sfb] = 0; | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1720 //#define SF_PRINT |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1721 #ifdef SF_PRINT |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1722 printf("%d\n", ics->scale_factors[g][sfb]); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1723 #endif |
10725 | 1724 break; |
1725 case INTENSITY_HCB: /* intensity books */ | |
1726 case INTENSITY_HCB2: | |
1727 | |
1728 /* decode intensity position */ | |
1729 t = huffman_scale_factor(ld); | |
1730 is_position += (t - 60); | |
1731 ics->scale_factors[g][sfb] = is_position; | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1732 #ifdef SF_PRINT |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1733 printf("%d\n", ics->scale_factors[g][sfb]); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1734 #endif |
10725 | 1735 |
1736 break; | |
1737 case NOISE_HCB: /* noise books */ | |
1738 | |
1739 /* decode noise energy */ | |
1740 if (noise_pcm_flag) | |
1741 { | |
1742 noise_pcm_flag = 0; | |
1743 t = (int16_t)faad_getbits(ld, 9 | |
1744 DEBUGVAR(1,73,"scale_factor_data(): first noise")) - 256; | |
1745 } else { | |
1746 t = huffman_scale_factor(ld); | |
1747 t -= 60; | |
1748 } | |
1749 noise_energy += t; | |
1750 ics->scale_factors[g][sfb] = noise_energy; | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1751 #ifdef SF_PRINT |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1752 printf("%d\n", ics->scale_factors[g][sfb]); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1753 #endif |
10725 | 1754 |
1755 break; | |
1756 default: /* spectral books */ | |
1757 | |
12527 | 1758 /* ics->scale_factors[g][sfb] must be between 0 and 255 */ |
1759 | |
1760 ics->scale_factors[g][sfb] = 0; | |
1761 | |
10725 | 1762 /* decode scale factor */ |
1763 t = huffman_scale_factor(ld); | |
1764 scale_factor += (t - 60); | |
12527 | 1765 if (scale_factor < 0 || scale_factor > 255) |
10725 | 1766 return 4; |
1767 ics->scale_factors[g][sfb] = scale_factor; | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1768 #ifdef SF_PRINT |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1769 printf("%d\n", ics->scale_factors[g][sfb]); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1770 #endif |
10725 | 1771 |
1772 break; | |
1773 } | |
1774 } | |
1775 } | |
1776 | |
1777 return 0; | |
1778 } | |
1779 | |
1780 /* Table 4.4.26 */ | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1781 static uint8_t scale_factor_data(NeAACDecHandle hDecoder, ic_stream *ics, bitfile *ld) |
10725 | 1782 { |
12527 | 1783 uint8_t ret = 0; |
1784 #ifdef PROFILE | |
1785 int64_t count = faad_get_ts(); | |
1786 #endif | |
1787 | |
10725 | 1788 #ifdef ERROR_RESILIENCE |
1789 if (!hDecoder->aacScalefactorDataResilienceFlag) | |
1790 { | |
1791 #endif | |
12527 | 1792 ret = decode_scale_factors(ics, ld); |
10725 | 1793 #ifdef ERROR_RESILIENCE |
1794 } else { | |
1795 /* In ER AAC the parameters for RVLC are seperated from the actual | |
1796 data that holds the scale_factors. | |
1797 Strangely enough, 2 parameters for HCR are put inbetween them. | |
1798 */ | |
12527 | 1799 ret = rvlc_scale_factor_data(ics, ld); |
10725 | 1800 } |
1801 #endif | |
12527 | 1802 |
1803 #ifdef PROFILE | |
1804 count = faad_get_ts() - count; | |
1805 hDecoder->scalefac_cycles += count; | |
1806 #endif | |
1807 | |
1808 return ret; | |
10725 | 1809 } |
1810 | |
1811 /* Table 4.4.27 */ | |
1812 static void tns_data(ic_stream *ics, tns_info *tns, bitfile *ld) | |
1813 { | |
1814 uint8_t w, filt, i, start_coef_bits, coef_bits; | |
1815 uint8_t n_filt_bits = 2; | |
1816 uint8_t length_bits = 6; | |
1817 uint8_t order_bits = 5; | |
1818 | |
1819 if (ics->window_sequence == EIGHT_SHORT_SEQUENCE) | |
1820 { | |
1821 n_filt_bits = 1; | |
1822 length_bits = 4; | |
1823 order_bits = 3; | |
1824 } | |
1825 | |
1826 for (w = 0; w < ics->num_windows; w++) | |
1827 { | |
1828 tns->n_filt[w] = (uint8_t)faad_getbits(ld, n_filt_bits | |
1829 DEBUGVAR(1,74,"tns_data(): n_filt")); | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1830 #if 0 |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1831 printf("%d\n", tns->n_filt[w]); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1832 #endif |
10725 | 1833 |
1834 if (tns->n_filt[w]) | |
1835 { | |
1836 if ((tns->coef_res[w] = faad_get1bit(ld | |
1837 DEBUGVAR(1,75,"tns_data(): coef_res"))) & 1) | |
1838 { | |
1839 start_coef_bits = 4; | |
1840 } else { | |
1841 start_coef_bits = 3; | |
1842 } | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1843 #if 0 |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1844 printf("%d\n", tns->coef_res[w]); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1845 #endif |
10725 | 1846 } |
1847 | |
1848 for (filt = 0; filt < tns->n_filt[w]; filt++) | |
1849 { | |
1850 tns->length[w][filt] = (uint8_t)faad_getbits(ld, length_bits | |
1851 DEBUGVAR(1,76,"tns_data(): length")); | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1852 #if 0 |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1853 printf("%d\n", tns->length[w][filt]); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1854 #endif |
10725 | 1855 tns->order[w][filt] = (uint8_t)faad_getbits(ld, order_bits |
1856 DEBUGVAR(1,77,"tns_data(): order")); | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1857 #if 0 |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1858 printf("%d\n", tns->order[w][filt]); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1859 #endif |
10725 | 1860 if (tns->order[w][filt]) |
1861 { | |
1862 tns->direction[w][filt] = faad_get1bit(ld | |
1863 DEBUGVAR(1,78,"tns_data(): direction")); | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1864 #if 0 |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1865 printf("%d\n", tns->direction[w][filt]); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1866 #endif |
10725 | 1867 tns->coef_compress[w][filt] = faad_get1bit(ld |
1868 DEBUGVAR(1,79,"tns_data(): coef_compress")); | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1869 #if 0 |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1870 printf("%d\n", tns->coef_compress[w][filt]); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1871 #endif |
10725 | 1872 |
1873 coef_bits = start_coef_bits - tns->coef_compress[w][filt]; | |
1874 for (i = 0; i < tns->order[w][filt]; i++) | |
1875 { | |
1876 tns->coef[w][filt][i] = (uint8_t)faad_getbits(ld, coef_bits | |
1877 DEBUGVAR(1,80,"tns_data(): coef")); | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1878 #if 0 |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1879 printf("%d\n", tns->coef[w][filt][i]); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1880 #endif |
10725 | 1881 } |
1882 } | |
1883 } | |
1884 } | |
1885 } | |
1886 | |
1887 #ifdef LTP_DEC | |
1888 /* Table 4.4.28 */ | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1889 static uint8_t ltp_data(NeAACDecHandle hDecoder, ic_stream *ics, ltp_info *ltp, bitfile *ld) |
10725 | 1890 { |
1891 uint8_t sfb, w; | |
1892 | |
12527 | 1893 ltp->lag = 0; |
1894 | |
10725 | 1895 #ifdef LD_DEC |
1896 if (hDecoder->object_type == LD) | |
1897 { | |
1898 ltp->lag_update = (uint8_t)faad_getbits(ld, 1 | |
1899 DEBUGVAR(1,142,"ltp_data(): lag_update")); | |
1900 | |
1901 if (ltp->lag_update) | |
1902 { | |
1903 ltp->lag = (uint16_t)faad_getbits(ld, 10 | |
1904 DEBUGVAR(1,81,"ltp_data(): lag")); | |
1905 } | |
1906 } else { | |
1907 #endif | |
1908 ltp->lag = (uint16_t)faad_getbits(ld, 11 | |
1909 DEBUGVAR(1,81,"ltp_data(): lag")); | |
1910 #ifdef LD_DEC | |
1911 } | |
1912 #endif | |
12527 | 1913 |
1914 /* Check length of lag */ | |
1915 if (ltp->lag > (hDecoder->frameLength << 1)) | |
1916 return 18; | |
1917 | |
10725 | 1918 ltp->coef = (uint8_t)faad_getbits(ld, 3 |
1919 DEBUGVAR(1,82,"ltp_data(): coef")); | |
1920 | |
1921 if (ics->window_sequence == EIGHT_SHORT_SEQUENCE) | |
1922 { | |
1923 for (w = 0; w < ics->num_windows; w++) | |
1924 { | |
1925 if ((ltp->short_used[w] = faad_get1bit(ld | |
1926 DEBUGVAR(1,83,"ltp_data(): short_used"))) & 1) | |
1927 { | |
1928 ltp->short_lag_present[w] = faad_get1bit(ld | |
1929 DEBUGVAR(1,84,"ltp_data(): short_lag_present")); | |
1930 if (ltp->short_lag_present[w]) | |
1931 { | |
1932 ltp->short_lag[w] = (uint8_t)faad_getbits(ld, 4 | |
1933 DEBUGVAR(1,85,"ltp_data(): short_lag")); | |
1934 } | |
1935 } | |
1936 } | |
1937 } else { | |
1938 ltp->last_band = (ics->max_sfb < MAX_LTP_SFB ? ics->max_sfb : MAX_LTP_SFB); | |
1939 | |
1940 for (sfb = 0; sfb < ltp->last_band; sfb++) | |
1941 { | |
1942 ltp->long_used[sfb] = faad_get1bit(ld | |
1943 DEBUGVAR(1,86,"ltp_data(): long_used")); | |
1944 } | |
1945 } | |
12527 | 1946 |
1947 return 0; | |
10725 | 1948 } |
1949 #endif | |
1950 | |
1951 /* Table 4.4.29 */ | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1952 static uint8_t spectral_data(NeAACDecHandle hDecoder, ic_stream *ics, bitfile *ld, |
10725 | 1953 int16_t *spectral_data) |
1954 { | |
1955 int8_t i; | |
1956 uint8_t g; | |
12527 | 1957 uint16_t inc, k, p = 0; |
10725 | 1958 uint8_t groups = 0; |
1959 uint8_t sect_cb; | |
1960 uint8_t result; | |
1961 uint16_t nshort = hDecoder->frameLength/8; | |
1962 | |
12527 | 1963 #ifdef PROFILE |
1964 int64_t count = faad_get_ts(); | |
1965 #endif | |
10725 | 1966 |
1967 for(g = 0; g < ics->num_window_groups; g++) | |
1968 { | |
1969 p = groups*nshort; | |
1970 | |
1971 for (i = 0; i < ics->num_sec[g]; i++) | |
1972 { | |
1973 sect_cb = ics->sect_cb[g][i]; | |
1974 | |
12527 | 1975 inc = (sect_cb >= FIRST_PAIR_HCB) ? 2 : 4; |
1976 | |
10725 | 1977 switch (sect_cb) |
1978 { | |
1979 case ZERO_HCB: | |
1980 case NOISE_HCB: | |
1981 case INTENSITY_HCB: | |
1982 case INTENSITY_HCB2: | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1983 //#define SD_PRINT |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1984 #ifdef SD_PRINT |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1985 { |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1986 int j; |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1987 for (j = ics->sect_sfb_offset[g][ics->sect_start[g][i]]; j < ics->sect_sfb_offset[g][ics->sect_end[g][i]]; j++) |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1988 { |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1989 printf("%d\n", 0); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1990 } |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1991 } |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1992 #endif |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1993 //#define SFBO_PRINT |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1994 #ifdef SFBO_PRINT |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1995 printf("%d\n", ics->sect_sfb_offset[g][ics->sect_start[g][i]]); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
1996 #endif |
10725 | 1997 p += (ics->sect_sfb_offset[g][ics->sect_end[g][i]] - |
1998 ics->sect_sfb_offset[g][ics->sect_start[g][i]]); | |
1999 break; | |
2000 default: | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
2001 #ifdef SFBO_PRINT |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
2002 printf("%d\n", ics->sect_sfb_offset[g][ics->sect_start[g][i]]); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
2003 #endif |
10725 | 2004 for (k = ics->sect_sfb_offset[g][ics->sect_start[g][i]]; |
12527 | 2005 k < ics->sect_sfb_offset[g][ics->sect_end[g][i]]; k += inc) |
10725 | 2006 { |
12527 | 2007 if ((result = huffman_spectral_data(sect_cb, ld, &spectral_data[p])) > 0) |
2008 return result; | |
13453
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
2009 #ifdef SD_PRINT |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
2010 { |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
2011 int j; |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
2012 for (j = p; j < p+inc; j++) |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
2013 { |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
2014 printf("%d\n", spectral_data[j]); |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
2015 } |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
2016 } |
6d50ef45a058
Update FAAD to a 2.1 beta CVS snapshot from 2004.07.12.
diego
parents:
12625
diff
changeset
|
2017 #endif |
12527 | 2018 p += inc; |
10725 | 2019 } |
2020 break; | |
2021 } | |
2022 } | |
2023 groups += ics->window_group_length[g]; | |
2024 } | |
2025 | |
12527 | 2026 #ifdef PROFILE |
2027 count = faad_get_ts() - count; | |
2028 hDecoder->spectral_cycles += count; | |
2029 #endif | |
2030 | |
10725 | 2031 return 0; |
2032 } | |
2033 | |
2034 /* Table 4.4.30 */ | |
2035 static uint16_t extension_payload(bitfile *ld, drc_info *drc, uint16_t count) | |
2036 { | |
2037 uint16_t i, n, dataElementLength; | |
2038 uint8_t dataElementLengthPart; | |
2039 uint8_t align = 4, data_element_version, loopCounter; | |
2040 | |
2041 uint8_t extension_type = (uint8_t)faad_getbits(ld, 4 | |
2042 DEBUGVAR(1,87,"extension_payload(): extension_type")); | |
2043 | |
2044 switch (extension_type) | |
2045 { | |
2046 case EXT_DYNAMIC_RANGE: | |
2047 drc->present = 1; | |
2048 n = dynamic_range_info(ld, drc); | |
2049 return n; | |
2050 case EXT_FILL_DATA: | |
2051 /* fill_nibble = */ faad_getbits(ld, 4 | |
2052 DEBUGVAR(1,136,"extension_payload(): fill_nibble")); /* must be ‘0000’ */ | |
2053 for (i = 0; i < count-1; i++) | |
2054 { | |
2055 /* fill_byte[i] = */ faad_getbits(ld, 8 | |
2056 DEBUGVAR(1,88,"extension_payload(): fill_byte")); /* must be ‘10100101’ */ | |
2057 } | |
2058 return count; | |
2059 case EXT_DATA_ELEMENT: | |
12527 | 2060 data_element_version = (uint8_t)faad_getbits(ld, 4 |
10725 | 2061 DEBUGVAR(1,400,"extension_payload(): data_element_version")); |
2062 switch (data_element_version) | |
2063 { | |
2064 case ANC_DATA: | |
2065 loopCounter = 0; | |
2066 dataElementLength = 0; | |
2067 do { | |
12527 | 2068 dataElementLengthPart = (uint8_t)faad_getbits(ld, 8 |
10725 | 2069 DEBUGVAR(1,401,"extension_payload(): dataElementLengthPart")); |
2070 dataElementLength += dataElementLengthPart; | |
2071 loopCounter++; | |
2072 } while (dataElementLengthPart == 255); | |
2073 | |
2074 for (i = 0; i < dataElementLength; i++) | |
2075 { | |
2076 /* data_element_byte[i] = */ faad_getbits(ld, 8 | |
2077 DEBUGVAR(1,402,"extension_payload(): data_element_byte")); | |
2078 return (dataElementLength+loopCounter+1); | |
2079 } | |
2080 default: | |
2081 align = 0; | |
2082 } | |
2083 case EXT_FIL: | |
2084 default: | |
2085 faad_getbits(ld, align | |
2086 DEBUGVAR(1,88,"extension_payload(): fill_nibble")); | |
2087 for (i = 0; i < count-1; i++) | |
2088 { | |
2089 /* other_bits[i] = */ faad_getbits(ld, 8 | |
2090 DEBUGVAR(1,89,"extension_payload(): fill_bit")); | |
2091 } | |
2092 return count; | |
2093 } | |
2094 } | |
2095 | |
2096 /* Table 4.4.31 */ | |
2097 static uint8_t dynamic_range_info(bitfile *ld, drc_info *drc) | |
2098 { | |
2099 uint8_t i, n = 1; | |
2100 uint8_t band_incr; | |
2101 | |
2102 drc->num_bands = 1; | |
2103 | |
2104 if (faad_get1bit(ld | |
2105 DEBUGVAR(1,90,"dynamic_range_info(): has instance_tag")) & 1) | |
2106 { | |
2107 drc->pce_instance_tag = (uint8_t)faad_getbits(ld, 4 | |
2108 DEBUGVAR(1,91,"dynamic_range_info(): pce_instance_tag")); | |
2109 /* drc->drc_tag_reserved_bits = */ faad_getbits(ld, 4 | |
2110 DEBUGVAR(1,92,"dynamic_range_info(): drc_tag_reserved_bits")); | |
2111 n++; | |
2112 } | |
2113 | |
2114 drc->excluded_chns_present = faad_get1bit(ld | |
2115 DEBUGVAR(1,93,"dynamic_range_info(): excluded_chns_present")); | |
2116 if (drc->excluded_chns_present == 1) | |
2117 { | |
2118 n += excluded_channels(ld, drc); | |
2119 } | |
2120 | |
2121 if (faad_get1bit(ld | |
2122 DEBUGVAR(1,94,"dynamic_range_info(): has bands data")) & 1) | |
2123 { | |
2124 band_incr = (uint8_t)faad_getbits(ld, 4 | |
2125 DEBUGVAR(1,95,"dynamic_range_info(): band_incr")); | |
2126 /* drc->drc_bands_reserved_bits = */ faad_getbits(ld, 4 | |
2127 DEBUGVAR(1,96,"dynamic_range_info(): drc_bands_reserved_bits")); | |
2128 n++; | |
2129 drc->num_bands += band_incr; | |
2130 | |
2131 for (i = 0; i < drc->num_bands; i++); | |
2132 { | |
2133 drc->band_top[i] = (uint8_t)faad_getbits(ld, 8 | |
2134 DEBUGVAR(1,97,"dynamic_range_info(): band_top")); | |
2135 n++; | |
2136 } | |
2137 } | |
2138 | |
2139 if (faad_get1bit(ld | |
2140 DEBUGVAR(1,98,"dynamic_range_info(): has prog_ref_level")) & 1) | |
2141 { | |
2142 drc->prog_ref_level = (uint8_t)faad_getbits(ld, 7 | |
2143 DEBUGVAR(1,99,"dynamic_range_info(): prog_ref_level")); | |
2144 /* drc->prog_ref_level_reserved_bits = */ faad_get1bit(ld | |
2145 DEBUGVAR(1,100,"dynamic_range_info(): prog_ref_level_reserved_bits")); | |
2146 n++; | |
2147 } | |
2148 | |
2149 for (i = 0; i < drc->num_bands; i++) | |
2150 { | |
2151 drc->dyn_rng_sgn[i] = faad_get1bit(ld | |
2152 DEBUGVAR(1,101,"dynamic_range_info(): dyn_rng_sgn")); | |
2153 drc->dyn_rng_ctl[i] = (uint8_t)faad_getbits(ld, 7 | |
2154 DEBUGVAR(1,102,"dynamic_range_info(): dyn_rng_ctl")); | |
2155 n++; | |
2156 } | |
2157 | |
2158 return n; | |
2159 } | |
2160 | |
2161 /* Table 4.4.32 */ | |
2162 static uint8_t excluded_channels(bitfile *ld, drc_info *drc) | |
2163 { | |
2164 uint8_t i, n = 0; | |
2165 uint8_t num_excl_chan = 7; | |
2166 | |
2167 for (i = 0; i < 7; i++) | |
2168 { | |
2169 drc->exclude_mask[i] = faad_get1bit(ld | |
2170 DEBUGVAR(1,103,"excluded_channels(): exclude_mask")); | |
2171 } | |
2172 n++; | |
2173 | |
2174 while ((drc->additional_excluded_chns[n-1] = faad_get1bit(ld | |
2175 DEBUGVAR(1,104,"excluded_channels(): additional_excluded_chns"))) == 1) | |
2176 { | |
2177 for (i = num_excl_chan; i < num_excl_chan+7; i++) | |
2178 { | |
2179 drc->exclude_mask[i] = faad_get1bit(ld | |
2180 DEBUGVAR(1,105,"excluded_channels(): exclude_mask")); | |
2181 } | |
2182 n++; | |
2183 num_excl_chan += 7; | |
2184 } | |
2185 | |
2186 return n; | |
2187 } | |
2188 | |
2189 /* Annex A: Audio Interchange Formats */ | |
2190 | |
2191 /* Table 1.A.2 */ | |
2192 void get_adif_header(adif_header *adif, bitfile *ld) | |
2193 { | |
2194 uint8_t i; | |
2195 | |
2196 /* adif_id[0] = */ faad_getbits(ld, 8 | |
2197 DEBUGVAR(1,106,"get_adif_header(): adif_id[0]")); | |
2198 /* adif_id[1] = */ faad_getbits(ld, 8 | |
2199 DEBUGVAR(1,107,"get_adif_header(): adif_id[1]")); | |
2200 /* adif_id[2] = */ faad_getbits(ld, 8 | |
2201 DEBUGVAR(1,108,"get_adif_header(): adif_id[2]")); | |
2202 /* adif_id[3] = */ faad_getbits(ld, 8 | |
2203 DEBUGVAR(1,109,"get_adif_header(): adif_id[3]")); | |
2204 adif->copyright_id_present = faad_get1bit(ld | |
2205 DEBUGVAR(1,110,"get_adif_header(): copyright_id_present")); | |
2206 if(adif->copyright_id_present) | |
2207 { | |
2208 for (i = 0; i < 72/8; i++) | |
2209 { | |
2210 adif->copyright_id[i] = (int8_t)faad_getbits(ld, 8 | |
2211 DEBUGVAR(1,111,"get_adif_header(): copyright_id")); | |
2212 } | |
2213 adif->copyright_id[i] = 0; | |
2214 } | |
2215 adif->original_copy = faad_get1bit(ld | |
2216 DEBUGVAR(1,112,"get_adif_header(): original_copy")); | |
2217 adif->home = faad_get1bit(ld | |
2218 DEBUGVAR(1,113,"get_adif_header(): home")); | |
2219 adif->bitstream_type = faad_get1bit(ld | |
2220 DEBUGVAR(1,114,"get_adif_header(): bitstream_type")); | |
2221 adif->bitrate = faad_getbits(ld, 23 | |
2222 DEBUGVAR(1,115,"get_adif_header(): bitrate")); | |
2223 adif->num_program_config_elements = (uint8_t)faad_getbits(ld, 4 | |
2224 DEBUGVAR(1,116,"get_adif_header(): num_program_config_elements")); | |
2225 | |
2226 for (i = 0; i < adif->num_program_config_elements + 1; i++) | |
2227 { | |
2228 if(adif->bitstream_type == 0) | |
2229 { | |
2230 adif->adif_buffer_fullness = faad_getbits(ld, 20 | |
2231 DEBUGVAR(1,117,"get_adif_header(): adif_buffer_fullness")); | |
2232 } else { | |
2233 adif->adif_buffer_fullness = 0; | |
2234 } | |
2235 | |
2236 program_config_element(&adif->pce[i], ld); | |
2237 } | |
2238 } | |
2239 | |
2240 /* Table 1.A.5 */ | |
2241 uint8_t adts_frame(adts_header *adts, bitfile *ld) | |
2242 { | |
2243 /* faad_byte_align(ld); */ | |
2244 if (adts_fixed_header(adts, ld)) | |
2245 return 5; | |
2246 adts_variable_header(adts, ld); | |
2247 adts_error_check(adts, ld); | |
2248 | |
2249 return 0; | |
2250 } | |
2251 | |
2252 /* Table 1.A.6 */ | |
2253 static uint8_t adts_fixed_header(adts_header *adts, bitfile *ld) | |
2254 { | |
2255 uint16_t i; | |
2256 uint8_t sync_err = 1; | |
2257 | |
2258 /* try to recover from sync errors */ | |
2259 for (i = 0; i < 768; i++) | |
2260 { | |
2261 adts->syncword = (uint16_t)faad_showbits(ld, 12); | |
2262 if (adts->syncword != 0xFFF) | |
2263 { | |
2264 faad_getbits(ld, 8 | |
2265 DEBUGVAR(0,0,"")); | |
2266 } else { | |
2267 sync_err = 0; | |
2268 faad_getbits(ld, 12 | |
2269 DEBUGVAR(1,118,"adts_fixed_header(): syncword")); | |
2270 break; | |
2271 } | |
2272 } | |
2273 if (sync_err) | |
2274 return 5; | |
2275 | |
2276 adts->id = faad_get1bit(ld | |
2277 DEBUGVAR(1,119,"adts_fixed_header(): id")); | |
2278 adts->layer = (uint8_t)faad_getbits(ld, 2 | |
2279 DEBUGVAR(1,120,"adts_fixed_header(): layer")); | |
2280 adts->protection_absent = faad_get1bit(ld | |
2281 DEBUGVAR(1,121,"adts_fixed_header(): protection_absent")); | |
2282 adts->profile = (uint8_t)faad_getbits(ld, 2 | |
2283 DEBUGVAR(1,122,"adts_fixed_header(): profile")); | |
2284 adts->sf_index = (uint8_t)faad_getbits(ld, 4 | |
2285 DEBUGVAR(1,123,"adts_fixed_header(): sf_index")); | |
2286 adts->private_bit = faad_get1bit(ld | |
2287 DEBUGVAR(1,124,"adts_fixed_header(): private_bit")); | |
2288 adts->channel_configuration = (uint8_t)faad_getbits(ld, 3 | |
2289 DEBUGVAR(1,125,"adts_fixed_header(): channel_configuration")); | |
2290 adts->original = faad_get1bit(ld | |
2291 DEBUGVAR(1,126,"adts_fixed_header(): original")); | |
2292 adts->home = faad_get1bit(ld | |
2293 DEBUGVAR(1,127,"adts_fixed_header(): home")); | |
10989 | 2294 |
2295 if (adts->old_format == 1) | |
2296 { | |
2297 /* Removed in corrigendum 14496-3:2002 */ | |
12527 | 2298 if (adts->id == 0) |
2299 { | |
2300 adts->emphasis = (uint8_t)faad_getbits(ld, 2 | |
2301 DEBUGVAR(1,128,"adts_fixed_header(): emphasis")); | |
2302 } | |
10989 | 2303 } |
10725 | 2304 |
2305 return 0; | |
2306 } | |
2307 | |
2308 /* Table 1.A.7 */ | |
2309 static void adts_variable_header(adts_header *adts, bitfile *ld) | |
2310 { | |
2311 adts->copyright_identification_bit = faad_get1bit(ld | |
2312 DEBUGVAR(1,129,"adts_variable_header(): copyright_identification_bit")); | |
2313 adts->copyright_identification_start = faad_get1bit(ld | |
2314 DEBUGVAR(1,130,"adts_variable_header(): copyright_identification_start")); | |
2315 adts->aac_frame_length = (uint16_t)faad_getbits(ld, 13 | |
2316 DEBUGVAR(1,131,"adts_variable_header(): aac_frame_length")); | |
2317 adts->adts_buffer_fullness = (uint16_t)faad_getbits(ld, 11 | |
2318 DEBUGVAR(1,132,"adts_variable_header(): adts_buffer_fullness")); | |
2319 adts->no_raw_data_blocks_in_frame = (uint8_t)faad_getbits(ld, 2 | |
2320 DEBUGVAR(1,133,"adts_variable_header(): no_raw_data_blocks_in_frame")); | |
2321 } | |
2322 | |
2323 /* Table 1.A.8 */ | |
2324 static void adts_error_check(adts_header *adts, bitfile *ld) | |
2325 { | |
2326 if (adts->protection_absent == 0) | |
2327 { | |
2328 adts->crc_check = (uint16_t)faad_getbits(ld, 16 | |
2329 DEBUGVAR(1,134,"adts_error_check(): crc_check")); | |
2330 } | |
2331 } | |
25834
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2332 |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2333 /* LATM parsing functions */ |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2334 |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2335 static uint32_t latm_get_value(bitfile *ld) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2336 { |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2337 uint32_t l, value; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2338 uint8_t bytesForValue; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2339 |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2340 bytesForValue = (uint8_t)faad_getbits(ld, 2); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2341 value = 0; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2342 for(l=0; l<bytesForValue; l++) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2343 value = (value << 8) | (uint8_t)faad_getbits(ld, 8); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2344 |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2345 return value; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2346 } |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2347 |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2348 |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2349 static uint32_t latmParsePayload(latm_header *latm, bitfile *ld) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2350 { |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2351 //assuming there's only one program with a single layer and 1 subFrame, |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2352 //allStreamsSametimeframing is set, |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2353 uint32_t framelen; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2354 uint8_t tmp; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2355 |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2356 //this should be the payload length field for the current configuration |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2357 framelen = 0; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2358 if(latm->framelen_type==0) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2359 { |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2360 do |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2361 { |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2362 tmp = (uint8_t)faad_getbits(ld, 8); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2363 framelen += tmp; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2364 } while(tmp==0xff); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2365 } |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2366 else if(latm->framelen_type==1) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2367 framelen=latm->frameLength; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2368 |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2369 return framelen; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2370 } |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2371 |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2372 |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2373 static uint32_t latmAudioMuxElement(latm_header *latm, bitfile *ld) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2374 { |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2375 uint32_t ascLen, asc_bits=0; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2376 uint32_t x1, y1, m, n, i; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2377 program_config pce; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2378 mp4AudioSpecificConfig mp4ASC; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2379 |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2380 latm->useSameStreamMux = (uint8_t)faad_getbits(ld, 1); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2381 if(!latm->useSameStreamMux) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2382 { |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2383 //parseSameStreamMuxConfig |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2384 latm->version = (uint8_t) faad_getbits(ld, 1); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2385 if(latm->version) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2386 latm->versionA = (uint8_t) faad_getbits(ld, 1); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2387 if(latm->versionA) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2388 { |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2389 //dunno the payload format for versionA |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2390 fprintf(stderr, "versionA not supported\n"); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2391 return 0; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2392 } |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2393 if(latm->version) //read taraBufferFullness |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2394 latm_get_value(ld); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2395 latm->allStreamsSameTimeFraming = (uint8_t)faad_getbits(ld, 1); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2396 latm->numSubFrames = (uint8_t)faad_getbits(ld, 6) + 1; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2397 latm->numPrograms = (uint8_t)faad_getbits(ld, 4) + 1; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2398 latm->numLayers = faad_getbits(ld, 3) + 1; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2399 if(latm->numPrograms>1 || !latm->allStreamsSameTimeFraming || latm->numSubFrames>1 || latm->numLayers>1) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2400 { |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2401 fprintf(stderr, "\r\nUnsupported LATM configuration: %d programs/ %d subframes, %d layers, allstreams: %d\n", |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2402 latm->numPrograms, latm->numSubFrames, latm->numLayers, latm->allStreamsSameTimeFraming); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2403 return 0; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2404 } |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2405 ascLen = 0; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2406 if(latm->version) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2407 ascLen = latm_get_value(ld); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2408 |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2409 x1 = faad_get_processed_bits(ld); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2410 if(AudioSpecificConfigFromBitfile(ld, &mp4ASC, &pce, 0, 1) < 0) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2411 return 0; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2412 |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2413 //horrid hack to unread the ASC bits and store them in latm->ASC |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2414 //the correct code would rely on an ideal faad_ungetbits() |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2415 y1 = faad_get_processed_bits(ld); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2416 if((y1-x1) <= MAX_ASC_BYTES*8) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2417 { |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2418 faad_rewindbits(ld); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2419 m = x1; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2420 while(m>0) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2421 { |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2422 n = min(m, 32); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2423 faad_getbits(ld, n); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2424 m -= n; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2425 } |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2426 |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2427 i = 0; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2428 m = latm->ASCbits = y1 - x1; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2429 while(m > 0) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2430 { |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2431 n = min(m, 8); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2432 latm->ASC[i++] = (uint8_t) faad_getbits(ld, n); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2433 m -= n; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2434 } |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2435 } |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2436 |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2437 asc_bits = y1-x1; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2438 |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2439 if(ascLen>asc_bits) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2440 faad_getbits(ld, ascLen-asc_bits); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2441 |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2442 latm->framelen_type = (uint8_t) faad_getbits(ld, 3); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2443 if(latm->framelen_type == 0) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2444 { |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2445 latm->frameLength = 0; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2446 faad_getbits(ld, 8); //buffer fullness for frame_len_type==0, useless |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2447 } |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2448 else if(latm->framelen_type == 1) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2449 { |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2450 latm->frameLength = faad_getbits(ld, 9); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2451 if(latm->frameLength==0) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2452 { |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2453 fprintf(stderr, "Invalid frameLength: 0\r\n"); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2454 return 0; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2455 } |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2456 latm->frameLength = (latm->frameLength+20)*8; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2457 } |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2458 else |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2459 { //hellish CELP or HCVX stuff, discard |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2460 fprintf(stderr, "Unsupported CELP/HCVX framelentype: %d\n", latm->framelen_type); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2461 return 0; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2462 } |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2463 |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2464 latm->otherDataLenBits = 0; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2465 if(faad_getbits(ld, 1)) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2466 { //other data present |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2467 int esc, tmp; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2468 if(latm->version) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2469 latm->otherDataLenBits = latm_get_value(ld); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2470 else do |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2471 { |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2472 esc = faad_getbits(ld, 1); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2473 tmp = faad_getbits(ld, 8); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2474 latm->otherDataLenBits = (latm->otherDataLenBits << 8) + tmp; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2475 } while(esc); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2476 } |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2477 if(faad_getbits(ld, 1)) //crc |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2478 faad_getbits(ld, 8); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2479 latm->inited = 1; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2480 } |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2481 |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2482 //read payload |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2483 if(latm->inited) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2484 return latmParsePayload(latm, ld); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2485 else |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2486 return 0; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2487 } |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2488 |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2489 |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2490 uint32_t faad_latm_frame(latm_header *latm, bitfile *ld) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2491 { |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2492 uint16_t len; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2493 uint32_t initpos, endpos, firstpos, ret; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2494 |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2495 firstpos = faad_get_processed_bits(ld); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2496 while(!ld->error && !ld->no_more_reading) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2497 { |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2498 faad_byte_align(ld); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2499 if(faad_showbits(ld, 11) != 0x2B7) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2500 { |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2501 faad_getbits(ld, 8); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2502 continue; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2503 } |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2504 faad_getbits(ld, 11); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2505 len = faad_getbits(ld, 13); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2506 if(!len) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2507 continue; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2508 initpos = faad_get_processed_bits(ld); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2509 ret = latmAudioMuxElement(latm, ld); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2510 endpos = faad_get_processed_bits(ld); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2511 if(ret>0) |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2512 return (len*8)-(endpos-initpos); |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2513 //faad_getbits(ld, initpos-endpos); //go back to initpos, but is valid a getbits(-N) ? |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2514 } |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2515 return -1U; |
69a4d646e55d
generic functions and structures to parse and statekeep LATM streams
nicodvb
parents:
25833
diff
changeset
|
2516 } |