xref: /aosp_15_r20/external/libavc/encoder/x86/svc/isvce_function_selector_ssse3.c (revision 495ae853bb871d1e5a258cb02c2cc13cde8ddb9a)
1 /******************************************************************************
2  *
3  * Copyright (C) 2022 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
23 *  isvce_function_selector_ssse3.c
24 *
25 * @brief
26 *  Contains functions to initialize function pointers of codec context
27 *
28 * @author
29 *  Ittiam
30 *
31 * @par List of Functions:
32 *  - isvce_init_function_ptr_ssse3
33 *
34 * @remarks
35 *  None
36 *
37 *******************************************************************************
38 */
39 
40 /*****************************************************************************/
41 /* File Includes                                                             */
42 /*****************************************************************************/
43 
44 /* System Include files */
45 #include <stdio.h>
46 #include <stddef.h>
47 #include <stdlib.h>
48 #include <string.h>
49 
50 /* User Include files */
51 #include "ih264_typedefs.h"
52 #include "iv2.h"
53 #include "ive2.h"
54 #include "isvc_defs.h"
55 #include "ih264_size_defs.h"
56 #include "isvce_defs.h"
57 #include "ih264e_error.h"
58 #include "ih264e_bitstream.h"
59 #include "ime_distortion_metrics.h"
60 #include "ime_defs.h"
61 #include "ime_structs.h"
62 #include "ih264_error.h"
63 #include "isvc_structs.h"
64 #include "isvc_trans_quant_itrans_iquant.h"
65 #include "ih264_inter_pred_filters.h"
66 #include "ih264_mem_fns.h"
67 #include "isvc_mem_fns.h"
68 #include "ih264_padding.h"
69 #include "ih264_intra_pred_filters.h"
70 #include "ih264_deblk_edge_filters.h"
71 #include "isvc_cabac_tables.h"
72 #include "irc_cntrl_param.h"
73 #include "irc_frame_info_collector.h"
74 #include "isvce_rate_control.h"
75 #include "isvce_cabac_structs.h"
76 #include "isvce_structs.h"
77 #include "ih264e_platform_macros.h"
78 #include "isvce_cabac.h"
79 #include "isvce_core_coding.h"
80 #include "ih264_cavlc_tables.h"
81 #include "isvce_cavlc.h"
82 #include "ih264e_intra_modes_eval.h"
83 #include "ih264e_fmt_conv.h"
84 #include "ih264e_half_pel.h"
85 
86 /**
87 *******************************************************************************
88 *
89 * @brief Initialize the intra/inter/transform/deblk function pointers of
90 * codec context
91 *
92 * @par Description: the current routine initializes the function pointers of
93 * codec context basing on the architecture in use
94 *
95 * @param[in] ps_codec
96 *  Codec context pointer
97 *
98 * @returns  none
99 *
100 * @remarks none
101 *
102 *******************************************************************************
103 */
isvce_init_function_ptr_ssse3(isvce_codec_t * ps_codec)104 void isvce_init_function_ptr_ssse3(isvce_codec_t *ps_codec)
105 {
106     isa_dependent_fxns_t *ps_isa_dependent_fxns = &ps_codec->s_isa_dependent_fxns;
107     inter_pred_fxns_t *ps_inter_pred_fxns = &ps_isa_dependent_fxns->s_inter_pred_fxns;
108     mem_fxns_t *ps_mem_fxns = &ps_isa_dependent_fxns->s_mem_fxns;
109 
110     /* Init function pointers for intra pred leaf level functions luma
111      * Intra 16x16 */
112     ps_codec->apf_intra_pred_16_l[0] = ih264_intra_pred_luma_16x16_mode_vert_ssse3;
113     ps_codec->apf_intra_pred_16_l[1] = ih264_intra_pred_luma_16x16_mode_horz_ssse3;
114     ps_codec->apf_intra_pred_16_l[2] = ih264_intra_pred_luma_16x16_mode_dc_ssse3;
115     ps_codec->apf_intra_pred_16_l[3] = ih264_intra_pred_luma_16x16_mode_plane_ssse3;
116 
117     /* Init function pointers for intra pred leaf level functions luma
118      * Intra 4x4 */
119     ps_codec->apf_intra_pred_4_l[0] = ih264_intra_pred_luma_4x4_mode_vert_ssse3;
120     ps_codec->apf_intra_pred_4_l[1] = ih264_intra_pred_luma_4x4_mode_horz_ssse3;
121     ps_codec->apf_intra_pred_4_l[2] = ih264_intra_pred_luma_4x4_mode_dc_ssse3;
122     ps_codec->apf_intra_pred_4_l[3] = ih264_intra_pred_luma_4x4_mode_diag_dl_ssse3;
123     ps_codec->apf_intra_pred_4_l[4] = ih264_intra_pred_luma_4x4_mode_diag_dr_ssse3;
124     ps_codec->apf_intra_pred_4_l[5] = ih264_intra_pred_luma_4x4_mode_vert_r_ssse3;
125     ps_codec->apf_intra_pred_4_l[6] = ih264_intra_pred_luma_4x4_mode_horz_d_ssse3;
126     ps_codec->apf_intra_pred_4_l[7] = ih264_intra_pred_luma_4x4_mode_vert_l_ssse3;
127     ps_codec->apf_intra_pred_4_l[8] = ih264_intra_pred_luma_4x4_mode_horz_u_ssse3;
128 
129     /* Init function pointers for intra pred leaf level functions luma
130      * Intra 8x8 */
131     ps_codec->apf_intra_pred_8_l[0] = ih264_intra_pred_luma_8x8_mode_vert_ssse3;
132     ps_codec->apf_intra_pred_8_l[2] = ih264_intra_pred_luma_8x8_mode_dc_ssse3;
133     ps_codec->apf_intra_pred_8_l[3] = ih264_intra_pred_luma_8x8_mode_diag_dl_ssse3;
134     ps_codec->apf_intra_pred_8_l[4] = ih264_intra_pred_luma_8x8_mode_diag_dr_ssse3;
135     ps_codec->apf_intra_pred_8_l[5] = ih264_intra_pred_luma_8x8_mode_vert_r_ssse3;
136     ps_codec->apf_intra_pred_8_l[6] = ih264_intra_pred_luma_8x8_mode_horz_d_ssse3;
137     ps_codec->apf_intra_pred_8_l[7] = ih264_intra_pred_luma_8x8_mode_vert_l_ssse3;
138     ps_codec->apf_intra_pred_8_l[8] = ih264_intra_pred_luma_8x8_mode_horz_u_ssse3;
139 
140     /* Init function pointers for intra pred leaf level functions chroma
141      * Intra 8x8 */
142     ps_codec->apf_intra_pred_c[1] = ih264_intra_pred_chroma_8x8_mode_horz_ssse3;
143     ps_codec->apf_intra_pred_c[2] = ih264_intra_pred_chroma_8x8_mode_vert_ssse3;
144     ps_codec->apf_intra_pred_c[3] = ih264_intra_pred_chroma_8x8_mode_plane_ssse3;
145 
146     /* Init fn ptr luma deblocking */
147     ps_codec->pf_deblk_luma_vert_bs4 = ih264_deblk_luma_vert_bs4_ssse3;
148     ps_codec->pf_deblk_luma_vert_bslt4 = ih264_deblk_luma_vert_bslt4_ssse3;
149     ps_codec->pf_deblk_luma_horz_bs4 = ih264_deblk_luma_horz_bs4_ssse3;
150     ps_codec->pf_deblk_luma_horz_bslt4 = ih264_deblk_luma_horz_bslt4_ssse3;
151     /* Init fn ptr chroma deblocking */
152     ps_codec->pf_deblk_chroma_vert_bs4 = ih264_deblk_chroma_vert_bs4_ssse3;
153     ps_codec->pf_deblk_chroma_vert_bslt4 = ih264_deblk_chroma_vert_bslt4_ssse3;
154     ps_codec->pf_deblk_chroma_horz_bs4 = ih264_deblk_chroma_horz_bs4_ssse3;
155     ps_codec->pf_deblk_chroma_horz_bslt4 = ih264_deblk_chroma_horz_bslt4_ssse3;
156 
157     /* Padding Functions */
158     ps_codec->pf_pad_left_luma = ih264_pad_left_luma_ssse3;
159     ps_codec->pf_pad_left_chroma = ih264_pad_left_chroma_ssse3;
160     ps_codec->pf_pad_right_luma = ih264_pad_right_luma_ssse3;
161     ps_codec->pf_pad_right_chroma = ih264_pad_right_chroma_ssse3;
162 
163     /* Inter pred leaf level functions */
164     ps_inter_pred_fxns->pf_inter_pred_luma_copy = ih264_inter_pred_luma_copy_ssse3;
165     ps_inter_pred_fxns->pf_inter_pred_luma_horz = ih264_inter_pred_luma_horz_ssse3;
166     ps_inter_pred_fxns->pf_inter_pred_luma_vert = ih264_inter_pred_luma_vert_ssse3;
167     ps_inter_pred_fxns->pf_inter_pred_chroma = ih264_inter_pred_chroma_ssse3;
168 
169     /* memory handling operations */
170     ps_mem_fxns->pf_mem_cpy_mul8 = ih264_memcpy_mul_8_ssse3;
171     ps_mem_fxns->pf_mem_set_mul8 = ih264_memset_mul_8_ssse3;
172     ps_mem_fxns->pf_copy_2d = isvc_copy_2d_ssse3;
173 
174     /*intra mode eval -encoder level function*/
175     ps_codec->pf_ih264e_evaluate_intra16x16_modes = ih264e_evaluate_intra16x16_modes_ssse3;
176     ps_codec->pf_ih264e_evaluate_intra_4x4_modes = ih264e_evaluate_intra_4x4_modes_ssse3;
177     ps_codec->pf_ih264e_evaluate_intra_chroma_modes = ih264e_evaluate_intra_chroma_modes_ssse3;
178 
179     /* Halp pel generation function - encoder level*/
180     ps_codec->pf_ih264e_sixtapfilter_horz = ih264e_sixtapfilter_horz_ssse3;
181     ps_codec->pf_ih264e_sixtap_filter_2dvh_vert = ih264e_sixtap_filter_2dvh_vert_ssse3;
182 }
183