Coverage Report

Created: 2026-05-08 06:29

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/libxaac/decoder/ixheaacd_longblock.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 "ixheaacd_sbr_common.h"
21
#include "ixheaac_type_def.h"
22
#include "ixheaac_constants.h"
23
#include "ixheaac_basic_ops32.h"
24
#include "ixheaac_basic_ops16.h"
25
#include "ixheaac_basic_ops40.h"
26
#include "ixheaac_basic_ops.h"
27
28
#include "ixheaacd_defines.h"
29
#include "ixheaacd_aac_rom.h"
30
#include "ixheaacd_aac_imdct.h"
31
#include "ixheaacd_bitbuffer.h"
32
#include "ixheaac_basic_op.h"
33
#include "ixheaacd_intrinsics.h"
34
35
#include "ixheaacd_pulsedata.h"
36
37
#include "ixheaacd_pns.h"
38
#include "ixheaacd_common_rom.h"
39
#include "ixheaacd_drc_data_struct.h"
40
41
#include "ixheaacd_lt_predict.h"
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 "ixheaacd_pulsedata.h"
52
#include "ixheaacd_pns.h"
53
#include "ixheaacd_sbrdecoder.h"
54
#include "ixheaacd_error_codes.h"
55
#include "ixheaacd_audioobjtypes.h"
56
#include "ixheaacd_latmdemux.h"
57
#include "ixheaacd_aacdec.h"
58
59
261k
#define LONG_BLOCK_SECT_LEN 5
60
46.9k
#define SHORT_BLOCK_SECT_LEN 3
61
62
IA_ERRORCODE ixheaacd_read_section_data(
63
    ia_bit_buf_struct *it_bit_buff,
64
    ia_aac_dec_channel_info_struct *ptr_aac_dec_channel_info,
65
    WORD32 aac_spect_data_resil_flag, WORD32 aac_sect_data_resil_flag,
66
261k
    ia_aac_dec_tables_struct *ptr_aac_tables) {
67
261k
  WORD sfb;
68
261k
  WORD sect_cb;
69
261k
  WORD sect_len;
70
261k
  WORD sect_len_incr;
71
261k
  WORD sect_esc_val;
72
261k
  ia_ics_info_struct *ptr_ics_info = &ptr_aac_dec_channel_info->str_ics_info;
73
261k
  WORD max_sfb = ptr_ics_info->max_sfb;
74
261k
  WORD num_win_group;
75
76
261k
  WORD8 *ptr_code_book = ptr_aac_dec_channel_info->ptr_code_book;
77
261k
  WORD8 *ptr_code_book_temp = ptr_code_book;
78
261k
  WORD32 sect_bitlen = LONG_BLOCK_SECT_LEN;
79
261k
  int num_lines_sec_idx = 0, top;
80
261k
  short *ptr_num_sect_lines =
81
261k
      ptr_aac_dec_channel_info->num_line_in_sec4_hcr_arr;
82
261k
  UWORD8 *ptr_hcr_code_book = ptr_aac_dec_channel_info->cb4_hcr_arr;
83
261k
  const short *band_offsets = (WORD16 *)ixheaacd_getscalefactorbandoffsets(
84
261k
      &(ptr_aac_dec_channel_info->str_ics_info), ptr_aac_tables);
85
261k
  ptr_aac_dec_channel_info->number_sect = 0;
86
87
261k
  if (ptr_aac_dec_channel_info->str_ics_info.window_sequence ==
88
261k
      EIGHT_SHORT_SEQUENCE) {
89
46.9k
    sect_bitlen = SHORT_BLOCK_SECT_LEN;
90
46.9k
  }
91
92
261k
  sect_esc_val = (1 << sect_bitlen) - 1;
93
94
670k
  for (num_win_group = 0; num_win_group < ptr_ics_info->num_window_groups;
95
411k
       num_win_group++) {
96
411k
    sfb = 0;
97
98
1.41M
    while (sfb < max_sfb) {
99
1.00M
      sect_len = 0;
100
1.00M
      if (aac_sect_data_resil_flag) {
101
555k
        sect_cb = ixheaacd_read_bits_buf(it_bit_buff, 5);
102
555k
      } else {
103
447k
        sect_cb = ixheaacd_read_bits_buf(it_bit_buff, 4);
104
447k
      }
105
106
1.00M
      if ((aac_sect_data_resil_flag == 0) ||
107
675k
          ((sect_cb < 11) || ((sect_cb > 11) && (sect_cb < 16)))) {
108
675k
        sect_len_incr = ixheaacd_read_bits_buf(it_bit_buff, sect_bitlen);
109
689k
        while (sect_len_incr == sect_esc_val) {
110
14.2k
          sect_len = (sect_len + sect_esc_val);
111
14.2k
          sect_len_incr = ixheaacd_read_bits_buf(it_bit_buff, sect_bitlen);
112
14.2k
        }
113
675k
      } else
114
326k
        sect_len_incr = 1;
115
116
1.00M
      sect_len = (sect_len + sect_len_incr);
117
118
1.00M
      if (aac_spect_data_resil_flag) {
119
392k
        top = (sfb + sect_len);
120
392k
        if ((num_lines_sec_idx >= MAX_SFB_HCR) ||
121
392k
            (top >= MAX_SCALE_FACTOR_BANDS_LONG)) {
122
27
          return -1;
123
27
        }
124
392k
        ptr_num_sect_lines[num_lines_sec_idx] =
125
392k
            band_offsets[top] - band_offsets[sfb];
126
392k
        num_lines_sec_idx++;
127
392k
        if (sect_cb == (ESC_HCB + 1)) {
128
319
          return IA_XHEAAC_DEC_EXE_NONFATAL_INVALID_CODE_BOOK;
129
392k
        } else {
130
392k
          *ptr_hcr_code_book++ = sect_cb;
131
392k
        }
132
392k
        ptr_aac_dec_channel_info->number_sect++;
133
392k
      }
134
135
1.00M
      sfb = (sfb + sect_len);
136
1.00M
      if (sfb > max_sfb) {
137
1.21k
        return (WORD16)(
138
1.21k
            (WORD32)IA_XHEAAC_DEC_EXE_NONFATAL_EXCEEDS_SFB_TRANSMITTED);
139
1.21k
      }
140
1.00M
      if (sect_cb == (ESC_HCB + 1)) {
141
154
        return (WORD16)(
142
154
            (WORD32)IA_XHEAAC_DEC_EXE_NONFATAL_INVALID_CODE_BOOK);
143
154
      }
144
145
4.42M
      while (sect_len--) {
146
3.42M
        *ptr_code_book_temp++ = sect_cb;
147
3.42M
      }
148
1.00M
    }
149
409k
    ptr_code_book += MAX_SCALE_FACTOR_BANDS_SHORT;
150
409k
    ptr_code_book_temp = ptr_code_book;
151
409k
  }
152
153
259k
  return AAC_DEC_OK;
154
261k
}
155
156
VOID ixheaacd_read_scale_factor_data(
157
    ia_bit_buf_struct *it_bit_buff,
158
    ia_aac_dec_channel_info_struct *ptr_aac_dec_channel_info,
159
200k
    ia_aac_dec_tables_struct *ptr_aac_tables, WORD32 object_type) {
160
200k
  WORD sfb;
161
200k
  WORD16 position = 0;
162
200k
  WORD num_win_group;
163
200k
  WORD16 factor = ptr_aac_dec_channel_info->global_gain;
164
200k
  WORD8 *ptr_code_book, *ptr_code_book_short;
165
200k
  WORD16 *ptr_scale_fact, *ptr_scale_fact_short;
166
200k
  WORD16 norm_value;
167
200k
  WORD16 index, length;
168
200k
  const UWORD16 *hcod_sf =
169
200k
      ptr_aac_tables->pstr_huffmann_tables->huffman_code_book_scl;
170
200k
  const UWORD32 *table_idx =
171
200k
      ptr_aac_tables->pstr_huffmann_tables->huffman_code_book_scl_index;
172
173
200k
  WORD start_bit_pos = it_bit_buff->bit_pos;
174
200k
  UWORD8 *start_read_pos = it_bit_buff->ptr_read_next;
175
200k
  UWORD8 *ptr_read_next = it_bit_buff->ptr_read_next;
176
200k
  WORD32 bit_pos = 7 - it_bit_buff->bit_pos;
177
200k
  WORD32 read_word;
178
200k
  WORD32 increment;
179
200k
  read_word = ixheaacd_aac_showbits_32(ptr_read_next, it_bit_buff->cnt_bits,
180
200k
                                       &increment);
181
200k
  ptr_read_next += increment;
182
183
200k
  ptr_code_book = ptr_aac_dec_channel_info->ptr_code_book;
184
185
200k
  ptr_scale_fact = ptr_aac_dec_channel_info->ptr_scale_factor;
186
187
200k
  for (num_win_group = 0;
188
538k
       num_win_group < ptr_aac_dec_channel_info->str_ics_info.num_window_groups;
189
338k
       num_win_group++) {
190
338k
    ptr_code_book_short =
191
338k
        &ptr_code_book[num_win_group * MAX_SCALE_FACTOR_BANDS_SHORT];
192
338k
    ptr_scale_fact_short =
193
338k
        &ptr_scale_fact[num_win_group * MAX_SCALE_FACTOR_BANDS_SHORT];
194
2.85M
    for (sfb = ptr_aac_dec_channel_info->str_ics_info.max_sfb - 1; sfb >= 0;
195
2.51M
         sfb--) {
196
2.51M
      WORD32 sfb_cb = *ptr_code_book_short++;
197
2.51M
      if (sfb_cb == ZERO_HCB)
198
633k
        *ptr_scale_fact_short++ = 0;
199
1.88M
      else {
200
1.88M
        {
201
1.88M
          WORD32 pns_present = 0;
202
1.88M
          WORD pns_band;
203
204
1.88M
          ia_pns_info_struct *ptr_pns_info =
205
1.88M
              &ptr_aac_dec_channel_info->str_pns_info;
206
207
1.88M
          if (sfb_cb == NOISE_HCB && (ptr_pns_info->pns_active != 1)) {
208
14.8k
            pns_present = 1;
209
14.8k
          }
210
211
1.88M
          if (!pns_present) {
212
1.86M
            UWORD32 read_word1;
213
214
1.86M
            read_word1 = read_word << bit_pos;
215
216
1.86M
            ixheaacd_huffman_decode(read_word1, &index, &length, hcod_sf,
217
1.86M
                                    table_idx);
218
219
1.86M
            bit_pos += length;
220
1.86M
            ixheaacd_aac_read_byte_corr(&ptr_read_next, &bit_pos, &read_word,
221
1.86M
                                        it_bit_buff->ptr_bit_buf_end);
222
223
1.86M
            ixheaacd_aac_read_byte_corr1(&ptr_read_next, &bit_pos, &read_word,
224
1.86M
                                         it_bit_buff->ptr_bit_buf_end);
225
226
1.86M
            norm_value = index - 60;
227
1.86M
          }
228
229
14.8k
          else {
230
14.8k
            WORD32 noise_start_value;
231
14.8k
            UWORD32 temp;
232
233
14.8k
            temp = (read_word << bit_pos);
234
14.8k
            temp = ((UWORD32)temp >> (32 - 9));
235
14.8k
            noise_start_value = temp;
236
14.8k
            bit_pos += 9;
237
238
14.8k
            ixheaacd_aac_read_byte_corr1(&ptr_read_next, &bit_pos, &read_word,
239
14.8k
                                         it_bit_buff->ptr_bit_buf_end);
240
241
14.8k
            norm_value = noise_start_value - 256;
242
14.8k
            ptr_pns_info->pns_active = 1;
243
244
14.8k
            ptr_pns_info->noise_energy =
245
14.8k
                ptr_aac_dec_channel_info->global_gain - NOISE_OFFSET;
246
14.8k
          }
247
248
1.88M
          if ((object_type != AOT_ER_AAC_ELD) &&
249
1.75M
              (object_type != AOT_ER_AAC_LD) && (object_type != AOT_ER_AAC_LC)) {
250
121k
            if (sfb_cb > NOISE_HCB) {
251
11.0k
              position = position + norm_value;
252
11.0k
              *ptr_scale_fact_short++ = -position;
253
110k
            } else if (sfb_cb < NOISE_HCB) {
254
65.7k
              factor = factor + norm_value;
255
65.7k
              *ptr_scale_fact_short++ = factor;
256
65.7k
            } else {
257
44.8k
              ptr_pns_info->noise_energy =
258
44.8k
                  ixheaac_add16_sat(ptr_pns_info->noise_energy, norm_value);
259
260
44.8k
              pns_band = (num_win_group << 4) +
261
44.8k
                         ptr_aac_dec_channel_info->str_ics_info.max_sfb - sfb -
262
44.8k
                         1;
263
44.8k
              ptr_aac_dec_channel_info->ptr_scale_factor[pns_band] =
264
44.8k
                  ptr_pns_info->noise_energy;
265
266
44.8k
              ptr_pns_info->pns_used[pns_band] = 1;
267
44.8k
              ptr_scale_fact_short++;
268
44.8k
            }
269
1.76M
          } else {
270
1.76M
            if ((sfb_cb == INTENSITY_HCB) || (sfb_cb == INTENSITY_HCB2)) {
271
212k
              position = position + norm_value;
272
212k
              *ptr_scale_fact_short++ = -position;
273
1.55M
            } else if (sfb_cb == NOISE_HCB) {
274
50.2k
              ptr_pns_info->noise_energy =
275
50.2k
                  ixheaac_add16_sat(ptr_pns_info->noise_energy, norm_value);
276
277
50.2k
              pns_band = (num_win_group << 4) +
278
50.2k
                         ptr_aac_dec_channel_info->str_ics_info.max_sfb - sfb -
279
50.2k
                         1;
280
50.2k
              ptr_aac_dec_channel_info->ptr_scale_factor[pns_band] =
281
50.2k
                  ptr_pns_info->noise_energy;
282
283
50.2k
              ptr_pns_info->pns_used[pns_band] = 1;
284
50.2k
              ptr_scale_fact_short++;
285
286
1.50M
            } else {
287
1.50M
              factor = factor + norm_value;
288
1.50M
              *ptr_scale_fact_short++ = factor;
289
1.50M
            }
290
1.76M
          }
291
1.88M
        }
292
1.88M
      }
293
2.51M
    }
294
338k
  }
295
296
200k
  it_bit_buff->ptr_read_next = ptr_read_next - increment;
297
298
200k
  it_bit_buff->bit_pos = 7 - bit_pos;
299
200k
  {
300
200k
    WORD bits_consumed;
301
200k
    bits_consumed =
302
200k
        (WORD)(((it_bit_buff->ptr_read_next - start_read_pos) << 3) +
303
200k
               (start_bit_pos - it_bit_buff->bit_pos));
304
200k
    it_bit_buff->cnt_bits -= bits_consumed;
305
200k
  }
306
200k
}