xref: /aosp_15_r20/external/libaom/config/riscv64/config/av1_rtcd.h (revision 77c1e3ccc04c968bd2bc212e87364f250e820521)
1 /*
2  * Copyright (c) 2024, 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 // This file is generated. Do not edit.
13 #ifndef AV1_RTCD_H_
14 #define AV1_RTCD_H_
15 
16 #ifdef RTCD_C
17 #define RTCD_EXTERN
18 #else
19 #define RTCD_EXTERN extern
20 #endif
21 
22 /*
23  * AV1
24  */
25 
26 #include "aom/aom_integer.h"
27 #include "aom_dsp/odintrin.h"
28 #include "aom_dsp/txfm_common.h"
29 #include "av1/common/av1_txfm.h"
30 #include "av1/common/common.h"
31 #include "av1/common/convolve.h"
32 #include "av1/common/enums.h"
33 #include "av1/common/filter.h"
34 #include "av1/common/quant_common.h"
35 #include "av1/common/restoration.h"
36 
37 struct macroblockd;
38 
39 /* Encoder forward decls */
40 struct macroblock;
41 struct txfm_param;
42 struct aom_variance_vtable;
43 struct search_site_config;
44 struct yv12_buffer_config;
45 struct NN_CONFIG;
46 typedef struct NN_CONFIG NN_CONFIG;
47 
48 enum { NONE, RELU, SOFTSIGN, SIGMOID } UENUM1BYTE(ACTIVATION);
49 #if CONFIG_NN_V2
50 enum { SOFTMAX_CROSS_ENTROPY } UENUM1BYTE(LOSS);
51 struct NN_CONFIG_V2;
52 typedef struct NN_CONFIG_V2 NN_CONFIG_V2;
53 struct FC_LAYER;
54 typedef struct FC_LAYER FC_LAYER;
55 #endif  // CONFIG_NN_V2
56 
57 struct CNN_CONFIG;
58 typedef struct CNN_CONFIG CNN_CONFIG;
59 struct CNN_LAYER_CONFIG;
60 typedef struct CNN_LAYER_CONFIG CNN_LAYER_CONFIG;
61 struct CNN_THREAD_DATA;
62 typedef struct CNN_THREAD_DATA CNN_THREAD_DATA;
63 struct CNN_BRANCH_CONFIG;
64 typedef struct CNN_BRANCH_CONFIG CNN_BRANCH_CONFIG;
65 struct CNN_MULTI_OUT;
66 typedef struct CNN_MULTI_OUT CNN_MULTI_OUT;
67 
68 /* Function pointers return by CfL functions */
69 typedef void (*cfl_subsample_lbd_fn)(const uint8_t *input, int input_stride,
70                                      uint16_t *output_q3);
71 
72 #if CONFIG_AV1_HIGHBITDEPTH
73 typedef void (*cfl_subsample_hbd_fn)(const uint16_t *input, int input_stride,
74                                      uint16_t *output_q3);
75 
76 typedef void (*cfl_predict_hbd_fn)(const int16_t *src, uint16_t *dst,
77                                    int dst_stride, int alpha_q3, int bd);
78 #endif
79 
80 typedef void (*cfl_subtract_average_fn)(const uint16_t *src, int16_t *dst);
81 
82 typedef void (*cfl_predict_lbd_fn)(const int16_t *src, uint8_t *dst,
83                                    int dst_stride, int alpha_q3);
84 
85 
86 #ifdef __cplusplus
87 extern "C" {
88 #endif
89 
90 void aom_comp_avg_upsampled_pred_c(MACROBLOCKD *xd, const struct AV1Common *const cm, int mi_row, int mi_col,
91                                                    const MV *const mv, uint8_t *comp_pred, const uint8_t *pred, int width,
92                                                    int height, int subpel_x_q3, int subpel_y_q3, const uint8_t *ref,
93                                                    int ref_stride, int subpel_search);
94 #define aom_comp_avg_upsampled_pred aom_comp_avg_upsampled_pred_c
95 
96 void aom_highbd_comp_avg_upsampled_pred_c(MACROBLOCKD *xd, const struct AV1Common *const cm, int mi_row, int mi_col,
97                                                             const MV *const mv, uint8_t *comp_pred8, const uint8_t *pred8, int width,
98                                                             int height, int subpel_x_q3, int subpel_y_q3, const uint8_t *ref8, int ref_stride, int bd, int subpel_search);
99 #define aom_highbd_comp_avg_upsampled_pred aom_highbd_comp_avg_upsampled_pred_c
100 
101 void aom_highbd_dist_wtd_comp_avg_upsampled_pred_c(MACROBLOCKD *xd, const struct AV1Common *const cm, int mi_row, int mi_col,
102                                                                 const MV *const mv, uint8_t *comp_pred8, const uint8_t *pred8, int width,
103                                                                 int height, int subpel_x_q3, int subpel_y_q3, const uint8_t *ref8,
104                                                                 int ref_stride, int bd, const DIST_WTD_COMP_PARAMS *jcp_param, int subpel_search);
105 #define aom_highbd_dist_wtd_comp_avg_upsampled_pred aom_highbd_dist_wtd_comp_avg_upsampled_pred_c
106 
107 void aom_highbd_upsampled_pred_c(MACROBLOCKD *xd, const struct AV1Common *const cm, int mi_row, int mi_col,
108                                                    const MV *const mv, uint8_t *comp_pred8, int width, int height, int subpel_x_q3,
109                                                    int subpel_y_q3, const uint8_t *ref8, int ref_stride, int bd, int subpel_search);
110 #define aom_highbd_upsampled_pred aom_highbd_upsampled_pred_c
111 
112 void aom_quantize_b_helper_c(const tran_low_t *coeff_ptr, intptr_t n_coeffs, const int16_t *zbin_ptr, const int16_t *round_ptr, const int16_t *quant_ptr, const int16_t *quant_shift_ptr, tran_low_t *qcoeff_ptr, tran_low_t *dqcoeff_ptr, const int16_t *dequant_ptr, uint16_t *eob_ptr, const int16_t *scan, const int16_t *iscan, const qm_val_t *qm_ptr, const qm_val_t *iqm_ptr, const int log_scale);
113 #define aom_quantize_b_helper aom_quantize_b_helper_c
114 
115 void aom_upsampled_pred_c(MACROBLOCKD *xd, const struct AV1Common *const cm, int mi_row, int mi_col,
116                                           const MV *const mv, uint8_t *comp_pred, int width, int height, int subpel_x_q3,
117                                           int subpel_y_q3, const uint8_t *ref, int ref_stride, int subpel_search);
118 #define aom_upsampled_pred aom_upsampled_pred_c
119 
120 int av1_apply_selfguided_restoration_c(const uint8_t *dat, int width, int height, int stride, int eps, const int *xqd, uint8_t *dst, int dst_stride, int32_t *tmpbuf, int bit_depth, int highbd);
121 #define av1_apply_selfguided_restoration av1_apply_selfguided_restoration_c
122 
123 void av1_apply_temporal_filter_c(const struct yv12_buffer_config *frame_to_filter, const struct macroblockd *mbd, const BLOCK_SIZE block_size, const int mb_row, const int mb_col, const int num_planes, const double *noise_levels, const MV *subblock_mvs, const int *subblock_mses, const int q_factor, const int filter_strength, int tf_wgt_calc_lvl, const uint8_t *pred, uint32_t *accum, uint16_t *count);
124 #define av1_apply_temporal_filter av1_apply_temporal_filter_c
125 
126 int64_t av1_block_error_c(const tran_low_t *coeff, const tran_low_t *dqcoeff, intptr_t block_size, int64_t *ssz);
127 #define av1_block_error av1_block_error_c
128 
129 int64_t av1_block_error_lp_c(const int16_t *coeff, const int16_t *dqcoeff, intptr_t block_size);
130 #define av1_block_error_lp av1_block_error_lp_c
131 
132 void av1_build_compound_diffwtd_mask_c(uint8_t *mask, DIFFWTD_MASK_TYPE mask_type, const uint8_t *src0, int src0_stride, const uint8_t *src1, int src1_stride, int h, int w);
133 #define av1_build_compound_diffwtd_mask av1_build_compound_diffwtd_mask_c
134 
135 void av1_build_compound_diffwtd_mask_d16_c(uint8_t *mask, DIFFWTD_MASK_TYPE mask_type, const CONV_BUF_TYPE *src0, int src0_stride, const CONV_BUF_TYPE *src1, int src1_stride, int h, int w, ConvolveParams *conv_params, int bd);
136 #define av1_build_compound_diffwtd_mask_d16 av1_build_compound_diffwtd_mask_d16_c
137 
138 void av1_build_compound_diffwtd_mask_highbd_c(uint8_t *mask, DIFFWTD_MASK_TYPE mask_type, const uint8_t *src0, int src0_stride, const uint8_t *src1, int src1_stride, int h, int w, int bd);
139 #define av1_build_compound_diffwtd_mask_highbd av1_build_compound_diffwtd_mask_highbd_c
140 
141 void av1_calc_indices_dim1_c(const int16_t *data, const int16_t *centroids, uint8_t *indices, int64_t *total_dist, int n, int k);
142 #define av1_calc_indices_dim1 av1_calc_indices_dim1_c
143 
144 void av1_calc_indices_dim2_c(const int16_t *data, const int16_t *centroids, uint8_t *indices, int64_t *total_dist, int n, int k);
145 #define av1_calc_indices_dim2 av1_calc_indices_dim2_c
146 
147 void av1_calc_proj_params_c(const uint8_t *src8, int width, int height, int src_stride, const uint8_t *dat8, int dat_stride, int32_t *flt0, int flt0_stride, int32_t *flt1, int flt1_stride, int64_t H[2][2], int64_t C[2], const sgr_params_type *params);
148 #define av1_calc_proj_params av1_calc_proj_params_c
149 
150 void av1_calc_proj_params_high_bd_c(const uint8_t *src8, int width, int height, int src_stride, const uint8_t *dat8, int dat_stride, int32_t *flt0, int flt0_stride, int32_t *flt1, int flt1_stride, int64_t H[2][2], int64_t C[2], const sgr_params_type *params);
151 #define av1_calc_proj_params_high_bd av1_calc_proj_params_high_bd_c
152 
153 void av1_cnn_activate_c(float **input, int channels, int width, int height, int stride, ACTIVATION layer_activation);
154 #define av1_cnn_activate av1_cnn_activate_c
155 
156 void av1_cnn_add_c(float **input, int channels, int width, int height, int stride, const float **add);
157 #define av1_cnn_add av1_cnn_add_c
158 
159 void av1_cnn_batchnorm_c(float **image, int channels, int width, int height, int stride, const float *gamma, const float *beta, const float *mean, const float *std);
160 #define av1_cnn_batchnorm av1_cnn_batchnorm_c
161 
162 void av1_cnn_convolve_no_maxpool_padding_valid_c(const float **input, int in_width, int in_height, int in_stride, const CNN_LAYER_CONFIG *layer_config, float **output, int out_stride, int start_idx, int cstep, int channel_step);
163 #define av1_cnn_convolve_no_maxpool_padding_valid av1_cnn_convolve_no_maxpool_padding_valid_c
164 
165 void av1_cnn_deconvolve_c(const float **input, int in_width, int in_height, int in_stride, const CNN_LAYER_CONFIG *layer_config, float **output, int out_stride);
166 #define av1_cnn_deconvolve av1_cnn_deconvolve_c
167 
168 bool av1_cnn_predict_c(const float **input, int in_width, int in_height, int in_stride, const CNN_CONFIG *cnn_config, const CNN_THREAD_DATA *thread_data, CNN_MULTI_OUT *output_struct);
169 #define av1_cnn_predict av1_cnn_predict_c
170 
171 void av1_compute_stats_c(int wiener_win, const uint8_t *dgd8, const uint8_t *src8, int16_t *dgd_avg, int16_t *src_avg, int h_start, int h_end, int v_start, int v_end, int dgd_stride, int src_stride, int64_t *M, int64_t *H, int use_downsampled_wiener_stats);
172 #define av1_compute_stats av1_compute_stats_c
173 
174 void av1_compute_stats_highbd_c(int wiener_win, const uint8_t *dgd8, const uint8_t *src8, int16_t *dgd_avg, int16_t *src_avg, int h_start, int h_end, int v_start, int v_end, int dgd_stride, int src_stride, int64_t *M, int64_t *H, aom_bit_depth_t bit_depth);
175 #define av1_compute_stats_highbd av1_compute_stats_highbd_c
176 
177 void av1_convolve_2d_scale_c(const uint8_t *src, int src_stride, uint8_t *dst, int dst_stride, int w, int h, const InterpFilterParams *filter_params_x, const InterpFilterParams *filter_params_y, const int subpel_x_qn, const int x_step_qn, const int subpel_y_qn, const int y_step_qn, ConvolveParams *conv_params);
178 #define av1_convolve_2d_scale av1_convolve_2d_scale_c
179 
180 void av1_convolve_2d_sr_c(const uint8_t *src, int src_stride, uint8_t *dst, int dst_stride, int w, int h, const InterpFilterParams *filter_params_x, const InterpFilterParams *filter_params_y, const int subpel_x_qn, const int subpel_y_qn, ConvolveParams *conv_params);
181 #define av1_convolve_2d_sr av1_convolve_2d_sr_c
182 
183 void av1_convolve_2d_sr_intrabc_c(const uint8_t *src, int src_stride, uint8_t *dst, int dst_stride, int w, int h, const InterpFilterParams *filter_params_x, const InterpFilterParams *filter_params_y, const int subpel_x_qn, const int subpel_y_qn, ConvolveParams *conv_params);
184 #define av1_convolve_2d_sr_intrabc av1_convolve_2d_sr_intrabc_c
185 
186 void av1_convolve_horiz_rs_c(const uint8_t *src, int src_stride, uint8_t *dst, int dst_stride, int w, int h, const int16_t *x_filters, int x0_qn, int x_step_qn);
187 #define av1_convolve_horiz_rs av1_convolve_horiz_rs_c
188 
189 void av1_convolve_x_sr_c(const uint8_t *src, int src_stride, uint8_t *dst, int dst_stride, int w, int h, const InterpFilterParams *filter_params_x, const int subpel_x_qn, ConvolveParams *conv_params);
190 #define av1_convolve_x_sr av1_convolve_x_sr_c
191 
192 void av1_convolve_x_sr_intrabc_c(const uint8_t *src, int src_stride, uint8_t *dst, int dst_stride, int w, int h, const InterpFilterParams *filter_params_x, const int subpel_x_qn, ConvolveParams *conv_params);
193 #define av1_convolve_x_sr_intrabc av1_convolve_x_sr_intrabc_c
194 
195 void av1_convolve_y_sr_c(const uint8_t *src, int src_stride, uint8_t *dst, int dst_stride, int w, int h, const InterpFilterParams *filter_params_y, const int subpel_y_qn);
196 #define av1_convolve_y_sr av1_convolve_y_sr_c
197 
198 void av1_convolve_y_sr_intrabc_c(const uint8_t *src, int src_stride, uint8_t *dst, int dst_stride, int w, int h, const InterpFilterParams *filter_params_y, const int subpel_y_qn);
199 #define av1_convolve_y_sr_intrabc av1_convolve_y_sr_intrabc_c
200 
201 void av1_dist_wtd_convolve_2d_c(const uint8_t *src, int src_stride, uint8_t *dst, int dst_stride, int w, int h, const InterpFilterParams *filter_params_x, const InterpFilterParams *filter_params_y, const int subpel_x_qn, const int subpel_y_qn, ConvolveParams *conv_params);
202 #define av1_dist_wtd_convolve_2d av1_dist_wtd_convolve_2d_c
203 
204 void av1_dist_wtd_convolve_2d_copy_c(const uint8_t *src, int src_stride, uint8_t *dst, int dst_stride, int w, int h, ConvolveParams *conv_params);
205 #define av1_dist_wtd_convolve_2d_copy av1_dist_wtd_convolve_2d_copy_c
206 
207 void av1_dist_wtd_convolve_x_c(const uint8_t *src, int src_stride, uint8_t *dst, int dst_stride, int w, int h, const InterpFilterParams *filter_params_x, const int subpel_x_qn, ConvolveParams *conv_params);
208 #define av1_dist_wtd_convolve_x av1_dist_wtd_convolve_x_c
209 
210 void av1_dist_wtd_convolve_y_c(const uint8_t *src, int src_stride, uint8_t *dst, int dst_stride, int w, int h, const InterpFilterParams *filter_params_y, const int subpel_y_qn, ConvolveParams *conv_params);
211 #define av1_dist_wtd_convolve_y av1_dist_wtd_convolve_y_c
212 
213 void av1_dr_prediction_z1_c(uint8_t *dst, ptrdiff_t stride, int bw, int bh, const uint8_t *above, const uint8_t *left, int upsample_above, int dx, int dy);
214 #define av1_dr_prediction_z1 av1_dr_prediction_z1_c
215 
216 void av1_dr_prediction_z2_c(uint8_t *dst, ptrdiff_t stride, int bw, int bh, const uint8_t *above, const uint8_t *left, int upsample_above, int upsample_left, int dx, int dy);
217 #define av1_dr_prediction_z2 av1_dr_prediction_z2_c
218 
219 void av1_dr_prediction_z3_c(uint8_t *dst, ptrdiff_t stride, int bw, int bh, const uint8_t *above, const uint8_t *left, int upsample_left, int dx, int dy);
220 #define av1_dr_prediction_z3 av1_dr_prediction_z3_c
221 
222 double av1_estimate_noise_from_single_plane_c(const uint8_t *src, int height, int width, int stride, int edge_thresh);
223 #define av1_estimate_noise_from_single_plane av1_estimate_noise_from_single_plane_c
224 
225 void av1_fdwt8x8_uint8_input_c(const uint8_t *input, tran_low_t *output, int stride, int hbd);
226 #define av1_fdwt8x8_uint8_input av1_fdwt8x8_uint8_input_c
227 
228 void av1_filter_intra_edge_c(uint8_t *p, int sz, int strength);
229 #define av1_filter_intra_edge av1_filter_intra_edge_c
230 
231 void av1_filter_intra_predictor_c(uint8_t *dst, ptrdiff_t stride, TX_SIZE tx_size, const uint8_t *above, const uint8_t *left, int mode);
232 #define av1_filter_intra_predictor av1_filter_intra_predictor_c
233 
234 void av1_fwd_txfm2d_16x16_c(const int16_t *input, int32_t *output, int stride, TX_TYPE tx_type, int bd);
235 #define av1_fwd_txfm2d_16x16 av1_fwd_txfm2d_16x16_c
236 
237 void av1_fwd_txfm2d_16x32_c(const int16_t *input, int32_t *output, int stride, TX_TYPE tx_type, int bd);
238 #define av1_fwd_txfm2d_16x32 av1_fwd_txfm2d_16x32_c
239 
240 void av1_fwd_txfm2d_16x4_c(const int16_t *input, int32_t *output, int stride, TX_TYPE tx_type, int bd);
241 #define av1_fwd_txfm2d_16x4 av1_fwd_txfm2d_16x4_c
242 
243 void av1_fwd_txfm2d_16x64_c(const int16_t *input, int32_t *output, int stride, TX_TYPE tx_type, int bd);
244 #define av1_fwd_txfm2d_16x64 av1_fwd_txfm2d_16x64_c
245 
246 void av1_fwd_txfm2d_16x8_c(const int16_t *input, int32_t *output, int stride, TX_TYPE tx_type, int bd);
247 #define av1_fwd_txfm2d_16x8 av1_fwd_txfm2d_16x8_c
248 
249 void av1_fwd_txfm2d_32x16_c(const int16_t *input, int32_t *output, int stride, TX_TYPE tx_type, int bd);
250 #define av1_fwd_txfm2d_32x16 av1_fwd_txfm2d_32x16_c
251 
252 void av1_fwd_txfm2d_32x32_c(const int16_t *input, int32_t *output, int stride, TX_TYPE tx_type, int bd);
253 #define av1_fwd_txfm2d_32x32 av1_fwd_txfm2d_32x32_c
254 
255 void av1_fwd_txfm2d_32x64_c(const int16_t *input, int32_t *output, int stride, TX_TYPE tx_type, int bd);
256 #define av1_fwd_txfm2d_32x64 av1_fwd_txfm2d_32x64_c
257 
258 void av1_fwd_txfm2d_32x8_c(const int16_t *input, int32_t *output, int stride, TX_TYPE tx_type, int bd);
259 #define av1_fwd_txfm2d_32x8 av1_fwd_txfm2d_32x8_c
260 
261 void av1_fwd_txfm2d_4x16_c(const int16_t *input, int32_t *output, int stride, TX_TYPE tx_type, int bd);
262 #define av1_fwd_txfm2d_4x16 av1_fwd_txfm2d_4x16_c
263 
264 void av1_fwd_txfm2d_4x4_c(const int16_t *input, int32_t *output, int stride, TX_TYPE tx_type, int bd);
265 #define av1_fwd_txfm2d_4x4 av1_fwd_txfm2d_4x4_c
266 
267 void av1_fwd_txfm2d_4x8_c(const int16_t *input, int32_t *output, int stride, TX_TYPE tx_type, int bd);
268 #define av1_fwd_txfm2d_4x8 av1_fwd_txfm2d_4x8_c
269 
270 void av1_fwd_txfm2d_64x16_c(const int16_t *input, int32_t *output, int stride, TX_TYPE tx_type, int bd);
271 #define av1_fwd_txfm2d_64x16 av1_fwd_txfm2d_64x16_c
272 
273 void av1_fwd_txfm2d_64x32_c(const int16_t *input, int32_t *output, int stride, TX_TYPE tx_type, int bd);
274 #define av1_fwd_txfm2d_64x32 av1_fwd_txfm2d_64x32_c
275 
276 void av1_fwd_txfm2d_64x64_c(const int16_t *input, int32_t *output, int stride, TX_TYPE tx_type, int bd);
277 #define av1_fwd_txfm2d_64x64 av1_fwd_txfm2d_64x64_c
278 
279 void av1_fwd_txfm2d_8x16_c(const int16_t *input, int32_t *output, int stride, TX_TYPE tx_type, int bd);
280 #define av1_fwd_txfm2d_8x16 av1_fwd_txfm2d_8x16_c
281 
282 void av1_fwd_txfm2d_8x32_c(const int16_t *input, int32_t *output, int stride, TX_TYPE tx_type, int bd);
283 #define av1_fwd_txfm2d_8x32 av1_fwd_txfm2d_8x32_c
284 
285 void av1_fwd_txfm2d_8x4_c(const int16_t *input, int32_t *output, int stride, TX_TYPE tx_type, int bd);
286 #define av1_fwd_txfm2d_8x4 av1_fwd_txfm2d_8x4_c
287 
288 void av1_fwd_txfm2d_8x8_c(const int16_t *input, int32_t *output, int stride, TX_TYPE tx_type, int bd);
289 #define av1_fwd_txfm2d_8x8 av1_fwd_txfm2d_8x8_c
290 
291 void av1_fwht4x4_c(const int16_t *input, tran_low_t *output, int stride);
292 #define av1_fwht4x4 av1_fwht4x4_c
293 
294 uint32_t av1_get_crc32c_value_c(void *crc_calculator, uint8_t *p, size_t length);
295 #define av1_get_crc32c_value av1_get_crc32c_value_c
296 
297 void av1_get_horver_correlation_full_c(const int16_t *diff, int stride, int w, int h, float *hcorr, float *vcorr);
298 #define av1_get_horver_correlation_full av1_get_horver_correlation_full_c
299 
300 void av1_get_nz_map_contexts_c(const uint8_t *const levels, const int16_t *const scan, const uint16_t eob, const TX_SIZE tx_size, const TX_CLASS tx_class, int8_t *const coeff_contexts);
301 #define av1_get_nz_map_contexts av1_get_nz_map_contexts_c
302 
303 void av1_highbd_apply_temporal_filter_c(const struct yv12_buffer_config *frame_to_filter, const struct macroblockd *mbd, const BLOCK_SIZE block_size, const int mb_row, const int mb_col, const int num_planes, const double *noise_levels, const MV *subblock_mvs, const int *subblock_mses, const int q_factor, const int filter_strength, int tf_wgt_calc_lvl, const uint8_t *pred, uint32_t *accum, uint16_t *count);
304 #define av1_highbd_apply_temporal_filter av1_highbd_apply_temporal_filter_c
305 
306 int64_t av1_highbd_block_error_c(const tran_low_t *coeff, const tran_low_t *dqcoeff, intptr_t block_size, int64_t *ssz, int bd);
307 #define av1_highbd_block_error av1_highbd_block_error_c
308 
309 void av1_highbd_convolve8_c(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const int16_t *filter_x, int x_step_q4, const int16_t *filter_y, int y_step_q4, int w, int h, int bps);
310 #define av1_highbd_convolve8 av1_highbd_convolve8_c
311 
312 void av1_highbd_convolve8_horiz_c(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const int16_t *filter_x, int x_step_q4, const int16_t *filter_y, int y_step_q4, int w, int h, int bps);
313 #define av1_highbd_convolve8_horiz av1_highbd_convolve8_horiz_c
314 
315 void av1_highbd_convolve8_vert_c(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const int16_t *filter_x, int x_step_q4, const int16_t *filter_y, int y_step_q4, int w, int h, int bps);
316 #define av1_highbd_convolve8_vert av1_highbd_convolve8_vert_c
317 
318 void av1_highbd_convolve_2d_scale_c(const uint16_t *src, int src_stride, uint16_t *dst, int dst_stride, int w, int h, const InterpFilterParams *filter_params_x, const InterpFilterParams *filter_params_y, const int subpel_x_qn, const int x_step_qn, const int subpel_y_qn, const int y_step_qn, ConvolveParams *conv_params, int bd);
319 #define av1_highbd_convolve_2d_scale av1_highbd_convolve_2d_scale_c
320 
321 void av1_highbd_convolve_2d_sr_c(const uint16_t *src, int src_stride, uint16_t *dst, int dst_stride, int w, int h, const InterpFilterParams *filter_params_x, const InterpFilterParams *filter_params_y, const int subpel_x_qn, const int subpel_y_qn, ConvolveParams *conv_params, int bd);
322 #define av1_highbd_convolve_2d_sr av1_highbd_convolve_2d_sr_c
323 
324 void av1_highbd_convolve_2d_sr_intrabc_c(const uint16_t *src, int src_stride, uint16_t *dst, int dst_stride, int w, int h, const InterpFilterParams *filter_params_x, const InterpFilterParams *filter_params_y, const int subpel_x_qn, const int subpel_y_qn, ConvolveParams *conv_params, int bd);
325 #define av1_highbd_convolve_2d_sr_intrabc av1_highbd_convolve_2d_sr_intrabc_c
326 
327 void av1_highbd_convolve_avg_c(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const int16_t *filter_x, int x_step_q4, const int16_t *filter_y, int y_step_q4, int w, int h, int bps);
328 #define av1_highbd_convolve_avg av1_highbd_convolve_avg_c
329 
330 void av1_highbd_convolve_copy_c(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const int16_t *filter_x, int x_step_q4, const int16_t *filter_y, int y_step_q4, int w, int h, int bps);
331 #define av1_highbd_convolve_copy av1_highbd_convolve_copy_c
332 
333 void av1_highbd_convolve_horiz_rs_c(const uint16_t *src, int src_stride, uint16_t *dst, int dst_stride, int w, int h, const int16_t *x_filters, int x0_qn, int x_step_qn, int bd);
334 #define av1_highbd_convolve_horiz_rs av1_highbd_convolve_horiz_rs_c
335 
336 void av1_highbd_convolve_x_sr_c(const uint16_t *src, int src_stride, uint16_t *dst, int dst_stride, int w, int h, const InterpFilterParams *filter_params_x, const int subpel_x_qn, ConvolveParams *conv_params, int bd);
337 #define av1_highbd_convolve_x_sr av1_highbd_convolve_x_sr_c
338 
339 void av1_highbd_convolve_x_sr_intrabc_c(const uint16_t *src, int src_stride, uint16_t *dst, int dst_stride, int w, int h, const InterpFilterParams *filter_params_x, const int subpel_x_qn, ConvolveParams *conv_params, int bd);
340 #define av1_highbd_convolve_x_sr_intrabc av1_highbd_convolve_x_sr_intrabc_c
341 
342 void av1_highbd_convolve_y_sr_c(const uint16_t *src, int src_stride, uint16_t *dst, int dst_stride, int w, int h, const InterpFilterParams *filter_params_y, const int subpel_y_qn, int bd);
343 #define av1_highbd_convolve_y_sr av1_highbd_convolve_y_sr_c
344 
345 void av1_highbd_convolve_y_sr_intrabc_c(const uint16_t *src, int src_stride, uint16_t *dst, int dst_stride, int w, int h, const InterpFilterParams *filter_params_y, const int subpel_y_qn, int bd);
346 #define av1_highbd_convolve_y_sr_intrabc av1_highbd_convolve_y_sr_intrabc_c
347 
348 void av1_highbd_dist_wtd_convolve_2d_c(const uint16_t *src, int src_stride, uint16_t *dst, int dst_stride, int w, int h, const InterpFilterParams *filter_params_x, const InterpFilterParams *filter_params_y, const int subpel_x_qn, const int subpel_y_qn, ConvolveParams *conv_params, int bd);
349 #define av1_highbd_dist_wtd_convolve_2d av1_highbd_dist_wtd_convolve_2d_c
350 
351 void av1_highbd_dist_wtd_convolve_2d_copy_c(const uint16_t *src, int src_stride, uint16_t *dst, int dst_stride, int w, int h, ConvolveParams *conv_params, int bd);
352 #define av1_highbd_dist_wtd_convolve_2d_copy av1_highbd_dist_wtd_convolve_2d_copy_c
353 
354 void av1_highbd_dist_wtd_convolve_x_c(const uint16_t *src, int src_stride, uint16_t *dst, int dst_stride, int w, int h, const InterpFilterParams *filter_params_x, const int subpel_x_qn, ConvolveParams *conv_params, int bd);
355 #define av1_highbd_dist_wtd_convolve_x av1_highbd_dist_wtd_convolve_x_c
356 
357 void av1_highbd_dist_wtd_convolve_y_c(const uint16_t *src, int src_stride, uint16_t *dst, int dst_stride, int w, int h, const InterpFilterParams *filter_params_y, const int subpel_y_qn, ConvolveParams *conv_params, int bd);
358 #define av1_highbd_dist_wtd_convolve_y av1_highbd_dist_wtd_convolve_y_c
359 
360 void av1_highbd_dr_prediction_z1_c(uint16_t *dst, ptrdiff_t stride, int bw, int bh, const uint16_t *above, const uint16_t *left, int upsample_above, int dx, int dy, int bd);
361 #define av1_highbd_dr_prediction_z1 av1_highbd_dr_prediction_z1_c
362 
363 void av1_highbd_dr_prediction_z2_c(uint16_t *dst, ptrdiff_t stride, int bw, int bh, const uint16_t *above, const uint16_t *left, int upsample_above, int upsample_left, int dx, int dy, int bd);
364 #define av1_highbd_dr_prediction_z2 av1_highbd_dr_prediction_z2_c
365 
366 void av1_highbd_dr_prediction_z3_c(uint16_t *dst, ptrdiff_t stride, int bw, int bh, const uint16_t *above, const uint16_t *left, int upsample_left, int dx, int dy, int bd);
367 #define av1_highbd_dr_prediction_z3 av1_highbd_dr_prediction_z3_c
368 
369 double av1_highbd_estimate_noise_from_single_plane_c(const uint16_t *src, int height, int width, int stride, int bit_depth, int edge_thresh);
370 #define av1_highbd_estimate_noise_from_single_plane av1_highbd_estimate_noise_from_single_plane_c
371 
372 void av1_highbd_filter_intra_edge_c(uint16_t *p, int sz, int strength);
373 #define av1_highbd_filter_intra_edge av1_highbd_filter_intra_edge_c
374 
375 void av1_highbd_inv_txfm_add_c(const tran_low_t *input, uint8_t *dest, int stride, const TxfmParam *txfm_param);
376 #define av1_highbd_inv_txfm_add av1_highbd_inv_txfm_add_c
377 
378 void av1_highbd_iwht4x4_16_add_c(const tran_low_t *input, uint8_t *dest, int dest_stride, int bd);
379 #define av1_highbd_iwht4x4_16_add av1_highbd_iwht4x4_16_add_c
380 
381 void av1_highbd_iwht4x4_1_add_c(const tran_low_t *input, uint8_t *dest, int dest_stride, int bd);
382 #define av1_highbd_iwht4x4_1_add av1_highbd_iwht4x4_1_add_c
383 
384 int64_t av1_highbd_pixel_proj_error_c(const uint8_t *src8, int width, int height, int src_stride, const uint8_t *dat8, int dat_stride, int32_t *flt0, int flt0_stride, int32_t *flt1, int flt1_stride, int xq[2], const sgr_params_type *params);
385 #define av1_highbd_pixel_proj_error av1_highbd_pixel_proj_error_c
386 
387 void av1_highbd_quantize_fp_c(const tran_low_t *coeff_ptr, intptr_t n_coeffs, const int16_t *zbin_ptr, const int16_t *round_ptr, const int16_t *quant_ptr, const int16_t *quant_shift_ptr, tran_low_t *qcoeff_ptr, tran_low_t *dqcoeff_ptr, const int16_t *dequant_ptr, uint16_t *eob_ptr, const int16_t *scan, const int16_t *iscan, int log_scale);
388 #define av1_highbd_quantize_fp av1_highbd_quantize_fp_c
389 
390 void av1_highbd_upsample_intra_edge_c(uint16_t *p, int sz, int bd);
391 #define av1_highbd_upsample_intra_edge av1_highbd_upsample_intra_edge_c
392 
393 void av1_highbd_warp_affine_c(const int32_t *mat, const uint16_t *ref, int width, int height, int stride, uint16_t *pred, int p_col, int p_row, int p_width, int p_height, int p_stride, int subsampling_x, int subsampling_y, int bd, ConvolveParams *conv_params, int16_t alpha, int16_t beta, int16_t gamma, int16_t delta);
394 #define av1_highbd_warp_affine av1_highbd_warp_affine_c
395 
396 void av1_highbd_wiener_convolve_add_src_c(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const int16_t *filter_x, int x_step_q4, const int16_t *filter_y, int y_step_q4, int w, int h, const WienerConvolveParams *conv_params, int bd);
397 #define av1_highbd_wiener_convolve_add_src av1_highbd_wiener_convolve_add_src_c
398 
399 void av1_inv_txfm2d_add_16x16_c(const int32_t *input, uint16_t *output, int stride, TX_TYPE tx_type, int bd);
400 #define av1_inv_txfm2d_add_16x16 av1_inv_txfm2d_add_16x16_c
401 
402 void av1_inv_txfm2d_add_16x32_c(const int32_t *input, uint16_t *output, int stride, TX_TYPE tx_type, int bd);
403 #define av1_inv_txfm2d_add_16x32 av1_inv_txfm2d_add_16x32_c
404 
405 void av1_inv_txfm2d_add_16x4_c(const int32_t *input, uint16_t *output, int stride, TX_TYPE tx_type, int bd);
406 #define av1_inv_txfm2d_add_16x4 av1_inv_txfm2d_add_16x4_c
407 
408 void av1_inv_txfm2d_add_16x64_c(const int32_t *input, uint16_t *output, int stride, TX_TYPE tx_type, int bd);
409 #define av1_inv_txfm2d_add_16x64 av1_inv_txfm2d_add_16x64_c
410 
411 void av1_inv_txfm2d_add_16x8_c(const int32_t *input, uint16_t *output, int stride, TX_TYPE tx_type, int bd);
412 #define av1_inv_txfm2d_add_16x8 av1_inv_txfm2d_add_16x8_c
413 
414 void av1_inv_txfm2d_add_32x16_c(const int32_t *input, uint16_t *output, int stride, TX_TYPE tx_type, int bd);
415 #define av1_inv_txfm2d_add_32x16 av1_inv_txfm2d_add_32x16_c
416 
417 void av1_inv_txfm2d_add_32x32_c(const int32_t *input, uint16_t *output, int stride, TX_TYPE tx_type, int bd);
418 #define av1_inv_txfm2d_add_32x32 av1_inv_txfm2d_add_32x32_c
419 
420 void av1_inv_txfm2d_add_32x64_c(const int32_t *input, uint16_t *output, int stride, TX_TYPE tx_type, int bd);
421 #define av1_inv_txfm2d_add_32x64 av1_inv_txfm2d_add_32x64_c
422 
423 void av1_inv_txfm2d_add_32x8_c(const int32_t *input, uint16_t *output, int stride, TX_TYPE tx_type, int bd);
424 #define av1_inv_txfm2d_add_32x8 av1_inv_txfm2d_add_32x8_c
425 
426 void av1_inv_txfm2d_add_4x16_c(const int32_t *input, uint16_t *output, int stride, TX_TYPE tx_type, int bd);
427 #define av1_inv_txfm2d_add_4x16 av1_inv_txfm2d_add_4x16_c
428 
429 void av1_inv_txfm2d_add_4x4_c(const int32_t *input, uint16_t *output, int stride, TX_TYPE tx_type, int bd);
430 #define av1_inv_txfm2d_add_4x4 av1_inv_txfm2d_add_4x4_c
431 
432 void av1_inv_txfm2d_add_4x8_c(const int32_t *input, uint16_t *output, int stride, TX_TYPE tx_type, int bd);
433 #define av1_inv_txfm2d_add_4x8 av1_inv_txfm2d_add_4x8_c
434 
435 void av1_inv_txfm2d_add_64x16_c(const int32_t *input, uint16_t *output, int stride, TX_TYPE tx_type, int bd);
436 #define av1_inv_txfm2d_add_64x16 av1_inv_txfm2d_add_64x16_c
437 
438 void av1_inv_txfm2d_add_64x32_c(const int32_t *input, uint16_t *output, int stride, TX_TYPE tx_type, int bd);
439 #define av1_inv_txfm2d_add_64x32 av1_inv_txfm2d_add_64x32_c
440 
441 void av1_inv_txfm2d_add_64x64_c(const int32_t *input, uint16_t *output, int stride, TX_TYPE tx_type, int bd);
442 #define av1_inv_txfm2d_add_64x64 av1_inv_txfm2d_add_64x64_c
443 
444 void av1_inv_txfm2d_add_8x16_c(const int32_t *input, uint16_t *output, int stride, TX_TYPE tx_type, int bd);
445 #define av1_inv_txfm2d_add_8x16 av1_inv_txfm2d_add_8x16_c
446 
447 void av1_inv_txfm2d_add_8x32_c(const int32_t *input, uint16_t *output, int stride, TX_TYPE tx_type, int bd);
448 #define av1_inv_txfm2d_add_8x32 av1_inv_txfm2d_add_8x32_c
449 
450 void av1_inv_txfm2d_add_8x4_c(const int32_t *input, uint16_t *output, int stride, TX_TYPE tx_type, int bd);
451 #define av1_inv_txfm2d_add_8x4 av1_inv_txfm2d_add_8x4_c
452 
453 void av1_inv_txfm2d_add_8x8_c(const int32_t *input, uint16_t *output, int stride, TX_TYPE tx_type, int bd);
454 #define av1_inv_txfm2d_add_8x8 av1_inv_txfm2d_add_8x8_c
455 
456 void av1_inv_txfm_add_c(const tran_low_t *dqcoeff, uint8_t *dst, int stride, const TxfmParam *txfm_param);
457 #define av1_inv_txfm_add av1_inv_txfm_add_c
458 
459 void av1_lowbd_fwd_txfm_c(const int16_t *src_diff, tran_low_t *coeff, int diff_stride, TxfmParam *txfm_param);
460 #define av1_lowbd_fwd_txfm av1_lowbd_fwd_txfm_c
461 
462 int64_t av1_lowbd_pixel_proj_error_c(const uint8_t *src8, int width, int height, int src_stride, const uint8_t *dat8, int dat_stride, int32_t *flt0, int flt0_stride, int32_t *flt1, int flt1_stride, int xq[2], const sgr_params_type *params);
463 #define av1_lowbd_pixel_proj_error av1_lowbd_pixel_proj_error_c
464 
465 void av1_nn_fast_softmax_16_c(const float *input_nodes, float *output);
466 #define av1_nn_fast_softmax_16 av1_nn_fast_softmax_16_c
467 
468 void av1_nn_predict_c(const float *input_nodes, const NN_CONFIG *const nn_config, int reduce_prec, float *const output);
469 #define av1_nn_predict av1_nn_predict_c
470 
471 void av1_quantize_b_c(const tran_low_t *coeff_ptr, intptr_t n_coeffs, const int16_t *zbin_ptr, const int16_t *round_ptr, const int16_t *quant_ptr, const int16_t *quant_shift_ptr, tran_low_t *qcoeff_ptr, tran_low_t *dqcoeff_ptr, const int16_t *dequant_ptr, uint16_t *eob_ptr, const int16_t *scan, const int16_t *iscan, const qm_val_t * qm_ptr, const qm_val_t * iqm_ptr, int log_scale);
472 #define av1_quantize_b av1_quantize_b_c
473 
474 void av1_quantize_fp_c(const tran_low_t *coeff_ptr, intptr_t n_coeffs, const int16_t *zbin_ptr, const int16_t *round_ptr, const int16_t *quant_ptr, const int16_t *quant_shift_ptr, tran_low_t *qcoeff_ptr, tran_low_t *dqcoeff_ptr, const int16_t *dequant_ptr, uint16_t *eob_ptr, const int16_t *scan, const int16_t *iscan);
475 #define av1_quantize_fp av1_quantize_fp_c
476 
477 void av1_quantize_fp_32x32_c(const tran_low_t *coeff_ptr, intptr_t n_coeffs, const int16_t *zbin_ptr, const int16_t *round_ptr, const int16_t *quant_ptr, const int16_t *quant_shift_ptr, tran_low_t *qcoeff_ptr, tran_low_t *dqcoeff_ptr, const int16_t *dequant_ptr, uint16_t *eob_ptr, const int16_t *scan, const int16_t *iscan);
478 #define av1_quantize_fp_32x32 av1_quantize_fp_32x32_c
479 
480 void av1_quantize_fp_64x64_c(const tran_low_t *coeff_ptr, intptr_t n_coeffs, const int16_t *zbin_ptr, const int16_t *round_ptr, const int16_t *quant_ptr, const int16_t *quant_shift_ptr, tran_low_t *qcoeff_ptr, tran_low_t *dqcoeff_ptr, const int16_t *dequant_ptr, uint16_t *eob_ptr, const int16_t *scan, const int16_t *iscan);
481 #define av1_quantize_fp_64x64 av1_quantize_fp_64x64_c
482 
483 void av1_quantize_lp_c(const int16_t *coeff_ptr, intptr_t n_coeffs, const int16_t *round_ptr, const int16_t *quant_ptr, int16_t *qcoeff_ptr, int16_t *dqcoeff_ptr, const int16_t *dequant_ptr, uint16_t *eob_ptr, const int16_t *scan, const int16_t *iscan);
484 #define av1_quantize_lp av1_quantize_lp_c
485 
486 void av1_resize_and_extend_frame_c(const YV12_BUFFER_CONFIG *src, YV12_BUFFER_CONFIG *dst, const InterpFilter filter, const int phase, const int num_planes);
487 #define av1_resize_and_extend_frame av1_resize_and_extend_frame_c
488 
489 void av1_resize_horz_dir_c(const uint8_t *const input, int in_stride, uint8_t *intbuf, int height, int filtered_length, int width2);
490 #define av1_resize_horz_dir av1_resize_horz_dir_c
491 
492 bool av1_resize_vert_dir_c(uint8_t *intbuf, uint8_t *output, int out_stride, int height, int height2, int width2, int start_col);
493 #define av1_resize_vert_dir av1_resize_vert_dir_c
494 
495 void av1_round_shift_array_c(int32_t *arr, int size, int bit);
496 #define av1_round_shift_array av1_round_shift_array_c
497 
498 int av1_selfguided_restoration_c(const uint8_t *dgd8, int width, int height,
499                                   int dgd_stride, int32_t *flt0, int32_t *flt1, int flt_stride,
500                                   int sgr_params_idx, int bit_depth, int highbd);
501 #define av1_selfguided_restoration av1_selfguided_restoration_c
502 
503 void av1_txb_init_levels_c(const tran_low_t *const coeff, const int width, const int height, uint8_t *const levels);
504 #define av1_txb_init_levels av1_txb_init_levels_c
505 
506 void av1_upsample_intra_edge_c(uint8_t *p, int sz);
507 #define av1_upsample_intra_edge av1_upsample_intra_edge_c
508 
509 void av1_warp_affine_c(const int32_t *mat, const uint8_t *ref, int width, int height, int stride, uint8_t *pred, int p_col, int p_row, int p_width, int p_height, int p_stride, int subsampling_x, int subsampling_y, ConvolveParams *conv_params, int16_t alpha, int16_t beta, int16_t gamma, int16_t delta);
510 #define av1_warp_affine av1_warp_affine_c
511 
512 void av1_wedge_compute_delta_squares_c(int16_t *d, const int16_t *a, const int16_t *b, int N);
513 #define av1_wedge_compute_delta_squares av1_wedge_compute_delta_squares_c
514 
515 int8_t av1_wedge_sign_from_residuals_c(const int16_t *ds, const uint8_t *m, int N, int64_t limit);
516 #define av1_wedge_sign_from_residuals av1_wedge_sign_from_residuals_c
517 
518 uint64_t av1_wedge_sse_from_residuals_c(const int16_t *r1, const int16_t *d, const uint8_t *m, int N);
519 #define av1_wedge_sse_from_residuals av1_wedge_sse_from_residuals_c
520 
521 void av1_wiener_convolve_add_src_c(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const int16_t *filter_x, int x_step_q4, const int16_t *filter_y, int y_step_q4, int w, int h, const WienerConvolveParams *conv_params);
522 #define av1_wiener_convolve_add_src av1_wiener_convolve_add_src_c
523 
524 void cdef_copy_rect8_16bit_to_16bit_c(uint16_t *dst, int dstride, const uint16_t *src, int sstride, int width, int height);
525 #define cdef_copy_rect8_16bit_to_16bit cdef_copy_rect8_16bit_to_16bit_c
526 
527 void cdef_copy_rect8_8bit_to_16bit_c(uint16_t *dst, int dstride, const uint8_t *src, int sstride, int width, int height);
528 #define cdef_copy_rect8_8bit_to_16bit cdef_copy_rect8_8bit_to_16bit_c
529 
530 void cdef_filter_16_0_c(void *dst16, int dstride, const uint16_t *in, int pri_strength, int sec_strength, int dir, int pri_damping, int sec_damping, int coeff_shift, int block_width, int block_height);
531 #define cdef_filter_16_0 cdef_filter_16_0_c
532 
533 void cdef_filter_16_1_c(void *dst16, int dstride, const uint16_t *in, int pri_strength, int sec_strength, int dir, int pri_damping, int sec_damping, int coeff_shift, int block_width, int block_height);
534 #define cdef_filter_16_1 cdef_filter_16_1_c
535 
536 void cdef_filter_16_2_c(void *dst16, int dstride, const uint16_t *in, int pri_strength, int sec_strength, int dir, int pri_damping, int sec_damping, int coeff_shift, int block_width, int block_height);
537 #define cdef_filter_16_2 cdef_filter_16_2_c
538 
539 void cdef_filter_16_3_c(void *dst16, int dstride, const uint16_t *in, int pri_strength, int sec_strength, int dir, int pri_damping, int sec_damping, int coeff_shift, int block_width, int block_height);
540 #define cdef_filter_16_3 cdef_filter_16_3_c
541 
542 void cdef_filter_8_0_c(void *dst8, int dstride, const uint16_t *in, int pri_strength, int sec_strength, int dir, int pri_damping, int sec_damping, int coeff_shift, int block_width, int block_height);
543 #define cdef_filter_8_0 cdef_filter_8_0_c
544 
545 void cdef_filter_8_1_c(void *dst8, int dstride, const uint16_t *in, int pri_strength, int sec_strength, int dir, int pri_damping, int sec_damping, int coeff_shift, int block_width, int block_height);
546 #define cdef_filter_8_1 cdef_filter_8_1_c
547 
548 void cdef_filter_8_2_c(void *dst8, int dstride, const uint16_t *in, int pri_strength, int sec_strength, int dir, int pri_damping, int sec_damping, int coeff_shift, int block_width, int block_height);
549 #define cdef_filter_8_2 cdef_filter_8_2_c
550 
551 void cdef_filter_8_3_c(void *dst8, int dstride, const uint16_t *in, int pri_strength, int sec_strength, int dir, int pri_damping, int sec_damping, int coeff_shift, int block_width, int block_height);
552 #define cdef_filter_8_3 cdef_filter_8_3_c
553 
554 int cdef_find_dir_c(const uint16_t *img, int stride, int32_t *var, int coeff_shift);
555 #define cdef_find_dir cdef_find_dir_c
556 
557 void cdef_find_dir_dual_c(const uint16_t *img1, const uint16_t *img2, int stride, int32_t *var1, int32_t *var2, int coeff_shift, int *out1, int *out2);
558 #define cdef_find_dir_dual cdef_find_dir_dual_c
559 
560 cfl_subsample_hbd_fn cfl_get_luma_subsampling_420_hbd_c(TX_SIZE tx_size);
561 #define cfl_get_luma_subsampling_420_hbd cfl_get_luma_subsampling_420_hbd_c
562 
563 cfl_subsample_lbd_fn cfl_get_luma_subsampling_420_lbd_c(TX_SIZE tx_size);
564 #define cfl_get_luma_subsampling_420_lbd cfl_get_luma_subsampling_420_lbd_c
565 
566 cfl_subsample_hbd_fn cfl_get_luma_subsampling_422_hbd_c(TX_SIZE tx_size);
567 #define cfl_get_luma_subsampling_422_hbd cfl_get_luma_subsampling_422_hbd_c
568 
569 cfl_subsample_lbd_fn cfl_get_luma_subsampling_422_lbd_c(TX_SIZE tx_size);
570 #define cfl_get_luma_subsampling_422_lbd cfl_get_luma_subsampling_422_lbd_c
571 
572 cfl_subsample_hbd_fn cfl_get_luma_subsampling_444_hbd_c(TX_SIZE tx_size);
573 #define cfl_get_luma_subsampling_444_hbd cfl_get_luma_subsampling_444_hbd_c
574 
575 cfl_subsample_lbd_fn cfl_get_luma_subsampling_444_lbd_c(TX_SIZE tx_size);
576 #define cfl_get_luma_subsampling_444_lbd cfl_get_luma_subsampling_444_lbd_c
577 
578 cfl_predict_hbd_fn cfl_get_predict_hbd_fn_c(TX_SIZE tx_size);
579 #define cfl_get_predict_hbd_fn cfl_get_predict_hbd_fn_c
580 
581 cfl_predict_lbd_fn cfl_get_predict_lbd_fn_c(TX_SIZE tx_size);
582 #define cfl_get_predict_lbd_fn cfl_get_predict_lbd_fn_c
583 
584 cfl_subtract_average_fn cfl_get_subtract_average_fn_c(TX_SIZE tx_size);
585 #define cfl_get_subtract_average_fn cfl_get_subtract_average_fn_c
586 
587 void av1_rtcd(void);
588 
589 #include "config/aom_config.h"
590 
591 #ifdef RTCD_C
setup_rtcd_internal(void)592 static void setup_rtcd_internal(void)
593 {
594 }
595 #endif
596 
597 #ifdef __cplusplus
598 }  // extern "C"
599 #endif
600 
601 #endif  // AV1_RTCD_H_
602