Coverage Report

Created: 2026-03-08 06:51

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/aom/av1/common/x86/cfl_ssse3.c
Line
Count
Source
1
/*
2
 * Copyright (c) 2017, Alliance for Open Media. All rights reserved.
3
 *
4
 * This source code is subject to the terms of the BSD 2 Clause License and
5
 * the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License
6
 * was not distributed with this source code in the LICENSE file, you can
7
 * obtain it at www.aomedia.org/license/software. If the Alliance for Open
8
 * Media Patent License 1.0 was not distributed with this source code in the
9
 * PATENTS file, you can obtain it at www.aomedia.org/license/patent.
10
 */
11
12
#include <tmmintrin.h>
13
14
#include "config/av1_rtcd.h"
15
16
#include "av1/common/cfl.h"
17
18
#include "av1/common/x86/cfl_simd.h"
19
20
// Load 32-bit integer from memory into the first element of dst.
21
7.44M
static inline __m128i _mm_loadh_epi32(__m128i const *mem_addr) {
22
7.44M
  return _mm_cvtsi32_si128(*((int *)mem_addr));
23
7.44M
}
24
25
// Store 32-bit integer from the first element of a into memory.
26
11.5M
static inline void _mm_storeh_epi32(__m128i const *mem_addr, __m128i a) {
27
11.5M
  *((int *)mem_addr) = _mm_cvtsi128_si32(a);
28
11.5M
}
29
30
/**
31
 * Adds 4 pixels (in a 2x2 grid) and multiplies them by 2. Resulting in a more
32
 * precise version of a box filter 4:2:0 pixel subsampling in Q3.
33
 *
34
 * The CfL prediction buffer is always of size CFL_BUF_SQUARE. However, the
35
 * active area is specified using width and height.
36
 *
37
 * Note: We don't need to worry about going over the active area, as long as we
38
 * stay inside the CfL prediction buffer.
39
 */
40
static inline void cfl_luma_subsampling_420_lbd_ssse3(const uint8_t *input,
41
                                                      int input_stride,
42
                                                      uint16_t *pred_buf_q3,
43
769k
                                                      int width, int height) {
44
769k
  const __m128i twos = _mm_set1_epi8(2);
45
769k
  __m128i *pred_buf_m128i = (__m128i *)pred_buf_q3;
46
769k
  const __m128i *end = pred_buf_m128i + (height >> 1) * CFL_BUF_LINE_I128;
47
769k
  const int luma_stride = input_stride << 1;
48
3.13M
  do {
49
3.13M
    if (width == 4) {
50
1.56M
      __m128i top = _mm_loadh_epi32((__m128i *)input);
51
1.56M
      top = _mm_maddubs_epi16(top, twos);
52
1.56M
      __m128i bot = _mm_loadh_epi32((__m128i *)(input + input_stride));
53
1.56M
      bot = _mm_maddubs_epi16(bot, twos);
54
1.56M
      const __m128i sum = _mm_add_epi16(top, bot);
55
1.56M
      _mm_storeh_epi32(pred_buf_m128i, sum);
56
1.57M
    } else if (width == 8) {
57
753k
      __m128i top = _mm_loadl_epi64((__m128i *)input);
58
753k
      top = _mm_maddubs_epi16(top, twos);
59
753k
      __m128i bot = _mm_loadl_epi64((__m128i *)(input + input_stride));
60
753k
      bot = _mm_maddubs_epi16(bot, twos);
61
753k
      const __m128i sum = _mm_add_epi16(top, bot);
62
753k
      _mm_storel_epi64(pred_buf_m128i, sum);
63
817k
    } else {
64
817k
      __m128i top = _mm_loadu_si128((__m128i *)input);
65
817k
      top = _mm_maddubs_epi16(top, twos);
66
817k
      __m128i bot = _mm_loadu_si128((__m128i *)(input + input_stride));
67
817k
      bot = _mm_maddubs_epi16(bot, twos);
68
817k
      const __m128i sum = _mm_add_epi16(top, bot);
69
817k
      _mm_storeu_si128(pred_buf_m128i, sum);
70
817k
      if (width == 32) {
71
0
        __m128i top_1 = _mm_loadu_si128(((__m128i *)input) + 1);
72
0
        __m128i bot_1 =
73
0
            _mm_loadu_si128(((__m128i *)(input + input_stride)) + 1);
74
0
        top_1 = _mm_maddubs_epi16(top_1, twos);
75
0
        bot_1 = _mm_maddubs_epi16(bot_1, twos);
76
0
        __m128i sum_1 = _mm_add_epi16(top_1, bot_1);
77
0
        _mm_storeu_si128(pred_buf_m128i + 1, sum_1);
78
0
      }
79
817k
    }
80
3.13M
    input += luma_stride;
81
3.13M
    pred_buf_m128i += CFL_BUF_LINE_I128;
82
3.13M
  } while (pred_buf_m128i < end);
83
769k
}
84
85
/**
86
 * Adds 2 pixels (in a 2x1 grid) and multiplies them by 4. Resulting in a more
87
 * precise version of a box filter 4:2:2 pixel subsampling in Q3.
88
 *
89
 * The CfL prediction buffer is always of size CFL_BUF_SQUARE. However, the
90
 * active area is specified using width and height.
91
 *
92
 * Note: We don't need to worry about going over the active area, as long as we
93
 * stay inside the CfL prediction buffer.
94
 */
