Coverage Report

Created: 2025-10-27 06:23

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/libxaac/decoder/ixheaacd_block.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 <stdlib.h>
21
#include "ixheaacd_sbr_common.h"
22
#include "ixheaac_type_def.h"
23
24
#include "ixheaac_constants.h"
25
#include "ixheaac_basic_ops32.h"
26
#include "ixheaac_basic_ops16.h"
27
#include "ixheaac_basic_ops40.h"
28
#include "ixheaac_basic_ops.h"
29
#include "ixheaacd_common_rom.h"
30
#include "ixheaacd_basic_funcs.h"
31
#include "ixheaacd_defines.h"
32
#include "ixheaacd_aac_rom.h"
33
#include "ixheaacd_bitbuffer.h"
34
#include "ixheaacd_intrinsics.h"
35
#include "ixheaacd_pulsedata.h"
36
37
#include "ixheaacd_pns.h"
38
#include "ixheaacd_drc_data_struct.h"
39
40
#include "ixheaacd_lt_predict.h"
41
42
#include "ixheaacd_cnst.h"
43
#include "ixheaacd_ec_defines.h"
44
#include "ixheaacd_ec_struct_def.h"
45
#include "ixheaacd_channelinfo.h"
46
#include "ixheaacd_drc_dec.h"
47
48
#include "ixheaacd_block.h"
49
#include "ixheaacd_channel.h"
50
51
#include "ixheaac_basic_op.h"
52
53
#include "ixheaacd_tns.h"
54
#include "ixheaacd_sbrdecoder.h"
55
#include "ixheaacd_error_codes.h"
56
57
#include "ixheaacd_audioobjtypes.h"
58
#include "ixheaacd_latmdemux.h"
59
60
#include "ixheaacd_aacdec.h"
61
62
static PLATFORM_INLINE WORD32 ixheaacd_mac32x16in32_sat(WORD32 a, WORD32 b,
63
43.1M
                                                        WORD16 c) {
64
43.1M
  WORD32 acc;
65
66
43.1M
  acc = ixheaac_mult32x16in32_sat(b, c);
67
68
43.1M
  acc = ixheaac_add32_sat(a, acc);
69
70
43.1M
  return acc;
71
43.1M
}
72
73
WORD32 ixheaacd_cnt_leading_ones(WORD32 a);
74
75
VOID ixheaacd_huff_sfb_table(WORD32 it_bit_buff, WORD16 *huff_index,
76
                             WORD32 *len, const UWORD16 *code_book_tbl,
77
4.92M
                             const UWORD32 *idx_table) {
78
4.92M
  UWORD32 temp = 0;
79
4.92M
  UWORD32 temp1 = 0;
80
4.92M
  WORD32 found = 0;
81
4.92M
  UWORD32 mask = 0x80000000;
82
83
4.92M
  WORD32 leading_ones;
84
4.92M
  WORD32 max_len;
85
4.92M
  WORD32 ixheaacd_drc_offset = 0;
86
4.92M
  WORD32 length;
87
4.92M
  UWORD32 code_word;
88
4.92M
  WORD32 len_end;
89
90
4.92M
  max_len = code_book_tbl[0];
91
4.92M
  mask = mask - (1 << (31 - max_len));
92
4.92M
  mask = mask << 1;
93
94
4.92M
  temp = (UWORD32)((it_bit_buff & mask));
95
96
4.92M
  len_end = code_book_tbl[0];
97
4.92M
  leading_ones = ixheaacd_cnt_leading_ones(temp);
98
7.86M
  do {
99
7.86M
    ixheaacd_drc_offset = (idx_table[leading_ones] >> 20) & 0x1ff;
100
7.86M
    length = code_book_tbl[ixheaacd_drc_offset + 1] & 0x1f;
101
7.86M
    code_word = idx_table[leading_ones] & 0xfffff;
102
7.86M
    temp1 = temp >> (32 - length);
103
7.86M
    if (temp1 <= code_word) {
104
4.92M
      ixheaacd_drc_offset = ixheaacd_drc_offset - (code_word - temp1);
105
4.92M
      found = 1;
106
4.92M
    } else {
107
2.93M
      len_end = len_end + ((idx_table[leading_ones] >> 29) & 0x7);
108
2.93M
      leading_ones = len_end;
109
2.93M
    }
110
7.86M
  } while (!found);
111
4.92M
  *huff_index = code_book_tbl[ixheaacd_drc_offset + 1] >> 5;
112
4.92M
  *len = length;
113
4.92M
}
114
115
VOID ixheaacd_inverse_quantize(WORD32 *x_invquant, WORD no_band,
116
                               WORD32 *ixheaacd_pow_table_Q13,
117
22.5k
                               WORD8 *scratch_in) {
118
22.5k
  WORD32 j;
119
22.5k
  WORD32 temp;
120
22.5k
  WORD32 q_abs;
121
122
1.63M
  for (j = no_band - 1; j >= 0; j--) {
123
1.61M
    q_abs = *scratch_in++;
124
1.61M
    temp = (ixheaacd_pow_table_Q13[q_abs]);
125
1.61M
    *x_invquant++ = -temp;
126
1.61M
  }
127
22.5k
}
128
129
static PLATFORM_INLINE WORD ixheaacd_huffman_dec_word1(
130
    ia_bit_buf_struct *it_bit_buff, WORD32 *spec_coef, WORD16 *offsets,
131
    WORD no_bands, WORD group_len, const UWORD16 *code_book_tbl,
132
58.0k
    WORD32 *ixheaacd_pow_table_Q13, const UWORD32 *idx_table, WORD32 maximum_bins_short) {
133
58.0k
  WORD32 sp1, sp2;
134
58.0k
  WORD32 flush_cw;
135
58.0k
  WORD32 i, value, norm_val, off;
136
58.0k
  WORD idx, grp_idx;
137
58.0k
  WORD32 out1, out2;
138
58.0k
  WORD32 err_code = 0;
139
58.0k
  WORD len_idx = 0;
140
58.0k
  UWORD8 *ptr_read_next = it_bit_buff->ptr_read_next;
141
58.0k
  WORD32 bit_pos = it_bit_buff->bit_pos;
142
58.0k
  WORD16 index;
143
58.0k
  WORD32 length;
144
58.0k
  WORD32 read_word;
145
58.0k
  WORD32 increment;
146
147
58.0k
  read_word = ixheaacd_aac_showbits_32(ptr_read_next, it_bit_buff->cnt_bits,
148
58.0k
                                       &increment);
149
58.0k
  ptr_read_next += increment;
150
151
60.4k
  do {
152
60.4k
    len_idx = offsets[1] - offsets[0];
153
60.4k
    grp_idx = group_len;
154
155
130k
    do {
156
130k
      spec_coef = spec_coef + offsets[0];
157
130k
      idx = len_idx;
158
493k
      do {
159
493k
        {
160
493k
          UWORD32 read_word1;
161
162
493k
          read_word1 = read_word << bit_pos;
163
493k
          ixheaacd_huff_sfb_table(read_word1, &index, &length, code_book_tbl,
164
493k
                                  idx_table);
165
493k
          bit_pos += length;
166
493k
          ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
167
493k
                                      it_bit_buff->ptr_bit_buf_end);
168
493k
        }
169
170
493k
        out1 = index / 17;
171
493k
        out2 = index - out1 * 17;
172
493k
        flush_cw = read_word << bit_pos;
173
174
493k
        sp1 = out1;
175
493k
        sp2 = out2;
176
177
493k
        if (out1) {
178
259k
          if (flush_cw & 0x80000000) {
179
184k
            out1 = -out1;
180
184k
          }
181
259k
          bit_pos++;
182
259k
          flush_cw = (WORD32)flush_cw << 1;
183
259k
        }
184
185
493k
        if (out2) {
186
250k
          bit_pos++;
187
250k
          if (flush_cw & 0x80000000) {
188
145k
            out2 = -out2;
189
145k
          }
190
250k
        }
191
493k
        ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
192
493k
                                    it_bit_buff->ptr_bit_buf_end);
193
194
493k
        if (sp1 == 16) {
195
20.4k
          i = 4;
196
20.4k
          value = ixheaac_extu(read_word, bit_pos, 23);
197
20.4k
          value = value | 0xfffffe00;
198
20.4k
          norm_val = ixheaac_norm32(value);
199
200
20.4k
          i += (norm_val - 22);
201
20.4k
          bit_pos += (norm_val - 21);
202
20.4k
          ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
203
20.4k
                                      it_bit_buff->ptr_bit_buf_end);
204
205
20.4k
          off = ixheaac_extu(read_word, bit_pos, 32 - i);
206
207
20.4k
          bit_pos += i;
208
209
20.4k
          ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
210
20.4k
                                      it_bit_buff->ptr_bit_buf_end);
211
20.4k
          ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
212
20.4k
                                      it_bit_buff->ptr_bit_buf_end);
