• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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 "ixheaacd_sbr_common.h"
22 #include "ixheaacd_type_def.h"
23 
24 #include "ixheaacd_constants.h"
25 #include "ixheaacd_basic_ops32.h"
26 #include "ixheaacd_basic_ops16.h"
27 #include "ixheaacd_basic_ops40.h"
28 #include "ixheaacd_basic_ops.h"
29 #include "ixheaacd_defines.h"
30 
31 #include "ixheaacd_intrinsics.h"
32 #include "ixheaacd_sbr_const.h"
33 #include "ixheaacd_basic_op.h"
34 #include "ixheaacd_defines.h"
35 #include "ixheaacd_bitbuffer.h"
36 #include "ixheaacd_pns.h"
37 
38 #include "ixheaacd_aac_rom.h"
39 #include "ixheaacd_pulsedata.h"
40 
41 #include "ixheaacd_drc_data_struct.h"
42 #include "ixheaacd_lt_predict.h"
43 #include "ixheaacd_channelinfo.h"
44 #include "ixheaacd_drc_dec.h"
45 
46 #include "ixheaacd_sbrdecoder.h"
47 
48 #include "ixheaacd_sbrdecsettings.h"
49 #include "ixheaacd_sbr_scale.h"
50 #include "ixheaacd_lpp_tran.h"
51 #include "ixheaacd_env_extr_part.h"
52 #include "ixheaacd_sbr_rom.h"
53 #include "ixheaacd_hybrid.h"
54 #include "ixheaacd_ps_dec.h"
55 #include "ixheaacd_ps_bitdec.h"
56 #include "ixheaacd_env_extr.h"
57 #include "ixheaacd_common_rom.h"
58 #include "ixheaacd_freq_sca.h"
59 
60 #include "ixheaacd_qmf_dec.h"
61 
62 #include "ixheaacd_env_calc.h"
63 
64 #include "ixheaacd_pvc_dec.h"
65 #include "ixheaacd_sbr_dec.h"
66 #include "ixheaacd_env_dec.h"
67 #include "ixheaacd_basic_funcs.h"
68 #include "ixheaacd_sbr_crc.h"
69 #include "ixheaacd_error_standards.h"
70 #include "ixheaacd_sbrqmftrans.h"
71 
72 #include "ixheaacd_audioobjtypes.h"
73 
74 #define ALIGN_SIZE64(x) ((((x) + 7) >> 3) << 3)
75 
ixheaacd_getsize_sbr_persistent()76 WORD32 ixheaacd_getsize_sbr_persistent() {
77   return (ALIGN_SIZE64(sizeof(ia_sbr_pers_struct)));
78 }
79 
ixheaacd_esbr_hbe_data_init(ia_esbr_hbe_txposer_struct * pstr_esbr_hbe_txposer,const WORD32 num_aac_samples,WORD32 samp_fac_4_flag,const WORD32 num_out_samples,VOID * persistent_hbe_mem)80 WORD32 ixheaacd_esbr_hbe_data_init(
81     ia_esbr_hbe_txposer_struct *pstr_esbr_hbe_txposer,
82     const WORD32 num_aac_samples, WORD32 samp_fac_4_flag,
83     const WORD32 num_out_samples, VOID *persistent_hbe_mem) {
84   WORD32 i;
85   WORD32 used_persistent = 0;
86 
87   if (pstr_esbr_hbe_txposer) {
88     memset(pstr_esbr_hbe_txposer, 0, sizeof(ia_esbr_hbe_txposer_struct));
89 
90     pstr_esbr_hbe_txposer->core_frame_length = num_aac_samples;
91 
92     pstr_esbr_hbe_txposer->no_bins = num_out_samples / NO_QMF_SYNTH_CHANNELS;
93 
94     pstr_esbr_hbe_txposer->hbe_qmf_in_len =
95         pstr_esbr_hbe_txposer->no_bins / 2 + HBE_OPER_WIN_LEN - 1;
96     pstr_esbr_hbe_txposer->hbe_qmf_out_len =
97         2 * pstr_esbr_hbe_txposer->hbe_qmf_in_len;
98 
99     pstr_esbr_hbe_txposer->ptr_input_buf =
100         (FLOAT32 *)((WORD8 *)persistent_hbe_mem);
101     used_persistent +=
102         (num_aac_samples + NO_QMF_SYNTH_CHANNELS) * sizeof(FLOAT32);
103 
104     pstr_esbr_hbe_txposer->qmf_in_buf =
105         (FLOAT32 **)((WORD8 *)persistent_hbe_mem + used_persistent);
106     used_persistent +=
107         pstr_esbr_hbe_txposer->hbe_qmf_in_len * sizeof(FLOAT32 *);
108 
109     for (i = 0; i < pstr_esbr_hbe_txposer->hbe_qmf_in_len; i++) {
110       pstr_esbr_hbe_txposer->qmf_in_buf[i] =
111           (FLOAT32 *)((WORD8 *)persistent_hbe_mem + used_persistent);
112 
113       used_persistent += (TWICE_QMF_SYNTH_CHANNELS_NUM * sizeof(FLOAT32));
114     }
115 
116     pstr_esbr_hbe_txposer->qmf_out_buf =
117         (FLOAT32 **)((WORD8 *)persistent_hbe_mem + used_persistent);
118     used_persistent +=
119         (pstr_esbr_hbe_txposer->hbe_qmf_out_len * sizeof(FLOAT32 *));
120 
121     for (i = 0; i < pstr_esbr_hbe_txposer->hbe_qmf_out_len; i++) {
122       pstr_esbr_hbe_txposer->qmf_out_buf[i] =
123           (FLOAT32 *)((WORD8 *)persistent_hbe_mem + used_persistent);
124       used_persistent += (TWICE_QMF_SYNTH_CHANNELS_NUM * sizeof(FLOAT32));
125     }
126     pstr_esbr_hbe_txposer->upsamp_4_flag = samp_fac_4_flag;
127   }
128 
129   return 0;
130 }
131 
ixheaacd_set_sbr_persistent_table_pointer(VOID * sbr_persistent_mem_v,ia_sbr_tables_struct * sbr_tables_ptr,ixheaacd_misc_tables * pstr_common_tables)132 VOID ixheaacd_set_sbr_persistent_table_pointer(
133     VOID *sbr_persistent_mem_v, ia_sbr_tables_struct *sbr_tables_ptr,
134     ixheaacd_misc_tables *pstr_common_tables) {
135   ia_sbr_pers_struct *sbr_persistent_mem =
136       (ia_sbr_pers_struct *)sbr_persistent_mem_v;
137   sbr_persistent_mem->str_sbr_dec_inst.pstr_sbr_tables = sbr_tables_ptr;
138   sbr_persistent_mem->str_sbr_dec_inst.pstr_common_tables = pstr_common_tables;
139 }
140 
ixheaacd_set_sbr_persistent_buffers(VOID * sbr_persistent_mem_v,WORD32 * persistent_used,WORD32 num_channel,WORD ps_enable)141 VOID ixheaacd_set_sbr_persistent_buffers(VOID *sbr_persistent_mem_v,
142                                          WORD32 *persistent_used,
143                                          WORD32 num_channel, WORD ps_enable) {
144   WORD32 i = 0;
145   WORD32 used_persistent = *persistent_used;
146   WORD32 temp, temp1, temp2, temp3;
147   struct ia_sbr_pers_struct *sbr_persistent_mem =
148       (struct ia_sbr_pers_struct *)sbr_persistent_mem_v;
149 
150   struct ia_sbr_dec_inst_struct *p_str_sbr_dec_inst =
151       &sbr_persistent_mem->str_sbr_dec_inst;
152 
153   memset(sbr_persistent_mem, 0, sizeof(struct ia_sbr_pers_struct));
154 
155   sbr_persistent_mem->sbr_qmf_analy_states =
156       (WORD16 *)((WORD8 *)sbr_persistent_mem_v + used_persistent);
157   temp = num_channel * ((QMF_FILTER_STATE_ANA_SIZE + 2 * NO_ANALYSIS_CHANNELS) *
158                         sizeof(WORD16));
159   used_persistent += temp;
160 
161   sbr_persistent_mem->sbr_qmf_analy_states_32 =
162       (WORD32 *)((WORD8 *)sbr_persistent_mem_v + used_persistent);
163   temp1 =
164       num_channel *
165       ((QMF_FILTER_STATE_ANA_SIZE + 2 * NO_ANALYSIS_CHANNELS) * sizeof(WORD32));
166   used_persistent += temp1;
167 
168   sbr_persistent_mem->sbr_qmf_synth_states =
169       (WORD16 *)((WORD8 *)sbr_persistent_mem_v + used_persistent);
170 
171   temp2 =
172       (num_channel * ((QMF_FILTER_STATE_SYN_SIZE + 2 * NO_SYNTHESIS_CHANNELS) *
173                       sizeof(WORD16)));
174   used_persistent += temp2;
175 
176   sbr_persistent_mem->sbr_qmf_synth_states_32 =
177       (WORD32 *)((WORD8 *)sbr_persistent_mem_v + used_persistent);
178 
179   temp3 =
180       (num_channel * ((QMF_FILTER_STATE_SYN_SIZE + 2 * NO_SYNTHESIS_CHANNELS) *
181                       sizeof(WORD32)));
182   used_persistent += temp3;
183 
184   memset(sbr_persistent_mem->sbr_qmf_analy_states, 0,
185          (temp + temp1 + temp2 + temp3));
186 
187   for (i = 0; i < num_channel; i++) {
188     sbr_persistent_mem->ptr_sbr_overlap_buf[i] =
189         (WORD32 *)((WORD8 *)sbr_persistent_mem_v + used_persistent);
190 
191     if (ps_enable) {
192       memset(sbr_persistent_mem->ptr_sbr_overlap_buf[i], 0,
193              2 * MAX_OV_COLS * NO_SYNTHESIS_CHANNELS * sizeof(WORD32));
194       used_persistent +=
195           2 * MAX_OV_COLS * NO_SYNTHESIS_CHANNELS * sizeof(WORD32);
196     } else {
197       memset(sbr_persistent_mem->ptr_sbr_overlap_buf[i], 0,
198              MAX_OV_COLS * NO_SYNTHESIS_CHANNELS * sizeof(WORD32));
199       used_persistent += MAX_OV_COLS * NO_SYNTHESIS_CHANNELS * sizeof(WORD32);
200     }
201   }
202 
203   for (i = 0; i < num_channel; i++) {
204     WORD32 j;
205     sbr_persistent_mem->sbr_lpc_filter_states_real[i] =
206         (WORD32 **)((WORD8 *)sbr_persistent_mem_v + used_persistent);
207     used_persistent += LPC_ORDER * sizeof(WORD32 *);
208     for (j = 0; j < LPC_ORDER; j++) {
209       sbr_persistent_mem->sbr_lpc_filter_states_real[i][j] =
210           (WORD32 *)((WORD8 *)sbr_persistent_mem_v + used_persistent);
211 
212       used_persistent += NO_ANALYSIS_CHANNELS * sizeof(WORD32);
213 
214       memset(sbr_persistent_mem->sbr_lpc_filter_states_real[i][j], 0,
215              NO_ANALYSIS_CHANNELS * sizeof(WORD32));
216     }
217   }
218 
219   if (ps_enable) {
220     for (i = 0; i < num_channel; i++) {
221       WORD32 j;
222 
223       sbr_persistent_mem->sbr_lpc_filter_states_imag[i] =
224           (WORD32 **)((WORD8 *)sbr_persistent_mem_v + used_persistent);
225       used_persistent += LPC_ORDER * sizeof(WORD32 *);
226       for (j = 0; j < LPC_ORDER; j++) {
227         sbr_persistent_mem->sbr_lpc_filter_states_imag[i][j] =
228             (WORD32 *)((WORD8 *)sbr_persistent_mem_v + used_persistent);
229 
230         used_persistent += NO_ANALYSIS_CHANNELS * sizeof(WORD32);
231 
232         memset(sbr_persistent_mem->sbr_lpc_filter_states_imag[i][j], 0,
233                NO_ANALYSIS_CHANNELS * sizeof(WORD32));
234       }
235     }
236   }
237   for (i = 0; i < num_channel; i++) {
238     WORD32 initial_used = used_persistent;
239     WORD32 temp_used = used_persistent;
240 
241     sbr_persistent_mem->sbr_smooth_gain_buf[i] =
242         (WORD16 *)((WORD8 *)sbr_persistent_mem_v + temp_used);
243     temp_used += 2 * MAX_FREQ_COEFFS * sizeof(WORD16);
244 
245     sbr_persistent_mem->sbr_smooth_noise_buf[i] =
246         (WORD16 *)((WORD8 *)sbr_persistent_mem_v + temp_used);
247 
248     temp_used += MAX_FREQ_COEFFS * sizeof(WORD16);
249 
250     p_str_sbr_dec_inst->pstr_freq_band_data[i] =
251         (VOID *)((WORD8 *)sbr_persistent_mem_v + temp_used);
252 
253     temp_used += ALIGN_SIZE64(sizeof(ia_freq_band_data_struct));
254 
255     sbr_persistent_mem->pstr_prev_frame_data[i] =
256         (VOID *)((WORD8 *)sbr_persistent_mem_v + temp_used);
257 
258     temp_used += ALIGN_SIZE64(sizeof(ia_sbr_prev_frame_data_struct));
259 
260     p_str_sbr_dec_inst->pstr_sbr_channel[i] =
261         (VOID *)((WORD8 *)sbr_persistent_mem_v + temp_used);
262 
263     temp_used += ALIGN_SIZE64(sizeof(ia_sbr_channel_struct));
264 
265     p_str_sbr_dec_inst->pstr_sbr_header[i] =
266         (VOID *)((WORD8 *)sbr_persistent_mem_v + temp_used);
267 
268     temp_used += ALIGN_SIZE64(sizeof(ia_sbr_header_data_struct));
269 
270     memset(sbr_persistent_mem->sbr_smooth_gain_buf[i], 0,
271            temp_used - initial_used);
272 
273     used_persistent = temp_used;
274   }
275 
276   if (ps_enable) {
277     p_str_sbr_dec_inst->pstr_ps_stereo_dec =
278         (ia_ps_dec_struct *)((WORD8 *)sbr_persistent_mem_v + used_persistent);
279 
280     memset(p_str_sbr_dec_inst->pstr_ps_stereo_dec, 0, sizeof(ia_ps_dec_struct));
281 
282     used_persistent += sizeof(ia_ps_dec_struct);
283   }
284 
285   p_str_sbr_dec_inst->frame_buffer[0] =
286       (VOID *)((WORD8 *)sbr_persistent_mem_v + used_persistent);
287   memset(p_str_sbr_dec_inst->frame_buffer[0], 0,
288          (sizeof(ia_sbr_frame_info_data_struct) +
289           MAX_FREQ_COEFFS * sizeof(WORD32) * 2 + 8));
290   used_persistent = used_persistent + (sizeof(ia_sbr_frame_info_data_struct) +
291                                        MAX_FREQ_COEFFS * sizeof(WORD32) + 8);
292 
293   p_str_sbr_dec_inst->frame_buffer[1] =
294       (VOID *)((WORD8 *)sbr_persistent_mem_v + used_persistent);
295   memset(p_str_sbr_dec_inst->frame_buffer[1], 0,
296          (sizeof(ia_sbr_frame_info_data_struct) +
297           MAX_FREQ_COEFFS * sizeof(WORD32) * 2 + 8));
298   used_persistent = used_persistent + (sizeof(ia_sbr_frame_info_data_struct) +
299                                        MAX_FREQ_COEFFS * sizeof(WORD32) + 8);
300 
301   {
302     WORD32 index = 0;
303     p_str_sbr_dec_inst->ptr_pvc_data_str =
304         (ia_pvc_data_struct *)((WORD8 *)sbr_persistent_mem_v + used_persistent);
305     memset(p_str_sbr_dec_inst->ptr_pvc_data_str, 0, sizeof(ia_pvc_data_struct));
306     used_persistent += sizeof(ia_pvc_data_struct);
307 
308     p_str_sbr_dec_inst->pstr_sbr_channel[0]->str_sbr_dec.p_hbe_txposer =
309         (ia_esbr_hbe_txposer_struct *)((WORD8 *)sbr_persistent_mem_v +
310                                        used_persistent);
311     memset(p_str_sbr_dec_inst->pstr_sbr_channel[0]->str_sbr_dec.p_hbe_txposer,
312            0, sizeof(ia_esbr_hbe_txposer_struct));
313     used_persistent += sizeof(ia_esbr_hbe_txposer_struct);
314 
315     if (num_channel == 2) {
316       p_str_sbr_dec_inst->pstr_sbr_channel[1]->str_sbr_dec.p_hbe_txposer =
317           (ia_esbr_hbe_txposer_struct *)((WORD8 *)sbr_persistent_mem_v +
318                                          used_persistent);
319       memset(p_str_sbr_dec_inst->pstr_sbr_channel[1]->str_sbr_dec.p_hbe_txposer,
320              0, sizeof(ia_esbr_hbe_txposer_struct));
321       used_persistent += sizeof(ia_esbr_hbe_txposer_struct);
322     }
323 
324     p_str_sbr_dec_inst->hbe_txposer_buffers =
325         (VOID *)((WORD8 *)sbr_persistent_mem_v + used_persistent);
326     memset(p_str_sbr_dec_inst->hbe_txposer_buffers, 0,
327            num_channel * MAX_HBE_PERSISTENT_SIZE);
328     used_persistent += num_channel * MAX_HBE_PERSISTENT_SIZE;
329 
330     p_str_sbr_dec_inst->pstr_sbr_channel[0]->str_sbr_dec.pp_qmf_buf_real =
331         (FLOAT32 **)((WORD8 *)sbr_persistent_mem_v + used_persistent);
332     memset(p_str_sbr_dec_inst->pstr_sbr_channel[0]->str_sbr_dec.pp_qmf_buf_real,
333            0, MAX_QMF_BUF_LEN * sizeof(FLOAT32 *));
334     used_persistent += MAX_QMF_BUF_LEN * sizeof(FLOAT32 *);
335 
336     p_str_sbr_dec_inst->pstr_sbr_channel[0]->str_sbr_dec.pp_qmf_buf_imag =
337         (FLOAT32 **)((WORD8 *)sbr_persistent_mem_v + used_persistent);
338     memset(p_str_sbr_dec_inst->pstr_sbr_channel[0]->str_sbr_dec.pp_qmf_buf_imag,
339            0, MAX_QMF_BUF_LEN);
340     used_persistent += MAX_QMF_BUF_LEN * sizeof(FLOAT32 *);
341 
342     if (num_channel == 2) {
343       p_str_sbr_dec_inst->pstr_sbr_channel[1]->str_sbr_dec.pp_qmf_buf_real =
344           (FLOAT32 **)((WORD8 *)sbr_persistent_mem_v + used_persistent);
345       memset(
346           p_str_sbr_dec_inst->pstr_sbr_channel[1]->str_sbr_dec.pp_qmf_buf_real,
347           0, MAX_QMF_BUF_LEN * sizeof(FLOAT32 *));
348       used_persistent += MAX_QMF_BUF_LEN * sizeof(FLOAT32 *);
349 
350       p_str_sbr_dec_inst->pstr_sbr_channel[1]->str_sbr_dec.pp_qmf_buf_imag =
351           (FLOAT32 **)((WORD8 *)sbr_persistent_mem_v + used_persistent);
352       memset(
353           p_str_sbr_dec_inst->pstr_sbr_channel[1]->str_sbr_dec.pp_qmf_buf_imag,
354           0, MAX_QMF_BUF_LEN * sizeof(FLOAT32 *));
355       used_persistent += MAX_QMF_BUF_LEN * sizeof(FLOAT32 *);
356     }
357 
358     for (index = 0; index < MAX_QMF_BUF_LEN; index++) {
359       p_str_sbr_dec_inst->pstr_sbr_channel[0]
360           ->str_sbr_dec.pp_qmf_buf_real[index] =
361           (FLOAT32 *)((WORD8 *)sbr_persistent_mem_v + used_persistent);
362       used_persistent += MAX_QMF_BUF_LEN * sizeof(FLOAT32);
363     }
364 
365     for (index = 0; index < MAX_QMF_BUF_LEN; index++) {
366       p_str_sbr_dec_inst->pstr_sbr_channel[0]
367           ->str_sbr_dec.pp_qmf_buf_imag[index] =
368           (FLOAT32 *)((WORD8 *)sbr_persistent_mem_v + used_persistent);
369       used_persistent += MAX_QMF_BUF_LEN * sizeof(FLOAT32);
370     }
371 
372     if (num_channel == 2) {
373       for (index = 0; index < MAX_QMF_BUF_LEN; index++) {
374         p_str_sbr_dec_inst->pstr_sbr_channel[1]
375             ->str_sbr_dec.pp_qmf_buf_real[index] =
376             (FLOAT32 *)((WORD8 *)sbr_persistent_mem_v + used_persistent);
377         used_persistent += MAX_QMF_BUF_LEN * sizeof(FLOAT32);
378       }
379 
380       for (index = 0; index < MAX_QMF_BUF_LEN; index++) {
381         p_str_sbr_dec_inst->pstr_sbr_channel[1]
382             ->str_sbr_dec.pp_qmf_buf_imag[index] =
383             (FLOAT32 *)((WORD8 *)sbr_persistent_mem_v + used_persistent);
384         used_persistent += MAX_QMF_BUF_LEN * sizeof(FLOAT32);
385       }
386     }
387   }
388 
389   *persistent_used = used_persistent;
390 }
391 
ia_enhaacplus_dec_get_sbr_buffers_size(WORD32 channels)392 WORD32 ia_enhaacplus_dec_get_sbr_buffers_size(WORD32 channels) {
393   WORD32 sbr_buffers_size = 0;
394   WORD32 temp, temp2;
395   WORD32 num_channel = channels;
396   WORD32 i;
397 
398   temp = num_channel * ((QMF_FILTER_STATE_ANA_SIZE + 2 * NO_ANALYSIS_CHANNELS) *
399                         sizeof(WORD16));
400   sbr_buffers_size += temp;
401 
402   temp2 =
403       (num_channel * ((QMF_FILTER_STATE_SYN_SIZE + 2 * NO_SYNTHESIS_CHANNELS) *
404                       sizeof(WORD16)));
405   sbr_buffers_size += temp2;
406 
407   for (i = 0; i < num_channel; i++) {
408     sbr_buffers_size +=
409         2 * MAX_OV_COLS * NO_SYNTHESIS_CHANNELS * sizeof(WORD32);
410   }
411 
412   for (i = 0; i < num_channel; i++) {
413     int j;
414     sbr_buffers_size += LPC_ORDER * sizeof(VOID *);
415 
416     for (j = 0; j < LPC_ORDER; j++) {
417       sbr_buffers_size += NO_ANALYSIS_CHANNELS * sizeof(WORD32);
418     }
419   }
420 
421   for (i = 0; i < num_channel; i++) {
422     int j;
423     sbr_buffers_size += LPC_ORDER * sizeof(WORD32);
424     for (j = 0; j < LPC_ORDER; j++) {
425       sbr_buffers_size += NO_ANALYSIS_CHANNELS * sizeof(WORD32);
426     }
427   }
428 
429   for (i = 0; i < num_channel; i++) {
430     WORD32 temp_used = sbr_buffers_size;
431 
432     temp_used += 2 * MAX_FREQ_COEFFS * sizeof(WORD16);
433     temp_used += MAX_FREQ_COEFFS * sizeof(WORD16);
434     temp_used += ALIGN_SIZE64(sizeof(ia_freq_band_data_struct));
435     temp_used += ALIGN_SIZE64(sizeof(ia_sbr_prev_frame_data_struct));
436     temp_used += ALIGN_SIZE64(sizeof(ia_sbr_channel_struct));
437     temp_used += ALIGN_SIZE64(sizeof(ia_sbr_header_data_struct));
438 
439     sbr_buffers_size = temp_used;
440   }
441 
442   sbr_buffers_size += sizeof(ia_ps_dec_struct);
443 
444   return sbr_buffers_size;
445 }
446 
ixheaacd_init_headerdata(ia_sbr_header_data_struct * ptr_header_data,WORD32 sample_rate_dec,WORD32 samp_per_frame,ia_freq_band_data_struct * freq_band_data,ia_sbr_tables_struct * sbr_tables,WORD audio_obj_type)447 static PLATFORM_INLINE VOID ixheaacd_init_headerdata(
448     ia_sbr_header_data_struct *ptr_header_data, WORD32 sample_rate_dec,
449     WORD32 samp_per_frame, ia_freq_band_data_struct *freq_band_data,
450     ia_sbr_tables_struct *sbr_tables, WORD audio_obj_type) {
451   ia_freq_band_data_struct *pstr_freq_band_data = freq_band_data;
452   WORD32 tmp;
453 
454   if (audio_obj_type != AOT_ER_AAC_ELD) {
455     memcpy(ptr_header_data,
456            &sbr_tables->env_extr_tables_ptr->str_sbr_default_header,
457            sizeof(ia_sbr_header_data_struct));
458   }
459 
460   if (audio_obj_type == AOT_ER_AAC_ELD) ptr_header_data->time_step -= 1;
461 
462   pstr_freq_band_data->freq_band_table[LOW] =
463       pstr_freq_band_data->freq_band_tbl_lo;
464   pstr_freq_band_data->freq_band_table[HIGH] =
465       pstr_freq_band_data->freq_band_tbl_hi;
466   ptr_header_data->pstr_freq_band_data = pstr_freq_band_data;
467 
468   ptr_header_data->core_frame_size = samp_per_frame;
469   ptr_header_data->out_sampling_freq = sample_rate_dec << 1;
470 
471   if (audio_obj_type != AOT_ER_AAC_ELD) {
472     tmp = ptr_header_data->time_step + 4;
473 
474     if (tmp < 0)
475       ptr_header_data->num_time_slots =
476           ixheaacd_extract16l(samp_per_frame << (-tmp));
477     else
478       ptr_header_data->num_time_slots =
479           ixheaacd_extract16l(samp_per_frame >> tmp);
480   } else {
481     ptr_header_data->time_step = 1;
482 
483     ptr_header_data->num_time_slots =
484         (samp_per_frame / 32 >> (ptr_header_data->time_step - 1));
485   }
486 }
487 
ixheaacd_setesbr_flags(VOID * sbr_persistent_mem_v,FLAG pvc_flag,FLAG hbe_flag,FLAG inter_tes_flag)488 VOID ixheaacd_setesbr_flags(VOID *sbr_persistent_mem_v, FLAG pvc_flag,
489                             FLAG hbe_flag, FLAG inter_tes_flag) {
490   ia_sbr_pers_struct *sbr_persistent_mem;
491   sbr_persistent_mem = (ia_sbr_pers_struct *)sbr_persistent_mem_v;
492   sbr_persistent_mem->str_sbr_dec_inst.hbe_flag = hbe_flag;
493   sbr_persistent_mem->str_sbr_dec_inst.pvc_flag = pvc_flag;
494   sbr_persistent_mem->str_sbr_dec_inst.inter_tes_flag = inter_tes_flag;
495   return;
496 }
497 
ixheaacd_init_sbr(WORD32 sample_rate_dec,WORD32 samp_per_frame,FLAG * down_sample_flag,VOID * sbr_persistent_mem_v,WORD32 * ptr_overlap_buf,WORD32 channel,WORD32 ps_enable,WORD32 sbr_ratio_idx,WORD32 output_frame_size,WORD32 * use_hbe,VOID * p_usac_dflt_header,ia_sbr_header_data_struct str_sbr_config,WORD32 audio_object_type)498 ia_handle_sbr_dec_inst_struct ixheaacd_init_sbr(
499     WORD32 sample_rate_dec, WORD32 samp_per_frame, FLAG *down_sample_flag,
500     VOID *sbr_persistent_mem_v, WORD32 *ptr_overlap_buf, WORD32 channel,
501     WORD32 ps_enable, WORD32 sbr_ratio_idx, WORD32 output_frame_size,
502     WORD32 *use_hbe, VOID *p_usac_dflt_header,
503     ia_sbr_header_data_struct str_sbr_config, WORD32 audio_object_type) {
504   WORD16 i;
505   WORD16 err;
506   ia_sbr_header_data_struct *ptr_header_data[MAXNRSBRCHANNELS];
507   ia_sbr_dec_struct *ptr_sbr_dec[2];
508   ia_qmf_dec_tables_struct *qmf_dec_tables_ptr;
509   ia_sbr_pers_struct *sbr_persistent_mem;
510 
511   sbr_persistent_mem = (ia_sbr_pers_struct *)sbr_persistent_mem_v;
512   ptr_sbr_dec[0] =
513       &sbr_persistent_mem->str_sbr_dec_inst.pstr_sbr_channel[0]->str_sbr_dec;
514   ptr_sbr_dec[1] =
515       &sbr_persistent_mem->str_sbr_dec_inst.pstr_sbr_channel[1]->str_sbr_dec;
516 
517   qmf_dec_tables_ptr =
518       sbr_persistent_mem->str_sbr_dec_inst.pstr_sbr_tables->qmf_dec_tables_ptr;
519 
520   if (sample_rate_dec > 48000) {
521     *down_sample_flag = 1;
522   }
523 
524   for (i = 0; i < channel; i++) {
525     if (audio_object_type == AOT_ER_AAC_ELD) {
526       memcpy(sbr_persistent_mem->str_sbr_dec_inst.pstr_sbr_header[i],
527              &str_sbr_config, sizeof(ia_sbr_header_data_struct));
528     }
529     ptr_header_data[i] =
530         sbr_persistent_mem->str_sbr_dec_inst.pstr_sbr_header[i];
531 
532     ixheaacd_init_headerdata(
533         ptr_header_data[i], sample_rate_dec, samp_per_frame,
534         sbr_persistent_mem->str_sbr_dec_inst.pstr_freq_band_data[i],
535         sbr_persistent_mem->str_sbr_dec_inst.pstr_sbr_tables,
536         audio_object_type);
537 
538     err = ixheaacd_create_sbrdec(
539 
540         sbr_persistent_mem->str_sbr_dec_inst.pstr_common_tables,
541         sbr_persistent_mem->str_sbr_dec_inst.pstr_sbr_channel[i],
542         ptr_header_data[i], i, *down_sample_flag, sbr_persistent_mem, ps_enable,
543         audio_object_type);
544 
545     ptr_header_data[i]->status = 1;
546 
547     if (err) {
548       return NULL;
549     }
550   }
551 
552   if (channel != 1) {
553     if (ps_enable) {
554       if (audio_object_type == AOT_ER_AAC_ELD)
555         err = (WORD16)ixheaacd_create_psdec(
556             sbr_persistent_mem->str_sbr_dec_inst.pstr_ps_stereo_dec,
557             sbr_persistent_mem, &ptr_overlap_buf[512 * 4]);
558       else
559         err = (WORD16)ixheaacd_create_psdec(
560             sbr_persistent_mem->str_sbr_dec_inst.pstr_ps_stereo_dec,
561             sbr_persistent_mem, ptr_overlap_buf);
562       if (err) {
563         return NULL;
564       }
565     }
566   }
567 
568   if (use_hbe != NULL) {
569     ia_sbr_header_data_struct *ptr_sbr_dflt_header =
570         &sbr_persistent_mem->str_sbr_dec_inst.str_sbr_dflt_header;
571     ia_sbr_header_data_struct *ptr_usac_dflt_header =
572         (ia_sbr_header_data_struct *)p_usac_dflt_header;
573     struct ia_sbr_dec_inst_struct *p_str_sbr_dec_inst =
574         &sbr_persistent_mem->str_sbr_dec_inst;
575     VOID *hbe_txposer_buffers = p_str_sbr_dec_inst->hbe_txposer_buffers;
576 
577     ptr_header_data[0] = p_str_sbr_dec_inst->pstr_sbr_header[0];
578     ptr_header_data[1] = p_str_sbr_dec_inst->pstr_sbr_header[1];
579 
580     ptr_header_data[0]->sbr_ratio_idx = sbr_ratio_idx;
581     ptr_header_data[0]->output_framesize = output_frame_size;
582     ptr_header_data[0]->pstr_freq_band_data->sub_band_start = 64;
583     ptr_header_data[0]->esbr_start_up = 1;
584     ptr_header_data[0]->esbr_start_up_pvc = 1;
585 
586     if (channel > 1) {
587       ptr_header_data[1]->sbr_ratio_idx = sbr_ratio_idx;
588       ptr_header_data[1]->output_framesize = output_frame_size;
589       ptr_header_data[1]->pstr_freq_band_data->sub_band_start = 64;
590       ptr_header_data[1]->esbr_start_up = 1;
591       ptr_header_data[1]->esbr_start_up_pvc = 1;
592     }
593     if (hbe_txposer_buffers != NULL && (use_hbe[0] == 1)) {
594       ixheaacd_esbr_hbe_data_init(ptr_sbr_dec[0]->p_hbe_txposer, samp_per_frame,
595                                   sbr_ratio_idx == SBR_UPSAMPLE_IDX_4_1 ? 1 : 0,
596                                   output_frame_size, hbe_txposer_buffers);
597 
598       hbe_txposer_buffers =
599           (WORD8 *)hbe_txposer_buffers + MAX_HBE_PERSISTENT_SIZE;
600 
601       ixheaacd_esbr_hbe_data_init(ptr_sbr_dec[1]->p_hbe_txposer, samp_per_frame,
602                                   sbr_ratio_idx == SBR_UPSAMPLE_IDX_4_1 ? 1 : 0,
603                                   output_frame_size, hbe_txposer_buffers);
604     }
605 
606     p_str_sbr_dec_inst->ptr_pvc_data_str->prev_first_bnd_idx = -1;
607     p_str_sbr_dec_inst->ptr_pvc_data_str->prev_pvc_rate = -1;
608     p_str_sbr_dec_inst->ptr_pvc_data_str->prev_sbr_mode = UNKNOWN_SBR;
609 
610     p_str_sbr_dec_inst->pstr_sbr_channel[0]
611         ->str_sbr_dec.str_codec_qmf_bank.num_time_slots =
612         output_frame_size / 64;
613     p_str_sbr_dec_inst->pstr_sbr_channel[1]
614         ->str_sbr_dec.str_codec_qmf_bank.num_time_slots =
615         output_frame_size / 64;
616 
617     ptr_header_data[0]->core_frame_size = samp_per_frame;
618     ptr_header_data[1]->core_frame_size = samp_per_frame;
619 
620     switch (sbr_ratio_idx) {
621       case SBR_UPSAMPLE_IDX_0_0:
622         ptr_sbr_dec[0]->str_codec_qmf_bank.no_channels = 32;
623         ptr_sbr_dec[0]->str_codec_qmf_bank.esbr_cos_twiddle =
624             (WORD32 *)qmf_dec_tables_ptr->esbr_sin_cos_twiddle_l32;
625         ptr_sbr_dec[0]->str_codec_qmf_bank.esbr_alt_sin_twiddle =
626             (WORD32 *)qmf_dec_tables_ptr->esbr_alt_sin_twiddle_l32;
627         ptr_sbr_dec[0]->str_codec_qmf_bank.esbr_t_cos =
628             (WORD32 *)qmf_dec_tables_ptr->esbr_t_cos_sin_l32;
629         ptr_header_data[0]->is_usf_4 = 0;
630         ptr_header_data[0]->upsamp_fac = 1;
631 
632         ptr_sbr_dec[1]->str_codec_qmf_bank.no_channels = 32;
633         ptr_sbr_dec[0]->str_codec_qmf_bank.esbr_cos_twiddle =
634             (WORD32 *)qmf_dec_tables_ptr->esbr_sin_cos_twiddle_l32;
635         ptr_sbr_dec[0]->str_codec_qmf_bank.esbr_alt_sin_twiddle =
636             (WORD32 *)qmf_dec_tables_ptr->esbr_alt_sin_twiddle_l32;
637         ptr_sbr_dec[0]->str_codec_qmf_bank.esbr_t_cos =
638             (WORD32 *)qmf_dec_tables_ptr->esbr_t_cos_sin_l32;
639         ptr_header_data[1]->is_usf_4 = 0;
640         ptr_header_data[1]->upsamp_fac = 1;
641         break;
642       case SBR_UPSAMPLE_IDX_2_1:
643         ptr_sbr_dec[0]->str_codec_qmf_bank.no_channels = 32;
644         ptr_sbr_dec[0]->str_codec_qmf_bank.esbr_cos_twiddle =
645             (WORD32 *)qmf_dec_tables_ptr->esbr_sin_cos_twiddle_l32;
646         ptr_sbr_dec[0]->str_codec_qmf_bank.esbr_alt_sin_twiddle =
647             (WORD32 *)qmf_dec_tables_ptr->esbr_alt_sin_twiddle_l32;
648         ptr_sbr_dec[0]->str_codec_qmf_bank.esbr_t_cos =
649             (WORD32 *)qmf_dec_tables_ptr->esbr_t_cos_sin_l32;
650         ptr_header_data[0]->is_usf_4 = 0;
651         ptr_header_data[0]->upsamp_fac = 2;
652 
653         ptr_sbr_dec[1]->str_codec_qmf_bank.no_channels = 32;
654         ptr_sbr_dec[1]->str_codec_qmf_bank.esbr_cos_twiddle =
655             (WORD32 *)qmf_dec_tables_ptr->esbr_sin_cos_twiddle_l32;
656         ptr_sbr_dec[1]->str_codec_qmf_bank.esbr_alt_sin_twiddle =
657             (WORD32 *)qmf_dec_tables_ptr->esbr_alt_sin_twiddle_l32;
658         ptr_sbr_dec[1]->str_codec_qmf_bank.esbr_t_cos =
659             (WORD32 *)qmf_dec_tables_ptr->esbr_t_cos_sin_l32;
660         ptr_header_data[1]->is_usf_4 = 0;
661         ptr_header_data[1]->upsamp_fac = 2;
662         break;
663       case SBR_UPSAMPLE_IDX_8_3:
664         ptr_sbr_dec[0]->str_codec_qmf_bank.no_channels = 24;
665         ptr_sbr_dec[0]->str_codec_qmf_bank.filter_pos_32 =
666             qmf_dec_tables_ptr->esbr_qmf_c_24;
667         ptr_sbr_dec[0]->str_codec_qmf_bank.analy_win_coeff_32 =
668             qmf_dec_tables_ptr->esbr_qmf_c_24;
669         ptr_sbr_dec[0]->str_codec_qmf_bank.esbr_cos_twiddle =
670             (WORD32 *)qmf_dec_tables_ptr->esbr_sin_cos_twiddle_l24;
671         ptr_sbr_dec[0]->str_codec_qmf_bank.esbr_alt_sin_twiddle =
672             (WORD32 *)qmf_dec_tables_ptr->esbr_alt_sin_twiddle_l24;
673         ptr_sbr_dec[0]->str_codec_qmf_bank.esbr_t_cos =
674             (WORD32 *)qmf_dec_tables_ptr->esbr_t_cos_sin_l24;
675 
676         ptr_header_data[0]->is_usf_4 = 0;
677         ptr_header_data[0]->upsamp_fac = 2;
678 
679         ptr_sbr_dec[1]->str_codec_qmf_bank.no_channels = 24;
680         ptr_sbr_dec[1]->str_codec_qmf_bank.filter_pos_32 =
681             qmf_dec_tables_ptr->esbr_qmf_c_24;
682         ptr_sbr_dec[1]->str_codec_qmf_bank.analy_win_coeff_32 =
683             qmf_dec_tables_ptr->esbr_qmf_c_24;
684         ptr_sbr_dec[1]->str_codec_qmf_bank.esbr_cos_twiddle =
685             (WORD32 *)qmf_dec_tables_ptr->esbr_sin_cos_twiddle_l24;
686         ptr_sbr_dec[1]->str_codec_qmf_bank.esbr_alt_sin_twiddle =
687             (WORD32 *)qmf_dec_tables_ptr->esbr_alt_sin_twiddle_l24;
688         ptr_sbr_dec[1]->str_codec_qmf_bank.esbr_t_cos =
689             (WORD32 *)qmf_dec_tables_ptr->esbr_t_cos_sin_l24;
690 
691         ptr_header_data[1]->is_usf_4 = 0;
692         ptr_header_data[1]->upsamp_fac = 2;
693         break;
694       case SBR_UPSAMPLE_IDX_4_1:
695         ptr_sbr_dec[0]->str_codec_qmf_bank.no_channels = 16;
696         ptr_sbr_dec[0]->str_codec_qmf_bank.esbr_cos_twiddle =
697             (WORD32 *)qmf_dec_tables_ptr->esbr_sin_cos_twiddle_l16;
698         ptr_sbr_dec[0]->str_codec_qmf_bank.esbr_alt_sin_twiddle =
699             (WORD32 *)qmf_dec_tables_ptr->esbr_alt_sin_twiddle_l16;
700         ptr_sbr_dec[0]->str_codec_qmf_bank.esbr_t_cos =
701             (WORD32 *)qmf_dec_tables_ptr->esbr_t_cos_sin_l16;
702         ptr_header_data[0]->is_usf_4 = 1;
703         ptr_header_data[0]->upsamp_fac = 4;
704         ptr_header_data[0]->out_sampling_freq =
705             ptr_header_data[0]->out_sampling_freq * 2;
706 
707         ptr_sbr_dec[1]->str_codec_qmf_bank.no_channels = 16;
708         ptr_sbr_dec[1]->str_codec_qmf_bank.esbr_cos_twiddle =
709             (WORD32 *)qmf_dec_tables_ptr->esbr_sin_cos_twiddle_l16;
710         ptr_sbr_dec[1]->str_codec_qmf_bank.esbr_alt_sin_twiddle =
711             (WORD32 *)qmf_dec_tables_ptr->esbr_alt_sin_twiddle_l16;
712         ptr_sbr_dec[1]->str_codec_qmf_bank.esbr_t_cos =
713             (WORD32 *)qmf_dec_tables_ptr->esbr_t_cos_sin_l16;
714         ptr_header_data[1]->is_usf_4 = 1;
715         ptr_header_data[1]->upsamp_fac = 4;
716         ptr_header_data[1]->out_sampling_freq =
717             ptr_header_data[1]->out_sampling_freq * 2;
718         break;
719     }
720 
721     ptr_sbr_dflt_header->start_freq = ptr_usac_dflt_header->start_freq;
722     ptr_sbr_dflt_header->stop_freq = ptr_usac_dflt_header->stop_freq;
723 
724     if (ptr_usac_dflt_header->header_extra_1) {
725       ptr_sbr_dflt_header->freq_scale = ptr_usac_dflt_header->freq_scale;
726       ptr_sbr_dflt_header->alter_scale = ptr_usac_dflt_header->alter_scale;
727       ptr_sbr_dflt_header->noise_bands = ptr_usac_dflt_header->noise_bands;
728     } else {
729       ptr_sbr_dflt_header->freq_scale = SBR_FREQ_SCALE_DEFAULT;
730       ptr_sbr_dflt_header->alter_scale = SBR_ALTER_SCALE_DEFAULT;
731       ptr_sbr_dflt_header->noise_bands = SBR_NOISE_BANDS_DEFAULT;
732     }
733 
734     if (ptr_usac_dflt_header->header_extra_2) {
735       ptr_sbr_dflt_header->limiter_bands = ptr_usac_dflt_header->limiter_bands;
736       ptr_sbr_dflt_header->limiter_gains = ptr_usac_dflt_header->limiter_gains;
737       ptr_sbr_dflt_header->interpol_freq = ptr_usac_dflt_header->interpol_freq;
738       ptr_sbr_dflt_header->smoothing_mode =
739           ptr_usac_dflt_header->smoothing_mode;
740     } else {
741       ptr_sbr_dflt_header->limiter_bands = SBR_LIMITER_BANDS_DEFAULT;
742       ptr_sbr_dflt_header->limiter_gains = SBR_LIMITER_GAINS_DEFAULT;
743       ptr_sbr_dflt_header->interpol_freq = SBR_INTERPOL_FREQ_DEFAULT;
744       ptr_sbr_dflt_header->smoothing_mode = SBR_SMOOTHING_LENGTH_DEFAULT;
745     }
746   }
747   return &(sbr_persistent_mem->str_sbr_dec_inst);
748 }
749 
ixheaacd_create_sbr_env_calc(ixheaacd_misc_tables * pstr_common_table,ia_sbr_calc_env_struct * hs,WORD16 chan,VOID * sbr_persistent_mem_v,ia_sbr_header_data_struct * ptr_header_data,WORD audio_object_type)750 static PLATFORM_INLINE WORD16 ixheaacd_create_sbr_env_calc(
751 
752     ixheaacd_misc_tables *pstr_common_table, ia_sbr_calc_env_struct *hs,
753     WORD16 chan, VOID *sbr_persistent_mem_v,
754     ia_sbr_header_data_struct *ptr_header_data, WORD audio_object_type) {
755   WORD16 err;
756   ia_sbr_pers_struct *sbr_persistent_mem =
757       (ia_sbr_pers_struct *)sbr_persistent_mem_v;
758 
759   err = 0;
760   memset(&hs->harm_flags_prev[0], 0, sizeof(WORD8) * MAX_FREQ_COEFFS);
761 
762   hs->harm_index = 0;
763 
764   hs->filt_buf_me = sbr_persistent_mem->sbr_smooth_gain_buf[chan];
765   hs->filt_buf_noise_m = sbr_persistent_mem->sbr_smooth_noise_buf[chan];
766   hs->tansient_env_prev = -1;
767 
768   ixheaacd_reset_sbrenvelope_calc(hs);
769 
770   if ((chan == 0) && (audio_object_type == AOT_ER_AAC_ELD)) {
771     err = ixheaacd_calc_frq_bnd_tbls(ptr_header_data, pstr_common_table);
772   }
773 
774   return err;
775 }
776 
ixheaacd_init_sbr_prev_framedata(ia_sbr_prev_frame_data_struct * ptr_prev_data,WORD16 time_slots)777 static PLATFORM_INLINE VOID ixheaacd_init_sbr_prev_framedata(
778     ia_sbr_prev_frame_data_struct *ptr_prev_data, WORD16 time_slots) {
779   WORD16 *psfb_nrg_prev = ptr_prev_data->sfb_nrg_prev;
780   WORD16 *psfb_noise_level = ptr_prev_data->prev_noise_level;
781   WORD32 *ppsbr_invf_mode = ptr_prev_data->sbr_invf_mode;
782 
783   memset(psfb_nrg_prev, 0, sizeof(WORD16) * (MAX_FREQ_COEFFS));
784   memset(psfb_noise_level, 0, sizeof(WORD16) * (MAX_NOISE_COEFFS));
785 
786   memset(ppsbr_invf_mode, 0, sizeof(WORD32) * MAX_INVF_BANDS);
787 
788   ptr_prev_data->end_position = time_slots;
789   ptr_prev_data->coupling_mode = COUPLING_OFF;
790   ptr_prev_data->amp_res = 0;
791   ptr_prev_data->max_qmf_subband_aac = 0;
792 }
793 
794 static PLATFORM_INLINE WORD32
ixheaacd_create_hyb_filterbank(ia_hybrid_struct * ptr_hybrid,WORD32 ** p_ptr,ia_sbr_tables_struct * sbr_tables_ptr)795 ixheaacd_create_hyb_filterbank(ia_hybrid_struct *ptr_hybrid, WORD32 **p_ptr,
796                                ia_sbr_tables_struct *sbr_tables_ptr) {
797   WORD16 i, ptr_step;
798   WORD32 *ptr = (WORD32 *)*p_ptr;
799 
800   ptr_hybrid->ptr_resol = sbr_tables_ptr->ps_tables_ptr->hyb_resol;
801   ptr_hybrid->ptr_qmf_buf = HYBRID_FILTER_LENGTH - 1;
802 
803   ptr_hybrid->ptr_temp_re = ptr;
804   ptr += NO_HYBRID_CHANNELS_HIGH;
805   ptr_hybrid->ptr_temp_im = ptr;
806   ptr += NO_HYBRID_CHANNELS_HIGH;
807 
808   memset(ptr_hybrid->ptr_temp_re, 0,
809          2 * NO_HYBRID_CHANNELS_HIGH * sizeof(WORD32));
810 
811   ptr_step = ixheaacd_add16(1, ptr_hybrid->ptr_qmf_buf);
812   ptr_hybrid->ptr_work_re = ptr;
813   ptr += 16;
814   ptr_hybrid->ptr_work_im = ptr;
815   ptr += 16;
816 
817   for (i = 0; i < NO_QMF_CHANNELS_IN_HYBRID; i++) {
818     ptr_hybrid->ptr_qmf_buf_re[i] = ptr;
819     ptr += ptr_hybrid->ptr_qmf_buf;
820 
821     ptr_hybrid->ptr_qmf_buf_im[i] = ptr;
822     ptr += ptr_hybrid->ptr_qmf_buf;
823 
824     memset(ptr_hybrid->ptr_qmf_buf_re[i], 0,
825            2 * ptr_hybrid->ptr_qmf_buf * sizeof(WORD32));
826   }
827 
828   *p_ptr = ptr;
829 
830   return 0;
831 }
832 
ixheaacd_create_hf_generator(ia_sbr_hf_generator_struct * ptr_hf_gen_str,WORD16 num_columns,WORD16 chan,VOID * sbr_persistent_mem_v,WORD32 ps_enable)833 static PLATFORM_INLINE WORD16 ixheaacd_create_hf_generator(
834     ia_sbr_hf_generator_struct *ptr_hf_gen_str, WORD16 num_columns, WORD16 chan,
835     VOID *sbr_persistent_mem_v, WORD32 ps_enable) {
836   WORD16 i;
837   ia_sbr_pers_struct *sbr_persistent_mem =
838       (ia_sbr_pers_struct *)sbr_persistent_mem_v;
839 
840   ptr_hf_gen_str->pstr_settings = &sbr_persistent_mem->str_sbr_tran_settings;
841 
842   ptr_hf_gen_str->lpc_filt_states_real[0] =
843       sbr_persistent_mem->sbr_lpc_filter_states_real[chan][0];
844   ptr_hf_gen_str->lpc_filt_states_real[1] =
845       sbr_persistent_mem->sbr_lpc_filter_states_real[chan][1];
846 
847   if (ps_enable) {
848     ptr_hf_gen_str->lpc_filt_states_imag[0] =
849         sbr_persistent_mem->sbr_lpc_filter_states_imag[chan][0];
850     ptr_hf_gen_str->lpc_filt_states_imag[1] =
851         sbr_persistent_mem->sbr_lpc_filter_states_imag[chan][1];
852   }
853 
854   for (i = 0; i < LPC_ORDER; i++) {
855     memset(ptr_hf_gen_str->lpc_filt_states_real[i], 0,
856            NO_ANALYSIS_CHANNELS * sizeof(WORD32));
857 
858     if (ps_enable)
859       memset(ptr_hf_gen_str->lpc_filt_states_imag[i], 0,
860              NO_ANALYSIS_CHANNELS * sizeof(WORD32));
861   }
862 
863   if (chan == 0) {
864     ptr_hf_gen_str->pstr_settings->num_columns = num_columns;
865   }
866   return 0;
867 }
868 
ixheaacd_create_psdec(ia_ps_dec_struct * ptr_ps_dec,VOID * sbr_persistent_mem_v,WORD32 * ptr_overlap_buf)869 WORD32 ixheaacd_create_psdec(ia_ps_dec_struct *ptr_ps_dec,
870                              VOID *sbr_persistent_mem_v,
871                              WORD32 *ptr_overlap_buf) {
872   ia_sbr_pers_struct *sbr_persistent_mem =
873       (ia_sbr_pers_struct *)sbr_persistent_mem_v;
874 
875   WORD16 *ptr1 = (WORD16 *)&(
876       sbr_persistent_mem->ptr_sbr_overlap_buf[MAXNRSBRCHANNELS - 1][0]);
877   WORD32 *ptr2 = (WORD32 *)&ptr_overlap_buf[512];
878   WORD16 *initial_ptr;
879   WORD16 delay;
880   WORD32 temp;
881 
882   ia_sbr_tables_struct *sbr_tables_ptr =
883       sbr_persistent_mem->str_sbr_dec_inst.pstr_sbr_tables;
884 
885   memset(ptr_ps_dec, 0, sizeof(ia_ps_dec_struct));
886 
887   ptr_ps_dec->ps_data_present = 0;
888   ptr_ps_dec->enable_iid = 0;
889   ptr_ps_dec->enable_icc = 0;
890   ptr_ps_dec->enable_ext = 0;
891   ptr_ps_dec->iid_mode = 0;
892   ptr_ps_dec->icc_mode = 0;
893 
894   ptr_ps_dec->ptr_hyb_left_re = ptr2;
895   ptr2 += 16;
896   ptr_ps_dec->ptr_hyb_left_im = ptr2;
897   ptr2 += 16;
898   ptr_ps_dec->ptr_hyb_right_re = ptr2;
899   ptr2 += 16;
900   ptr_ps_dec->ptr_hyb_right_im = ptr2;
901   ptr2 += 16;
902 
903   memset(ptr_ps_dec->ptr_hyb_left_re, 0, sizeof(WORD32) * 16 * 4);
904 
905   ixheaacd_create_hyb_filterbank(&ptr_ps_dec->str_hybrid, &ptr2,
906                                  sbr_tables_ptr);
907 
908   ptr_ps_dec->peak_decay_diff = ptr2;
909   ptr2 += NUM_OF_BINS;
910   ptr_ps_dec->energy_prev = ptr2;
911   ptr2 += NUM_OF_BINS;
912   ptr_ps_dec->peak_decay_diff_prev = ptr2;
913   ptr2 += NUM_OF_BINS;
914 
915   memset(ptr_ps_dec->peak_decay_diff, 0, 3 * sizeof(WORD32) * NUM_OF_BINS);
916 
917   ptr_ps_dec->delay_buf_idx = 0;
918   ptr_ps_dec->delay_buf_idx_long = 0;
919 
920   memset(ptr_ps_dec->delay_buf_qmf_sub_re_im, 0,
921          2 * 16 * DEL_ALL_PASS * sizeof(WORD16));
922   memset(ptr_ps_dec->delay_buf_qmf_sub_ser_re_im, 0,
923          2 * 16 * NUM_SER_AP_LINKS * 5 * sizeof(WORD16));
924 
925   initial_ptr = ptr1;
926   ptr_ps_dec->delay_buf_qmf_ser_re_im = (VOID *)ptr1;
927   ptr1 += 2 * NUM_SER_AP_LINKS * 32 * 5;
928 
929   delay = 2;
930   ptr_ps_dec->delay_buf_qmf_ap_re_im = (VOID *)ptr1;
931   ptr1 += 2 * delay * 32;
932 
933   delay = HIGH_DEL;
934   ptr_ps_dec->delay_buf_qmf_ld_re_im = (VOID *)ptr1;
935   ptr1 += 2 * delay * SMALL_DEL_STRT;
936 
937   delay = SMALL_DEL;
938   ptr_ps_dec->delay_buf_qmf_sd_re_im = (VOID *)ptr1;
939   ptr1 +=
940       2 * delay * (NUM_OF_QUAD_MIRROR_FILTER_ICC_CHNLS -
941                    (NUM_OF_QUAD_MIRROR_FILTER_ALL_PASS_CHNLS + SMALL_DEL_STRT));
942 
943   temp = ptr1 - initial_ptr;
944   memset(ptr_ps_dec->delay_buf_qmf_ser_re_im, 0, temp * sizeof(WORD16));
945 
946   memset(ptr_ps_dec->delay_buf_idx_ser, 0, NUM_SER_AP_LINKS * sizeof(WORD16));
947   memcpy(ptr_ps_dec->delay_sample_ser,
948          sbr_tables_ptr->ps_tables_ptr->rev_link_delay_ser,
949          NUM_SER_AP_LINKS * sizeof(WORD16));
950 
951   memset(ptr_ps_dec->h11_h12_vec, 0xff,
952          (NO_IID_GROUPS + 2) * 2 * sizeof(WORD16));
953   memset(ptr_ps_dec->h21_h22_vec, 0, sizeof(ptr_ps_dec->h21_h22_vec));
954 
955   return 0;
956 }
957 
ixheaacd_create_cplx_anal_qmfbank(ia_sbr_qmf_filter_bank_struct * ptr_sbr_qmf,ia_sbr_scale_fact_struct * sbr_scale_factor,WORD16 no_bins,WORD16 usb,WORD16 chan,WORD16 * sbr_qmf_analy_states,WORD32 * sbr_qmf_analy_states_32,ia_qmf_dec_tables_struct * qmf_dec_tables_ptr,WORD32 audio_object_type)958 static PLATFORM_INLINE WORD32 ixheaacd_create_cplx_anal_qmfbank(
959     ia_sbr_qmf_filter_bank_struct *ptr_sbr_qmf,
960     ia_sbr_scale_fact_struct *sbr_scale_factor, WORD16 no_bins, WORD16 usb,
961     WORD16 chan, WORD16 *sbr_qmf_analy_states, WORD32 *sbr_qmf_analy_states_32,
962     ia_qmf_dec_tables_struct *qmf_dec_tables_ptr, WORD32 audio_object_type) {
963   memset(ptr_sbr_qmf, 0, sizeof(ia_sbr_qmf_filter_bank_struct));
964 
965   if (audio_object_type != AOT_ER_AAC_ELD &&
966       audio_object_type != AOT_ER_AAC_LD) {
967     ptr_sbr_qmf->analy_win_coeff = qmf_dec_tables_ptr->qmf_c;
968   } else {
969     ptr_sbr_qmf->analy_win_coeff = qmf_dec_tables_ptr->qmf_c_eld3;
970   }
971 
972   ptr_sbr_qmf->analy_win_coeff_32 = qmf_dec_tables_ptr->esbr_qmf_c;
973 
974   ptr_sbr_qmf->no_channels = NO_ANALYSIS_CHANNELS;
975   ptr_sbr_qmf->num_time_slots = no_bins;
976 
977   ptr_sbr_qmf->lsb = 0;
978   ptr_sbr_qmf->usb = usb;
979 
980   ptr_sbr_qmf->anal_filter_states =
981       &(sbr_qmf_analy_states[chan ? QMF_FILTER_STATE_ANA_SIZE : 0]);
982 
983   memset(ptr_sbr_qmf->anal_filter_states, 0,
984          sizeof(WORD16) * QMF_FILTER_STATE_ANA_SIZE);
985 
986   ptr_sbr_qmf->anal_filter_states_32 =
987       &(sbr_qmf_analy_states_32[chan ? QMF_FILTER_STATE_ANA_SIZE : 0]);
988 
989   memset(ptr_sbr_qmf->anal_filter_states_32, 0,
990          sizeof(WORD32) * QMF_FILTER_STATE_ANA_SIZE);
991 
992   ptr_sbr_qmf->core_samples_buffer = ptr_sbr_qmf->anal_filter_states;
993 
994   ptr_sbr_qmf->state_new_samples_pos_low_32 =
995       ptr_sbr_qmf->anal_filter_states_32;
996   if (audio_object_type != AOT_ER_AAC_ELD &&
997       audio_object_type != AOT_ER_AAC_LD) {
998     ptr_sbr_qmf->filter_pos = (WORD16 *)qmf_dec_tables_ptr->qmf_c;
999   } else {
1000     ptr_sbr_qmf->filter_pos = (WORD16 *)qmf_dec_tables_ptr->qmf_c_eld3;
1001   }
1002 
1003   ptr_sbr_qmf->filter_pos_32 = (WORD32 *)qmf_dec_tables_ptr->esbr_qmf_c;
1004 
1005   sbr_scale_factor->st_lb_scale = 0;
1006 
1007   sbr_scale_factor->st_syn_scale = -6;
1008 
1009   if (audio_object_type == AOT_ER_AAC_ELD ||
1010       audio_object_type == AOT_ER_AAC_LD) {
1011     ptr_sbr_qmf->filter_2 = ptr_sbr_qmf->filter_pos + 32;
1012     ptr_sbr_qmf->fp1_anal = ptr_sbr_qmf->anal_filter_states;
1013     ptr_sbr_qmf->fp2_anal =
1014         ptr_sbr_qmf->anal_filter_states + NO_ANALYSIS_CHANNELS;
1015   }
1016 
1017   return 0;
1018 }
1019 
ixheaacd_create_cplx_synt_qmfbank(ia_sbr_qmf_filter_bank_struct * ptr_sbr_qmf,WORD16 no_bins,WORD16 lsb,WORD16 usb,WORD16 chan,FLAG down_sample_flag,WORD16 * sbr_qmf_synth_states,WORD32 * sbr_qmf_synth_states_32,ia_qmf_dec_tables_struct * qmf_dec_tables_ptr,WORD32 audio_object_type)1020 static PLATFORM_INLINE WORD32 ixheaacd_create_cplx_synt_qmfbank(
1021     ia_sbr_qmf_filter_bank_struct *ptr_sbr_qmf, WORD16 no_bins, WORD16 lsb,
1022     WORD16 usb, WORD16 chan, FLAG down_sample_flag,
1023     WORD16 *sbr_qmf_synth_states, WORD32 *sbr_qmf_synth_states_32,
1024     ia_qmf_dec_tables_struct *qmf_dec_tables_ptr, WORD32 audio_object_type) {
1025   WORD32 L;
1026 
1027   WORD32 qmf_filter_state_size;
1028 
1029   memset(ptr_sbr_qmf, 0, sizeof(ia_sbr_qmf_filter_bank_struct));
1030   qmf_filter_state_size = QMF_FILTER_STATE_SYN_SIZE;
1031 
1032   if (down_sample_flag) {
1033     L = NO_SYNTHESIS_CHANNELS_DOWN_SAMPLED;
1034     ptr_sbr_qmf->usb = NO_SYNTHESIS_CHANNELS_DOWN_SAMPLED;
1035   } else {
1036     L = NO_SYNTHESIS_CHANNELS;
1037     ptr_sbr_qmf->usb = usb;
1038   }
1039 
1040   ptr_sbr_qmf->ixheaacd_drc_offset = 0;
1041   if (audio_object_type != AOT_ER_AAC_ELD &&
1042       audio_object_type != AOT_ER_AAC_LD) {
1043     ptr_sbr_qmf->filter_pos_syn = (WORD16 *)qmf_dec_tables_ptr->qmf_c;
1044     ptr_sbr_qmf->p_filter = qmf_dec_tables_ptr->qmf_c;
1045   } else {
1046     ptr_sbr_qmf->filter_pos_syn = (WORD16 *)qmf_dec_tables_ptr->qmf_c_eld;
1047     ptr_sbr_qmf->p_filter = qmf_dec_tables_ptr->qmf_c_eld;
1048   }
1049 
1050   ptr_sbr_qmf->filter_pos_syn_32 = (WORD32 *)qmf_dec_tables_ptr->esbr_qmf_c;
1051   ptr_sbr_qmf->p_filter_32 = qmf_dec_tables_ptr->esbr_qmf_c;
1052 
1053   ptr_sbr_qmf->no_channels = L;
1054   ptr_sbr_qmf->qmf_filter_state_size = qmf_filter_state_size;
1055   ptr_sbr_qmf->num_time_slots = no_bins;
1056   ptr_sbr_qmf->lsb = lsb;
1057 
1058   ptr_sbr_qmf->filter_states =
1059       &sbr_qmf_synth_states[chan ? qmf_filter_state_size : 0];
1060 
1061   memset(ptr_sbr_qmf->filter_states, 0, sizeof(WORD16) * qmf_filter_state_size);
1062 
1063   ptr_sbr_qmf->filter_states_32 =
1064       &sbr_qmf_synth_states_32[chan ? qmf_filter_state_size : 0];
1065 
1066   memset(ptr_sbr_qmf->filter_states_32, 0,
1067          sizeof(WORD32) * qmf_filter_state_size);
1068 
1069   if (audio_object_type == AOT_ER_AAC_ELD ||
1070       audio_object_type == AOT_ER_AAC_LD) {
1071     ptr_sbr_qmf->fp1_syn = ptr_sbr_qmf->filter_states;
1072     ptr_sbr_qmf->fp2_syn =
1073         ptr_sbr_qmf->filter_states + ptr_sbr_qmf->no_channels;
1074     ptr_sbr_qmf->sixty4 = NO_SYNTHESIS_CHANNELS;
1075   }
1076 
1077   return 0;
1078 }
1079 
ixheaacd_create_sbrdec(ixheaacd_misc_tables * pstr_common_table,ia_sbr_channel_struct * ptr_sbr_channel,ia_sbr_header_data_struct * ptr_header_data,WORD16 chan,FLAG down_sample_flag,VOID * sbr_persistent_mem_v,WORD ps_enable,WORD audio_object_type)1080 WORD16 ixheaacd_create_sbrdec(ixheaacd_misc_tables *pstr_common_table,
1081                               ia_sbr_channel_struct *ptr_sbr_channel,
1082                               ia_sbr_header_data_struct *ptr_header_data,
1083                               WORD16 chan, FLAG down_sample_flag,
1084                               VOID *sbr_persistent_mem_v, WORD ps_enable,
1085                               WORD audio_object_type)
1086 
1087 {
1088   WORD16 err;
1089   WORD16 time_slots;
1090   WORD16 no_bins;
1091   ia_sbr_pers_struct *sbr_persistent_mem =
1092       (ia_sbr_pers_struct *)sbr_persistent_mem_v;
1093   ia_sbr_dec_struct *hs = &(ptr_sbr_channel->str_sbr_dec);
1094 
1095   time_slots = ptr_header_data->num_time_slots;
1096 
1097   no_bins = (WORD16)(time_slots * ptr_header_data->time_step);
1098 
1099   hs->str_sbr_scale_fact.ov_lb_scale = INT_BITS - 1;
1100   hs->str_sbr_scale_fact.hb_scale = INT_BITS - 1;
1101   hs->str_sbr_scale_fact.ov_hb_scale = INT_BITS - 1;
1102   hs->str_sbr_scale_fact.st_syn_scale = INT_BITS - 1;
1103 
1104   ptr_sbr_channel->pstr_prev_frame_data =
1105       sbr_persistent_mem->pstr_prev_frame_data[chan];
1106 
1107   err = ixheaacd_create_sbr_env_calc(pstr_common_table, &hs->str_sbr_calc_env,
1108                                      chan, sbr_persistent_mem, ptr_header_data,
1109                                      audio_object_type);
1110 
1111   if (err) {
1112     return (-1);
1113   }
1114 
1115   ixheaacd_create_cplx_anal_qmfbank(
1116       &hs->str_codec_qmf_bank, &hs->str_sbr_scale_fact, no_bins,
1117       ptr_header_data->pstr_freq_band_data->sub_band_start, chan,
1118       sbr_persistent_mem->sbr_qmf_analy_states,
1119       sbr_persistent_mem->sbr_qmf_analy_states_32,
1120       sbr_persistent_mem->str_sbr_dec_inst.pstr_sbr_tables->qmf_dec_tables_ptr,
1121       audio_object_type);
1122 
1123   ixheaacd_create_cplx_synt_qmfbank(
1124       &hs->str_synthesis_qmf_bank, no_bins,
1125       ptr_header_data->pstr_freq_band_data->sub_band_start,
1126       ptr_header_data->pstr_freq_band_data->sub_band_end, chan,
1127       down_sample_flag, sbr_persistent_mem->sbr_qmf_synth_states,
1128       sbr_persistent_mem->sbr_qmf_synth_states_32,
1129       sbr_persistent_mem->str_sbr_dec_inst.pstr_sbr_tables->qmf_dec_tables_ptr,
1130       audio_object_type);
1131 
1132   ixheaacd_init_sbr_prev_framedata(ptr_sbr_channel->pstr_prev_frame_data,
1133                                    time_slots);
1134 
1135   err = ixheaacd_create_hf_generator(&hs->str_hf_generator,
1136                                      hs->str_codec_qmf_bank.num_time_slots,
1137                                      chan, sbr_persistent_mem, ps_enable);
1138 
1139   if (err) {
1140     return (-1);
1141   }
1142 
1143   hs->ptr_sbr_overlap_buf = sbr_persistent_mem->ptr_sbr_overlap_buf[chan];
1144 
1145   return 0;
1146 }
1147