95
static inline void cfl_luma_subsampling_422_lbd_ssse3(const uint8_t *input,
96
                                                      int input_stride,
97
                                                      uint16_t *pred_buf_q3,
98
4.17k
                                                      int width, int height) {
99
4.17k
  const __m128i fours = _mm_set1_epi8(4);
100
4.17k
  __m128i *pred_buf_m128i = (__m128i *)pred_buf_q3;
101
4.17k
  const __m128i *end = pred_buf_m128i + height * CFL_BUF_LINE_I128;
102
32.7k
  do {
103
32.7k
    if (width == 4) {
104
792
      __m128i top = _mm_loadh_epi32((__m128i *)input);
105
792
      top = _mm_maddubs_epi16(top, fours);
106
792
      _mm_storeh_epi32(pred_buf_m128i, top);
107
31.9k
    } else if (width == 8) {
108
22.7k
      __m128i top = _mm_loadl_epi64((__m128i *)input);
109
22.7k
      top = _mm_maddubs_epi16(top, fours);
110
22.7k
      _mm_storel_epi64(pred_buf_m128i, top);
111
22.7k
    } else {
112
9.20k
      __m128i top = _mm_loadu_si128((__m128i *)input);
113
9.20k
      top = _mm_maddubs_epi16(top, fours);
114
9.20k
      _mm_storeu_si128(pred_buf_m128i, top);
115
9.20k
      if (width == 32) {
116
0
        __m128i top_1 = _mm_loadu_si128(((__m128i *)input) + 1);
117
0
        top_1 = _mm_maddubs_epi16(top_1, fours);
118
0
        _mm_storeu_si128(pred_buf_m128i + 1, top_1);
119
0
      }
120
9.20k
    }
121
32.7k
    input += input_stride;
122
32.7k
    pred_buf_m128i += CFL_BUF_LINE_I128;
123
32.7k
  } while (pred_buf_m128i < end);
124
4.17k
}
125
126
/**
127
 * Multiplies the pixels by 8 (scaling in Q3).
128
 *
129
 * The CfL prediction buffer is always of size CFL_BUF_SQUARE. However, the
130
 * active area is specified using width and height.
131
 *
132
 * Note: We don't need to worry about going over the active area, as long as we
133
 * stay inside the CfL prediction buffer.
134
 */