213
214
20.4k
          i = off + ((WORD32)1 << i);
215
216
20.4k
          if (i <= IQ_TABLE_SIZE_HALF)
217
17.8k
            i = ixheaacd_pow_table_Q13[i];
218
2.56k
          else {
219
2.56k
            err_code |= ixheaacd_inv_quant(&i, ixheaacd_pow_table_Q13);
220
2.56k
          }
221
222
20.4k
          if (out1 < 0) {
223
7.32k
            out1 = -i;
224
13.0k
          } else {
225
13.0k
            out1 = i;
226
13.0k
          }
227
20.4k
          *spec_coef++ = out1;
228
472k
        } else {
229
472k
          if (out1 <= 0) {
230
410k
            out1 = -out1;
231
410k
            out1 = ixheaacd_pow_table_Q13[out1];
232
410k
            *spec_coef++ = -out1;
233
410k
          } else {
234
62.2k
            out1 = ixheaacd_pow_table_Q13[out1];
235
62.2k
            *spec_coef++ = out1;
236
62.2k
          }
237
472k
        }
238
239
493k
        if (sp2 == 16) {
240
16.0k
          i = 4;
241
16.0k
          value = ixheaac_extu(read_word, bit_pos, 23);
242
16.0k
          value = value | 0xfffffe00;
243
16.0k
          norm_val = ixheaac_norm32(value);
244
245
16.0k
          i += (norm_val - 22);
246
247
16.0k
          bit_pos += (norm_val - 21);
248
16.0k
          ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
249
16.0k
                                      it_bit_buff->ptr_bit_buf_end);
250
251
16.0k
          off = ixheaac_extu(read_word, bit_pos, 32 - i);
252
253
16.0k
          bit_pos += i;
254
255
16.0k
          ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
256
16.0k
                                      it_bit_buff->ptr_bit_buf_end);
257
16.0k
          ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
258
16.0k
                                      it_bit_buff->ptr_bit_buf_end);
259
260
16.0k
          i = off + ((WORD32)1 << i);
261
262
16.0k
          if (i <= IQ_TABLE_SIZE_HALF)
263
14.6k
            i = ixheaacd_pow_table_Q13[i];
264
1.37k
          else {
265
1.37k
            err_code |= ixheaacd_inv_quant(&i, ixheaacd_pow_table_Q13);
266
1.37k
          }
267
268
16.0k
          if (out2 < 0) {
269
3.20k
            out2 = -i;
270
12.8k
          } else {
271
12.8k
            out2 = i;
272
12.8k
          }
273
16.0k
          *spec_coef++ = out2;
274
477k
        } else {
275
477k
          if (out2 <= 0) {
276
384k
            out2 = -out2;
277
384k
            out2 = ixheaacd_pow_table_Q13[out2];
278
384k
            *spec_coef++ = -out2;
279
384k
          } else {
280
92.7k
            out2 = ixheaacd_pow_table_Q13[out2];
281
92.7k
            *spec_coef++ = out2;
282
92.7k
          }
283
477k
        }
284
285
493k
        idx -= 2;
286
493k
      } while (idx != 0);
287
288
130k
      if (maximum_bins_short == 120) {
289
115k
        spec_coef += (maximum_bins_short - offsets[1]);
290
115k
      } else {
291
15.3k
        spec_coef += (MAX_BINS_SHORT - offsets[1]);
292
15.3k
      }
293
294
130k
      grp_idx--;
295
130k
    } while (grp_idx != 0);
296
297
60.4k
    offsets++;
298
299
60.4k
    if (maximum_bins_short == 120) {
300
53.9k
      spec_coef -= (maximum_bins_short * group_len);
301
53.9k
    } else {
302
6.48k
      spec_coef -= (MAX_BINS_SHORT * group_len);
303
6.48k
    }
304
305
60.4k
    no_bands--;
306
60.4k
  } while (no_bands >= 0);
307
308
58.0k
  ptr_read_next = ptr_read_next - increment;
309
58.0k
  ixheaacd_aac_read_byte_corr1(&ptr_read_next, &bit_pos, &read_word,
310
58.0k
                               it_bit_buff->ptr_bit_buf_end);
311
312
58.0k
  it_bit_buff->bit_pos = bit_pos;
313
58.0k
  it_bit_buff->ptr_read_next = ptr_read_next;
314
315
58.0k
  return err_code;
316
58.0k
}
317
318
static PLATFORM_INLINE WORD ixheaacd_huffman_dec_word2_11(
319
    ia_bit_buf_struct *it_bit_buff, WORD32 width, const UWORD16 *code_book_tbl,
320
    WORD32 *x_invquant, WORD32 *ixheaacd_pow_table_Q13, WORD8 *ptr_scratch,
321
76.4k
    const UWORD32 *idx_table) {
322
76.4k
  WORD32 sp1, sp2;
323
76.4k
  WORD32 flush_cw;
324
76.4k
  WORD32 i, value, norm_val, off;
325
76.4k
  WORD idx;
326
76.4k
  WORD32 out1, out2;
327
76.4k
  WORD32 err_code = 0;
328
76.4k
  WORD16 index;
329
76.4k
  WORD32 length;
330
76.4k
  UWORD8 *ptr_read_next = it_bit_buff->ptr_read_next;
331
76.4k
  WORD32 bit_pos = it_bit_buff->bit_pos;
332
76.4k
  WORD32 read_word;
333
76.4k
  WORD32 increment;
334
335
76.4k
  read_word = ixheaacd_aac_showbits_32(ptr_read_next, it_bit_buff->cnt_bits,
336
76.4k
                                       &increment);
337
76.4k
  ptr_read_next += increment;
338
339
1.87M
  for (idx = width; idx != 0; idx -= 2) {
340
1.79M
    {
341
1.79M
      UWORD32 read_word1;
342
343
1.79M
      read_word1 = read_word << bit_pos;
344
1.79M
      ixheaacd_huff_sfb_table(read_word1, &index, &length, code_book_tbl,
345
1.79M
                              idx_table);
346
1.79M
      bit_pos += length;
347
1.79M
      ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
348
1.79M
                                  it_bit_buff->ptr_bit_buf_end);
349
1.79M
    }
350
351
1.79M
    flush_cw = read_word << bit_pos;
352
1.79M
    out1 = index / 17;
353
1.79M
    out2 = index - out1 * 17;
354
1.79M
    sp1 = out1;
355
356
1.79M
    if (out1) {
357
1.00M
      if (flush_cw & 0x80000000) {
358
633k
        out1 = -out1;
359
633k
      }
360
361
1.00M
      bit_pos++;
362
1.00M
      flush_cw = (WORD32)flush_cw << 1;
363
1.00M
    }
364
365
1.79M
    sp2 = out2;
366
1.79M
    if (out2) {
367
994k
      bit_pos++;
368
994k
      if (flush_cw & 0x80000000) {
369
466k
        out2 = -out2;
370
466k
      }
371
994k
    }
372
373
1.79M
    ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
374
1.79M
                                it_bit_buff->ptr_bit_buf_end);
375
376
1.79M
    if (sp1 == 16) {
377
85.7k
      i = 4;
378
85.7k
      value = ixheaac_extu(read_word, bit_pos, 23);
379
85.7k
      value = value | 0xfffffe00;
380
85.7k
      norm_val = ixheaac_norm32(value);
381
85.7k
      i += (norm_val - 22);
382
85.7k
      bit_pos += (norm_val - 21);
383
384
85.7k
      ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
385
85.7k
                                  it_bit_buff->ptr_bit_buf_end);
386
387
85.7k
      off = ixheaac_extu(read_word, bit_pos, 32 - i);
