xref: /aosp_15_r20/external/libdav1d/src/x86/mc.h (revision c09093415860a1c2373dacd84c4fde00c507cdfd)
1*c0909341SAndroid Build Coastguard Worker /*
2*c0909341SAndroid Build Coastguard Worker  * Copyright © 2018-2021, VideoLAN and dav1d authors
3*c0909341SAndroid Build Coastguard Worker  * Copyright © 2018-2021, Two Orioles, LLC
4*c0909341SAndroid Build Coastguard Worker  * All rights reserved.
5*c0909341SAndroid Build Coastguard Worker  *
6*c0909341SAndroid Build Coastguard Worker  * Redistribution and use in source and binary forms, with or without
7*c0909341SAndroid Build Coastguard Worker  * modification, are permitted provided that the following conditions are met:
8*c0909341SAndroid Build Coastguard Worker  *
9*c0909341SAndroid Build Coastguard Worker  * 1. Redistributions of source code must retain the above copyright notice, this
10*c0909341SAndroid Build Coastguard Worker  *    list of conditions and the following disclaimer.
11*c0909341SAndroid Build Coastguard Worker  *
12*c0909341SAndroid Build Coastguard Worker  * 2. Redistributions in binary form must reproduce the above copyright notice,
13*c0909341SAndroid Build Coastguard Worker  *    this list of conditions and the following disclaimer in the documentation
14*c0909341SAndroid Build Coastguard Worker  *    and/or other materials provided with the distribution.
15*c0909341SAndroid Build Coastguard Worker  *
16*c0909341SAndroid Build Coastguard Worker  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
17*c0909341SAndroid Build Coastguard Worker  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18*c0909341SAndroid Build Coastguard Worker  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
19*c0909341SAndroid Build Coastguard Worker  * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
20*c0909341SAndroid Build Coastguard Worker  * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
21*c0909341SAndroid Build Coastguard Worker  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
22*c0909341SAndroid Build Coastguard Worker  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
23*c0909341SAndroid Build Coastguard Worker  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24*c0909341SAndroid Build Coastguard Worker  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
25*c0909341SAndroid Build Coastguard Worker  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26*c0909341SAndroid Build Coastguard Worker  */
27*c0909341SAndroid Build Coastguard Worker 
28*c0909341SAndroid Build Coastguard Worker #include "src/cpu.h"
29*c0909341SAndroid Build Coastguard Worker #include "src/mc.h"
30*c0909341SAndroid Build Coastguard Worker 
31*c0909341SAndroid Build Coastguard Worker #define decl_fn(type, name) \
32*c0909341SAndroid Build Coastguard Worker     decl_##type##_fn(BF(name, ssse3)); \
33*c0909341SAndroid Build Coastguard Worker     decl_##type##_fn(BF(name, avx2)); \
34*c0909341SAndroid Build Coastguard Worker     decl_##type##_fn(BF(name, avx512icl));
35*c0909341SAndroid Build Coastguard Worker #define init_mc_fn(type, name, suffix) \
36*c0909341SAndroid Build Coastguard Worker     c->mc[type] = BF(dav1d_put_##name, suffix)
37*c0909341SAndroid Build Coastguard Worker #define init_mct_fn(type, name, suffix) \
38*c0909341SAndroid Build Coastguard Worker     c->mct[type] = BF(dav1d_prep_##name, suffix)
39*c0909341SAndroid Build Coastguard Worker #define init_mc_scaled_fn(type, name, suffix) \
40*c0909341SAndroid Build Coastguard Worker     c->mc_scaled[type] = BF(dav1d_put_##name, suffix)
41*c0909341SAndroid Build Coastguard Worker #define init_mct_scaled_fn(type, name, suffix) \
42*c0909341SAndroid Build Coastguard Worker     c->mct_scaled[type] = BF(dav1d_prep_##name, suffix)
43*c0909341SAndroid Build Coastguard Worker 
44*c0909341SAndroid Build Coastguard Worker decl_fn(mc, dav1d_put_8tap_regular);
45*c0909341SAndroid Build Coastguard Worker decl_fn(mc, dav1d_put_8tap_regular_smooth);
46*c0909341SAndroid Build Coastguard Worker decl_fn(mc, dav1d_put_8tap_regular_sharp);
47*c0909341SAndroid Build Coastguard Worker decl_fn(mc, dav1d_put_8tap_smooth);
48*c0909341SAndroid Build Coastguard Worker decl_fn(mc, dav1d_put_8tap_smooth_regular);
49*c0909341SAndroid Build Coastguard Worker decl_fn(mc, dav1d_put_8tap_smooth_sharp);
50*c0909341SAndroid Build Coastguard Worker decl_fn(mc, dav1d_put_8tap_sharp);
51*c0909341SAndroid Build Coastguard Worker decl_fn(mc, dav1d_put_8tap_sharp_regular);
52*c0909341SAndroid Build Coastguard Worker decl_fn(mc, dav1d_put_8tap_sharp_smooth);
53*c0909341SAndroid Build Coastguard Worker decl_fn(mc, dav1d_put_bilin);
54*c0909341SAndroid Build Coastguard Worker 
55*c0909341SAndroid Build Coastguard Worker decl_fn(mct, dav1d_prep_8tap_regular);
56*c0909341SAndroid Build Coastguard Worker decl_fn(mct, dav1d_prep_8tap_regular_smooth);
57*c0909341SAndroid Build Coastguard Worker decl_fn(mct, dav1d_prep_8tap_regular_sharp);
58*c0909341SAndroid Build Coastguard Worker decl_fn(mct, dav1d_prep_8tap_smooth);
59*c0909341SAndroid Build Coastguard Worker decl_fn(mct, dav1d_prep_8tap_smooth_regular);
60*c0909341SAndroid Build Coastguard Worker decl_fn(mct, dav1d_prep_8tap_smooth_sharp);
61*c0909341SAndroid Build Coastguard Worker decl_fn(mct, dav1d_prep_8tap_sharp);
62*c0909341SAndroid Build Coastguard Worker decl_fn(mct, dav1d_prep_8tap_sharp_regular);
63*c0909341SAndroid Build Coastguard Worker decl_fn(mct, dav1d_prep_8tap_sharp_smooth);
64*c0909341SAndroid Build Coastguard Worker decl_fn(mct, dav1d_prep_bilin);
65*c0909341SAndroid Build Coastguard Worker 
66*c0909341SAndroid Build Coastguard Worker decl_fn(mc_scaled, dav1d_put_8tap_scaled_regular);
67*c0909341SAndroid Build Coastguard Worker decl_fn(mc_scaled, dav1d_put_8tap_scaled_regular_smooth);
68*c0909341SAndroid Build Coastguard Worker decl_fn(mc_scaled, dav1d_put_8tap_scaled_regular_sharp);
69*c0909341SAndroid Build Coastguard Worker decl_fn(mc_scaled, dav1d_put_8tap_scaled_smooth);
70*c0909341SAndroid Build Coastguard Worker decl_fn(mc_scaled, dav1d_put_8tap_scaled_smooth_regular);
71*c0909341SAndroid Build Coastguard Worker decl_fn(mc_scaled, dav1d_put_8tap_scaled_smooth_sharp);
72*c0909341SAndroid Build Coastguard Worker decl_fn(mc_scaled, dav1d_put_8tap_scaled_sharp);
73*c0909341SAndroid Build Coastguard Worker decl_fn(mc_scaled, dav1d_put_8tap_scaled_sharp_regular);
74*c0909341SAndroid Build Coastguard Worker decl_fn(mc_scaled, dav1d_put_8tap_scaled_sharp_smooth);
75*c0909341SAndroid Build Coastguard Worker decl_fn(mc_scaled, dav1d_put_bilin_scaled);
76*c0909341SAndroid Build Coastguard Worker 
77*c0909341SAndroid Build Coastguard Worker decl_fn(mct_scaled, dav1d_prep_8tap_scaled_regular);
78*c0909341SAndroid Build Coastguard Worker decl_fn(mct_scaled, dav1d_prep_8tap_scaled_regular_smooth);
79*c0909341SAndroid Build Coastguard Worker decl_fn(mct_scaled, dav1d_prep_8tap_scaled_regular_sharp);
80*c0909341SAndroid Build Coastguard Worker decl_fn(mct_scaled, dav1d_prep_8tap_scaled_smooth);
81*c0909341SAndroid Build Coastguard Worker decl_fn(mct_scaled, dav1d_prep_8tap_scaled_smooth_regular);
82*c0909341SAndroid Build Coastguard Worker decl_fn(mct_scaled, dav1d_prep_8tap_scaled_smooth_sharp);
83*c0909341SAndroid Build Coastguard Worker decl_fn(mct_scaled, dav1d_prep_8tap_scaled_sharp);
84*c0909341SAndroid Build Coastguard Worker decl_fn(mct_scaled, dav1d_prep_8tap_scaled_sharp_regular);
85*c0909341SAndroid Build Coastguard Worker decl_fn(mct_scaled, dav1d_prep_8tap_scaled_sharp_smooth);
86*c0909341SAndroid Build Coastguard Worker decl_fn(mct_scaled, dav1d_prep_bilin_scaled);
87*c0909341SAndroid Build Coastguard Worker 
88*c0909341SAndroid Build Coastguard Worker decl_fn(avg, dav1d_avg);
89*c0909341SAndroid Build Coastguard Worker decl_fn(w_avg, dav1d_w_avg);
90*c0909341SAndroid Build Coastguard Worker decl_fn(mask, dav1d_mask);
91*c0909341SAndroid Build Coastguard Worker decl_fn(w_mask, dav1d_w_mask_420);
92*c0909341SAndroid Build Coastguard Worker decl_fn(w_mask, dav1d_w_mask_422);
93*c0909341SAndroid Build Coastguard Worker decl_fn(w_mask, dav1d_w_mask_444);
94*c0909341SAndroid Build Coastguard Worker decl_fn(blend, dav1d_blend);
95*c0909341SAndroid Build Coastguard Worker decl_fn(blend_dir, dav1d_blend_v);
96*c0909341SAndroid Build Coastguard Worker decl_fn(blend_dir, dav1d_blend_h);
97*c0909341SAndroid Build Coastguard Worker 
98*c0909341SAndroid Build Coastguard Worker decl_fn(warp8x8, dav1d_warp_affine_8x8);
99*c0909341SAndroid Build Coastguard Worker decl_warp8x8_fn(BF(dav1d_warp_affine_8x8, sse4));
100*c0909341SAndroid Build Coastguard Worker decl_fn(warp8x8t, dav1d_warp_affine_8x8t);
101*c0909341SAndroid Build Coastguard Worker decl_warp8x8t_fn(BF(dav1d_warp_affine_8x8t, sse4));
102*c0909341SAndroid Build Coastguard Worker 
103*c0909341SAndroid Build Coastguard Worker decl_fn(emu_edge, dav1d_emu_edge);
104*c0909341SAndroid Build Coastguard Worker 
105*c0909341SAndroid Build Coastguard Worker decl_fn(resize, dav1d_resize);
106*c0909341SAndroid Build Coastguard Worker 
mc_dsp_init_x86(Dav1dMCDSPContext * const c)107*c0909341SAndroid Build Coastguard Worker static ALWAYS_INLINE void mc_dsp_init_x86(Dav1dMCDSPContext *const c) {
108*c0909341SAndroid Build Coastguard Worker     const unsigned flags = dav1d_get_cpu_flags();
109*c0909341SAndroid Build Coastguard Worker 
110*c0909341SAndroid Build Coastguard Worker     if(!(flags & DAV1D_X86_CPU_FLAG_SSSE3))
111*c0909341SAndroid Build Coastguard Worker         return;
112*c0909341SAndroid Build Coastguard Worker 
113*c0909341SAndroid Build Coastguard Worker     init_mc_fn(FILTER_2D_8TAP_REGULAR,        8tap_regular,        ssse3);
114*c0909341SAndroid Build Coastguard Worker     init_mc_fn(FILTER_2D_8TAP_REGULAR_SMOOTH, 8tap_regular_smooth, ssse3);
115*c0909341SAndroid Build Coastguard Worker     init_mc_fn(FILTER_2D_8TAP_REGULAR_SHARP,  8tap_regular_sharp,  ssse3);
116*c0909341SAndroid Build Coastguard Worker     init_mc_fn(FILTER_2D_8TAP_SMOOTH_REGULAR, 8tap_smooth_regular, ssse3);
117*c0909341SAndroid Build Coastguard Worker     init_mc_fn(FILTER_2D_8TAP_SMOOTH,         8tap_smooth,         ssse3);
118*c0909341SAndroid Build Coastguard Worker     init_mc_fn(FILTER_2D_8TAP_SMOOTH_SHARP,   8tap_smooth_sharp,   ssse3);
119*c0909341SAndroid Build Coastguard Worker     init_mc_fn(FILTER_2D_8TAP_SHARP_REGULAR,  8tap_sharp_regular,  ssse3);
120*c0909341SAndroid Build Coastguard Worker     init_mc_fn(FILTER_2D_8TAP_SHARP_SMOOTH,   8tap_sharp_smooth,   ssse3);
121*c0909341SAndroid Build Coastguard Worker     init_mc_fn(FILTER_2D_8TAP_SHARP,          8tap_sharp,          ssse3);
122*c0909341SAndroid Build Coastguard Worker     init_mc_fn(FILTER_2D_BILINEAR,            bilin,               ssse3);
123*c0909341SAndroid Build Coastguard Worker 
124*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_REGULAR,        8tap_regular,        ssse3);
125*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_REGULAR_SMOOTH, 8tap_regular_smooth, ssse3);
126*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_REGULAR_SHARP,  8tap_regular_sharp,  ssse3);
127*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_SMOOTH_REGULAR, 8tap_smooth_regular, ssse3);
128*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_SMOOTH,         8tap_smooth,         ssse3);
129*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_SMOOTH_SHARP,   8tap_smooth_sharp,   ssse3);
130*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_SHARP_REGULAR,  8tap_sharp_regular,  ssse3);
131*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_SHARP_SMOOTH,   8tap_sharp_smooth,   ssse3);
132*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_SHARP,          8tap_sharp,          ssse3);
133*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_BILINEAR,            bilin,               ssse3);
134*c0909341SAndroid Build Coastguard Worker 
135*c0909341SAndroid Build Coastguard Worker     init_mc_scaled_fn(FILTER_2D_8TAP_REGULAR,        8tap_scaled_regular,        ssse3);
136*c0909341SAndroid Build Coastguard Worker     init_mc_scaled_fn(FILTER_2D_8TAP_REGULAR_SMOOTH, 8tap_scaled_regular_smooth, ssse3);
137*c0909341SAndroid Build Coastguard Worker     init_mc_scaled_fn(FILTER_2D_8TAP_REGULAR_SHARP,  8tap_scaled_regular_sharp,  ssse3);
138*c0909341SAndroid Build Coastguard Worker     init_mc_scaled_fn(FILTER_2D_8TAP_SMOOTH_REGULAR, 8tap_scaled_smooth_regular, ssse3);
139*c0909341SAndroid Build Coastguard Worker     init_mc_scaled_fn(FILTER_2D_8TAP_SMOOTH,         8tap_scaled_smooth,         ssse3);
140*c0909341SAndroid Build Coastguard Worker     init_mc_scaled_fn(FILTER_2D_8TAP_SMOOTH_SHARP,   8tap_scaled_smooth_sharp,   ssse3);
141*c0909341SAndroid Build Coastguard Worker     init_mc_scaled_fn(FILTER_2D_8TAP_SHARP_REGULAR,  8tap_scaled_sharp_regular,  ssse3);
142*c0909341SAndroid Build Coastguard Worker     init_mc_scaled_fn(FILTER_2D_8TAP_SHARP_SMOOTH,   8tap_scaled_sharp_smooth,   ssse3);
143*c0909341SAndroid Build Coastguard Worker     init_mc_scaled_fn(FILTER_2D_8TAP_SHARP,          8tap_scaled_sharp,          ssse3);
144*c0909341SAndroid Build Coastguard Worker     init_mc_scaled_fn(FILTER_2D_BILINEAR,            bilin_scaled,               ssse3);
145*c0909341SAndroid Build Coastguard Worker 
146*c0909341SAndroid Build Coastguard Worker     init_mct_scaled_fn(FILTER_2D_8TAP_REGULAR,        8tap_scaled_regular,        ssse3);
147*c0909341SAndroid Build Coastguard Worker     init_mct_scaled_fn(FILTER_2D_8TAP_REGULAR_SMOOTH, 8tap_scaled_regular_smooth, ssse3);
148*c0909341SAndroid Build Coastguard Worker     init_mct_scaled_fn(FILTER_2D_8TAP_REGULAR_SHARP,  8tap_scaled_regular_sharp,  ssse3);
149*c0909341SAndroid Build Coastguard Worker     init_mct_scaled_fn(FILTER_2D_8TAP_SMOOTH_REGULAR, 8tap_scaled_smooth_regular, ssse3);
150*c0909341SAndroid Build Coastguard Worker     init_mct_scaled_fn(FILTER_2D_8TAP_SMOOTH,         8tap_scaled_smooth,         ssse3);
151*c0909341SAndroid Build Coastguard Worker     init_mct_scaled_fn(FILTER_2D_8TAP_SMOOTH_SHARP,   8tap_scaled_smooth_sharp,   ssse3);
152*c0909341SAndroid Build Coastguard Worker     init_mct_scaled_fn(FILTER_2D_8TAP_SHARP_REGULAR,  8tap_scaled_sharp_regular,  ssse3);
153*c0909341SAndroid Build Coastguard Worker     init_mct_scaled_fn(FILTER_2D_8TAP_SHARP_SMOOTH,   8tap_scaled_sharp_smooth,   ssse3);
154*c0909341SAndroid Build Coastguard Worker     init_mct_scaled_fn(FILTER_2D_8TAP_SHARP,          8tap_scaled_sharp,          ssse3);
155*c0909341SAndroid Build Coastguard Worker     init_mct_scaled_fn(FILTER_2D_BILINEAR,            bilin_scaled,               ssse3);
156*c0909341SAndroid Build Coastguard Worker 
157*c0909341SAndroid Build Coastguard Worker     c->avg = BF(dav1d_avg, ssse3);
158*c0909341SAndroid Build Coastguard Worker     c->w_avg = BF(dav1d_w_avg, ssse3);
159*c0909341SAndroid Build Coastguard Worker     c->mask = BF(dav1d_mask, ssse3);
160*c0909341SAndroid Build Coastguard Worker     c->w_mask[0] = BF(dav1d_w_mask_444, ssse3);
161*c0909341SAndroid Build Coastguard Worker     c->w_mask[1] = BF(dav1d_w_mask_422, ssse3);
162*c0909341SAndroid Build Coastguard Worker     c->w_mask[2] = BF(dav1d_w_mask_420, ssse3);
163*c0909341SAndroid Build Coastguard Worker     c->blend = BF(dav1d_blend, ssse3);
164*c0909341SAndroid Build Coastguard Worker     c->blend_v = BF(dav1d_blend_v, ssse3);
165*c0909341SAndroid Build Coastguard Worker     c->blend_h = BF(dav1d_blend_h, ssse3);
166*c0909341SAndroid Build Coastguard Worker     c->warp8x8  = BF(dav1d_warp_affine_8x8, ssse3);
167*c0909341SAndroid Build Coastguard Worker     c->warp8x8t = BF(dav1d_warp_affine_8x8t, ssse3);
168*c0909341SAndroid Build Coastguard Worker     c->emu_edge = BF(dav1d_emu_edge, ssse3);
169*c0909341SAndroid Build Coastguard Worker     c->resize = BF(dav1d_resize, ssse3);
170*c0909341SAndroid Build Coastguard Worker 
171*c0909341SAndroid Build Coastguard Worker     if(!(flags & DAV1D_X86_CPU_FLAG_SSE41))
172*c0909341SAndroid Build Coastguard Worker         return;
173*c0909341SAndroid Build Coastguard Worker 
174*c0909341SAndroid Build Coastguard Worker #if BITDEPTH == 8
175*c0909341SAndroid Build Coastguard Worker     c->warp8x8  = BF(dav1d_warp_affine_8x8, sse4);
176*c0909341SAndroid Build Coastguard Worker     c->warp8x8t = BF(dav1d_warp_affine_8x8t, sse4);
177*c0909341SAndroid Build Coastguard Worker #endif
178*c0909341SAndroid Build Coastguard Worker 
179*c0909341SAndroid Build Coastguard Worker #if ARCH_X86_64
180*c0909341SAndroid Build Coastguard Worker     if (!(flags & DAV1D_X86_CPU_FLAG_AVX2))
181*c0909341SAndroid Build Coastguard Worker         return;
182*c0909341SAndroid Build Coastguard Worker 
183*c0909341SAndroid Build Coastguard Worker     init_mc_fn(FILTER_2D_8TAP_REGULAR,        8tap_regular,        avx2);
184*c0909341SAndroid Build Coastguard Worker     init_mc_fn(FILTER_2D_8TAP_REGULAR_SMOOTH, 8tap_regular_smooth, avx2);
185*c0909341SAndroid Build Coastguard Worker     init_mc_fn(FILTER_2D_8TAP_REGULAR_SHARP,  8tap_regular_sharp,  avx2);
186*c0909341SAndroid Build Coastguard Worker     init_mc_fn(FILTER_2D_8TAP_SMOOTH_REGULAR, 8tap_smooth_regular, avx2);
187*c0909341SAndroid Build Coastguard Worker     init_mc_fn(FILTER_2D_8TAP_SMOOTH,         8tap_smooth,         avx2);
188*c0909341SAndroid Build Coastguard Worker     init_mc_fn(FILTER_2D_8TAP_SMOOTH_SHARP,   8tap_smooth_sharp,   avx2);
189*c0909341SAndroid Build Coastguard Worker     init_mc_fn(FILTER_2D_8TAP_SHARP_REGULAR,  8tap_sharp_regular,  avx2);
190*c0909341SAndroid Build Coastguard Worker     init_mc_fn(FILTER_2D_8TAP_SHARP_SMOOTH,   8tap_sharp_smooth,   avx2);
191*c0909341SAndroid Build Coastguard Worker     init_mc_fn(FILTER_2D_8TAP_SHARP,          8tap_sharp,          avx2);
192*c0909341SAndroid Build Coastguard Worker     init_mc_fn(FILTER_2D_BILINEAR,            bilin,               avx2);
193*c0909341SAndroid Build Coastguard Worker 
194*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_REGULAR,        8tap_regular,        avx2);
195*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_REGULAR_SMOOTH, 8tap_regular_smooth, avx2);
196*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_REGULAR_SHARP,  8tap_regular_sharp,  avx2);
197*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_SMOOTH_REGULAR, 8tap_smooth_regular, avx2);
198*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_SMOOTH,         8tap_smooth,         avx2);
199*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_SMOOTH_SHARP,   8tap_smooth_sharp,   avx2);
200*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_SHARP_REGULAR,  8tap_sharp_regular,  avx2);
201*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_SHARP_SMOOTH,   8tap_sharp_smooth,   avx2);
202*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_SHARP,          8tap_sharp,          avx2);
203*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_BILINEAR,            bilin,               avx2);
204*c0909341SAndroid Build Coastguard Worker 
205*c0909341SAndroid Build Coastguard Worker     init_mc_scaled_fn(FILTER_2D_8TAP_REGULAR,        8tap_scaled_regular,        avx2);
206*c0909341SAndroid Build Coastguard Worker     init_mc_scaled_fn(FILTER_2D_8TAP_REGULAR_SMOOTH, 8tap_scaled_regular_smooth, avx2);
207*c0909341SAndroid Build Coastguard Worker     init_mc_scaled_fn(FILTER_2D_8TAP_REGULAR_SHARP,  8tap_scaled_regular_sharp,  avx2);
208*c0909341SAndroid Build Coastguard Worker     init_mc_scaled_fn(FILTER_2D_8TAP_SMOOTH_REGULAR, 8tap_scaled_smooth_regular, avx2);
209*c0909341SAndroid Build Coastguard Worker     init_mc_scaled_fn(FILTER_2D_8TAP_SMOOTH,         8tap_scaled_smooth,         avx2);
210*c0909341SAndroid Build Coastguard Worker     init_mc_scaled_fn(FILTER_2D_8TAP_SMOOTH_SHARP,   8tap_scaled_smooth_sharp,   avx2);
211*c0909341SAndroid Build Coastguard Worker     init_mc_scaled_fn(FILTER_2D_8TAP_SHARP_REGULAR,  8tap_scaled_sharp_regular,  avx2);
212*c0909341SAndroid Build Coastguard Worker     init_mc_scaled_fn(FILTER_2D_8TAP_SHARP_SMOOTH,   8tap_scaled_sharp_smooth,   avx2);
213*c0909341SAndroid Build Coastguard Worker     init_mc_scaled_fn(FILTER_2D_8TAP_SHARP,          8tap_scaled_sharp,          avx2);
214*c0909341SAndroid Build Coastguard Worker     init_mc_scaled_fn(FILTER_2D_BILINEAR,            bilin_scaled,               avx2);
215*c0909341SAndroid Build Coastguard Worker 
216*c0909341SAndroid Build Coastguard Worker     init_mct_scaled_fn(FILTER_2D_8TAP_REGULAR,        8tap_scaled_regular,        avx2);
217*c0909341SAndroid Build Coastguard Worker     init_mct_scaled_fn(FILTER_2D_8TAP_REGULAR_SMOOTH, 8tap_scaled_regular_smooth, avx2);
218*c0909341SAndroid Build Coastguard Worker     init_mct_scaled_fn(FILTER_2D_8TAP_REGULAR_SHARP,  8tap_scaled_regular_sharp,  avx2);
219*c0909341SAndroid Build Coastguard Worker     init_mct_scaled_fn(FILTER_2D_8TAP_SMOOTH_REGULAR, 8tap_scaled_smooth_regular, avx2);
220*c0909341SAndroid Build Coastguard Worker     init_mct_scaled_fn(FILTER_2D_8TAP_SMOOTH,         8tap_scaled_smooth,         avx2);
221*c0909341SAndroid Build Coastguard Worker     init_mct_scaled_fn(FILTER_2D_8TAP_SMOOTH_SHARP,   8tap_scaled_smooth_sharp,   avx2);
222*c0909341SAndroid Build Coastguard Worker     init_mct_scaled_fn(FILTER_2D_8TAP_SHARP_REGULAR,  8tap_scaled_sharp_regular,  avx2);
223*c0909341SAndroid Build Coastguard Worker     init_mct_scaled_fn(FILTER_2D_8TAP_SHARP_SMOOTH,   8tap_scaled_sharp_smooth,   avx2);
224*c0909341SAndroid Build Coastguard Worker     init_mct_scaled_fn(FILTER_2D_8TAP_SHARP,          8tap_scaled_sharp,          avx2);
225*c0909341SAndroid Build Coastguard Worker     init_mct_scaled_fn(FILTER_2D_BILINEAR,            bilin_scaled,               avx2);
226*c0909341SAndroid Build Coastguard Worker 
227*c0909341SAndroid Build Coastguard Worker     c->avg = BF(dav1d_avg, avx2);
228*c0909341SAndroid Build Coastguard Worker     c->w_avg = BF(dav1d_w_avg, avx2);
229*c0909341SAndroid Build Coastguard Worker     c->mask = BF(dav1d_mask, avx2);
230*c0909341SAndroid Build Coastguard Worker     c->w_mask[0] = BF(dav1d_w_mask_444, avx2);
231*c0909341SAndroid Build Coastguard Worker     c->w_mask[1] = BF(dav1d_w_mask_422, avx2);
232*c0909341SAndroid Build Coastguard Worker     c->w_mask[2] = BF(dav1d_w_mask_420, avx2);
233*c0909341SAndroid Build Coastguard Worker     c->blend = BF(dav1d_blend, avx2);
234*c0909341SAndroid Build Coastguard Worker     c->blend_v = BF(dav1d_blend_v, avx2);
235*c0909341SAndroid Build Coastguard Worker     c->blend_h = BF(dav1d_blend_h, avx2);
236*c0909341SAndroid Build Coastguard Worker     c->warp8x8  = BF(dav1d_warp_affine_8x8, avx2);
237*c0909341SAndroid Build Coastguard Worker     c->warp8x8t = BF(dav1d_warp_affine_8x8t, avx2);
238*c0909341SAndroid Build Coastguard Worker     c->emu_edge = BF(dav1d_emu_edge, avx2);
239*c0909341SAndroid Build Coastguard Worker     c->resize = BF(dav1d_resize, avx2);
240*c0909341SAndroid Build Coastguard Worker 
241*c0909341SAndroid Build Coastguard Worker     if (!(flags & DAV1D_X86_CPU_FLAG_AVX512ICL))
242*c0909341SAndroid Build Coastguard Worker         return;
243*c0909341SAndroid Build Coastguard Worker 
244*c0909341SAndroid Build Coastguard Worker     init_mc_fn (FILTER_2D_8TAP_REGULAR,        8tap_regular,        avx512icl);
245*c0909341SAndroid Build Coastguard Worker     init_mc_fn (FILTER_2D_8TAP_REGULAR_SMOOTH, 8tap_regular_smooth, avx512icl);
246*c0909341SAndroid Build Coastguard Worker     init_mc_fn (FILTER_2D_8TAP_REGULAR_SHARP,  8tap_regular_sharp,  avx512icl);
247*c0909341SAndroid Build Coastguard Worker     init_mc_fn (FILTER_2D_8TAP_SMOOTH_REGULAR, 8tap_smooth_regular, avx512icl);
248*c0909341SAndroid Build Coastguard Worker     init_mc_fn (FILTER_2D_8TAP_SMOOTH,         8tap_smooth,         avx512icl);
249*c0909341SAndroid Build Coastguard Worker     init_mc_fn (FILTER_2D_8TAP_SMOOTH_SHARP,   8tap_smooth_sharp,   avx512icl);
250*c0909341SAndroid Build Coastguard Worker     init_mc_fn (FILTER_2D_8TAP_SHARP_REGULAR,  8tap_sharp_regular,  avx512icl);
251*c0909341SAndroid Build Coastguard Worker     init_mc_fn (FILTER_2D_8TAP_SHARP_SMOOTH,   8tap_sharp_smooth,   avx512icl);
252*c0909341SAndroid Build Coastguard Worker     init_mc_fn (FILTER_2D_8TAP_SHARP,          8tap_sharp,          avx512icl);
253*c0909341SAndroid Build Coastguard Worker     init_mc_fn (FILTER_2D_BILINEAR,            bilin,               avx512icl);
254*c0909341SAndroid Build Coastguard Worker 
255*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_REGULAR,        8tap_regular,        avx512icl);
256*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_REGULAR_SMOOTH, 8tap_regular_smooth, avx512icl);
257*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_REGULAR_SHARP,  8tap_regular_sharp,  avx512icl);
258*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_SMOOTH_REGULAR, 8tap_smooth_regular, avx512icl);
259*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_SMOOTH,         8tap_smooth,         avx512icl);
260*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_SMOOTH_SHARP,   8tap_smooth_sharp,   avx512icl);
261*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_SHARP_REGULAR,  8tap_sharp_regular,  avx512icl);
262*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_SHARP_SMOOTH,   8tap_sharp_smooth,   avx512icl);
263*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_8TAP_SHARP,          8tap_sharp,          avx512icl);
264*c0909341SAndroid Build Coastguard Worker     init_mct_fn(FILTER_2D_BILINEAR,            bilin,               avx512icl);
265*c0909341SAndroid Build Coastguard Worker 
266*c0909341SAndroid Build Coastguard Worker     c->avg = BF(dav1d_avg, avx512icl);
267*c0909341SAndroid Build Coastguard Worker     c->w_avg = BF(dav1d_w_avg, avx512icl);
268*c0909341SAndroid Build Coastguard Worker     c->mask = BF(dav1d_mask, avx512icl);
269*c0909341SAndroid Build Coastguard Worker     c->w_mask[0] = BF(dav1d_w_mask_444, avx512icl);
270*c0909341SAndroid Build Coastguard Worker     c->w_mask[1] = BF(dav1d_w_mask_422, avx512icl);
271*c0909341SAndroid Build Coastguard Worker     c->w_mask[2] = BF(dav1d_w_mask_420, avx512icl);
272*c0909341SAndroid Build Coastguard Worker     c->blend = BF(dav1d_blend, avx512icl);
273*c0909341SAndroid Build Coastguard Worker     c->blend_v = BF(dav1d_blend_v, avx512icl);
274*c0909341SAndroid Build Coastguard Worker     c->blend_h = BF(dav1d_blend_h, avx512icl);
275*c0909341SAndroid Build Coastguard Worker 
276*c0909341SAndroid Build Coastguard Worker     if (!(flags & DAV1D_X86_CPU_FLAG_SLOW_GATHER)) {
277*c0909341SAndroid Build Coastguard Worker         c->resize = BF(dav1d_resize, avx512icl);
278*c0909341SAndroid Build Coastguard Worker         c->warp8x8  = BF(dav1d_warp_affine_8x8, avx512icl);
279*c0909341SAndroid Build Coastguard Worker         c->warp8x8t = BF(dav1d_warp_affine_8x8t, avx512icl);
280*c0909341SAndroid Build Coastguard Worker     }
281*c0909341SAndroid Build Coastguard Worker #endif
282*c0909341SAndroid Build Coastguard Worker }
283