1*fb1b10abSAndroid Build Coastguard Worker /*
2*fb1b10abSAndroid Build Coastguard Worker * Copyright (c) 2015 The WebM project authors. All Rights Reserved.
3*fb1b10abSAndroid Build Coastguard Worker *
4*fb1b10abSAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license
5*fb1b10abSAndroid Build Coastguard Worker * that can be found in the LICENSE file in the root of the source
6*fb1b10abSAndroid Build Coastguard Worker * tree. An additional intellectual property rights grant can be found
7*fb1b10abSAndroid Build Coastguard Worker * in the file PATENTS. All contributing project authors may
8*fb1b10abSAndroid Build Coastguard Worker * be found in the AUTHORS file in the root of the source tree.
9*fb1b10abSAndroid Build Coastguard Worker */
10*fb1b10abSAndroid Build Coastguard Worker
11*fb1b10abSAndroid Build Coastguard Worker #include "./vpx_config.h"
12*fb1b10abSAndroid Build Coastguard Worker #include "./vpx_dsp_rtcd.h"
13*fb1b10abSAndroid Build Coastguard Worker
14*fb1b10abSAndroid Build Coastguard Worker #include "vpx_dsp/vpx_dsp_common.h"
15*fb1b10abSAndroid Build Coastguard Worker #include "vpx_mem/vpx_mem.h"
16*fb1b10abSAndroid Build Coastguard Worker
17*fb1b10abSAndroid Build Coastguard Worker #define DST(x, y) dst[(x) + (y)*stride]
18*fb1b10abSAndroid Build Coastguard Worker #define AVG3(a, b, c) (((a) + 2 * (b) + (c) + 2) >> 2)
19*fb1b10abSAndroid Build Coastguard Worker #define AVG2(a, b) (((a) + (b) + 1) >> 1)
20*fb1b10abSAndroid Build Coastguard Worker
d207_predictor(uint8_t * dst,ptrdiff_t stride,int bs,const uint8_t * above,const uint8_t * left)21*fb1b10abSAndroid Build Coastguard Worker static INLINE void d207_predictor(uint8_t *dst, ptrdiff_t stride, int bs,
22*fb1b10abSAndroid Build Coastguard Worker const uint8_t *above, const uint8_t *left) {
23*fb1b10abSAndroid Build Coastguard Worker int r, c;
24*fb1b10abSAndroid Build Coastguard Worker (void)above;
25*fb1b10abSAndroid Build Coastguard Worker // first column
26*fb1b10abSAndroid Build Coastguard Worker for (r = 0; r < bs - 1; ++r) dst[r * stride] = AVG2(left[r], left[r + 1]);
27*fb1b10abSAndroid Build Coastguard Worker dst[(bs - 1) * stride] = left[bs - 1];
28*fb1b10abSAndroid Build Coastguard Worker dst++;
29*fb1b10abSAndroid Build Coastguard Worker
30*fb1b10abSAndroid Build Coastguard Worker // second column
31*fb1b10abSAndroid Build Coastguard Worker for (r = 0; r < bs - 2; ++r)
32*fb1b10abSAndroid Build Coastguard Worker dst[r * stride] = AVG3(left[r], left[r + 1], left[r + 2]);
33*fb1b10abSAndroid Build Coastguard Worker dst[(bs - 2) * stride] = AVG3(left[bs - 2], left[bs - 1], left[bs - 1]);
34*fb1b10abSAndroid Build Coastguard Worker dst[(bs - 1) * stride] = left[bs - 1];
35*fb1b10abSAndroid Build Coastguard Worker dst++;
36*fb1b10abSAndroid Build Coastguard Worker
37*fb1b10abSAndroid Build Coastguard Worker // rest of last row
38*fb1b10abSAndroid Build Coastguard Worker for (c = 0; c < bs - 2; ++c) dst[(bs - 1) * stride + c] = left[bs - 1];
39*fb1b10abSAndroid Build Coastguard Worker
40*fb1b10abSAndroid Build Coastguard Worker for (r = bs - 2; r >= 0; --r)
41*fb1b10abSAndroid Build Coastguard Worker for (c = 0; c < bs - 2; ++c)
42*fb1b10abSAndroid Build Coastguard Worker dst[r * stride + c] = dst[(r + 1) * stride + c - 2];
43*fb1b10abSAndroid Build Coastguard Worker }
44*fb1b10abSAndroid Build Coastguard Worker
d63_predictor(uint8_t * dst,ptrdiff_t stride,int bs,const uint8_t * above,const uint8_t * left)45*fb1b10abSAndroid Build Coastguard Worker static INLINE void d63_predictor(uint8_t *dst, ptrdiff_t stride, int bs,
46*fb1b10abSAndroid Build Coastguard Worker const uint8_t *above, const uint8_t *left) {
47*fb1b10abSAndroid Build Coastguard Worker int r, c;
48*fb1b10abSAndroid Build Coastguard Worker int size;
49*fb1b10abSAndroid Build Coastguard Worker (void)left;
50*fb1b10abSAndroid Build Coastguard Worker for (c = 0; c < bs; ++c) {
51*fb1b10abSAndroid Build Coastguard Worker dst[c] = AVG2(above[c], above[c + 1]);
52*fb1b10abSAndroid Build Coastguard Worker dst[stride + c] = AVG3(above[c], above[c + 1], above[c + 2]);
53*fb1b10abSAndroid Build Coastguard Worker }
54*fb1b10abSAndroid Build Coastguard Worker for (r = 2, size = bs - 2; r < bs; r += 2, --size) {
55*fb1b10abSAndroid Build Coastguard Worker memcpy(dst + (r + 0) * stride, dst + (r >> 1), size);
56*fb1b10abSAndroid Build Coastguard Worker memset(dst + (r + 0) * stride + size, above[bs - 1], bs - size);
57*fb1b10abSAndroid Build Coastguard Worker memcpy(dst + (r + 1) * stride, dst + stride + (r >> 1), size);
58*fb1b10abSAndroid Build Coastguard Worker memset(dst + (r + 1) * stride + size, above[bs - 1], bs - size);
59*fb1b10abSAndroid Build Coastguard Worker }
60*fb1b10abSAndroid Build Coastguard Worker }
61*fb1b10abSAndroid Build Coastguard Worker
d45_predictor(uint8_t * dst,ptrdiff_t stride,int bs,const uint8_t * above,const uint8_t * left)62*fb1b10abSAndroid Build Coastguard Worker static INLINE void d45_predictor(uint8_t *dst, ptrdiff_t stride, int bs,
63*fb1b10abSAndroid Build Coastguard Worker const uint8_t *above, const uint8_t *left) {
64*fb1b10abSAndroid Build Coastguard Worker const uint8_t above_right = above[bs - 1];
65*fb1b10abSAndroid Build Coastguard Worker const uint8_t *const dst_row0 = dst;
66*fb1b10abSAndroid Build Coastguard Worker int x, size;
67*fb1b10abSAndroid Build Coastguard Worker (void)left;
68*fb1b10abSAndroid Build Coastguard Worker
69*fb1b10abSAndroid Build Coastguard Worker for (x = 0; x < bs - 1; ++x) {
70*fb1b10abSAndroid Build Coastguard Worker dst[x] = AVG3(above[x], above[x + 1], above[x + 2]);
71*fb1b10abSAndroid Build Coastguard Worker }
72*fb1b10abSAndroid Build Coastguard Worker dst[bs - 1] = above_right;
73*fb1b10abSAndroid Build Coastguard Worker dst += stride;
74*fb1b10abSAndroid Build Coastguard Worker for (x = 1, size = bs - 2; x < bs; ++x, --size) {
75*fb1b10abSAndroid Build Coastguard Worker memcpy(dst, dst_row0 + x, size);
76*fb1b10abSAndroid Build Coastguard Worker memset(dst + size, above_right, x + 1);
77*fb1b10abSAndroid Build Coastguard Worker dst += stride;
78*fb1b10abSAndroid Build Coastguard Worker }
79*fb1b10abSAndroid Build Coastguard Worker }
80*fb1b10abSAndroid Build Coastguard Worker
d117_predictor(uint8_t * dst,ptrdiff_t stride,int bs,const uint8_t * above,const uint8_t * left)81*fb1b10abSAndroid Build Coastguard Worker static INLINE void d117_predictor(uint8_t *dst, ptrdiff_t stride, int bs,
82*fb1b10abSAndroid Build Coastguard Worker const uint8_t *above, const uint8_t *left) {
83*fb1b10abSAndroid Build Coastguard Worker int r, c;
84*fb1b10abSAndroid Build Coastguard Worker
85*fb1b10abSAndroid Build Coastguard Worker // first row
86*fb1b10abSAndroid Build Coastguard Worker for (c = 0; c < bs; c++) dst[c] = AVG2(above[c - 1], above[c]);
87*fb1b10abSAndroid Build Coastguard Worker dst += stride;
88*fb1b10abSAndroid Build Coastguard Worker
89*fb1b10abSAndroid Build Coastguard Worker // second row
90*fb1b10abSAndroid Build Coastguard Worker dst[0] = AVG3(left[0], above[-1], above[0]);
91*fb1b10abSAndroid Build Coastguard Worker for (c = 1; c < bs; c++) dst[c] = AVG3(above[c - 2], above[c - 1], above[c]);
92*fb1b10abSAndroid Build Coastguard Worker dst += stride;
93*fb1b10abSAndroid Build Coastguard Worker
94*fb1b10abSAndroid Build Coastguard Worker // the rest of first col
95*fb1b10abSAndroid Build Coastguard Worker dst[0] = AVG3(above[-1], left[0], left[1]);
96*fb1b10abSAndroid Build Coastguard Worker for (r = 3; r < bs; ++r)
97*fb1b10abSAndroid Build Coastguard Worker dst[(r - 2) * stride] = AVG3(left[r - 3], left[r - 2], left[r - 1]);
98*fb1b10abSAndroid Build Coastguard Worker
99*fb1b10abSAndroid Build Coastguard Worker // the rest of the block
100*fb1b10abSAndroid Build Coastguard Worker for (r = 2; r < bs; ++r) {
101*fb1b10abSAndroid Build Coastguard Worker for (c = 1; c < bs; c++) dst[c] = dst[-2 * stride + c - 1];
102*fb1b10abSAndroid Build Coastguard Worker dst += stride;
103*fb1b10abSAndroid Build Coastguard Worker }
104*fb1b10abSAndroid Build Coastguard Worker }
105*fb1b10abSAndroid Build Coastguard Worker
d135_predictor(uint8_t * dst,ptrdiff_t stride,int bs,const uint8_t * above,const uint8_t * left)106*fb1b10abSAndroid Build Coastguard Worker static INLINE void d135_predictor(uint8_t *dst, ptrdiff_t stride, int bs,
107*fb1b10abSAndroid Build Coastguard Worker const uint8_t *above, const uint8_t *left) {
108*fb1b10abSAndroid Build Coastguard Worker int i;
109*fb1b10abSAndroid Build Coastguard Worker #if defined(__GNUC__) && __GNUC__ == 4 && __GNUC_MINOR__ > 7
110*fb1b10abSAndroid Build Coastguard Worker // silence a spurious -Warray-bounds warning, possibly related to:
111*fb1b10abSAndroid Build Coastguard Worker // https://gcc.gnu.org/bugzilla/show_bug.cgi?id=56273
112*fb1b10abSAndroid Build Coastguard Worker uint8_t border[69];
113*fb1b10abSAndroid Build Coastguard Worker #else
114*fb1b10abSAndroid Build Coastguard Worker uint8_t border[32 + 32 - 1]; // outer border from bottom-left to top-right
115*fb1b10abSAndroid Build Coastguard Worker #endif
116*fb1b10abSAndroid Build Coastguard Worker
117*fb1b10abSAndroid Build Coastguard Worker // dst(bs, bs - 2)[0], i.e., border starting at bottom-left
118*fb1b10abSAndroid Build Coastguard Worker for (i = 0; i < bs - 2; ++i) {
119*fb1b10abSAndroid Build Coastguard Worker border[i] = AVG3(left[bs - 3 - i], left[bs - 2 - i], left[bs - 1 - i]);
120*fb1b10abSAndroid Build Coastguard Worker }
121*fb1b10abSAndroid Build Coastguard Worker border[bs - 2] = AVG3(above[-1], left[0], left[1]);
122*fb1b10abSAndroid Build Coastguard Worker border[bs - 1] = AVG3(left[0], above[-1], above[0]);
123*fb1b10abSAndroid Build Coastguard Worker border[bs - 0] = AVG3(above[-1], above[0], above[1]);
124*fb1b10abSAndroid Build Coastguard Worker // dst[0][2, size), i.e., remaining top border ascending
125*fb1b10abSAndroid Build Coastguard Worker for (i = 0; i < bs - 2; ++i) {
126*fb1b10abSAndroid Build Coastguard Worker border[bs + 1 + i] = AVG3(above[i], above[i + 1], above[i + 2]);
127*fb1b10abSAndroid Build Coastguard Worker }
128*fb1b10abSAndroid Build Coastguard Worker
129*fb1b10abSAndroid Build Coastguard Worker for (i = 0; i < bs; ++i) {
130*fb1b10abSAndroid Build Coastguard Worker memcpy(dst + i * stride, border + bs - 1 - i, bs);
131*fb1b10abSAndroid Build Coastguard Worker }
132*fb1b10abSAndroid Build Coastguard Worker }
133*fb1b10abSAndroid Build Coastguard Worker
d153_predictor(uint8_t * dst,ptrdiff_t stride,int bs,const uint8_t * above,const uint8_t * left)134*fb1b10abSAndroid Build Coastguard Worker static INLINE void d153_predictor(uint8_t *dst, ptrdiff_t stride, int bs,
135*fb1b10abSAndroid Build Coastguard Worker const uint8_t *above, const uint8_t *left) {
136*fb1b10abSAndroid Build Coastguard Worker int r, c;
137*fb1b10abSAndroid Build Coastguard Worker dst[0] = AVG2(above[-1], left[0]);
138*fb1b10abSAndroid Build Coastguard Worker for (r = 1; r < bs; r++) dst[r * stride] = AVG2(left[r - 1], left[r]);
139*fb1b10abSAndroid Build Coastguard Worker dst++;
140*fb1b10abSAndroid Build Coastguard Worker
141*fb1b10abSAndroid Build Coastguard Worker dst[0] = AVG3(left[0], above[-1], above[0]);
142*fb1b10abSAndroid Build Coastguard Worker dst[stride] = AVG3(above[-1], left[0], left[1]);
143*fb1b10abSAndroid Build Coastguard Worker for (r = 2; r < bs; r++)
144*fb1b10abSAndroid Build Coastguard Worker dst[r * stride] = AVG3(left[r - 2], left[r - 1], left[r]);
145*fb1b10abSAndroid Build Coastguard Worker dst++;
146*fb1b10abSAndroid Build Coastguard Worker
147*fb1b10abSAndroid Build Coastguard Worker for (c = 0; c < bs - 2; c++)
148*fb1b10abSAndroid Build Coastguard Worker dst[c] = AVG3(above[c - 1], above[c], above[c + 1]);
149*fb1b10abSAndroid Build Coastguard Worker dst += stride;
150*fb1b10abSAndroid Build Coastguard Worker
151*fb1b10abSAndroid Build Coastguard Worker for (r = 1; r < bs; ++r) {
152*fb1b10abSAndroid Build Coastguard Worker for (c = 0; c < bs - 2; c++) dst[c] = dst[-stride + c - 2];
153*fb1b10abSAndroid Build Coastguard Worker dst += stride;
154*fb1b10abSAndroid Build Coastguard Worker }
155*fb1b10abSAndroid Build Coastguard Worker }
156*fb1b10abSAndroid Build Coastguard Worker
v_predictor(uint8_t * dst,ptrdiff_t stride,int bs,const uint8_t * above,const uint8_t * left)157*fb1b10abSAndroid Build Coastguard Worker static INLINE void v_predictor(uint8_t *dst, ptrdiff_t stride, int bs,
158*fb1b10abSAndroid Build Coastguard Worker const uint8_t *above, const uint8_t *left) {
159*fb1b10abSAndroid Build Coastguard Worker int r;
160*fb1b10abSAndroid Build Coastguard Worker (void)left;
161*fb1b10abSAndroid Build Coastguard Worker
162*fb1b10abSAndroid Build Coastguard Worker for (r = 0; r < bs; r++) {
163*fb1b10abSAndroid Build Coastguard Worker memcpy(dst, above, bs);
164*fb1b10abSAndroid Build Coastguard Worker dst += stride;
165*fb1b10abSAndroid Build Coastguard Worker }
166*fb1b10abSAndroid Build Coastguard Worker }
167*fb1b10abSAndroid Build Coastguard Worker
h_predictor(uint8_t * dst,ptrdiff_t stride,int bs,const uint8_t * above,const uint8_t * left)168*fb1b10abSAndroid Build Coastguard Worker static INLINE void h_predictor(uint8_t *dst, ptrdiff_t stride, int bs,
169*fb1b10abSAndroid Build Coastguard Worker const uint8_t *above, const uint8_t *left) {
170*fb1b10abSAndroid Build Coastguard Worker int r;
171*fb1b10abSAndroid Build Coastguard Worker (void)above;
172*fb1b10abSAndroid Build Coastguard Worker
173*fb1b10abSAndroid Build Coastguard Worker for (r = 0; r < bs; r++) {
174*fb1b10abSAndroid Build Coastguard Worker memset(dst, left[r], bs);
175*fb1b10abSAndroid Build Coastguard Worker dst += stride;
176*fb1b10abSAndroid Build Coastguard Worker }
177*fb1b10abSAndroid Build Coastguard Worker }
178*fb1b10abSAndroid Build Coastguard Worker
tm_predictor(uint8_t * dst,ptrdiff_t stride,int bs,const uint8_t * above,const uint8_t * left)179*fb1b10abSAndroid Build Coastguard Worker static INLINE void tm_predictor(uint8_t *dst, ptrdiff_t stride, int bs,
180*fb1b10abSAndroid Build Coastguard Worker const uint8_t *above, const uint8_t *left) {
181*fb1b10abSAndroid Build Coastguard Worker int r, c;
182*fb1b10abSAndroid Build Coastguard Worker int ytop_left = above[-1];
183*fb1b10abSAndroid Build Coastguard Worker
184*fb1b10abSAndroid Build Coastguard Worker for (r = 0; r < bs; r++) {
185*fb1b10abSAndroid Build Coastguard Worker for (c = 0; c < bs; c++)
186*fb1b10abSAndroid Build Coastguard Worker dst[c] = clip_pixel(left[r] + above[c] - ytop_left);
187*fb1b10abSAndroid Build Coastguard Worker dst += stride;
188*fb1b10abSAndroid Build Coastguard Worker }
189*fb1b10abSAndroid Build Coastguard Worker }
190*fb1b10abSAndroid Build Coastguard Worker
dc_128_predictor(uint8_t * dst,ptrdiff_t stride,int bs,const uint8_t * above,const uint8_t * left)191*fb1b10abSAndroid Build Coastguard Worker static INLINE void dc_128_predictor(uint8_t *dst, ptrdiff_t stride, int bs,
192*fb1b10abSAndroid Build Coastguard Worker const uint8_t *above, const uint8_t *left) {
193*fb1b10abSAndroid Build Coastguard Worker int r;
194*fb1b10abSAndroid Build Coastguard Worker (void)above;
195*fb1b10abSAndroid Build Coastguard Worker (void)left;
196*fb1b10abSAndroid Build Coastguard Worker
197*fb1b10abSAndroid Build Coastguard Worker for (r = 0; r < bs; r++) {
198*fb1b10abSAndroid Build Coastguard Worker memset(dst, 128, bs);
199*fb1b10abSAndroid Build Coastguard Worker dst += stride;
200*fb1b10abSAndroid Build Coastguard Worker }
201*fb1b10abSAndroid Build Coastguard Worker }
202*fb1b10abSAndroid Build Coastguard Worker
dc_left_predictor(uint8_t * dst,ptrdiff_t stride,int bs,const uint8_t * above,const uint8_t * left)203*fb1b10abSAndroid Build Coastguard Worker static INLINE void dc_left_predictor(uint8_t *dst, ptrdiff_t stride, int bs,
204*fb1b10abSAndroid Build Coastguard Worker const uint8_t *above,
205*fb1b10abSAndroid Build Coastguard Worker const uint8_t *left) {
206*fb1b10abSAndroid Build Coastguard Worker int i, r, expected_dc, sum = 0;
207*fb1b10abSAndroid Build Coastguard Worker (void)above;
208*fb1b10abSAndroid Build Coastguard Worker
209*fb1b10abSAndroid Build Coastguard Worker for (i = 0; i < bs; i++) sum += left[i];
210*fb1b10abSAndroid Build Coastguard Worker expected_dc = (sum + (bs >> 1)) / bs;
211*fb1b10abSAndroid Build Coastguard Worker
212*fb1b10abSAndroid Build Coastguard Worker for (r = 0; r < bs; r++) {
213*fb1b10abSAndroid Build Coastguard Worker memset(dst, expected_dc, bs);
214*fb1b10abSAndroid Build Coastguard Worker dst += stride;
215*fb1b10abSAndroid Build Coastguard Worker }
216*fb1b10abSAndroid Build Coastguard Worker }
217*fb1b10abSAndroid Build Coastguard Worker
dc_top_predictor(uint8_t * dst,ptrdiff_t stride,int bs,const uint8_t * above,const uint8_t * left)218*fb1b10abSAndroid Build Coastguard Worker static INLINE void dc_top_predictor(uint8_t *dst, ptrdiff_t stride, int bs,
219*fb1b10abSAndroid Build Coastguard Worker const uint8_t *above, const uint8_t *left) {
220*fb1b10abSAndroid Build Coastguard Worker int i, r, expected_dc, sum = 0;
221*fb1b10abSAndroid Build Coastguard Worker (void)left;
222*fb1b10abSAndroid Build Coastguard Worker
223*fb1b10abSAndroid Build Coastguard Worker for (i = 0; i < bs; i++) sum += above[i];
224*fb1b10abSAndroid Build Coastguard Worker expected_dc = (sum + (bs >> 1)) / bs;
225*fb1b10abSAndroid Build Coastguard Worker
226*fb1b10abSAndroid Build Coastguard Worker for (r = 0; r < bs; r++) {
227*fb1b10abSAndroid Build Coastguard Worker memset(dst, expected_dc, bs);
228*fb1b10abSAndroid Build Coastguard Worker dst += stride;
229*fb1b10abSAndroid Build Coastguard Worker }
230*fb1b10abSAndroid Build Coastguard Worker }
231*fb1b10abSAndroid Build Coastguard Worker
dc_predictor(uint8_t * dst,ptrdiff_t stride,int bs,const uint8_t * above,const uint8_t * left)232*fb1b10abSAndroid Build Coastguard Worker static INLINE void dc_predictor(uint8_t *dst, ptrdiff_t stride, int bs,
233*fb1b10abSAndroid Build Coastguard Worker const uint8_t *above, const uint8_t *left) {
234*fb1b10abSAndroid Build Coastguard Worker int i, r, expected_dc, sum = 0;
235*fb1b10abSAndroid Build Coastguard Worker const int count = 2 * bs;
236*fb1b10abSAndroid Build Coastguard Worker
237*fb1b10abSAndroid Build Coastguard Worker for (i = 0; i < bs; i++) {
238*fb1b10abSAndroid Build Coastguard Worker sum += above[i];
239*fb1b10abSAndroid Build Coastguard Worker sum += left[i];
240*fb1b10abSAndroid Build Coastguard Worker }
241*fb1b10abSAndroid Build Coastguard Worker
242*fb1b10abSAndroid Build Coastguard Worker expected_dc = (sum + (count >> 1)) / count;
243*fb1b10abSAndroid Build Coastguard Worker
244*fb1b10abSAndroid Build Coastguard Worker for (r = 0; r < bs; r++) {
245*fb1b10abSAndroid Build Coastguard Worker memset(dst, expected_dc, bs);
246*fb1b10abSAndroid Build Coastguard Worker dst += stride;
247*fb1b10abSAndroid Build Coastguard Worker }
248*fb1b10abSAndroid Build Coastguard Worker }
249*fb1b10abSAndroid Build Coastguard Worker
vpx_he_predictor_4x4_c(uint8_t * dst,ptrdiff_t stride,const uint8_t * above,const uint8_t * left)250*fb1b10abSAndroid Build Coastguard Worker void vpx_he_predictor_4x4_c(uint8_t *dst, ptrdiff_t stride,
251*fb1b10abSAndroid Build Coastguard Worker const uint8_t *above, const uint8_t *left) {
252*fb1b10abSAndroid Build Coastguard Worker const int H = above[-1];
253*fb1b10abSAndroid Build Coastguard Worker const int I = left[0];
254*fb1b10abSAndroid Build Coastguard Worker const int J = left[1];
255*fb1b10abSAndroid Build Coastguard Worker const int K = left[2];
256*fb1b10abSAndroid Build Coastguard Worker const int L = left[3];
257*fb1b10abSAndroid Build Coastguard Worker
258*fb1b10abSAndroid Build Coastguard Worker memset(dst + stride * 0, AVG3(H, I, J), 4);
259*fb1b10abSAndroid Build Coastguard Worker memset(dst + stride * 1, AVG3(I, J, K), 4);
260*fb1b10abSAndroid Build Coastguard Worker memset(dst + stride * 2, AVG3(J, K, L), 4);
261*fb1b10abSAndroid Build Coastguard Worker memset(dst + stride * 3, AVG3(K, L, L), 4);
262*fb1b10abSAndroid Build Coastguard Worker }
263*fb1b10abSAndroid Build Coastguard Worker
vpx_ve_predictor_4x4_c(uint8_t * dst,ptrdiff_t stride,const uint8_t * above,const uint8_t * left)264*fb1b10abSAndroid Build Coastguard Worker void vpx_ve_predictor_4x4_c(uint8_t *dst, ptrdiff_t stride,
265*fb1b10abSAndroid Build Coastguard Worker const uint8_t *above, const uint8_t *left) {
266*fb1b10abSAndroid Build Coastguard Worker const int H = above[-1];
267*fb1b10abSAndroid Build Coastguard Worker const int I = above[0];
268*fb1b10abSAndroid Build Coastguard Worker const int J = above[1];
269*fb1b10abSAndroid Build Coastguard Worker const int K = above[2];
270*fb1b10abSAndroid Build Coastguard Worker const int L = above[3];
271*fb1b10abSAndroid Build Coastguard Worker const int M = above[4];
272*fb1b10abSAndroid Build Coastguard Worker (void)left;
273*fb1b10abSAndroid Build Coastguard Worker
274*fb1b10abSAndroid Build Coastguard Worker dst[0] = AVG3(H, I, J);
275*fb1b10abSAndroid Build Coastguard Worker dst[1] = AVG3(I, J, K);
276*fb1b10abSAndroid Build Coastguard Worker dst[2] = AVG3(J, K, L);
277*fb1b10abSAndroid Build Coastguard Worker dst[3] = AVG3(K, L, M);
278*fb1b10abSAndroid Build Coastguard Worker memcpy(dst + stride * 1, dst, 4);
279*fb1b10abSAndroid Build Coastguard Worker memcpy(dst + stride * 2, dst, 4);
280*fb1b10abSAndroid Build Coastguard Worker memcpy(dst + stride * 3, dst, 4);
281*fb1b10abSAndroid Build Coastguard Worker }
282*fb1b10abSAndroid Build Coastguard Worker
vpx_d207_predictor_4x4_c(uint8_t * dst,ptrdiff_t stride,const uint8_t * above,const uint8_t * left)283*fb1b10abSAndroid Build Coastguard Worker void vpx_d207_predictor_4x4_c(uint8_t *dst, ptrdiff_t stride,
284*fb1b10abSAndroid Build Coastguard Worker const uint8_t *above, const uint8_t *left) {
285*fb1b10abSAndroid Build Coastguard Worker const int I = left[0];
286*fb1b10abSAndroid Build Coastguard Worker const int J = left[1];
287*fb1b10abSAndroid Build Coastguard Worker const int K = left[2];
288*fb1b10abSAndroid Build Coastguard Worker const int L = left[3];
289*fb1b10abSAndroid Build Coastguard Worker (void)above;
290*fb1b10abSAndroid Build Coastguard Worker DST(0, 0) = AVG2(I, J);
291*fb1b10abSAndroid Build Coastguard Worker DST(2, 0) = DST(0, 1) = AVG2(J, K);
292*fb1b10abSAndroid Build Coastguard Worker DST(2, 1) = DST(0, 2) = AVG2(K, L);
293*fb1b10abSAndroid Build Coastguard Worker DST(1, 0) = AVG3(I, J, K);
294*fb1b10abSAndroid Build Coastguard Worker DST(3, 0) = DST(1, 1) = AVG3(J, K, L);
295*fb1b10abSAndroid Build Coastguard Worker DST(3, 1) = DST(1, 2) = AVG3(K, L, L);
296*fb1b10abSAndroid Build Coastguard Worker DST(3, 2) = DST(2, 2) = DST(0, 3) = DST(1, 3) = DST(2, 3) = DST(3, 3) = L;
297*fb1b10abSAndroid Build Coastguard Worker }
298*fb1b10abSAndroid Build Coastguard Worker
vpx_d63_predictor_4x4_c(uint8_t * dst,ptrdiff_t stride,const uint8_t * above,const uint8_t * left)299*fb1b10abSAndroid Build Coastguard Worker void vpx_d63_predictor_4x4_c(uint8_t *dst, ptrdiff_t stride,
300*fb1b10abSAndroid Build Coastguard Worker const uint8_t *above, const uint8_t *left) {
301*fb1b10abSAndroid Build Coastguard Worker const int A = above[0];
302*fb1b10abSAndroid Build Coastguard Worker const int B = above[1];
303*fb1b10abSAndroid Build Coastguard Worker const int C = above[2];
304*fb1b10abSAndroid Build Coastguard Worker const int D = above[3];
305*fb1b10abSAndroid Build Coastguard Worker const int E = above[4];
306*fb1b10abSAndroid Build Coastguard Worker const int F = above[5];
307*fb1b10abSAndroid Build Coastguard Worker const int G = above[6];
308*fb1b10abSAndroid Build Coastguard Worker (void)left;
309*fb1b10abSAndroid Build Coastguard Worker DST(0, 0) = AVG2(A, B);
310*fb1b10abSAndroid Build Coastguard Worker DST(1, 0) = DST(0, 2) = AVG2(B, C);
311*fb1b10abSAndroid Build Coastguard Worker DST(2, 0) = DST(1, 2) = AVG2(C, D);
312*fb1b10abSAndroid Build Coastguard Worker DST(3, 0) = DST(2, 2) = AVG2(D, E);
313*fb1b10abSAndroid Build Coastguard Worker DST(3, 2) = AVG2(E, F); // differs from vp8
314*fb1b10abSAndroid Build Coastguard Worker
315*fb1b10abSAndroid Build Coastguard Worker DST(0, 1) = AVG3(A, B, C);
316*fb1b10abSAndroid Build Coastguard Worker DST(1, 1) = DST(0, 3) = AVG3(B, C, D);
317*fb1b10abSAndroid Build Coastguard Worker DST(2, 1) = DST(1, 3) = AVG3(C, D, E);
318*fb1b10abSAndroid Build Coastguard Worker DST(3, 1) = DST(2, 3) = AVG3(D, E, F);
319*fb1b10abSAndroid Build Coastguard Worker DST(3, 3) = AVG3(E, F, G); // differs from vp8
320*fb1b10abSAndroid Build Coastguard Worker }
321*fb1b10abSAndroid Build Coastguard Worker
vpx_d63e_predictor_4x4_c(uint8_t * dst,ptrdiff_t stride,const uint8_t * above,const uint8_t * left)322*fb1b10abSAndroid Build Coastguard Worker void vpx_d63e_predictor_4x4_c(uint8_t *dst, ptrdiff_t stride,
323*fb1b10abSAndroid Build Coastguard Worker const uint8_t *above, const uint8_t *left) {
324*fb1b10abSAndroid Build Coastguard Worker const int A = above[0];
325*fb1b10abSAndroid Build Coastguard Worker const int B = above[1];
326*fb1b10abSAndroid Build Coastguard Worker const int C = above[2];
327*fb1b10abSAndroid Build Coastguard Worker const int D = above[3];
328*fb1b10abSAndroid Build Coastguard Worker const int E = above[4];
329*fb1b10abSAndroid Build Coastguard Worker const int F = above[5];
330*fb1b10abSAndroid Build Coastguard Worker const int G = above[6];
331*fb1b10abSAndroid Build Coastguard Worker const int H = above[7];
332*fb1b10abSAndroid Build Coastguard Worker (void)left;
333*fb1b10abSAndroid Build Coastguard Worker DST(0, 0) = AVG2(A, B);
334*fb1b10abSAndroid Build Coastguard Worker DST(1, 0) = DST(0, 2) = AVG2(B, C);
335*fb1b10abSAndroid Build Coastguard Worker DST(2, 0) = DST(1, 2) = AVG2(C, D);
336*fb1b10abSAndroid Build Coastguard Worker DST(3, 0) = DST(2, 2) = AVG2(D, E);
337*fb1b10abSAndroid Build Coastguard Worker DST(3, 2) = AVG3(E, F, G);
338*fb1b10abSAndroid Build Coastguard Worker
339*fb1b10abSAndroid Build Coastguard Worker DST(0, 1) = AVG3(A, B, C);
340*fb1b10abSAndroid Build Coastguard Worker DST(1, 1) = DST(0, 3) = AVG3(B, C, D);
341*fb1b10abSAndroid Build Coastguard Worker DST(2, 1) = DST(1, 3) = AVG3(C, D, E);
342*fb1b10abSAndroid Build Coastguard Worker DST(3, 1) = DST(2, 3) = AVG3(D, E, F);
343*fb1b10abSAndroid Build Coastguard Worker DST(3, 3) = AVG3(F, G, H);
344*fb1b10abSAndroid Build Coastguard Worker }
345*fb1b10abSAndroid Build Coastguard Worker
vpx_d45_predictor_4x4_c(uint8_t * dst,ptrdiff_t stride,const uint8_t * above,const uint8_t * left)346*fb1b10abSAndroid Build Coastguard Worker void vpx_d45_predictor_4x4_c(uint8_t *dst, ptrdiff_t stride,
347*fb1b10abSAndroid Build Coastguard Worker const uint8_t *above, const uint8_t *left) {
348*fb1b10abSAndroid Build Coastguard Worker const int A = above[0];
349*fb1b10abSAndroid Build Coastguard Worker const int B = above[1];
350*fb1b10abSAndroid Build Coastguard Worker const int C = above[2];
351*fb1b10abSAndroid Build Coastguard Worker const int D = above[3];
352*fb1b10abSAndroid Build Coastguard Worker const int E = above[4];
353*fb1b10abSAndroid Build Coastguard Worker const int F = above[5];
354*fb1b10abSAndroid Build Coastguard Worker const int G = above[6];
355*fb1b10abSAndroid Build Coastguard Worker const int H = above[7];
356*fb1b10abSAndroid Build Coastguard Worker (void)stride;
357*fb1b10abSAndroid Build Coastguard Worker (void)left;
358*fb1b10abSAndroid Build Coastguard Worker DST(0, 0) = AVG3(A, B, C);
359*fb1b10abSAndroid Build Coastguard Worker DST(1, 0) = DST(0, 1) = AVG3(B, C, D);
360*fb1b10abSAndroid Build Coastguard Worker DST(2, 0) = DST(1, 1) = DST(0, 2) = AVG3(C, D, E);
361*fb1b10abSAndroid Build Coastguard Worker DST(3, 0) = DST(2, 1) = DST(1, 2) = DST(0, 3) = AVG3(D, E, F);
362*fb1b10abSAndroid Build Coastguard Worker DST(3, 1) = DST(2, 2) = DST(1, 3) = AVG3(E, F, G);
363*fb1b10abSAndroid Build Coastguard Worker DST(3, 2) = DST(2, 3) = AVG3(F, G, H);
364*fb1b10abSAndroid Build Coastguard Worker DST(3, 3) = H; // differs from vp8
365*fb1b10abSAndroid Build Coastguard Worker }
366*fb1b10abSAndroid Build Coastguard Worker
vpx_d45e_predictor_4x4_c(uint8_t * dst,ptrdiff_t stride,const uint8_t * above,const uint8_t * left)367*fb1b10abSAndroid Build Coastguard Worker void vpx_d45e_predictor_4x4_c(uint8_t *dst, ptrdiff_t stride,
368*fb1b10abSAndroid Build Coastguard Worker const uint8_t *above, const uint8_t *left) {
369*fb1b10abSAndroid Build Coastguard Worker const int A = above[0];
370*fb1b10abSAndroid Build Coastguard Worker const int B = above[1];
371*fb1b10abSAndroid Build Coastguard Worker const int C = above[2];
372*fb1b10abSAndroid Build Coastguard Worker const int D = above[3];
373*fb1b10abSAndroid Build Coastguard Worker const int E = above[4];
374*fb1b10abSAndroid Build Coastguard Worker const int F = above[5];
375*fb1b10abSAndroid Build Coastguard Worker const int G = above[6];
376*fb1b10abSAndroid Build Coastguard Worker const int H = above[7];
377*fb1b10abSAndroid Build Coastguard Worker (void)stride;
378*fb1b10abSAndroid Build Coastguard Worker (void)left;
379*fb1b10abSAndroid Build Coastguard Worker DST(0, 0) = AVG3(A, B, C);
380*fb1b10abSAndroid Build Coastguard Worker DST(1, 0) = DST(0, 1) = AVG3(B, C, D);
381*fb1b10abSAndroid Build Coastguard Worker DST(2, 0) = DST(1, 1) = DST(0, 2) = AVG3(C, D, E);
382*fb1b10abSAndroid Build Coastguard Worker DST(3, 0) = DST(2, 1) = DST(1, 2) = DST(0, 3) = AVG3(D, E, F);
383*fb1b10abSAndroid Build Coastguard Worker DST(3, 1) = DST(2, 2) = DST(1, 3) = AVG3(E, F, G);
384*fb1b10abSAndroid Build Coastguard Worker DST(3, 2) = DST(2, 3) = AVG3(F, G, H);
385*fb1b10abSAndroid Build Coastguard Worker DST(3, 3) = AVG3(G, H, H);
386*fb1b10abSAndroid Build Coastguard Worker }
387*fb1b10abSAndroid Build Coastguard Worker
vpx_d117_predictor_4x4_c(uint8_t * dst,ptrdiff_t stride,const uint8_t * above,const uint8_t * left)388*fb1b10abSAndroid Build Coastguard Worker void vpx_d117_predictor_4x4_c(uint8_t *dst, ptrdiff_t stride,
389*fb1b10abSAndroid Build Coastguard Worker const uint8_t *above, const uint8_t *left) {
390*fb1b10abSAndroid Build Coastguard Worker const int I = left[0];
391*fb1b10abSAndroid Build Coastguard Worker const int J = left[1];
392*fb1b10abSAndroid Build Coastguard Worker const int K = left[2];
393*fb1b10abSAndroid Build Coastguard Worker const int X = above[-1];
394*fb1b10abSAndroid Build Coastguard Worker const int A = above[0];
395*fb1b10abSAndroid Build Coastguard Worker const int B = above[1];
396*fb1b10abSAndroid Build Coastguard Worker const int C = above[2];
397*fb1b10abSAndroid Build Coastguard Worker const int D = above[3];
398*fb1b10abSAndroid Build Coastguard Worker DST(0, 0) = DST(1, 2) = AVG2(X, A);
399*fb1b10abSAndroid Build Coastguard Worker DST(1, 0) = DST(2, 2) = AVG2(A, B);
400*fb1b10abSAndroid Build Coastguard Worker DST(2, 0) = DST(3, 2) = AVG2(B, C);
401*fb1b10abSAndroid Build Coastguard Worker DST(3, 0) = AVG2(C, D);
402*fb1b10abSAndroid Build Coastguard Worker
403*fb1b10abSAndroid Build Coastguard Worker DST(0, 3) = AVG3(K, J, I);
404*fb1b10abSAndroid Build Coastguard Worker DST(0, 2) = AVG3(J, I, X);
405*fb1b10abSAndroid Build Coastguard Worker DST(0, 1) = DST(1, 3) = AVG3(I, X, A);
406*fb1b10abSAndroid Build Coastguard Worker DST(1, 1) = DST(2, 3) = AVG3(X, A, B);
407*fb1b10abSAndroid Build Coastguard Worker DST(2, 1) = DST(3, 3) = AVG3(A, B, C);
408*fb1b10abSAndroid Build Coastguard Worker DST(3, 1) = AVG3(B, C, D);
409*fb1b10abSAndroid Build Coastguard Worker }
410*fb1b10abSAndroid Build Coastguard Worker
vpx_d135_predictor_4x4_c(uint8_t * dst,ptrdiff_t stride,const uint8_t * above,const uint8_t * left)411*fb1b10abSAndroid Build Coastguard Worker void vpx_d135_predictor_4x4_c(uint8_t *dst, ptrdiff_t stride,
412*fb1b10abSAndroid Build Coastguard Worker const uint8_t *above, const uint8_t *left) {
413*fb1b10abSAndroid Build Coastguard Worker const int I = left[0];
414*fb1b10abSAndroid Build Coastguard Worker const int J = left[1];
415*fb1b10abSAndroid Build Coastguard Worker const int K = left[2];
416*fb1b10abSAndroid Build Coastguard Worker const int L = left[3];
417*fb1b10abSAndroid Build Coastguard Worker const int X = above[-1];
418*fb1b10abSAndroid Build Coastguard Worker const int A = above[0];
419*fb1b10abSAndroid Build Coastguard Worker const int B = above[1];
420*fb1b10abSAndroid Build Coastguard Worker const int C = above[2];
421*fb1b10abSAndroid Build Coastguard Worker const int D = above[3];
422*fb1b10abSAndroid Build Coastguard Worker (void)stride;
423*fb1b10abSAndroid Build Coastguard Worker DST(0, 3) = AVG3(J, K, L);
424*fb1b10abSAndroid Build Coastguard Worker DST(1, 3) = DST(0, 2) = AVG3(I, J, K);
425*fb1b10abSAndroid Build Coastguard Worker DST(2, 3) = DST(1, 2) = DST(0, 1) = AVG3(X, I, J);
426*fb1b10abSAndroid Build Coastguard Worker DST(3, 3) = DST(2, 2) = DST(1, 1) = DST(0, 0) = AVG3(A, X, I);
427*fb1b10abSAndroid Build Coastguard Worker DST(3, 2) = DST(2, 1) = DST(1, 0) = AVG3(B, A, X);
428*fb1b10abSAndroid Build Coastguard Worker DST(3, 1) = DST(2, 0) = AVG3(C, B, A);
429*fb1b10abSAndroid Build Coastguard Worker DST(3, 0) = AVG3(D, C, B);
430*fb1b10abSAndroid Build Coastguard Worker }
431*fb1b10abSAndroid Build Coastguard Worker
vpx_d153_predictor_4x4_c(uint8_t * dst,ptrdiff_t stride,const uint8_t * above,const uint8_t * left)432*fb1b10abSAndroid Build Coastguard Worker void vpx_d153_predictor_4x4_c(uint8_t *dst, ptrdiff_t stride,
433*fb1b10abSAndroid Build Coastguard Worker const uint8_t *above, const uint8_t *left) {
434*fb1b10abSAndroid Build Coastguard Worker const int I = left[0];
435*fb1b10abSAndroid Build Coastguard Worker const int J = left[1];
436*fb1b10abSAndroid Build Coastguard Worker const int K = left[2];
437*fb1b10abSAndroid Build Coastguard Worker const int L = left[3];
438*fb1b10abSAndroid Build Coastguard Worker const int X = above[-1];
439*fb1b10abSAndroid Build Coastguard Worker const int A = above[0];
440*fb1b10abSAndroid Build Coastguard Worker const int B = above[1];
441*fb1b10abSAndroid Build Coastguard Worker const int C = above[2];
442*fb1b10abSAndroid Build Coastguard Worker
443*fb1b10abSAndroid Build Coastguard Worker DST(0, 0) = DST(2, 1) = AVG2(I, X);
444*fb1b10abSAndroid Build Coastguard Worker DST(0, 1) = DST(2, 2) = AVG2(J, I);
445*fb1b10abSAndroid Build Coastguard Worker DST(0, 2) = DST(2, 3) = AVG2(K, J);
446*fb1b10abSAndroid Build Coastguard Worker DST(0, 3) = AVG2(L, K);
447*fb1b10abSAndroid Build Coastguard Worker
448*fb1b10abSAndroid Build Coastguard Worker DST(3, 0) = AVG3(A, B, C);
449*fb1b10abSAndroid Build Coastguard Worker DST(2, 0) = AVG3(X, A, B);
450*fb1b10abSAndroid Build Coastguard Worker DST(1, 0) = DST(3, 1) = AVG3(I, X, A);
451*fb1b10abSAndroid Build Coastguard Worker DST(1, 1) = DST(3, 2) = AVG3(J, I, X);
452*fb1b10abSAndroid Build Coastguard Worker DST(1, 2) = DST(3, 3) = AVG3(K, J, I);
453*fb1b10abSAndroid Build Coastguard Worker DST(1, 3) = AVG3(L, K, J);
454*fb1b10abSAndroid Build Coastguard Worker }
455*fb1b10abSAndroid Build Coastguard Worker
456*fb1b10abSAndroid Build Coastguard Worker #if CONFIG_VP9_HIGHBITDEPTH
highbd_d207_predictor(uint16_t * dst,ptrdiff_t stride,int bs,const uint16_t * above,const uint16_t * left,int bd)457*fb1b10abSAndroid Build Coastguard Worker static INLINE void highbd_d207_predictor(uint16_t *dst, ptrdiff_t stride,
458*fb1b10abSAndroid Build Coastguard Worker int bs, const uint16_t *above,
459*fb1b10abSAndroid Build Coastguard Worker const uint16_t *left, int bd) {
460*fb1b10abSAndroid Build Coastguard Worker int r, c;
461*fb1b10abSAndroid Build Coastguard Worker (void)above;
462*fb1b10abSAndroid Build Coastguard Worker (void)bd;
463*fb1b10abSAndroid Build Coastguard Worker
464*fb1b10abSAndroid Build Coastguard Worker // First column.
465*fb1b10abSAndroid Build Coastguard Worker for (r = 0; r < bs - 1; ++r) {
466*fb1b10abSAndroid Build Coastguard Worker dst[r * stride] = AVG2(left[r], left[r + 1]);
467*fb1b10abSAndroid Build Coastguard Worker }
468*fb1b10abSAndroid Build Coastguard Worker dst[(bs - 1) * stride] = left[bs - 1];
469*fb1b10abSAndroid Build Coastguard Worker dst++;
470*fb1b10abSAndroid Build Coastguard Worker
471*fb1b10abSAndroid Build Coastguard Worker // Second column.
472*fb1b10abSAndroid Build Coastguard Worker for (r = 0; r < bs - 2; ++r) {
473*fb1b10abSAndroid Build Coastguard Worker dst[r * stride] = AVG3(left[r], left[r + 1], left[r + 2]);
474*fb1b10abSAndroid Build Coastguard Worker }
475*fb1b10abSAndroid Build Coastguard Worker dst[(bs - 2) * stride] = AVG3(left[bs - 2], left[bs - 1], left[bs - 1]);
476*fb1b10abSAndroid Build Coastguard Worker dst[(bs - 1) * stride] = left[bs - 1];
477*fb1b10abSAndroid Build Coastguard Worker dst++;
478*fb1b10abSAndroid Build Coastguard Worker
479*fb1b10abSAndroid Build Coastguard Worker // Rest of last row.
480*fb1b10abSAndroid Build Coastguard Worker for (c = 0; c < bs - 2; ++c) dst[(bs - 1) * stride + c] = left[bs - 1];
481*fb1b10abSAndroid Build Coastguard Worker
482*fb1b10abSAndroid Build Coastguard Worker for (r = bs - 2; r >= 0; --r) {
483*fb1b10abSAndroid Build Coastguard Worker for (c = 0; c < bs - 2; ++c)
484*fb1b10abSAndroid Build Coastguard Worker dst[r * stride + c] = dst[(r + 1) * stride + c - 2];
485*fb1b10abSAndroid Build Coastguard Worker }
486*fb1b10abSAndroid Build Coastguard Worker }
487*fb1b10abSAndroid Build Coastguard Worker
highbd_d63_predictor(uint16_t * dst,ptrdiff_t stride,int bs,const uint16_t * above,const uint16_t * left,int bd)488*fb1b10abSAndroid Build Coastguard Worker static INLINE void highbd_d63_predictor(uint16_t *dst, ptrdiff_t stride, int bs,
489*fb1b10abSAndroid Build Coastguard Worker const uint16_t *above,
490*fb1b10abSAndroid Build Coastguard Worker const uint16_t *left, int bd) {
491*fb1b10abSAndroid Build Coastguard Worker int r, c;
492*fb1b10abSAndroid Build Coastguard Worker int size;
493*fb1b10abSAndroid Build Coastguard Worker (void)left;
494*fb1b10abSAndroid Build Coastguard Worker (void)bd;
495*fb1b10abSAndroid Build Coastguard Worker for (c = 0; c < bs; ++c) {
496*fb1b10abSAndroid Build Coastguard Worker dst[c] = AVG2(above[c], above[c + 1]);
497*fb1b10abSAndroid Build Coastguard Worker dst[stride + c] = AVG3(above[c], above[c + 1], above[c + 2]);
498*fb1b10abSAndroid Build Coastguard Worker }
499*fb1b10abSAndroid Build Coastguard Worker for (r = 2, size = bs - 2; r < bs; r += 2, --size) {
500*fb1b10abSAndroid Build Coastguard Worker memcpy(dst + (r + 0) * stride, dst + (r >> 1), size * sizeof(*dst));
501*fb1b10abSAndroid Build Coastguard Worker vpx_memset16(dst + (r + 0) * stride + size, above[bs - 1], bs - size);
502*fb1b10abSAndroid Build Coastguard Worker memcpy(dst + (r + 1) * stride, dst + stride + (r >> 1),
503*fb1b10abSAndroid Build Coastguard Worker size * sizeof(*dst));
504*fb1b10abSAndroid Build Coastguard Worker vpx_memset16(dst + (r + 1) * stride + size, above[bs - 1], bs - size);
505*fb1b10abSAndroid Build Coastguard Worker }
506*fb1b10abSAndroid Build Coastguard Worker }
507*fb1b10abSAndroid Build Coastguard Worker
highbd_d45_predictor(uint16_t * dst,ptrdiff_t stride,int bs,const uint16_t * above,const uint16_t * left,int bd)508*fb1b10abSAndroid Build Coastguard Worker static INLINE void highbd_d45_predictor(uint16_t *dst, ptrdiff_t stride, int bs,
509*fb1b10abSAndroid Build Coastguard Worker const uint16_t *above,
510*fb1b10abSAndroid Build Coastguard Worker const uint16_t *left, int bd) {
511*fb1b10abSAndroid Build Coastguard Worker const uint16_t above_right = above[bs - 1];
512*fb1b10abSAndroid Build Coastguard Worker const uint16_t *const dst_row0 = dst;
513*fb1b10abSAndroid Build Coastguard Worker int x, size;
514*fb1b10abSAndroid Build Coastguard Worker (void)left;
515*fb1b10abSAndroid Build Coastguard Worker (void)bd;
516*fb1b10abSAndroid Build Coastguard Worker
517*fb1b10abSAndroid Build Coastguard Worker for (x = 0; x < bs - 1; ++x) {
518*fb1b10abSAndroid Build Coastguard Worker dst[x] = AVG3(above[x], above[x + 1], above[x + 2]);
519*fb1b10abSAndroid Build Coastguard Worker }
520*fb1b10abSAndroid Build Coastguard Worker dst[bs - 1] = above_right;
521*fb1b10abSAndroid Build Coastguard Worker dst += stride;
522*fb1b10abSAndroid Build Coastguard Worker for (x = 1, size = bs - 2; x < bs; ++x, --size) {
523*fb1b10abSAndroid Build Coastguard Worker memcpy(dst, dst_row0 + x, size * sizeof(*dst));
524*fb1b10abSAndroid Build Coastguard Worker vpx_memset16(dst + size, above_right, x + 1);
525*fb1b10abSAndroid Build Coastguard Worker dst += stride;
526*fb1b10abSAndroid Build Coastguard Worker }
527*fb1b10abSAndroid Build Coastguard Worker }
528*fb1b10abSAndroid Build Coastguard Worker
highbd_d117_predictor(uint16_t * dst,ptrdiff_t stride,int bs,const uint16_t * above,const uint16_t * left,int bd)529*fb1b10abSAndroid Build Coastguard Worker static INLINE void highbd_d117_predictor(uint16_t *dst, ptrdiff_t stride,
530*fb1b10abSAndroid Build Coastguard Worker int bs, const uint16_t *above,
531*fb1b10abSAndroid Build Coastguard Worker const uint16_t *left, int bd) {
532*fb1b10abSAndroid Build Coastguard Worker int r, c;
533*fb1b10abSAndroid Build Coastguard Worker (void)bd;
534*fb1b10abSAndroid Build Coastguard Worker
535*fb1b10abSAndroid Build Coastguard Worker // first row
536*fb1b10abSAndroid Build Coastguard Worker for (c = 0; c < bs; c++) dst[c] = AVG2(above[c - 1], above[c]);
537*fb1b10abSAndroid Build Coastguard Worker dst += stride;
538*fb1b10abSAndroid Build Coastguard Worker
539*fb1b10abSAndroid Build Coastguard Worker // second row
540*fb1b10abSAndroid Build Coastguard Worker dst[0] = AVG3(left[0], above[-1], above[0]);
541*fb1b10abSAndroid Build Coastguard Worker for (c = 1; c < bs; c++) dst[c] = AVG3(above[c - 2], above[c - 1], above[c]);
542*fb1b10abSAndroid Build Coastguard Worker dst += stride;
543*fb1b10abSAndroid Build Coastguard Worker
544*fb1b10abSAndroid Build Coastguard Worker // the rest of first col
545*fb1b10abSAndroid Build Coastguard Worker dst[0] = AVG3(above[-1], left[0], left[1]);
546*fb1b10abSAndroid Build Coastguard Worker for (r = 3; r < bs; ++r)
547*fb1b10abSAndroid Build Coastguard Worker dst[(r - 2) * stride] = AVG3(left[r - 3], left[r - 2], left[r - 1]);
548*fb1b10abSAndroid Build Coastguard Worker
549*fb1b10abSAndroid Build Coastguard Worker // the rest of the block
550*fb1b10abSAndroid Build Coastguard Worker for (r = 2; r < bs; ++r) {
551*fb1b10abSAndroid Build Coastguard Worker for (c = 1; c < bs; c++) dst[c] = dst[-2 * stride + c - 1];
552*fb1b10abSAndroid Build Coastguard Worker dst += stride;
553*fb1b10abSAndroid Build Coastguard Worker }
554*fb1b10abSAndroid Build Coastguard Worker }
555*fb1b10abSAndroid Build Coastguard Worker
highbd_d135_predictor(uint16_t * dst,ptrdiff_t stride,int bs,const uint16_t * above,const uint16_t * left,int bd)556*fb1b10abSAndroid Build Coastguard Worker static INLINE void highbd_d135_predictor(uint16_t *dst, ptrdiff_t stride,
557*fb1b10abSAndroid Build Coastguard Worker int bs, const uint16_t *above,
558*fb1b10abSAndroid Build Coastguard Worker const uint16_t *left, int bd) {
559*fb1b10abSAndroid Build Coastguard Worker int i;
560*fb1b10abSAndroid Build Coastguard Worker #if defined(__GNUC__) && __GNUC__ == 4 && __GNUC_MINOR__ > 7
561*fb1b10abSAndroid Build Coastguard Worker // silence a spurious -Warray-bounds warning, possibly related to:
562*fb1b10abSAndroid Build Coastguard Worker // https://gcc.gnu.org/bugzilla/show_bug.cgi?id=56273
563*fb1b10abSAndroid Build Coastguard Worker uint16_t border[69];
564*fb1b10abSAndroid Build Coastguard Worker #else
565*fb1b10abSAndroid Build Coastguard Worker uint16_t border[32 + 32 - 1]; // outer border from bottom-left to top-right
566*fb1b10abSAndroid Build Coastguard Worker #endif
567*fb1b10abSAndroid Build Coastguard Worker (void)bd;
568*fb1b10abSAndroid Build Coastguard Worker
569*fb1b10abSAndroid Build Coastguard Worker // dst(bs, bs - 2)[0], i.e., border starting at bottom-left
570*fb1b10abSAndroid Build Coastguard Worker for (i = 0; i < bs - 2; ++i) {
571*fb1b10abSAndroid Build Coastguard Worker border[i] = AVG3(left[bs - 3 - i], left[bs - 2 - i], left[bs - 1 - i]);
572*fb1b10abSAndroid Build Coastguard Worker }
573*fb1b10abSAndroid Build Coastguard Worker border[bs - 2] = AVG3(above[-1], left[0], left[1]);
574*fb1b10abSAndroid Build Coastguard Worker border[bs - 1] = AVG3(left[0], above[-1], above[0]);
575*fb1b10abSAndroid Build Coastguard Worker border[bs - 0] = AVG3(above[-1], above[0], above[1]);
576*fb1b10abSAndroid Build Coastguard Worker // dst[0][2, size), i.e., remaining top border ascending
577*fb1b10abSAndroid Build Coastguard Worker for (i = 0; i < bs - 2; ++i) {
578*fb1b10abSAndroid Build Coastguard Worker border[bs + 1 + i] = AVG3(above[i], above[i + 1], above[i + 2]);
579*fb1b10abSAndroid Build Coastguard Worker }
580*fb1b10abSAndroid Build Coastguard Worker
581*fb1b10abSAndroid Build Coastguard Worker for (i = 0; i < bs; ++i) {
582*fb1b10abSAndroid Build Coastguard Worker memcpy(dst + i * stride, border + bs - 1 - i, bs * sizeof(dst[0]));
583*fb1b10abSAndroid Build Coastguard Worker }
584*fb1b10abSAndroid Build Coastguard Worker }
585*fb1b10abSAndroid Build Coastguard Worker
highbd_d153_predictor(uint16_t * dst,ptrdiff_t stride,int bs,const uint16_t * above,const uint16_t * left,int bd)586*fb1b10abSAndroid Build Coastguard Worker static INLINE void highbd_d153_predictor(uint16_t *dst, ptrdiff_t stride,
587*fb1b10abSAndroid Build Coastguard Worker int bs, const uint16_t *above,
588*fb1b10abSAndroid Build Coastguard Worker const uint16_t *left, int bd) {
589*fb1b10abSAndroid Build Coastguard Worker int r, c;
590*fb1b10abSAndroid Build Coastguard Worker (void)bd;
591*fb1b10abSAndroid Build Coastguard Worker dst[0] = AVG2(above[-1], left[0]);
592*fb1b10abSAndroid Build Coastguard Worker for (r = 1; r < bs; r++) dst[r * stride] = AVG2(left[r - 1], left[r]);
593*fb1b10abSAndroid Build Coastguard Worker dst++;
594*fb1b10abSAndroid Build Coastguard Worker
595*fb1b10abSAndroid Build Coastguard Worker dst[0] = AVG3(left[0], above[-1], above[0]);
596*fb1b10abSAndroid Build Coastguard Worker dst[stride] = AVG3(above[-1], left[0], left[1]);
597*fb1b10abSAndroid Build Coastguard Worker for (r = 2; r < bs; r++)
598*fb1b10abSAndroid Build Coastguard Worker dst[r * stride] = AVG3(left[r - 2], left[r - 1], left[r]);
599*fb1b10abSAndroid Build Coastguard Worker dst++;
600*fb1b10abSAndroid Build Coastguard Worker
601*fb1b10abSAndroid Build Coastguard Worker for (c = 0; c < bs - 2; c++)
602*fb1b10abSAndroid Build Coastguard Worker dst[c] = AVG3(above[c - 1], above[c], above[c + 1]);
603*fb1b10abSAndroid Build Coastguard Worker dst += stride;
604*fb1b10abSAndroid Build Coastguard Worker
605*fb1b10abSAndroid Build Coastguard Worker for (r = 1; r < bs; ++r) {
606*fb1b10abSAndroid Build Coastguard Worker for (c = 0; c < bs - 2; c++) dst[c] = dst[-stride + c - 2];
607*fb1b10abSAndroid Build Coastguard Worker dst += stride;
608*fb1b10abSAndroid Build Coastguard Worker }
609*fb1b10abSAndroid Build Coastguard Worker }
610*fb1b10abSAndroid Build Coastguard Worker
highbd_v_predictor(uint16_t * dst,ptrdiff_t stride,int bs,const uint16_t * above,const uint16_t * left,int bd)611*fb1b10abSAndroid Build Coastguard Worker static INLINE void highbd_v_predictor(uint16_t *dst, ptrdiff_t stride, int bs,
612*fb1b10abSAndroid Build Coastguard Worker const uint16_t *above,
613*fb1b10abSAndroid Build Coastguard Worker const uint16_t *left, int bd) {
614*fb1b10abSAndroid Build Coastguard Worker int r;
615*fb1b10abSAndroid Build Coastguard Worker (void)left;
616*fb1b10abSAndroid Build Coastguard Worker (void)bd;
617*fb1b10abSAndroid Build Coastguard Worker for (r = 0; r < bs; r++) {
618*fb1b10abSAndroid Build Coastguard Worker memcpy(dst, above, bs * sizeof(uint16_t));
619*fb1b10abSAndroid Build Coastguard Worker dst += stride;
620*fb1b10abSAndroid Build Coastguard Worker }
621*fb1b10abSAndroid Build Coastguard Worker }
622*fb1b10abSAndroid Build Coastguard Worker
highbd_h_predictor(uint16_t * dst,ptrdiff_t stride,int bs,const uint16_t * above,const uint16_t * left,int bd)623*fb1b10abSAndroid Build Coastguard Worker static INLINE void highbd_h_predictor(uint16_t *dst, ptrdiff_t stride, int bs,
624*fb1b10abSAndroid Build Coastguard Worker const uint16_t *above,
625*fb1b10abSAndroid Build Coastguard Worker const uint16_t *left, int bd) {
626*fb1b10abSAndroid Build Coastguard Worker int r;
627*fb1b10abSAndroid Build Coastguard Worker (void)above;
628*fb1b10abSAndroid Build Coastguard Worker (void)bd;
629*fb1b10abSAndroid Build Coastguard Worker for (r = 0; r < bs; r++) {
630*fb1b10abSAndroid Build Coastguard Worker vpx_memset16(dst, left[r], bs);
631*fb1b10abSAndroid Build Coastguard Worker dst += stride;
632*fb1b10abSAndroid Build Coastguard Worker }
633*fb1b10abSAndroid Build Coastguard Worker }
634*fb1b10abSAndroid Build Coastguard Worker
highbd_tm_predictor(uint16_t * dst,ptrdiff_t stride,int bs,const uint16_t * above,const uint16_t * left,int bd)635*fb1b10abSAndroid Build Coastguard Worker static INLINE void highbd_tm_predictor(uint16_t *dst, ptrdiff_t stride, int bs,
636*fb1b10abSAndroid Build Coastguard Worker const uint16_t *above,
637*fb1b10abSAndroid Build Coastguard Worker const uint16_t *left, int bd) {
638*fb1b10abSAndroid Build Coastguard Worker int r, c;
639*fb1b10abSAndroid Build Coastguard Worker int ytop_left = above[-1];
640*fb1b10abSAndroid Build Coastguard Worker (void)bd;
641*fb1b10abSAndroid Build Coastguard Worker
642*fb1b10abSAndroid Build Coastguard Worker for (r = 0; r < bs; r++) {
643*fb1b10abSAndroid Build Coastguard Worker for (c = 0; c < bs; c++)
644*fb1b10abSAndroid Build Coastguard Worker dst[c] = clip_pixel_highbd(left[r] + above[c] - ytop_left, bd);
645*fb1b10abSAndroid Build Coastguard Worker dst += stride;
646*fb1b10abSAndroid Build Coastguard Worker }
647*fb1b10abSAndroid Build Coastguard Worker }
648*fb1b10abSAndroid Build Coastguard Worker
highbd_dc_128_predictor(uint16_t * dst,ptrdiff_t stride,int bs,const uint16_t * above,const uint16_t * left,int bd)649*fb1b10abSAndroid Build Coastguard Worker static INLINE void highbd_dc_128_predictor(uint16_t *dst, ptrdiff_t stride,
650*fb1b10abSAndroid Build Coastguard Worker int bs, const uint16_t *above,
651*fb1b10abSAndroid Build Coastguard Worker const uint16_t *left, int bd) {
652*fb1b10abSAndroid Build Coastguard Worker int r;
653*fb1b10abSAndroid Build Coastguard Worker (void)above;
654*fb1b10abSAndroid Build Coastguard Worker (void)left;
655*fb1b10abSAndroid Build Coastguard Worker
656*fb1b10abSAndroid Build Coastguard Worker for (r = 0; r < bs; r++) {
657*fb1b10abSAndroid Build Coastguard Worker vpx_memset16(dst, 128 << (bd - 8), bs);
658*fb1b10abSAndroid Build Coastguard Worker dst += stride;
659*fb1b10abSAndroid Build Coastguard Worker }
660*fb1b10abSAndroid Build Coastguard Worker }
661*fb1b10abSAndroid Build Coastguard Worker
highbd_dc_left_predictor(uint16_t * dst,ptrdiff_t stride,int bs,const uint16_t * above,const uint16_t * left,int bd)662*fb1b10abSAndroid Build Coastguard Worker static INLINE void highbd_dc_left_predictor(uint16_t *dst, ptrdiff_t stride,
663*fb1b10abSAndroid Build Coastguard Worker int bs, const uint16_t *above,
664*fb1b10abSAndroid Build Coastguard Worker const uint16_t *left, int bd) {
665*fb1b10abSAndroid Build Coastguard Worker int i, r, expected_dc, sum = 0;
666*fb1b10abSAndroid Build Coastguard Worker (void)above;
667*fb1b10abSAndroid Build Coastguard Worker (void)bd;
668*fb1b10abSAndroid Build Coastguard Worker
669*fb1b10abSAndroid Build Coastguard Worker for (i = 0; i < bs; i++) sum += left[i];
670*fb1b10abSAndroid Build Coastguard Worker expected_dc = (sum + (bs >> 1)) / bs;
671*fb1b10abSAndroid Build Coastguard Worker
672*fb1b10abSAndroid Build Coastguard Worker for (r = 0; r < bs; r++) {
673*fb1b10abSAndroid Build Coastguard Worker vpx_memset16(dst, expected_dc, bs);
674*fb1b10abSAndroid Build Coastguard Worker dst += stride;
675*fb1b10abSAndroid Build Coastguard Worker }
676*fb1b10abSAndroid Build Coastguard Worker }
677*fb1b10abSAndroid Build Coastguard Worker
highbd_dc_top_predictor(uint16_t * dst,ptrdiff_t stride,int bs,const uint16_t * above,const uint16_t * left,int bd)678*fb1b10abSAndroid Build Coastguard Worker static INLINE void highbd_dc_top_predictor(uint16_t *dst, ptrdiff_t stride,
679*fb1b10abSAndroid Build Coastguard Worker int bs, const uint16_t *above,
680*fb1b10abSAndroid Build Coastguard Worker const uint16_t *left, int bd) {
681*fb1b10abSAndroid Build Coastguard Worker int i, r, expected_dc, sum = 0;
682*fb1b10abSAndroid Build Coastguard Worker (void)left;
683*fb1b10abSAndroid Build Coastguard Worker (void)bd;
684*fb1b10abSAndroid Build Coastguard Worker
685*fb1b10abSAndroid Build Coastguard Worker for (i = 0; i < bs; i++) sum += above[i];
686*fb1b10abSAndroid Build Coastguard Worker expected_dc = (sum + (bs >> 1)) / bs;
687*fb1b10abSAndroid Build Coastguard Worker
688*fb1b10abSAndroid Build Coastguard Worker for (r = 0; r < bs; r++) {
689*fb1b10abSAndroid Build Coastguard Worker vpx_memset16(dst, expected_dc, bs);
690*fb1b10abSAndroid Build Coastguard Worker dst += stride;
691*fb1b10abSAndroid Build Coastguard Worker }
692*fb1b10abSAndroid Build Coastguard Worker }
693*fb1b10abSAndroid Build Coastguard Worker
highbd_dc_predictor(uint16_t * dst,ptrdiff_t stride,int bs,const uint16_t * above,const uint16_t * left,int bd)694*fb1b10abSAndroid Build Coastguard Worker static INLINE void highbd_dc_predictor(uint16_t *dst, ptrdiff_t stride, int bs,
695*fb1b10abSAndroid Build Coastguard Worker const uint16_t *above,
696*fb1b10abSAndroid Build Coastguard Worker const uint16_t *left, int bd) {
697*fb1b10abSAndroid Build Coastguard Worker int i, r, expected_dc, sum = 0;
698*fb1b10abSAndroid Build Coastguard Worker const int count = 2 * bs;
699*fb1b10abSAndroid Build Coastguard Worker (void)bd;
700*fb1b10abSAndroid Build Coastguard Worker
701*fb1b10abSAndroid Build Coastguard Worker for (i = 0; i < bs; i++) {
702*fb1b10abSAndroid Build Coastguard Worker sum += above[i];
703*fb1b10abSAndroid Build Coastguard Worker sum += left[i];
704*fb1b10abSAndroid Build Coastguard Worker }
705*fb1b10abSAndroid Build Coastguard Worker
706*fb1b10abSAndroid Build Coastguard Worker expected_dc = (sum + (count >> 1)) / count;
707*fb1b10abSAndroid Build Coastguard Worker
708*fb1b10abSAndroid Build Coastguard Worker for (r = 0; r < bs; r++) {
709*fb1b10abSAndroid Build Coastguard Worker vpx_memset16(dst, expected_dc, bs);
710*fb1b10abSAndroid Build Coastguard Worker dst += stride;
711*fb1b10abSAndroid Build Coastguard Worker }
712*fb1b10abSAndroid Build Coastguard Worker }
713*fb1b10abSAndroid Build Coastguard Worker
vpx_highbd_d207_predictor_4x4_c(uint16_t * dst,ptrdiff_t stride,const uint16_t * above,const uint16_t * left,int bd)714*fb1b10abSAndroid Build Coastguard Worker void vpx_highbd_d207_predictor_4x4_c(uint16_t *dst, ptrdiff_t stride,
715*fb1b10abSAndroid Build Coastguard Worker const uint16_t *above,
716*fb1b10abSAndroid Build Coastguard Worker const uint16_t *left, int bd) {
717*fb1b10abSAndroid Build Coastguard Worker const int I = left[0];
718*fb1b10abSAndroid Build Coastguard Worker const int J = left[1];
719*fb1b10abSAndroid Build Coastguard Worker const int K = left[2];
720*fb1b10abSAndroid Build Coastguard Worker const int L = left[3];
721*fb1b10abSAndroid Build Coastguard Worker (void)above;
722*fb1b10abSAndroid Build Coastguard Worker (void)bd;
723*fb1b10abSAndroid Build Coastguard Worker DST(0, 0) = AVG2(I, J);
724*fb1b10abSAndroid Build Coastguard Worker DST(2, 0) = DST(0, 1) = AVG2(J, K);
725*fb1b10abSAndroid Build Coastguard Worker DST(2, 1) = DST(0, 2) = AVG2(K, L);
726*fb1b10abSAndroid Build Coastguard Worker DST(1, 0) = AVG3(I, J, K);
727*fb1b10abSAndroid Build Coastguard Worker DST(3, 0) = DST(1, 1) = AVG3(J, K, L);
728*fb1b10abSAndroid Build Coastguard Worker DST(3, 1) = DST(1, 2) = AVG3(K, L, L);
729*fb1b10abSAndroid Build Coastguard Worker DST(3, 2) = DST(2, 2) = DST(0, 3) = DST(1, 3) = DST(2, 3) = DST(3, 3) = L;
730*fb1b10abSAndroid Build Coastguard Worker }
731*fb1b10abSAndroid Build Coastguard Worker
vpx_highbd_d63_predictor_4x4_c(uint16_t * dst,ptrdiff_t stride,const uint16_t * above,const uint16_t * left,int bd)732*fb1b10abSAndroid Build Coastguard Worker void vpx_highbd_d63_predictor_4x4_c(uint16_t *dst, ptrdiff_t stride,
733*fb1b10abSAndroid Build Coastguard Worker const uint16_t *above, const uint16_t *left,
734*fb1b10abSAndroid Build Coastguard Worker int bd) {
735*fb1b10abSAndroid Build Coastguard Worker const int A = above[0];
736*fb1b10abSAndroid Build Coastguard Worker const int B = above[1];
737*fb1b10abSAndroid Build Coastguard Worker const int C = above[2];
738*fb1b10abSAndroid Build Coastguard Worker const int D = above[3];
739*fb1b10abSAndroid Build Coastguard Worker const int E = above[4];
740*fb1b10abSAndroid Build Coastguard Worker const int F = above[5];
741*fb1b10abSAndroid Build Coastguard Worker const int G = above[6];
742*fb1b10abSAndroid Build Coastguard Worker (void)left;
743*fb1b10abSAndroid Build Coastguard Worker (void)bd;
744*fb1b10abSAndroid Build Coastguard Worker DST(0, 0) = AVG2(A, B);
745*fb1b10abSAndroid Build Coastguard Worker DST(1, 0) = DST(0, 2) = AVG2(B, C);
746*fb1b10abSAndroid Build Coastguard Worker DST(2, 0) = DST(1, 2) = AVG2(C, D);
747*fb1b10abSAndroid Build Coastguard Worker DST(3, 0) = DST(2, 2) = AVG2(D, E);
748*fb1b10abSAndroid Build Coastguard Worker DST(3, 2) = AVG2(E, F); // differs from vp8
749*fb1b10abSAndroid Build Coastguard Worker
750*fb1b10abSAndroid Build Coastguard Worker DST(0, 1) = AVG3(A, B, C);
751*fb1b10abSAndroid Build Coastguard Worker DST(1, 1) = DST(0, 3) = AVG3(B, C, D);
752*fb1b10abSAndroid Build Coastguard Worker DST(2, 1) = DST(1, 3) = AVG3(C, D, E);
753*fb1b10abSAndroid Build Coastguard Worker DST(3, 1) = DST(2, 3) = AVG3(D, E, F);
754*fb1b10abSAndroid Build Coastguard Worker DST(3, 3) = AVG3(E, F, G); // differs from vp8
755*fb1b10abSAndroid Build Coastguard Worker }
756*fb1b10abSAndroid Build Coastguard Worker
vpx_highbd_d45_predictor_4x4_c(uint16_t * dst,ptrdiff_t stride,const uint16_t * above,const uint16_t * left,int bd)757*fb1b10abSAndroid Build Coastguard Worker void vpx_highbd_d45_predictor_4x4_c(uint16_t *dst, ptrdiff_t stride,
758*fb1b10abSAndroid Build Coastguard Worker const uint16_t *above, const uint16_t *left,
759*fb1b10abSAndroid Build Coastguard Worker int bd) {
760*fb1b10abSAndroid Build Coastguard Worker const int A = above[0];
761*fb1b10abSAndroid Build Coastguard Worker const int B = above[1];
762*fb1b10abSAndroid Build Coastguard Worker const int C = above[2];
763*fb1b10abSAndroid Build Coastguard Worker const int D = above[3];
764*fb1b10abSAndroid Build Coastguard Worker const int E = above[4];
765*fb1b10abSAndroid Build Coastguard Worker const int F = above[5];
766*fb1b10abSAndroid Build Coastguard Worker const int G = above[6];
767*fb1b10abSAndroid Build Coastguard Worker const int H = above[7];
768*fb1b10abSAndroid Build Coastguard Worker (void)left;
769*fb1b10abSAndroid Build Coastguard Worker (void)bd;
770*fb1b10abSAndroid Build Coastguard Worker DST(0, 0) = AVG3(A, B, C);
771*fb1b10abSAndroid Build Coastguard Worker DST(1, 0) = DST(0, 1) = AVG3(B, C, D);
772*fb1b10abSAndroid Build Coastguard Worker DST(2, 0) = DST(1, 1) = DST(0, 2) = AVG3(C, D, E);
773*fb1b10abSAndroid Build Coastguard Worker DST(3, 0) = DST(2, 1) = DST(1, 2) = DST(0, 3) = AVG3(D, E, F);
774*fb1b10abSAndroid Build Coastguard Worker DST(3, 1) = DST(2, 2) = DST(1, 3) = AVG3(E, F, G);
775*fb1b10abSAndroid Build Coastguard Worker DST(3, 2) = DST(2, 3) = AVG3(F, G, H);
776*fb1b10abSAndroid Build Coastguard Worker DST(3, 3) = H; // differs from vp8
777*fb1b10abSAndroid Build Coastguard Worker }
778*fb1b10abSAndroid Build Coastguard Worker
vpx_highbd_d117_predictor_4x4_c(uint16_t * dst,ptrdiff_t stride,const uint16_t * above,const uint16_t * left,int bd)779*fb1b10abSAndroid Build Coastguard Worker void vpx_highbd_d117_predictor_4x4_c(uint16_t *dst, ptrdiff_t stride,
780*fb1b10abSAndroid Build Coastguard Worker const uint16_t *above,
781*fb1b10abSAndroid Build Coastguard Worker const uint16_t *left, int bd) {
782*fb1b10abSAndroid Build Coastguard Worker const int I = left[0];
783*fb1b10abSAndroid Build Coastguard Worker const int J = left[1];
784*fb1b10abSAndroid Build Coastguard Worker const int K = left[2];
785*fb1b10abSAndroid Build Coastguard Worker const int X = above[-1];
786*fb1b10abSAndroid Build Coastguard Worker const int A = above[0];
787*fb1b10abSAndroid Build Coastguard Worker const int B = above[1];
788*fb1b10abSAndroid Build Coastguard Worker const int C = above[2];
789*fb1b10abSAndroid Build Coastguard Worker const int D = above[3];
790*fb1b10abSAndroid Build Coastguard Worker (void)bd;
791*fb1b10abSAndroid Build Coastguard Worker DST(0, 0) = DST(1, 2) = AVG2(X, A);
792*fb1b10abSAndroid Build Coastguard Worker DST(1, 0) = DST(2, 2) = AVG2(A, B);
793*fb1b10abSAndroid Build Coastguard Worker DST(2, 0) = DST(3, 2) = AVG2(B, C);
794*fb1b10abSAndroid Build Coastguard Worker DST(3, 0) = AVG2(C, D);
795*fb1b10abSAndroid Build Coastguard Worker
796*fb1b10abSAndroid Build Coastguard Worker DST(0, 3) = AVG3(K, J, I);
797*fb1b10abSAndroid Build Coastguard Worker DST(0, 2) = AVG3(J, I, X);
798*fb1b10abSAndroid Build Coastguard Worker DST(0, 1) = DST(1, 3) = AVG3(I, X, A);
799*fb1b10abSAndroid Build Coastguard Worker DST(1, 1) = DST(2, 3) = AVG3(X, A, B);
800*fb1b10abSAndroid Build Coastguard Worker DST(2, 1) = DST(3, 3) = AVG3(A, B, C);
801*fb1b10abSAndroid Build Coastguard Worker DST(3, 1) = AVG3(B, C, D);
802*fb1b10abSAndroid Build Coastguard Worker }
803*fb1b10abSAndroid Build Coastguard Worker
vpx_highbd_d135_predictor_4x4_c(uint16_t * dst,ptrdiff_t stride,const uint16_t * above,const uint16_t * left,int bd)804*fb1b10abSAndroid Build Coastguard Worker void vpx_highbd_d135_predictor_4x4_c(uint16_t *dst, ptrdiff_t stride,
805*fb1b10abSAndroid Build Coastguard Worker const uint16_t *above,
806*fb1b10abSAndroid Build Coastguard Worker const uint16_t *left, int bd) {
807*fb1b10abSAndroid Build Coastguard Worker const int I = left[0];
808*fb1b10abSAndroid Build Coastguard Worker const int J = left[1];
809*fb1b10abSAndroid Build Coastguard Worker const int K = left[2];
810*fb1b10abSAndroid Build Coastguard Worker const int L = left[3];
811*fb1b10abSAndroid Build Coastguard Worker const int X = above[-1];
812*fb1b10abSAndroid Build Coastguard Worker const int A = above[0];
813*fb1b10abSAndroid Build Coastguard Worker const int B = above[1];
814*fb1b10abSAndroid Build Coastguard Worker const int C = above[2];
815*fb1b10abSAndroid Build Coastguard Worker const int D = above[3];
816*fb1b10abSAndroid Build Coastguard Worker (void)bd;
817*fb1b10abSAndroid Build Coastguard Worker DST(0, 3) = AVG3(J, K, L);
818*fb1b10abSAndroid Build Coastguard Worker DST(1, 3) = DST(0, 2) = AVG3(I, J, K);
819*fb1b10abSAndroid Build Coastguard Worker DST(2, 3) = DST(1, 2) = DST(0, 1) = AVG3(X, I, J);
820*fb1b10abSAndroid Build Coastguard Worker DST(3, 3) = DST(2, 2) = DST(1, 1) = DST(0, 0) = AVG3(A, X, I);
821*fb1b10abSAndroid Build Coastguard Worker DST(3, 2) = DST(2, 1) = DST(1, 0) = AVG3(B, A, X);
822*fb1b10abSAndroid Build Coastguard Worker DST(3, 1) = DST(2, 0) = AVG3(C, B, A);
823*fb1b10abSAndroid Build Coastguard Worker DST(3, 0) = AVG3(D, C, B);
824*fb1b10abSAndroid Build Coastguard Worker }
825*fb1b10abSAndroid Build Coastguard Worker
vpx_highbd_d153_predictor_4x4_c(uint16_t * dst,ptrdiff_t stride,const uint16_t * above,const uint16_t * left,int bd)826*fb1b10abSAndroid Build Coastguard Worker void vpx_highbd_d153_predictor_4x4_c(uint16_t *dst, ptrdiff_t stride,
827*fb1b10abSAndroid Build Coastguard Worker const uint16_t *above,
828*fb1b10abSAndroid Build Coastguard Worker const uint16_t *left, int bd) {
829*fb1b10abSAndroid Build Coastguard Worker const int I = left[0];
830*fb1b10abSAndroid Build Coastguard Worker const int J = left[1];
831*fb1b10abSAndroid Build Coastguard Worker const int K = left[2];
832*fb1b10abSAndroid Build Coastguard Worker const int L = left[3];
833*fb1b10abSAndroid Build Coastguard Worker const int X = above[-1];
834*fb1b10abSAndroid Build Coastguard Worker const int A = above[0];
835*fb1b10abSAndroid Build Coastguard Worker const int B = above[1];
836*fb1b10abSAndroid Build Coastguard Worker const int C = above[2];
837*fb1b10abSAndroid Build Coastguard Worker (void)bd;
838*fb1b10abSAndroid Build Coastguard Worker
839*fb1b10abSAndroid Build Coastguard Worker DST(0, 0) = DST(2, 1) = AVG2(I, X);
840*fb1b10abSAndroid Build Coastguard Worker DST(0, 1) = DST(2, 2) = AVG2(J, I);
841*fb1b10abSAndroid Build Coastguard Worker DST(0, 2) = DST(2, 3) = AVG2(K, J);
842*fb1b10abSAndroid Build Coastguard Worker DST(0, 3) = AVG2(L, K);
843*fb1b10abSAndroid Build Coastguard Worker
844*fb1b10abSAndroid Build Coastguard Worker DST(3, 0) = AVG3(A, B, C);
845*fb1b10abSAndroid Build Coastguard Worker DST(2, 0) = AVG3(X, A, B);
846*fb1b10abSAndroid Build Coastguard Worker DST(1, 0) = DST(3, 1) = AVG3(I, X, A);
847*fb1b10abSAndroid Build Coastguard Worker DST(1, 1) = DST(3, 2) = AVG3(J, I, X);
848*fb1b10abSAndroid Build Coastguard Worker DST(1, 2) = DST(3, 3) = AVG3(K, J, I);
849*fb1b10abSAndroid Build Coastguard Worker DST(1, 3) = AVG3(L, K, J);
850*fb1b10abSAndroid Build Coastguard Worker }
851*fb1b10abSAndroid Build Coastguard Worker #endif // CONFIG_VP9_HIGHBITDEPTH
852*fb1b10abSAndroid Build Coastguard Worker
853*fb1b10abSAndroid Build Coastguard Worker // This serves as a wrapper function, so that all the prediction functions
854*fb1b10abSAndroid Build Coastguard Worker // can be unified and accessed as a pointer array. Note that the boundary
855*fb1b10abSAndroid Build Coastguard Worker // above and left are not necessarily used all the time.
856*fb1b10abSAndroid Build Coastguard Worker #define intra_pred_sized(type, size) \
857*fb1b10abSAndroid Build Coastguard Worker void vpx_##type##_predictor_##size##x##size##_c( \
858*fb1b10abSAndroid Build Coastguard Worker uint8_t *dst, ptrdiff_t stride, const uint8_t *above, \
859*fb1b10abSAndroid Build Coastguard Worker const uint8_t *left) { \
860*fb1b10abSAndroid Build Coastguard Worker type##_predictor(dst, stride, size, above, left); \
861*fb1b10abSAndroid Build Coastguard Worker }
862*fb1b10abSAndroid Build Coastguard Worker
863*fb1b10abSAndroid Build Coastguard Worker #if CONFIG_VP9_HIGHBITDEPTH
864*fb1b10abSAndroid Build Coastguard Worker #define intra_pred_highbd_sized(type, size) \
865*fb1b10abSAndroid Build Coastguard Worker void vpx_highbd_##type##_predictor_##size##x##size##_c( \
866*fb1b10abSAndroid Build Coastguard Worker uint16_t *dst, ptrdiff_t stride, const uint16_t *above, \
867*fb1b10abSAndroid Build Coastguard Worker const uint16_t *left, int bd) { \
868*fb1b10abSAndroid Build Coastguard Worker highbd_##type##_predictor(dst, stride, size, above, left, bd); \
869*fb1b10abSAndroid Build Coastguard Worker }
870*fb1b10abSAndroid Build Coastguard Worker
871*fb1b10abSAndroid Build Coastguard Worker /* clang-format off */
872*fb1b10abSAndroid Build Coastguard Worker #define intra_pred_allsizes(type) \
873*fb1b10abSAndroid Build Coastguard Worker intra_pred_sized(type, 4) \
874*fb1b10abSAndroid Build Coastguard Worker intra_pred_sized(type, 8) \
875*fb1b10abSAndroid Build Coastguard Worker intra_pred_sized(type, 16) \
876*fb1b10abSAndroid Build Coastguard Worker intra_pred_sized(type, 32) \
877*fb1b10abSAndroid Build Coastguard Worker intra_pred_highbd_sized(type, 4) \
878*fb1b10abSAndroid Build Coastguard Worker intra_pred_highbd_sized(type, 8) \
879*fb1b10abSAndroid Build Coastguard Worker intra_pred_highbd_sized(type, 16) \
880*fb1b10abSAndroid Build Coastguard Worker intra_pred_highbd_sized(type, 32)
881*fb1b10abSAndroid Build Coastguard Worker
882*fb1b10abSAndroid Build Coastguard Worker #define intra_pred_no_4x4(type) \
883*fb1b10abSAndroid Build Coastguard Worker intra_pred_sized(type, 8) \
884*fb1b10abSAndroid Build Coastguard Worker intra_pred_sized(type, 16) \
885*fb1b10abSAndroid Build Coastguard Worker intra_pred_sized(type, 32) \
886*fb1b10abSAndroid Build Coastguard Worker intra_pred_highbd_sized(type, 8) \
887*fb1b10abSAndroid Build Coastguard Worker intra_pred_highbd_sized(type, 16) \
888*fb1b10abSAndroid Build Coastguard Worker intra_pred_highbd_sized(type, 32)
889*fb1b10abSAndroid Build Coastguard Worker
890*fb1b10abSAndroid Build Coastguard Worker #else
891*fb1b10abSAndroid Build Coastguard Worker #define intra_pred_allsizes(type) \
892*fb1b10abSAndroid Build Coastguard Worker intra_pred_sized(type, 4) \
893*fb1b10abSAndroid Build Coastguard Worker intra_pred_sized(type, 8) \
894*fb1b10abSAndroid Build Coastguard Worker intra_pred_sized(type, 16) \
895*fb1b10abSAndroid Build Coastguard Worker intra_pred_sized(type, 32)
896*fb1b10abSAndroid Build Coastguard Worker
897*fb1b10abSAndroid Build Coastguard Worker #define intra_pred_no_4x4(type) \
898*fb1b10abSAndroid Build Coastguard Worker intra_pred_sized(type, 8) \
899*fb1b10abSAndroid Build Coastguard Worker intra_pred_sized(type, 16) \
900*fb1b10abSAndroid Build Coastguard Worker intra_pred_sized(type, 32)
901*fb1b10abSAndroid Build Coastguard Worker #endif // CONFIG_VP9_HIGHBITDEPTH
902*fb1b10abSAndroid Build Coastguard Worker
903*fb1b10abSAndroid Build Coastguard Worker intra_pred_no_4x4(d207)
904*fb1b10abSAndroid Build Coastguard Worker intra_pred_no_4x4(d63)
905*fb1b10abSAndroid Build Coastguard Worker intra_pred_no_4x4(d45)
906*fb1b10abSAndroid Build Coastguard Worker intra_pred_no_4x4(d117)
907*fb1b10abSAndroid Build Coastguard Worker intra_pred_no_4x4(d135)
908*fb1b10abSAndroid Build Coastguard Worker intra_pred_no_4x4(d153)
909*fb1b10abSAndroid Build Coastguard Worker intra_pred_allsizes(v)
910*fb1b10abSAndroid Build Coastguard Worker intra_pred_allsizes(h)
911*fb1b10abSAndroid Build Coastguard Worker intra_pred_allsizes(tm)
912*fb1b10abSAndroid Build Coastguard Worker intra_pred_allsizes(dc_128)
913*fb1b10abSAndroid Build Coastguard Worker intra_pred_allsizes(dc_left)
914*fb1b10abSAndroid Build Coastguard Worker intra_pred_allsizes(dc_top)
915*fb1b10abSAndroid Build Coastguard Worker intra_pred_allsizes(dc)
916*fb1b10abSAndroid Build Coastguard Worker /* clang-format on */
917*fb1b10abSAndroid Build Coastguard Worker #undef intra_pred_allsizes
918