xref: /aosp_15_r20/external/libdav1d/src/wedge.c (revision c09093415860a1c2373dacd84c4fde00c507cdfd)
1*c0909341SAndroid Build Coastguard Worker /*
2*c0909341SAndroid Build Coastguard Worker  * Copyright © 2018, VideoLAN and dav1d authors
3*c0909341SAndroid Build Coastguard Worker  * Copyright © 2018, 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 "config.h"
29*c0909341SAndroid Build Coastguard Worker 
30*c0909341SAndroid Build Coastguard Worker #include <stdint.h>
31*c0909341SAndroid Build Coastguard Worker #include <string.h>
32*c0909341SAndroid Build Coastguard Worker 
33*c0909341SAndroid Build Coastguard Worker #include "common/intops.h"
34*c0909341SAndroid Build Coastguard Worker 
35*c0909341SAndroid Build Coastguard Worker #include "src/wedge.h"
36*c0909341SAndroid Build Coastguard Worker 
37*c0909341SAndroid Build Coastguard Worker enum WedgeDirectionType {
38*c0909341SAndroid Build Coastguard Worker     WEDGE_HORIZONTAL = 0,
39*c0909341SAndroid Build Coastguard Worker     WEDGE_VERTICAL = 1,
40*c0909341SAndroid Build Coastguard Worker     WEDGE_OBLIQUE27 = 2,
41*c0909341SAndroid Build Coastguard Worker     WEDGE_OBLIQUE63 = 3,
42*c0909341SAndroid Build Coastguard Worker     WEDGE_OBLIQUE117 = 4,
43*c0909341SAndroid Build Coastguard Worker     WEDGE_OBLIQUE153 = 5,
44*c0909341SAndroid Build Coastguard Worker     N_WEDGE_DIRECTIONS
45*c0909341SAndroid Build Coastguard Worker };
46*c0909341SAndroid Build Coastguard Worker 
47*c0909341SAndroid Build Coastguard Worker typedef struct {
48*c0909341SAndroid Build Coastguard Worker     uint8_t /* enum WedgeDirectionType */ direction;
49*c0909341SAndroid Build Coastguard Worker     uint8_t x_offset;
50*c0909341SAndroid Build Coastguard Worker     uint8_t y_offset;
51*c0909341SAndroid Build Coastguard Worker } wedge_code_type;
52*c0909341SAndroid Build Coastguard Worker 
53*c0909341SAndroid Build Coastguard Worker static const wedge_code_type wedge_codebook_16_hgtw[16] = {
54*c0909341SAndroid Build Coastguard Worker     { WEDGE_OBLIQUE27,  4, 4 }, { WEDGE_OBLIQUE63,  4, 4 },
55*c0909341SAndroid Build Coastguard Worker     { WEDGE_OBLIQUE117, 4, 4 }, { WEDGE_OBLIQUE153, 4, 4 },
56*c0909341SAndroid Build Coastguard Worker     { WEDGE_HORIZONTAL, 4, 2 }, { WEDGE_HORIZONTAL, 4, 4 },
57*c0909341SAndroid Build Coastguard Worker     { WEDGE_HORIZONTAL, 4, 6 }, { WEDGE_VERTICAL,   4, 4 },
58*c0909341SAndroid Build Coastguard Worker     { WEDGE_OBLIQUE27,  4, 2 }, { WEDGE_OBLIQUE27,  4, 6 },
59*c0909341SAndroid Build Coastguard Worker     { WEDGE_OBLIQUE153, 4, 2 }, { WEDGE_OBLIQUE153, 4, 6 },
60*c0909341SAndroid Build Coastguard Worker     { WEDGE_OBLIQUE63,  2, 4 }, { WEDGE_OBLIQUE63,  6, 4 },
61*c0909341SAndroid Build Coastguard Worker     { WEDGE_OBLIQUE117, 2, 4 }, { WEDGE_OBLIQUE117, 6, 4 },
62*c0909341SAndroid Build Coastguard Worker };
63*c0909341SAndroid Build Coastguard Worker 
64*c0909341SAndroid Build Coastguard Worker static const wedge_code_type wedge_codebook_16_hltw[16] = {
65*c0909341SAndroid Build Coastguard Worker     { WEDGE_OBLIQUE27,  4, 4 }, { WEDGE_OBLIQUE63,  4, 4 },
66*c0909341SAndroid Build Coastguard Worker     { WEDGE_OBLIQUE117, 4, 4 }, { WEDGE_OBLIQUE153, 4, 4 },
67*c0909341SAndroid Build Coastguard Worker     { WEDGE_VERTICAL,   2, 4 }, { WEDGE_VERTICAL,   4, 4 },
68*c0909341SAndroid Build Coastguard Worker     { WEDGE_VERTICAL,   6, 4 }, { WEDGE_HORIZONTAL, 4, 4 },
69*c0909341SAndroid Build Coastguard Worker     { WEDGE_OBLIQUE27,  4, 2 }, { WEDGE_OBLIQUE27,  4, 6 },
70*c0909341SAndroid Build Coastguard Worker     { WEDGE_OBLIQUE153, 4, 2 }, { WEDGE_OBLIQUE153, 4, 6 },
71*c0909341SAndroid Build Coastguard Worker     { WEDGE_OBLIQUE63,  2, 4 }, { WEDGE_OBLIQUE63,  6, 4 },
72*c0909341SAndroid Build Coastguard Worker     { WEDGE_OBLIQUE117, 2, 4 }, { WEDGE_OBLIQUE117, 6, 4 },
73*c0909341SAndroid Build Coastguard Worker };
74*c0909341SAndroid Build Coastguard Worker 
75*c0909341SAndroid Build Coastguard Worker static const wedge_code_type wedge_codebook_16_heqw[16] = {
76*c0909341SAndroid Build Coastguard Worker     { WEDGE_OBLIQUE27,  4, 4 }, { WEDGE_OBLIQUE63,  4, 4 },
77*c0909341SAndroid Build Coastguard Worker     { WEDGE_OBLIQUE117, 4, 4 }, { WEDGE_OBLIQUE153, 4, 4 },
78*c0909341SAndroid Build Coastguard Worker     { WEDGE_HORIZONTAL, 4, 2 }, { WEDGE_HORIZONTAL, 4, 6 },
79*c0909341SAndroid Build Coastguard Worker     { WEDGE_VERTICAL,   2, 4 }, { WEDGE_VERTICAL,   6, 4 },
80*c0909341SAndroid Build Coastguard Worker     { WEDGE_OBLIQUE27,  4, 2 }, { WEDGE_OBLIQUE27,  4, 6 },
81*c0909341SAndroid Build Coastguard Worker     { WEDGE_OBLIQUE153, 4, 2 }, { WEDGE_OBLIQUE153, 4, 6 },
82*c0909341SAndroid Build Coastguard Worker     { WEDGE_OBLIQUE63,  2, 4 }, { WEDGE_OBLIQUE63,  6, 4 },
83*c0909341SAndroid Build Coastguard Worker     { WEDGE_OBLIQUE117, 2, 4 }, { WEDGE_OBLIQUE117, 6, 4 },
84*c0909341SAndroid Build Coastguard Worker };
85*c0909341SAndroid Build Coastguard Worker 
86*c0909341SAndroid Build Coastguard Worker Dav1dMasks dav1d_masks;
87*c0909341SAndroid Build Coastguard Worker 
insert_border(uint8_t * const dst,const uint8_t * const src,const int ctr)88*c0909341SAndroid Build Coastguard Worker static void insert_border(uint8_t *const dst, const uint8_t *const src,
89*c0909341SAndroid Build Coastguard Worker                           const int ctr)
90*c0909341SAndroid Build Coastguard Worker {
91*c0909341SAndroid Build Coastguard Worker     if (ctr > 4) memset(dst, 0, ctr - 4);
92*c0909341SAndroid Build Coastguard Worker     memcpy(dst + imax(ctr, 4) - 4, src + imax(4 - ctr, 0), imin(64 - ctr, 8));
93*c0909341SAndroid Build Coastguard Worker     if (ctr < 64 - 4)
94*c0909341SAndroid Build Coastguard Worker         memset(dst + ctr + 4, 64, 64 - 4 - ctr);
95*c0909341SAndroid Build Coastguard Worker }
96*c0909341SAndroid Build Coastguard Worker 
transpose(uint8_t * const dst,const uint8_t * const src)97*c0909341SAndroid Build Coastguard Worker static void transpose(uint8_t *const dst, const uint8_t *const src) {
98*c0909341SAndroid Build Coastguard Worker     for (int y = 0, y_off = 0; y < 64; y++, y_off += 64)
99*c0909341SAndroid Build Coastguard Worker         for (int x = 0, x_off = 0; x < 64; x++, x_off += 64)
100*c0909341SAndroid Build Coastguard Worker             dst[x_off + y] = src[y_off + x];
101*c0909341SAndroid Build Coastguard Worker }
102*c0909341SAndroid Build Coastguard Worker 
hflip(uint8_t * const dst,const uint8_t * const src)103*c0909341SAndroid Build Coastguard Worker static void hflip(uint8_t *const dst, const uint8_t *const src) {
104*c0909341SAndroid Build Coastguard Worker     for (int y = 0, y_off = 0; y < 64; y++, y_off += 64)
105*c0909341SAndroid Build Coastguard Worker         for (int x = 0; x < 64; x++)
106*c0909341SAndroid Build Coastguard Worker             dst[y_off + 64 - 1 - x] = src[y_off + x];
107*c0909341SAndroid Build Coastguard Worker }
108*c0909341SAndroid Build Coastguard Worker 
copy2d(uint8_t * dst,const uint8_t * src,int sign,const int w,const int h,const int x_off,const int y_off)109*c0909341SAndroid Build Coastguard Worker static void copy2d(uint8_t *dst, const uint8_t *src, int sign,
110*c0909341SAndroid Build Coastguard Worker                    const int w, const int h, const int x_off, const int y_off)
111*c0909341SAndroid Build Coastguard Worker {
112*c0909341SAndroid Build Coastguard Worker     src += y_off * 64 + x_off;
113*c0909341SAndroid Build Coastguard Worker     if (sign) {
114*c0909341SAndroid Build Coastguard Worker         for (int y = 0; y < h; y++) {
115*c0909341SAndroid Build Coastguard Worker             for (int x = 0; x < w; x++)
116*c0909341SAndroid Build Coastguard Worker                 dst[x] = 64 - src[x];
117*c0909341SAndroid Build Coastguard Worker             src += 64;
118*c0909341SAndroid Build Coastguard Worker             dst += w;
119*c0909341SAndroid Build Coastguard Worker         }
120*c0909341SAndroid Build Coastguard Worker     } else {
121*c0909341SAndroid Build Coastguard Worker         for (int y = 0; y < h; y++) {
122*c0909341SAndroid Build Coastguard Worker             memcpy(dst, src, w);
123*c0909341SAndroid Build Coastguard Worker             src += 64;
124*c0909341SAndroid Build Coastguard Worker             dst += w;
125*c0909341SAndroid Build Coastguard Worker         }
126*c0909341SAndroid Build Coastguard Worker     }
127*c0909341SAndroid Build Coastguard Worker }
128*c0909341SAndroid Build Coastguard Worker 
129*c0909341SAndroid Build Coastguard Worker #define MASK_OFFSET(x) ((uint16_t)(((uintptr_t)(x) - (uintptr_t)&dav1d_masks) >> 3))
130*c0909341SAndroid Build Coastguard Worker 
init_chroma(uint8_t * chroma,const uint8_t * luma,const int sign,const int w,const int h,const int ss_ver)131*c0909341SAndroid Build Coastguard Worker static COLD uint16_t init_chroma(uint8_t *chroma, const uint8_t *luma,
132*c0909341SAndroid Build Coastguard Worker                                  const int sign, const int w, const int h,
133*c0909341SAndroid Build Coastguard Worker                                  const int ss_ver)
134*c0909341SAndroid Build Coastguard Worker {
135*c0909341SAndroid Build Coastguard Worker     const uint16_t offset = MASK_OFFSET(chroma);
136*c0909341SAndroid Build Coastguard Worker     for (int y = 0; y < h; y += 1 + ss_ver) {
137*c0909341SAndroid Build Coastguard Worker         for (int x = 0; x < w; x += 2) {
138*c0909341SAndroid Build Coastguard Worker             int sum = luma[x] + luma[x + 1] + 1;
139*c0909341SAndroid Build Coastguard Worker             if (ss_ver) sum += luma[w + x] + luma[w + x + 1] + 1;
140*c0909341SAndroid Build Coastguard Worker             chroma[x >> 1] = (sum - sign) >> (1 + ss_ver);
141*c0909341SAndroid Build Coastguard Worker         }
142*c0909341SAndroid Build Coastguard Worker         luma += w << ss_ver;
143*c0909341SAndroid Build Coastguard Worker         chroma += w >> 1;
144*c0909341SAndroid Build Coastguard Worker     }
145*c0909341SAndroid Build Coastguard Worker     return offset;
146*c0909341SAndroid Build Coastguard Worker }
147*c0909341SAndroid Build Coastguard Worker 
fill2d_16x2(const int w,const int h,const enum BlockSize bs,const uint8_t (* const master)[64* 64],const wedge_code_type * const cb,uint8_t * masks_444,uint8_t * masks_422,uint8_t * masks_420,unsigned signs)148*c0909341SAndroid Build Coastguard Worker static COLD void fill2d_16x2(const int w, const int h, const enum BlockSize bs,
149*c0909341SAndroid Build Coastguard Worker                              const uint8_t (*const master)[64 * 64],
150*c0909341SAndroid Build Coastguard Worker                              const wedge_code_type *const cb,
151*c0909341SAndroid Build Coastguard Worker                              uint8_t *masks_444, uint8_t *masks_422,
152*c0909341SAndroid Build Coastguard Worker                              uint8_t *masks_420, unsigned signs)
153*c0909341SAndroid Build Coastguard Worker {
154*c0909341SAndroid Build Coastguard Worker     const int n_stride_444 = (w * h);
155*c0909341SAndroid Build Coastguard Worker     const int n_stride_422 = n_stride_444 >> 1;
156*c0909341SAndroid Build Coastguard Worker     const int n_stride_420 = n_stride_444 >> 2;
157*c0909341SAndroid Build Coastguard Worker     const int sign_stride_422 = 16 * n_stride_422;
158*c0909341SAndroid Build Coastguard Worker     const int sign_stride_420 = 16 * n_stride_420;
159*c0909341SAndroid Build Coastguard Worker 
160*c0909341SAndroid Build Coastguard Worker     // assign pointer offsets in lookup table
161*c0909341SAndroid Build Coastguard Worker     for (int n = 0; n < 16; n++) {
162*c0909341SAndroid Build Coastguard Worker         const int sign = signs & 1;
163*c0909341SAndroid Build Coastguard Worker 
164*c0909341SAndroid Build Coastguard Worker         copy2d(masks_444, master[cb[n].direction], sign, w, h,
165*c0909341SAndroid Build Coastguard Worker                32 - (w * cb[n].x_offset >> 3), 32 - (h * cb[n].y_offset >> 3));
166*c0909341SAndroid Build Coastguard Worker 
167*c0909341SAndroid Build Coastguard Worker         // not using !sign is intentional here, since 444 does not require
168*c0909341SAndroid Build Coastguard Worker         // any rounding since no chroma subsampling is applied.
169*c0909341SAndroid Build Coastguard Worker         dav1d_masks.offsets[0][bs].wedge[0][n] =
170*c0909341SAndroid Build Coastguard Worker         dav1d_masks.offsets[0][bs].wedge[1][n] = MASK_OFFSET(masks_444);
171*c0909341SAndroid Build Coastguard Worker 
172*c0909341SAndroid Build Coastguard Worker         dav1d_masks.offsets[1][bs].wedge[0][n] =
173*c0909341SAndroid Build Coastguard Worker             init_chroma(&masks_422[ sign * sign_stride_422], masks_444, 0, w, h, 0);
174*c0909341SAndroid Build Coastguard Worker         dav1d_masks.offsets[1][bs].wedge[1][n] =
175*c0909341SAndroid Build Coastguard Worker             init_chroma(&masks_422[!sign * sign_stride_422], masks_444, 1, w, h, 0);
176*c0909341SAndroid Build Coastguard Worker         dav1d_masks.offsets[2][bs].wedge[0][n] =
177*c0909341SAndroid Build Coastguard Worker             init_chroma(&masks_420[ sign * sign_stride_420], masks_444, 0, w, h, 1);
178*c0909341SAndroid Build Coastguard Worker         dav1d_masks.offsets[2][bs].wedge[1][n] =
179*c0909341SAndroid Build Coastguard Worker             init_chroma(&masks_420[!sign * sign_stride_420], masks_444, 1, w, h, 1);
180*c0909341SAndroid Build Coastguard Worker 
181*c0909341SAndroid Build Coastguard Worker         signs >>= 1;
182*c0909341SAndroid Build Coastguard Worker         masks_444 += n_stride_444;
183*c0909341SAndroid Build Coastguard Worker         masks_422 += n_stride_422;
184*c0909341SAndroid Build Coastguard Worker         masks_420 += n_stride_420;
185*c0909341SAndroid Build Coastguard Worker     }
186*c0909341SAndroid Build Coastguard Worker }
187*c0909341SAndroid Build Coastguard Worker 
build_nondc_ii_masks(uint8_t * const mask_v,const int w,const int h,const int step)188*c0909341SAndroid Build Coastguard Worker static COLD void build_nondc_ii_masks(uint8_t *const mask_v, const int w,
189*c0909341SAndroid Build Coastguard Worker                                       const int h, const int step)
190*c0909341SAndroid Build Coastguard Worker {
191*c0909341SAndroid Build Coastguard Worker     static const uint8_t ii_weights_1d[32] = {
192*c0909341SAndroid Build Coastguard Worker         60, 52, 45, 39, 34, 30, 26, 22, 19, 17, 15, 13, 11, 10,  8,  7,
193*c0909341SAndroid Build Coastguard Worker          6,  6,  5,  4,  4,  3,  3,  2,  2,  2,  2,  1,  1,  1,  1,  1,
194*c0909341SAndroid Build Coastguard Worker     };
195*c0909341SAndroid Build Coastguard Worker 
196*c0909341SAndroid Build Coastguard Worker     uint8_t *const mask_h  = &mask_v[w * h];
197*c0909341SAndroid Build Coastguard Worker     uint8_t *const mask_sm = &mask_h[w * h];
198*c0909341SAndroid Build Coastguard Worker     for (int y = 0, off = 0; y < h; y++, off += w) {
199*c0909341SAndroid Build Coastguard Worker         memset(&mask_v[off], ii_weights_1d[y * step], w);
200*c0909341SAndroid Build Coastguard Worker         for (int x = 0; x < w; x++) {
201*c0909341SAndroid Build Coastguard Worker             mask_sm[off + x] = ii_weights_1d[imin(x, y) * step];
202*c0909341SAndroid Build Coastguard Worker             mask_h[off + x] = ii_weights_1d[x * step];
203*c0909341SAndroid Build Coastguard Worker         }
204*c0909341SAndroid Build Coastguard Worker     }
205*c0909341SAndroid Build Coastguard Worker }
206*c0909341SAndroid Build Coastguard Worker 
dav1d_init_ii_wedge_masks(void)207*c0909341SAndroid Build Coastguard Worker COLD void dav1d_init_ii_wedge_masks(void) {
208*c0909341SAndroid Build Coastguard Worker     // This function is guaranteed to be called only once
209*c0909341SAndroid Build Coastguard Worker 
210*c0909341SAndroid Build Coastguard Worker     enum WedgeMasterLineType {
211*c0909341SAndroid Build Coastguard Worker         WEDGE_MASTER_LINE_ODD,
212*c0909341SAndroid Build Coastguard Worker         WEDGE_MASTER_LINE_EVEN,
213*c0909341SAndroid Build Coastguard Worker         WEDGE_MASTER_LINE_VERT,
214*c0909341SAndroid Build Coastguard Worker         N_WEDGE_MASTER_LINES,
215*c0909341SAndroid Build Coastguard Worker     };
216*c0909341SAndroid Build Coastguard Worker     static const uint8_t wedge_master_border[N_WEDGE_MASTER_LINES][8] = {
217*c0909341SAndroid Build Coastguard Worker         [WEDGE_MASTER_LINE_ODD]  = {  1,  2,  6, 18, 37, 53, 60, 63 },
218*c0909341SAndroid Build Coastguard Worker         [WEDGE_MASTER_LINE_EVEN] = {  1,  4, 11, 27, 46, 58, 62, 63 },
219*c0909341SAndroid Build Coastguard Worker         [WEDGE_MASTER_LINE_VERT] = {  0,  2,  7, 21, 43, 57, 62, 64 },
220*c0909341SAndroid Build Coastguard Worker     };
221*c0909341SAndroid Build Coastguard Worker     uint8_t master[6][64 * 64];
222*c0909341SAndroid Build Coastguard Worker 
223*c0909341SAndroid Build Coastguard Worker     // create master templates
224*c0909341SAndroid Build Coastguard Worker     for (int y = 0, off = 0; y < 64; y++, off += 64)
225*c0909341SAndroid Build Coastguard Worker         insert_border(&master[WEDGE_VERTICAL][off],
226*c0909341SAndroid Build Coastguard Worker                       wedge_master_border[WEDGE_MASTER_LINE_VERT], 32);
227*c0909341SAndroid Build Coastguard Worker     for (int y = 0, off = 0, ctr = 48; y < 64; y += 2, off += 128, ctr--)
228*c0909341SAndroid Build Coastguard Worker     {
229*c0909341SAndroid Build Coastguard Worker         insert_border(&master[WEDGE_OBLIQUE63][off],
230*c0909341SAndroid Build Coastguard Worker                       wedge_master_border[WEDGE_MASTER_LINE_EVEN], ctr);
231*c0909341SAndroid Build Coastguard Worker         insert_border(&master[WEDGE_OBLIQUE63][off + 64],
232*c0909341SAndroid Build Coastguard Worker                       wedge_master_border[WEDGE_MASTER_LINE_ODD], ctr - 1);
233*c0909341SAndroid Build Coastguard Worker     }
234*c0909341SAndroid Build Coastguard Worker 
235*c0909341SAndroid Build Coastguard Worker     transpose(master[WEDGE_OBLIQUE27], master[WEDGE_OBLIQUE63]);
236*c0909341SAndroid Build Coastguard Worker     transpose(master[WEDGE_HORIZONTAL], master[WEDGE_VERTICAL]);
237*c0909341SAndroid Build Coastguard Worker     hflip(master[WEDGE_OBLIQUE117], master[WEDGE_OBLIQUE63]);
238*c0909341SAndroid Build Coastguard Worker     hflip(master[WEDGE_OBLIQUE153], master[WEDGE_OBLIQUE27]);
239*c0909341SAndroid Build Coastguard Worker 
240*c0909341SAndroid Build Coastguard Worker #define fill(w, h, sz_422, sz_420, hvsw, signs) \
241*c0909341SAndroid Build Coastguard Worker     fill2d_16x2(w, h, BS_##w##x##h - BS_32x32, \
242*c0909341SAndroid Build Coastguard Worker                 master, wedge_codebook_16_##hvsw, \
243*c0909341SAndroid Build Coastguard Worker                 dav1d_masks.wedge_444_##w##x##h, \
244*c0909341SAndroid Build Coastguard Worker                 dav1d_masks.wedge_422_##sz_422, \
245*c0909341SAndroid Build Coastguard Worker                 dav1d_masks.wedge_420_##sz_420, signs)
246*c0909341SAndroid Build Coastguard Worker 
247*c0909341SAndroid Build Coastguard Worker     fill(32, 32, 16x32, 16x16, heqw, 0x7bfb);
248*c0909341SAndroid Build Coastguard Worker     fill(32, 16, 16x16, 16x8,  hltw, 0x7beb);
249*c0909341SAndroid Build Coastguard Worker     fill(32,  8, 16x8,  16x4,  hltw, 0x6beb);
250*c0909341SAndroid Build Coastguard Worker     fill(16, 32,  8x32,  8x16, hgtw, 0x7beb);
251*c0909341SAndroid Build Coastguard Worker     fill(16, 16,  8x16,  8x8,  heqw, 0x7bfb);
252*c0909341SAndroid Build Coastguard Worker     fill(16,  8,  8x8,   8x4,  hltw, 0x7beb);
253*c0909341SAndroid Build Coastguard Worker     fill( 8, 32,  4x32,  4x16, hgtw, 0x7aeb);
254*c0909341SAndroid Build Coastguard Worker     fill( 8, 16,  4x16,  4x8,  hgtw, 0x7beb);
255*c0909341SAndroid Build Coastguard Worker     fill( 8,  8,  4x8,   4x4,  heqw, 0x7bfb);
256*c0909341SAndroid Build Coastguard Worker #undef fill
257*c0909341SAndroid Build Coastguard Worker 
258*c0909341SAndroid Build Coastguard Worker     memset(dav1d_masks.ii_dc, 32, 32 * 32);
259*c0909341SAndroid Build Coastguard Worker     for (int c = 0; c < 3; c++) {
260*c0909341SAndroid Build Coastguard Worker         dav1d_masks.offsets[c][BS_32x32-BS_32x32].ii[II_DC_PRED] =
261*c0909341SAndroid Build Coastguard Worker         dav1d_masks.offsets[c][BS_32x16-BS_32x32].ii[II_DC_PRED] =
262*c0909341SAndroid Build Coastguard Worker         dav1d_masks.offsets[c][BS_16x32-BS_32x32].ii[II_DC_PRED] =
263*c0909341SAndroid Build Coastguard Worker         dav1d_masks.offsets[c][BS_16x16-BS_32x32].ii[II_DC_PRED] =
264*c0909341SAndroid Build Coastguard Worker         dav1d_masks.offsets[c][BS_16x8 -BS_32x32].ii[II_DC_PRED] =
265*c0909341SAndroid Build Coastguard Worker         dav1d_masks.offsets[c][BS_8x16 -BS_32x32].ii[II_DC_PRED] =
266*c0909341SAndroid Build Coastguard Worker         dav1d_masks.offsets[c][BS_8x8  -BS_32x32].ii[II_DC_PRED] =
267*c0909341SAndroid Build Coastguard Worker             MASK_OFFSET(dav1d_masks.ii_dc);
268*c0909341SAndroid Build Coastguard Worker     }
269*c0909341SAndroid Build Coastguard Worker 
270*c0909341SAndroid Build Coastguard Worker #define BUILD_NONDC_II_MASKS(w, h, step) \
271*c0909341SAndroid Build Coastguard Worker     build_nondc_ii_masks(dav1d_masks.ii_nondc_##w##x##h, w, h, step)
272*c0909341SAndroid Build Coastguard Worker 
273*c0909341SAndroid Build Coastguard Worker #define ASSIGN_NONDC_II_OFFSET(bs, w444, h444, w422, h422, w420, h420) \
274*c0909341SAndroid Build Coastguard Worker     dav1d_masks.offsets[0][bs-BS_32x32].ii[p + 1] = \
275*c0909341SAndroid Build Coastguard Worker         MASK_OFFSET(&dav1d_masks.ii_nondc_##w444##x##h444[p*w444*h444]); \
276*c0909341SAndroid Build Coastguard Worker     dav1d_masks.offsets[1][bs-BS_32x32].ii[p + 1] = \
277*c0909341SAndroid Build Coastguard Worker         MASK_OFFSET(&dav1d_masks.ii_nondc_##w422##x##h422[p*w422*h422]); \
278*c0909341SAndroid Build Coastguard Worker     dav1d_masks.offsets[2][bs-BS_32x32].ii[p + 1] = \
279*c0909341SAndroid Build Coastguard Worker         MASK_OFFSET(&dav1d_masks.ii_nondc_##w420##x##h420[p*w420*h420])
280*c0909341SAndroid Build Coastguard Worker 
281*c0909341SAndroid Build Coastguard Worker     BUILD_NONDC_II_MASKS(32, 32, 1);
282*c0909341SAndroid Build Coastguard Worker     BUILD_NONDC_II_MASKS(16, 32, 1);
283*c0909341SAndroid Build Coastguard Worker     BUILD_NONDC_II_MASKS(16, 16, 2);
284*c0909341SAndroid Build Coastguard Worker     BUILD_NONDC_II_MASKS( 8, 32, 1);
285*c0909341SAndroid Build Coastguard Worker     BUILD_NONDC_II_MASKS( 8, 16, 2);
286*c0909341SAndroid Build Coastguard Worker     BUILD_NONDC_II_MASKS( 8,  8, 4);
287*c0909341SAndroid Build Coastguard Worker     BUILD_NONDC_II_MASKS( 4, 16, 2);
288*c0909341SAndroid Build Coastguard Worker     BUILD_NONDC_II_MASKS( 4,  8, 4);
289*c0909341SAndroid Build Coastguard Worker     BUILD_NONDC_II_MASKS( 4,  4, 8);
290*c0909341SAndroid Build Coastguard Worker     for (int p = 0; p < 3; p++) {
291*c0909341SAndroid Build Coastguard Worker         ASSIGN_NONDC_II_OFFSET(BS_32x32, 32, 32, 16, 32, 16, 16);
292*c0909341SAndroid Build Coastguard Worker         ASSIGN_NONDC_II_OFFSET(BS_32x16, 32, 32, 16, 16, 16, 16);
293*c0909341SAndroid Build Coastguard Worker         ASSIGN_NONDC_II_OFFSET(BS_16x32, 16, 32,  8, 32,  8, 16);
294*c0909341SAndroid Build Coastguard Worker         ASSIGN_NONDC_II_OFFSET(BS_16x16, 16, 16,  8, 16,  8,  8);
295*c0909341SAndroid Build Coastguard Worker         ASSIGN_NONDC_II_OFFSET(BS_16x8,  16, 16,  8,  8,  8,  8);
296*c0909341SAndroid Build Coastguard Worker         ASSIGN_NONDC_II_OFFSET(BS_8x16,   8, 16,  4, 16,  4,  8);
297*c0909341SAndroid Build Coastguard Worker         ASSIGN_NONDC_II_OFFSET(BS_8x8,    8,  8,  4,  8,  4,  4);
298*c0909341SAndroid Build Coastguard Worker     }
299*c0909341SAndroid Build Coastguard Worker }
300