388
389
85.7k
      bit_pos += i;
390
85.7k
      ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
391
85.7k
                                  it_bit_buff->ptr_bit_buf_end);
392
393
85.7k
      value = *ptr_scratch++;
394
395
85.7k
      ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
396
85.7k
                                  it_bit_buff->ptr_bit_buf_end);
397
85.7k
      i = off + ((WORD32)1 << i);
398
85.7k
      i += value;
399
400
85.7k
      if (i <= IQ_TABLE_SIZE_HALF)
401
81.1k
        i = ixheaacd_pow_table_Q13[i];
402
4.58k
      else {
403
4.58k
        err_code |= ixheaacd_inv_quant(&i, ixheaacd_pow_table_Q13);
404
4.58k
      }
405
85.7k
      if (out1 < 0) {
406
38.1k
        i = -i;
407
38.1k
      }
408
85.7k
      *x_invquant++ = i;
409
1.70M
    } else {
410
1.70M
      WORD8 temp = *ptr_scratch++;
411
1.70M
      if (out1 <= 0) {
412
1.38M
        out1 = temp - out1;
413
1.38M
        out1 = ixheaacd_pow_table_Q13[out1];
414
1.38M
        *x_invquant++ = -out1;
415
1.38M
      } else {
416
321k
        out1 += temp;
417
321k
        out1 = ixheaacd_pow_table_Q13[out1];
418
321k
        *x_invquant++ = out1;
419
321k
      }
420
1.70M
    }
421
422
1.79M
    if (sp2 == 16) {
423
84.9k
      i = 4;
424
84.9k
      value = ixheaac_extu(read_word, bit_pos, 23);
425
84.9k
      value = value | 0xfffffe00;
426
84.9k
      norm_val = ixheaac_norm32(value);
427
428
84.9k
      i += (norm_val - 22);
429
430
84.9k
      bit_pos += (norm_val - 21);
431
84.9k
      ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
432
84.9k
                                  it_bit_buff->ptr_bit_buf_end);
433
434
84.9k
      off = ixheaac_extu(read_word, bit_pos, 32 - i);
435
436
84.9k
      bit_pos += i;
437
84.9k
      ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
438
84.9k
                                  it_bit_buff->ptr_bit_buf_end);
439
84.9k
      value = *ptr_scratch++;
440
84.9k
      ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
441
84.9k
                                  it_bit_buff->ptr_bit_buf_end);
442
443
84.9k
      i = off + ((WORD32)1 << i);
444
84.9k
      i += value;
445
84.9k
      if (i <= IQ_TABLE_SIZE_HALF)
446
78.6k
        i = ixheaacd_pow_table_Q13[i];
447
6.23k
      else {
448
6.23k
        err_code |= ixheaacd_inv_quant(&i, ixheaacd_pow_table_Q13);
449
6.23k
      }
450
451
84.9k
      if (out2 < 0) {
452
23.6k
        i = -i;
453
23.6k
      }
454
84.9k
      *x_invquant++ = i;
455
456
1.70M
    } else {
457
1.70M
      WORD8 temp = *ptr_scratch++;
458
1.70M
      if (out2 <= 0) {
459
1.24M
        out2 = temp - out2;
460
1.24M
        out2 = ixheaacd_pow_table_Q13[out2];
461
1.24M
        *x_invquant++ = -out2;
462
1.24M
      } else {
463
466k
        out2 += temp;
464
466k
        out2 = ixheaacd_pow_table_Q13[out2];
465
466k
        *x_invquant++ = out2;
466
466k
      }
467
1.70M
    }
468
1.79M
  }
469
76.4k
  ptr_read_next = ptr_read_next - increment;
470
76.4k
  ixheaacd_aac_read_byte_corr1(&ptr_read_next, &bit_pos, &read_word,
471
76.4k
                               it_bit_buff->ptr_bit_buf_end);
472
473
76.4k
  it_bit_buff->ptr_read_next = ptr_read_next;
474
76.4k
  it_bit_buff->bit_pos = bit_pos;
475
476
76.4k
  return err_code;
477
76.4k
}
478
479
static PLATFORM_INLINE WORD ixheaacd_huffman_dec_quad(
480
    ia_bit_buf_struct *it_bit_buff, WORD32 *spec_coef, WORD16 *offsets,
481
    WORD no_bands, WORD group_len, const UWORD16 *code_book_tbl,
482
    WORD32 *ixheaacd_pow_table_Q13, WORD32 tbl_sign, const UWORD32 *idx_table,
483
6.17k
    WORD32 maximum_bins_short) {
484
6.17k
  WORD idx, grp_idx;
485
6.17k
  WORD idx_len;
486
6.17k
  WORD32 *spec_orig;
487
6.17k
  WORD16 index, length;
488
6.17k
  UWORD8 *ptr_read_next = it_bit_buff->ptr_read_next;
489
6.17k
  WORD32 bit_pos = it_bit_buff->bit_pos;
490
6.17k
  WORD32 read_word;
491
6.17k
  WORD32 increment;
492
493
6.17k
  read_word = ixheaacd_aac_showbits_32(ptr_read_next, it_bit_buff->cnt_bits,
494
6.17k
                                       &increment);
495
6.17k
  ptr_read_next += increment;
496
6.17k
  spec_orig = spec_coef;
497
26.0k
  do {
498
26.0k
    idx_len = offsets[1] - offsets[0];
499
26.0k
    grp_idx = group_len;
500
501
40.1k
    do {
502
40.1k
      spec_coef = spec_coef + offsets[0];
503
40.1k
      idx = idx_len;
504
66.3k
      do {
505
66.3k
        UWORD32 read_word1;
506
507
66.3k
        read_word1 = read_word << bit_pos;
508
66.3k
        ixheaacd_huffman_decode(read_word1, &index, &length, code_book_tbl,
509
66.3k
                                idx_table);
510
66.3k
        bit_pos += length;
511
66.3k
        ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
512
66.3k
                                    it_bit_buff->ptr_bit_buf_end);
513
66.3k
        if (tbl_sign) {
514
26.6k
          WORD32 temp_word;
515
26.6k
          WORD32 w, x, y, z;
516
26.6k
          temp_word = read_word << bit_pos;
517
26.6k
          w = index / 27;
518
26.6k
          index = index - w * 27;
519
26.6k
          x = index / 9;
520
26.6k
          index = index - x * 9;
521
26.6k
          y = index / 3;
522
26.6k
          z = index - y * 3;
523
26.6k
          if (w) {
524
18.9k
            w = ixheaacd_pow_table_Q13[w];
525
18.9k
            if (temp_word & 0x80000000) w = -w;
526
18.9k
            temp_word <<= 1;
527
18.9k
            bit_pos++;
528
18.9k
          }
529
26.6k
          *spec_coef++ = w;
530
531
26.6k
          if (x) {
532
19.2k
            x = ixheaacd_pow_table_Q13[x];
533
19.2k
            if (temp_word & 0x80000000) x = -x;
534
19.2k
            temp_word <<= 1;
535
19.2k
            bit_pos++;
536
19.2k
          }
537
26.6k
          *spec_coef++ = x;
538
26.6k
          if (y) {
539
20.0k
            y = ixheaacd_pow_table_Q13[y];
540
20.0k
            if (temp_word & 0x80000000) y = -y;
541
20.0k
            temp_word <<= 1;
542
20.0k
            bit_pos++;
543
20.0k
          }
544
26.6k
          *spec_coef++ = y;
545
26.6k
          if (z) {
546
20.1k
            z = ixheaacd_pow_table_Q13[z];
547
20.1k
            if (temp_word & 0x80000000) z = -z;
548
20.1k
            temp_word <<= 1;
549
20.1k
            bit_pos++;
550
20.1k
          }
551
26.6k
          *spec_coef++ = z;
552
553
26.6k
        }
554
555
39.7k
        else {
556
39.7k
          WORD32 w, x, y, z;
557
558
39.7k
          w = index / 27 - 1;
559
39.7k
          index = index - (w + 1) * 27;
560
39.7k
          x = index / 9 - 1;
561
39.7k
          index = index - (x + 1) * 9;
562
39.7k
          y = index / 3 - 1;
563
39.7k
          z = index - ((y + 1) * 3) - 1;
564
39.7k
          if (w < 0) {
565
3.96k
            w = -w;
566
3.96k
            w = ixheaacd_pow_table_Q13[w];
567
3.96k
            w = -w;
568
3.96k
          } else
569
35.7k
            w = ixheaacd_pow_table_Q13[w];
570
571
39.7k
          *spec_coef++ = w;
572
573
39.7k
          if (x < 0) {
574
2.41k
            x = -x;
575
2.41k
            x = ixheaacd_pow_table_Q13[x];
576
2.41k
            x = -x;
577
2.41k
          } else
578
37.2k
            x = ixheaacd_pow_table_Q13[x];
579
580
39.7k
          *spec_coef++ = x;
581
582
39.7k
          if (y < 0) {
583
5.31k
            y = -y;
584
5.31k
            y = ixheaacd_pow_table_Q13[y];
585
5.31k
            y = -y;
586
5.31k
          } else
587
34.3k
            y = ixheaacd_pow_table_Q13[y];
588
589
39.7k
          *spec_coef++ = y;
590
591
39.7k
          if (z < 0) {
592
3.91k
            z = -z;
593
3.91k
            z = ixheaacd_pow_table_Q13[z];
594
3.91k
            z = -z;
595
3.91k
          } else
596
35.7k
            z = ixheaacd_pow_table_Q13[z];
597
598
39.7k
          *spec_coef++ = z;
599
39.7k
        }
600
601
66.3k
        ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
602
66.3k
                                    it_bit_buff->ptr_bit_buf_end);
603
66.3k
        idx -= 4;
604
66.3k
      } while (idx != 0);
605
606
40.1k
      if (maximum_bins_short == 120) {
607
30.5k
        spec_coef += (maximum_bins_short - offsets[1]);
608
30.5k
      } else {
609
9.53k
        spec_coef += (MAX_BINS_SHORT - offsets[1]);
610
9.53k
      }
611
612
40.1k
      grp_idx--;
613
40.1k
    } while (grp_idx != 0);
