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