1*c83a76b0SSuyog Pawar /****************************************************************************** 2*c83a76b0SSuyog Pawar * 3*c83a76b0SSuyog Pawar * Copyright (C) 2012 Ittiam Systems Pvt Ltd, Bangalore 4*c83a76b0SSuyog Pawar * 5*c83a76b0SSuyog Pawar * Licensed under the Apache License, Version 2.0 (the "License"); 6*c83a76b0SSuyog Pawar * you may not use this file except in compliance with the License. 7*c83a76b0SSuyog Pawar * You may obtain a copy of the License at: 8*c83a76b0SSuyog Pawar * 9*c83a76b0SSuyog Pawar * http://www.apache.org/licenses/LICENSE-2.0 10*c83a76b0SSuyog Pawar * 11*c83a76b0SSuyog Pawar * Unless required by applicable law or agreed to in writing, software 12*c83a76b0SSuyog Pawar * distributed under the License is distributed on an "AS IS" BASIS, 13*c83a76b0SSuyog Pawar * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14*c83a76b0SSuyog Pawar * See the License for the specific language governing permissions and 15*c83a76b0SSuyog Pawar * limitations under the License. 16*c83a76b0SSuyog Pawar * 17*c83a76b0SSuyog Pawar ******************************************************************************/ 18*c83a76b0SSuyog Pawar /** 19*c83a76b0SSuyog Pawar ******************************************************************************* 20*c83a76b0SSuyog Pawar * @file 21*c83a76b0SSuyog Pawar * ihevc_itrans_recon.h 22*c83a76b0SSuyog Pawar * 23*c83a76b0SSuyog Pawar * @brief 24*c83a76b0SSuyog Pawar * Functions declarations for inverse transform and reconstruction 25*c83a76b0SSuyog Pawar * 26*c83a76b0SSuyog Pawar * @author 27*c83a76b0SSuyog Pawar * Ittiam 28*c83a76b0SSuyog Pawar * 29*c83a76b0SSuyog Pawar * @remarks 30*c83a76b0SSuyog Pawar * None 31*c83a76b0SSuyog Pawar * 32*c83a76b0SSuyog Pawar ******************************************************************************* 33*c83a76b0SSuyog Pawar */ 34*c83a76b0SSuyog Pawar #ifndef _IHEVC_ITRANS_RECON_H_ 35*c83a76b0SSuyog Pawar #define _IHEVC_ITRANS_RECON_H_ 36*c83a76b0SSuyog Pawar 37*c83a76b0SSuyog Pawar typedef void ihevc_itrans_recon_4x4_ttype1_ft(WORD16 *pi2_src, 38*c83a76b0SSuyog Pawar WORD16 *pi2_tmp, 39*c83a76b0SSuyog Pawar UWORD8 *pu1_pred, 40*c83a76b0SSuyog Pawar UWORD8 *pu1_dst, 41*c83a76b0SSuyog Pawar WORD32 src_strd, 42*c83a76b0SSuyog Pawar WORD32 pred_strd, 43*c83a76b0SSuyog Pawar WORD32 dst_strd, 44*c83a76b0SSuyog Pawar WORD32 zero_cols, 45*c83a76b0SSuyog Pawar WORD32 zero_rows); 46*c83a76b0SSuyog Pawar typedef void ihevc_hbd_itrans_recon_4x4_ttype1_ft(WORD16 *pi2_src, 47*c83a76b0SSuyog Pawar WORD16 *pi2_tmp, 48*c83a76b0SSuyog Pawar UWORD16 *pu2_pred, 49*c83a76b0SSuyog Pawar UWORD16 *pu2_dst, 50*c83a76b0SSuyog Pawar WORD32 src_strd, 51*c83a76b0SSuyog Pawar WORD32 pred_strd, 52*c83a76b0SSuyog Pawar WORD32 dst_strd, 53*c83a76b0SSuyog Pawar WORD32 zero_cols, 54*c83a76b0SSuyog Pawar WORD32 zero_rows, 55*c83a76b0SSuyog Pawar UWORD8 bit_depth); 56*c83a76b0SSuyog Pawar typedef void ihevc_itrans_recon_4x4_ft(WORD16 *pi2_src, 57*c83a76b0SSuyog Pawar WORD16 *pi2_tmp, 58*c83a76b0SSuyog Pawar UWORD8 *pu1_pred, 59*c83a76b0SSuyog Pawar UWORD8 *pu1_dst, 60*c83a76b0SSuyog Pawar WORD32 src_strd, 61*c83a76b0SSuyog Pawar WORD32 pred_strd, 62*c83a76b0SSuyog Pawar WORD32 dst_strd, 63*c83a76b0SSuyog Pawar WORD32 zero_cols, 64*c83a76b0SSuyog Pawar WORD32 zero_rows); 65*c83a76b0SSuyog Pawar typedef void ihevc_hbd_itrans_recon_4x4_ft(WORD16 *pi2_src, 66*c83a76b0SSuyog Pawar WORD16 *pi2_tmp, 67*c83a76b0SSuyog Pawar UWORD16 *pu2_pred, 68*c83a76b0SSuyog Pawar UWORD16 *pu2_dst, 69*c83a76b0SSuyog Pawar WORD32 src_strd, 70*c83a76b0SSuyog Pawar WORD32 pred_strd, 71*c83a76b0SSuyog Pawar WORD32 dst_strd, 72*c83a76b0SSuyog Pawar WORD32 zero_cols, 73*c83a76b0SSuyog Pawar WORD32 zero_rows, 74*c83a76b0SSuyog Pawar UWORD8 bit_depth); 75*c83a76b0SSuyog Pawar typedef void ihevc_itrans_recon_8x8_ft(WORD16 *pi2_src, 76*c83a76b0SSuyog Pawar WORD16 *pi2_tmp, 77*c83a76b0SSuyog Pawar UWORD8 *pu1_pred, 78*c83a76b0SSuyog Pawar UWORD8 *pu1_dst, 79*c83a76b0SSuyog Pawar WORD32 src_strd, 80*c83a76b0SSuyog Pawar WORD32 pred_strd, 81*c83a76b0SSuyog Pawar WORD32 dst_strd, 82*c83a76b0SSuyog Pawar WORD32 zero_cols, 83*c83a76b0SSuyog Pawar WORD32 zero_rows); 84*c83a76b0SSuyog Pawar typedef void ihevc_hbd_itrans_recon_8x8_ft(WORD16 *pi2_src, 85*c83a76b0SSuyog Pawar WORD16 *pi2_tmp, 86*c83a76b0SSuyog Pawar UWORD16 *pu2_pred, 87*c83a76b0SSuyog Pawar UWORD16 *pu2_dst, 88*c83a76b0SSuyog Pawar WORD32 src_strd, 89*c83a76b0SSuyog Pawar WORD32 pred_strd, 90*c83a76b0SSuyog Pawar WORD32 dst_strd, 91*c83a76b0SSuyog Pawar WORD32 zero_cols, 92*c83a76b0SSuyog Pawar WORD32 zero_rows, 93*c83a76b0SSuyog Pawar UWORD8 bit_depth); 94*c83a76b0SSuyog Pawar typedef void ihevc_itrans_recon_16x16_ft(WORD16 *pi2_src, 95*c83a76b0SSuyog Pawar WORD16 *pi2_tmp, 96*c83a76b0SSuyog Pawar UWORD8 *pu1_pred, 97*c83a76b0SSuyog Pawar UWORD8 *pu1_dst, 98*c83a76b0SSuyog Pawar WORD32 src_strd, 99*c83a76b0SSuyog Pawar WORD32 pred_strd, 100*c83a76b0SSuyog Pawar WORD32 dst_strd, 101*c83a76b0SSuyog Pawar WORD32 zero_cols, 102*c83a76b0SSuyog Pawar WORD32 zero_rows); 103*c83a76b0SSuyog Pawar typedef void ihevc_hbd_itrans_recon_16x16_ft(WORD16 *pi2_src, 104*c83a76b0SSuyog Pawar WORD16 *pi2_tmp, 105*c83a76b0SSuyog Pawar UWORD16 *pu2_pred, 106*c83a76b0SSuyog Pawar UWORD16 *pu2_dst, 107*c83a76b0SSuyog Pawar WORD32 src_strd, 108*c83a76b0SSuyog Pawar WORD32 pred_strd, 109*c83a76b0SSuyog Pawar WORD32 dst_strd, 110*c83a76b0SSuyog Pawar WORD32 zero_cols, 111*c83a76b0SSuyog Pawar WORD32 zero_rows, 112*c83a76b0SSuyog Pawar UWORD8 bit_depth); 113*c83a76b0SSuyog Pawar typedef void ihevc_itrans_recon_32x32_ft(WORD16 *pi2_src, 114*c83a76b0SSuyog Pawar WORD16 *pi2_tmp, 115*c83a76b0SSuyog Pawar UWORD8 *pu1_pred, 116*c83a76b0SSuyog Pawar UWORD8 *pu1_dst, 117*c83a76b0SSuyog Pawar WORD32 src_strd, 118*c83a76b0SSuyog Pawar WORD32 pred_strd, 119*c83a76b0SSuyog Pawar WORD32 dst_strd, 120*c83a76b0SSuyog Pawar WORD32 zero_cols, 121*c83a76b0SSuyog Pawar WORD32 zero_rows); 122*c83a76b0SSuyog Pawar typedef void ihevc_hbd_itrans_recon_32x32_ft(WORD16 *pi2_src, 123*c83a76b0SSuyog Pawar WORD16 *pi2_tmp, 124*c83a76b0SSuyog Pawar UWORD16 *pu2_pred, 125*c83a76b0SSuyog Pawar UWORD16 *pu2_dst, 126*c83a76b0SSuyog Pawar WORD32 src_strd, 127*c83a76b0SSuyog Pawar WORD32 pred_strd, 128*c83a76b0SSuyog Pawar WORD32 dst_strd, 129*c83a76b0SSuyog Pawar WORD32 zero_cols, 130*c83a76b0SSuyog Pawar WORD32 zero_rows, 131*c83a76b0SSuyog Pawar UWORD8 bit_depth); 132*c83a76b0SSuyog Pawar 133*c83a76b0SSuyog Pawar /* C function declarations */ 134*c83a76b0SSuyog Pawar ihevc_itrans_recon_4x4_ttype1_ft ihevc_itrans_recon_4x4_ttype1; 135*c83a76b0SSuyog Pawar ihevc_itrans_recon_4x4_ft ihevc_itrans_recon_4x4; 136*c83a76b0SSuyog Pawar ihevc_itrans_recon_8x8_ft ihevc_itrans_recon_8x8; 137*c83a76b0SSuyog Pawar ihevc_itrans_recon_16x16_ft ihevc_itrans_recon_16x16; 138*c83a76b0SSuyog Pawar ihevc_itrans_recon_32x32_ft ihevc_itrans_recon_32x32; 139*c83a76b0SSuyog Pawar 140*c83a76b0SSuyog Pawar ihevc_hbd_itrans_recon_4x4_ttype1_ft ihevc_hbd_itrans_recon_4x4_ttype1; 141*c83a76b0SSuyog Pawar ihevc_hbd_itrans_recon_4x4_ft ihevc_hbd_itrans_recon_4x4; 142*c83a76b0SSuyog Pawar ihevc_hbd_itrans_recon_8x8_ft ihevc_hbd_itrans_recon_8x8; 143*c83a76b0SSuyog Pawar ihevc_hbd_itrans_recon_16x16_ft ihevc_hbd_itrans_recon_16x16; 144*c83a76b0SSuyog Pawar ihevc_hbd_itrans_recon_32x32_ft ihevc_hbd_itrans_recon_32x32; 145*c83a76b0SSuyog Pawar 146*c83a76b0SSuyog Pawar /* A9 Q function declarations */ 147*c83a76b0SSuyog Pawar ihevc_itrans_recon_4x4_ttype1_ft ihevc_itrans_recon_4x4_ttype1_a9q; 148*c83a76b0SSuyog Pawar ihevc_itrans_recon_4x4_ft ihevc_itrans_recon_4x4_a9q; 149*c83a76b0SSuyog Pawar ihevc_itrans_recon_8x8_ft ihevc_itrans_recon_8x8_a9q; 150*c83a76b0SSuyog Pawar ihevc_itrans_recon_16x16_ft ihevc_itrans_recon_16x16_a9q; 151*c83a76b0SSuyog Pawar ihevc_itrans_recon_32x32_ft ihevc_itrans_recon_32x32_a9q; 152*c83a76b0SSuyog Pawar 153*c83a76b0SSuyog Pawar /* A9 A function declarations */ 154*c83a76b0SSuyog Pawar ihevc_itrans_recon_4x4_ttype1_ft ihevc_itrans_recon_4x4_ttype1_a9a; 155*c83a76b0SSuyog Pawar ihevc_itrans_recon_4x4_ft ihevc_itrans_recon_4x4_a9a; 156*c83a76b0SSuyog Pawar ihevc_itrans_recon_8x8_ft ihevc_itrans_recon_8x8_a9a; 157*c83a76b0SSuyog Pawar ihevc_itrans_recon_16x16_ft ihevc_itrans_recon_16x16_a9a; 158*c83a76b0SSuyog Pawar ihevc_itrans_recon_32x32_ft ihevc_itrans_recon_32x32_a9a; 159*c83a76b0SSuyog Pawar 160*c83a76b0SSuyog Pawar /* NEONINTR function declarations */ 161*c83a76b0SSuyog Pawar ihevc_itrans_recon_4x4_ttype1_ft ihevc_itrans_recon_4x4_ttype1_neonintr; 162*c83a76b0SSuyog Pawar ihevc_itrans_recon_4x4_ft ihevc_itrans_recon_4x4_neonintr; 163*c83a76b0SSuyog Pawar ihevc_itrans_recon_8x8_ft ihevc_itrans_recon_8x8_neonintr; 164*c83a76b0SSuyog Pawar ihevc_itrans_recon_16x16_ft ihevc_itrans_recon_16x16_neonintr; 165*c83a76b0SSuyog Pawar ihevc_itrans_recon_32x32_ft ihevc_itrans_recon_32x32_neonintr; 166*c83a76b0SSuyog Pawar 167*c83a76b0SSuyog Pawar /* SSSE31 function declarations */ 168*c83a76b0SSuyog Pawar ihevc_itrans_recon_4x4_ttype1_ft ihevc_itrans_recon_4x4_ttype1_ssse3; 169*c83a76b0SSuyog Pawar ihevc_itrans_recon_4x4_ft ihevc_itrans_recon_4x4_ssse3; 170*c83a76b0SSuyog Pawar ihevc_itrans_recon_8x8_ft ihevc_itrans_recon_8x8_ssse3; 171*c83a76b0SSuyog Pawar ihevc_itrans_recon_16x16_ft ihevc_itrans_recon_16x16_ssse3; 172*c83a76b0SSuyog Pawar ihevc_itrans_recon_32x32_ft ihevc_itrans_recon_32x32_ssse3; 173*c83a76b0SSuyog Pawar 174*c83a76b0SSuyog Pawar /* SSE42 function declarations */ 175*c83a76b0SSuyog Pawar ihevc_itrans_recon_4x4_ttype1_ft ihevc_itrans_recon_4x4_ttype1_sse42; 176*c83a76b0SSuyog Pawar ihevc_itrans_recon_4x4_ft ihevc_itrans_recon_4x4_sse42; 177*c83a76b0SSuyog Pawar ihevc_itrans_recon_8x8_ft ihevc_itrans_recon_8x8_sse42; 178*c83a76b0SSuyog Pawar ihevc_itrans_recon_32x32_ft ihevc_itrans_recon_32x32_sse42; 179*c83a76b0SSuyog Pawar 180*c83a76b0SSuyog Pawar ihevc_hbd_itrans_recon_4x4_ttype1_ft ihevc_hbd_itrans_recon_4x4_ttype1_sse42; 181*c83a76b0SSuyog Pawar ihevc_hbd_itrans_recon_4x4_ft ihevc_hbd_itrans_recon_4x4_sse42; 182*c83a76b0SSuyog Pawar ihevc_hbd_itrans_recon_8x8_ft ihevc_hbd_itrans_recon_8x8_sse42; 183*c83a76b0SSuyog Pawar ihevc_hbd_itrans_recon_16x16_ft ihevc_hbd_itrans_recon_16x16_sse42; 184*c83a76b0SSuyog Pawar ihevc_hbd_itrans_recon_32x32_ft ihevc_hbd_itrans_recon_32x32_sse42; 185*c83a76b0SSuyog Pawar 186*c83a76b0SSuyog Pawar 187*c83a76b0SSuyog Pawar /* armv8 function declarations */ 188*c83a76b0SSuyog Pawar ihevc_itrans_recon_4x4_ttype1_ft ihevc_itrans_recon_4x4_ttype1_av8; 189*c83a76b0SSuyog Pawar ihevc_itrans_recon_4x4_ft ihevc_itrans_recon_4x4_av8; 190*c83a76b0SSuyog Pawar ihevc_itrans_recon_8x8_ft ihevc_itrans_recon_8x8_av8; 191*c83a76b0SSuyog Pawar ihevc_itrans_recon_16x16_ft ihevc_itrans_recon_16x16_av8; 192*c83a76b0SSuyog Pawar ihevc_itrans_recon_32x32_ft ihevc_itrans_recon_32x32_av8; 193*c83a76b0SSuyog Pawar #endif /*_IHEVC_ITRANS_RECON_H_*/ 194