614
26.0k
    offsets++;
615
26.0k
    spec_coef = spec_orig;
616
26.0k
    no_bands--;
617
26.0k
  } while (no_bands >= 0);
618
619
6.17k
  ptr_read_next = ptr_read_next - increment;
620
6.17k
  ixheaacd_aac_read_byte_corr1(&ptr_read_next, &bit_pos, &read_word,
621
6.17k
                               it_bit_buff->ptr_bit_buf_end);
622
6.17k
  it_bit_buff->ptr_read_next = ptr_read_next;
623
6.17k
  it_bit_buff->bit_pos = bit_pos;
624
625
6.17k
  return 0;
626
6.17k
}
627
628
static PLATFORM_INLINE WORD ixheaacd_huffman_dec_word2_quad(
629
    ia_bit_buf_struct *it_bit_buff, WORD32 width, const UWORD16 *code_book_tbl,
630
    WORD32 *x_invquant, WORD32 *ixheaacd_pow_table_Q13, WORD8 *ptr_scratch,
631
33.3k
    WORD32 tbl_sign, const UWORD32 *idx_table) {
632
33.3k
  WORD idx;
633
33.3k
  WORD16 index, length;
634
33.3k
  UWORD8 *ptr_read_next = it_bit_buff->ptr_read_next;
635
33.3k
  WORD32 bit_pos = it_bit_buff->bit_pos;
636
33.3k
  WORD32 read_word;
637
33.3k
  WORD32 increment;
638
639
33.3k
  read_word = ixheaacd_aac_showbits_32(ptr_read_next, it_bit_buff->cnt_bits,
640
33.3k
                                       &increment);
641
33.3k
  ptr_read_next += increment;
642
643
1.79M
  for (idx = width; idx != 0; idx -= 4) {
644
1.76M
    WORD32 ampres, ampres1;
645
1.76M
    WORD32 ampres2, ampres3;
646
1.76M
    UWORD32 read_word1;
647
648
1.76M
    read_word1 = read_word << bit_pos;
649
1.76M
    ixheaacd_huffman_decode(read_word1, &index, &length, code_book_tbl,
650
1.76M
                            idx_table);
651
1.76M
    bit_pos += length;
652
1.76M
    ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
653
1.76M
                                it_bit_buff->ptr_bit_buf_end);
654
1.76M
    if (tbl_sign) {
655
1.36M
      WORD32 w, x, y, z;
656
1.36M
      WORD32 ampout0, ampout1, ampout2, ampout3;
657
1.36M
      WORD32 temp_word;
658
1.36M
      temp_word = read_word << bit_pos;
659
660
1.36M
      w = index / 27;
661
1.36M
      index = index - w * 27;
662
1.36M
      x = index / 9;
663
1.36M
      index = index - x * 9;
664
1.36M
      y = index / 3;
665
1.36M
      z = index - y * 3;
666
667
1.36M
      ampout0 = w + *ptr_scratch++;
668
1.36M
      ampout0 = ixheaacd_pow_table_Q13[ampout0];
669
670
1.36M
      if (w) {
671
689k
        if (temp_word & 0x80000000) {
672
328k
          ampout0 = -ampout0;
673
328k
        }
674
689k
        temp_word = temp_word << 1;
675
689k
        bit_pos++;
676
689k
      } else {
677
672k
        ampout0 = -ampout0;
678
672k
      }
679
680
1.36M
      ampout1 = x + *ptr_scratch++;
681
1.36M
      ampout1 = ixheaacd_pow_table_Q13[ampout1];
682
683
1.36M
      if (x) {
684
519k
        if (temp_word & 0x80000000) {
685
210k
          ampout1 = -ampout1;
686
210k
        }
687
519k
        temp_word = temp_word << 1;
688
519k
        bit_pos++;
689
842k
      } else {
690
842k
        ampout1 = -ampout1;
691
842k
      }
692
693
1.36M
      ampout2 = y + *ptr_scratch++;
694
1.36M
      ampout2 = ixheaacd_pow_table_Q13[ampout2];
695
696
1.36M
      if (y) {
697
686k
        if (temp_word & 0x80000000) {
698
340k
          ampout2 = -ampout2;
699
340k
        }
700
686k
        temp_word = temp_word << 1;
701
686k
        bit_pos++;
702
686k
      } else {
703
675k
        ampout2 = -ampout2;
704
675k
      }
705
706
1.36M
      ampout3 = z + *ptr_scratch++;
707
1.36M
      ampout3 = ixheaacd_pow_table_Q13[ampout3];
708
709
1.36M
      if (z) {
710
674k
        if (temp_word & 0x80000000) {
711
325k
          ampout3 = -ampout3;
712
325k
        }
713
674k
        temp_word = temp_word << 1;
714
674k
        bit_pos++;
715
686k
      } else {
716
686k
        ampout3 = -ampout3;
717
686k
      }
718
1.36M
      *x_invquant++ = ampout0;
719
1.36M
      *x_invquant++ = ampout1;
720
1.36M
      *x_invquant++ = ampout2;
721
1.36M
      *x_invquant++ = ampout3;
722
1.36M
    } else {
723
399k
      WORD32 w, x, y, z;
724
399k
      ampres = *ptr_scratch++;
725
399k
      ampres1 = *ptr_scratch++;
726
399k
      ampres2 = *ptr_scratch++;
727
399k
      ampres3 = *ptr_scratch++;
728
729
399k
      w = index / 27 - 1;
730
399k
      index = index - (w + 1) * 27;
731
399k
      x = index / 9 - 1;
732
399k
      index = index - (x + 1) * 9;
733
399k
      y = index / 3 - 1;
734
399k
      z = index - ((y + 1) * 3) - 1;
735
399k
      if (w <= 0) {
736
371k
        ampres = ampres - w;
737
371k
        ampres = ixheaacd_pow_table_Q13[ampres];
738
371k
        ampres = -ampres;
739
371k
      } else {
740
28.2k
        ampres += w;
741
28.2k
        ampres = ixheaacd_pow_table_Q13[ampres];
742
28.2k
      }
743
744
399k
      if (x <= 0) {
745
357k
        ampres1 = ampres1 - x;
746
357k
        ampres1 = ixheaacd_pow_table_Q13[ampres1];
747
357k
        ampres1 = -ampres1;
748
357k
      } else {
749
42.4k
        ampres1 += x;
750
42.4k
        ampres1 = ixheaacd_pow_table_Q13[ampres1];
751
42.4k
      }
752
753
399k
      if (y <= 0) {
754
373k
        ampres2 = ampres2 - y;
755
373k
        ampres2 = ixheaacd_pow_table_Q13[ampres2];
756
373k
        ampres2 = -ampres2;
757
373k
      } else {
758
25.8k
        ampres2 += y;
759
25.8k
        ampres2 = ixheaacd_pow_table_Q13[ampres2];
760
25.8k
      }
761
762
399k
      if (z <= 0) {
763
392k
        ampres3 = ampres3 - z;
764
392k
        ampres3 = ixheaacd_pow_table_Q13[ampres3];
765
392k
        ampres3 = -ampres3;
766
392k
      } else {
767
7.60k
        ampres3 += z;
768
7.60k
        ampres3 = ixheaacd_pow_table_Q13[ampres3];
769
7.60k
      }
770
771
399k
      *x_invquant++ = ampres;
772
399k
      *x_invquant++ = ampres1;
773
399k
      *x_invquant++ = ampres2;
774
399k
      *x_invquant++ = ampres3;
775
399k
    }
776
777
1.76M
    ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
778
1.76M
                                it_bit_buff->ptr_bit_buf_end);