135
static inline void cfl_luma_subsampling_444_lbd_ssse3(const uint8_t *input,
136
                                                      int input_stride,
137
                                                      uint16_t *pred_buf_q3,
138
624k
                                                      int width, int height) {
139
624k
  const __m128i zeros = _mm_setzero_si128();
140
624k
  const int luma_stride = input_stride;
141
624k
  __m128i *pred_buf_m128i = (__m128i *)pred_buf_q3;
142
624k
  const __m128i *end = pred_buf_m128i + height * CFL_BUF_LINE_I128;
143
7.94M
  do {
144
7.94M
    if (width == 4) {
145
4.32M
      __m128i row = _mm_loadh_epi32((__m128i *)input);
146
4.32M
      row = _mm_unpacklo_epi8(row, zeros);
147
4.32M
      _mm_storel_epi64(pred_buf_m128i, _mm_slli_epi16(row, 3));
148
4.32M
    } else if (width == 8) {
149
1.74M
      __m128i row = _mm_loadl_epi64((__m128i *)input);
150
1.74M
      row = _mm_unpacklo_epi8(row, zeros);
151
1.74M
      _mm_storeu_si128(pred_buf_m128i, _mm_slli_epi16(row, 3));
152
1.87M
    } else {
153
1.87M
      __m128i row = _mm_loadu_si128((__m128i *)input);
154
1.87M
      const __m128i row_lo = _mm_unpacklo_epi8(row, zeros);
155
1.87M
      const __m128i row_hi = _mm_unpackhi_epi8(row, zeros);
156
1.87M
      _mm_storeu_si128(pred_buf_m128i, _mm_slli_epi16(row_lo, 3));
157
1.87M
      _mm_storeu_si128(pred_buf_m128i + 1, _mm_slli_epi16(row_hi, 3));
158
1.87M
      if (width == 32) {
159
0
        __m128i row_1 = _mm_loadu_si128(((__m128i *)input) + 1);
160
0
        const __m128i row_1_lo = _mm_unpacklo_epi8(row_1, zeros);
161
0
        const __m128i row_1_hi = _mm_unpackhi_epi8(row_1, zeros);
162
0
        _mm_storeu_si128(pred_buf_m128i + 2, _mm_slli_epi16(row_1_lo, 3));
163
0
        _mm_storeu_si128(pred_buf_m128i + 3, _mm_slli_epi16(row_1_hi, 3));
164
0
      }
165
1.87M
    }
166
7.94M
    input += luma_stride;
167
7.94M
    pred_buf_m128i += CFL_BUF_LINE_I128;
168
7.94M
  } while (pred_buf_m128i < end);
169
624k
}
170
171
#if CONFIG_AV1_HIGHBITDEPTH
172
/**
173
 * Adds 4 pixels (in a 2x2 grid) and multiplies them by 2. Resulting in a more
174
 * precise version of a box filter 4:2:0 pixel subsampling in Q3.
175
 *
176
 * The CfL prediction buffer is always of size CFL_BUF_SQUARE. However, the
177
 * active area is specified using width and height.
178
 *
179
 * Note: We don't need to worry about going over the active area, as long as we
180
 * stay inside the CfL prediction buffer.
181
 */
182
static inline void cfl_luma_subsampling_420_hbd_ssse3(const uint16_t *input,
183
                                                      int input_stride,
184
                                                      uint16_t *pred_buf_q3,
185
725k
                                                      int width, int height) {
186
725k
  const uint16_t *end = pred_buf_q3 + (height >> 1) * CFL_BUF_LINE;
187
725k
  const int luma_stride = input_stride << 1;
188
2.78M
  do {
189
2.78M
    if (width == 4) {
190
1.44M
      const __m128i top = _mm_loadl_epi64((__m128i *)input);
191
1.44M
      const __m128i bot = _mm_loadl_epi64((__m128i *)(input + input_stride));
192
1.44M
      __m128i sum = _mm_add_epi16(top, bot);
193
1.44M
      sum = _mm_hadd_epi16(sum, sum);
194
1.44M
      *((int *)pred_buf_q3) = _mm_cvtsi128_si32(_mm_add_epi16(sum, sum));
195
1.44M
    } else {
196
1.33M
      const __m128i top = _mm_loadu_si128((__m128i *)input);
197
1.33M
      const __m128i bot = _mm_loadu_si128((__m128i *)(input + input_stride));
198
1.33M
      __m128i sum = _mm_add_epi16(top, bot);
199
1.33M
      if (width == 8) {
200
650k
        sum = _mm_hadd_epi16(sum, sum);
201
650k
        _mm_storel_epi64((__m128i *)pred_buf_q3, _mm_add_epi16(sum, sum));
202
682k
      } else {
203
682k
        const __m128i top_1 = _mm_loadu_si128(((__m128i *)input) + 1);
204
682k
        const __m128i bot_1 =
205
682k
            _mm_loadu_si128(((__m128i *)(input + input_stride)) + 1);
206
682k
        sum = _mm_hadd_epi16(sum, _mm_add_epi16(top_1, bot_1));
207
682k
        _mm_storeu_si128((__m128i *)pred_buf_q3, _mm_add_epi16(sum, sum));
208
682k
        if (width == 32) {
209
0
          const __m128i top_2 = _mm_loadu_si128(((__m128i *)input) + 2);
210
0
          const __m128i bot_2 =
211
0
              _mm_loadu_si128(((__m128i *)(input + input_stride)) + 2);
212
0
          const __m128i top_3 = _mm_loadu_si128(((__m128i *)input) + 3);
213
0
          const __m128i bot_3 =
214
0
              _mm_loadu_si128(((__m128i *)(input + input_stride)) + 3);
215
0
          const __m128i sum_2 = _mm_add_epi16(top_2, bot_2);
216
0
          const __m128i sum_3 = _mm_add_epi16(top_3, bot_3);
217
0
          __m128i next_sum = _mm_hadd_epi16(sum_2, sum_3);
218
0
          _mm_storeu_si128(((__m128i *)pred_buf_q3) + 1,
219
0
                           _mm_add_epi16(next_sum, next_sum));
220
0
        }
221
682k
      }
222
1.33M
    }
223
2.78M
    input += luma_stride;
224
2.78M
  } while ((pred_buf_q3 += CFL_BUF_LINE) < end);
225
725k
}
226
227
/**
228
 * Adds 2 pixels (in a 2x1 grid) and multiplies them by 4. Resulting in a more
229
 * precise version of a box filter 4:2:2 pixel subsampling in Q3.
230
 *
231
 * The CfL prediction buffer is always of size CFL_BUF_SQUARE. However, the
232
 * active area is specified using width and height.
233
 *
234
 * Note: We don't need to worry about going over the active area, as long as we
235
 * stay inside the CfL prediction buffer.
236
 */
