xref: /aosp_15_r20/external/libavc/encoder/ih264e_half_pel.h (revision 495ae853bb871d1e5a258cb02c2cc13cde8ddb9a)
1*495ae853SAndroid Build Coastguard Worker /******************************************************************************
2*495ae853SAndroid Build Coastguard Worker  *
3*495ae853SAndroid Build Coastguard Worker  * Copyright (C) 2015 The Android Open Source Project
4*495ae853SAndroid Build Coastguard Worker  *
5*495ae853SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
6*495ae853SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
7*495ae853SAndroid Build Coastguard Worker  * You may obtain a copy of the License at:
8*495ae853SAndroid Build Coastguard Worker  *
9*495ae853SAndroid Build Coastguard Worker  * http://www.apache.org/licenses/LICENSE-2.0
10*495ae853SAndroid Build Coastguard Worker  *
11*495ae853SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
12*495ae853SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
13*495ae853SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14*495ae853SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
15*495ae853SAndroid Build Coastguard Worker  * limitations under the License.
16*495ae853SAndroid Build Coastguard Worker  *
17*495ae853SAndroid Build Coastguard Worker  *****************************************************************************
18*495ae853SAndroid Build Coastguard Worker  * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore
19*495ae853SAndroid Build Coastguard Worker */
20*495ae853SAndroid Build Coastguard Worker 
21*495ae853SAndroid Build Coastguard Worker /**
22*495ae853SAndroid Build Coastguard Worker *******************************************************************************
23*495ae853SAndroid Build Coastguard Worker * @file
24*495ae853SAndroid Build Coastguard Worker *  ih264e_half_pel.h
25*495ae853SAndroid Build Coastguard Worker *
26*495ae853SAndroid Build Coastguard Worker * @brief
27*495ae853SAndroid Build Coastguard Worker *  Contains declarations of subpel functions used by the encoder
28*495ae853SAndroid Build Coastguard Worker *
29*495ae853SAndroid Build Coastguard Worker * @author
30*495ae853SAndroid Build Coastguard Worker *  ittiam
31*495ae853SAndroid Build Coastguard Worker *
32*495ae853SAndroid Build Coastguard Worker * @remarks
33*495ae853SAndroid Build Coastguard Worker *  none
34*495ae853SAndroid Build Coastguard Worker *
35*495ae853SAndroid Build Coastguard Worker *******************************************************************************
36*495ae853SAndroid Build Coastguard Worker */
37*495ae853SAndroid Build Coastguard Worker 
38*495ae853SAndroid Build Coastguard Worker #ifndef _IH264E_HALF_PEL_H_
39*495ae853SAndroid Build Coastguard Worker #define _IH264E_HALF_PEL_H_
40*495ae853SAndroid Build Coastguard Worker 
41*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
42*495ae853SAndroid Build Coastguard Worker /* Constant Macros                                                           */
43*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
44*495ae853SAndroid Build Coastguard Worker /*
45*495ae853SAndroid Build Coastguard Worker  * Dimensions of subpel plane buffers
46*495ae853SAndroid Build Coastguard Worker  */
47*495ae853SAndroid Build Coastguard Worker #define HP_PL_WD  MB_SIZE + 1
48*495ae853SAndroid Build Coastguard Worker #define HP_PL_HT  MB_SIZE + 1
49*495ae853SAndroid Build Coastguard Worker 
50*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
51*495ae853SAndroid Build Coastguard Worker /* Function Declarations                                                     */
52*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
53*495ae853SAndroid Build Coastguard Worker 
54*495ae853SAndroid Build Coastguard Worker typedef void ih264e_sixtapfilter_horz_ft(UWORD8 *pu1_src,
55*495ae853SAndroid Build Coastguard Worker                                          UWORD8 *pu1_dst,
56*495ae853SAndroid Build Coastguard Worker                                          WORD32 src_strd,
57*495ae853SAndroid Build Coastguard Worker                                          WORD32 dst_strd);
58*495ae853SAndroid Build Coastguard Worker 
59*495ae853SAndroid Build Coastguard Worker typedef void ih264e_sixtap_filter_2dvh_vert_ft(UWORD8 *pu1_src,
60*495ae853SAndroid Build Coastguard Worker                                                UWORD8 *pu1_dst1,
61*495ae853SAndroid Build Coastguard Worker                                                UWORD8 *pu1_dst2,
62*495ae853SAndroid Build Coastguard Worker                                                WORD32 src_strd,
63*495ae853SAndroid Build Coastguard Worker                                                WORD32 dst_strd,
64*495ae853SAndroid Build Coastguard Worker                                                WORD32 *pi4_pred,
65*495ae853SAndroid Build Coastguard Worker                                                WORD32 i4_pred_strd);
66*495ae853SAndroid Build Coastguard Worker 
67*495ae853SAndroid Build Coastguard Worker /* C Declarations */
68*495ae853SAndroid Build Coastguard Worker ih264e_sixtapfilter_horz_ft ih264e_sixtapfilter_horz;
69*495ae853SAndroid Build Coastguard Worker ih264e_sixtap_filter_2dvh_vert_ft ih264e_sixtap_filter_2dvh_vert;
70*495ae853SAndroid Build Coastguard Worker 
71*495ae853SAndroid Build Coastguard Worker /* A9 Declarations */
72*495ae853SAndroid Build Coastguard Worker ih264e_sixtapfilter_horz_ft ih264e_sixtapfilter_horz_a9q;
73*495ae853SAndroid Build Coastguard Worker ih264e_sixtap_filter_2dvh_vert_ft ih264e_sixtap_filter_2dvh_vert_a9q;
74*495ae853SAndroid Build Coastguard Worker 
75*495ae853SAndroid Build Coastguard Worker /* AV8 Declarations */
76*495ae853SAndroid Build Coastguard Worker ih264e_sixtapfilter_horz_ft ih264e_sixtapfilter_horz_av8;
77*495ae853SAndroid Build Coastguard Worker ih264e_sixtap_filter_2dvh_vert_ft ih264e_sixtap_filter_2dvh_vert_av8;
78*495ae853SAndroid Build Coastguard Worker 
79*495ae853SAndroid Build Coastguard Worker /* SSSE3 Declarations */
80*495ae853SAndroid Build Coastguard Worker ih264e_sixtapfilter_horz_ft ih264e_sixtapfilter_horz_ssse3;
81*495ae853SAndroid Build Coastguard Worker ih264e_sixtap_filter_2dvh_vert_ft ih264e_sixtap_filter_2dvh_vert_ssse3;
82*495ae853SAndroid Build Coastguard Worker 
83*495ae853SAndroid Build Coastguard Worker #endif /* _IH264E_HALF_PEL_H_ */
84