779
1.76M
  }
780
781
33.3k
  ptr_read_next = ptr_read_next - increment;
782
33.3k
  ixheaacd_aac_read_byte_corr1(&ptr_read_next, &bit_pos, &read_word,
783
33.3k
                               it_bit_buff->ptr_bit_buf_end);
784
33.3k
  it_bit_buff->ptr_read_next = ptr_read_next;
785
33.3k
  it_bit_buff->bit_pos = bit_pos;
786
787
33.3k
  return 0;
788
33.3k
}
789
790
static PLATFORM_INLINE WORD ixheaacd_huffman_dec_pair(
791
    ia_bit_buf_struct *it_bit_buff, WORD32 *spec_coef, WORD16 *offsets,
792
    WORD no_bands, WORD group_len, const UWORD16 *code_book_tbl,
793
    WORD32 *ixheaacd_pow_table_Q13, WORD32 tbl_sign, const UWORD32 *idx_table,
794
8.61k
    WORD32 huff_mode, WORD32 maximum_bins_short) {
795
8.61k
  WORD idx, grp_idx;
796
8.61k
  WORD len_idx;
797
8.61k
  WORD16 index, length;
798
8.61k
  WORD32 y, z;
799
8.61k
  WORD32 *spec_orig = spec_coef;
800
801
8.61k
  UWORD8 *ptr_read_next = it_bit_buff->ptr_read_next;
802
8.61k
  WORD32 bit_pos = it_bit_buff->bit_pos;
803
8.61k
  WORD32 read_word;
804
8.61k
  WORD32 increment;
805
806
8.61k
  read_word = ixheaacd_aac_showbits_32(ptr_read_next, it_bit_buff->cnt_bits,
807
8.61k
                                       &increment);
808
8.61k
  ptr_read_next += increment;
809
810
34.8k
  do {
811
34.8k
    len_idx = offsets[1] - offsets[0];
812
34.8k
    grp_idx = group_len;
813
131k
    do {
814
131k
      spec_coef += offsets[0];
815
131k
      idx = len_idx;
816
389k
      do {
817
389k
        UWORD32 read_word1;
818
389k
        read_word1 = read_word << bit_pos;
819
389k
        ixheaacd_huffman_decode(read_word1, &index, &length, code_book_tbl,
820
389k
                                idx_table);
821
389k
        bit_pos += length;
822
389k
        ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
823
389k
                                    it_bit_buff->ptr_bit_buf_end);
824
389k
        if (tbl_sign) {
825
172k
          WORD32 temp_word;
826
172k
          temp_word = read_word << bit_pos;
827
172k
          y = index / huff_mode;
828
172k
          z = index - huff_mode * y;
829
172k
          if (y) {
830
38.2k
            y = ixheaacd_pow_table_Q13[y];
831
38.2k
            if (temp_word & 0x80000000) y = -y;
832
833
38.2k
            temp_word = temp_word << 1;
834
38.2k
            bit_pos++;
835
38.2k
          }
836
172k
          *spec_coef++ = y;
837
838
172k
          if (z) {
839
33.0k
            z = ixheaacd_pow_table_Q13[z];
840
33.0k
            if (temp_word & 0x80000000) {
841
11.5k
              z = -z;
842
11.5k
            }
843
33.0k
            temp_word <<= 1;
844
33.0k
            bit_pos++;
845
33.0k
          }
846
172k
          *spec_coef++ = z;
847
217k
        } else {
848
217k
          y = (index / huff_mode) - 4;
849
217k
          z = index - ((y + 4) * huff_mode) - 4;
850
217k
          if (y < 0) {
851
25.7k
            y = -y;
852
25.7k
            y = ixheaacd_pow_table_Q13[y];
853
25.7k
            y = -y;
854
25.7k
          } else
855
191k
            y = ixheaacd_pow_table_Q13[y];
856
857
217k
          if (z < 0) {
858
16.8k
            z = -z;
859
16.8k
            z = ixheaacd_pow_table_Q13[z];
860
16.8k
            z = -z;
861
16.8k
          } else
862
200k
            z = ixheaacd_pow_table_Q13[z];
863
864
217k
          *spec_coef++ = y;
865
217k
          *spec_coef++ = z;
866
217k
        }
867
389k
        ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
868
389k
                                    it_bit_buff->ptr_bit_buf_end);
869
389k
        idx -= 2;
870
389k
      } while (idx != 0);
871
872
131k
      if (maximum_bins_short == 120)
873
41.1k
        spec_coef += (maximum_bins_short - offsets[1]);
874
90.6k
      else
875
90.6k
        spec_coef += (MAX_BINS_SHORT - offsets[1]);
876
877
131k
      grp_idx--;
878
131k
    } while (grp_idx != 0);
879
880
34.8k
    offsets++;
881
34.8k
    spec_coef = spec_orig;
882
34.8k
    no_bands--;
883
34.8k
  } while (no_bands >= 0);
884
885
8.61k
  ptr_read_next = ptr_read_next - increment;
886
8.61k
  ixheaacd_aac_read_byte_corr1(&ptr_read_next, &bit_pos, &read_word,
887
8.61k
                               it_bit_buff->ptr_bit_buf_end);
888
8.61k
  it_bit_buff->ptr_read_next = ptr_read_next;
889
8.61k
  it_bit_buff->bit_pos = bit_pos;
890
891
8.61k
  return 0;
892
8.61k
}
893
894
static PLATFORM_INLINE WORD ixheaacd_huffman_dec_word2_pair(
895
    ia_bit_buf_struct *it_bit_buff, WORD32 width, const UWORD16 *code_book_tbl,
896
    WORD32 *x_invquant, WORD32 *ixheaacd_pow_table_Q13, WORD8 *ptr_scratch,
897
    WORD32 tbl_sign, const UWORD32 *idx_table, WORD32 huff_mode)
