huangcm
2024-12-18 9d29be7f7249789d6ffd0440067187a9f040c2cd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
/******************************************************************************
*
* Copyright (C) 2012 Ittiam Systems Pvt Ltd, Bangalore
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at:
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
******************************************************************************/
/**
*******************************************************************************
* @file
*  ihevc_itrans_recon.h
*
* @brief
*  Functions declarations for inverse transform and  reconstruction
*
* @author
*  Ittiam
*
* @remarks
*  None
*
*******************************************************************************
*/
#ifndef _IHEVC_ITRANS_RECON_H_
#define _IHEVC_ITRANS_RECON_H_
 
typedef void ihevc_itrans_recon_4x4_ttype1_ft(WORD16 *pi2_src,
                                              WORD16 *pi2_tmp,
                                              UWORD8 *pu1_pred,
                                              UWORD8 *pu1_dst,
                                              WORD32 src_strd,
                                              WORD32 pred_strd,
                                              WORD32 dst_strd,
                                              WORD32 zero_cols,
                                              WORD32 zero_rows);
typedef void ihevc_hbd_itrans_recon_4x4_ttype1_ft(WORD16 *pi2_src,
                                                  WORD16 *pi2_tmp,
                                                  UWORD16 *pu2_pred,
                                                  UWORD16 *pu2_dst,
                                                  WORD32 src_strd,
                                                  WORD32 pred_strd,
                                                  WORD32 dst_strd,
                                                  WORD32 zero_cols,
                                                  WORD32 zero_rows,
                                                  UWORD8 bit_depth);
typedef void ihevc_itrans_recon_4x4_ft(WORD16 *pi2_src,
                                       WORD16 *pi2_tmp,
                                       UWORD8 *pu1_pred,
                                       UWORD8 *pu1_dst,
                                       WORD32 src_strd,
                                       WORD32 pred_strd,
                                       WORD32 dst_strd,
                                       WORD32 zero_cols,
                                       WORD32 zero_rows);
typedef void ihevc_hbd_itrans_recon_4x4_ft(WORD16 *pi2_src,
                                           WORD16 *pi2_tmp,
                                           UWORD16 *pu2_pred,
                                           UWORD16 *pu2_dst,
                                           WORD32 src_strd,
                                           WORD32 pred_strd,
                                           WORD32 dst_strd,
                                           WORD32 zero_cols,
                                           WORD32 zero_rows,
                                           UWORD8 bit_depth);
typedef void ihevc_itrans_recon_8x8_ft(WORD16 *pi2_src,
                                       WORD16 *pi2_tmp,
                                       UWORD8 *pu1_pred,
                                       UWORD8 *pu1_dst,
                                       WORD32 src_strd,
                                       WORD32 pred_strd,
                                       WORD32 dst_strd,
                                       WORD32 zero_cols,
                                       WORD32 zero_rows);
typedef void ihevc_hbd_itrans_recon_8x8_ft(WORD16 *pi2_src,
                                           WORD16 *pi2_tmp,
                                           UWORD16 *pu2_pred,
                                           UWORD16 *pu2_dst,
                                           WORD32 src_strd,
                                           WORD32 pred_strd,
                                           WORD32 dst_strd,
                                           WORD32 zero_cols,
                                           WORD32 zero_rows,
                                           UWORD8 bit_depth);
typedef void ihevc_itrans_recon_16x16_ft(WORD16 *pi2_src,
                                         WORD16 *pi2_tmp,
                                         UWORD8 *pu1_pred,
                                         UWORD8 *pu1_dst,
                                         WORD32 src_strd,
                                         WORD32 pred_strd,
                                         WORD32 dst_strd,
                                         WORD32 zero_cols,
                                         WORD32 zero_rows);
typedef void ihevc_hbd_itrans_recon_16x16_ft(WORD16 *pi2_src,
                                             WORD16 *pi2_tmp,
                                             UWORD16 *pu2_pred,
                                             UWORD16 *pu2_dst,
                                             WORD32 src_strd,
                                             WORD32 pred_strd,
                                             WORD32 dst_strd,
                                             WORD32 zero_cols,
                                             WORD32 zero_rows,
                                             UWORD8 bit_depth);
typedef void ihevc_itrans_recon_32x32_ft(WORD16 *pi2_src,
                                         WORD16 *pi2_tmp,
                                         UWORD8 *pu1_pred,
                                         UWORD8 *pu1_dst,
                                         WORD32 src_strd,
                                         WORD32 pred_strd,
                                         WORD32 dst_strd,
                                         WORD32 zero_cols,
                                         WORD32 zero_rows);
typedef void ihevc_hbd_itrans_recon_32x32_ft(WORD16 *pi2_src,
                                             WORD16 *pi2_tmp,
                                             UWORD16 *pu2_pred,
                                             UWORD16 *pu2_dst,
                                             WORD32 src_strd,
                                             WORD32 pred_strd,
                                             WORD32 dst_strd,
                                             WORD32 zero_cols,
                                             WORD32 zero_rows,
                                             UWORD8 bit_depth);
 
