Upstream version 5.34.104.0
[platform/framework/web/crosswalk.git] / src / third_party / libvpx / source / config / linux / arm-neon / vp9_rtcd.h
1 #ifndef VP9_RTCD_H_
2 #define VP9_RTCD_H_
3
4 #ifdef RTCD_C
5 #define RTCD_EXTERN
6 #else
7 #define RTCD_EXTERN extern
8 #endif
9
10 #ifdef __cplusplus
11 extern "C" {
12 #endif
13
14 /*
15  * VP9
16  */
17
18 #include "vpx/vpx_integer.h"
19 #include "vp9/common/vp9_enums.h"
20
21 struct macroblockd;
22
23 /* Encoder forward decls */
24 struct macroblock;
25 struct vp9_variance_vtable;
26
27 #define DEC_MVCOSTS int *mvjcost, int *mvcost[2]
28 struct mv;
29 union int_mv;
30 struct yv12_buffer_config;
31
32 void vp9_d207_predictor_4x4_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
33 #define vp9_d207_predictor_4x4 vp9_d207_predictor_4x4_c
34
35 void vp9_d45_predictor_4x4_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
36 #define vp9_d45_predictor_4x4 vp9_d45_predictor_4x4_c
37
38 void vp9_d63_predictor_4x4_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
39 #define vp9_d63_predictor_4x4 vp9_d63_predictor_4x4_c
40
41 void vp9_h_predictor_4x4_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
42 void vp9_h_predictor_4x4_neon(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
43 #define vp9_h_predictor_4x4 vp9_h_predictor_4x4_neon
44
45 void vp9_d117_predictor_4x4_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
46 #define vp9_d117_predictor_4x4 vp9_d117_predictor_4x4_c
47
48 void vp9_d135_predictor_4x4_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
49 #define vp9_d135_predictor_4x4 vp9_d135_predictor_4x4_c
50
51 void vp9_d153_predictor_4x4_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
52 #define vp9_d153_predictor_4x4 vp9_d153_predictor_4x4_c
53
54 void vp9_v_predictor_4x4_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
55 void vp9_v_predictor_4x4_neon(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
56 #define vp9_v_predictor_4x4 vp9_v_predictor_4x4_neon
57
58 void vp9_tm_predictor_4x4_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
59 void vp9_tm_predictor_4x4_neon(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
60 #define vp9_tm_predictor_4x4 vp9_tm_predictor_4x4_neon
61
62 void vp9_dc_predictor_4x4_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
63 #define vp9_dc_predictor_4x4 vp9_dc_predictor_4x4_c
64
65 void vp9_dc_top_predictor_4x4_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
66 #define vp9_dc_top_predictor_4x4 vp9_dc_top_predictor_4x4_c
67
68 void vp9_dc_left_predictor_4x4_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
69 #define vp9_dc_left_predictor_4x4 vp9_dc_left_predictor_4x4_c
70
71 void vp9_dc_128_predictor_4x4_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
72 #define vp9_dc_128_predictor_4x4 vp9_dc_128_predictor_4x4_c
73
74 void vp9_d207_predictor_8x8_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
75 #define vp9_d207_predictor_8x8 vp9_d207_predictor_8x8_c
76
77 void vp9_d45_predictor_8x8_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
78 #define vp9_d45_predictor_8x8 vp9_d45_predictor_8x8_c
79
80 void vp9_d63_predictor_8x8_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
81 #define vp9_d63_predictor_8x8 vp9_d63_predictor_8x8_c
82
83 void vp9_h_predictor_8x8_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
84 void vp9_h_predictor_8x8_neon(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
85 #define vp9_h_predictor_8x8 vp9_h_predictor_8x8_neon
86
87 void vp9_d117_predictor_8x8_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
88 #define vp9_d117_predictor_8x8 vp9_d117_predictor_8x8_c
89
90 void vp9_d135_predictor_8x8_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
91 #define vp9_d135_predictor_8x8 vp9_d135_predictor_8x8_c
92
93 void vp9_d153_predictor_8x8_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
94 #define vp9_d153_predictor_8x8 vp9_d153_predictor_8x8_c
95
96 void vp9_v_predictor_8x8_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
97 void vp9_v_predictor_8x8_neon(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
98 #define vp9_v_predictor_8x8 vp9_v_predictor_8x8_neon
99
100 void vp9_tm_predictor_8x8_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
101 void vp9_tm_predictor_8x8_neon(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
102 #define vp9_tm_predictor_8x8 vp9_tm_predictor_8x8_neon
103
104 void vp9_dc_predictor_8x8_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
105 #define vp9_dc_predictor_8x8 vp9_dc_predictor_8x8_c
106
107 void vp9_dc_top_predictor_8x8_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
108 #define vp9_dc_top_predictor_8x8 vp9_dc_top_predictor_8x8_c
109
110 void vp9_dc_left_predictor_8x8_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
111 #define vp9_dc_left_predictor_8x8 vp9_dc_left_predictor_8x8_c
112
113 void vp9_dc_128_predictor_8x8_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
114 #define vp9_dc_128_predictor_8x8 vp9_dc_128_predictor_8x8_c
115
116 void vp9_d207_predictor_16x16_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
117 #define vp9_d207_predictor_16x16 vp9_d207_predictor_16x16_c
118
119 void vp9_d45_predictor_16x16_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
120 #define vp9_d45_predictor_16x16 vp9_d45_predictor_16x16_c
121
122 void vp9_d63_predictor_16x16_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
123 #define vp9_d63_predictor_16x16 vp9_d63_predictor_16x16_c
124
125 void vp9_h_predictor_16x16_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
126 void vp9_h_predictor_16x16_neon(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
127 #define vp9_h_predictor_16x16 vp9_h_predictor_16x16_neon
128
129 void vp9_d117_predictor_16x16_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
130 #define vp9_d117_predictor_16x16 vp9_d117_predictor_16x16_c
131
132 void vp9_d135_predictor_16x16_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
133 #define vp9_d135_predictor_16x16 vp9_d135_predictor_16x16_c
134
135 void vp9_d153_predictor_16x16_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
136 #define vp9_d153_predictor_16x16 vp9_d153_predictor_16x16_c
137
138 void vp9_v_predictor_16x16_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
139 void vp9_v_predictor_16x16_neon(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
140 #define vp9_v_predictor_16x16 vp9_v_predictor_16x16_neon
141
142 void vp9_tm_predictor_16x16_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
143 void vp9_tm_predictor_16x16_neon(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
144 #define vp9_tm_predictor_16x16 vp9_tm_predictor_16x16_neon
145
146 void vp9_dc_predictor_16x16_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
147 #define vp9_dc_predictor_16x16 vp9_dc_predictor_16x16_c
148
149 void vp9_dc_top_predictor_16x16_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
150 #define vp9_dc_top_predictor_16x16 vp9_dc_top_predictor_16x16_c
151
152 void vp9_dc_left_predictor_16x16_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
153 #define vp9_dc_left_predictor_16x16 vp9_dc_left_predictor_16x16_c
154
155 void vp9_dc_128_predictor_16x16_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
156 #define vp9_dc_128_predictor_16x16 vp9_dc_128_predictor_16x16_c
157
158 void vp9_d207_predictor_32x32_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
159 #define vp9_d207_predictor_32x32 vp9_d207_predictor_32x32_c
160
161 void vp9_d45_predictor_32x32_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
162 #define vp9_d45_predictor_32x32 vp9_d45_predictor_32x32_c
163
164 void vp9_d63_predictor_32x32_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
165 #define vp9_d63_predictor_32x32 vp9_d63_predictor_32x32_c
166
167 void vp9_h_predictor_32x32_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
168 void vp9_h_predictor_32x32_neon(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
169 #define vp9_h_predictor_32x32 vp9_h_predictor_32x32_neon
170
171 void vp9_d117_predictor_32x32_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
172 #define vp9_d117_predictor_32x32 vp9_d117_predictor_32x32_c
173
174 void vp9_d135_predictor_32x32_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
175 #define vp9_d135_predictor_32x32 vp9_d135_predictor_32x32_c
176
177 void vp9_d153_predictor_32x32_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
178 #define vp9_d153_predictor_32x32 vp9_d153_predictor_32x32_c
179
180 void vp9_v_predictor_32x32_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
181 void vp9_v_predictor_32x32_neon(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
182 #define vp9_v_predictor_32x32 vp9_v_predictor_32x32_neon
183
184 void vp9_tm_predictor_32x32_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
185 void vp9_tm_predictor_32x32_neon(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
186 #define vp9_tm_predictor_32x32 vp9_tm_predictor_32x32_neon
187
188 void vp9_dc_predictor_32x32_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
189 #define vp9_dc_predictor_32x32 vp9_dc_predictor_32x32_c
190
191 void vp9_dc_top_predictor_32x32_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
192 #define vp9_dc_top_predictor_32x32 vp9_dc_top_predictor_32x32_c
193
194 void vp9_dc_left_predictor_32x32_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
195 #define vp9_dc_left_predictor_32x32 vp9_dc_left_predictor_32x32_c
196
197 void vp9_dc_128_predictor_32x32_c(uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left);
198 #define vp9_dc_128_predictor_32x32 vp9_dc_128_predictor_32x32_c
199
200 void vp9_lpf_vertical_16_c(uint8_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh);
201 void vp9_lpf_vertical_16_neon(uint8_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh);
202 #define vp9_lpf_vertical_16 vp9_lpf_vertical_16_neon
203
204 void vp9_lpf_vertical_16_dual_c(uint8_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh);
205 void vp9_lpf_vertical_16_dual_neon(uint8_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh);
206 #define vp9_lpf_vertical_16_dual vp9_lpf_vertical_16_dual_neon
207
208 void vp9_lpf_vertical_8_c(uint8_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh, int count);
209 void vp9_lpf_vertical_8_neon(uint8_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh, int count);
210 #define vp9_lpf_vertical_8 vp9_lpf_vertical_8_neon
211
212 void vp9_lpf_vertical_8_dual_c(uint8_t *s, int pitch, const uint8_t *blimit0, const uint8_t *limit0, const uint8_t *thresh0, const uint8_t *blimit1, const uint8_t *limit1, const uint8_t *thresh1);
213 void vp9_lpf_vertical_8_dual_neon(uint8_t *s, int pitch, const uint8_t *blimit0, const uint8_t *limit0, const uint8_t *thresh0, const uint8_t *blimit1, const uint8_t *limit1, const uint8_t *thresh1);
214 #define vp9_lpf_vertical_8_dual vp9_lpf_vertical_8_dual_neon
215
216 void vp9_lpf_vertical_4_c(uint8_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh, int count);
217 void vp9_lpf_vertical_4_neon(uint8_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh, int count);
218 #define vp9_lpf_vertical_4 vp9_lpf_vertical_4_neon
219
220 void vp9_lpf_vertical_4_dual_c(uint8_t *s, int pitch, const uint8_t *blimit0, const uint8_t *limit0, const uint8_t *thresh0, const uint8_t *blimit1, const uint8_t *limit1, const uint8_t *thresh1);
221 void vp9_lpf_vertical_4_dual_neon(uint8_t *s, int pitch, const uint8_t *blimit0, const uint8_t *limit0, const uint8_t *thresh0, const uint8_t *blimit1, const uint8_t *limit1, const uint8_t *thresh1);
222 #define vp9_lpf_vertical_4_dual vp9_lpf_vertical_4_dual_neon
223
224 void vp9_lpf_horizontal_16_c(uint8_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh, int count);
225 void vp9_lpf_horizontal_16_neon(uint8_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh, int count);
226 #define vp9_lpf_horizontal_16 vp9_lpf_horizontal_16_neon
227
228 void vp9_lpf_horizontal_8_c(uint8_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh, int count);
229 void vp9_lpf_horizontal_8_neon(uint8_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh, int count);
230 #define vp9_lpf_horizontal_8 vp9_lpf_horizontal_8_neon
231
232 void vp9_lpf_horizontal_8_dual_c(uint8_t *s, int pitch, const uint8_t *blimit0, const uint8_t *limit0, const uint8_t *thresh0, const uint8_t *blimit1, const uint8_t *limit1, const uint8_t *thresh1);
233 void vp9_lpf_horizontal_8_dual_neon(uint8_t *s, int pitch, const uint8_t *blimit0, const uint8_t *limit0, const uint8_t *thresh0, const uint8_t *blimit1, const uint8_t *limit1, const uint8_t *thresh1);
234 #define vp9_lpf_horizontal_8_dual vp9_lpf_horizontal_8_dual_neon
235
236 void vp9_lpf_horizontal_4_c(uint8_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh, int count);
237 void vp9_lpf_horizontal_4_neon(uint8_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh, int count);
238 #define vp9_lpf_horizontal_4 vp9_lpf_horizontal_4_neon
239
240 void vp9_lpf_horizontal_4_dual_c(uint8_t *s, int pitch, const uint8_t *blimit0, const uint8_t *limit0, const uint8_t *thresh0, const uint8_t *blimit1, const uint8_t *limit1, const uint8_t *thresh1);
241 void vp9_lpf_horizontal_4_dual_neon(uint8_t *s, int pitch, const uint8_t *blimit0, const uint8_t *limit0, const uint8_t *thresh0, const uint8_t *blimit1, const uint8_t *limit1, const uint8_t *thresh1);
242 #define vp9_lpf_horizontal_4_dual vp9_lpf_horizontal_4_dual_neon
243
244 void vp9_blend_mb_inner_c(uint8_t *y, uint8_t *u, uint8_t *v, int y1, int u1, int v1, int alpha, int stride);
245 #define vp9_blend_mb_inner vp9_blend_mb_inner_c
246
247 void vp9_blend_mb_outer_c(uint8_t *y, uint8_t *u, uint8_t *v, int y1, int u1, int v1, int alpha, int stride);
248 #define vp9_blend_mb_outer vp9_blend_mb_outer_c
249
250 void vp9_blend_b_c(uint8_t *y, uint8_t *u, uint8_t *v, int y1, int u1, int v1, int alpha, int stride);
251 #define vp9_blend_b vp9_blend_b_c
252
253 void vp9_convolve_copy_c(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const int16_t *filter_x, int x_step_q4, const int16_t *filter_y, int y_step_q4, int w, int h);
254 void vp9_convolve_copy_neon(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const int16_t *filter_x, int x_step_q4, const int16_t *filter_y, int y_step_q4, int w, int h);
255 #define vp9_convolve_copy vp9_convolve_copy_neon
256
257 void vp9_convolve_avg_c(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const int16_t *filter_x, int x_step_q4, const int16_t *filter_y, int y_step_q4, int w, int h);
258 void vp9_convolve_avg_neon(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const int16_t *filter_x, int x_step_q4, const int16_t *filter_y, int y_step_q4, int w, int h);
259 #define vp9_convolve_avg vp9_convolve_avg_neon
260
261 void vp9_convolve8_c(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const int16_t *filter_x, int x_step_q4, const int16_t *filter_y, int y_step_q4, int w, int h);
262 void vp9_convolve8_neon(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const int16_t *filter_x, int x_step_q4, const int16_t *filter_y, int y_step_q4, int w, int h);
263 #define vp9_convolve8 vp9_convolve8_neon
264
265 void vp9_convolve8_horiz_c(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const int16_t *filter_x, int x_step_q4, const int16_t *filter_y, int y_step_q4, int w, int h);
266 void vp9_convolve8_horiz_neon(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const int16_t *filter_x, int x_step_q4, const int16_t *filter_y, int y_step_q4, int w, int h);
267 #define vp9_convolve8_horiz vp9_convolve8_horiz_neon
268
269 void vp9_convolve8_vert_c(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const int16_t *filter_x, int x_step_q4, const int16_t *filter_y, int y_step_q4, int w, int h);
270 void vp9_convolve8_vert_neon(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const int16_t *filter_x, int x_step_q4, const int16_t *filter_y, int y_step_q4, int w, int h);
271 #define vp9_convolve8_vert vp9_convolve8_vert_neon
272
273 void vp9_convolve8_avg_c(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const int16_t *filter_x, int x_step_q4, const int16_t *filter_y, int y_step_q4, int w, int h);
274 void vp9_convolve8_avg_neon(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const int16_t *filter_x, int x_step_q4, const int16_t *filter_y, int y_step_q4, int w, int h);
275 #define vp9_convolve8_avg vp9_convolve8_avg_neon
276
277 void vp9_convolve8_avg_horiz_c(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const int16_t *filter_x, int x_step_q4, const int16_t *filter_y, int y_step_q4, int w, int h);
278 void vp9_convolve8_avg_horiz_neon(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const int16_t *filter_x, int x_step_q4, const int16_t *filter_y, int y_step_q4, int w, int h);
279 #define vp9_convolve8_avg_horiz vp9_convolve8_avg_horiz_neon
280
281 void vp9_convolve8_avg_vert_c(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const int16_t *filter_x, int x_step_q4, const int16_t *filter_y, int y_step_q4, int w, int h);
282 void vp9_convolve8_avg_vert_neon(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const int16_t *filter_x, int x_step_q4, const int16_t *filter_y, int y_step_q4, int w, int h);
283 #define vp9_convolve8_avg_vert vp9_convolve8_avg_vert_neon
284
285 void vp9_idct4x4_1_add_c(const int16_t *input, uint8_t *dest, int dest_stride);
286 void vp9_idct4x4_1_add_neon(const int16_t *input, uint8_t *dest, int dest_stride);
287 #define vp9_idct4x4_1_add vp9_idct4x4_1_add_neon
288
289 void vp9_idct4x4_16_add_c(const int16_t *input, uint8_t *dest, int dest_stride);
290 void vp9_idct4x4_16_add_neon(const int16_t *input, uint8_t *dest, int dest_stride);
291 #define vp9_idct4x4_16_add vp9_idct4x4_16_add_neon
292
293 void vp9_idct8x8_1_add_c(const int16_t *input, uint8_t *dest, int dest_stride);
294 void vp9_idct8x8_1_add_neon(const int16_t *input, uint8_t *dest, int dest_stride);
295 #define vp9_idct8x8_1_add vp9_idct8x8_1_add_neon
296
297 void vp9_idct8x8_64_add_c(const int16_t *input, uint8_t *dest, int dest_stride);
298 void vp9_idct8x8_64_add_neon(const int16_t *input, uint8_t *dest, int dest_stride);
299 #define vp9_idct8x8_64_add vp9_idct8x8_64_add_neon
300
301 void vp9_idct8x8_10_add_c(const int16_t *input, uint8_t *dest, int dest_stride);
302 void vp9_idct8x8_10_add_neon(const int16_t *input, uint8_t *dest, int dest_stride);
303 #define vp9_idct8x8_10_add vp9_idct8x8_10_add_neon
304
305 void vp9_idct16x16_1_add_c(const int16_t *input, uint8_t *dest, int dest_stride);
306 void vp9_idct16x16_1_add_neon(const int16_t *input, uint8_t *dest, int dest_stride);
307 #define vp9_idct16x16_1_add vp9_idct16x16_1_add_neon
308
309 void vp9_idct16x16_256_add_c(const int16_t *input, uint8_t *dest, int dest_stride);
310 void vp9_idct16x16_256_add_neon(const int16_t *input, uint8_t *dest, int dest_stride);
311 #define vp9_idct16x16_256_add vp9_idct16x16_256_add_neon
312
313 void vp9_idct16x16_10_add_c(const int16_t *input, uint8_t *dest, int dest_stride);
314 void vp9_idct16x16_10_add_neon(const int16_t *input, uint8_t *dest, int dest_stride);
315 #define vp9_idct16x16_10_add vp9_idct16x16_10_add_neon
316
317 void vp9_idct32x32_1024_add_c(const int16_t *input, uint8_t *dest, int dest_stride);
318 void vp9_idct32x32_1024_add_neon(const int16_t *input, uint8_t *dest, int dest_stride);
319 #define vp9_idct32x32_1024_add vp9_idct32x32_1024_add_neon
320
321 void vp9_idct32x32_34_add_c(const int16_t *input, uint8_t *dest, int dest_stride);
322 void vp9_idct32x32_1024_add_neon(const int16_t *input, uint8_t *dest, int dest_stride);
323 #define vp9_idct32x32_34_add vp9_idct32x32_1024_add_neon
324
325 void vp9_idct32x32_1_add_c(const int16_t *input, uint8_t *dest, int dest_stride);
326 void vp9_idct32x32_1_add_neon(const int16_t *input, uint8_t *dest, int dest_stride);
327 #define vp9_idct32x32_1_add vp9_idct32x32_1_add_neon
328
329 void vp9_iht4x4_16_add_c(const int16_t *input, uint8_t *dest, int dest_stride, int tx_type);
330 void vp9_iht4x4_16_add_neon(const int16_t *input, uint8_t *dest, int dest_stride, int tx_type);
331 #define vp9_iht4x4_16_add vp9_iht4x4_16_add_neon
332
333 void vp9_iht8x8_64_add_c(const int16_t *input, uint8_t *dest, int dest_stride, int tx_type);
334 void vp9_iht8x8_64_add_neon(const int16_t *input, uint8_t *dest, int dest_stride, int tx_type);
335 #define vp9_iht8x8_64_add vp9_iht8x8_64_add_neon
336
337 void vp9_iht16x16_256_add_c(const int16_t *input, uint8_t *output, int pitch, int tx_type);
338 #define vp9_iht16x16_256_add vp9_iht16x16_256_add_c
339
340 void vp9_iwht4x4_1_add_c(const int16_t *input, uint8_t *dest, int dest_stride);
341 #define vp9_iwht4x4_1_add vp9_iwht4x4_1_add_c
342
343 void vp9_iwht4x4_16_add_c(const int16_t *input, uint8_t *dest, int dest_stride);
344 #define vp9_iwht4x4_16_add vp9_iwht4x4_16_add_c
345
346 void vp9_rtcd(void);
347 #include "vpx_config.h"
348
349 #ifdef RTCD_C
350 #include "vpx_ports/arm.h"
351 static void setup_rtcd_internal(void)
352 {
353     int flags = arm_cpu_caps();
354
355     (void)flags;
356
357
358 }
359 #endif
360
361 #ifdef __cplusplus
362 }  // extern "C"
363 #endif
364
365 #endif