Coverage Report

Created: 2026-03-31 06:59

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
5.28M
static inline __m128i _mm_loadh_epi32(__m128i const *mem_addr) {
22
5.28M
  return _mm_cvtsi32_si128(*((int *)mem_addr));
23
5.28M
}
24
25
// Store 32-bit integer from the first element of a into memory.
26
8.37M
static inline void _mm_storeh_epi32(__m128i const *mem_addr, __m128i a) {
27
8.37M
  *((int *)mem_addr) = _mm_cvtsi128_si32(a);
28
8.37M
}
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
584k
                                                      int width, int height) {
44
584k
  const __m128i twos = _mm_set1_epi8(2);
45
584k
  __m128i *pred_buf_m128i = (__m128i *)pred_buf_q3;
46
584k
  const __m128i *end = pred_buf_m128i + (height >> 1) * CFL_BUF_LINE_I128;
47
584k
  const int luma_stride = input_stride << 1;
48
2.35M
  do {
49
2.35M
    if (width == 4) {
50
1.10M
      __m128i top = _mm_loadh_epi32((__m128i *)input);
51
1.10M
      top = _mm_maddubs_epi16(top, twos);
52
1.10M
      __m128i bot = _mm_loadh_epi32((__m128i *)(input + input_stride));
53
1.10M
      bot = _mm_maddubs_epi16(bot, twos);
54
1.10M
      const __m128i sum = _mm_add_epi16(top, bot);
55
1.10M
      _mm_storeh_epi32(pred_buf_m128i, sum);
56
1.24M
    } else if (width == 8) {
57
624k
      __m128i top = _mm_loadl_epi64((__m128i *)input);
58
624k
      top = _mm_maddubs_epi16(top, twos);
59
624k
      __m128i bot = _mm_loadl_epi64((__m128i *)(input + input_stride));
60
624k
      bot = _mm_maddubs_epi16(bot, twos);
61
624k
      const __m128i sum = _mm_add_epi16(top, bot);
62
624k
      _mm_storel_epi64(pred_buf_m128i, sum);
63
624k
    } else {
64
623k
      __m128i top = _mm_loadu_si128((__m128i *)input);
65
623k
      top = _mm_maddubs_epi16(top, twos);
66
623k
      __m128i bot = _mm_loadu_si128((__m128i *)(input + input_stride));
67
623k
      bot = _mm_maddubs_epi16(bot, twos);
68
623k
      const __m128i sum = _mm_add_epi16(top, bot);
69
623k
      _mm_storeu_si128(pred_buf_m128i, sum);
70
623k
      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
623k
    }
80
2.35M
    input += luma_stride;
81
2.35M
    pred_buf_m128i += CFL_BUF_LINE_I128;
82
2.35M
  } while (pred_buf_m128i < end);
83
584k
}
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
3.63k
                                                      int width, int height) {
99
3.63k
  const __m128i fours = _mm_set1_epi8(4);
100
3.63k
  __m128i *pred_buf_m128i = (__m128i *)pred_buf_q3;
101
3.63k
  const __m128i *end = pred_buf_m128i + height * CFL_BUF_LINE_I128;
102
28.2k
  do {
103
28.2k
    if (width == 4) {
104
888
      __m128i top = _mm_loadh_epi32((__m128i *)input);
105
888
      top = _mm_maddubs_epi16(top, fours);
106
888
      _mm_storeh_epi32(pred_buf_m128i, top);
107
27.3k
    } else if (width == 8) {
108
21.6k
      __m128i top = _mm_loadl_epi64((__m128i *)input);
109
21.6k
      top = _mm_maddubs_epi16(top, fours);
110
21.6k
      _mm_storel_epi64(pred_buf_m128i, top);
111
21.6k
    } else {
112
5.63k
      __m128i top = _mm_loadu_si128((__m128i *)input);
113
5.63k
      top = _mm_maddubs_epi16(top, fours);
114
5.63k
      _mm_storeu_si128(pred_buf_m128i, top);
115
5.63k
      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
5.63k
    }
121
28.2k
    input += input_stride;
122
28.2k
    pred_buf_m128i += CFL_BUF_LINE_I128;
123
28.2k
  } while (pred_buf_m128i < end);
124
3.63k
}
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
417k
                                                      int width, int height) {
139
417k
  const __m128i zeros = _mm_setzero_si128();
140
417k
  const int luma_stride = input_stride;
141
417k
  __m128i *pred_buf_m128i = (__m128i *)pred_buf_q3;
142
417k
  const __m128i *end = pred_buf_m128i + height * CFL_BUF_LINE_I128;
143
5.38M
  do {
144
5.38M
    if (width == 4) {
145
3.07M
      __m128i row = _mm_loadh_epi32((__m128i *)input);
146
3.07M
      row = _mm_unpacklo_epi8(row, zeros);
147
3.07M
      _mm_storel_epi64(pred_buf_m128i, _mm_slli_epi16(row, 3));
148
3.07M
    } else if (width == 8) {
149
1.10M
      __m128i row = _mm_loadl_epi64((__m128i *)input);
150
1.10M
      row = _mm_unpacklo_epi8(row, zeros);
151
1.10M
      _mm_storeu_si128(pred_buf_m128i, _mm_slli_epi16(row, 3));
152
1.20M
    } else {
153
1.20M
      __m128i row = _mm_loadu_si128((__m128i *)input);
154
1.20M
      const __m128i row_lo = _mm_unpacklo_epi8(row, zeros);
155
1.20M
      const __m128i row_hi = _mm_unpackhi_epi8(row, zeros);
156
1.20M
      _mm_storeu_si128(pred_buf_m128i, _mm_slli_epi16(row_lo, 3));
157
1.20M
      _mm_storeu_si128(pred_buf_m128i + 1, _mm_slli_epi16(row_hi, 3));
158
1.20M
      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.20M
    }
166
5.38M
    input += luma_stride;
167
5.38M
    pred_buf_m128i += CFL_BUF_LINE_I128;
168
5.38M
  } while (pred_buf_m128i < end);
169
417k
}
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
834k
                                                      int width, int height) {
186
834k
  const uint16_t *end = pred_buf_q3 + (height >> 1) * CFL_BUF_LINE;
187
834k
  const int luma_stride = input_stride << 1;
188
3.27M
  do {
189
3.27M
    if (width == 4) {
190
1.64M
      const __m128i top = _mm_loadl_epi64((__m128i *)input);
191
1.64M
      const __m128i bot = _mm_loadl_epi64((__m128i *)(input + input_stride));
192
1.64M
      __m128i sum = _mm_add_epi16(top, bot);
193
1.64M
      sum = _mm_hadd_epi16(sum, sum);
194
1.64M
      *((int *)pred_buf_q3) = _mm_cvtsi128_si32(_mm_add_epi16(sum, sum));
195
1.64M
    } else {
196
1.62M
      const __m128i top = _mm_loadu_si128((__m128i *)input);
197
1.62M
      const __m128i bot = _mm_loadu_si128((__m128i *)(input + input_stride));
198
1.62M
      __m128i sum = _mm_add_epi16(top, bot);
199
1.62M
      if (width == 8) {
200
769k
        sum = _mm_hadd_epi16(sum, sum);
201
769k
        _mm_storel_epi64((__m128i *)pred_buf_q3, _mm_add_epi16(sum, sum));
202
859k
      } else {
203
859k
        const __m128i top_1 = _mm_loadu_si128(((__m128i *)input) + 1);
204
859k
        const __m128i bot_1 =
205
859k
            _mm_loadu_si128(((__m128i *)(input + input_stride)) + 1);
206
859k
        sum = _mm_hadd_epi16(sum, _mm_add_epi16(top_1, bot_1));
207
859k
        _mm_storeu_si128((__m128i *)pred_buf_q3, _mm_add_epi16(sum, sum));
208
859k
        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
859k
      }
222
1.62M
    }
223
3.27M
    input += luma_stride;
224
3.27M
  } while ((pred_buf_q3 += CFL_BUF_LINE) < end);
225
834k
}
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.55k
                                                      int width, int height) {
241
1.55k
  __m128i *pred_buf_m128i = (__m128i *)pred_buf_q3;
242
1.55k
  const __m128i *end = pred_buf_m128i + height * CFL_BUF_LINE_I128;
243
7.26k
  do {
244
7.26k
    if (width == 4) {
245
4.10k
      const __m128i top = _mm_loadl_epi64((__m128i *)input);
246
4.10k
      const __m128i sum = _mm_slli_epi16(_mm_hadd_epi16(top, top), 2);
247
4.10k
      _mm_storeh_epi32(pred_buf_m128i, sum);
248
4.10k
    } else {
249
3.15k
      const __m128i top = _mm_loadu_si128((__m128i *)input);
250
3.15k
      if (width == 8) {
251
1.95k
        const __m128i sum = _mm_slli_epi16(_mm_hadd_epi16(top, top), 2);
252
1.95k
        _mm_storel_epi64(pred_buf_m128i, sum);
253
1.95k
      } else {
254
1.20k
        const __m128i top_1 = _mm_loadu_si128(((__m128i *)input) + 1);
255
1.20k
        const __m128i sum = _mm_slli_epi16(_mm_hadd_epi16(top, top_1), 2);
256
1.20k
        _mm_storeu_si128(pred_buf_m128i, sum);
257
1.20k
        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.20k
      }
264
3.15k
    }
265
7.26k
    pred_buf_m128i += CFL_BUF_LINE_I128;
266
7.26k
    input += input_stride;
267
7.26k
  } while (pred_buf_m128i < end);
268
1.55k
}
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
392k
                                                      int width, int height) {
274
392k
  const uint16_t *end = pred_buf_q3 + height * CFL_BUF_LINE;
275
3.59M
  do {
276
3.59M
    if (width == 4) {
277
782k
      const __m128i row = _mm_slli_epi16(_mm_loadl_epi64((__m128i *)input), 3);
278
782k
      _mm_storel_epi64((__m128i *)pred_buf_q3, row);
279
2.81M
    } else {
280
2.81M
      const __m128i row = _mm_slli_epi16(_mm_loadu_si128((__m128i *)input), 3);
281
2.81M
      _mm_storeu_si128((__m128i *)pred_buf_q3, row);
282
2.81M
      if (width >= 16) {
283
1.12M
        __m128i row_1 = _mm_loadu_si128(((__m128i *)input) + 1);
284
1.12M
        row_1 = _mm_slli_epi16(row_1, 3);
285
1.12M
        _mm_storeu_si128(((__m128i *)pred_buf_q3) + 1, row_1);
286
1.12M
        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.12M
      }
295
2.81M
    }
296
3.59M
    input += input_stride;
297
3.59M
    pred_buf_q3 += CFL_BUF_LINE;
298
3.59M
  } while (pred_buf_q3 < end);
299
392k
}
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
23.2M
                                        __m128i alpha_sign, __m128i dc_q0) {
306
23.2M
  __m128i ac_q3 = _mm_loadu_si128(input);
307
23.2M
  __m128i ac_sign = _mm_sign_epi16(alpha_sign, ac_q3);
308
23.2M
  __m128i scaled_luma_q0 = _mm_mulhrs_epi16(_mm_abs_epi16(ac_q3), alpha_q12);
309
23.2M
  scaled_luma_q0 = _mm_sign_epi16(scaled_luma_q0, ac_sign);
310
23.2M
  return _mm_add_epi16(scaled_luma_q0, dc_q0);
311
23.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.20M
                                         int alpha_q3, int width, int height) {
316
1.20M
  const __m128i alpha_sign = _mm_set1_epi16(alpha_q3);
317
1.20M
  const __m128i alpha_q12 = _mm_slli_epi16(_mm_abs_epi16(alpha_sign), 9);
318
1.20M
  const __m128i dc_q0 = _mm_set1_epi16(*dst);
319
1.20M
  __m128i *row = (__m128i *)pred_buf_q3;
320
1.20M
  const __m128i *row_end = row + height * CFL_BUF_LINE_I128;
321
13.4M
  do {
322
13.4M
    __m128i res = predict_unclipped(row, alpha_q12, alpha_sign, dc_q0);
323
13.4M
    if (width < 16) {
324
10.3M
      res = _mm_packus_epi16(res, res);
325
10.3M
      if (width == 4)
326
7.25M
        _mm_storeh_epi32((__m128i *)dst, res);
327
3.09M
      else
328
3.09M
        _mm_storel_epi64((__m128i *)dst, res);
329
10.3M
    } else {
330
3.10M
      __m128i next = predict_unclipped(row + 1, alpha_q12, alpha_sign, dc_q0);
331
3.10M
      res = _mm_packus_epi16(res, next);
332
3.10M
      _mm_storeu_si128((__m128i *)dst, res);
333
3.10M
      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
3.10M
    }
340
13.4M
    dst += dst_stride;
341
13.4M
  } while ((row += CFL_BUF_LINE_I128) < row_end);
342
1.20M
}
343
344
0
CFL_PREDICT_FN(ssse3, lbd)
345
346
#if CONFIG_AV1_HIGHBITDEPTH
347
827k
static inline __m128i highbd_max_epi16(int bd) {
348
827k
  const __m128i neg_one = _mm_set1_epi16(-1);
349
  // (1 << bd) - 1 => -(-1 << bd) -1 => -1 - (-1 << bd) => -1 ^ (-1 << bd)
350
827k
  return _mm_xor_si128(_mm_slli_epi16(neg_one, bd), neg_one);
351
827k
}
352
353
6.66M
static inline __m128i highbd_clamp_epi16(__m128i u, __m128i zero, __m128i max) {
354
6.66M
  return _mm_max_epi16(_mm_min_epi16(u, max), zero);
355
6.66M
}
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
827k
                                         int height) {
361
827k
  const __m128i alpha_sign = _mm_set1_epi16(alpha_q3);
362
827k
  const __m128i alpha_q12 = _mm_slli_epi16(_mm_abs_epi16(alpha_sign), 9);
363
827k
  const __m128i dc_q0 = _mm_set1_epi16(*dst);
364
827k
  const __m128i max = highbd_max_epi16(bd);
365
827k
  const __m128i zeros = _mm_setzero_si128();
366
827k
  __m128i *row = (__m128i *)pred_buf_q3;
367
827k
  const __m128i *row_end = row + height * CFL_BUF_LINE_I128;
368
6.66M
  do {
369
6.66M
    __m128i res = predict_unclipped(row, alpha_q12, alpha_sign, dc_q0);
370
6.66M
    res = highbd_clamp_epi16(res, zeros, max);
371
6.66M
    if (width == 4) {
372
2.59M
      _mm_storel_epi64((__m128i *)dst, res);
373
4.07M
    } else {
374
4.07M
      _mm_storeu_si128((__m128i *)dst, res);
375
4.07M
    }
376
6.66M
    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
6.66M
    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
6.66M
    dst += dst_stride;
393
6.66M
  } while ((row += CFL_BUF_LINE_I128) < row_end);
394
827k
}
395
396
CFL_PREDICT_FN(ssse3, hbd)
397
#endif  // CONFIG_AV1_HIGHBITDEPTH