]> granicus.if.org Git - libvpx/blob - vpx_dsp/vpx_dsp_rtcd_defs.pl
Clean add_protos of highbd idct functions
[libvpx] / vpx_dsp / vpx_dsp_rtcd_defs.pl
1 sub vpx_dsp_forward_decls() {
2 print <<EOF
3 /*
4  * DSP
5  */
6
7 #include "vpx/vpx_integer.h"
8 #include "vpx_dsp/vpx_dsp_common.h"
9
10 EOF
11 }
12 forward_decls qw/vpx_dsp_forward_decls/;
13
14 # functions that are 64 bit only.
15 $mmx_x86_64 = $sse2_x86_64 = $ssse3_x86_64 = $avx_x86_64 = $avx2_x86_64 = '';
16 if ($opts{arch} eq "x86_64") {
17   $mmx_x86_64 = 'mmx';
18   $sse2_x86_64 = 'sse2';
19   $ssse3_x86_64 = 'ssse3';
20   $avx_x86_64 = 'avx';
21   $avx2_x86_64 = 'avx2';
22 }
23
24 #
25 # Intra prediction
26 #
27
28 add_proto qw/void vpx_d207_predictor_4x4/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
29 specialize qw/vpx_d207_predictor_4x4 sse2/;
30
31 add_proto qw/void vpx_d45_predictor_4x4/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
32 specialize qw/vpx_d45_predictor_4x4 neon sse2/;
33
34 add_proto qw/void vpx_d45e_predictor_4x4/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
35
36 add_proto qw/void vpx_d63_predictor_4x4/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
37 specialize qw/vpx_d63_predictor_4x4 ssse3/;
38
39 add_proto qw/void vpx_d63e_predictor_4x4/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
40
41 add_proto qw/void vpx_h_predictor_4x4/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
42 specialize qw/vpx_h_predictor_4x4 neon dspr2 msa sse2 vsx/;
43
44 add_proto qw/void vpx_he_predictor_4x4/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
45
46 add_proto qw/void vpx_d117_predictor_4x4/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
47
48 add_proto qw/void vpx_d135_predictor_4x4/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
49 specialize qw/vpx_d135_predictor_4x4 neon/;
50
51 add_proto qw/void vpx_d153_predictor_4x4/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
52 specialize qw/vpx_d153_predictor_4x4 ssse3/;
53
54 add_proto qw/void vpx_v_predictor_4x4/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
55 specialize qw/vpx_v_predictor_4x4 neon msa sse2/;
56
57 add_proto qw/void vpx_ve_predictor_4x4/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
58
59 add_proto qw/void vpx_tm_predictor_4x4/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
60 specialize qw/vpx_tm_predictor_4x4 neon dspr2 msa sse2 vsx/;
61
62 add_proto qw/void vpx_dc_predictor_4x4/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
63 specialize qw/vpx_dc_predictor_4x4 dspr2 msa neon sse2/;
64
65 add_proto qw/void vpx_dc_top_predictor_4x4/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
66 specialize qw/vpx_dc_top_predictor_4x4 msa neon sse2/;
67
68 add_proto qw/void vpx_dc_left_predictor_4x4/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
69 specialize qw/vpx_dc_left_predictor_4x4 msa neon sse2/;
70
71 add_proto qw/void vpx_dc_128_predictor_4x4/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
72 specialize qw/vpx_dc_128_predictor_4x4 msa neon sse2/;
73
74 add_proto qw/void vpx_d207_predictor_8x8/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
75 specialize qw/vpx_d207_predictor_8x8 ssse3/;
76
77 add_proto qw/void vpx_d45_predictor_8x8/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
78 specialize qw/vpx_d45_predictor_8x8 neon sse2 vsx/;
79
80 add_proto qw/void vpx_d63_predictor_8x8/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
81 specialize qw/vpx_d63_predictor_8x8 ssse3 vsx/;
82
83 add_proto qw/void vpx_h_predictor_8x8/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
84 specialize qw/vpx_h_predictor_8x8 neon dspr2 msa sse2 vsx/;
85
86 add_proto qw/void vpx_d117_predictor_8x8/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
87
88 add_proto qw/void vpx_d135_predictor_8x8/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
89 specialize qw/vpx_d135_predictor_8x8 neon/;
90
91 add_proto qw/void vpx_d153_predictor_8x8/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
92 specialize qw/vpx_d153_predictor_8x8 ssse3/;
93
94 add_proto qw/void vpx_v_predictor_8x8/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
95 specialize qw/vpx_v_predictor_8x8 neon msa sse2/;
96
97 add_proto qw/void vpx_tm_predictor_8x8/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
98 specialize qw/vpx_tm_predictor_8x8 neon dspr2 msa sse2 vsx/;
99
100 add_proto qw/void vpx_dc_predictor_8x8/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
101 specialize qw/vpx_dc_predictor_8x8 dspr2 neon msa sse2 vsx/;
102
103 add_proto qw/void vpx_dc_top_predictor_8x8/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
104 specialize qw/vpx_dc_top_predictor_8x8 neon msa sse2/;
105
106 add_proto qw/void vpx_dc_left_predictor_8x8/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
107 specialize qw/vpx_dc_left_predictor_8x8 neon msa sse2/;
108
109 add_proto qw/void vpx_dc_128_predictor_8x8/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
110 specialize qw/vpx_dc_128_predictor_8x8 neon msa sse2/;
111
112 add_proto qw/void vpx_d207_predictor_16x16/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
113 specialize qw/vpx_d207_predictor_16x16 ssse3/;
114
115 add_proto qw/void vpx_d45_predictor_16x16/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
116 specialize qw/vpx_d45_predictor_16x16 neon ssse3 vsx/;
117
118 add_proto qw/void vpx_d63_predictor_16x16/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
119 specialize qw/vpx_d63_predictor_16x16 ssse3 vsx/;
120
121 add_proto qw/void vpx_h_predictor_16x16/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
122 specialize qw/vpx_h_predictor_16x16 neon dspr2 msa sse2 vsx/;
123
124 add_proto qw/void vpx_d117_predictor_16x16/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
125
126 add_proto qw/void vpx_d135_predictor_16x16/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
127 specialize qw/vpx_d135_predictor_16x16 neon/;
128
129 add_proto qw/void vpx_d153_predictor_16x16/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
130 specialize qw/vpx_d153_predictor_16x16 ssse3/;
131
132 add_proto qw/void vpx_v_predictor_16x16/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
133 specialize qw/vpx_v_predictor_16x16 neon msa sse2 vsx/;
134
135 add_proto qw/void vpx_tm_predictor_16x16/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
136 specialize qw/vpx_tm_predictor_16x16 neon msa sse2 vsx/;
137
138 add_proto qw/void vpx_dc_predictor_16x16/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
139 specialize qw/vpx_dc_predictor_16x16 dspr2 neon msa sse2 vsx/;
140
141 add_proto qw/void vpx_dc_top_predictor_16x16/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
142 specialize qw/vpx_dc_top_predictor_16x16 neon msa sse2 vsx/;
143
144 add_proto qw/void vpx_dc_left_predictor_16x16/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
145 specialize qw/vpx_dc_left_predictor_16x16 neon msa sse2 vsx/;
146
147 add_proto qw/void vpx_dc_128_predictor_16x16/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
148 specialize qw/vpx_dc_128_predictor_16x16 neon msa sse2 vsx/;
149
150 add_proto qw/void vpx_d207_predictor_32x32/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
151 specialize qw/vpx_d207_predictor_32x32 ssse3/;
152
153 add_proto qw/void vpx_d45_predictor_32x32/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
154 specialize qw/vpx_d45_predictor_32x32 neon ssse3 vsx/;
155
156 add_proto qw/void vpx_d63_predictor_32x32/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
157 specialize qw/vpx_d63_predictor_32x32 ssse3 vsx/;
158
159 add_proto qw/void vpx_h_predictor_32x32/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
160 specialize qw/vpx_h_predictor_32x32 neon msa sse2 vsx/;
161
162 add_proto qw/void vpx_d117_predictor_32x32/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
163
164 add_proto qw/void vpx_d135_predictor_32x32/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
165 specialize qw/vpx_d135_predictor_32x32 neon/;
166
167 add_proto qw/void vpx_d153_predictor_32x32/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
168 specialize qw/vpx_d153_predictor_32x32 ssse3/;
169
170 add_proto qw/void vpx_v_predictor_32x32/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
171 specialize qw/vpx_v_predictor_32x32 neon msa sse2 vsx/;
172
173 add_proto qw/void vpx_tm_predictor_32x32/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
174 specialize qw/vpx_tm_predictor_32x32 neon msa sse2 vsx/;
175
176 add_proto qw/void vpx_dc_predictor_32x32/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
177 specialize qw/vpx_dc_predictor_32x32 msa neon sse2 vsx/;
178
179 add_proto qw/void vpx_dc_top_predictor_32x32/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
180 specialize qw/vpx_dc_top_predictor_32x32 msa neon sse2 vsx/;
181
182 add_proto qw/void vpx_dc_left_predictor_32x32/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
183 specialize qw/vpx_dc_left_predictor_32x32 msa neon sse2 vsx/;
184
185 add_proto qw/void vpx_dc_128_predictor_32x32/, "uint8_t *dst, ptrdiff_t y_stride, const uint8_t *above, const uint8_t *left";
186 specialize qw/vpx_dc_128_predictor_32x32 msa neon sse2 vsx/;
187
188 # High bitdepth functions
189 if (vpx_config("CONFIG_VP9_HIGHBITDEPTH") eq "yes") {
190   add_proto qw/void vpx_highbd_d207_predictor_4x4/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
191
192   add_proto qw/void vpx_highbd_d45_predictor_4x4/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
193   specialize qw/vpx_highbd_d45_predictor_4x4 neon/;
194
195   add_proto qw/void vpx_highbd_d63_predictor_4x4/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
196
197   add_proto qw/void vpx_highbd_h_predictor_4x4/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
198   specialize qw/vpx_highbd_h_predictor_4x4 neon/;
199
200   add_proto qw/void vpx_highbd_d117_predictor_4x4/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
201
202   add_proto qw/void vpx_highbd_d135_predictor_4x4/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
203   specialize qw/vpx_highbd_d135_predictor_4x4 neon/;
204
205   add_proto qw/void vpx_highbd_d153_predictor_4x4/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
206
207   add_proto qw/void vpx_highbd_v_predictor_4x4/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
208   specialize qw/vpx_highbd_v_predictor_4x4 neon sse2/;
209
210   add_proto qw/void vpx_highbd_tm_predictor_4x4/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
211   specialize qw/vpx_highbd_tm_predictor_4x4 neon sse2/;
212
213   add_proto qw/void vpx_highbd_dc_predictor_4x4/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
214   specialize qw/vpx_highbd_dc_predictor_4x4 neon sse2/;
215
216   add_proto qw/void vpx_highbd_dc_top_predictor_4x4/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
217   specialize qw/vpx_highbd_dc_top_predictor_4x4 neon/;
218
219   add_proto qw/void vpx_highbd_dc_left_predictor_4x4/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
220   specialize qw/vpx_highbd_dc_left_predictor_4x4 neon/;
221
222   add_proto qw/void vpx_highbd_dc_128_predictor_4x4/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
223   specialize qw/vpx_highbd_dc_128_predictor_4x4 neon/;
224
225   add_proto qw/void vpx_highbd_d207_predictor_8x8/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
226
227   add_proto qw/void vpx_highbd_d45_predictor_8x8/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
228   specialize qw/vpx_highbd_d45_predictor_8x8 neon/;
229
230   add_proto qw/void vpx_highbd_d63_predictor_8x8/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
231
232   add_proto qw/void vpx_highbd_h_predictor_8x8/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
233   specialize qw/vpx_highbd_h_predictor_8x8 neon/;
234
235   add_proto qw/void vpx_highbd_d117_predictor_8x8/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
236
237   add_proto qw/void vpx_highbd_d135_predictor_8x8/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
238   specialize qw/vpx_highbd_d135_predictor_8x8 neon/;
239
240   add_proto qw/void vpx_highbd_d153_predictor_8x8/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
241
242   add_proto qw/void vpx_highbd_v_predictor_8x8/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
243   specialize qw/vpx_highbd_v_predictor_8x8 neon sse2/;
244
245   add_proto qw/void vpx_highbd_tm_predictor_8x8/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
246   specialize qw/vpx_highbd_tm_predictor_8x8 neon sse2/;
247
248   add_proto qw/void vpx_highbd_dc_predictor_8x8/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
249   specialize qw/vpx_highbd_dc_predictor_8x8 neon sse2/;
250
251   add_proto qw/void vpx_highbd_dc_top_predictor_8x8/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
252   specialize qw/vpx_highbd_dc_top_predictor_8x8 neon/;
253
254   add_proto qw/void vpx_highbd_dc_left_predictor_8x8/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
255   specialize qw/vpx_highbd_dc_left_predictor_8x8 neon/;
256
257   add_proto qw/void vpx_highbd_dc_128_predictor_8x8/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
258   specialize qw/vpx_highbd_dc_128_predictor_8x8 neon/;
259
260   add_proto qw/void vpx_highbd_d207_predictor_16x16/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
261
262   add_proto qw/void vpx_highbd_d45_predictor_16x16/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
263   specialize qw/vpx_highbd_d45_predictor_16x16 neon/;
264
265   add_proto qw/void vpx_highbd_d63_predictor_16x16/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
266
267   add_proto qw/void vpx_highbd_h_predictor_16x16/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
268   specialize qw/vpx_highbd_h_predictor_16x16 neon/;
269
270   add_proto qw/void vpx_highbd_d117_predictor_16x16/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
271
272   add_proto qw/void vpx_highbd_d135_predictor_16x16/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
273   specialize qw/vpx_highbd_d135_predictor_16x16 neon/;
274
275   add_proto qw/void vpx_highbd_d153_predictor_16x16/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
276
277   add_proto qw/void vpx_highbd_v_predictor_16x16/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
278   specialize qw/vpx_highbd_v_predictor_16x16 neon sse2/;
279
280   add_proto qw/void vpx_highbd_tm_predictor_16x16/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
281   specialize qw/vpx_highbd_tm_predictor_16x16 neon sse2/;
282
283   add_proto qw/void vpx_highbd_dc_predictor_16x16/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
284   specialize qw/vpx_highbd_dc_predictor_16x16 neon sse2/;
285
286   add_proto qw/void vpx_highbd_dc_top_predictor_16x16/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
287   specialize qw/vpx_highbd_dc_top_predictor_16x16 neon/;
288
289   add_proto qw/void vpx_highbd_dc_left_predictor_16x16/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
290   specialize qw/vpx_highbd_dc_left_predictor_16x16 neon/;
291
292   add_proto qw/void vpx_highbd_dc_128_predictor_16x16/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
293   specialize qw/vpx_highbd_dc_128_predictor_16x16 neon/;
294
295   add_proto qw/void vpx_highbd_d207_predictor_32x32/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
296
297   add_proto qw/void vpx_highbd_d45_predictor_32x32/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
298   specialize qw/vpx_highbd_d45_predictor_32x32 neon/;
299
300   add_proto qw/void vpx_highbd_d63_predictor_32x32/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
301
302   add_proto qw/void vpx_highbd_h_predictor_32x32/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
303   specialize qw/vpx_highbd_h_predictor_32x32 neon/;
304
305   add_proto qw/void vpx_highbd_d117_predictor_32x32/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
306
307   add_proto qw/void vpx_highbd_d135_predictor_32x32/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
308   specialize qw/vpx_highbd_d135_predictor_32x32 neon/;
309
310   add_proto qw/void vpx_highbd_d153_predictor_32x32/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
311
312   add_proto qw/void vpx_highbd_v_predictor_32x32/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
313   specialize qw/vpx_highbd_v_predictor_32x32 neon sse2/;
314
315   add_proto qw/void vpx_highbd_tm_predictor_32x32/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
316   specialize qw/vpx_highbd_tm_predictor_32x32 neon sse2/;
317
318   add_proto qw/void vpx_highbd_dc_predictor_32x32/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
319   specialize qw/vpx_highbd_dc_predictor_32x32 neon sse2/;
320
321   add_proto qw/void vpx_highbd_dc_top_predictor_32x32/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
322   specialize qw/vpx_highbd_dc_top_predictor_32x32 neon/;
323
324   add_proto qw/void vpx_highbd_dc_left_predictor_32x32/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
325   specialize qw/vpx_highbd_dc_left_predictor_32x32 neon/;
326
327   add_proto qw/void vpx_highbd_dc_128_predictor_32x32/, "uint16_t *dst, ptrdiff_t y_stride, const uint16_t *above, const uint16_t *left, int bd";
328   specialize qw/vpx_highbd_dc_128_predictor_32x32 neon/;
329 }  # CONFIG_VP9_HIGHBITDEPTH
330
331 #
332 # Sub Pixel Filters
333 #
334 add_proto qw/void vpx_convolve_copy/, "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";
335 specialize qw/vpx_convolve_copy neon dspr2 msa sse2 vsx/;
336
337 add_proto qw/void vpx_convolve_avg/, "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";
338 specialize qw/vpx_convolve_avg neon dspr2 msa sse2 vsx/;
339
340 add_proto qw/void vpx_convolve8/, "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";
341 specialize qw/vpx_convolve8 sse2 ssse3 avx2 neon dspr2 msa/;
342
343 add_proto qw/void vpx_convolve8_horiz/, "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";
344 specialize qw/vpx_convolve8_horiz sse2 ssse3 avx2 neon dspr2 msa/;
345
346 add_proto qw/void vpx_convolve8_vert/, "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";
347 specialize qw/vpx_convolve8_vert sse2 ssse3 avx2 neon dspr2 msa/;
348
349 add_proto qw/void vpx_convolve8_avg/, "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";
350 specialize qw/vpx_convolve8_avg sse2 ssse3 neon dspr2 msa/;
351
352 add_proto qw/void vpx_convolve8_avg_horiz/, "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";
353 specialize qw/vpx_convolve8_avg_horiz sse2 ssse3 neon dspr2 msa/;
354
355 add_proto qw/void vpx_convolve8_avg_vert/, "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";
356 specialize qw/vpx_convolve8_avg_vert sse2 ssse3 neon dspr2 msa/;
357
358 add_proto qw/void vpx_scaled_2d/, "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";
359 specialize qw/vpx_scaled_2d ssse3/;
360
361 add_proto qw/void vpx_scaled_horiz/, "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";
362
363 add_proto qw/void vpx_scaled_vert/, "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";
364
365 add_proto qw/void vpx_scaled_avg_2d/, "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";
366
367 add_proto qw/void vpx_scaled_avg_horiz/, "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";
368
369 add_proto qw/void vpx_scaled_avg_vert/, "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";
370
371 if (vpx_config("CONFIG_VP9_HIGHBITDEPTH") eq "yes") {
372   #
373   # Sub Pixel Filters
374   #
375   add_proto qw/void vpx_highbd_convolve_copy/, "const uint16_t *src, ptrdiff_t src_stride, uint16_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, int bps";
376   specialize qw/vpx_highbd_convolve_copy sse2 avx2 neon/;
377
378   add_proto qw/void vpx_highbd_convolve_avg/, "const uint16_t *src, ptrdiff_t src_stride, uint16_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, int bps";
379   specialize qw/vpx_highbd_convolve_avg sse2 avx2 neon/;
380
381   add_proto qw/void vpx_highbd_convolve8/, "const uint16_t *src, ptrdiff_t src_stride, uint16_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, int bps";
382   specialize qw/vpx_highbd_convolve8 neon/, "$sse2_x86_64";
383
384   add_proto qw/void vpx_highbd_convolve8_horiz/, "const uint16_t *src, ptrdiff_t src_stride, uint16_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, int bps";
385   specialize qw/vpx_highbd_convolve8_horiz neon/, "$sse2_x86_64";
386
387   add_proto qw/void vpx_highbd_convolve8_vert/, "const uint16_t *src, ptrdiff_t src_stride, uint16_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, int bps";
388   specialize qw/vpx_highbd_convolve8_vert neon/, "$sse2_x86_64";
389
390   add_proto qw/void vpx_highbd_convolve8_avg/, "const uint16_t *src, ptrdiff_t src_stride, uint16_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, int bps";
391   specialize qw/vpx_highbd_convolve8_avg neon/, "$sse2_x86_64";
392
393   add_proto qw/void vpx_highbd_convolve8_avg_horiz/, "const uint16_t *src, ptrdiff_t src_stride, uint16_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, int bps";
394   specialize qw/vpx_highbd_convolve8_avg_horiz neon/, "$sse2_x86_64";
395
396   add_proto qw/void vpx_highbd_convolve8_avg_vert/, "const uint16_t *src, ptrdiff_t src_stride, uint16_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, int bps";
397   specialize qw/vpx_highbd_convolve8_avg_vert neon/, "$sse2_x86_64";
398 }  # CONFIG_VP9_HIGHBITDEPTH
399
400 #
401 # Loopfilter
402 #
403 add_proto qw/void vpx_lpf_vertical_16/, "uint8_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh";
404 specialize qw/vpx_lpf_vertical_16 sse2 neon dspr2 msa/;
405
406 add_proto qw/void vpx_lpf_vertical_16_dual/, "uint8_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh";
407 specialize qw/vpx_lpf_vertical_16_dual sse2 neon dspr2 msa/;
408
409 add_proto qw/void vpx_lpf_vertical_8/, "uint8_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh";
410 specialize qw/vpx_lpf_vertical_8 sse2 neon dspr2 msa/;
411
412 add_proto qw/void vpx_lpf_vertical_8_dual/, "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";
413 specialize qw/vpx_lpf_vertical_8_dual sse2 neon dspr2 msa/;
414
415 add_proto qw/void vpx_lpf_vertical_4/, "uint8_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh";
416 specialize qw/vpx_lpf_vertical_4 sse2 neon dspr2 msa/;
417
418 add_proto qw/void vpx_lpf_vertical_4_dual/, "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";
419 specialize qw/vpx_lpf_vertical_4_dual sse2 neon dspr2 msa/;
420
421 add_proto qw/void vpx_lpf_horizontal_16/, "uint8_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh";
422 specialize qw/vpx_lpf_horizontal_16 sse2 avx2 neon dspr2 msa/;
423
424 add_proto qw/void vpx_lpf_horizontal_16_dual/, "uint8_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh";
425 specialize qw/vpx_lpf_horizontal_16_dual sse2 avx2 neon dspr2 msa/;
426
427 add_proto qw/void vpx_lpf_horizontal_8/, "uint8_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh";
428 specialize qw/vpx_lpf_horizontal_8 sse2 neon dspr2 msa/;
429
430 add_proto qw/void vpx_lpf_horizontal_8_dual/, "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";
431 specialize qw/vpx_lpf_horizontal_8_dual sse2 neon dspr2 msa/;
432
433 add_proto qw/void vpx_lpf_horizontal_4/, "uint8_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh";
434 specialize qw/vpx_lpf_horizontal_4 sse2 neon dspr2 msa/;
435
436 add_proto qw/void vpx_lpf_horizontal_4_dual/, "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";
437 specialize qw/vpx_lpf_horizontal_4_dual sse2 neon dspr2 msa/;
438
439 if (vpx_config("CONFIG_VP9_HIGHBITDEPTH") eq "yes") {
440   add_proto qw/void vpx_highbd_lpf_vertical_16/, "uint16_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh, int bd";
441   specialize qw/vpx_highbd_lpf_vertical_16 sse2 neon/;
442
443   add_proto qw/void vpx_highbd_lpf_vertical_16_dual/, "uint16_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh, int bd";
444   specialize qw/vpx_highbd_lpf_vertical_16_dual sse2 neon/;
445
446   add_proto qw/void vpx_highbd_lpf_vertical_8/, "uint16_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh, int bd";
447   specialize qw/vpx_highbd_lpf_vertical_8 sse2 neon/;
448
449   add_proto qw/void vpx_highbd_lpf_vertical_8_dual/, "uint16_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, int bd";
450   specialize qw/vpx_highbd_lpf_vertical_8_dual sse2 neon/;
451
452   add_proto qw/void vpx_highbd_lpf_vertical_4/, "uint16_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh, int bd";
453   specialize qw/vpx_highbd_lpf_vertical_4 sse2 neon/;
454
455   add_proto qw/void vpx_highbd_lpf_vertical_4_dual/, "uint16_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, int bd";
456   specialize qw/vpx_highbd_lpf_vertical_4_dual sse2 neon/;
457
458   add_proto qw/void vpx_highbd_lpf_horizontal_16/, "uint16_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh, int bd";
459   specialize qw/vpx_highbd_lpf_horizontal_16 sse2 neon/;
460
461   add_proto qw/void vpx_highbd_lpf_horizontal_16_dual/, "uint16_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh, int bd";
462   specialize qw/vpx_highbd_lpf_horizontal_16_dual sse2 neon/;
463
464   add_proto qw/void vpx_highbd_lpf_horizontal_8/, "uint16_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh, int bd";
465   specialize qw/vpx_highbd_lpf_horizontal_8 sse2 neon/;
466
467   add_proto qw/void vpx_highbd_lpf_horizontal_8_dual/, "uint16_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, int bd";
468   specialize qw/vpx_highbd_lpf_horizontal_8_dual sse2 neon/;
469
470   add_proto qw/void vpx_highbd_lpf_horizontal_4/, "uint16_t *s, int pitch, const uint8_t *blimit, const uint8_t *limit, const uint8_t *thresh, int bd";
471   specialize qw/vpx_highbd_lpf_horizontal_4 sse2 neon/;
472
473   add_proto qw/void vpx_highbd_lpf_horizontal_4_dual/, "uint16_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, int bd";
474   specialize qw/vpx_highbd_lpf_horizontal_4_dual sse2 neon/;
475 }  # CONFIG_VP9_HIGHBITDEPTH
476
477 #
478 # Encoder functions.
479 #
480
481 #
482 # Forward transform
483 #
484 if (vpx_config("CONFIG_VP9_ENCODER") eq "yes") {
485 if (vpx_config("CONFIG_VP9_HIGHBITDEPTH") eq "yes") {
486   add_proto qw/void vpx_fdct4x4/, "const int16_t *input, tran_low_t *output, int stride";
487   specialize qw/vpx_fdct4x4 sse2/;
488
489   add_proto qw/void vpx_fdct4x4_1/, "const int16_t *input, tran_low_t *output, int stride";
490   specialize qw/vpx_fdct4x4_1 sse2/;
491
492   add_proto qw/void vpx_fdct8x8/, "const int16_t *input, tran_low_t *output, int stride";
493   specialize qw/vpx_fdct8x8 neon sse2/;
494
495   add_proto qw/void vpx_fdct8x8_1/, "const int16_t *input, tran_low_t *output, int stride";
496   specialize qw/vpx_fdct8x8_1 neon sse2/;
497
498   add_proto qw/void vpx_fdct16x16/, "const int16_t *input, tran_low_t *output, int stride";
499   specialize qw/vpx_fdct16x16 sse2/;
500
501   add_proto qw/void vpx_fdct16x16_1/, "const int16_t *input, tran_low_t *output, int stride";
502   specialize qw/vpx_fdct16x16_1 sse2/;
503
504   add_proto qw/void vpx_fdct32x32/, "const int16_t *input, tran_low_t *output, int stride";
505   specialize qw/vpx_fdct32x32 sse2/;
506
507   add_proto qw/void vpx_fdct32x32_rd/, "const int16_t *input, tran_low_t *output, int stride";
508   specialize qw/vpx_fdct32x32_rd sse2/;
509
510   add_proto qw/void vpx_fdct32x32_1/, "const int16_t *input, tran_low_t *output, int stride";
511   specialize qw/vpx_fdct32x32_1 sse2/;
512
513   add_proto qw/void vpx_highbd_fdct4x4/, "const int16_t *input, tran_low_t *output, int stride";
514   specialize qw/vpx_highbd_fdct4x4 sse2/;
515
516   add_proto qw/void vpx_highbd_fdct8x8/, "const int16_t *input, tran_low_t *output, int stride";
517   specialize qw/vpx_highbd_fdct8x8 sse2/;
518
519   add_proto qw/void vpx_highbd_fdct8x8_1/, "const int16_t *input, tran_low_t *output, int stride";
520
521   add_proto qw/void vpx_highbd_fdct16x16/, "const int16_t *input, tran_low_t *output, int stride";
522   specialize qw/vpx_highbd_fdct16x16 sse2/;
523
524   add_proto qw/void vpx_highbd_fdct16x16_1/, "const int16_t *input, tran_low_t *output, int stride";
525
526   add_proto qw/void vpx_highbd_fdct32x32/, "const int16_t *input, tran_low_t *output, int stride";
527   specialize qw/vpx_highbd_fdct32x32 sse2/;
528
529   add_proto qw/void vpx_highbd_fdct32x32_rd/, "const int16_t *input, tran_low_t *output, int stride";
530   specialize qw/vpx_highbd_fdct32x32_rd sse2/;
531
532   add_proto qw/void vpx_highbd_fdct32x32_1/, "const int16_t *input, tran_low_t *output, int stride";
533 } else {
534   add_proto qw/void vpx_fdct4x4/, "const int16_t *input, tran_low_t *output, int stride";
535   specialize qw/vpx_fdct4x4 sse2 msa/;
536
537   add_proto qw/void vpx_fdct4x4_1/, "const int16_t *input, tran_low_t *output, int stride";
538   specialize qw/vpx_fdct4x4_1 sse2/;
539
540   add_proto qw/void vpx_fdct8x8/, "const int16_t *input, tran_low_t *output, int stride";
541   specialize qw/vpx_fdct8x8 sse2 neon msa/, "$ssse3_x86_64";
542
543   add_proto qw/void vpx_fdct8x8_1/, "const int16_t *input, tran_low_t *output, int stride";
544   specialize qw/vpx_fdct8x8_1 sse2 neon msa/;
545
546   add_proto qw/void vpx_fdct16x16/, "const int16_t *input, tran_low_t *output, int stride";
547   specialize qw/vpx_fdct16x16 sse2 msa/;
548
549   add_proto qw/void vpx_fdct16x16_1/, "const int16_t *input, tran_low_t *output, int stride";
550   specialize qw/vpx_fdct16x16_1 sse2 msa/;
551
552   add_proto qw/void vpx_fdct32x32/, "const int16_t *input, tran_low_t *output, int stride";
553   specialize qw/vpx_fdct32x32 sse2 avx2 msa/;
554
555   add_proto qw/void vpx_fdct32x32_rd/, "const int16_t *input, tran_low_t *output, int stride";
556   specialize qw/vpx_fdct32x32_rd sse2 avx2 msa/;
557
558   add_proto qw/void vpx_fdct32x32_1/, "const int16_t *input, tran_low_t *output, int stride";
559   specialize qw/vpx_fdct32x32_1 sse2 msa/;
560 }  # CONFIG_VP9_HIGHBITDEPTH
561 }  # CONFIG_VP9_ENCODER
562
563 #
564 # Inverse transform
565 if (vpx_config("CONFIG_VP9") eq "yes") {
566
567 add_proto qw/void vpx_idct4x4_16_add/, "const tran_low_t *input, uint8_t *dest, int stride";
568
569 add_proto qw/void vpx_idct4x4_1_add/, "const tran_low_t *input, uint8_t *dest, int stride";
570
571 add_proto qw/void vpx_idct8x8_64_add/, "const tran_low_t *input, uint8_t *dest, int stride";
572
573 add_proto qw/void vpx_idct8x8_12_add/, "const tran_low_t *input, uint8_t *dest, int stride";
574
575 add_proto qw/void vpx_idct8x8_1_add/, "const tran_low_t *input, uint8_t *dest, int stride";
576
577 add_proto qw/void vpx_idct16x16_256_add/, "const tran_low_t *input, uint8_t *dest, int stride";
578
579 add_proto qw/void vpx_idct16x16_38_add/, "const tran_low_t *input, uint8_t *dest, int stride";
580
581 add_proto qw/void vpx_idct16x16_10_add/, "const tran_low_t *input, uint8_t *dest, int stride";
582
583 add_proto qw/void vpx_idct16x16_1_add/, "const tran_low_t *input, uint8_t *dest, int stride";
584
585 add_proto qw/void vpx_idct32x32_1024_add/, "const tran_low_t *input, uint8_t *dest, int stride";
586
587 add_proto qw/void vpx_idct32x32_135_add/, "const tran_low_t *input, uint8_t *dest, int stride";
588
589 add_proto qw/void vpx_idct32x32_34_add/, "const tran_low_t *input, uint8_t *dest, int stride";
590
591 add_proto qw/void vpx_idct32x32_1_add/, "const tran_low_t *input, uint8_t *dest, int stride";
592
593 add_proto qw/void vpx_iwht4x4_16_add/, "const tran_low_t *input, uint8_t *dest, int stride";
594
595 add_proto qw/void vpx_iwht4x4_1_add/, "const tran_low_t *input, uint8_t *dest, int stride";
596
597 if (vpx_config("CONFIG_VP9_HIGHBITDEPTH") eq "yes") {
598   # Note as optimized versions of these functions are added we need to add a check to ensure
599   # that when CONFIG_EMULATE_HARDWARE is on, it defaults to the C versions only.
600   specialize qw/vpx_iwht4x4_16_add sse2/;
601
602   add_proto qw/void vpx_highbd_idct4x4_16_add/, "const tran_low_t *input, uint8_t *dest, int stride, int bd";
603
604   add_proto qw/void vpx_highbd_idct4x4_1_add/, "const tran_low_t *input, uint8_t *dest, int stride, int bd";
605   specialize qw/vpx_highbd_idct4x4_1_add neon/;
606
607   add_proto qw/void vpx_highbd_idct8x8_64_add/, "const tran_low_t *input, uint8_t *dest, int stride, int bd";
608
609   add_proto qw/void vpx_highbd_idct8x8_12_add/, "const tran_low_t *input, uint8_t *dest, int stride, int bd";
610
611   add_proto qw/void vpx_highbd_idct8x8_1_add/, "const tran_low_t *input, uint8_t *dest, int stride, int bd";
612   specialize qw/vpx_highbd_idct8x8_1_add neon/;
613
614   add_proto qw/void vpx_highbd_idct16x16_256_add/, "const tran_low_t *input, uint8_t *dest, int stride, int bd";
615
616   add_proto qw/void vpx_highbd_idct16x16_38_add/, "const tran_low_t *input, uint8_t *dest, int stride, int bd";
617
618   add_proto qw/void vpx_highbd_idct16x16_10_add/, "const tran_low_t *input, uint8_t *dest, int stride, int bd";
619
620   add_proto qw/void vpx_highbd_idct16x16_1_add/, "const tran_low_t *input, uint8_t *dest, int stride, int bd";
621   specialize qw/vpx_highbd_idct16x16_1_add neon/;
622
623   add_proto qw/void vpx_highbd_idct32x32_1024_add/, "const tran_low_t *input, uint8_t *dest, int stride, int bd";
624
625   add_proto qw/void vpx_highbd_idct32x32_135_add/, "const tran_low_t *input, uint8_t *dest, int stride, int bd";
626
627   add_proto qw/void vpx_highbd_idct32x32_34_add/, "const tran_low_t *input, uint8_t *dest, int stride, int bd";
628
629   add_proto qw/void vpx_highbd_idct32x32_1_add/, "const tran_low_t *input, uint8_t *dest, int stride, int bd";
630   specialize qw/vpx_highbd_idct32x32_1_add neon sse2/;
631
632   add_proto qw/void vpx_highbd_iwht4x4_16_add/, "const tran_low_t *input, uint8_t *dest, int stride, int bd";
633
634   add_proto qw/void vpx_highbd_iwht4x4_1_add/, "const tran_low_t *input, uint8_t *dest, int stride, int bd";
635
636   if (vpx_config("CONFIG_EMULATE_HARDWARE") ne "yes") {
637     specialize qw/vpx_idct4x4_16_add neon sse2/;
638
639     specialize qw/vpx_idct4x4_1_add neon sse2/;
640
641     specialize qw/vpx_idct8x8_64_add neon sse2 ssse3/;
642
643     specialize qw/vpx_idct8x8_12_add neon sse2 ssse3/;
644
645     specialize qw/vpx_idct8x8_1_add neon sse2/;
646
647     specialize qw/vpx_idct16x16_256_add neon sse2/;
648
649     specialize qw/vpx_idct16x16_38_add neon sse2/;
650     $vpx_idct16x16_38_add_sse2=vpx_idct16x16_256_add_sse2;
651
652     specialize qw/vpx_idct16x16_10_add neon sse2/;
653
654     specialize qw/vpx_idct16x16_1_add neon sse2/;
655
656     specialize qw/vpx_idct32x32_1024_add neon sse2 ssse3/;
657
658     specialize qw/vpx_idct32x32_135_add neon sse2 ssse3/;
659     # Need to add 135 eob idct32x32 implementations.
660     $vpx_idct32x32_135_add_sse2=vpx_idct32x32_1024_add_sse2;
661
662     specialize qw/vpx_idct32x32_34_add neon sse2 ssse3/;
663
664     specialize qw/vpx_idct32x32_1_add neon sse2/;
665
666     specialize qw/vpx_highbd_idct4x4_16_add neon sse2/;
667
668     specialize qw/vpx_highbd_idct8x8_64_add neon sse2/;
669
670     specialize qw/vpx_highbd_idct8x8_12_add neon sse2/;
671
672     specialize qw/vpx_highbd_idct16x16_256_add neon sse2/;
673
674     specialize qw/vpx_highbd_idct16x16_38_add neon sse2/;
675     $vpx_highbd_idct16x16_38_add_sse2=vpx_highbd_idct16x16_256_add_sse2;
676
677     specialize qw/vpx_highbd_idct16x16_10_add neon sse2/;
678
679     specialize qw/vpx_highbd_idct32x32_1024_add neon/;
680
681     specialize qw/vpx_highbd_idct32x32_135_add neon/;
682
683     specialize qw/vpx_highbd_idct32x32_34_add neon/;
684   }  # !CONFIG_EMULATE_HARDWARE
685 } else {
686   if (vpx_config("CONFIG_EMULATE_HARDWARE") ne "yes") {
687     specialize qw/vpx_idct4x4_1_add sse2 neon dspr2 msa/;
688
689     specialize qw/vpx_idct4x4_16_add sse2 neon dspr2 msa/;
690
691     specialize qw/vpx_idct8x8_1_add sse2 neon dspr2 msa/;
692
693     specialize qw/vpx_idct8x8_64_add sse2 ssse3 neon dspr2 msa/;
694
695     specialize qw/vpx_idct8x8_12_add sse2 ssse3 neon dspr2 msa/;
696
697     specialize qw/vpx_idct16x16_1_add sse2 neon dspr2 msa/;
698
699     specialize qw/vpx_idct16x16_256_add sse2 neon dspr2 msa/;
700
701     specialize qw/vpx_idct16x16_38_add sse2 neon dspr2 msa/;
702     $vpx_idct16x16_38_add_sse2=vpx_idct16x16_256_add_sse2;
703     $vpx_idct16x16_38_add_dspr2=vpx_idct16x16_256_add_dspr2;
704     $vpx_idct16x16_38_add_msa=vpx_idct16x16_256_add_msa;
705
706     specialize qw/vpx_idct16x16_10_add sse2 neon dspr2 msa/;
707
708     specialize qw/vpx_idct32x32_1024_add sse2 ssse3 neon dspr2 msa/;
709
710     specialize qw/vpx_idct32x32_135_add sse2 ssse3 neon dspr2 msa/;
711     $vpx_idct32x32_135_add_sse2=vpx_idct32x32_1024_add_sse2;
712     $vpx_idct32x32_135_add_dspr2=vpx_idct32x32_1024_add_dspr2;
713     $vpx_idct32x32_135_add_msa=vpx_idct32x32_1024_add_msa;
714
715     specialize qw/vpx_idct32x32_34_add sse2 ssse3 neon dspr2 msa/;
716
717     specialize qw/vpx_idct32x32_1_add sse2 neon dspr2 msa/;
718
719     specialize qw/vpx_iwht4x4_1_add msa/;
720
721     specialize qw/vpx_iwht4x4_16_add msa sse2/;
722   }  # !CONFIG_EMULATE_HARDWARE
723 }  # CONFIG_VP9_HIGHBITDEPTH
724 }  # CONFIG_VP9
725
726 #
727 # Quantization
728 #
729 if (vpx_config("CONFIG_VP9_ENCODER") eq "yes") {
730   add_proto qw/void vpx_quantize_b/, "const tran_low_t *coeff_ptr, intptr_t n_coeffs, int skip_block, const int16_t *zbin_ptr, const int16_t *round_ptr, const int16_t *quant_ptr, const int16_t *quant_shift_ptr, tran_low_t *qcoeff_ptr, tran_low_t *dqcoeff_ptr, const int16_t *dequant_ptr, uint16_t *eob_ptr, const int16_t *scan, const int16_t *iscan";
731   specialize qw/vpx_quantize_b sse2/, "$ssse3_x86_64", "$avx_x86_64";
732
733   add_proto qw/void vpx_quantize_b_32x32/, "const tran_low_t *coeff_ptr, intptr_t n_coeffs, int skip_block, const int16_t *zbin_ptr, const int16_t *round_ptr, const int16_t *quant_ptr, const int16_t *quant_shift_ptr, tran_low_t *qcoeff_ptr, tran_low_t *dqcoeff_ptr, const int16_t *dequant_ptr, uint16_t *eob_ptr, const int16_t *scan, const int16_t *iscan";
734   specialize qw/vpx_quantize_b_32x32/, "$ssse3_x86_64", "$avx_x86_64";
735
736   if (vpx_config("CONFIG_VP9_HIGHBITDEPTH") eq "yes") {
737     add_proto qw/void vpx_highbd_quantize_b/, "const tran_low_t *coeff_ptr, intptr_t n_coeffs, int skip_block, const int16_t *zbin_ptr, const int16_t *round_ptr, const int16_t *quant_ptr, const int16_t *quant_shift_ptr, tran_low_t *qcoeff_ptr, tran_low_t *dqcoeff_ptr, const int16_t *dequant_ptr, uint16_t *eob_ptr, const int16_t *scan, const int16_t *iscan";
738     specialize qw/vpx_highbd_quantize_b sse2/;
739
740     add_proto qw/void vpx_highbd_quantize_b_32x32/, "const tran_low_t *coeff_ptr, intptr_t n_coeffs, int skip_block, const int16_t *zbin_ptr, const int16_t *round_ptr, const int16_t *quant_ptr, const int16_t *quant_shift_ptr, tran_low_t *qcoeff_ptr, tran_low_t *dqcoeff_ptr, const int16_t *dequant_ptr, uint16_t *eob_ptr, const int16_t *scan, const int16_t *iscan";
741     specialize qw/vpx_highbd_quantize_b_32x32 sse2/;
742   }  # CONFIG_VP9_HIGHBITDEPTH
743 }  # CONFIG_VP9_ENCODER
744
745 if (vpx_config("CONFIG_ENCODERS") eq "yes") {
746 #
747 # Block subtraction
748 #
749 add_proto qw/void vpx_subtract_block/, "int rows, int cols, int16_t *diff_ptr, ptrdiff_t diff_stride, const uint8_t *src_ptr, ptrdiff_t src_stride, const uint8_t *pred_ptr, ptrdiff_t pred_stride";
750 specialize qw/vpx_subtract_block neon msa sse2/;
751
752 #
753 # Single block SAD
754 #
755 add_proto qw/unsigned int vpx_sad64x64/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
756 specialize qw/vpx_sad64x64 avx2 neon msa sse2/;
757
758 add_proto qw/unsigned int vpx_sad64x32/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
759 specialize qw/vpx_sad64x32 avx2 msa sse2/;
760
761 add_proto qw/unsigned int vpx_sad32x64/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
762 specialize qw/vpx_sad32x64 avx2 msa sse2/;
763
764 add_proto qw/unsigned int vpx_sad32x32/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
765 specialize qw/vpx_sad32x32 avx2 neon msa sse2/;
766
767 add_proto qw/unsigned int vpx_sad32x16/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
768 specialize qw/vpx_sad32x16 avx2 msa sse2/;
769
770 add_proto qw/unsigned int vpx_sad16x32/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
771 specialize qw/vpx_sad16x32 msa sse2/;
772
773 add_proto qw/unsigned int vpx_sad16x16/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
774 specialize qw/vpx_sad16x16 neon msa sse2/;
775
776 add_proto qw/unsigned int vpx_sad16x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
777 specialize qw/vpx_sad16x8 neon msa sse2/;
778
779 add_proto qw/unsigned int vpx_sad8x16/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
780 specialize qw/vpx_sad8x16 neon msa sse2/;
781
782 add_proto qw/unsigned int vpx_sad8x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
783 specialize qw/vpx_sad8x8 neon msa sse2/;
784
785 add_proto qw/unsigned int vpx_sad8x4/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
786 specialize qw/vpx_sad8x4 msa sse2/;
787
788 add_proto qw/unsigned int vpx_sad4x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
789 specialize qw/vpx_sad4x8 msa sse2/;
790
791 add_proto qw/unsigned int vpx_sad4x4/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
792 specialize qw/vpx_sad4x4 neon msa sse2/;
793
794 #
795 # Avg
796 #
797 if (vpx_config("CONFIG_VP9_ENCODER") eq "yes") {
798   add_proto qw/unsigned int vpx_avg_8x8/, "const uint8_t *, int p";
799   specialize qw/vpx_avg_8x8 sse2 neon msa/;
800
801   add_proto qw/unsigned int vpx_avg_4x4/, "const uint8_t *, int p";
802   specialize qw/vpx_avg_4x4 sse2 neon msa/;
803
804   add_proto qw/void vpx_minmax_8x8/, "const uint8_t *s, int p, const uint8_t *d, int dp, int *min, int *max";
805   specialize qw/vpx_minmax_8x8 sse2 neon msa/;
806
807   if (vpx_config("CONFIG_VP9_HIGHBITDEPTH") eq "yes") {
808     add_proto qw/void vpx_hadamard_8x8/, "const int16_t *src_diff, int src_stride, tran_low_t *coeff";
809     specialize qw/vpx_hadamard_8x8 sse2 neon vsx/, "$ssse3_x86_64";
810
811     add_proto qw/void vpx_hadamard_16x16/, "const int16_t *src_diff, int src_stride, tran_low_t *coeff";
812     specialize qw/vpx_hadamard_16x16 sse2 neon vsx/;
813
814     add_proto qw/int vpx_satd/, "const tran_low_t *coeff, int length";
815     specialize qw/vpx_satd sse2 neon/;
816   } else {
817     add_proto qw/void vpx_hadamard_8x8/, "const int16_t *src_diff, int src_stride, int16_t *coeff";
818     specialize qw/vpx_hadamard_8x8 sse2 neon msa vsx/, "$ssse3_x86_64";
819
820     add_proto qw/void vpx_hadamard_16x16/, "const int16_t *src_diff, int src_stride, int16_t *coeff";
821     specialize qw/vpx_hadamard_16x16 sse2 neon msa vsx/;
822
823     add_proto qw/int vpx_satd/, "const int16_t *coeff, int length";
824     specialize qw/vpx_satd sse2 neon msa/;
825   }
826
827   add_proto qw/void vpx_int_pro_row/, "int16_t *hbuf, const uint8_t *ref, const int ref_stride, const int height";
828   specialize qw/vpx_int_pro_row sse2 neon msa/;
829
830   add_proto qw/int16_t vpx_int_pro_col/, "const uint8_t *ref, const int width";
831   specialize qw/vpx_int_pro_col sse2 neon msa/;
832
833   add_proto qw/int vpx_vector_var/, "const int16_t *ref, const int16_t *src, const int bwl";
834   specialize qw/vpx_vector_var neon sse2 msa/;
835 }  # CONFIG_VP9_ENCODER
836
837 add_proto qw/unsigned int vpx_sad64x64_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
838 specialize qw/vpx_sad64x64_avg avx2 msa sse2/;
839
840 add_proto qw/unsigned int vpx_sad64x32_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
841 specialize qw/vpx_sad64x32_avg avx2 msa sse2/;
842
843 add_proto qw/unsigned int vpx_sad32x64_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
844 specialize qw/vpx_sad32x64_avg avx2 msa sse2/;
845
846 add_proto qw/unsigned int vpx_sad32x32_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
847 specialize qw/vpx_sad32x32_avg avx2 msa sse2/;
848
849 add_proto qw/unsigned int vpx_sad32x16_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
850 specialize qw/vpx_sad32x16_avg avx2 msa sse2/;
851
852 add_proto qw/unsigned int vpx_sad16x32_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
853 specialize qw/vpx_sad16x32_avg msa sse2/;
854
855 add_proto qw/unsigned int vpx_sad16x16_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
856 specialize qw/vpx_sad16x16_avg msa sse2/;
857
858 add_proto qw/unsigned int vpx_sad16x8_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
859 specialize qw/vpx_sad16x8_avg msa sse2/;
860
861 add_proto qw/unsigned int vpx_sad8x16_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
862 specialize qw/vpx_sad8x16_avg msa sse2/;
863
864 add_proto qw/unsigned int vpx_sad8x8_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
865 specialize qw/vpx_sad8x8_avg msa sse2/;
866
867 add_proto qw/unsigned int vpx_sad8x4_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
868 specialize qw/vpx_sad8x4_avg msa sse2/;
869
870 add_proto qw/unsigned int vpx_sad4x8_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
871 specialize qw/vpx_sad4x8_avg msa sse2/;
872
873 add_proto qw/unsigned int vpx_sad4x4_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
874 specialize qw/vpx_sad4x4_avg msa sse2/;
875
876 #
877 # Multi-block SAD, comparing a reference to N blocks 1 pixel apart horizontally
878 #
879 # Blocks of 3
880 add_proto qw/void vpx_sad64x64x3/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
881 specialize qw/vpx_sad64x64x3 msa/;
882
883 add_proto qw/void vpx_sad32x32x3/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
884 specialize qw/vpx_sad32x32x3 msa/;
885
886 add_proto qw/void vpx_sad16x16x3/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
887 specialize qw/vpx_sad16x16x3 sse3 ssse3 msa/;
888
889 add_proto qw/void vpx_sad16x8x3/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
890 specialize qw/vpx_sad16x8x3 sse3 ssse3 msa/;
891
892 add_proto qw/void vpx_sad8x16x3/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
893 specialize qw/vpx_sad8x16x3 sse3 msa/;
894
895 add_proto qw/void vpx_sad8x8x3/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
896 specialize qw/vpx_sad8x8x3 sse3 msa/;
897
898 add_proto qw/void vpx_sad4x4x3/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
899 specialize qw/vpx_sad4x4x3 sse3 msa/;
900
901 # Blocks of 8
902 add_proto qw/void vpx_sad64x64x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
903 specialize qw/vpx_sad64x64x8 msa/;
904
905 add_proto qw/void vpx_sad32x32x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
906 specialize qw/vpx_sad32x32x8 msa/;
907
908 add_proto qw/void vpx_sad16x16x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
909 specialize qw/vpx_sad16x16x8 sse4_1 msa/;
910
911 add_proto qw/void vpx_sad16x8x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
912 specialize qw/vpx_sad16x8x8 sse4_1 msa/;
913
914 add_proto qw/void vpx_sad8x16x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
915 specialize qw/vpx_sad8x16x8 sse4_1 msa/;
916
917 add_proto qw/void vpx_sad8x8x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
918 specialize qw/vpx_sad8x8x8 sse4_1 msa/;
919
920 add_proto qw/void vpx_sad8x4x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
921 specialize qw/vpx_sad8x4x8 msa/;
922
923 add_proto qw/void vpx_sad4x8x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
924 specialize qw/vpx_sad4x8x8 msa/;
925
926 add_proto qw/void vpx_sad4x4x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
927 specialize qw/vpx_sad4x4x8 sse4_1 msa/;
928
929 #
930 # Multi-block SAD, comparing a reference to N independent blocks
931 #
932 add_proto qw/void vpx_sad64x64x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t * const ref_ptr[], int ref_stride, uint32_t *sad_array";
933 specialize qw/vpx_sad64x64x4d avx2 neon msa sse2/;
934
935 add_proto qw/void vpx_sad64x32x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t * const ref_ptr[], int ref_stride, uint32_t *sad_array";
936 specialize qw/vpx_sad64x32x4d msa sse2/;
937
938 add_proto qw/void vpx_sad32x64x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t * const ref_ptr[], int ref_stride, uint32_t *sad_array";
939 specialize qw/vpx_sad32x64x4d msa sse2/;
940
941 add_proto qw/void vpx_sad32x32x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t * const ref_ptr[], int ref_stride, uint32_t *sad_array";
942 specialize qw/vpx_sad32x32x4d avx2 neon msa sse2/;
943
944 add_proto qw/void vpx_sad32x16x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t * const ref_ptr[], int ref_stride, uint32_t *sad_array";
945 specialize qw/vpx_sad32x16x4d msa sse2/;
946
947 add_proto qw/void vpx_sad16x32x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t * const ref_ptr[], int ref_stride, uint32_t *sad_array";
948 specialize qw/vpx_sad16x32x4d msa sse2/;
949
950 add_proto qw/void vpx_sad16x16x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t * const ref_ptr[], int ref_stride, uint32_t *sad_array";
951 specialize qw/vpx_sad16x16x4d neon msa sse2/;
952
953 add_proto qw/void vpx_sad16x8x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t * const ref_ptr[], int ref_stride, uint32_t *sad_array";
954 specialize qw/vpx_sad16x8x4d msa sse2/;
955
956 add_proto qw/void vpx_sad8x16x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t * const ref_ptr[], int ref_stride, uint32_t *sad_array";
957 specialize qw/vpx_sad8x16x4d msa sse2/;
958
959 add_proto qw/void vpx_sad8x8x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t * const ref_ptr[], int ref_stride, uint32_t *sad_array";
960 specialize qw/vpx_sad8x8x4d msa sse2/;
961
962 add_proto qw/void vpx_sad8x4x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t * const ref_ptr[], int ref_stride, uint32_t *sad_array";
963 specialize qw/vpx_sad8x4x4d msa sse2/;
964
965 add_proto qw/void vpx_sad4x8x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t * const ref_ptr[], int ref_stride, uint32_t *sad_array";
966 specialize qw/vpx_sad4x8x4d msa sse2/;
967
968 add_proto qw/void vpx_sad4x4x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t * const ref_ptr[], int ref_stride, uint32_t *sad_array";
969 specialize qw/vpx_sad4x4x4d msa sse2/;
970
971 add_proto qw/uint64_t vpx_sum_squares_2d_i16/, "const int16_t *src, int stride, int size";
972 specialize qw/vpx_sum_squares_2d_i16 sse2 msa/;
973
974 #
975 # Structured Similarity (SSIM)
976 #
977 if (vpx_config("CONFIG_INTERNAL_STATS") eq "yes") {
978     add_proto qw/void vpx_ssim_parms_8x8/, "const uint8_t *s, int sp, const uint8_t *r, int rp, uint32_t *sum_s, uint32_t *sum_r, uint32_t *sum_sq_s, uint32_t *sum_sq_r, uint32_t *sum_sxr";
979     specialize qw/vpx_ssim_parms_8x8/, "$sse2_x86_64";
980
981     add_proto qw/void vpx_ssim_parms_16x16/, "const uint8_t *s, int sp, const uint8_t *r, int rp, uint32_t *sum_s, uint32_t *sum_r, uint32_t *sum_sq_s, uint32_t *sum_sq_r, uint32_t *sum_sxr";
982     specialize qw/vpx_ssim_parms_16x16/, "$sse2_x86_64";
983 }
984
985 if (vpx_config("CONFIG_VP9_HIGHBITDEPTH") eq "yes") {
986   #
987   # Block subtraction
988   #
989   add_proto qw/void vpx_highbd_subtract_block/, "int rows, int cols, int16_t *diff_ptr, ptrdiff_t diff_stride, const uint8_t *src_ptr, ptrdiff_t src_stride, const uint8_t *pred_ptr, ptrdiff_t pred_stride, int bd";
990
991   #
992   # Single block SAD
993   #
994   add_proto qw/unsigned int vpx_highbd_sad64x64/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
995   specialize qw/vpx_highbd_sad64x64 sse2/;
996
997   add_proto qw/unsigned int vpx_highbd_sad64x32/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
998   specialize qw/vpx_highbd_sad64x32 sse2/;
999
1000   add_proto qw/unsigned int vpx_highbd_sad32x64/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
1001   specialize qw/vpx_highbd_sad32x64 sse2/;
1002
1003   add_proto qw/unsigned int vpx_highbd_sad32x32/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
1004   specialize qw/vpx_highbd_sad32x32 sse2/;
1005
1006   add_proto qw/unsigned int vpx_highbd_sad32x16/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
1007   specialize qw/vpx_highbd_sad32x16 sse2/;
1008
1009   add_proto qw/unsigned int vpx_highbd_sad16x32/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
1010   specialize qw/vpx_highbd_sad16x32 sse2/;
1011
1012   add_proto qw/unsigned int vpx_highbd_sad16x16/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
1013   specialize qw/vpx_highbd_sad16x16 sse2/;
1014
1015   add_proto qw/unsigned int vpx_highbd_sad16x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
1016   specialize qw/vpx_highbd_sad16x8 sse2/;
1017
1018   add_proto qw/unsigned int vpx_highbd_sad8x16/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
1019   specialize qw/vpx_highbd_sad8x16 sse2/;
1020
1021   add_proto qw/unsigned int vpx_highbd_sad8x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
1022   specialize qw/vpx_highbd_sad8x8 sse2/;
1023
1024   add_proto qw/unsigned int vpx_highbd_sad8x4/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
1025   specialize qw/vpx_highbd_sad8x4 sse2/;
1026
1027   add_proto qw/unsigned int vpx_highbd_sad4x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
1028
1029   add_proto qw/unsigned int vpx_highbd_sad4x4/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride";
1030
1031   #
1032   # Avg
1033   #
1034   add_proto qw/unsigned int vpx_highbd_avg_8x8/, "const uint8_t *, int p";
1035   add_proto qw/unsigned int vpx_highbd_avg_4x4/, "const uint8_t *, int p";
1036   add_proto qw/void vpx_highbd_minmax_8x8/, "const uint8_t *s, int p, const uint8_t *d, int dp, int *min, int *max";
1037
1038   add_proto qw/unsigned int vpx_highbd_sad64x64_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
1039   specialize qw/vpx_highbd_sad64x64_avg sse2/;
1040
1041   add_proto qw/unsigned int vpx_highbd_sad64x32_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
1042   specialize qw/vpx_highbd_sad64x32_avg sse2/;
1043
1044   add_proto qw/unsigned int vpx_highbd_sad32x64_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
1045   specialize qw/vpx_highbd_sad32x64_avg sse2/;
1046
1047   add_proto qw/unsigned int vpx_highbd_sad32x32_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
1048   specialize qw/vpx_highbd_sad32x32_avg sse2/;
1049
1050   add_proto qw/unsigned int vpx_highbd_sad32x16_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
1051   specialize qw/vpx_highbd_sad32x16_avg sse2/;
1052
1053   add_proto qw/unsigned int vpx_highbd_sad16x32_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
1054   specialize qw/vpx_highbd_sad16x32_avg sse2/;
1055
1056   add_proto qw/unsigned int vpx_highbd_sad16x16_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
1057   specialize qw/vpx_highbd_sad16x16_avg sse2/;
1058
1059   add_proto qw/unsigned int vpx_highbd_sad16x8_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
1060   specialize qw/vpx_highbd_sad16x8_avg sse2/;
1061
1062   add_proto qw/unsigned int vpx_highbd_sad8x16_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
1063   specialize qw/vpx_highbd_sad8x16_avg sse2/;
1064
1065   add_proto qw/unsigned int vpx_highbd_sad8x8_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
1066   specialize qw/vpx_highbd_sad8x8_avg sse2/;
1067
1068   add_proto qw/unsigned int vpx_highbd_sad8x4_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
1069   specialize qw/vpx_highbd_sad8x4_avg sse2/;
1070
1071   add_proto qw/unsigned int vpx_highbd_sad4x8_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
1072
1073   add_proto qw/unsigned int vpx_highbd_sad4x4_avg/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, const uint8_t *second_pred";
1074
1075   #
1076   # Multi-block SAD, comparing a reference to N blocks 1 pixel apart horizontally
1077   #
1078   # Blocks of 3
1079   add_proto qw/void vpx_highbd_sad64x64x3/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
1080
1081   add_proto qw/void vpx_highbd_sad32x32x3/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
1082
1083   add_proto qw/void vpx_highbd_sad16x16x3/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
1084
1085   add_proto qw/void vpx_highbd_sad16x8x3/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
1086
1087   add_proto qw/void vpx_highbd_sad8x16x3/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
1088
1089   add_proto qw/void vpx_highbd_sad8x8x3/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
1090
1091   add_proto qw/void vpx_highbd_sad4x4x3/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
1092
1093   # Blocks of 8
1094   add_proto qw/void vpx_highbd_sad64x64x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
1095
1096   add_proto qw/void vpx_highbd_sad32x32x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
1097
1098   add_proto qw/void vpx_highbd_sad16x16x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
1099
1100   add_proto qw/void vpx_highbd_sad16x8x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
1101
1102   add_proto qw/void vpx_highbd_sad8x16x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
1103
1104   add_proto qw/void vpx_highbd_sad8x8x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
1105
1106   add_proto qw/void vpx_highbd_sad8x4x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
1107
1108   add_proto qw/void vpx_highbd_sad4x8x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
1109
1110   add_proto qw/void vpx_highbd_sad4x4x8/, "const uint8_t *src_ptr, int src_stride, const uint8_t *ref_ptr, int ref_stride, uint32_t *sad_array";
1111
1112   #
1113   # Multi-block SAD, comparing a reference to N independent blocks
1114   #
1115   add_proto qw/void vpx_highbd_sad64x64x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t* const ref_ptr[], int ref_stride, uint32_t *sad_array";
1116   specialize qw/vpx_highbd_sad64x64x4d sse2/;
1117
1118   add_proto qw/void vpx_highbd_sad64x32x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t* const ref_ptr[], int ref_stride, uint32_t *sad_array";
1119   specialize qw/vpx_highbd_sad64x32x4d sse2/;
1120
1121   add_proto qw/void vpx_highbd_sad32x64x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t* const ref_ptr[], int ref_stride, uint32_t *sad_array";
1122   specialize qw/vpx_highbd_sad32x64x4d sse2/;
1123
1124   add_proto qw/void vpx_highbd_sad32x32x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t* const ref_ptr[], int ref_stride, uint32_t *sad_array";
1125   specialize qw/vpx_highbd_sad32x32x4d sse2/;
1126
1127   add_proto qw/void vpx_highbd_sad32x16x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t* const ref_ptr[], int ref_stride, uint32_t *sad_array";
1128   specialize qw/vpx_highbd_sad32x16x4d sse2/;
1129
1130   add_proto qw/void vpx_highbd_sad16x32x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t* const ref_ptr[], int ref_stride, uint32_t *sad_array";
1131   specialize qw/vpx_highbd_sad16x32x4d sse2/;
1132
1133   add_proto qw/void vpx_highbd_sad16x16x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t* const ref_ptr[], int ref_stride, uint32_t *sad_array";
1134   specialize qw/vpx_highbd_sad16x16x4d sse2/;
1135
1136   add_proto qw/void vpx_highbd_sad16x8x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t* const ref_ptr[], int ref_stride, uint32_t *sad_array";
1137   specialize qw/vpx_highbd_sad16x8x4d sse2/;
1138
1139   add_proto qw/void vpx_highbd_sad8x16x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t* const ref_ptr[], int ref_stride, uint32_t *sad_array";
1140   specialize qw/vpx_highbd_sad8x16x4d sse2/;
1141
1142   add_proto qw/void vpx_highbd_sad8x8x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t* const ref_ptr[], int ref_stride, uint32_t *sad_array";
1143   specialize qw/vpx_highbd_sad8x8x4d sse2/;
1144
1145   add_proto qw/void vpx_highbd_sad8x4x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t* const ref_ptr[], int ref_stride, uint32_t *sad_array";
1146   specialize qw/vpx_highbd_sad8x4x4d sse2/;
1147
1148   add_proto qw/void vpx_highbd_sad4x8x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t* const ref_ptr[], int ref_stride, uint32_t *sad_array";
1149   specialize qw/vpx_highbd_sad4x8x4d sse2/;
1150
1151   add_proto qw/void vpx_highbd_sad4x4x4d/, "const uint8_t *src_ptr, int src_stride, const uint8_t* const ref_ptr[], int ref_stride, uint32_t *sad_array";
1152   specialize qw/vpx_highbd_sad4x4x4d sse2/;
1153
1154   #
1155   # Structured Similarity (SSIM)
1156   #
1157   if (vpx_config("CONFIG_INTERNAL_STATS") eq "yes") {
1158     add_proto qw/void vpx_highbd_ssim_parms_8x8/, "const uint16_t *s, int sp, const uint16_t *r, int rp, uint32_t *sum_s, uint32_t *sum_r, uint32_t *sum_sq_s, uint32_t *sum_sq_r, uint32_t *sum_sxr";
1159   }
1160 }  # CONFIG_VP9_HIGHBITDEPTH
1161 }  # CONFIG_ENCODERS
1162
1163 if (vpx_config("CONFIG_ENCODERS") eq "yes" || vpx_config("CONFIG_POSTPROC") eq "yes" || vpx_config("CONFIG_VP9_POSTPROC") eq "yes") {
1164
1165 #
1166 # Variance
1167 #
1168 add_proto qw/unsigned int vpx_variance64x64/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1169   specialize qw/vpx_variance64x64 sse2 avx2 neon msa/;
1170
1171 add_proto qw/unsigned int vpx_variance64x32/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1172   specialize qw/vpx_variance64x32 sse2 avx2 neon msa/;
1173
1174 add_proto qw/unsigned int vpx_variance32x64/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1175   specialize qw/vpx_variance32x64 sse2 neon msa/;
1176
1177 add_proto qw/unsigned int vpx_variance32x32/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1178   specialize qw/vpx_variance32x32 sse2 avx2 neon msa/;
1179
1180 add_proto qw/unsigned int vpx_variance32x16/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1181   specialize qw/vpx_variance32x16 sse2 avx2 msa/;
1182
1183 add_proto qw/unsigned int vpx_variance16x32/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1184   specialize qw/vpx_variance16x32 sse2 msa/;
1185
1186 add_proto qw/unsigned int vpx_variance16x16/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1187   specialize qw/vpx_variance16x16 sse2 avx2 neon msa/;
1188
1189 add_proto qw/unsigned int vpx_variance16x8/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1190   specialize qw/vpx_variance16x8 sse2 neon msa/;
1191
1192 add_proto qw/unsigned int vpx_variance8x16/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1193   specialize qw/vpx_variance8x16 sse2 neon msa/;
1194
1195 add_proto qw/unsigned int vpx_variance8x8/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1196   specialize qw/vpx_variance8x8 sse2 neon msa/;
1197
1198 add_proto qw/unsigned int vpx_variance8x4/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1199   specialize qw/vpx_variance8x4 sse2 msa/;
1200
1201 add_proto qw/unsigned int vpx_variance4x8/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1202   specialize qw/vpx_variance4x8 sse2 msa/;
1203
1204 add_proto qw/unsigned int vpx_variance4x4/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1205   specialize qw/vpx_variance4x4 sse2 msa/;
1206
1207 #
1208 # Specialty Variance
1209 #
1210 add_proto qw/void vpx_get16x16var/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse, int *sum";
1211   specialize qw/vpx_get16x16var sse2 avx2 neon msa/;
1212
1213 add_proto qw/void vpx_get8x8var/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse, int *sum";
1214   specialize qw/vpx_get8x8var sse2 neon msa/;
1215
1216 add_proto qw/unsigned int vpx_mse16x16/, "const uint8_t *src_ptr, int  source_stride, const uint8_t *ref_ptr, int  recon_stride, unsigned int *sse";
1217   specialize qw/vpx_mse16x16 sse2 avx2 neon msa/;
1218
1219 add_proto qw/unsigned int vpx_mse16x8/, "const uint8_t *src_ptr, int  source_stride, const uint8_t *ref_ptr, int  recon_stride, unsigned int *sse";
1220   specialize qw/vpx_mse16x8 sse2 msa/;
1221
1222 add_proto qw/unsigned int vpx_mse8x16/, "const uint8_t *src_ptr, int  source_stride, const uint8_t *ref_ptr, int  recon_stride, unsigned int *sse";
1223   specialize qw/vpx_mse8x16 sse2 msa/;
1224
1225 add_proto qw/unsigned int vpx_mse8x8/, "const uint8_t *src_ptr, int  source_stride, const uint8_t *ref_ptr, int  recon_stride, unsigned int *sse";
1226   specialize qw/vpx_mse8x8 sse2 msa/;
1227
1228 add_proto qw/unsigned int vpx_get_mb_ss/, "const int16_t *";
1229   specialize qw/vpx_get_mb_ss sse2 msa/;
1230
1231 add_proto qw/unsigned int vpx_get4x4sse_cs/, "const unsigned char *src_ptr, int source_stride, const unsigned char *ref_ptr, int  ref_stride";
1232   specialize qw/vpx_get4x4sse_cs neon msa/;
1233
1234 add_proto qw/void vpx_comp_avg_pred/, "uint8_t *comp_pred, const uint8_t *pred, int width, int height, const uint8_t *ref, int ref_stride";
1235   specialize qw/vpx_comp_avg_pred sse2/;
1236
1237 #
1238 # Subpixel Variance
1239 #
1240 add_proto qw/uint32_t vpx_sub_pixel_variance64x64/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1241   specialize qw/vpx_sub_pixel_variance64x64 avx2 neon msa sse2 ssse3/;
1242
1243 add_proto qw/uint32_t vpx_sub_pixel_variance64x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1244   specialize qw/vpx_sub_pixel_variance64x32 msa sse2 ssse3/;
1245
1246 add_proto qw/uint32_t vpx_sub_pixel_variance32x64/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1247   specialize qw/vpx_sub_pixel_variance32x64 msa sse2 ssse3/;
1248
1249 add_proto qw/uint32_t vpx_sub_pixel_variance32x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1250   specialize qw/vpx_sub_pixel_variance32x32 avx2 neon msa sse2 ssse3/;
1251
1252 add_proto qw/uint32_t vpx_sub_pixel_variance32x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1253   specialize qw/vpx_sub_pixel_variance32x16 msa sse2 ssse3/;
1254
1255 add_proto qw/uint32_t vpx_sub_pixel_variance16x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1256   specialize qw/vpx_sub_pixel_variance16x32 msa sse2 ssse3/;
1257
1258 add_proto qw/uint32_t vpx_sub_pixel_variance16x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1259   specialize qw/vpx_sub_pixel_variance16x16 neon msa sse2 ssse3/;
1260
1261 add_proto qw/uint32_t vpx_sub_pixel_variance16x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1262   specialize qw/vpx_sub_pixel_variance16x8 msa sse2 ssse3/;
1263
1264 add_proto qw/uint32_t vpx_sub_pixel_variance8x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1265   specialize qw/vpx_sub_pixel_variance8x16 msa sse2 ssse3/;
1266
1267 add_proto qw/uint32_t vpx_sub_pixel_variance8x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1268   specialize qw/vpx_sub_pixel_variance8x8 neon msa sse2 ssse3/;
1269
1270 add_proto qw/uint32_t vpx_sub_pixel_variance8x4/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1271   specialize qw/vpx_sub_pixel_variance8x4 msa sse2 ssse3/;
1272
1273 add_proto qw/uint32_t vpx_sub_pixel_variance4x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1274   specialize qw/vpx_sub_pixel_variance4x8 msa sse2 ssse3/;
1275
1276 add_proto qw/uint32_t vpx_sub_pixel_variance4x4/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1277   specialize qw/vpx_sub_pixel_variance4x4 msa sse2 ssse3/;
1278
1279 add_proto qw/uint32_t vpx_sub_pixel_avg_variance64x64/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1280   specialize qw/vpx_sub_pixel_avg_variance64x64 avx2 msa sse2 ssse3/;
1281
1282 add_proto qw/uint32_t vpx_sub_pixel_avg_variance64x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1283   specialize qw/vpx_sub_pixel_avg_variance64x32 msa sse2 ssse3/;
1284
1285 add_proto qw/uint32_t vpx_sub_pixel_avg_variance32x64/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1286   specialize qw/vpx_sub_pixel_avg_variance32x64 msa sse2 ssse3/;
1287
1288 add_proto qw/uint32_t vpx_sub_pixel_avg_variance32x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1289   specialize qw/vpx_sub_pixel_avg_variance32x32 avx2 msa sse2 ssse3/;
1290
1291 add_proto qw/uint32_t vpx_sub_pixel_avg_variance32x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1292   specialize qw/vpx_sub_pixel_avg_variance32x16 msa sse2 ssse3/;
1293
1294 add_proto qw/uint32_t vpx_sub_pixel_avg_variance16x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1295   specialize qw/vpx_sub_pixel_avg_variance16x32 msa sse2 ssse3/;
1296
1297 add_proto qw/uint32_t vpx_sub_pixel_avg_variance16x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1298   specialize qw/vpx_sub_pixel_avg_variance16x16 msa sse2 ssse3/;
1299
1300 add_proto qw/uint32_t vpx_sub_pixel_avg_variance16x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1301   specialize qw/vpx_sub_pixel_avg_variance16x8 msa sse2 ssse3/;
1302
1303 add_proto qw/uint32_t vpx_sub_pixel_avg_variance8x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1304   specialize qw/vpx_sub_pixel_avg_variance8x16 msa sse2 ssse3/;
1305
1306 add_proto qw/uint32_t vpx_sub_pixel_avg_variance8x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1307   specialize qw/vpx_sub_pixel_avg_variance8x8 msa sse2 ssse3/;
1308
1309 add_proto qw/uint32_t vpx_sub_pixel_avg_variance8x4/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1310   specialize qw/vpx_sub_pixel_avg_variance8x4 msa sse2 ssse3/;
1311
1312 add_proto qw/uint32_t vpx_sub_pixel_avg_variance4x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1313   specialize qw/vpx_sub_pixel_avg_variance4x8 msa sse2 ssse3/;
1314
1315 add_proto qw/uint32_t vpx_sub_pixel_avg_variance4x4/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1316   specialize qw/vpx_sub_pixel_avg_variance4x4 msa sse2 ssse3/;
1317
1318 if (vpx_config("CONFIG_VP9_HIGHBITDEPTH") eq "yes") {
1319   add_proto qw/unsigned int vpx_highbd_12_variance64x64/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1320   specialize qw/vpx_highbd_12_variance64x64 sse2/;
1321
1322   add_proto qw/unsigned int vpx_highbd_12_variance64x32/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1323   specialize qw/vpx_highbd_12_variance64x32 sse2/;
1324
1325   add_proto qw/unsigned int vpx_highbd_12_variance32x64/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1326   specialize qw/vpx_highbd_12_variance32x64 sse2/;
1327
1328   add_proto qw/unsigned int vpx_highbd_12_variance32x32/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1329   specialize qw/vpx_highbd_12_variance32x32 sse2/;
1330
1331   add_proto qw/unsigned int vpx_highbd_12_variance32x16/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1332   specialize qw/vpx_highbd_12_variance32x16 sse2/;
1333
1334   add_proto qw/unsigned int vpx_highbd_12_variance16x32/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1335   specialize qw/vpx_highbd_12_variance16x32 sse2/;
1336
1337   add_proto qw/unsigned int vpx_highbd_12_variance16x16/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1338   specialize qw/vpx_highbd_12_variance16x16 sse2/;
1339
1340   add_proto qw/unsigned int vpx_highbd_12_variance16x8/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1341   specialize qw/vpx_highbd_12_variance16x8 sse2/;
1342
1343   add_proto qw/unsigned int vpx_highbd_12_variance8x16/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1344   specialize qw/vpx_highbd_12_variance8x16 sse2/;
1345
1346   add_proto qw/unsigned int vpx_highbd_12_variance8x8/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1347   specialize qw/vpx_highbd_12_variance8x8 sse2/;
1348
1349   add_proto qw/unsigned int vpx_highbd_12_variance8x4/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1350   add_proto qw/unsigned int vpx_highbd_12_variance4x8/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1351   add_proto qw/unsigned int vpx_highbd_12_variance4x4/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1352
1353   add_proto qw/unsigned int vpx_highbd_10_variance64x64/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1354   specialize qw/vpx_highbd_10_variance64x64 sse2/;
1355
1356   add_proto qw/unsigned int vpx_highbd_10_variance64x32/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1357   specialize qw/vpx_highbd_10_variance64x32 sse2/;
1358
1359   add_proto qw/unsigned int vpx_highbd_10_variance32x64/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1360   specialize qw/vpx_highbd_10_variance32x64 sse2/;
1361
1362   add_proto qw/unsigned int vpx_highbd_10_variance32x32/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1363   specialize qw/vpx_highbd_10_variance32x32 sse2/;
1364
1365   add_proto qw/unsigned int vpx_highbd_10_variance32x16/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1366   specialize qw/vpx_highbd_10_variance32x16 sse2/;
1367
1368   add_proto qw/unsigned int vpx_highbd_10_variance16x32/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1369   specialize qw/vpx_highbd_10_variance16x32 sse2/;
1370
1371   add_proto qw/unsigned int vpx_highbd_10_variance16x16/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1372   specialize qw/vpx_highbd_10_variance16x16 sse2/;
1373
1374   add_proto qw/unsigned int vpx_highbd_10_variance16x8/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1375   specialize qw/vpx_highbd_10_variance16x8 sse2/;
1376
1377   add_proto qw/unsigned int vpx_highbd_10_variance8x16/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1378   specialize qw/vpx_highbd_10_variance8x16 sse2/;
1379
1380   add_proto qw/unsigned int vpx_highbd_10_variance8x8/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1381   specialize qw/vpx_highbd_10_variance8x8 sse2/;
1382
1383   add_proto qw/unsigned int vpx_highbd_10_variance8x4/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1384   add_proto qw/unsigned int vpx_highbd_10_variance4x8/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1385   add_proto qw/unsigned int vpx_highbd_10_variance4x4/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1386
1387   add_proto qw/unsigned int vpx_highbd_8_variance64x64/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1388   specialize qw/vpx_highbd_8_variance64x64 sse2/;
1389
1390   add_proto qw/unsigned int vpx_highbd_8_variance64x32/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1391   specialize qw/vpx_highbd_8_variance64x32 sse2/;
1392
1393   add_proto qw/unsigned int vpx_highbd_8_variance32x64/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1394   specialize qw/vpx_highbd_8_variance32x64 sse2/;
1395
1396   add_proto qw/unsigned int vpx_highbd_8_variance32x32/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1397   specialize qw/vpx_highbd_8_variance32x32 sse2/;
1398
1399   add_proto qw/unsigned int vpx_highbd_8_variance32x16/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1400   specialize qw/vpx_highbd_8_variance32x16 sse2/;
1401
1402   add_proto qw/unsigned int vpx_highbd_8_variance16x32/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1403   specialize qw/vpx_highbd_8_variance16x32 sse2/;
1404
1405   add_proto qw/unsigned int vpx_highbd_8_variance16x16/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1406   specialize qw/vpx_highbd_8_variance16x16 sse2/;
1407
1408   add_proto qw/unsigned int vpx_highbd_8_variance16x8/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1409   specialize qw/vpx_highbd_8_variance16x8 sse2/;
1410
1411   add_proto qw/unsigned int vpx_highbd_8_variance8x16/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1412   specialize qw/vpx_highbd_8_variance8x16 sse2/;
1413
1414   add_proto qw/unsigned int vpx_highbd_8_variance8x8/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1415   specialize qw/vpx_highbd_8_variance8x8 sse2/;
1416
1417   add_proto qw/unsigned int vpx_highbd_8_variance8x4/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1418   add_proto qw/unsigned int vpx_highbd_8_variance4x8/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1419   add_proto qw/unsigned int vpx_highbd_8_variance4x4/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse";
1420
1421   add_proto qw/void vpx_highbd_8_get16x16var/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse, int *sum";
1422   add_proto qw/void vpx_highbd_8_get8x8var/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse, int *sum";
1423
1424   add_proto qw/void vpx_highbd_10_get16x16var/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse, int *sum";
1425   add_proto qw/void vpx_highbd_10_get8x8var/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse, int *sum";
1426
1427   add_proto qw/void vpx_highbd_12_get16x16var/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse, int *sum";
1428   add_proto qw/void vpx_highbd_12_get8x8var/, "const uint8_t *src_ptr, int source_stride, const uint8_t *ref_ptr, int ref_stride, unsigned int *sse, int *sum";
1429
1430   add_proto qw/unsigned int vpx_highbd_8_mse16x16/, "const uint8_t *src_ptr, int  source_stride, const uint8_t *ref_ptr, int  recon_stride, unsigned int *sse";
1431   specialize qw/vpx_highbd_8_mse16x16 sse2/;
1432
1433   add_proto qw/unsigned int vpx_highbd_8_mse16x8/, "const uint8_t *src_ptr, int  source_stride, const uint8_t *ref_ptr, int  recon_stride, unsigned int *sse";
1434   add_proto qw/unsigned int vpx_highbd_8_mse8x16/, "const uint8_t *src_ptr, int  source_stride, const uint8_t *ref_ptr, int  recon_stride, unsigned int *sse";
1435   add_proto qw/unsigned int vpx_highbd_8_mse8x8/, "const uint8_t *src_ptr, int  source_stride, const uint8_t *ref_ptr, int  recon_stride, unsigned int *sse";
1436   specialize qw/vpx_highbd_8_mse8x8 sse2/;
1437
1438   add_proto qw/unsigned int vpx_highbd_10_mse16x16/, "const uint8_t *src_ptr, int  source_stride, const uint8_t *ref_ptr, int  recon_stride, unsigned int *sse";
1439   specialize qw/vpx_highbd_10_mse16x16 sse2/;
1440
1441   add_proto qw/unsigned int vpx_highbd_10_mse16x8/, "const uint8_t *src_ptr, int  source_stride, const uint8_t *ref_ptr, int  recon_stride, unsigned int *sse";
1442   add_proto qw/unsigned int vpx_highbd_10_mse8x16/, "const uint8_t *src_ptr, int  source_stride, const uint8_t *ref_ptr, int  recon_stride, unsigned int *sse";
1443   add_proto qw/unsigned int vpx_highbd_10_mse8x8/, "const uint8_t *src_ptr, int  source_stride, const uint8_t *ref_ptr, int  recon_stride, unsigned int *sse";
1444   specialize qw/vpx_highbd_10_mse8x8 sse2/;
1445
1446   add_proto qw/unsigned int vpx_highbd_12_mse16x16/, "const uint8_t *src_ptr, int  source_stride, const uint8_t *ref_ptr, int  recon_stride, unsigned int *sse";
1447   specialize qw/vpx_highbd_12_mse16x16 sse2/;
1448
1449   add_proto qw/unsigned int vpx_highbd_12_mse16x8/, "const uint8_t *src_ptr, int  source_stride, const uint8_t *ref_ptr, int  recon_stride, unsigned int *sse";
1450   add_proto qw/unsigned int vpx_highbd_12_mse8x16/, "const uint8_t *src_ptr, int  source_stride, const uint8_t *ref_ptr, int  recon_stride, unsigned int *sse";
1451   add_proto qw/unsigned int vpx_highbd_12_mse8x8/, "const uint8_t *src_ptr, int  source_stride, const uint8_t *ref_ptr, int  recon_stride, unsigned int *sse";
1452   specialize qw/vpx_highbd_12_mse8x8 sse2/;
1453
1454   add_proto qw/void vpx_highbd_comp_avg_pred/, "uint16_t *comp_pred, const uint8_t *pred8, int width, int height, const uint8_t *ref8, int ref_stride";
1455
1456   #
1457   # Subpixel Variance
1458   #
1459   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_variance64x64/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1460   specialize qw/vpx_highbd_12_sub_pixel_variance64x64 sse2/;
1461
1462   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_variance64x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1463   specialize qw/vpx_highbd_12_sub_pixel_variance64x32 sse2/;
1464
1465   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_variance32x64/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1466   specialize qw/vpx_highbd_12_sub_pixel_variance32x64 sse2/;
1467
1468   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_variance32x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1469   specialize qw/vpx_highbd_12_sub_pixel_variance32x32 sse2/;
1470
1471   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_variance32x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1472   specialize qw/vpx_highbd_12_sub_pixel_variance32x16 sse2/;
1473
1474   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_variance16x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1475   specialize qw/vpx_highbd_12_sub_pixel_variance16x32 sse2/;
1476
1477   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_variance16x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1478   specialize qw/vpx_highbd_12_sub_pixel_variance16x16 sse2/;
1479
1480   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_variance16x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1481   specialize qw/vpx_highbd_12_sub_pixel_variance16x8 sse2/;
1482
1483   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_variance8x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1484   specialize qw/vpx_highbd_12_sub_pixel_variance8x16 sse2/;
1485
1486   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_variance8x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1487   specialize qw/vpx_highbd_12_sub_pixel_variance8x8 sse2/;
1488
1489   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_variance8x4/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1490   specialize qw/vpx_highbd_12_sub_pixel_variance8x4 sse2/;
1491
1492   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_variance4x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1493   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_variance4x4/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1494
1495   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_variance64x64/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1496   specialize qw/vpx_highbd_10_sub_pixel_variance64x64 sse2/;
1497
1498   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_variance64x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1499   specialize qw/vpx_highbd_10_sub_pixel_variance64x32 sse2/;
1500
1501   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_variance32x64/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1502   specialize qw/vpx_highbd_10_sub_pixel_variance32x64 sse2/;
1503
1504   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_variance32x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1505   specialize qw/vpx_highbd_10_sub_pixel_variance32x32 sse2/;
1506
1507   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_variance32x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1508   specialize qw/vpx_highbd_10_sub_pixel_variance32x16 sse2/;
1509
1510   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_variance16x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1511   specialize qw/vpx_highbd_10_sub_pixel_variance16x32 sse2/;
1512
1513   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_variance16x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1514   specialize qw/vpx_highbd_10_sub_pixel_variance16x16 sse2/;
1515
1516   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_variance16x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1517   specialize qw/vpx_highbd_10_sub_pixel_variance16x8 sse2/;
1518
1519   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_variance8x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1520   specialize qw/vpx_highbd_10_sub_pixel_variance8x16 sse2/;
1521
1522   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_variance8x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1523   specialize qw/vpx_highbd_10_sub_pixel_variance8x8 sse2/;
1524
1525   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_variance8x4/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1526   specialize qw/vpx_highbd_10_sub_pixel_variance8x4 sse2/;
1527
1528   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_variance4x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1529   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_variance4x4/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1530
1531   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_variance64x64/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1532   specialize qw/vpx_highbd_8_sub_pixel_variance64x64 sse2/;
1533
1534   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_variance64x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1535   specialize qw/vpx_highbd_8_sub_pixel_variance64x32 sse2/;
1536
1537   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_variance32x64/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1538   specialize qw/vpx_highbd_8_sub_pixel_variance32x64 sse2/;
1539
1540   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_variance32x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1541   specialize qw/vpx_highbd_8_sub_pixel_variance32x32 sse2/;
1542
1543   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_variance32x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1544   specialize qw/vpx_highbd_8_sub_pixel_variance32x16 sse2/;
1545
1546   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_variance16x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1547   specialize qw/vpx_highbd_8_sub_pixel_variance16x32 sse2/;
1548
1549   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_variance16x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1550   specialize qw/vpx_highbd_8_sub_pixel_variance16x16 sse2/;
1551
1552   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_variance16x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1553   specialize qw/vpx_highbd_8_sub_pixel_variance16x8 sse2/;
1554
1555   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_variance8x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1556   specialize qw/vpx_highbd_8_sub_pixel_variance8x16 sse2/;
1557
1558   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_variance8x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1559   specialize qw/vpx_highbd_8_sub_pixel_variance8x8 sse2/;
1560
1561   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_variance8x4/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1562   specialize qw/vpx_highbd_8_sub_pixel_variance8x4 sse2/;
1563
1564   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_variance4x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1565   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_variance4x4/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse";
1566
1567   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_avg_variance64x64/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1568   specialize qw/vpx_highbd_12_sub_pixel_avg_variance64x64 sse2/;
1569
1570   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_avg_variance64x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1571   specialize qw/vpx_highbd_12_sub_pixel_avg_variance64x32 sse2/;
1572
1573   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_avg_variance32x64/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1574   specialize qw/vpx_highbd_12_sub_pixel_avg_variance32x64 sse2/;
1575
1576   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_avg_variance32x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1577   specialize qw/vpx_highbd_12_sub_pixel_avg_variance32x32 sse2/;
1578
1579   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_avg_variance32x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1580   specialize qw/vpx_highbd_12_sub_pixel_avg_variance32x16 sse2/;
1581
1582   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_avg_variance16x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1583   specialize qw/vpx_highbd_12_sub_pixel_avg_variance16x32 sse2/;
1584
1585   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_avg_variance16x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1586   specialize qw/vpx_highbd_12_sub_pixel_avg_variance16x16 sse2/;
1587
1588   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_avg_variance16x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1589   specialize qw/vpx_highbd_12_sub_pixel_avg_variance16x8 sse2/;
1590
1591   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_avg_variance8x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1592   specialize qw/vpx_highbd_12_sub_pixel_avg_variance8x16 sse2/;
1593
1594   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_avg_variance8x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1595   specialize qw/vpx_highbd_12_sub_pixel_avg_variance8x8 sse2/;
1596
1597   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_avg_variance8x4/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1598   specialize qw/vpx_highbd_12_sub_pixel_avg_variance8x4 sse2/;
1599
1600   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_avg_variance4x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1601   add_proto qw/uint32_t vpx_highbd_12_sub_pixel_avg_variance4x4/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1602
1603   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_avg_variance64x64/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1604   specialize qw/vpx_highbd_10_sub_pixel_avg_variance64x64 sse2/;
1605
1606   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_avg_variance64x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1607   specialize qw/vpx_highbd_10_sub_pixel_avg_variance64x32 sse2/;
1608
1609   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_avg_variance32x64/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1610   specialize qw/vpx_highbd_10_sub_pixel_avg_variance32x64 sse2/;
1611
1612   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_avg_variance32x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1613   specialize qw/vpx_highbd_10_sub_pixel_avg_variance32x32 sse2/;
1614
1615   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_avg_variance32x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1616   specialize qw/vpx_highbd_10_sub_pixel_avg_variance32x16 sse2/;
1617
1618   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_avg_variance16x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1619   specialize qw/vpx_highbd_10_sub_pixel_avg_variance16x32 sse2/;
1620
1621   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_avg_variance16x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1622   specialize qw/vpx_highbd_10_sub_pixel_avg_variance16x16 sse2/;
1623
1624   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_avg_variance16x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1625   specialize qw/vpx_highbd_10_sub_pixel_avg_variance16x8 sse2/;
1626
1627   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_avg_variance8x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1628   specialize qw/vpx_highbd_10_sub_pixel_avg_variance8x16 sse2/;
1629
1630   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_avg_variance8x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1631   specialize qw/vpx_highbd_10_sub_pixel_avg_variance8x8 sse2/;
1632
1633   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_avg_variance8x4/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1634   specialize qw/vpx_highbd_10_sub_pixel_avg_variance8x4 sse2/;
1635
1636   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_avg_variance4x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1637   add_proto qw/uint32_t vpx_highbd_10_sub_pixel_avg_variance4x4/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1638
1639   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_avg_variance64x64/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1640   specialize qw/vpx_highbd_8_sub_pixel_avg_variance64x64 sse2/;
1641
1642   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_avg_variance64x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1643   specialize qw/vpx_highbd_8_sub_pixel_avg_variance64x32 sse2/;
1644
1645   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_avg_variance32x64/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1646   specialize qw/vpx_highbd_8_sub_pixel_avg_variance32x64 sse2/;
1647
1648   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_avg_variance32x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1649   specialize qw/vpx_highbd_8_sub_pixel_avg_variance32x32 sse2/;
1650
1651   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_avg_variance32x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1652   specialize qw/vpx_highbd_8_sub_pixel_avg_variance32x16 sse2/;
1653
1654   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_avg_variance16x32/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1655   specialize qw/vpx_highbd_8_sub_pixel_avg_variance16x32 sse2/;
1656
1657   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_avg_variance16x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1658   specialize qw/vpx_highbd_8_sub_pixel_avg_variance16x16 sse2/;
1659
1660   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_avg_variance16x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1661   specialize qw/vpx_highbd_8_sub_pixel_avg_variance16x8 sse2/;
1662
1663   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_avg_variance8x16/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1664   specialize qw/vpx_highbd_8_sub_pixel_avg_variance8x16 sse2/;
1665
1666   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_avg_variance8x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1667   specialize qw/vpx_highbd_8_sub_pixel_avg_variance8x8 sse2/;
1668
1669   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_avg_variance8x4/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1670   specialize qw/vpx_highbd_8_sub_pixel_avg_variance8x4 sse2/;
1671
1672   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_avg_variance4x8/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1673   add_proto qw/uint32_t vpx_highbd_8_sub_pixel_avg_variance4x4/, "const uint8_t *src_ptr, int source_stride, int xoffset, int  yoffset, const uint8_t *ref_ptr, int ref_stride, uint32_t *sse, const uint8_t *second_pred";
1674
1675 }  # CONFIG_VP9_HIGHBITDEPTH
1676
1677 #
1678 # Post Processing
1679 #
1680 if (vpx_config("CONFIG_POSTPROC") eq "yes" || vpx_config("CONFIG_VP9_POSTPROC") eq "yes") {
1681     add_proto qw/void vpx_plane_add_noise/, "uint8_t *start, const int8_t *noise, int blackclamp, int whiteclamp, int width, int height, int pitch";
1682     specialize qw/vpx_plane_add_noise sse2 msa/;
1683
1684     add_proto qw/void vpx_mbpost_proc_down/, "unsigned char *dst, int pitch, int rows, int cols,int flimit";
1685     specialize qw/vpx_mbpost_proc_down sse2 neon msa/;
1686
1687     add_proto qw/void vpx_mbpost_proc_across_ip/, "unsigned char *dst, int pitch, int rows, int cols,int flimit";
1688     specialize qw/vpx_mbpost_proc_across_ip sse2 neon msa/;
1689
1690     add_proto qw/void vpx_post_proc_down_and_across_mb_row/, "unsigned char *src, unsigned char *dst, int src_pitch, int dst_pitch, int cols, unsigned char *flimits, int size";
1691     specialize qw/vpx_post_proc_down_and_across_mb_row sse2 neon msa/;
1692
1693 }
1694
1695 }  # CONFIG_ENCODERS || CONFIG_POSTPROC || CONFIG_VP9_POSTPROC
1696
1697 1;