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 "ixheaacd_type_def.h" 22 23 #include "ixheaacd_constants.h" 24 #include "ixheaacd_basic_ops32.h" 25 #include "ixheaacd_basic_ops16.h" 26 #include "ixheaacd_basic_ops40.h" 27 #include "ixheaacd_basic_ops.h" 28 #include "ixheaacd_common_rom.h" 29 #include "ixheaacd_dsp_fft32x32s.h" 30 #include "ixheaacd_intrinsics.h" 31 32 #include "ixheaacd_basic_op.h" 33 34 VOID ixheaacd_inv_dit_fft_8pt_dec(WORD32 *y, WORD32 *real, WORD32 *imag) { 35 WORD32 a0, a1, a2, a3, a00, a10, a20, a30; 36 WORD32 vr, vi; 37 38 WORD32 x[16]; 39 40 a00 = ixheaacd_add32_sat(y[0], y[8]); 41 a0 = ixheaacd_sub32_sat(y[0], y[8]); 42 43 a20 = ixheaacd_add32_sat(y[1], y[9]); 44 a3 = ixheaacd_sub32_sat(y[1], y[9]); 45 46 a10 = ixheaacd_add32_sat(y[4], y[12]); 47 a2 = ixheaacd_sub32_sat(y[4], y[12]); 48 49 a30 = ixheaacd_add32_sat(y[5], y[13]); 50 a1 = ixheaacd_sub32_sat(y[5], y[13]); 51 52 x[0] = ixheaacd_add32_sat(a00, a10); 53 x[4] = ixheaacd_sub32_sat(a00, a10); 54 x[1] = ixheaacd_add32_sat(a20, a30); 55 x[5] = ixheaacd_sub32_sat(a20, a30); 56 57 x[2] = ixheaacd_sub32_sat(a0, a1); 58 x[6] = ixheaacd_add32_sat(a0, a1); 59 x[3] = ixheaacd_add32_sat(a3, a2); 60 x[7] = ixheaacd_sub32_sat(a3, a2); 61 62 a00 = ixheaacd_add32_sat(y[2], y[10]); 63 a0 = ixheaacd_sub32_sat(y[2], y[10]); 64 65 a20 = ixheaacd_add32_sat(y[3], y[11]); 66 a3 = ixheaacd_sub32_sat(y[3], y[11]); 67 68 a10 = ixheaacd_add32_sat(y[6], y[14]); 69 a2 = ixheaacd_sub32_sat(y[6], y[14]); 70 71 a30 = ixheaacd_add32_sat(y[7], y[15]); 72 a1 = ixheaacd_sub32_sat(y[7], y[15]); 73 74 x[8] = ixheaacd_add32_sat(a00, a10); 75 x[12] = ixheaacd_sub32_sat(a00, a10); 76 x[9] = ixheaacd_add32_sat(a20, a30); 77 x[13] = ixheaacd_sub32_sat(a20, a30); 78 79 x[10] = ixheaacd_sub32_sat(a0, a1); 80 x[14] = ixheaacd_add32_sat(a0, a1); 81 x[11] = ixheaacd_add32_sat(a3, a2); 82 x[15] = ixheaacd_sub32_sat(a3, a2); 83 84 real[0] = ixheaacd_add32_sat(x[0], x[8]); 85 imag[0] = ixheaacd_add32_sat(x[1], x[9]); 86 a00 = ixheaacd_sub32_sat(x[0], x[8]); 87 a10 = ixheaacd_sub32_sat(x[1], x[9]); 88 89 a0 = ixheaacd_sub32_sat(x[4], x[13]); 90 a1 = ixheaacd_add32_sat(x[5], x[12]); 91 92 real[4] = ixheaacd_add32_sat(x[4], x[13]); 93 imag[4] = ixheaacd_sub32_sat(x[5], x[12]); 94 95 vr = ixheaacd_mult32x16in32_shl_sat(ixheaacd_sub32_sat(x[10], x[11]), 0x5A82); 96 vi = ixheaacd_mult32x16in32_shl_sat(ixheaacd_add32_sat(x[10], x[11]), 0x5A82); 97 98 real[1] = ixheaacd_add32_sat(x[2], vr); 99 imag[1] = ixheaacd_add32_sat(x[3], vi); 100 101 a2 = ixheaacd_sub32_sat(x[2], vr); 102 a3 = ixheaacd_sub32_sat(x[3], vi); 103 104 real[2] = ixheaacd_add32_sat(a0, a2); 105 imag[2] = ixheaacd_add32_sat(a1, a3); 106 vr = ixheaacd_mult32x16in32_shl_sat(ixheaacd_add32_sat(x[14], x[15]), 0x5A82); 107 vi = ixheaacd_mult32x16in32_shl_sat(ixheaacd_sub32_sat(x[14], x[15]), 0x5A82); 108 109 a20 = ixheaacd_sub32_sat(x[6], vr); 110 a30 = ixheaacd_add32_sat(x[7], vi); 111 112 real[3] = ixheaacd_add32_sat(a00, a20); 113 imag[3] = ixheaacd_add32_sat(a10, a30); 114 115 real[5] = ixheaacd_add32_sat(x[6], vr); 116 imag[5] = ixheaacd_sub32_sat(x[7], vi); 117 } 118