Coverage Report

Created: 2026-06-25 07:09

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/libxaac/decoder/ixheaacd_initfuncs.c
Line
Count
Source
1
/******************************************************************************
2
 *                                                                            *
3
 * Copyright (C) 2018 The Android Open Source Project
4
 *
5
 * Licensed under the Apache License, Version 2.0 (the "License");
6
 * you may not use this file except in compliance with the License.
7
 * You may obtain a copy of the License at:
8
 *
9
 * http://www.apache.org/licenses/LICENSE-2.0
10
 *
11
 * Unless required by applicable law or agreed to in writing, software
12
 * distributed under the License is distributed on an "AS IS" BASIS,
13
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
 * See the License for the specific language governing permissions and
15
 * limitations under the License.
16
 *
17
 *****************************************************************************
18
 * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore
19
*/
20
#include <string.h>
21
#include "ixheaac_type_def.h"
22
23
#include "ixheaacd_sbr_common.h"
24
25
#include "ixheaac_constants.h"
26
#include "ixheaac_basic_ops32.h"
27
#include "ixheaac_basic_ops16.h"
28
#include "ixheaac_basic_ops40.h"
29
#include "ixheaac_basic_ops.h"
30
#include "ixheaacd_bitbuffer.h"
31
32
#include "ixheaac_basic_op.h"
33
#include "ixheaacd_intrinsics.h"
34
35
#include "ixheaacd_defines.h"
36
37
#include "ixheaacd_aac_rom.h"
38
39
#include "ixheaacd_definitions.h"
40
41
#include "ixheaacd_error_codes.h"
42
43
#include "ixheaacd_pulsedata.h"
44
45
#include "ixheaacd_pns.h"
46
#include "ixheaacd_drc_data_struct.h"
47
48
#include "ixheaacd_lt_predict.h"
49
#include "ixheaacd_cnst.h"
50
#include "ixheaacd_ec_defines.h"
51
#include "ixheaacd_ec_struct_def.h"
52
53
#include "ixheaacd_channelinfo.h"
54
#include "ixheaacd_drc_dec.h"
55
56
#include "ixheaacd_sbrdecoder.h"
57
#include "ixheaacd_block.h"
58
#include "ixheaacd_channel.h"
59
60
#include "ixheaacd_sbr_payload.h"
61
#include "ixheaacd_common_rom.h"
62
#include "ixheaacd_sbrdecsettings.h"
63
#include "ixheaacd_sbr_scale.h"
64
#include "ixheaacd_env_extr_part.h"
65
#include "ixheaacd_sbr_rom.h"
66
67
#include "ixheaacd_lpp_tran.h"
68
#include "ixheaacd_hybrid.h"
69
#include "ixheaacd_ps_dec.h"
70
71
#include "ixheaacd_env_extr.h"
72
#include "ixheaacd_adts.h"
73
#include "ixheaacd_audioobjtypes.h"
74
#include "ixheaacd_memory_standards.h"
75
76
#include "ixheaacd_latmdemux.h"
77
78
#include "ixheaacd_aacdec.h"
79
#include "ixheaacd_mps_polyphase.h"
80
#include "ixheaacd_config.h"
81
#include "ixheaacd_qmf_dec.h"
82
#include "ixheaacd_mps_macro_def.h"
83
#include "ixheaacd_mps_struct_def.h"
84
#include "ixheaacd_mps_res_rom.h"
85
#include "ixheaacd_mps_aac_struct.h"
86
#include "ixheaacd_mps_dec.h"
87
88
#include "ixheaacd_struct_def.h"
89
90
#include "ixheaacd_multichannel.h"
91
92
217k
#define ALIGN_SIZE64(x) ((((x) + 7) >> 3) << 3)
93
94
WORD32 ixheaacd_set_aac_persistent_buffers(VOID *aac_persistent_mem_v,
95
23.9k
                                           WORD32 num_channel) {
96
23.9k
  WORD32 persistent_used;
97
98
23.9k
  struct ia_aac_persistent_struct *aac_persistent_mem =
99
23.9k
      (struct ia_aac_persistent_struct *)aac_persistent_mem_v;
100
101
23.9k
  persistent_used =
102
23.9k
      IXHEAAC_GET_SIZE_ALIGNED(sizeof(struct ia_aac_persistent_struct), BYTE_ALIGN_8);
103
104
23.9k
  memset(aac_persistent_mem, 0,
105
23.9k
         IXHEAAC_GET_SIZE_ALIGNED(sizeof(struct ia_aac_persistent_struct), BYTE_ALIGN_8));
106
23.9k
  aac_persistent_mem->overlap_buffer =
107
23.9k
      (WORD32 *)((WORD8 *)aac_persistent_mem_v + persistent_used);
108
109
23.9k
  memset(
110
23.9k
      (WORD32 *)((WORD8 *)aac_persistent_mem_v + persistent_used), 0,
111
23.9k
      IXHEAAC_GET_SIZE_ALIGNED(
112
23.9k
          4 * 512 * num_channel * sizeof(aac_persistent_mem->overlap_buffer[0]), BYTE_ALIGN_8));
113
114
23.9k
  persistent_used += IXHEAAC_GET_SIZE_ALIGNED(
115
23.9k
      4 * 512 * num_channel * sizeof(aac_persistent_mem->overlap_buffer[0]), BYTE_ALIGN_8);
116
117
23.9k
  aac_persistent_mem->sbr_payload_buffer =
118
23.9k
      (WORD8 *)((WORD8 *)aac_persistent_mem_v + persistent_used);
119
120
23.9k
  memset((WORD16 *)((WORD8 *)aac_persistent_mem_v + persistent_used), 0,
121
23.9k
         num_channel *
122
23.9k
             IXHEAAC_GET_SIZE_ALIGNED(
123
23.9k
                 MAXSBRBYTES * sizeof(aac_persistent_mem->sbr_payload_buffer[0]), BYTE_ALIGN_8));
124
125
23.9k
  persistent_used +=
126
23.9k
      num_channel *
127
23.9k
      IXHEAAC_GET_SIZE_ALIGNED(MAXSBRBYTES * sizeof(aac_persistent_mem->sbr_payload_buffer[0]),
128
23.9k
                               BYTE_ALIGN_8);
129
130
23.9k
  aac_persistent_mem->prev_sbr_payload_buffer =
131
23.9k
      (WORD8 *)((WORD8 *)aac_persistent_mem_v + persistent_used);
132
133
23.9k
  memset((WORD8 *)aac_persistent_mem->prev_sbr_payload_buffer, 0,
134
23.9k
         num_channel * IXHEAAC_GET_SIZE_ALIGNED(
135
23.9k
                           MAXSBRBYTES * sizeof(*(aac_persistent_mem->prev_sbr_payload_buffer)),
136
23.9k
                           BYTE_ALIGN_8));
137
138
23.9k
  persistent_used +=
139
23.9k
      num_channel *
140
23.9k
      IXHEAAC_GET_SIZE_ALIGNED(
141
23.9k
          MAXSBRBYTES * sizeof(*(aac_persistent_mem->prev_sbr_payload_buffer)), BYTE_ALIGN_8);
142
143
23.9k
  {
144
23.9k
    WORD32 i;
145
146
70.3k
    for (i = 0; i < num_channel; i++) {
147
46.3k
      aac_persistent_mem->ltp_buf[i] =
148
46.3k
          (WORD16 *)((WORD8 *)aac_persistent_mem_v + persistent_used);
149
150
46.3k
      memset((WORD16 *)((WORD8 *)aac_persistent_mem_v + persistent_used), 0,
151
46.3k
             IXHEAAC_GET_SIZE_ALIGNED(ltp_buffer_size * sizeof(aac_persistent_mem->ltp_buf[i][0]),
152
46.3k
                                      BYTE_ALIGN_8));
153
154
46.3k
      persistent_used += IXHEAAC_GET_SIZE_ALIGNED(
155
46.3k
          ltp_buffer_size * sizeof(aac_persistent_mem->ltp_buf[i][0]), BYTE_ALIGN_8);
156
157
46.3k
      aac_persistent_mem->ptr_aac_dec_static_channel_info[i] =
158
46.3k
          (ia_aac_dec_channel_info *)((WORD8 *)aac_persistent_mem_v + persistent_used);
159
46.3k
      persistent_used += IXHEAAC_GET_SIZE_ALIGNED(sizeof(ia_aac_dec_channel_info), BYTE_ALIGN_8);
160
161
46.3k
      aac_persistent_mem->ptr_aac_dec_static_channel_info[i]
162
46.3k
          ->overlap_add_data.win_shape = 0;
163
46.3k
      aac_persistent_mem->ptr_aac_dec_static_channel_info[i]
164
46.3k
          ->overlap_add_data.win_seq = 0;
165
166
46.3k
      aac_persistent_mem->ptr_aac_dec_static_channel_info[i]
167
46.3k
          ->overlap_add_data.ptr_overlap_buf =
168
46.3k
          &aac_persistent_mem->overlap_buffer[i * OVERLAP_BUFFER_SIZE];
169
46.3k
    }
170
23.9k
  }
171
172
23.9k
  return persistent_used;
173
23.9k
}
174
175
14.8k
VOID ixheaacd_huff_tables_create(ia_aac_dec_tables_struct *ptr_aac_tables) {
176
14.8k
  ptr_aac_tables->code_book[0] = 0;
177
14.8k
  ptr_aac_tables->code_book[1] =
178
14.8k
      (UWORD16 *)ptr_aac_tables->pstr_huffmann_tables->input_table_cb1;
179
14.8k
  ptr_aac_tables->code_book[2] =
180
14.8k
      (UWORD16 *)ptr_aac_tables->pstr_huffmann_tables->input_table_cb2;
181
14.8k
  ptr_aac_tables->code_book[3] =
182
14.8k
      (UWORD16 *)ptr_aac_tables->pstr_huffmann_tables->input_table_cb3;
183
14.8k
  ptr_aac_tables->code_book[4] =
184
14.8k
      (UWORD16 *)ptr_aac_tables->pstr_huffmann_tables->input_table_cb4;
185
14.8k
  ptr_aac_tables->code_book[5] =
186
14.8k
      (UWORD16 *)ptr_aac_tables->pstr_huffmann_tables->input_table_cb5;
187
14.8k
  ptr_aac_tables->code_book[6] =
188
14.8k
      (UWORD16 *)ptr_aac_tables->pstr_huffmann_tables->input_table_cb6;
189
14.8k
  ptr_aac_tables->code_book[7] =
190
14.8k
      (UWORD16 *)ptr_aac_tables->pstr_huffmann_tables->input_table_cb7;
191
14.8k
  ptr_aac_tables->code_book[8] =
192
14.8k
      (UWORD16 *)ptr_aac_tables->pstr_huffmann_tables->input_table_cb8;
193
14.8k
  ptr_aac_tables->code_book[9] =
194
14.8k
      (UWORD16 *)ptr_aac_tables->pstr_huffmann_tables->input_table_cb9;
195
14.8k
  ptr_aac_tables->code_book[10] =
196
14.8k
      (UWORD16 *)ptr_aac_tables->pstr_huffmann_tables->input_table_cb10;
197
14.8k
  ptr_aac_tables->code_book[11] =
198
14.8k
      (UWORD16 *)ptr_aac_tables->pstr_huffmann_tables->input_table_cb10;
199
14.8k
  ptr_aac_tables->code_book[12] =
200
14.8k
      (UWORD16 *)ptr_aac_tables->pstr_huffmann_tables->input_table_cb10;
201
202
14.8k
  ptr_aac_tables->index_table[1] =
203
14.8k
      (UWORD32 *)ptr_aac_tables->pstr_huffmann_tables->idx_table_hf1;
204
14.8k
  ptr_aac_tables->index_table[2] =
205
14.8k
      (UWORD32 *)ptr_aac_tables->pstr_huffmann_tables->idx_table_hf2;
206
14.8k
  ptr_aac_tables->index_table[3] =
207
14.8k
      (UWORD32 *)ptr_aac_tables->pstr_huffmann_tables->idx_table_hf3;
208
14.8k
  ptr_aac_tables->index_table[4] =
209
14.8k
      (UWORD32 *)ptr_aac_tables->pstr_huffmann_tables->idx_table_hf4;
210
14.8k
  ptr_aac_tables->index_table[5] =
211
14.8k
      (UWORD32 *)ptr_aac_tables->pstr_huffmann_tables->idx_table_hf5;
212
14.8k
  ptr_aac_tables->index_table[6] =
213
14.8k
      (UWORD32 *)ptr_aac_tables->pstr_huffmann_tables->idx_table_hf6;
214
14.8k
  ptr_aac_tables->index_table[7] =
215
14.8k
      (UWORD32 *)ptr_aac_tables->pstr_huffmann_tables->idx_table_hf7;
216
14.8k
  ptr_aac_tables->index_table[8] =
217
14.8k
      (UWORD32 *)ptr_aac_tables->pstr_huffmann_tables->idx_table_hf8;
218
14.8k
  ptr_aac_tables->index_table[9] =
219
14.8k
      (UWORD32 *)ptr_aac_tables->pstr_huffmann_tables->idx_table_hf9;
220
14.8k
  ptr_aac_tables->index_table[10] =
221
14.8k
      (UWORD32 *)ptr_aac_tables->pstr_huffmann_tables->idx_table_hf10;
222
14.8k
  ptr_aac_tables->index_table[11] =
223
14.8k
      (UWORD32 *)ptr_aac_tables->pstr_huffmann_tables->idx_table_hf10;
224
14.8k
  ptr_aac_tables->index_table[12] =
225
14.8k
      (UWORD32 *)ptr_aac_tables->pstr_huffmann_tables->idx_table_hf10;
226
227
14.8k
  ptr_aac_tables->scale_factor_bands_short[0] =
228
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_96_128;
229
14.8k
  ptr_aac_tables->scale_factor_bands_short[1] =
230
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_96_128;
231
14.8k
  ptr_aac_tables->scale_factor_bands_short[2] =
232
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_96_128;
233
14.8k
  ptr_aac_tables->scale_factor_bands_short[3] =
234
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_48_128;
235
14.8k
  ptr_aac_tables->scale_factor_bands_short[4] =
236
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_48_128;
237
14.8k
  ptr_aac_tables->scale_factor_bands_short[5] =
238
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_48_128;
239
14.8k
  ptr_aac_tables->scale_factor_bands_short[6] =
240
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_128;
241
14.8k
  ptr_aac_tables->scale_factor_bands_short[7] =
242
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_128;
243
14.8k
  ptr_aac_tables->scale_factor_bands_short[8] =
244
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_16_128;
245
14.8k
  ptr_aac_tables->scale_factor_bands_short[9] =
246
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_16_128;
247
14.8k
  ptr_aac_tables->scale_factor_bands_short[10] =
248
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_16_128;
249
14.8k
  ptr_aac_tables->scale_factor_bands_short[11] =
250
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_8_128;
251
252
14.8k
  ptr_aac_tables->scale_factor_bands_short[12] =
253
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_96_120;
254
14.8k
  ptr_aac_tables->scale_factor_bands_short[13] =
255
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_96_120;
256
14.8k
  ptr_aac_tables->scale_factor_bands_short[14] =
257
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_96_120;
258
14.8k
  ptr_aac_tables->scale_factor_bands_short[15] =
259
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_48_120;
260
14.8k
  ptr_aac_tables->scale_factor_bands_short[16] =
261
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_48_120;
262
14.8k
  ptr_aac_tables->scale_factor_bands_short[17] =
263
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_48_120;
264
14.8k
  ptr_aac_tables->scale_factor_bands_short[18] =
265
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_120;
266
14.8k
  ptr_aac_tables->scale_factor_bands_short[19] =
267
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_120;
268
14.8k
  ptr_aac_tables->scale_factor_bands_short[20] =
269
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_16_120;
270
14.8k
  ptr_aac_tables->scale_factor_bands_short[21] =
271
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_16_120;
272
14.8k
  ptr_aac_tables->scale_factor_bands_short[22] =
273
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_16_120;
274
14.8k
  ptr_aac_tables->scale_factor_bands_short[23] =
275
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_8_120;
276
277
14.8k
  ptr_aac_tables->scale_factor_bands_long[0] =
278
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_96_1024;
279
14.8k
  ptr_aac_tables->scale_factor_bands_long[1] =
280
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_96_1024;
281
14.8k
  ptr_aac_tables->scale_factor_bands_long[2] =
282
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_64_1024;
283
14.8k
  ptr_aac_tables->scale_factor_bands_long[3] =
284
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_48_1024;
285
14.8k
  ptr_aac_tables->scale_factor_bands_long[4] =
286
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_48_1024;
287
14.8k
  ptr_aac_tables->scale_factor_bands_long[5] =
288
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_32_1024;
289
14.8k
  ptr_aac_tables->scale_factor_bands_long[6] =
290
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_1024;
291
14.8k
  ptr_aac_tables->scale_factor_bands_long[7] =
292
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_1024;
293
14.8k
  ptr_aac_tables->scale_factor_bands_long[8] =
294
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_16_1024;
295
14.8k
  ptr_aac_tables->scale_factor_bands_long[9] =
296
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_16_1024;
297
14.8k
  ptr_aac_tables->scale_factor_bands_long[10] =
298
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_16_1024;
299
14.8k
  ptr_aac_tables->scale_factor_bands_long[11] =
300
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_8_1024;
301
302
14.8k
  ptr_aac_tables->scale_factor_bands_long[12] =
303
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_96_960;
304
14.8k
  ptr_aac_tables->scale_factor_bands_long[13] =
305
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_96_960;
306
14.8k
  ptr_aac_tables->scale_factor_bands_long[14] =
307
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_64_960;
308
14.8k
  ptr_aac_tables->scale_factor_bands_long[15] =
309
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_48_960;
310
14.8k
  ptr_aac_tables->scale_factor_bands_long[16] =
311
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_48_960;
312
14.8k
  ptr_aac_tables->scale_factor_bands_long[17] =
313
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_48_960;
314
14.8k
  ptr_aac_tables->scale_factor_bands_long[18] =
315
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_960;
316
14.8k
  ptr_aac_tables->scale_factor_bands_long[19] =
317
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_960;
318
14.8k
  ptr_aac_tables->scale_factor_bands_long[20] =
319
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_16_960;
320
14.8k
  ptr_aac_tables->scale_factor_bands_long[21] =
321
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_16_960;
322
14.8k
  ptr_aac_tables->scale_factor_bands_long[22] =
323
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_16_960;
324
14.8k
  ptr_aac_tables->scale_factor_bands_long[23] =
325
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_8_960;
326
327
14.8k
  ptr_aac_tables->scale_fac_bands_512[0] =
328
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_48_512;
329
14.8k
  ptr_aac_tables->scale_fac_bands_512[1] =
330
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_48_512;
331
14.8k
  ptr_aac_tables->scale_fac_bands_512[2] =
332
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_48_512;
333
14.8k
  ptr_aac_tables->scale_fac_bands_512[3] =
334
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_48_512;
335
14.8k
  ptr_aac_tables->scale_fac_bands_512[4] =
336
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_48_512;
337
14.8k
  ptr_aac_tables->scale_fac_bands_512[5] =
338
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_32_512;
339
14.8k
  ptr_aac_tables->scale_fac_bands_512[6] =
340
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_512;
341
14.8k
  ptr_aac_tables->scale_fac_bands_512[7] =
342
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_512;
343
14.8k
  ptr_aac_tables->scale_fac_bands_512[8] =
344
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_512;
345
14.8k
  ptr_aac_tables->scale_fac_bands_512[9] =
346
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_512;
347
14.8k
  ptr_aac_tables->scale_fac_bands_512[10] =
348
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_512;
349
14.8k
  ptr_aac_tables->scale_fac_bands_512[11] =
350
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_512;
351
14.8k
  ptr_aac_tables->scale_fac_bands_512[12] =
352
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_512;
353
14.8k
  ptr_aac_tables->scale_fac_bands_512[13] =
354
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_512;
355
14.8k
  ptr_aac_tables->scale_fac_bands_512[14] =
356
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_512;
357
14.8k
  ptr_aac_tables->scale_fac_bands_512[15] =
358
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_512;
359
360
14.8k
  ptr_aac_tables->scale_fac_bands_480[0] =
361
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_48_480;
362
14.8k
  ptr_aac_tables->scale_fac_bands_480[1] =
363
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_48_480;
364
14.8k
  ptr_aac_tables->scale_fac_bands_480[2] =
365
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_48_480;
366
14.8k
  ptr_aac_tables->scale_fac_bands_480[3] =
367
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_48_480;
368
14.8k
  ptr_aac_tables->scale_fac_bands_480[4] =
369
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_48_480;
370
14.8k
  ptr_aac_tables->scale_fac_bands_480[5] =
371
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_32_480;
372
14.8k
  ptr_aac_tables->scale_fac_bands_480[6] =
373
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_480;
374
14.8k
  ptr_aac_tables->scale_fac_bands_480[7] =
375
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_480;
376
14.8k
  ptr_aac_tables->scale_fac_bands_480[8] =
377
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_480;
378
14.8k
  ptr_aac_tables->scale_fac_bands_480[9] =
379
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_480;
380
14.8k
  ptr_aac_tables->scale_fac_bands_480[10] =
381
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_480;
382
14.8k
  ptr_aac_tables->scale_fac_bands_480[11] =
383
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_480;
384
14.8k
  ptr_aac_tables->scale_fac_bands_480[12] =
385
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_480;
386
14.8k
  ptr_aac_tables->scale_fac_bands_480[13] =
387
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_480;
388
14.8k
  ptr_aac_tables->scale_fac_bands_480[14] =
389
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_480;
390
14.8k
  ptr_aac_tables->scale_fac_bands_480[15] =
391
14.8k
      ptr_aac_tables->pstr_huffmann_tables->ixheaacd_sfb_24_480;
392
14.8k
}
393
394
ia_aac_decoder_struct *ixheaacd_aac_decoder_init(
395
    ia_aac_dec_state_struct *p_state_enhaacplus_dec,
396
    ia_aac_dec_sbr_bitstream_struct *ptr_sbr_bitstream, WORD channels,
397
108k
    VOID *aac_persistent_mem_v, WORD32 frame_length) {
398
108k
  WORD i, ch;
399
108k
  struct ia_aac_persistent_struct *aac_persistent_mem;
400
108k
  aac_persistent_mem = (struct ia_aac_persistent_struct *)aac_persistent_mem_v;
401
402
108k
  aac_persistent_mem->str_aac_decoder.pstr_sbr_bitstream = ptr_sbr_bitstream;
403
404
325k
  for (ch = 0; ch < channels; ch++) {
405
216k
    ia_aac_decoder_struct *aac_dec_handle =
406
216k
        &aac_persistent_mem->str_aac_decoder;
407
216k
    aac_dec_handle->pstr_aac_dec_overlap_info[ch] =
408
216k
        &aac_persistent_mem->str_aac_dec_overlap_info[ch];
409
216k
    aac_dec_handle->pstr_pns_rand_vec_data =
410
216k
        &aac_persistent_mem->str_pns_rand_vec_data;
411
412
216k
    aac_dec_handle->pstr_aac_dec_overlap_info[ch]->window_shape = 0;
413
216k
    aac_dec_handle->pstr_aac_dec_overlap_info[ch]->window_sequence = 0;
414
216k
    if (p_state_enhaacplus_dec->audio_object_type == AOT_ER_AAC_ELD)
415
45.8k
      aac_dec_handle->pstr_aac_dec_overlap_info[ch]->ptr_overlap_buf =
416
45.8k
          &aac_persistent_mem->overlap_buffer[ch * 4 * OVERLAP_BUFFER_SIZE];
417
170k
    else
418
170k
      aac_dec_handle->pstr_aac_dec_overlap_info[ch]->ptr_overlap_buf =
419
170k
          &aac_persistent_mem->overlap_buffer[ch * OVERLAP_BUFFER_SIZE];
420
421
216k
    {
422
216k
      WORD32 *ptr_overlap_buf =
423
216k
          aac_dec_handle->pstr_aac_dec_overlap_info[ch]->ptr_overlap_buf;
424
216k
      memset(ptr_overlap_buf, 0,
425
216k
             IXHEAAC_GET_SIZE_ALIGNED(sizeof(ptr_overlap_buf[0]) * 4 * 512, BYTE_ALIGN_8));
426
216k
    }
427
216k
    aac_persistent_mem->str_aac_decoder.ptr_aac_dec_static_channel_info[ch] =
428
216k
        aac_persistent_mem->ptr_aac_dec_static_channel_info[ch];
429
216k
    aac_persistent_mem->str_aac_decoder.ptr_aac_dec_static_channel_info[ch]
430
216k
        ->ltp_buf = aac_persistent_mem->ltp_buf[ch];
431
216k
  }
432
433
217k
  for (i = 0; i < 1; i++) {
434
108k
    ia_aac_dec_sbr_bitstream_struct *ptr_sbr_bitstream =
435
108k
        &aac_persistent_mem->str_aac_decoder.pstr_sbr_bitstream[i];
436
437
108k
    ptr_sbr_bitstream->no_elements = 0;
438
108k
    ptr_sbr_bitstream->str_sbr_ele[0].ptr_sbr_data =
439
108k
        &aac_persistent_mem->sbr_payload_buffer[ALIGN_SIZE64(MAXSBRBYTES) * i];
440
108k
    ptr_sbr_bitstream->str_sbr_ele[0].ptr_prev_sbr_data =
441
108k
        &aac_persistent_mem->prev_sbr_payload_buffer[ALIGN_SIZE64(MAXSBRBYTES) * i];
442
108k
    ptr_sbr_bitstream->str_sbr_ele[0].sbr_ele_id = ID_SCE;
443
108k
    ptr_sbr_bitstream->str_sbr_ele[0].size_payload = 0;
444
108k
    ptr_sbr_bitstream->str_sbr_ele[0].prev_size_payload = 0;
445
108k
    ptr_sbr_bitstream->str_sbr_ele[0].prev_sbr_ele_id = ID_SCE;
446
108k
    ptr_sbr_bitstream->str_sbr_ele[0].size_payload_old = 0;
447
108k
  }
448
449
108k
  {
450
108k
    ia_aac_dec_tables_struct *ptr_aac_tables =
451
108k
        aac_persistent_mem->str_aac_decoder.pstr_aac_tables;
452
108k
    ia_aac_dec_huffman_tables_struct *pstr_huffmann_tables =
453
108k
        ptr_aac_tables->pstr_huffmann_tables;
454
455
108k
    WORD num_entries = sizeof(pstr_huffmann_tables->str_sample_rate_info) /
456
108k
                       sizeof(ia_sampling_rate_info_struct);
457
458
108k
    WORD32 sampling_rate = p_state_enhaacplus_dec->sampling_rate;
459
108k
    WORD sfidx;
460
461
108k
    i = 0;
462
801k
    while ((i < num_entries) &&
463
801k
           sampling_rate != ((pstr_huffmann_tables->str_sample_rate_info[i]
464
801k
                                  .sampling_frequency))) {
465
692k
      i++;
466
692k
    }
467
108k
    if (i == 12) {
468
402
      i = i - 1;
469
402
    }
470
471
108k
    if (i == num_entries) {
472
0
      return NULL;
473
0
    }
474
108k
    sfidx = i;
475
476
108k
    if (frame_length == 1024 || frame_length == 960) {
477
72.6k
      WORD16 *psfb_table_idx[2];
478
72.6k
      const WORD8 *psfb_width[2];
479
72.6k
      WORD width_idx;
480
72.6k
      WORD32 j;
481
482
72.6k
      if (frame_length == 960)
483
11.8k
        sfidx += 12;
484
485
72.6k
      psfb_table_idx[0] = ptr_aac_tables->sfb_long_table;
486
72.6k
      psfb_table_idx[1] = ptr_aac_tables->sfb_short_table;
487
488
72.6k
      psfb_width[0] = ptr_aac_tables->scale_factor_bands_long[sfidx];
489
72.6k
      psfb_width[1] = ptr_aac_tables->scale_factor_bands_short[sfidx];
490
491
217k
      for (j = 1; j >= 0; j--) {
492
145k
        const WORD8 *ptr_width = psfb_width[j];
493
145k
        WORD16 *ptable_idx = psfb_table_idx[j];
494
145k
        width_idx = 0;
495
145k
        *ptable_idx++ = width_idx;
496
4.33M
        do {
497
4.33M
          width_idx += (*ptr_width++);
498
4.33M
          *ptable_idx++ = width_idx;
499
4.33M
        } while (*ptr_width != -1);
500
501
145k
        aac_persistent_mem->str_aac_decoder.num_swb_window[j] =
502
145k
            (WORD8)(ptr_width - psfb_width[j]);
503
145k
      }
504
505
72.6k
      {
506
72.6k
        ptr_aac_tables->str_aac_sfb_info[0].sfb_index =
507
72.6k
            ptr_aac_tables->sfb_long_table;
508
72.6k
        ptr_aac_tables->str_aac_sfb_info[1].sfb_index =
509
72.6k
            ptr_aac_tables->sfb_long_table;
510
72.6k
        ptr_aac_tables->str_aac_sfb_info[3].sfb_index =
511
72.6k
            ptr_aac_tables->sfb_long_table;
512
513
72.6k
        ptr_aac_tables->str_aac_sfb_info[2].sfb_index =
514
72.6k
            ptr_aac_tables->sfb_short_table;
515
516
72.6k
        ptr_aac_tables->str_aac_sfb_info[0].sfb_width = (WORD8 *)psfb_width[0];
517
72.6k
        ptr_aac_tables->str_aac_sfb_info[1].sfb_width = (WORD8 *)psfb_width[0];
518
72.6k
        ptr_aac_tables->str_aac_sfb_info[3].sfb_width = (WORD8 *)psfb_width[0];
519
520
72.6k
        ptr_aac_tables->str_aac_sfb_info[2].sfb_width = (WORD8 *)psfb_width[1];
521
72.6k
      }
522
72.6k
    } else {
523
36.2k
      WORD16 *ptr_sfb_idx[2];
524
36.2k
      const WORD8 *ptr_sfb_width[2] = {0};
525
36.2k
      WORD width_idx;
526
36.2k
      WORD32 j;
527
528
36.2k
      ptr_sfb_idx[0] = ptr_aac_tables->sfb_long_table;
529
36.2k
      ptr_sfb_idx[1] = ptr_aac_tables->sfb_short_table;
530
531
36.2k
      if (frame_length == 512)
532
22.7k
        ptr_sfb_width[0] = ptr_aac_tables->scale_fac_bands_512[i];
533
13.5k
      else
534
13.5k
        ptr_sfb_width[0] = ptr_aac_tables->scale_fac_bands_480[i];
535
536
72.4k
      for (j = 0; j >= 0; j--) {
537
36.2k
        const WORD8 *ptr_width = ptr_sfb_width[j];
538
36.2k
        WORD16 *ptr_idx = ptr_sfb_idx[j];
539
36.2k
        width_idx = 0;
540
36.2k
        *ptr_idx++ = width_idx;
541
1.19M
        do {
542
1.19M
          width_idx += (*ptr_width++);
543
1.19M
          *ptr_idx++ = width_idx;
544
1.19M
        } while (*ptr_width != -1);
545
546
36.2k
        aac_persistent_mem->str_aac_decoder.num_swb_window[j] =
547
36.2k
            (WORD8)(ptr_width - ptr_sfb_width[j]);
548
36.2k
      }
549
550
36.2k
      {
551
36.2k
        ptr_aac_tables->str_aac_sfb_info[0].sfb_index =
552
36.2k
            ptr_aac_tables->sfb_long_table;
553
36.2k
        ptr_aac_tables->str_aac_sfb_info[1].sfb_index =
554
36.2k
            ptr_aac_tables->sfb_long_table;
555
36.2k
        ptr_aac_tables->str_aac_sfb_info[3].sfb_index =
556
36.2k
            ptr_aac_tables->sfb_long_table;
557
36.2k
        ptr_aac_tables->str_aac_sfb_info[2].sfb_index =
558
36.2k
            ptr_aac_tables->sfb_short_table;
559
560
36.2k
        ptr_aac_tables->str_aac_sfb_info[0].sfb_width =
561
36.2k
            (WORD8 *)ptr_sfb_width[0];
562
36.2k
        ptr_aac_tables->str_aac_sfb_info[1].sfb_width =
563
36.2k
            (WORD8 *)ptr_sfb_width[0];
564
36.2k
        ptr_aac_tables->str_aac_sfb_info[3].sfb_width =
565
36.2k
            (WORD8 *)ptr_sfb_width[0];
566
36.2k
        ptr_aac_tables->str_aac_sfb_info[2].sfb_width =
567
36.2k
            (WORD8 *)ptr_sfb_width[1];
568
36.2k
      }
569
36.2k
    }
570
108k
    {
571
108k
      ia_aac_decoder_struct *aac_dec_handle =
572
108k
          &aac_persistent_mem->str_aac_decoder;
573
108k
      aac_dec_handle->sampling_rate_index = (WORD16)i;
574
108k
      aac_dec_handle->sampling_rate = sampling_rate;
575
108k
      aac_dec_handle->channels = 1;
576
108k
      aac_dec_handle->block_number = 0;
577
108k
      aac_dec_handle->samples_per_frame = frame_length;
578
108k
    }
579
108k
  }
580
581
0
  return &(aac_persistent_mem->str_aac_decoder);
582
108k
}