237
static inline void cfl_luma_subsampling_422_hbd_ssse3(const uint16_t *input,
238
                                                      int input_stride,
239
                                                      uint16_t *pred_buf_q3,
240
1.66k
                                                      int width, int height) {
241
1.66k
  __m128i *pred_buf_m128i = (__m128i *)pred_buf_q3;
242
1.66k
  const __m128i *end = pred_buf_m128i + height * CFL_BUF_LINE_I128;
243
7.83k
  do {
244
7.83k
    if (width == 4) {
245
4.49k
      const __m128i top = _mm_loadl_epi64((__m128i *)input);
246
4.49k
      const __m128i sum = _mm_slli_epi16(_mm_hadd_epi16(top, top), 2);
247
4.49k
      _mm_storeh_epi32(pred_buf_m128i, sum);
248
4.49k
    } else {
249
3.34k
      const __m128i top = _mm_loadu_si128((__m128i *)input);
250
3.34k
      if (width == 8) {
251
2.10k
        const __m128i sum = _mm_slli_epi16(_mm_hadd_epi16(top, top), 2);
252
2.10k
        _mm_storel_epi64(pred_buf_m128i, sum);
253
2.10k
      } else {
254
1.24k
        const __m128i top_1 = _mm_loadu_si128(((__m128i *)input) + 1);
255
1.24k
        const __m128i sum = _mm_slli_epi16(_mm_hadd_epi16(top, top_1), 2);
256
1.24k
        _mm_storeu_si128(pred_buf_m128i, sum);
257
1.24k
        if (width == 32) {
258
0
          const __m128i top_2 = _mm_loadu_si128(((__m128i *)input) + 2);
259
0
          const __m128i top_3 = _mm_loadu_si128(((__m128i *)input) + 3);
260
0
          const __m128i sum_1 = _mm_slli_epi16(_mm_hadd_epi16(top_2, top_3), 2);
261
0
          _mm_storeu_si128(pred_buf_m128i + 1, sum_1);
262
0
        }
263
1.24k
      }
264
3.34k
    }
265
7.83k
    pred_buf_m128i += CFL_BUF_LINE_I128;
266
7.83k
    input += input_stride;
267
7.83k
  } while (pred_buf_m128i < end);
268
1.66k
}
269
270
static inline void cfl_luma_subsampling_444_hbd_ssse3(const uint16_t *input,
271
                                                      int input_stride,
272
                                                      uint16_t *pred_buf_q3,
273
459k
                                                      int width, int height) {
274
459k
  const uint16_t *end = pred_buf_q3 + height * CFL_BUF_LINE;
275
4.40M
  do {
276
4.40M
    if (width == 4) {
277
923k
      const __m128i row = _mm_slli_epi16(_mm_loadl_epi64((__m128i *)input), 3);
278
923k
      _mm_storel_epi64((__m128i *)pred_buf_q3, row);
279
3.48M
    } else {
280
3.48M
      const __m128i row = _mm_slli_epi16(_mm_loadu_si128((__m128i *)input), 3);
281
3.48M
      _mm_storeu_si128((__m128i *)pred_buf_q3, row);
282
3.48M
      if (width >= 16) {
283
1.54M
        __m128i row_1 = _mm_loadu_si128(((__m128i *)input) + 1);
284
1.54M
        row_1 = _mm_slli_epi16(row_1, 3);
285
1.54M
        _mm_storeu_si128(((__m128i *)pred_buf_q3) + 1, row_1);
286
1.54M
        if (width == 32) {
287
0
          __m128i row_2 = _mm_loadu_si128(((__m128i *)input) + 2);
288
0
          row_2 = _mm_slli_epi16(row_2, 3);
289
0
          _mm_storeu_si128(((__m128i *)pred_buf_q3) + 2, row_2);
290
0
          __m128i row_3 = _mm_loadu_si128(((__m128i *)input) + 3);
291
0
          row_3 = _mm_slli_epi16(row_3, 3);
292
0
          _mm_storeu_si128(((__m128i *)pred_buf_q3) + 3, row_3);
293
0
        }
294
1.54M
      }
295
3.48M
    }
296
4.40M
    input += input_stride;
297
4.40M
    pred_buf_q3 += CFL_BUF_LINE;
298
4.40M
  } while (pred_buf_q3 < end);
299
459k
}
300
#endif  // CONFIG_AV1_HIGHBITDEPTH
301
302
0
CFL_GET_SUBSAMPLE_FUNCTION(ssse3)
Unexecuted instantiation: cfl_get_luma_subsampling_420_lbd_ssse3
Unexecuted instantiation: cfl_get_luma_subsampling_422_lbd_ssse3
Unexecuted instantiation: cfl_get_luma_subsampling_444_lbd_ssse3
Unexecuted instantiation: cfl_get_luma_subsampling_420_hbd_ssse3
Unexecuted instantiation: cfl_get_luma_subsampling_422_hbd_ssse3
Unexecuted instantiation: cfl_get_luma_subsampling_444_hbd_ssse3
303
0
304
0
static inline __m128i predict_unclipped(const __m128i *input, __m128i alpha_q12,
305
31.2M
                                        __m128i alpha_sign, __m128i dc_q0) {
306
31.2M
  __m128i ac_q3 = _mm_loadu_si128(input);
307
31.2M
  __m128i ac_sign = _mm_sign_epi16(alpha_sign, ac_q3);
308
31.2M
  __m128i scaled_luma_q0 = _mm_mulhrs_epi16(_mm_abs_epi16(ac_q3), alpha_q12);
309
31.2M
  scaled_luma_q0 = _mm_sign_epi16(scaled_luma_q0, ac_sign);
310
31.2M
  return _mm_add_epi16(scaled_luma_q0, dc_q0);
311
31.2M
}
312
313
static inline void cfl_predict_lbd_ssse3(const int16_t *pred_buf_q3,
314
                                         uint8_t *dst, int dst_stride,
315
1.71M
                                         int alpha_q3, int width, int height) {
316
1.71M
  const __m128i alpha_sign = _mm_set1_epi16(alpha_q3);
317
1.71M
  const __m128i alpha_q12 = _mm_slli_epi16(_mm_abs_epi16(alpha_sign), 9);
318
1.71M
  const __m128i dc_q0 = _mm_set1_epi16(*dst);
319
1.71M
  __m128i *row = (__m128i *)pred_buf_q3;
320
1.71M
  const __m128i *row_end = row + height * CFL_BUF_LINE_I128;
321
19.3M
  do {
322
19.3M
    __m128i res = predict_unclipped(row, alpha_q12, alpha_sign, dc_q0);
323
19.3M
    if (width < 16) {
324
14.6M
      res = _mm_packus_epi16(res, res);
325
14.6M
      if (width == 4)
326
10.0M
        _mm_storeh_epi32((__m128i *)dst, res);
327
4.64M
      else
328
4.64M
        _mm_storel_epi64((__m128i *)dst, res);
329
14.6M
    } else {
330
4.67M
      __m128i next = predict_unclipped(row + 1, alpha_q12, alpha_sign, dc_q0);
331
4.67M
      res = _mm_packus_epi16(res, next);
332
4.67M
      _mm_storeu_si128((__m128i *)dst, res);
333
4.67M
      if (width == 32) {
334
0
        res = predict_unclipped(row + 2, alpha_q12, alpha_sign, dc_q0);
335
0
        next = predict_unclipped(row + 3, alpha_q12, alpha_sign, dc_q0);
336
0
        res = _mm_packus_epi16(res, next);
337
0
        _mm_storeu_si128((__m128i *)(dst + 16), res);
338
0
      }
339
4.67M
    }
340
19.3M
    dst += dst_stride;
341
19.3M
  } while ((row += CFL_BUF_LINE_I128) < row_end);
342
1.71M
}
343
344
0
CFL_PREDICT_FN(ssse3, lbd)
345
346
#if CONFIG_AV1_HIGHBITDEPTH
347
860k
static inline __m128i highbd_max_epi16(int bd) {
348
860k
  const __m128i neg_one = _mm_set1_epi16(-1);
349
  // (1 << bd) - 1 => -(-1 << bd) -1 => -1 - (-1 << bd) => -1 ^ (-1 << bd)
350
860k
  return _mm_xor_si128(_mm_slli_epi16(neg_one, bd), neg_one);
351
860k
}
352
353
7.22M
static inline __m128i highbd_clamp_epi16(__m128i u, __m128i zero, __m128i max) {
354
7.22M
  return _mm_max_epi16(_mm_min_epi16(u, max), zero);
355
7.22M
}
356
357
static inline void cfl_predict_hbd_ssse3(const int16_t *pred_buf_q3,
358
                                         uint16_t *dst, int dst_stride,
359
                                         int alpha_q3, int bd, int width,
360
860k
                                         int height) {
361
860k
  const __m128i alpha_sign = _mm_set1_epi16(alpha_q3);
362
860k
  const __m128i alpha_q12 = _mm_slli_epi16(_mm_abs_epi16(alpha_sign), 9);
363
860k
  const __m128i dc_q0 = _mm_set1_epi16(*dst);
364
860k
  const __m128i max = highbd_max_epi16(bd);
365
860k
  const __m128i zeros = _mm_setzero_si128();
366
860k
  __m128i *row = (__m128i *)pred_buf_q3;
367
860k
  const __m128i *row_end = row + height * CFL_BUF_LINE_I128;
368
7.22M
  do {
369
7.22M
    __m128i res = predict_unclipped(row, alpha_q12, alpha_sign, dc_q0);
370
7.22M
    res = highbd_clamp_epi16(res, zeros, max);
371
7.22M
    if (width == 4) {
372
2.68M
      _mm_storel_epi64((__m128i *)dst, res);
373
4.53M
    } else {
374
4.53M
      _mm_storeu_si128((__m128i *)dst, res);
375
4.53M
    }
376
7.22M
    if (width >= 16) {
377
0
      const __m128i res_1 =
378
0
          predict_unclipped(row + 1, alpha_q12, alpha_sign, dc_q0);
379
0
      _mm_storeu_si128(((__m128i *)dst) + 1,
380
0
                       highbd_clamp_epi16(res_1, zeros, max));
381
0
    }
382
7.22M
    if (width == 32) {
383
0
      const __m128i res_2 =
384
0
          predict_unclipped(row + 2, alpha_q12, alpha_sign, dc_q0);
385
0
      _mm_storeu_si128((__m128i *)(dst + 16),
386
0
                       highbd_clamp_epi16(res_2, zeros, max));
387
0
      const __m128i res_3 =
388
0
          predict_unclipped(row + 3, alpha_q12, alpha_sign, dc_q0);
389
0
      _mm_storeu_si128((__m128i *)(dst + 24),
390
0
                       highbd_clamp_epi16(res_3, zeros, max));
391
0
    }
392
7.22M
    dst += dst_stride;
393
7.22M
  } while ((row += CFL_BUF_LINE_I128) < row_end);
394
860k
}
395
396
CFL_PREDICT_FN(ssse3, hbd)
397
#endif  // CONFIG_AV1_HIGHBITDEPTH