Home | History | Annotate | Download | only in decoder
      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_type_def.h>
     21 #include "ixheaacd_sbr_common.h"
     22 #include <ixheaacd_type_def.h>
     23 #include "ixheaacd_bitbuffer.h"
     24 #include "ixheaacd_defines.h"
     25 #include <ixheaacd_aac_rom.h>
     26 
     27 #include "ixheaacd_sbrdecsettings.h"
     28 #include "ixheaacd_env_extr_part.h"
     29 #include <ixheaacd_sbr_rom.h>
     30 
     31 #include "ixheaacd_common_rom.h"
     32 #include "ixheaacd_pulsedata.h"
     33 
     34 #include "ixheaacd_pns.h"
     35 #include "ixheaacd_drc_data_struct.h"
     36 
     37 #include "ixheaacd_lt_predict.h"
     38 
     39 #include "ixheaacd_channelinfo.h"
     40 #include "ixheaacd_drc_dec.h"
     41 #include "ixheaacd_sbrdecoder.h"
     42 
     43 #include "ixheaacd_channel.h"
     44 
     45 #include "ixheaacd_audioobjtypes.h"
     46 #include "ixheaacd_memory_standards.h"
     47 #include "ixheaacd_adts.h"
     48 #include "ixheaacd_audioobjtypes.h"
     49 #include "ixheaacd_latmdemux.h"
     50 #include "ixheaacd_aacdec.h"
     51 
     52 #include "ixheaacd_mps_polyphase.h"
     53 #include "ixheaacd_config.h"
     54 #include "ixheaacd_mps_dec.h"
     55 
     56 #include "ixheaacd_struct_def.h"
     57 #include "ixheaacd_error_codes.h"
     58 
     59 #include "ixheaacd_adts_crc_check.h"
     60 
     61 VOID ixheaacd_adts_crc_open(ia_adts_crc_info_struct *ptr_adts_crc_info) {
     62   WORD32 i, j;
     63   UWORD16 val;
     64 
     65   ptr_adts_crc_info->no_reg = 0;
     66   ptr_adts_crc_info->crc_active = 0;
     67 
     68   for (i = 0; i <= 255; ++i) {
     69     for (val = i << 8, j = 8; --j >= 0;) {
     70       val = (val & 0x8000) ? (val << 1) ^ 0x8005 : val << 1;
     71     }
     72 
     73     ptr_adts_crc_info->crc_lookup[i] = val;
     74   }
     75 }
     76 
     77 VOID ixheaacd_copy_bit_buf_state(
     78     ia_bit_buf_struct *it_bit_buff_src,
     79     ia_crc_bit_buf_struct_handle it_crc_bit_buff_dst) {
     80   it_crc_bit_buff_dst->ptr_bit_buf_base = it_bit_buff_src->ptr_bit_buf_base;
     81   it_crc_bit_buff_dst->ptr_bit_buf_end = it_bit_buff_src->ptr_bit_buf_end;
     82   it_crc_bit_buff_dst->ptr_read_next = it_bit_buff_src->ptr_read_next;
     83   it_crc_bit_buff_dst->bit_pos = it_bit_buff_src->bit_pos;
     84   it_crc_bit_buff_dst->cnt_bits = it_bit_buff_src->cnt_bits;
     85   it_crc_bit_buff_dst->size = it_bit_buff_src->size;
     86 }
     87 
     88 WORD32 ixheaacd_adts_crc_start_reg(ia_adts_crc_info_struct *ptr_adts_crc_info,
     89                                    ia_bit_buf_struct *it_bit_buff_src,
     90                                    WORD32 no_bits) {
     91   UWORD32 no_bytes;
     92 
     93   ptr_adts_crc_info->str_crc_reg_data[ptr_adts_crc_info->no_reg].bit_cnt = 0;
     94   ptr_adts_crc_info->str_crc_reg_data[ptr_adts_crc_info->no_reg].max_bits =
     95       no_bits;
     96 
     97   if (no_bits < 0) {
     98     no_bits = -no_bits;
     99   }
    100 
    101   if (no_bits == 0) {
    102     no_bits = 16 << 3;
    103   }
    104 
    105   no_bytes = no_bits >> 3;
    106 
    107   if (no_bytes << 3 < (UWORD32)no_bits) {
    108     no_bytes++;
    109   }
    110 
    111   ptr_adts_crc_info->str_crc_reg_data[ptr_adts_crc_info->no_reg].buf_size =
    112       no_bytes;
    113   ptr_adts_crc_info->str_crc_reg_data[ptr_adts_crc_info->no_reg].active = 1;
    114 
    115   ixheaacd_copy_bit_buf_state(
    116       it_bit_buff_src,
    117       &(ptr_adts_crc_info->str_crc_reg_data[ptr_adts_crc_info->no_reg]
    118             .str_bit_buf));
    119 
    120   ptr_adts_crc_info->no_reg += 1;
    121 
    122   return (ptr_adts_crc_info->no_reg - 1);
    123 }
    124 
    125 VOID ixheaacd_adts_crc_end_reg(ia_adts_crc_info_struct *ptr_adts_crc_info,
    126                                ia_bit_buf_struct *it_bit_buff_src, WORD32 reg) {
    127   ptr_adts_crc_info->str_crc_reg_data[reg].active = 0;
    128   ptr_adts_crc_info->str_crc_reg_data[reg].bit_buf_cnt =
    129       ptr_adts_crc_info->str_crc_reg_data[reg].str_bit_buf.cnt_bits -
    130       it_bit_buff_src->cnt_bits;
    131 }
    132 
    133 VOID ixheaacd_adts_crc_fast_crc(ia_adts_crc_info_struct *ptr_adts_crc_info,
    134                                 UWORD16 *crc_reg, UWORD8 feed) {
    135   *crc_reg =
    136       (*crc_reg << 8) ^ ptr_adts_crc_info->crc_lookup[(*crc_reg >> 8) ^ feed];
    137 }
    138 
    139 VOID ixheaacd_adts_crc_slow_crc(UWORD16 *crc_reg, UWORD8 feed,
    140                                 UWORD32 no_bits) {
    141   UWORD32 i;
    142   UWORD16 tmp;
    143   for (i = 0; i < no_bits; i++) {
    144     tmp = (feed & (1 << (7 - i))) >> (7 - i);
    145     tmp ^= (*crc_reg & (1 << 15)) >> 15;
    146     tmp *= 32773;
    147     *crc_reg <<= 1;
    148     *crc_reg ^= tmp;
    149   }
    150 }
    151 
    152 WORD32 ixheaacd_adts_crc_check_crc(ia_adts_crc_info_struct *ptr_adts_crc_info) {
    153   WORD32 error_code = AAC_DEC_OK;
    154   UWORD16 crc = 65535;
    155   WORD32 reg;
    156   ia_crc_reg_data_struct *ptr_reg_data;
    157 
    158   for (reg = 0; reg < ptr_adts_crc_info->no_reg; reg++) {
    159     UWORD8 bits;
    160     UWORD32 bits_remaining;
    161 
    162     ptr_reg_data = &ptr_adts_crc_info->str_crc_reg_data[reg];
    163 
    164     if (ptr_reg_data->max_bits > 0) {
    165       if (ptr_adts_crc_info->str_crc_reg_data[reg].bit_buf_cnt >
    166           ptr_reg_data->max_bits)
    167         bits_remaining = ptr_reg_data->max_bits;
    168       else
    169         bits_remaining = ptr_adts_crc_info->str_crc_reg_data[reg].bit_buf_cnt;
    170     } else {
    171       bits_remaining = ptr_adts_crc_info->str_crc_reg_data[reg].bit_buf_cnt;
    172     }
    173 
    174     while (bits_remaining >= 8) {
    175       bits = (UWORD8)ixheaacd_read_bits_buf(
    176           (ia_bit_buf_struct *)(&ptr_adts_crc_info->str_crc_reg_data[reg]
    177                                      .str_bit_buf),
    178           8);
    179       ixheaacd_adts_crc_fast_crc(ptr_adts_crc_info, &crc, bits);
    180       bits_remaining -= 8;
    181     }
    182 
    183     bits = (UWORD8)ixheaacd_read_bits_buf(
    184         (ia_bit_buf_struct *)(&ptr_adts_crc_info->str_crc_reg_data[reg]
    185                                    .str_bit_buf),
    186         bits_remaining);
    187     ixheaacd_adts_crc_slow_crc(&crc, (UWORD8)(bits << (8 - bits_remaining)),
    188                                bits_remaining);
    189 
    190     if (ptr_reg_data->max_bits >
    191         ptr_adts_crc_info->str_crc_reg_data[reg].bit_buf_cnt) {
    192       bits_remaining = ptr_reg_data->max_bits -
    193                        ptr_adts_crc_info->str_crc_reg_data[reg].bit_buf_cnt;
    194 
    195       for (; bits_remaining >= 8; bits_remaining -= 8) {
    196         ixheaacd_adts_crc_fast_crc(ptr_adts_crc_info, &crc, 0);
    197       }
    198 
    199       ixheaacd_adts_crc_slow_crc(&crc, 0, bits_remaining);
    200     }
    201   }
    202 
    203   ptr_adts_crc_info->no_reg = 0;
    204 
    205   if (crc != ptr_adts_crc_info->file_value) {
    206     return (IA_ENHAACPLUS_DEC_EXE_NONFATAL_ADTS_HDR_CRC_FAIL);
    207   }
    208 
    209   return (error_code);
    210 }
    211