xref: /aosp_15_r20/external/libxaac/decoder/ixheaacd_adts_crc_check.c (revision 15dc779a375ca8b5125643b829a8aa4b70d7f451)
1*15dc779aSAndroid Build Coastguard Worker /******************************************************************************
2*15dc779aSAndroid Build Coastguard Worker  *                                                                            *
3*15dc779aSAndroid Build Coastguard Worker  * Copyright (C) 2018 The Android Open Source Project
4*15dc779aSAndroid Build Coastguard Worker  *
5*15dc779aSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
6*15dc779aSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
7*15dc779aSAndroid Build Coastguard Worker  * You may obtain a copy of the License at:
8*15dc779aSAndroid Build Coastguard Worker  *
9*15dc779aSAndroid Build Coastguard Worker  * http://www.apache.org/licenses/LICENSE-2.0
10*15dc779aSAndroid Build Coastguard Worker  *
11*15dc779aSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
12*15dc779aSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
13*15dc779aSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14*15dc779aSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
15*15dc779aSAndroid Build Coastguard Worker  * limitations under the License.
16*15dc779aSAndroid Build Coastguard Worker  *
17*15dc779aSAndroid Build Coastguard Worker  *****************************************************************************
18*15dc779aSAndroid Build Coastguard Worker  * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore
19*15dc779aSAndroid Build Coastguard Worker */
20*15dc779aSAndroid Build Coastguard Worker #include "ixheaac_type_def.h"
21*15dc779aSAndroid Build Coastguard Worker #include "ixheaac_constants.h"
22*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_memory_standards.h"
23*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_mps_struct_def.h"
24*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_mps_res_rom.h"
25*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_defines.h"
26*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_mps_aac_struct.h"
27*15dc779aSAndroid Build Coastguard Worker 
28*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_sbr_common.h"
29*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_bitbuffer.h"
30*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_defines.h"
31*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_aac_rom.h"
32*15dc779aSAndroid Build Coastguard Worker 
33*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_sbrdecsettings.h"
34*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_sbr_scale.h"
35*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_env_extr_part.h"
36*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_sbr_rom.h"
37*15dc779aSAndroid Build Coastguard Worker 
38*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_common_rom.h"
39*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_pulsedata.h"
40*15dc779aSAndroid Build Coastguard Worker 
41*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_pns.h"
42*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_drc_data_struct.h"
43*15dc779aSAndroid Build Coastguard Worker 
44*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_lt_predict.h"
45*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_cnst.h"
46*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_ec_defines.h"
47*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_ec_struct_def.h"
48*15dc779aSAndroid Build Coastguard Worker 
49*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_channelinfo.h"
50*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_drc_dec.h"
51*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_sbrdecoder.h"
52*15dc779aSAndroid Build Coastguard Worker 
53*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_channel.h"
54*15dc779aSAndroid Build Coastguard Worker 
55*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_audioobjtypes.h"
56*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_memory_standards.h"
57*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_adts.h"
58*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_audioobjtypes.h"
59*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_latmdemux.h"
60*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_aacdec.h"
61*15dc779aSAndroid Build Coastguard Worker 
62*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_hybrid.h"
63*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_ps_dec.h"
64*15dc779aSAndroid Build Coastguard Worker 
65*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_mps_polyphase.h"
66*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_config.h"
67*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_qmf_dec.h"
68*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_mps_dec.h"
69*15dc779aSAndroid Build Coastguard Worker 
70*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_struct_def.h"
71*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_error_codes.h"
72*15dc779aSAndroid Build Coastguard Worker 
73*15dc779aSAndroid Build Coastguard Worker #include "ixheaacd_adts_crc_check.h"
74*15dc779aSAndroid Build Coastguard Worker 
ixheaacd_adts_crc_open(ia_adts_crc_info_struct * ptr_adts_crc_info)75*15dc779aSAndroid Build Coastguard Worker VOID ixheaacd_adts_crc_open(ia_adts_crc_info_struct *ptr_adts_crc_info) {
76*15dc779aSAndroid Build Coastguard Worker   WORD32 i, j;
77*15dc779aSAndroid Build Coastguard Worker   UWORD16 val;
78*15dc779aSAndroid Build Coastguard Worker 
79*15dc779aSAndroid Build Coastguard Worker   ptr_adts_crc_info->no_reg = 0;
80*15dc779aSAndroid Build Coastguard Worker   ptr_adts_crc_info->crc_active = 0;
81*15dc779aSAndroid Build Coastguard Worker 
82*15dc779aSAndroid Build Coastguard Worker   for (i = 0; i <= 255; ++i) {
83*15dc779aSAndroid Build Coastguard Worker     for (val = i << 8, j = 8; --j >= 0;) {
84*15dc779aSAndroid Build Coastguard Worker       val = (val & 0x8000) ? (val << 1) ^ 0x8005 : val << 1;
85*15dc779aSAndroid Build Coastguard Worker     }
86*15dc779aSAndroid Build Coastguard Worker 
87*15dc779aSAndroid Build Coastguard Worker     ptr_adts_crc_info->crc_lookup[i] = val;
88*15dc779aSAndroid Build Coastguard Worker   }
89*15dc779aSAndroid Build Coastguard Worker }
90*15dc779aSAndroid Build Coastguard Worker 
ixheaacd_copy_bit_buf_state(ia_bit_buf_struct * it_bit_buff_src,ia_crc_bit_buf_struct_handle it_crc_bit_buff_dst)91*15dc779aSAndroid Build Coastguard Worker VOID ixheaacd_copy_bit_buf_state(
92*15dc779aSAndroid Build Coastguard Worker     ia_bit_buf_struct *it_bit_buff_src,
93*15dc779aSAndroid Build Coastguard Worker     ia_crc_bit_buf_struct_handle it_crc_bit_buff_dst) {
94*15dc779aSAndroid Build Coastguard Worker   it_crc_bit_buff_dst->ptr_bit_buf_base = it_bit_buff_src->ptr_bit_buf_base;
95*15dc779aSAndroid Build Coastguard Worker   it_crc_bit_buff_dst->ptr_bit_buf_end = it_bit_buff_src->ptr_bit_buf_end;
96*15dc779aSAndroid Build Coastguard Worker   it_crc_bit_buff_dst->ptr_read_next = it_bit_buff_src->ptr_read_next;
97*15dc779aSAndroid Build Coastguard Worker   it_crc_bit_buff_dst->bit_pos = it_bit_buff_src->bit_pos;
98*15dc779aSAndroid Build Coastguard Worker   it_crc_bit_buff_dst->cnt_bits = it_bit_buff_src->cnt_bits;
99*15dc779aSAndroid Build Coastguard Worker   it_crc_bit_buff_dst->size = it_bit_buff_src->size;
100*15dc779aSAndroid Build Coastguard Worker }
101*15dc779aSAndroid Build Coastguard Worker 
ixheaacd_adts_crc_start_reg(ia_adts_crc_info_struct * ptr_adts_crc_info,ia_bit_buf_struct * it_bit_buff_src,WORD32 no_bits)102*15dc779aSAndroid Build Coastguard Worker WORD32 ixheaacd_adts_crc_start_reg(ia_adts_crc_info_struct *ptr_adts_crc_info,
103*15dc779aSAndroid Build Coastguard Worker                                    ia_bit_buf_struct *it_bit_buff_src,
104*15dc779aSAndroid Build Coastguard Worker                                    WORD32 no_bits) {
105*15dc779aSAndroid Build Coastguard Worker   UWORD32 no_bytes;
106*15dc779aSAndroid Build Coastguard Worker 
107*15dc779aSAndroid Build Coastguard Worker   ptr_adts_crc_info->str_crc_reg_data[ptr_adts_crc_info->no_reg].bit_cnt = 0;
108*15dc779aSAndroid Build Coastguard Worker   ptr_adts_crc_info->str_crc_reg_data[ptr_adts_crc_info->no_reg].max_bits =
109*15dc779aSAndroid Build Coastguard Worker       no_bits;
110*15dc779aSAndroid Build Coastguard Worker 
111*15dc779aSAndroid Build Coastguard Worker   if (no_bits < 0) {
112*15dc779aSAndroid Build Coastguard Worker     no_bits = -no_bits;
113*15dc779aSAndroid Build Coastguard Worker   }
114*15dc779aSAndroid Build Coastguard Worker 
115*15dc779aSAndroid Build Coastguard Worker   if (no_bits == 0) {
116*15dc779aSAndroid Build Coastguard Worker     no_bits = 16 << 3;
117*15dc779aSAndroid Build Coastguard Worker   }
118*15dc779aSAndroid Build Coastguard Worker 
119*15dc779aSAndroid Build Coastguard Worker   no_bytes = no_bits >> 3;
120*15dc779aSAndroid Build Coastguard Worker 
121*15dc779aSAndroid Build Coastguard Worker   if (no_bytes << 3 < (UWORD32)no_bits) {
122*15dc779aSAndroid Build Coastguard Worker     no_bytes++;
123*15dc779aSAndroid Build Coastguard Worker   }
124*15dc779aSAndroid Build Coastguard Worker 
125*15dc779aSAndroid Build Coastguard Worker   ptr_adts_crc_info->str_crc_reg_data[ptr_adts_crc_info->no_reg].buf_size =
126*15dc779aSAndroid Build Coastguard Worker       no_bytes;
127*15dc779aSAndroid Build Coastguard Worker   ptr_adts_crc_info->str_crc_reg_data[ptr_adts_crc_info->no_reg].active = 1;
128*15dc779aSAndroid Build Coastguard Worker 
129*15dc779aSAndroid Build Coastguard Worker   ixheaacd_copy_bit_buf_state(
130*15dc779aSAndroid Build Coastguard Worker       it_bit_buff_src,
131*15dc779aSAndroid Build Coastguard Worker       &(ptr_adts_crc_info->str_crc_reg_data[ptr_adts_crc_info->no_reg]
132*15dc779aSAndroid Build Coastguard Worker             .str_bit_buf));
133*15dc779aSAndroid Build Coastguard Worker 
134*15dc779aSAndroid Build Coastguard Worker   ptr_adts_crc_info->no_reg += 1;
135*15dc779aSAndroid Build Coastguard Worker 
136*15dc779aSAndroid Build Coastguard Worker   return (ptr_adts_crc_info->no_reg - 1);
137*15dc779aSAndroid Build Coastguard Worker }
138*15dc779aSAndroid Build Coastguard Worker 
ixheaacd_adts_crc_end_reg(ia_adts_crc_info_struct * ptr_adts_crc_info,ia_bit_buf_struct * it_bit_buff_src,WORD32 reg)139*15dc779aSAndroid Build Coastguard Worker VOID ixheaacd_adts_crc_end_reg(ia_adts_crc_info_struct *ptr_adts_crc_info,
140*15dc779aSAndroid Build Coastguard Worker                                ia_bit_buf_struct *it_bit_buff_src, WORD32 reg) {
141*15dc779aSAndroid Build Coastguard Worker   ptr_adts_crc_info->str_crc_reg_data[reg].active = 0;
142*15dc779aSAndroid Build Coastguard Worker   ptr_adts_crc_info->str_crc_reg_data[reg].bit_buf_cnt =
143*15dc779aSAndroid Build Coastguard Worker       ptr_adts_crc_info->str_crc_reg_data[reg].str_bit_buf.cnt_bits -
144*15dc779aSAndroid Build Coastguard Worker       it_bit_buff_src->cnt_bits;
145*15dc779aSAndroid Build Coastguard Worker }
146*15dc779aSAndroid Build Coastguard Worker 
ixheaacd_adts_crc_fast_crc(ia_adts_crc_info_struct * ptr_adts_crc_info,UWORD16 * crc_reg,UWORD8 feed)147*15dc779aSAndroid Build Coastguard Worker VOID ixheaacd_adts_crc_fast_crc(ia_adts_crc_info_struct *ptr_adts_crc_info,
148*15dc779aSAndroid Build Coastguard Worker                                 UWORD16 *crc_reg, UWORD8 feed) {
149*15dc779aSAndroid Build Coastguard Worker   *crc_reg =
150*15dc779aSAndroid Build Coastguard Worker       (*crc_reg << 8) ^ ptr_adts_crc_info->crc_lookup[(*crc_reg >> 8) ^ feed];
151*15dc779aSAndroid Build Coastguard Worker }
152*15dc779aSAndroid Build Coastguard Worker 
ixheaacd_adts_crc_slow_crc(UWORD16 * crc_reg,UWORD8 feed,UWORD32 no_bits)153*15dc779aSAndroid Build Coastguard Worker VOID ixheaacd_adts_crc_slow_crc(UWORD16 *crc_reg, UWORD8 feed,
154*15dc779aSAndroid Build Coastguard Worker                                 UWORD32 no_bits) {
155*15dc779aSAndroid Build Coastguard Worker   UWORD32 i;
156*15dc779aSAndroid Build Coastguard Worker   UWORD16 tmp;
157*15dc779aSAndroid Build Coastguard Worker   for (i = 0; i < no_bits; i++) {
158*15dc779aSAndroid Build Coastguard Worker     tmp = (feed & (1 << (7 - i))) >> (7 - i);
159*15dc779aSAndroid Build Coastguard Worker     tmp ^= (*crc_reg & (1 << 15)) >> 15;
160*15dc779aSAndroid Build Coastguard Worker     tmp *= 32773;
161*15dc779aSAndroid Build Coastguard Worker     *crc_reg <<= 1;
162*15dc779aSAndroid Build Coastguard Worker     *crc_reg ^= tmp;
163*15dc779aSAndroid Build Coastguard Worker   }
164*15dc779aSAndroid Build Coastguard Worker }
165*15dc779aSAndroid Build Coastguard Worker 
ixheaacd_adts_crc_check_crc(ia_adts_crc_info_struct * ptr_adts_crc_info)166*15dc779aSAndroid Build Coastguard Worker WORD32 ixheaacd_adts_crc_check_crc(ia_adts_crc_info_struct *ptr_adts_crc_info) {
167*15dc779aSAndroid Build Coastguard Worker   WORD32 error_code = AAC_DEC_OK;
168*15dc779aSAndroid Build Coastguard Worker   UWORD16 crc = 65535;
169*15dc779aSAndroid Build Coastguard Worker   WORD32 reg;
170*15dc779aSAndroid Build Coastguard Worker   ia_crc_reg_data_struct *ptr_reg_data;
171*15dc779aSAndroid Build Coastguard Worker 
172*15dc779aSAndroid Build Coastguard Worker   for (reg = 0; reg < ptr_adts_crc_info->no_reg; reg++) {
173*15dc779aSAndroid Build Coastguard Worker     UWORD8 bits;
174*15dc779aSAndroid Build Coastguard Worker     WORD32 bits_remaining;
175*15dc779aSAndroid Build Coastguard Worker 
176*15dc779aSAndroid Build Coastguard Worker     ptr_reg_data = &ptr_adts_crc_info->str_crc_reg_data[reg];
177*15dc779aSAndroid Build Coastguard Worker 
178*15dc779aSAndroid Build Coastguard Worker     if (ptr_reg_data->max_bits > 0) {
179*15dc779aSAndroid Build Coastguard Worker       if (ptr_adts_crc_info->str_crc_reg_data[reg].bit_buf_cnt >
180*15dc779aSAndroid Build Coastguard Worker           ptr_reg_data->max_bits)
181*15dc779aSAndroid Build Coastguard Worker         bits_remaining = ptr_reg_data->max_bits;
182*15dc779aSAndroid Build Coastguard Worker       else
183*15dc779aSAndroid Build Coastguard Worker         bits_remaining = ptr_adts_crc_info->str_crc_reg_data[reg].bit_buf_cnt;
184*15dc779aSAndroid Build Coastguard Worker     } else {
185*15dc779aSAndroid Build Coastguard Worker       bits_remaining = ptr_adts_crc_info->str_crc_reg_data[reg].bit_buf_cnt;
186*15dc779aSAndroid Build Coastguard Worker     }
187*15dc779aSAndroid Build Coastguard Worker 
188*15dc779aSAndroid Build Coastguard Worker     while (bits_remaining >= 8) {
189*15dc779aSAndroid Build Coastguard Worker       if (ptr_reg_data->str_bit_buf.cnt_bits < 8) {
190*15dc779aSAndroid Build Coastguard Worker         return IA_XHEAAC_DEC_EXE_NONFATAL_INSUFFICIENT_INPUT_BYTES;
191*15dc779aSAndroid Build Coastguard Worker       }
192*15dc779aSAndroid Build Coastguard Worker       bits = (UWORD8)ixheaacd_read_bits_buf(
193*15dc779aSAndroid Build Coastguard Worker           (ia_bit_buf_struct *)(&ptr_adts_crc_info->str_crc_reg_data[reg]
194*15dc779aSAndroid Build Coastguard Worker                                      .str_bit_buf),
195*15dc779aSAndroid Build Coastguard Worker           8);
196*15dc779aSAndroid Build Coastguard Worker       ixheaacd_adts_crc_fast_crc(ptr_adts_crc_info, &crc, bits);
197*15dc779aSAndroid Build Coastguard Worker       bits_remaining -= 8;
198*15dc779aSAndroid Build Coastguard Worker     }
199*15dc779aSAndroid Build Coastguard Worker 
200*15dc779aSAndroid Build Coastguard Worker     if (ptr_reg_data->str_bit_buf.cnt_bits < bits_remaining) {
201*15dc779aSAndroid Build Coastguard Worker       return IA_XHEAAC_DEC_EXE_NONFATAL_INSUFFICIENT_INPUT_BYTES;
202*15dc779aSAndroid Build Coastguard Worker     }
203*15dc779aSAndroid Build Coastguard Worker     bits = (UWORD8)ixheaacd_read_bits_buf(
204*15dc779aSAndroid Build Coastguard Worker         (ia_bit_buf_struct *)(&ptr_adts_crc_info->str_crc_reg_data[reg]
205*15dc779aSAndroid Build Coastguard Worker                                    .str_bit_buf),
206*15dc779aSAndroid Build Coastguard Worker         bits_remaining);
207*15dc779aSAndroid Build Coastguard Worker     ixheaacd_adts_crc_slow_crc(&crc, (UWORD8)(bits << (8 - bits_remaining)),
208*15dc779aSAndroid Build Coastguard Worker                                bits_remaining);
209*15dc779aSAndroid Build Coastguard Worker 
210*15dc779aSAndroid Build Coastguard Worker     if (ptr_reg_data->max_bits >
211*15dc779aSAndroid Build Coastguard Worker         ptr_adts_crc_info->str_crc_reg_data[reg].bit_buf_cnt) {
212*15dc779aSAndroid Build Coastguard Worker       bits_remaining = ptr_reg_data->max_bits -
213*15dc779aSAndroid Build Coastguard Worker                        ptr_adts_crc_info->str_crc_reg_data[reg].bit_buf_cnt;
214*15dc779aSAndroid Build Coastguard Worker 
215*15dc779aSAndroid Build Coastguard Worker       for (; bits_remaining >= 8; bits_remaining -= 8) {
216*15dc779aSAndroid Build Coastguard Worker         ixheaacd_adts_crc_fast_crc(ptr_adts_crc_info, &crc, 0);
217*15dc779aSAndroid Build Coastguard Worker       }
218*15dc779aSAndroid Build Coastguard Worker 
219*15dc779aSAndroid Build Coastguard Worker       ixheaacd_adts_crc_slow_crc(&crc, 0, bits_remaining);
220*15dc779aSAndroid Build Coastguard Worker     }
221*15dc779aSAndroid Build Coastguard Worker   }
222*15dc779aSAndroid Build Coastguard Worker 
223*15dc779aSAndroid Build Coastguard Worker   ptr_adts_crc_info->no_reg = 0;
224*15dc779aSAndroid Build Coastguard Worker 
225*15dc779aSAndroid Build Coastguard Worker   if (crc != ptr_adts_crc_info->file_value) {
226*15dc779aSAndroid Build Coastguard Worker     return (IA_XHEAAC_DEC_EXE_NONFATAL_ADTS_HDR_CRC_FAIL);
227*15dc779aSAndroid Build Coastguard Worker   }
228*15dc779aSAndroid Build Coastguard Worker 
229*15dc779aSAndroid Build Coastguard Worker   return (error_code);
230*15dc779aSAndroid Build Coastguard Worker }
231