898
899
60.2k
{
900
60.2k
  WORD32 ampres;
901
60.2k
  WORD idx;
902
60.2k
  WORD16 index, length;
903
60.2k
  UWORD8 *ptr_read_next = it_bit_buff->ptr_read_next;
904
60.2k
  WORD32 bit_pos = it_bit_buff->bit_pos;
905
60.2k
  WORD32 read_word;
906
60.2k
  WORD32 increment;
907
908
60.2k
  read_word = ixheaacd_aac_showbits_32(ptr_read_next, it_bit_buff->cnt_bits,
909
60.2k
                                       &increment);
910
60.2k
  ptr_read_next += increment;
911
912
1.12M
  for (idx = width; idx != 0; idx -= 2) {
913
1.06M
    {
914
1.06M
      UWORD32 read_word1;
915
1.06M
      read_word1 = read_word << bit_pos;
916
1.06M
      ixheaacd_huffman_decode(read_word1, &index, &length, code_book_tbl,
917
1.06M
                              idx_table);
918
1.06M
      bit_pos += length;
919
1.06M
      ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
920
1.06M
                                  it_bit_buff->ptr_bit_buf_end);
921
1.06M
    }
922
923
1.06M
    if (tbl_sign) {
924
582k
      WORD32 out0, out1, temp_word;
925
582k
      WORD32 ampout0, ampout1;
926
927
582k
      ampout0 = *ptr_scratch++;
928
582k
      ampout1 = *ptr_scratch++;
929
582k
      out0 = index / huff_mode;
930
582k
      out1 = index - huff_mode * out0;
931
582k
      ampout0 += out0;
932
582k
      ampout0 = ixheaacd_pow_table_Q13[ampout0];
933
934
582k
      ampout1 += out1;
935
582k
      ampout1 = ixheaacd_pow_table_Q13[ampout1];
936
582k
      temp_word = read_word << bit_pos;
937
582k
      if (out0) {
938
365k
        if (temp_word & 0x80000000) {
939
133k
          ampout0 = -(ampout0);
940
133k
        }
941
942
365k
        bit_pos++;
943
365k
        temp_word = temp_word << 1;
944
365k
      } else {
945
216k
        ampout0 = -(ampout0);
946
216k
      }
947
948
582k
      if (out1) {
949
381k
        if (temp_word & 0x80000000) {
950
165k
          ampout1 = -(ampout1);
951
165k
        }
952
381k
        bit_pos++;
953
381k
      } else {
954
200k
        ampout1 = -(ampout1);
955
200k
      }
956
957
582k
      ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
958
582k
                                  it_bit_buff->ptr_bit_buf_end);
959
582k
      *x_invquant++ = ampout0;
960
582k
      *x_invquant++ = ampout1;
961
582k
    } else {
962
483k
      WORD32 y, z;
963
483k
      y = (index / huff_mode) - 4;
964
483k
      z = index - ((y + 4) * huff_mode) - 4;
965
966
483k
      ampres = *ptr_scratch++;
967
483k
      if (y <= 0) {
968
342k
        ampres = ampres - y;
969
342k
        ampres = ixheaacd_pow_table_Q13[ampres];
970
342k
        *x_invquant++ = -ampres;
971
342k
      } else {
972
141k
        ampres += y;
973
141k
        *x_invquant++ = ixheaacd_pow_table_Q13[ampres];
974
141k
      }
975
483k
      ampres = *ptr_scratch++;
976
483k
      if (z <= 0) {
977
354k
        ampres = ampres - z;
978
354k
        ampres = ixheaacd_pow_table_Q13[ampres];
979
354k
        *x_invquant++ = -ampres;
980
354k
      } else {
981
129k
        ampres += z;
982
129k
        *x_invquant++ = ixheaacd_pow_table_Q13[ampres];
983
129k
      }
984
483k
    }
985
1.06M
    ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
986
1.06M
                                it_bit_buff->ptr_bit_buf_end);
987
1.06M
  }
988
989
60.2k
  ptr_read_next = ptr_read_next - increment;
990
60.2k
  ixheaacd_aac_read_byte_corr1(&ptr_read_next, &bit_pos, &read_word,
991
60.2k
                               it_bit_buff->ptr_bit_buf_end);
992
60.2k
  it_bit_buff->ptr_read_next = ptr_read_next;
993
60.2k
  it_bit_buff->bit_pos = bit_pos;
994
995
60.2k
  return 0;
