aboutsummaryrefslogtreecommitdiff
path: root/decoder/ixheaacd_aac_imdct.h
diff options
context:
space:
mode:
Diffstat (limited to 'decoder/ixheaacd_aac_imdct.h')
-rw-r--r--decoder/ixheaacd_aac_imdct.h54
1 files changed, 51 insertions, 3 deletions
diff --git a/decoder/ixheaacd_aac_imdct.h b/decoder/ixheaacd_aac_imdct.h
index d6dc58f..f88322d 100644
--- a/decoder/ixheaacd_aac_imdct.h
+++ b/decoder/ixheaacd_aac_imdct.h
@@ -25,6 +25,11 @@ WORD32 ixheaacd_inverse_transform(
ia_aac_dec_imdct_tables_struct *ptr_imdct_tables, WORD32 expo,
WORD32 npoints);
+VOID ixheaacd_inverse_transform_960(
+ WORD32 spec_data[], WORD32 scratch[],
+ ia_aac_dec_imdct_tables_struct *ptr_imdct_tables, WORD32 expo,
+ WORD32 *imdct_scale);
+
VOID ixheaacd_post_twiddle_dec(WORD32 out_ptr[], WORD32 spec_data[],
ia_aac_dec_imdct_tables_struct *ptr_imdct_tables,
WORD32 npoints);
@@ -38,19 +43,19 @@ VOID ixheaacd_post_twiddle_armv8(
ia_aac_dec_imdct_tables_struct *ptr_imdct_tables, WORD32 npoints);
VOID ixheaacd_post_twid_overlap_add_dec(
- WORD16 pcm_out[], WORD32 spec_data[],
+ WORD32 pcm_out[], WORD32 spec_data[],
ia_aac_dec_imdct_tables_struct *ptr_imdct_tables, WORD npoints,
WORD32 *ptr_overlap_buf, WORD16 q_shift, const WORD16 *window,
WORD16 ch_fac);
VOID ixheaacd_post_twid_overlap_add_armv7(
- WORD16 pcm_out[], WORD32 spec_data[],
+ WORD32 pcm_out[], WORD32 spec_data[],
ia_aac_dec_imdct_tables_struct *ptr_imdct_tables, WORD npoints,
WORD32 *ptr_overlap_buf, WORD16 q_shift, const WORD16 *window,
WORD16 ch_fac);
VOID ixheaacd_post_twid_overlap_add_armv8(
- WORD16 pcm_out[], WORD32 spec_data[],
+ WORD32 pcm_out[], WORD32 spec_data[],
ia_aac_dec_imdct_tables_struct *ptr_imdct_tables, WORD npoints,
WORD32 *ptr_overlap_buf, WORD16 q_shift, const WORD16 *window,
WORD16 ch_fac);
@@ -60,6 +65,11 @@ VOID ixheaacd_pretwiddle_compute_dec(
ia_aac_dec_imdct_tables_struct *ptr_imdct_tables, WORD npoints4,
WORD32 neg_expo);
+VOID ixheaacd_pretwiddle_compute_960_dec(
+ WORD32 *spec_data1, WORD32 *spec_data2, WORD32 *out_ptr,
+ ia_aac_dec_imdct_tables_struct *ptr_imdct_tables, WORD npoints4,
+ WORD32 neg_expo);
+
VOID ixheaacd_pretwiddle_compute_armv7(
WORD32 *spec_data1, WORD32 *spec_data2, WORD32 *out_ptr,
ia_aac_dec_imdct_tables_struct *ptr_imdct_tables, WORD npoints4,
@@ -85,12 +95,46 @@ VOID ixheaacd_imdct_using_fft_armv8(
VOID ixheaacd_fft_480_ld(WORD32 *inp, WORD32 *op,
ia_aac_dec_imdct_tables_struct *imdct_tables_ptr);
+VOID ixheaacd_fft_5(WORD32 *inp, WORD32 *op);
+
+VOID ixheaacd_fft_3(WORD32 *inp, WORD32 *op);
+
+VOID ixheaacd_fft_960_15(WORD32 *inp, WORD32 *op,
+ ia_aac_dec_imdct_tables_struct *imdct_tables_ptr);
+
+VOID ixheaacd_fft_960(WORD32 *inp, WORD32 *op,
+ ia_aac_dec_imdct_tables_struct *imdct_tables_ptr);
+
+VOID ixheaacd_fft_120(ia_aac_dec_imdct_tables_struct *imdct_tables_ptr,
+ WORD32 npoints, WORD32* ptr_x, WORD32* ptr_y);
+
+VOID ixheaacd_fft_32_points(WORD16 *ptr_w, WORD32 npoints,
+ WORD32* ptr_x, WORD32* ptr_y);
+
+VOID ixheaacd_ld_dec_fft_15_opt(WORD32 *inp, WORD32 *op, WORD32 *fft3out,
+ WORD16 *re_arr_tab_sml_240_ptr);
+
+VOID ixheaacd_dec_rearrange_short(WORD32 *ip, WORD32 *op, WORD32 mdct_len_2,
+ WORD16 *re_arr_tab);
+
VOID ixheaacd_pre_twiddle(WORD32 *xptr, WORD32 *data, WORD32 n,
WORD32 *cos_array_ptr, WORD32 neg_expo);
+VOID ixheaacd_pre_twiddle_960(WORD32 *xptr, WORD32 *data, WORD32 n,
+ WORD32 *cos_array_ptr, WORD32 neg_expo);
+
+VOID ixheaacd_pre_twiddle_120(WORD32 *xptr, WORD32 *data, WORD32 n,
+ WORD16 *cos_array_ptr, WORD32 neg_expo);
+
VOID ixheaacd_post_twiddle_ld(WORD32 out[], WORD32 x[],
const WORD32 *cos_sin_ptr, WORD m);
+VOID ixheaacd_post_twiddle_960(WORD32 out[], WORD32 x[],
+ const WORD32 *cos_sin_ptr, WORD m);
+
+VOID ixheaacd_post_twiddle_120(WORD32 out[], WORD32 x[],
+ const WORD16 *cos_sin_ptr, WORD m);
+
VOID ixheaacd_post_twiddle_eld(WORD32 out[], WORD32 x[],
const WORD32 *cos_sin_ptr, WORD m);
@@ -125,6 +169,10 @@ VOID ixheaacd_inverse_transform_512(
WORD32 data[], WORD32 temp[], WORD32 *imdct_scale, WORD32 *cos_sin_ptr,
ia_aac_dec_imdct_tables_struct *imdct_tables_ptr, WORD32 object_type);
+VOID ixheaacd_mdct_960(WORD32 *inp, WORD32 *scratch, WORD32 *mdct_scale,
+ WORD32 mdct_flag,
+ ia_aac_dec_imdct_tables_struct *imdct_tables_ptr);
+
VOID ixheaacd_mdct_480_ld(WORD32 *inp, WORD32 *scratch, WORD32 *mdct_scale,
WORD32 mdct_flag,
ia_aac_dec_imdct_tables_struct *imdct_tables_ptr,