1/******************************************************************************
2 *
3 * Copyright (C) 2015 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*  ih264e_function_selector_generic.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*  - ih264e_init_function_ptr_generic
33*
34* @remarks
35*  None
36*
37*******************************************************************************
38*/
39
40
41/*****************************************************************************/
42/* File Includes                                                             */
43/*****************************************************************************/
44
45/*****************************************************************************/
46/* File Includes                                                             */
47/*****************************************************************************/
48
49/* System Include files */
50#include <stdio.h>
51#include <stddef.h>
52#include <stdlib.h>
53#include <string.h>
54
55/* User Include files */
56#include "ih264_typedefs.h"
57#include "iv2.h"
58#include "ive2.h"
59#include "ih264_defs.h"
60#include "ih264_size_defs.h"
61#include "ih264e_defs.h"
62#include "ih264e_error.h"
63#include "ih264e_bitstream.h"
64#include "ime_distortion_metrics.h"
65#include "ime_defs.h"
66#include "ime_structs.h"
67#include "ih264_error.h"
68#include "ih264_structs.h"
69#include "ih264_trans_quant_itrans_iquant.h"
70#include "ih264_inter_pred_filters.h"
71#include "ih264_mem_fns.h"
72#include "ih264_padding.h"
73#include "ih264_intra_pred_filters.h"
74#include "ih264_deblk_edge_filters.h"
75#include "ih264_cabac_tables.h"
76#include "irc_cntrl_param.h"
77#include "irc_frame_info_collector.h"
78#include "ih264e_rate_control.h"
79#include "ih264e_cabac_structs.h"
80#include "ih264e_structs.h"
81#include "ih264e_platform_macros.h"
82#include "ih264e_cabac.h"
83#include "ih264e_core_coding.h"
84#include "ih264_cavlc_tables.h"
85#include "ih264e_cavlc.h"
86#include "ih264e_intra_modes_eval.h"
87#include "ih264e_fmt_conv.h"
88#include "ih264e_half_pel.h"
89
90
91/**
92*******************************************************************************
93*
94* @brief Initialize the intra/inter/transform/deblk function pointers of
95* codec context
96*
97* @par Description: the current routine initializes the function pointers of
98* codec context basing on the architecture in use
99*
100* @param[in] ps_codec
101*  Codec context pointer
102*
103* @returns  none
104*
105* @remarks none
106*
107*******************************************************************************
108*/
109void ih264e_init_function_ptr_neon_av8(codec_t *ps_codec)
110{
111
112    WORD32 i= 0;
113
114        /* curr proc ctxt */
115        process_ctxt_t *ps_proc = NULL;
116        me_ctxt_t *ps_me_ctxt = NULL;
117
118        /* Init function pointers for intra pred leaf level functions luma
119         * Intra 16x16 */
120        ps_codec->apf_intra_pred_16_l[0] = ih264_intra_pred_luma_16x16_mode_vert_av8;
121        ps_codec->apf_intra_pred_16_l[1] = ih264_intra_pred_luma_16x16_mode_horz_av8;
122        ps_codec->apf_intra_pred_16_l[2] = ih264_intra_pred_luma_16x16_mode_dc_av8;
123        ps_codec->apf_intra_pred_16_l[3] = ih264_intra_pred_luma_16x16_mode_plane_av8;
124
125        /* Init function pointers for intra pred leaf level functions luma
126         * Intra 4x4 */
127        ps_codec->apf_intra_pred_4_l[0] = ih264_intra_pred_luma_4x4_mode_vert_av8;
128        ps_codec->apf_intra_pred_4_l[1] = ih264_intra_pred_luma_4x4_mode_horz_av8;
129        ps_codec->apf_intra_pred_4_l[2] = ih264_intra_pred_luma_4x4_mode_dc_av8;
130        ps_codec->apf_intra_pred_4_l[3] = ih264_intra_pred_luma_4x4_mode_diag_dl_av8;
131        ps_codec->apf_intra_pred_4_l[4] = ih264_intra_pred_luma_4x4_mode_diag_dr_av8;
132        ps_codec->apf_intra_pred_4_l[5] = ih264_intra_pred_luma_4x4_mode_vert_r_av8;
133        ps_codec->apf_intra_pred_4_l[6] = ih264_intra_pred_luma_4x4_mode_horz_d_av8;
134        ps_codec->apf_intra_pred_4_l[7] = ih264_intra_pred_luma_4x4_mode_vert_l_av8;
135        ps_codec->apf_intra_pred_4_l[8] = ih264_intra_pred_luma_4x4_mode_horz_u_av8;
136
137        /* Init function pointers for intra pred leaf level functions luma
138         * Intra 8x8 */
139        ps_codec->apf_intra_pred_8_l[0] = ih264_intra_pred_luma_8x8_mode_vert_av8;
140        ps_codec->apf_intra_pred_8_l[2] = ih264_intra_pred_luma_8x8_mode_dc_av8;
141        ps_codec->apf_intra_pred_8_l[3] = ih264_intra_pred_luma_8x8_mode_diag_dl_av8;
142        ps_codec->apf_intra_pred_8_l[4] = ih264_intra_pred_luma_8x8_mode_diag_dr_av8;
143        ps_codec->apf_intra_pred_8_l[5] = ih264_intra_pred_luma_8x8_mode_vert_r_av8;
144        ps_codec->apf_intra_pred_8_l[6] = ih264_intra_pred_luma_8x8_mode_horz_d_av8;
145        ps_codec->apf_intra_pred_8_l[7] = ih264_intra_pred_luma_8x8_mode_vert_l_av8;
146        ps_codec->apf_intra_pred_8_l[8] = ih264_intra_pred_luma_8x8_mode_horz_u_av8;
147
148        /* Init function pointers for intra pred leaf level functions chroma
149         * Intra 8x8 */
150        ps_codec->apf_intra_pred_c[0] = ih264_intra_pred_chroma_8x8_mode_dc_av8;
151        ps_codec->apf_intra_pred_c[1] = ih264_intra_pred_chroma_8x8_mode_horz_av8;
152        ps_codec->apf_intra_pred_c[2] = ih264_intra_pred_chroma_8x8_mode_vert_av8;
153        ps_codec->apf_intra_pred_c[3] = ih264_intra_pred_chroma_8x8_mode_plane_av8;
154
155
156        /* Init forward transform fn ptr */
157        ps_codec->pf_resi_trans_quant_8x8           = ih264_resi_trans_quant_8x8;
158        ps_codec->pf_resi_trans_quant_4x4           = ih264_resi_trans_quant_4x4_av8;
159        ps_codec->pf_resi_trans_quant_chroma_4x4    = ih264_resi_trans_quant_chroma_4x4_av8;
160        ps_codec->pf_hadamard_quant_4x4             = ih264_hadamard_quant_4x4_av8;
161        ps_codec->pf_hadamard_quant_2x2_uv          = ih264_hadamard_quant_2x2_uv_av8;
162
163        /* Init inverse transform fn ptr */
164        ps_codec->pf_iquant_itrans_recon_8x8          = ih264_iquant_itrans_recon_8x8_av8;
165        ps_codec->pf_iquant_itrans_recon_4x4          = ih264_iquant_itrans_recon_4x4_av8;
166        ps_codec->pf_iquant_itrans_recon_4x4_dc       = ih264_iquant_itrans_recon_4x4_dc_av8;
167        ps_codec->pf_iquant_itrans_recon_chroma_4x4   = ih264_iquant_itrans_recon_chroma_4x4_av8;
168        ps_codec->pf_iquant_itrans_recon_chroma_4x4_dc = ih264_iquant_itrans_recon_chroma_4x4_dc_av8;
169        ps_codec->pf_ihadamard_scaling_4x4            = ih264_ihadamard_scaling_4x4_av8;
170        ps_codec->pf_ihadamard_scaling_2x2_uv         = ih264_ihadamard_scaling_2x2_uv_av8;
171        ps_codec->pf_interleave_copy                  = ih264_interleave_copy_av8;
172
173        /* Init fn ptr luma core coding */
174        ps_codec->luma_energy_compaction[0] = ih264e_code_luma_intra_macroblock_16x16;
175        ps_codec->luma_energy_compaction[1] = ih264e_code_luma_intra_macroblock_4x4;
176        ps_codec->luma_energy_compaction[3] = ih264e_code_luma_inter_macroblock_16x16;
177
178        /* Init fn ptr chroma core coding */
179        ps_codec->chroma_energy_compaction[0] = ih264e_code_chroma_intra_macroblock_8x8;
180        ps_codec->chroma_energy_compaction[1] = ih264e_code_chroma_inter_macroblock_8x8;
181
182        /* Init fn ptr luma deblocking */
183        ps_codec->pf_deblk_luma_vert_bs4 = ih264_deblk_luma_vert_bs4_av8;
184        ps_codec->pf_deblk_luma_vert_bslt4 = ih264_deblk_luma_vert_bslt4_av8;
185        ps_codec->pf_deblk_luma_horz_bs4 = ih264_deblk_luma_horz_bs4_av8;
186        ps_codec->pf_deblk_luma_horz_bslt4 = ih264_deblk_luma_horz_bslt4_av8;
187
188          /* Init fn ptr chroma deblocking */
189        ps_codec->pf_deblk_chroma_vert_bs4 = ih264_deblk_chroma_vert_bs4_av8;
190        ps_codec->pf_deblk_chroma_vert_bslt4 = ih264_deblk_chroma_vert_bslt4_av8;
191        ps_codec->pf_deblk_chroma_horz_bs4 = ih264_deblk_chroma_horz_bs4_av8;
192        ps_codec->pf_deblk_chroma_horz_bslt4 = ih264_deblk_chroma_horz_bslt4_av8;
193
194        /* write mb syntax layer */
195        /* write mb syntax layer */
196        ps_codec->pf_write_mb_syntax_layer[CAVLC][ISLICE] = ih264e_write_islice_mb_cavlc;
197        ps_codec->pf_write_mb_syntax_layer[CAVLC][PSLICE] = ih264e_write_pslice_mb_cavlc;
198        ps_codec->pf_write_mb_syntax_layer[CAVLC][BSLICE] = ih264e_write_bslice_mb_cavlc;
199        ps_codec->pf_write_mb_syntax_layer[CABAC][ISLICE] = ih264e_write_islice_mb_cabac;
200        ps_codec->pf_write_mb_syntax_layer[CABAC][PSLICE] = ih264e_write_pslice_mb_cabac;
201
202        /* Padding Functions */
203        ps_codec->pf_pad_top = ih264_pad_top_av8;
204        ps_codec->pf_pad_bottom = ih264_pad_bottom;
205        ps_codec->pf_pad_left_luma = ih264_pad_left_luma_av8;
206        ps_codec->pf_pad_left_chroma = ih264_pad_left_chroma_av8;
207        ps_codec->pf_pad_right_luma = ih264_pad_right_luma_av8;
208        ps_codec->pf_pad_right_chroma = ih264_pad_right_chroma_av8;
209
210        /* Inter pred leaf level functions */
211        ps_codec->pf_inter_pred_luma_copy = ih264_inter_pred_luma_copy_av8;
212        ps_codec->pf_inter_pred_luma_horz = ih264_inter_pred_luma_horz_av8;
213        ps_codec->pf_inter_pred_luma_vert = ih264_inter_pred_luma_vert_av8;
214        ps_codec->pf_inter_pred_luma_bilinear = ih264_inter_pred_luma_bilinear;
215        ps_codec->pf_inter_pred_chroma = ih264_inter_pred_chroma_av8;
216
217        /* sad me level functions */
218        ps_codec->apf_compute_sad_16x16[0] = ime_compute_sad_16x16_av8;
219        ps_codec->apf_compute_sad_16x16[1] = ime_compute_sad_16x16_fast_av8;
220        ps_codec->pf_compute_sad_16x8 = ime_compute_sad_16x8_av8;
221
222        /* memor handling operations */
223        ps_codec->pf_mem_cpy = ih264_memcpy_av8;
224        ps_codec->pf_mem_cpy_mul8 = ih264_memcpy_mul_8_av8;
225        ps_codec->pf_mem_set = ih264_memset_av8;
226        ps_codec->pf_mem_set_mul8 = ih264_memset_mul_8_av8;
227
228        /* sad me level functions */
229        for(i = 0; i < (MAX_PROCESS_CTXT); i++)
230        {
231            ps_proc = &ps_codec->as_process[i];
232            ps_me_ctxt = &ps_proc->s_me_ctxt;
233            ps_me_ctxt->pf_ime_compute_sad_16x16[0] = ime_compute_sad_16x16_av8;
234            ps_me_ctxt->pf_ime_compute_sad_16x16[1] = ime_compute_sad_16x16_fast_av8;
235            ps_me_ctxt->pf_ime_compute_sad_16x8 = ime_compute_sad_16x8_av8;
236            ps_me_ctxt->pf_ime_compute_sad4_diamond = ime_calculate_sad4_prog_av8;
237            ps_me_ctxt->pf_ime_compute_sad3_diamond = ime_calculate_sad3_prog_av8;
238            ps_me_ctxt->pf_ime_compute_sad2_diamond = ime_calculate_sad2_prog_av8;
239            ps_me_ctxt->pf_ime_sub_pel_compute_sad_16x16 = ime_sub_pel_compute_sad_16x16_av8;
240            ps_me_ctxt->pf_ime_compute_sad_stat_luma_16x16 = ime_compute_satqd_16x16_lumainter_av8;
241        }
242
243        /* intra mode eval -encoder level function */
244        ps_codec->pf_ih264e_evaluate_intra16x16_modes = ih264e_evaluate_intra16x16_modes_av8;
245        ps_codec->pf_ih264e_evaluate_intra_chroma_modes = ih264e_evaluate_intra_chroma_modes_av8;
246        ps_codec->pf_ih264e_evaluate_intra_4x4_modes = ih264e_evaluate_intra_4x4_modes;
247
248        /* csc */
249        ps_codec->pf_ih264e_conv_420p_to_420sp = ih264e_fmt_conv_420p_to_420sp;
250        ps_codec->pf_ih264e_fmt_conv_422i_to_420sp = ih264e_fmt_conv_422i_to_420sp;
251
252        /* Halp pel generation function - encoder level*/
253        ps_codec->pf_ih264e_sixtapfilter_horz = ih264e_sixtapfilter_horz_av8;
254        ps_codec->pf_ih264e_sixtap_filter_2dvh_vert = ih264e_sixtap_filter_2dvh_vert_av8;
255
256        return ;
257    }
258
259