996
60.2k
}
997
998
WORD ixheaacd_decode_huffman(ia_bit_buf_struct *it_bit_buff, WORD32 cb_no,
999
                             WORD32 *spec_coef, WORD16 *sfb_offset, WORD start,
1000
                             WORD sfb, WORD group_len,
1001
                             ia_aac_dec_tables_struct *ptr_aac_tables,
1002
72.8k
                             WORD32 maximum_bins_short) {
1003
72.8k
  WORD ret_val = 0;
1004
72.8k
  WORD start_bit_pos = it_bit_buff->bit_pos;
1005
72.8k
  UWORD8 *start_read_pos = it_bit_buff->ptr_read_next;
1006
72.8k
  const UWORD16 *cb_table = (UWORD16 *)(ptr_aac_tables->code_book[cb_no]);
1007
72.8k
  WORD32 huff_mode;
1008
72.8k
  const UWORD32 *idx_table = (UWORD32 *)(ptr_aac_tables->index_table[cb_no]);
1009
72.8k
  WORD32 *pow_table =
1010
72.8k
      (WORD32 *)ptr_aac_tables->pstr_block_tables->ixheaacd_pow_table_Q13;
1011
72.8k
  WORD32 no_bands = sfb - start - 1;
1012
72.8k
  WORD16 *band_offset = sfb_offset + start;
1013
1014
72.8k
  if (cb_no == 11) {
1015
58.0k
    const UWORD32 *idx_table =
1016
58.0k
        ptr_aac_tables->pstr_huffmann_tables->idx_table_hf11;
1017
58.0k
    const UWORD16 *cb_table =
1018
58.0k
        ptr_aac_tables->pstr_huffmann_tables->input_table_cb11;
1019
1020
58.0k
    ret_val = ixheaacd_huffman_dec_word1(it_bit_buff, spec_coef, band_offset,
1021
58.0k
                                         no_bands, group_len, cb_table,
1022
58.0k
                                         pow_table, idx_table, maximum_bins_short);
1023
1024
58.0k
  } else if (cb_no <= 4) {
1025
6.17k
    WORD32 tbl_sign = 0;
1026
1027
6.17k
    if (cb_no > 2) {
1028
3.96k
      tbl_sign = 1;
1029
3.96k
    }
1030
6.17k
    ret_val = ixheaacd_huffman_dec_quad(it_bit_buff, spec_coef, band_offset,
1031
6.17k
                                        no_bands, group_len, cb_table,
1032
6.17k
                                        pow_table, tbl_sign, idx_table, maximum_bins_short);
1033
6.17k
  }
1034
1035
8.61k
  else if (cb_no <= 10) {
1036
8.61k
    WORD32 tbl_sign = 0;
1037
8.61k
    huff_mode = 9;
1038
8.61k
    if (cb_no > 6) {
1039
6.26k
      if (cb_no > 8)
1040
4.73k
        huff_mode = 13;
1041
1.52k
      else
1042
1.52k
        huff_mode = 8;
1043
6.26k
      tbl_sign = 1;
1044
6.26k
    }
1045
8.61k
    ret_val = ixheaacd_huffman_dec_pair(
1046
8.61k
        it_bit_buff, spec_coef, band_offset, no_bands, group_len, cb_table,
1047
8.61k
        pow_table, tbl_sign, idx_table, huff_mode, maximum_bins_short);
1048
8.61k
  }
1049
1050
72.8k
  {
1051
72.8k
    WORD bits_cons;
1052
72.8k
    bits_cons = (WORD)(((it_bit_buff->ptr_read_next - start_read_pos) << 3) +
1053
72.8k
                       (it_bit_buff->bit_pos - start_bit_pos));
1054
72.8k
    it_bit_buff->cnt_bits -= bits_cons;
1055
72.8k
  }
1056
72.8k
  return ret_val;
1057
72.8k
}
1058
1059
WORD ixheaacd_huffman_dec_word2(ia_bit_buf_struct *it_bit_buff, WORD32 cb_no,
1060
                                WORD32 width,
1061
                                ia_aac_dec_tables_struct *ptr_aac_tables,
1062
170k
                                WORD32 *x_invquant, WORD8 *scratch_ptr) {
1063
170k
  WORD ret_val = 0;
1064
170k
  WORD32 huff_mode;
1065
170k
  WORD start_bit_pos = it_bit_buff->bit_pos;
1066
170k
  WORD32 cnt_bits = it_bit_buff->cnt_bits;
1067
170k
  WORD32 *pow_table =
1068
170k
      (WORD32 *)ptr_aac_tables->pstr_block_tables->ixheaacd_pow_table_Q13;
1069
170k
  UWORD8 *start_read_pos = it_bit_buff->ptr_read_next;
1070
1071
170k
  const UWORD16 *cb_table = (UWORD16 *)(ptr_aac_tables->code_book[cb_no]);
1072
170k
  const UWORD32 *idx_table = (UWORD32 *)(ptr_aac_tables->index_table[cb_no]);
1073
1074
170k
  if (cb_no == 11) {
1075
76.4k
    const UWORD16 *cb_table =
1076
76.4k
        ptr_aac_tables->pstr_huffmann_tables->input_table_cb11;
1077
1078
76.4k
    ret_val = ixheaacd_huffman_dec_word2_11(
1079
76.4k
        it_bit_buff, width, cb_table, x_invquant, pow_table, scratch_ptr,
1080
76.4k
        ptr_aac_tables->pstr_huffmann_tables->idx_table_hf11);
1081
93.6k
  } else if (cb_no <= 4) {
1082
33.3k
    WORD32 tbl_sign = 0;
1083
33.3k
    if (cb_no > 2) tbl_sign = 1;
1084
33.3k
    ret_val = ixheaacd_huffman_dec_word2_quad(it_bit_buff, width, cb_table,
1085
33.3k
                                              x_invquant, pow_table,
1086
33.3k
                                              scratch_ptr, tbl_sign, idx_table);
1087
60.2k
  } else if (cb_no <= 10) {
1088
60.2k
    WORD32 tbl_sign = 0;
1089
60.2k
    huff_mode = 9;
1090
60.2k
    if (cb_no > 6) {
1091
54.7k
      if (cb_no > 8) {
1092
2.87k
        huff_mode = 13;
1093
51.8k
      } else {
1094
51.8k
        huff_mode = 8;
1095
51.8k
      }
1096
1097
54.7k
      tbl_sign = 1;
1098
54.7k
    }
1099
60.2k
    ret_val = ixheaacd_huffman_dec_word2_pair(
1100
60.2k
        it_bit_buff, width, cb_table, x_invquant, pow_table, scratch_ptr,
1101
60.2k
        tbl_sign, idx_table, huff_mode);
1102
60.2k
  }
1103
1104
170k
  {
1105
170k
    WORD bits_cons;
1106
170k
    if (it_bit_buff->bit_pos <= 7) {
1107
170k
      bits_cons = (WORD)(((it_bit_buff->ptr_read_next - start_read_pos) << 3) +
1108
170k
                         (it_bit_buff->bit_pos - start_bit_pos));
1109
170k
      if (bits_cons > cnt_bits)
1110
36
      {
1111
36
        return IA_XHEAAC_DEC_EXE_NONFATAL_INSUFFICIENT_INPUT_BYTES;
1112
36
      }
1113
169k
      it_bit_buff->cnt_bits = cnt_bits - bits_cons;
1114
169k
    } else {
1115
71
      it_bit_buff->ptr_read_next += (it_bit_buff->bit_pos) >> 3;
1116
71
      it_bit_buff->bit_pos = it_bit_buff->bit_pos & 0x7;
1117
71
      if ((SIZE_T)(it_bit_buff->ptr_read_next) > (SIZE_T)(it_bit_buff->ptr_bit_buf_end + 1))
1118
71
      {
1119
71
        it_bit_buff->ptr_read_next = it_bit_buff->ptr_bit_buf_end + 1;
1120
71
        return IA_XHEAAC_DEC_EXE_NONFATAL_INSUFFICIENT_INPUT_BYTES;
1121
71
      }
1122
1123
0
      bits_cons = (WORD)(((it_bit_buff->ptr_read_next - start_read_pos) << 3) +
1124
0
                         (it_bit_buff->bit_pos - start_bit_pos));
1125
0
      it_bit_buff->cnt_bits = cnt_bits - bits_cons;
1126
0
    }
1127
170k
  }
1128
169k
  return ret_val;
1129
170k
}
1130
1131
VOID ixheaacd_dec_copy_outsample(WORD32 *out_samples, WORD32 *p_overlap_buffer,
1132
2.88k
                                 WORD32 size, WORD16 stride) {
1133
2.88k
  WORD32 i;
1134
1135
1.21M
  for (i = 0; i < size; i++) {
1136
1.21M
    out_samples[stride*i] = (ixheaac_shl16_sat((WORD16)(p_overlap_buffer[i]), 1) << 14);
1137
1.21M
  }
1138
2.88k
}
1139
1140
VOID ixheaacd_lap1_512_480(WORD32 *coef, WORD32 *prev, VOID *out_tmp,
1141
                           const WORD16 *window, WORD16 q_shift, WORD16 size,
1142
26.8k
                           WORD16 stride , WORD slot_element) {
1143
26.8k
  WORD32 accu;
1144
26.8k
  WORD32 i;
1145
26.8k
  WORD16 rounding_fac = -0x2000;
1146
1147
26.8k
  WORD32 *window_i = (WORD32 *)window;
1148
1149
26.8k
  WORD16 *ptr_out1, *ptr_out2;
1150
1151
26.8k
  WORD32 *pwin1, *pwin2;
1152
26.8k
  WORD32 *pCoef = &coef[size * 2 - 1 - 0];
1153
1154
26.8k
  WORD16 * out  = (WORD16*)out_tmp - slot_element;
1155
1156
26.8k
  pwin1 = &window_i[size - 1 - 0];
1157
26.8k
  pwin2 = &window_i[size + 0];
1158
1159
26.8k
  ptr_out1 = &out[stride * (size - 1 - 0)];
1160
26.8k
  ptr_out2 = &out[stride * (size + 0)];
1161
1162
6.83M
  for (i = 0; i < size; i++) {
1163
6.80M
    WORD32 win1, win2, coeff;
1164
6.80M
    WORD32 prev_data = *prev++;
1165
1166
6.80M
    win1 = *pwin1--;
1167
6.80M
    coeff = *pCoef--;
1168
6.80M
    win2 = *pwin2++;
1169
1170
6.80M
    accu = ixheaac_sub32_sat(
1171
6.80M
        ixheaac_shl32_dir_sat_limit(ixheaac_mult32_shl(coeff, win1), q_shift),
1172
6.80M
        ixheaac_mac32x16in32_shl(rounding_fac, win2, (WORD16)(prev_data)));
1173
1174
6.80M
    accu = ixheaac_add32_sat(accu, accu);
1175
6.80M
    accu = ixheaac_add32_sat(accu, accu);
1176
1177
6.80M
    *ptr_out1 = ixheaac_shr32(accu, 16);
1178
6.80M
    ptr_out1 -= stride;
1179
1180
6.80M
    accu = ixheaac_sub32_sat(
1181
6.80M
        ixheaac_shl32_dir_sat_limit(
1182
6.80M
            ixheaac_mult32_shl(ixheaac_negate32_sat(coeff), win2), q_shift),
1183
6.80M
        ixheaac_mac32x16in32_shl(rounding_fac, win1, (WORD16)(prev_data)));
1184
1185
6.80M
    accu = ixheaac_add32_sat(accu, accu);
1186
6.80M
    accu = ixheaac_add32_sat(accu, accu);
1187
1188
6.80M
    *ptr_out2 = ixheaac_shr32(accu, 16);
1189
6.80M
    ptr_out2 += stride;
1190
6.80M
  }
1191
26.8k
}
1192
1193
VOID ixheaacd_over_lap_add1_dec(WORD32 *coef, WORD32 *prev, WORD32 *out,
1194
                                const WORD16 *window, WORD16 q_shift,
1195
154k
                                WORD16 size, WORD16 ch_fac) {
1196
154k
  WORD32 accu;
1197
154k
  WORD32 i;
1198
154k
  WORD16 rounding_fac = 0;
1199
1200
21.7M
  for (i = 0; i < size; i++) {
1201
21.5M
    WORD16 window1, window2;
1202
1203
21.5M
    window1 = window[2 * size - 2 * i - 1];
1204
21.5M
    window2 = window[2 * size - 2 * i - 2];
1205
21.5M
    accu = ixheaac_sub32_sat(
1206
21.5M
        ixheaac_shl32_dir_sat_limit(
1207
21.5M
            ixheaac_mult32x16in32(coef[size * 2 - 1 - i], window2), q_shift),
1208
21.5M
        ixheaacd_mac32x16in32_sat(rounding_fac, prev[i], window1));
1209
21.5M
    out[ch_fac * (size - i - 1)] = accu;
1210
21.5M
    accu = ixheaac_sub32_sat(
1211
21.5M
        ixheaac_shl32_dir_sat_limit(
1212
21.5M
            ixheaac_mult32x16in32(ixheaac_negate32_sat(coef[size * 2 - 1 - i]),
1213
21.5M
                                   window1),
1214
21.5M
            q_shift),
1215
21.5M
        ixheaacd_mac32x16in32_sat(rounding_fac, prev[i], window2));
1216
21.5M
    out[ch_fac * (size + i)] = accu;
1217
21.5M
  }
1218
154k
}
1219
1220
VOID ixheaacd_over_lap_add2_dec(WORD32 *coef, WORD32 *prev, WORD32 *out,
1221
                                const WORD16 *window, WORD16 q_shift,
1222
172k
                                WORD16 size, WORD16 ch_fac) {
1223
172k
  WORD32 accu;
1224
172k
  WORD32 i;
1225
1226
10.9M
  for (i = 0; i < size; i++) {
1227
10.8M
    accu = ixheaac_sub32_sat(
1228
10.8M
        ixheaac_mult32x16in32(coef[size + i], window[2 * i]),
1229
10.8M
        ixheaac_mult32x16in32(prev[size - 1 - i], window[2 * i + 1]));
1230
10.8M
    out[ch_fac * i] = ixheaac_shr32_sat(accu, 16 - (q_shift + 1));
1231
10.8M
  }
1232
1233
10.9M
  for (i = 0; i < size; i++) {
1234
10.8M
    accu = ixheaac_sub32_sat(
1235
10.8M
        ixheaac_mult32x16in32(ixheaac_negate32_sat(coef[size * 2 - 1 - i]),
1236
10.8M
                               window[2 * size - 2 * i - 1]),
1237
10.8M
        ixheaac_mult32x16in32(prev[i], window[2 * size - 2 * i - 2]));
1238
10.8M
    out[ch_fac * (i + size)] = ixheaac_shr32_sat(accu, 16 - (q_shift + 1));
1239
10.8M
  }
1240
172k
}
1241
1242
VOID ixheaacd_process_single_scf(WORD32 scale_factor, WORD32 *x_invquant,
1243
                                 WORD32 width, WORD32 *ptr_scale_table,
1244
                                 WORD32 total_channels, WORD32 object_type,
1245
4.91M
                                 WORD32 aac_sf_data_resil_flag) {
1246
4.91M
  WORD32 j;
1247
1248
4.91M
  WORD32 temp1;
1249
4.91M
  WORD32 q_factor;
1250
4.91M
  WORD32 buffer1;
1251
4.91M
  WORD16 scale_short;
1252
1253
4.91M
  object_type = 0;
1254
4.91M
  aac_sf_data_resil_flag = 0;
1255
1256
4.91M
  if (scale_factor < 24) {
1257
24.1M
    for (j = width; j > 0; j--) {
1258
21.8M
      *x_invquant++ = 0;
1259
21.8M
    }
1260
2.64M
  } else {
1261
2.64M
    WORD32 shift;
1262
1263
2.64M
    if (total_channels > 2)
1264
128k
      q_factor = 34 - (scale_factor >> 2);
1265
2.51M
    else
1266
2.51M
      q_factor = 37 - (scale_factor >> 2);
1267
1268
2.64M
    scale_short = ptr_scale_table[(scale_factor & 0x0003)];
1269
2.64M
    shift = q_factor;
1270
2.64M
    if (shift > 0) {
1271
875k
      if (scale_short == (WORD16)0x8000) {
1272
0
        for (j = width; j > 0; j--) {
1273
0
          temp1 = *x_invquant;
1274
0
          buffer1 = ixheaac_mult32x16in32_shl_sat(temp1, scale_short);
1275
0
          buffer1 = ixheaac_shr32(buffer1, shift);
1276
0
          *x_invquant++ = buffer1;
1277
0
        }
1278
875k
      } else {
1279
13.3M
        for (j = width; j > 0; j--) {
1280
12.4M
          temp1 = *x_invquant;
1281
12.4M
          buffer1 = ixheaac_mult32x16in32_shl(temp1, scale_short);
1282
12.4M
          buffer1 = ixheaac_shr32(buffer1, shift);
1283
12.4M
          *x_invquant++ = buffer1;
1284
12.4M
        }
1285
875k
      }
1286
1.76M
    } else {
1287
1.76M
      shift = -shift;
1288
1.76M
      if (shift > 0) {
1289
1.76M
        if (scale_short == (WORD16)0x8000) {
1290
0
          for (j = width; j > 0; j--) {
1291
0
            temp1 = *x_invquant;
1292
0
            temp1 = ixheaac_shl32(temp1, shift - 1);
1293
0
            buffer1 = ixheaac_mult32x16in32_shl_sat(temp1, scale_short);
1294
0
            buffer1 = ixheaac_shl32(buffer1, 1);
1295
0
            *x_invquant++ = buffer1;
1296
0
          }
1297
1.76M
        } else {
1298
18.4M
          for (j = width; j > 0; j--) {
1299
16.6M
            temp1 = *x_invquant;
1300
16.6M
            temp1 = ixheaac_shl32(temp1, shift - 1);
1301
16.6M
            buffer1 = ixheaac_mult32x16in32_shl(temp1, scale_short);
1302
16.6M
            buffer1 = ixheaac_shl32(buffer1, 1);
1303
16.6M
            *x_invquant++ = buffer1;
1304
16.6M
          }
1305
1.76M
        }
1306
1307
1.76M
      } else {
1308
2.20k
        if (scale_short == (WORD16)0x8000) {
1309
0
          for (j = width; j > 0; j--) {
1310
0
            temp1 = *x_invquant;
1311
0
            buffer1 = ixheaac_mult32x16in32_shl_sat(temp1, scale_short);
1312
0
            *x_invquant++ = buffer1;
1313
0
          }
1314
2.20k
        } else {
1315
24.3k
          for (j = width; j > 0; j--) {
1316
22.1k
            temp1 = *x_invquant;
1317
22.1k
            buffer1 = ixheaac_mult32x16in32_shl(temp1, scale_short);
1318
22.1k
            *x_invquant++ = buffer1;
1319
22.1k
          }
1320
2.20k
        }
1321
2.20k
      }
1322
1.76M
    }
1323
2.64M
  }
1324
4.91M
}
1325
1326
VOID ixheaacd_scale_factor_process_dec(WORD32 *x_invquant, WORD16 *scale_fact,
1327
                                       WORD no_band, WORD8 *width,
1328
                                       WORD32 *ptr_scale_table,
1329
                                       WORD32 total_channels,
1330
                                       WORD32 object_type,
1331
602k
                                       WORD32 aac_sf_data_resil_flag) {
1332
602k
  WORD32 i;
1333
602k
  WORD16 scale_factor;
1334
1335
5.51M
  for (i = no_band - 1; i >= 0; i--) {
1336
4.91M
    scale_factor = *scale_fact++;
1337
4.91M
    ixheaacd_process_single_scf(scale_factor, x_invquant, *width,
1338
4.91M
                                ptr_scale_table, total_channels, object_type,
1339
4.91M
                                aac_sf_data_resil_flag);
1340
1341
4.91M
    x_invquant += *width;
1342
4.91M
    width++;
1343
4.91M
  }
1344
602k
}
1345
1346
VOID ixheaacd_right_shift_block(WORD32 *p_spectrum, WORD32 length,
1347
9.68k
                                WORD32 shift_val) {
1348
9.68k
  WORD32 i;
1349
9.68k
  WORD32 temp1, temp2;
1350
9.68k
  WORD32 *temp_ptr = &p_spectrum[0];
1351
9.68k
  length = length >> 2;
1352
1353
656k
  for (i = length - 1; i >= 0; i--) {
1354
646k
    temp1 = *temp_ptr;
1355
646k
    temp2 = *(temp_ptr + 1);
1356
646k
    *temp_ptr++ = temp1 >> shift_val;
1357
646k
    temp1 = *(temp_ptr + 1);
1358
646k
    *temp_ptr++ = temp2 >> shift_val;
1359
646k
    temp2 = *(temp_ptr + 1);
1360
646k
    *temp_ptr++ = temp1 >> shift_val;
1361
646k
    *temp_ptr++ = temp2 >> shift_val;
1362
646k
  }
1363
9.68k
}