/* C function declarations */
ihevc_itrans_recon_4x4_ttype1_ft ihevc_itrans_recon_4x4_ttype1;
ihevc_itrans_recon_4x4_ft ihevc_itrans_recon_4x4;
ihevc_itrans_recon_8x8_ft ihevc_itrans_recon_8x8;
ihevc_itrans_recon_16x16_ft ihevc_itrans_recon_16x16;
ihevc_itrans_recon_32x32_ft ihevc_itrans_recon_32x32;
 
ihevc_hbd_itrans_recon_4x4_ttype1_ft ihevc_hbd_itrans_recon_4x4_ttype1;
ihevc_hbd_itrans_recon_4x4_ft ihevc_hbd_itrans_recon_4x4;
ihevc_hbd_itrans_recon_8x8_ft ihevc_hbd_itrans_recon_8x8;
ihevc_hbd_itrans_recon_16x16_ft ihevc_hbd_itrans_recon_16x16;
ihevc_hbd_itrans_recon_32x32_ft ihevc_hbd_itrans_recon_32x32;
 
/* A9 Q function declarations */
ihevc_itrans_recon_4x4_ttype1_ft ihevc_itrans_recon_4x4_ttype1_a9q;
ihevc_itrans_recon_4x4_ft ihevc_itrans_recon_4x4_a9q;
ihevc_itrans_recon_8x8_ft ihevc_itrans_recon_8x8_a9q;
ihevc_itrans_recon_16x16_ft ihevc_itrans_recon_16x16_a9q;
ihevc_itrans_recon_32x32_ft ihevc_itrans_recon_32x32_a9q;
 
/* A9 A function declarations */
ihevc_itrans_recon_4x4_ttype1_ft ihevc_itrans_recon_4x4_ttype1_a9a;
ihevc_itrans_recon_4x4_ft ihevc_itrans_recon_4x4_a9a;
ihevc_itrans_recon_8x8_ft ihevc_itrans_recon_8x8_a9a;
ihevc_itrans_recon_16x16_ft ihevc_itrans_recon_16x16_a9a;
ihevc_itrans_recon_32x32_ft ihevc_itrans_recon_32x32_a9a;
 
/* NEONINTR function declarations */
ihevc_itrans_recon_4x4_ttype1_ft ihevc_itrans_recon_4x4_ttype1_neonintr;
ihevc_itrans_recon_4x4_ft ihevc_itrans_recon_4x4_neonintr;
ihevc_itrans_recon_8x8_ft ihevc_itrans_recon_8x8_neonintr;
ihevc_itrans_recon_16x16_ft ihevc_itrans_recon_16x16_neonintr;
ihevc_itrans_recon_32x32_ft ihevc_itrans_recon_32x32_neonintr;
 
/* SSSE31 function declarations */
ihevc_itrans_recon_4x4_ttype1_ft ihevc_itrans_recon_4x4_ttype1_ssse3;
ihevc_itrans_recon_4x4_ft ihevc_itrans_recon_4x4_ssse3;
ihevc_itrans_recon_8x8_ft ihevc_itrans_recon_8x8_ssse3;
ihevc_itrans_recon_16x16_ft ihevc_itrans_recon_16x16_ssse3;
ihevc_itrans_recon_32x32_ft ihevc_itrans_recon_32x32_ssse3;
 
/* SSE42 function declarations */
ihevc_itrans_recon_4x4_ttype1_ft ihevc_itrans_recon_4x4_ttype1_sse42;
ihevc_itrans_recon_4x4_ft ihevc_itrans_recon_4x4_sse42;
ihevc_itrans_recon_8x8_ft ihevc_itrans_recon_8x8_sse42;
ihevc_itrans_recon_32x32_ft ihevc_itrans_recon_32x32_sse42;
 
ihevc_hbd_itrans_recon_4x4_ttype1_ft ihevc_hbd_itrans_recon_4x4_ttype1_sse42;
ihevc_hbd_itrans_recon_4x4_ft ihevc_hbd_itrans_recon_4x4_sse42;
ihevc_hbd_itrans_recon_8x8_ft ihevc_hbd_itrans_recon_8x8_sse42;
ihevc_hbd_itrans_recon_16x16_ft ihevc_hbd_itrans_recon_16x16_sse42;
ihevc_hbd_itrans_recon_32x32_ft ihevc_hbd_itrans_recon_32x32_sse42;
 
 
/* armv8 function declarations */
ihevc_itrans_recon_4x4_ttype1_ft ihevc_itrans_recon_4x4_ttype1_av8;
ihevc_itrans_recon_4x4_ft ihevc_itrans_recon_4x4_av8;
ihevc_itrans_recon_8x8_ft ihevc_itrans_recon_8x8_av8;
ihevc_itrans_recon_16x16_ft ihevc_itrans_recon_16x16_av8;
ihevc_itrans_recon_32x32_ft ihevc_itrans_recon_32x32_av8;
#endif /*_IHEVC_ITRANS_RECON_H_*/