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 /*! 21 ****************************************************************************** 22 * \file ihevce_cmn_utils_instr_set_router.h 23 * 24 * \brief 25 * This file contains declarations related to common utilities used in encoder 26 * 27 * \date 28 * 15/07/2013 29 * 30 * \author 31 * Ittiam 32 * 33 * List of Functions 34 * 35 * 36 ****************************************************************************** 37 */ 38 39 #ifndef __IHEVCE_CMN_UTILS_INSTR_SET_ROUTER_H_ 40 #define __IHEVCE_CMN_UTILS_INSTR_SET_ROUTER_H_ 41 42 #include "ihevc_typedefs.h" 43 #include "ihevc_defs.h" 44 #include "ihevce_defs.h" 45 46 /*****************************************************************************/ 47 /* Typedefs */ 48 /*****************************************************************************/ 49 typedef UWORD32 FT_CALC_HAD_SATD_8BIT(UWORD8 *, WORD32, UWORD8 *, WORD32, WORD16 *, WORD32); 50 51 typedef LWORD64 FT_SSD_CALCULATOR( 52 UWORD8 *, UWORD8 *, UWORD32, UWORD32, UWORD32, UWORD32, CHROMA_PLANE_ID_T); 53 54 typedef LWORD64 FT_SSD_AND_SAD_CALCULATOR(UWORD8 *, WORD32, UWORD8 *, WORD32, WORD32, UWORD32 *); 55 56 typedef void FT_CHROMA_INTERLEAVE_2D_COPY( 57 UWORD8 *, WORD32, UWORD8 *, WORD32, WORD32, WORD32, CHROMA_PLANE_ID_T); 58 59 typedef void FT_COPY_2D(UWORD8 *, WORD32, UWORD8 *, WORD32, WORD32, WORD32); 60 61 typedef void FT_2D_SQUARE_COPY(void *, WORD32, void *, WORD32, WORD32, WORD32); 62 63 typedef void FT_WT_AVG_2D( 64 UWORD8 *, 65 UWORD8 *, 66 WORD32, 67 WORD32, 68 WORD32, 69 WORD32, 70 UWORD8 *, 71 WORD32, 72 WORD32, 73 WORD32, 74 WORD32, 75 WORD32, 76 WORD32); 77 78 typedef void 79 FT_ITRANS_RECON_DC(UWORD8 *, WORD32, UWORD8 *, WORD32, WORD32, WORD16, CHROMA_PLANE_ID_T); 80 81 typedef WORD32 FT_SCAN_COEFFS(WORD16 *, WORD32 *, WORD32, WORD32, UWORD8 *, UWORD8 *, WORD32); 82 83 typedef void FT_GET_EO_SAO_PARAMS(void *, WORD32, WORD32 *, WORD32 *); 84 85 /*****************************************************************************/ 86 /* Structure */ 87 /*****************************************************************************/ 88 typedef struct 89 { 90 FT_CALC_HAD_SATD_8BIT *pf_HAD_4x4_8bit; 91 FT_CALC_HAD_SATD_8BIT *pf_HAD_8x8_8bit; 92 FT_CALC_HAD_SATD_8BIT *pf_HAD_16x16_8bit; 93 FT_CALC_HAD_SATD_8BIT *pf_HAD_32x32_8bit; 94 FT_CALC_HAD_SATD_8BIT *pf_AC_HAD_8x8_8bit; 95 FT_CALC_HAD_SATD_8BIT *pf_chroma_HAD_4x4_8bit; 96 FT_CALC_HAD_SATD_8BIT *pf_chroma_AC_HAD_4x4_8bit; 97 FT_CALC_HAD_SATD_8BIT *pf_chroma_HAD_8x8_8bit; 98 FT_CALC_HAD_SATD_8BIT *pf_chroma_HAD_16x16_8bit; 99 FT_SSD_CALCULATOR *pf_ssd_calculator; 100 FT_SSD_CALCULATOR *pf_chroma_interleave_ssd_calculator; 101 FT_SSD_AND_SAD_CALCULATOR *pf_ssd_and_sad_calculator; 102 FT_CHROMA_INTERLEAVE_2D_COPY *pf_chroma_interleave_2d_copy; 103 FT_COPY_2D *pf_copy_2d; 104 FT_2D_SQUARE_COPY *pf_2d_square_copy; 105 FT_WT_AVG_2D *pf_wt_avg_2d; 106 FT_ITRANS_RECON_DC *pf_itrans_recon_dc; 107 FT_SCAN_COEFFS *pf_scan_coeffs; 108 FT_GET_EO_SAO_PARAMS *pf_get_luma_eo_sao_params; 109 FT_GET_EO_SAO_PARAMS *pf_get_chroma_eo_sao_params; 110 } ihevce_cmn_opt_func_t; 111 112 /*****************************************************************************/ 113 /* Extern Function Declarations */ 114 /*****************************************************************************/ 115 void ihevce_cmn_utils_instr_set_router( 116 ihevce_cmn_opt_func_t *ps_func_list, UWORD8 u1_is_popcnt_available, IV_ARCH_T e_arch); 117 118 /* Function List - C */ 119 FT_CALC_HAD_SATD_8BIT ihevce_HAD_4x4_8bit; 120 FT_CALC_HAD_SATD_8BIT ihevce_HAD_8x8_8bit; 121 FT_CALC_HAD_SATD_8BIT ihevce_HAD_16x16_8bit; 122 FT_CALC_HAD_SATD_8BIT ihevce_HAD_32x32_8bit; 123 FT_CALC_HAD_SATD_8BIT ihevce_compute_ac_had_8x8_8bit; 124 FT_CALC_HAD_SATD_8BIT ihevce_chroma_HAD_4x4_8bit; 125 FT_CALC_HAD_SATD_8BIT ihevce_chroma_compute_AC_HAD_4x4_8bit; 126 FT_CALC_HAD_SATD_8BIT ihevce_chroma_HAD_8x8_8bit; 127 FT_CALC_HAD_SATD_8BIT ihevce_chroma_HAD_16x16_8bit; 128 FT_SSD_CALCULATOR ihevce_ssd_calculator; 129 FT_SSD_CALCULATOR ihevce_chroma_interleave_ssd_calculator; 130 FT_SSD_AND_SAD_CALCULATOR ihevce_ssd_and_sad_calculator; 131 FT_CHROMA_INTERLEAVE_2D_COPY ihevce_chroma_interleave_2d_copy; 132 FT_COPY_2D ihevce_copy_2d; 133 FT_2D_SQUARE_COPY ihevce_2d_square_copy_luma; 134 FT_WT_AVG_2D ihevce_wt_avg_2d; 135 FT_ITRANS_RECON_DC ihevce_itrans_recon_dc; 136 FT_SCAN_COEFFS ihevce_scan_coeffs; 137 FT_GET_EO_SAO_PARAMS ihevce_get_luma_eo_sao_params; 138 FT_GET_EO_SAO_PARAMS ihevce_get_chroma_eo_sao_params; 139 140 #ifdef ENABLE_NEON 141 FT_CALC_HAD_SATD_8BIT ihevce_HAD_4x4_8bit_neon; 142 FT_CALC_HAD_SATD_8BIT ihevce_HAD_8x8_8bit_neon; 143 FT_CALC_HAD_SATD_8BIT ihevce_chroma_compute_AC_HAD_4x4_8bit_neon; 144 FT_CALC_HAD_SATD_8BIT ihevce_compute_ac_had_8x8_8bit_neon; 145 FT_CALC_HAD_SATD_8BIT ihevce_HAD_16x16_8bit_neon; 146 FT_CALC_HAD_SATD_8BIT ihevce_chroma_HAD_4x4_8bit_neon; 147 FT_CALC_HAD_SATD_8BIT ihevce_chroma_HAD_8x8_8bit_neon; 148 FT_CALC_HAD_SATD_8BIT ihevce_chroma_HAD_16x16_8bit_neon; 149 FT_CALC_HAD_SATD_8BIT ihevce_HAD_32x32_8bit_neon; 150 FT_SSD_CALCULATOR ihevce_ssd_calculator_neon; 151 FT_SSD_CALCULATOR ihevce_chroma_interleave_ssd_calculator_neon; 152 FT_SSD_AND_SAD_CALCULATOR ihevce_ssd_and_sad_calculator_neon; 153 FT_2D_SQUARE_COPY ihevce_2d_square_copy_luma_neon; 154 FT_CHROMA_INTERLEAVE_2D_COPY ihevce_chroma_interleave_2d_copy_neon; 155 FT_COPY_2D ihevce_copy_2d_neon; 156 FT_GET_EO_SAO_PARAMS ihevce_get_luma_eo_sao_params_neon; 157 FT_ITRANS_RECON_DC ihevce_itrans_recon_dc_neon; 158 FT_GET_EO_SAO_PARAMS ihevce_get_chroma_eo_sao_params_neon; 159 FT_SCAN_COEFFS ihevce_scan_coeffs_neon; 160 FT_WT_AVG_2D ihevce_wt_avg_2d_neon; 161 #endif 162 163 #endif 164