Home | History | Annotate | Download | only in armv7
      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 <stdio.h>
     21 #include <string.h>
     22 #include "ixheaacd_sbr_common.h"
     23 #include <ixheaacd_type_def.h>
     24 
     25 #include "ixheaacd_constants.h"
     26 #include <ixheaacd_basic_ops32.h>
     27 #include <ixheaacd_basic_ops16.h>
     28 #include <ixheaacd_basic_ops40.h>
     29 #include "ixheaacd_basic_ops.h"
     30 
     31 #include <ixheaacd_basic_op.h>
     32 #include "ixheaacd_intrinsics.h"
     33 #include "ixheaacd_common_rom.h"
     34 #include "ixheaacd_sbrdecsettings.h"
     35 #include "ixheaacd_bitbuffer.h"
     36 #include "ixheaacd_defines.h"
     37 
     38 #include "ixheaacd_pns.h"
     39 
     40 #include <ixheaacd_aac_rom.h>
     41 #include "ixheaacd_aac_imdct.h"
     42 #include "ixheaacd_pulsedata.h"
     43 
     44 #include "ixheaacd_drc_data_struct.h"
     45 
     46 #include "ixheaacd_lt_predict.h"
     47 
     48 #include "ixheaacd_channelinfo.h"
     49 #include "ixheaacd_drc_dec.h"
     50 
     51 #include "ixheaacd_sbrdecoder.h"
     52 #include "ixheaacd_tns.h"
     53 #include "ixheaacd_sbr_scale.h"
     54 #include "ixheaacd_lpp_tran.h"
     55 #include "ixheaacd_env_extr_part.h"
     56 #include <ixheaacd_sbr_rom.h>
     57 #include "ixheaacd_block.h"
     58 #include "ixheaacd_hybrid.h"
     59 #include "ixheaacd_ps_dec.h"
     60 #include "ixheaacd_env_extr.h"
     61 
     62 #include "ixheaacd_basic_funcs.h"
     63 #include "ixheaacd_env_calc.h"
     64 #include "ixheaacd_dsp_fft32x32s.h"
     65 
     66 #include "ixheaacd_interface.h"
     67 
     68 WORD32 (*ixheaacd_fix_div)(WORD32, WORD32) = &ixheaacd_fix_div_armv7;
     69 
     70 VOID(*ixheaacd_covariance_matrix_calc)
     71 (WORD32 *, ixheaacd_lpp_trans_cov_matrix *,
     72  WORD32) = &ixheaacd_covariance_matrix_calc_armv7;
     73 
     74 VOID(*ixheaacd_covariance_matrix_calc_2)
     75 (ixheaacd_lpp_trans_cov_matrix *, WORD32 *, WORD32,
     76  WORD16) = &ixheaacd_covariance_matrix_calc_2_armv7;
     77 
     78 VOID(*ixheaacd_over_lap_add1)
     79 (WORD32 *, WORD32 *, WORD16 *, const WORD16 *, WORD16, WORD16,
     80  WORD16) = &ixheaacd_over_lap_add1_armv7;
     81 
     82 VOID(*ixheaacd_over_lap_add2)
     83 (WORD32 *, WORD32 *, WORD32 *, const WORD16 *, WORD16, WORD16,
     84  WORD16) = &ixheaacd_over_lap_add2_armv7;
     85 
     86 VOID(*ixheaacd_decorr_filter2)
     87 (ia_ps_dec_struct *ptr_ps_dec, WORD32 *p_buf_left_real, WORD32 *p_buf_left_imag,
     88  WORD32 *p_buf_right_real, WORD32 *p_buf_right_imag,
     89  ia_ps_tables_struct *ps_tables_ptr,
     90  WORD16 *transient_ratio) = &ixheaacd_decorr_filter2_armv7;
     91 
     92 VOID(*ixheaacd_decorr_filter1)
     93 (ia_ps_dec_struct *ptr_ps_dec, ia_ps_tables_struct *ps_tables_ptr,
     94  WORD16 *transient_ratio) = &ixheaacd_decorr_filter1_armv7;
     95 
     96 WORD32(*ixheaacd_divide16_pos)
     97 (WORD32 op1, WORD32 op2) = &ixheaacd_divide16_pos_armv7;
     98 
     99 VOID(*ixheaacd_decorrelation)
    100 (ia_ps_dec_struct *ptr_ps_dec, WORD32 *p_buf_left_real, WORD32 *p_buf_left_imag,
    101  WORD32 *p_buf_right_real, WORD32 *p_buf_right_imag,
    102  ia_ps_tables_struct *ps_tables_ptr) = &ixheaacd_decorrelation_armv7;
    103 
    104 VOID(*ixheaacd_apply_rot)
    105 (ia_ps_dec_struct *ptr_ps_dec, WORD32 *qmf_left_real, WORD32 *qmf_left_imag,
    106  WORD32 *qmf_right_real, WORD32 *qmf_right_imag,
    107  ia_sbr_tables_struct *sbr_tables_ptr,
    108  const WORD16 *ptr_resol) = &ixheaacd_apply_rot_armv7;
    109 
    110 VOID(*ixheaacd_conv_ergtoamplitudelp)
    111 (WORD32 bands, WORD16 noise_e, WORD16 *nrg_sine, WORD16 *nrg_gain,
    112  WORD16 *noise_level_mant,
    113  WORD16 *sqrt_table) = &ixheaacd_conv_ergtoamplitudelp_armv7;
    114 
    115 VOID(*ixheaacd_conv_ergtoamplitude)
    116 (WORD32 bands, WORD16 noise_e, WORD16 *nrg_sine, WORD16 *nrg_gain,
    117  WORD16 *noise_level_mant,
    118  WORD16 *sqrt_table) = &ixheaacd_conv_ergtoamplitude_armv7;
    119 
    120 VOID(*ixheaacd_adjust_scale)
    121 (WORD32 **re, WORD32 **im, WORD32 sub_band_start, WORD32 sub_band_end,
    122  WORD32 start_pos, WORD32 next_pos, WORD32 shift,
    123  FLAG low_pow_flag) = &ixheaacd_adjust_scale_armv7;
    124 
    125 WORD16(*ixheaacd_ixheaacd_expsubbandsamples)
    126 (WORD32 **re, WORD32 **im, WORD32 sub_band_start, WORD32 sub_band_end,
    127  WORD32 start_pos, WORD32 next_pos,
    128  FLAG low_pow_flag) = &ixheaacd_expsubbandsamples_armv7;
    129 
    130 VOID(*ixheaacd_enery_calc_per_subband)
    131 (WORD32 start_pos, WORD32 next_pos, WORD32 sub_band_start, WORD32 sub_band_end,
    132  WORD32 frame_exp, WORD16 *nrg_est_mant, FLAG low_pow_flag,
    133  ia_sbr_tables_struct *ptr_sbr_tables,
    134  WORD32 *ptr_qmf_matrix) = &ixheaacd_enery_calc_per_subband_armv7;
    135 
    136 VOID(*ixheaacd_harm_idx_zerotwolp)
    137 (WORD32 *ptr_real_buf, WORD16 *ptr_gain_buf, WORD32 scale_change,
    138  WORD16 *ptr_sine_level_buf, const WORD32 *ptr_rand_ph,
    139  WORD16 *noise_level_mant, WORD32 num_sub_bands, FLAG noise_absc_flag,
    140  WORD32 harm_index) = &ixheaacd_harm_idx_zerotwolp_armv7;
    141 
    142 VOID(*ixheaacd_tns_ar_filter_fixed)
    143 (WORD32 *spectrum, WORD32 size, WORD32 inc, WORD32 *lpc, WORD32 order,
    144  WORD32 shift_value, WORD scale_spec) = &ixheaacd_tns_ar_filter_fixed_armv7;
    145 
    146 VOID(*ixheaacd_tns_ar_filter)
    147 (WORD32 *spectrum, WORD32 size, WORD32 inc, WORD16 *lpc, WORD32 order,
    148  WORD32 shift_value, WORD scale_spec,
    149  WORD32 *ptr_filter_state) = &ixheaacd_tns_ar_filter_armv7;
    150 
    151 VOID(*ixheaacd_tns_parcor_lpc_convert)
    152 (WORD16 *parcor, WORD16 *lpc, WORD16 *scale,
    153  WORD order) = &ixheaacd_tns_parcor_lpc_convert_armv7;
    154 
    155 WORD32(*ixheaacd_calc_max_spectral_line)
    156 (WORD32 *ptr_tmp, WORD32 size) = &ixheaacd_calc_max_spectral_line_armv7;
    157 
    158 VOID(*ixheaacd_post_twiddle)
    159 (WORD32 out_ptr[], WORD32 spec_data[],
    160  ia_aac_dec_imdct_tables_struct *ptr_imdct_tables,
    161  WORD npoints) = &ixheaacd_post_twiddle_armv7;
    162 
    163 VOID(*ixheaacd_post_twid_overlap_add)
    164 (WORD16 pcm_out[], WORD32 spec_data[],
    165  ia_aac_dec_imdct_tables_struct *ptr_imdct_tables, WORD npoints,
    166  WORD32 *ptr_overlap_buf, WORD16 q_shift, const WORD16 *window,
    167  WORD16 ch_fac) = &ixheaacd_post_twid_overlap_add_armv7;
    168 VOID(*ixheaacd_neg_shift_spec)
    169 (WORD32 *coef, WORD16 *out, WORD16 q_shift,
    170  WORD16 ch_fac) = &ixheaacd_neg_shift_spec_armv7;
    171 
    172 VOID(*ixheaacd_spec_to_overlapbuf)
    173 (WORD32 *ptr_overlap_buf, WORD32 *ptr_spec_coeff, WORD32 q_shift,
    174  WORD32 size) = &ixheaacd_spec_to_overlapbuf_armv7;
    175 
    176 VOID(*ixheaacd_overlap_buf_out)
    177 (WORD16 *out_samples, WORD32 *ptr_overlap_buf, WORD32 size,
    178  const WORD16 ch_fac) = &ixheaacd_overlap_buf_out_armv7;
    179 
    180 VOID(*ixheaacd_overlap_out_copy)
    181 (WORD16 *out_samples, WORD32 *ptr_overlap_buf, WORD32 *ptr_overlap_buf1,
    182  const WORD16 ch_fac) = &ixheaacd_overlap_out_copy_armv7;
    183 
    184 VOID(*ixheaacd_pretwiddle_compute)
    185 (WORD32 *spec_data1, WORD32 *spec_data2, WORD32 *out_ptr,
    186  ia_aac_dec_imdct_tables_struct *ptr_imdct_tables, WORD npoints4,
    187  WORD32 neg_expo) = &ixheaacd_pretwiddle_compute_armv7;
    188 
    189 VOID(*ixheaacd_imdct_using_fft)
    190 (ia_aac_dec_imdct_tables_struct *ptr_imdct_tables, WORD32 npoints,
    191  WORD32 *ptr_x, WORD32 *ptr_y) = &ixheaacd_imdct_using_fft_armv7;
    192 
    193 VOID(*ixheaacd_complex_fft_p2)
    194 (WORD32 *xr, WORD32 *xi, WORD32 nlength, WORD32 fft_mode,
    195  WORD32 *preshift) = &ixheaacd_complex_fft_p2_armv7;
    196 
    197 VOID(*ixheaacd_mps_complex_fft_64)
    198 (WORD32 *ptr_x, WORD32 *fin_re, WORD32 *fin_im,
    199  WORD32 nlength) = &ixheaacd_mps_complex_fft_64_armv7;
    200 
    201 VOID(*ixheaacd_mps_synt_pre_twiddle)
    202 (WORD32 *ptr_in, WORD32 *table_re, WORD32 *table_im,
    203  WORD32 resolution) = &ixheaacd_mps_synt_pre_twiddle_armv7;
    204 
    205 VOID(*ixheaacd_mps_synt_post_twiddle)
    206 (WORD32 *ptr_in, WORD32 *table_re, WORD32 *table_im,
    207  WORD32 resolution) = &ixheaacd_mps_synt_post_twiddle_armv7;
    208 
    209 VOID(*ixheaacd_calc_pre_twid)
    210 (WORD32 *ptr_x, WORD32 *r_ptr, WORD32 *i_ptr, WORD32 nlength,
    211  const WORD32 *cos_ptr, const WORD32 *sin_ptr) = &ixheaacd_calc_pre_twid_armv7;
    212 
    213 VOID(*ixheaacd_calc_post_twid)
    214 (WORD32 *ptr_x, WORD32 *r_ptr, WORD32 *i_ptr, WORD32 nlength,
    215  const WORD32 *cos_ptr, const WORD32 *sin_ptr) = &ixheaacd_calc_post_twid_armv7;
    216 
    217 VOID(*ixheaacd_mps_synt_post_fft_twiddle)
    218 (WORD32 resolution, WORD32 *fin_re, WORD32 *fin_im, WORD32 *table_re,
    219  WORD32 *table_im, WORD32 *state) = &ixheaacd_mps_synt_post_fft_twiddle_armv7;
    220 
    221 VOID(*ixheaacd_mps_synt_out_calc)
    222 (WORD32 resolution, WORD32 *out, WORD32 *state,
    223  const WORD32 *filter_coeff) = &ixheaacd_mps_synt_out_calc_armv7;
    224 
    225 VOID(*ixheaacd_fft_15_ld)
    226 (WORD32 *inp, WORD32 *op, WORD32 *fft3out,
    227  UWORD8 *re_arr_tab_sml_240_ptr) = &ixheaacd_fft_15_ld_armv7;
    228 
    229 VOID(*ixheaacd_aac_ld_dec_rearrange)
    230 (WORD32 *ip, WORD32 *op, WORD32 mdct_len_2,
    231  UWORD8 *re_arr_tab) = &ia_aac_ld_dec_rearrange_armv7;
    232 
    233 VOID(*ixheaacd_fft32x32_ld)
    234 (ia_aac_dec_imdct_tables_struct *imdct_tables_ptr, WORD32 npoints,
    235  WORD32 *ptr_x, WORD32 *ptr_y) = &ixheaacd_imdct_using_fft_armv7;
    236 
    237 VOID(*ixheaacd_fft32x32_ld2)
    238 (ia_aac_dec_imdct_tables_struct *imdct_tables_ptr, WORD32 npoints,
    239  WORD32 *ptr_x, WORD32 *ptr_y) = &ixheaacd_fft32x32_ld2_armv7;
    240 
    241 WORD16 (*ixheaacd_neg_expo_inc)(WORD16 neg_expo) = &ixheaacd_neg_expo_inc_arm;
    242 
    243 VOID(*ixheaacd_inv_dit_fft_8pt)
    244 (WORD32 *x, WORD32 *real, WORD32 *imag) = &ixheaacd_inv_dit_fft_8pt_armv7;
    245 
    246 VOID(*ixheaacd_scale_factor_process)
    247 (WORD32 *x_invquant, WORD16 *scale_fact, WORD no_band, WORD8 *width,
    248  WORD32 *scale_tables_ptr, WORD32 total_channels, WORD32 object_type,
    249  WORD32 aac_sf_data_resil_flag) = &ixheaacd_scale_factor_process_armv7;
    250