Home | History | Annotate | Download | only in mips-dspr2
      1 #ifndef VP8_RTCD_H_
      2 #define VP8_RTCD_H_
      3 
      4 #ifdef RTCD_C
      5 #define RTCD_EXTERN
      6 #else
      7 #define RTCD_EXTERN extern
      8 #endif
      9 
     10 #ifdef __cplusplus
     11 extern "C" {
     12 #endif
     13 
     14 /*
     15  * VP8
     16  */
     17 
     18 struct blockd;
     19 struct macroblockd;
     20 struct loop_filter_info;
     21 
     22 /* Encoder forward decls */
     23 struct block;
     24 struct macroblock;
     25 struct variance_vtable;
     26 union int_mv;
     27 struct yv12_buffer_config;
     28 
     29 void vp8_bilinear_predict16x16_c(unsigned char *src, int src_pitch, int xofst, int yofst, unsigned char *dst, int dst_pitch);
     30 #define vp8_bilinear_predict16x16 vp8_bilinear_predict16x16_c
     31 
     32 void vp8_bilinear_predict4x4_c(unsigned char *src, int src_pitch, int xofst, int yofst, unsigned char *dst, int dst_pitch);
     33 #define vp8_bilinear_predict4x4 vp8_bilinear_predict4x4_c
     34 
     35 void vp8_bilinear_predict8x4_c(unsigned char *src, int src_pitch, int xofst, int yofst, unsigned char *dst, int dst_pitch);
     36 #define vp8_bilinear_predict8x4 vp8_bilinear_predict8x4_c
     37 
     38 void vp8_bilinear_predict8x8_c(unsigned char *src, int src_pitch, int xofst, int yofst, unsigned char *dst, int dst_pitch);
     39 #define vp8_bilinear_predict8x8 vp8_bilinear_predict8x8_c
     40 
     41 int vp8_block_error_c(short *coeff, short *dqcoeff);
     42 #define vp8_block_error vp8_block_error_c
     43 
     44 void vp8_build_intra_predictors_mbuv_s_c(struct macroblockd *x, unsigned char * uabove_row, unsigned char * vabove_row,  unsigned char *uleft, unsigned char *vleft, int left_stride, unsigned char * upred_ptr, unsigned char * vpred_ptr, int pred_stride);
     45 #define vp8_build_intra_predictors_mbuv_s vp8_build_intra_predictors_mbuv_s_c
     46 
     47 void vp8_build_intra_predictors_mby_s_c(struct macroblockd *x, unsigned char * yabove_row, unsigned char * yleft, int left_stride, unsigned char * ypred_ptr, int y_stride);
     48 #define vp8_build_intra_predictors_mby_s vp8_build_intra_predictors_mby_s_c
     49 
     50 void vp8_clear_system_state_c();
     51 #define vp8_clear_system_state vp8_clear_system_state_c
     52 
     53 void vp8_copy_mem16x16_c(unsigned char *src, int src_pitch, unsigned char *dst, int dst_pitch);
     54 void vp8_copy_mem16x16_dspr2(unsigned char *src, int src_pitch, unsigned char *dst, int dst_pitch);
     55 #define vp8_copy_mem16x16 vp8_copy_mem16x16_dspr2
     56 
     57 void vp8_copy_mem8x4_c(unsigned char *src, int src_pitch, unsigned char *dst, int dst_pitch);
     58 void vp8_copy_mem8x4_dspr2(unsigned char *src, int src_pitch, unsigned char *dst, int dst_pitch);
     59 #define vp8_copy_mem8x4 vp8_copy_mem8x4_dspr2
     60 
     61 void vp8_copy_mem8x8_c(unsigned char *src, int src_pitch, unsigned char *dst, int dst_pitch);
     62 void vp8_copy_mem8x8_dspr2(unsigned char *src, int src_pitch, unsigned char *dst, int dst_pitch);
     63 #define vp8_copy_mem8x8 vp8_copy_mem8x8_dspr2
     64 
     65 void vp8_dc_only_idct_add_c(short input, unsigned char *pred, int pred_stride, unsigned char *dst, int dst_stride);
     66 void vp8_dc_only_idct_add_dspr2(short input, unsigned char *pred, int pred_stride, unsigned char *dst, int dst_stride);
     67 #define vp8_dc_only_idct_add vp8_dc_only_idct_add_dspr2
     68 
     69 int vp8_denoiser_filter_c(struct yv12_buffer_config* mc_running_avg, struct yv12_buffer_config* running_avg, struct macroblock* signal, unsigned int motion_magnitude2, int y_offset, int uv_offset);
     70 #define vp8_denoiser_filter vp8_denoiser_filter_c
     71 
     72 void vp8_dequant_idct_add_c(short *input, short *dq, unsigned char *output, int stride);
     73 void vp8_dequant_idct_add_dspr2(short *input, short *dq, unsigned char *output, int stride);
     74 #define vp8_dequant_idct_add vp8_dequant_idct_add_dspr2
     75 
     76 void vp8_dequant_idct_add_uv_block_c(short *q, short *dq, unsigned char *dst_u, unsigned char *dst_v, int stride, char *eobs);
     77 void vp8_dequant_idct_add_uv_block_dspr2(short *q, short *dq, unsigned char *dst_u, unsigned char *dst_v, int stride, char *eobs);
     78 #define vp8_dequant_idct_add_uv_block vp8_dequant_idct_add_uv_block_dspr2
     79 
     80 void vp8_dequant_idct_add_y_block_c(short *q, short *dq, unsigned char *dst, int stride, char *eobs);
     81 void vp8_dequant_idct_add_y_block_dspr2(short *q, short *dq, unsigned char *dst, int stride, char *eobs);
     82 #define vp8_dequant_idct_add_y_block vp8_dequant_idct_add_y_block_dspr2
     83 
     84 void vp8_dequantize_b_c(struct blockd*, short *dqc);
     85 #define vp8_dequantize_b vp8_dequantize_b_c
     86 
     87 int vp8_diamond_search_sad_c(struct macroblock *x, struct block *b, struct blockd *d, union int_mv *ref_mv, union int_mv *best_mv, int search_param, int sad_per_bit, int *num00, struct variance_vtable *fn_ptr, int *mvcost[2], union int_mv *center_mv);
     88 #define vp8_diamond_search_sad vp8_diamond_search_sad_c
     89 
     90 void vp8_fast_quantize_b_c(struct block *, struct blockd *);
     91 #define vp8_fast_quantize_b vp8_fast_quantize_b_c
     92 
     93 void vp8_fast_quantize_b_pair_c(struct block *b1, struct block *b2, struct blockd *d1, struct blockd *d2);
     94 #define vp8_fast_quantize_b_pair vp8_fast_quantize_b_pair_c
     95 
     96 int vp8_full_search_sad_c(struct macroblock *x, struct block *b, struct blockd *d, union int_mv *ref_mv, int sad_per_bit, int distance, struct variance_vtable *fn_ptr, int *mvcost[2], union int_mv *center_mv);
     97 #define vp8_full_search_sad vp8_full_search_sad_c
     98 
     99 unsigned int vp8_get4x4sse_cs_c(const unsigned char *src_ptr, int source_stride, const unsigned char *ref_ptr, int  ref_stride);
    100 #define vp8_get4x4sse_cs vp8_get4x4sse_cs_c
    101 
    102 unsigned int vp8_get_mb_ss_c(const short *);
    103 #define vp8_get_mb_ss vp8_get_mb_ss_c
    104 
    105 void vp8_intra4x4_predict_c(unsigned char *Above, unsigned char *yleft, int left_stride, int b_mode, unsigned char *dst, int dst_stride, unsigned char top_left);
    106 #define vp8_intra4x4_predict vp8_intra4x4_predict_c
    107 
    108 void vp8_loop_filter_bh_c(unsigned char *y, unsigned char *u, unsigned char *v, int ystride, int uv_stride, struct loop_filter_info *lfi);
    109 void vp8_loop_filter_bh_dspr2(unsigned char *y, unsigned char *u, unsigned char *v, int ystride, int uv_stride, struct loop_filter_info *lfi);
    110 #define vp8_loop_filter_bh vp8_loop_filter_bh_dspr2
    111 
    112 void vp8_loop_filter_bv_c(unsigned char *y, unsigned char *u, unsigned char *v, int ystride, int uv_stride, struct loop_filter_info *lfi);
    113 void vp8_loop_filter_bv_dspr2(unsigned char *y, unsigned char *u, unsigned char *v, int ystride, int uv_stride, struct loop_filter_info *lfi);
    114 #define vp8_loop_filter_bv vp8_loop_filter_bv_dspr2
    115 
    116 void vp8_loop_filter_mbh_c(unsigned char *y, unsigned char *u, unsigned char *v, int ystride, int uv_stride, struct loop_filter_info *lfi);
    117 void vp8_loop_filter_mbh_dspr2(unsigned char *y, unsigned char *u, unsigned char *v, int ystride, int uv_stride, struct loop_filter_info *lfi);
    118 #define vp8_loop_filter_mbh vp8_loop_filter_mbh_dspr2
    119 
    120 void vp8_loop_filter_mbv_c(unsigned char *y, unsigned char *u, unsigned char *v, int ystride, int uv_stride, struct loop_filter_info *lfi);
    121 void vp8_loop_filter_mbv_dspr2(unsigned char *y, unsigned char *u, unsigned char *v, int ystride, int uv_stride, struct loop_filter_info *lfi);
    122 #define vp8_loop_filter_mbv vp8_loop_filter_mbv_dspr2
    123 
    124 void vp8_loop_filter_bhs_c(unsigned char *y, int ystride, const unsigned char *blimit);
    125 #define vp8_loop_filter_simple_bh vp8_loop_filter_bhs_c
    126 
    127 void vp8_loop_filter_bvs_c(unsigned char *y, int ystride, const unsigned char *blimit);
    128 #define vp8_loop_filter_simple_bv vp8_loop_filter_bvs_c
    129 
    130 void vp8_loop_filter_simple_horizontal_edge_c(unsigned char *y, int ystride, const unsigned char *blimit);
    131 #define vp8_loop_filter_simple_mbh vp8_loop_filter_simple_horizontal_edge_c
    132 
    133 void vp8_loop_filter_simple_vertical_edge_c(unsigned char *y, int ystride, const unsigned char *blimit);
    134 #define vp8_loop_filter_simple_mbv vp8_loop_filter_simple_vertical_edge_c
    135 
    136 int vp8_mbblock_error_c(struct macroblock *mb, int dc);
    137 #define vp8_mbblock_error vp8_mbblock_error_c
    138 
    139 int vp8_mbuverror_c(struct macroblock *mb);
    140 #define vp8_mbuverror vp8_mbuverror_c
    141 
    142 unsigned int vp8_mse16x16_c(const unsigned char *src_ptr, int source_stride, const unsigned char *ref_ptr, int  ref_stride, unsigned int *sse);
    143 #define vp8_mse16x16 vp8_mse16x16_c
    144 
    145 void vp8_quantize_mb_c(struct macroblock *);
    146 #define vp8_quantize_mb vp8_quantize_mb_c
    147 
    148 void vp8_quantize_mbuv_c(struct macroblock *);
    149 #define vp8_quantize_mbuv vp8_quantize_mbuv_c
    150 
    151 void vp8_quantize_mby_c(struct macroblock *);
    152 #define vp8_quantize_mby vp8_quantize_mby_c
    153 
    154 int vp8_refining_search_sad_c(struct macroblock *x, struct block *b, struct blockd *d, union int_mv *ref_mv, int sad_per_bit, int distance, struct variance_vtable *fn_ptr, int *mvcost[2], union int_mv *center_mv);
    155 #define vp8_refining_search_sad vp8_refining_search_sad_c
    156 
    157 void vp8_regular_quantize_b_c(struct block *, struct blockd *);
    158 #define vp8_regular_quantize_b vp8_regular_quantize_b_c
    159 
    160 void vp8_regular_quantize_b_pair_c(struct block *b1, struct block *b2, struct blockd *d1, struct blockd *d2);
    161 #define vp8_regular_quantize_b_pair vp8_regular_quantize_b_pair_c
    162 
    163 unsigned int vp8_sad16x16_c(const unsigned char *src_ptr, int src_stride, const unsigned char *ref_ptr, int ref_stride, unsigned int max_sad);
    164 #define vp8_sad16x16 vp8_sad16x16_c
    165 
    166 void vp8_sad16x16x3_c(const unsigned char *src_ptr, int src_stride, const unsigned char *ref_ptr, int  ref_stride, unsigned int *sad_array);
    167 #define vp8_sad16x16x3 vp8_sad16x16x3_c
    168 
    169 void vp8_sad16x16x4d_c(const unsigned char *src_ptr, int src_stride, const unsigned char * const ref_ptr[], int  ref_stride, unsigned int *sad_array);
    170 #define vp8_sad16x16x4d vp8_sad16x16x4d_c
    171 
    172 void vp8_sad16x16x8_c(const unsigned char *src_ptr, int src_stride, const unsigned char *ref_ptr, int  ref_stride, unsigned short *sad_array);
    173 #define vp8_sad16x16x8 vp8_sad16x16x8_c
    174 
    175 unsigned int vp8_sad16x8_c(const unsigned char *src_ptr, int src_stride, const unsigned char *ref_ptr, int ref_stride, unsigned int max_sad);
    176 #define vp8_sad16x8 vp8_sad16x8_c
    177 
    178 void vp8_sad16x8x3_c(const unsigned char *src_ptr, int src_stride, const unsigned char *ref_ptr, int  ref_stride, unsigned int *sad_array);
    179 #define vp8_sad16x8x3 vp8_sad16x8x3_c
    180 
    181 void vp8_sad16x8x4d_c(const unsigned char *src_ptr, int src_stride, const unsigned char * const ref_ptr[], int  ref_stride, unsigned int *sad_array);
    182 #define vp8_sad16x8x4d vp8_sad16x8x4d_c
    183 
    184 void vp8_sad16x8x8_c(const unsigned char *src_ptr, int src_stride, const unsigned char *ref_ptr, int  ref_stride, unsigned short *sad_array);
    185 #define vp8_sad16x8x8 vp8_sad16x8x8_c
    186 
    187 unsigned int vp8_sad4x4_c(const unsigned char *src_ptr, int src_stride, const unsigned char *ref_ptr, int ref_stride, unsigned int max_sad);
    188 #define vp8_sad4x4 vp8_sad4x4_c
    189 
    190 void vp8_sad4x4x3_c(const unsigned char *src_ptr, int src_stride, const unsigned char *ref_ptr, int  ref_stride, unsigned int *sad_array);
    191 #define vp8_sad4x4x3 vp8_sad4x4x3_c
    192 
    193 void vp8_sad4x4x4d_c(const unsigned char *src_ptr, int src_stride, const unsigned char * const ref_ptr[], int  ref_stride, unsigned int *sad_array);
    194 #define vp8_sad4x4x4d vp8_sad4x4x4d_c
    195 
    196 void vp8_sad4x4x8_c(const unsigned char *src_ptr, int src_stride, const unsigned char *ref_ptr, int  ref_stride, unsigned short *sad_array);
    197 #define vp8_sad4x4x8 vp8_sad4x4x8_c
    198 
    199 unsigned int vp8_sad8x16_c(const unsigned char *src_ptr, int src_stride, const unsigned char *ref_ptr, int ref_stride, unsigned int max_sad);
    200 #define vp8_sad8x16 vp8_sad8x16_c
    201 
    202 void vp8_sad8x16x3_c(const unsigned char *src_ptr, int src_stride, const unsigned char *ref_ptr, int  ref_stride, unsigned int *sad_array);
    203 #define vp8_sad8x16x3 vp8_sad8x16x3_c
    204 
    205 void vp8_sad8x16x4d_c(const unsigned char *src_ptr, int src_stride, const unsigned char * const ref_ptr[], int  ref_stride, unsigned int *sad_array);
    206 #define vp8_sad8x16x4d vp8_sad8x16x4d_c
    207 
    208 void vp8_sad8x16x8_c(const unsigned char *src_ptr, int src_stride, const unsigned char *ref_ptr, int  ref_stride, unsigned short *sad_array);
    209 #define vp8_sad8x16x8 vp8_sad8x16x8_c
    210 
    211 unsigned int vp8_sad8x8_c(const unsigned char *src_ptr, int src_stride, const unsigned char *ref_ptr, int ref_stride, unsigned int max_sad);
    212 #define vp8_sad8x8 vp8_sad8x8_c
    213 
    214 void vp8_sad8x8x3_c(const unsigned char *src_ptr, int src_stride, const unsigned char *ref_ptr, int  ref_stride, unsigned int *sad_array);
    215 #define vp8_sad8x8x3 vp8_sad8x8x3_c
    216 
    217 void vp8_sad8x8x4d_c(const unsigned char *src_ptr, int src_stride, const unsigned char * const ref_ptr[], int  ref_stride, unsigned int *sad_array);
    218 #define vp8_sad8x8x4d vp8_sad8x8x4d_c
    219 
    220 void vp8_sad8x8x8_c(const unsigned char *src_ptr, int src_stride, const unsigned char *ref_ptr, int  ref_stride, unsigned short *sad_array);
    221 #define vp8_sad8x8x8 vp8_sad8x8x8_c
    222 
    223 void vp8_short_fdct4x4_c(short *input, short *output, int pitch);
    224 #define vp8_short_fdct4x4 vp8_short_fdct4x4_c
    225 
    226 void vp8_short_fdct8x4_c(short *input, short *output, int pitch);
    227 #define vp8_short_fdct8x4 vp8_short_fdct8x4_c
    228 
    229 void vp8_short_idct4x4llm_c(short *input, unsigned char *pred, int pitch, unsigned char *dst, int dst_stride);
    230 void vp8_short_idct4x4llm_dspr2(short *input, unsigned char *pred, int pitch, unsigned char *dst, int dst_stride);
    231 #define vp8_short_idct4x4llm vp8_short_idct4x4llm_dspr2
    232 
    233 void vp8_short_inv_walsh4x4_c(short *input, short *output);
    234 void vp8_short_inv_walsh4x4_dspr2(short *input, short *output);
    235 #define vp8_short_inv_walsh4x4 vp8_short_inv_walsh4x4_dspr2
    236 
    237 void vp8_short_inv_walsh4x4_1_c(short *input, short *output);
    238 void vp8_short_inv_walsh4x4_1_dspr2(short *input, short *output);
    239 #define vp8_short_inv_walsh4x4_1 vp8_short_inv_walsh4x4_1_dspr2
    240 
    241 void vp8_short_walsh4x4_c(short *input, short *output, int pitch);
    242 #define vp8_short_walsh4x4 vp8_short_walsh4x4_c
    243 
    244 void vp8_sixtap_predict16x16_c(unsigned char *src, int src_pitch, int xofst, int yofst, unsigned char *dst, int dst_pitch);
    245 void vp8_sixtap_predict16x16_dspr2(unsigned char *src, int src_pitch, int xofst, int yofst, unsigned char *dst, int dst_pitch);
    246 #define vp8_sixtap_predict16x16 vp8_sixtap_predict16x16_dspr2
    247 
    248 void vp8_sixtap_predict4x4_c(unsigned char *src, int src_pitch, int xofst, int yofst, unsigned char *dst, int dst_pitch);
    249 void vp8_sixtap_predict4x4_dspr2(unsigned char *src, int src_pitch, int xofst, int yofst, unsigned char *dst, int dst_pitch);
    250 #define vp8_sixtap_predict4x4 vp8_sixtap_predict4x4_dspr2
    251 
    252 void vp8_sixtap_predict8x4_c(unsigned char *src, int src_pitch, int xofst, int yofst, unsigned char *dst, int dst_pitch);
    253 void vp8_sixtap_predict8x4_dspr2(unsigned char *src, int src_pitch, int xofst, int yofst, unsigned char *dst, int dst_pitch);
    254 #define vp8_sixtap_predict8x4 vp8_sixtap_predict8x4_dspr2
    255 
    256 void vp8_sixtap_predict8x8_c(unsigned char *src, int src_pitch, int xofst, int yofst, unsigned char *dst, int dst_pitch);
    257 void vp8_sixtap_predict8x8_dspr2(unsigned char *src, int src_pitch, int xofst, int yofst, unsigned char *dst, int dst_pitch);
    258 #define vp8_sixtap_predict8x8 vp8_sixtap_predict8x8_dspr2
    259 
    260 unsigned int vp8_sub_pixel_mse16x16_c(const unsigned char  *src_ptr, int  source_stride, int  xoffset, int  yoffset, const unsigned char *ref_ptr, int Refstride, unsigned int *sse);
    261 #define vp8_sub_pixel_mse16x16 vp8_sub_pixel_mse16x16_c
    262 
    263 unsigned int vp8_sub_pixel_variance16x16_c(const unsigned char  *src_ptr, int  source_stride, int  xoffset, int  yoffset, const unsigned char *ref_ptr, int Refstride, unsigned int *sse);
    264 #define vp8_sub_pixel_variance16x16 vp8_sub_pixel_variance16x16_c
    265 
    266 unsigned int vp8_sub_pixel_variance16x8_c(const unsigned char  *src_ptr, int  source_stride, int  xoffset, int  yoffset, const unsigned char *ref_ptr, int Refstride, unsigned int *sse);
    267 #define vp8_sub_pixel_variance16x8 vp8_sub_pixel_variance16x8_c
    268 
    269 unsigned int vp8_sub_pixel_variance4x4_c(const unsigned char  *src_ptr, int  source_stride, int  xoffset, int  yoffset, const unsigned char *ref_ptr, int Refstride, unsigned int *sse);
    270 #define vp8_sub_pixel_variance4x4 vp8_sub_pixel_variance4x4_c
    271 
    272 unsigned int vp8_sub_pixel_variance8x16_c(const unsigned char  *src_ptr, int  source_stride, int  xoffset, int  yoffset, const unsigned char *ref_ptr, int Refstride, unsigned int *sse);
    273 #define vp8_sub_pixel_variance8x16 vp8_sub_pixel_variance8x16_c
    274 
    275 unsigned int vp8_sub_pixel_variance8x8_c(const unsigned char  *src_ptr, int  source_stride, int  xoffset, int  yoffset, const unsigned char *ref_ptr, int Refstride, unsigned int *sse);
    276 #define vp8_sub_pixel_variance8x8 vp8_sub_pixel_variance8x8_c
    277 
    278 void vp8_subtract_b_c(struct block *be, struct blockd *bd, int pitch);
    279 #define vp8_subtract_b vp8_subtract_b_c
    280 
    281 void vp8_subtract_mbuv_c(short *diff, unsigned char *usrc, unsigned char *vsrc, int src_stride, unsigned char *upred, unsigned char *vpred, int pred_stride);
    282 #define vp8_subtract_mbuv vp8_subtract_mbuv_c
    283 
    284 void vp8_subtract_mby_c(short *diff, unsigned char *src, int src_stride, unsigned char *pred, int pred_stride);
    285 #define vp8_subtract_mby vp8_subtract_mby_c
    286 
    287 unsigned int vp8_variance16x16_c(const unsigned char *src_ptr, int source_stride, const unsigned char *ref_ptr, int  ref_stride, unsigned int *sse);
    288 #define vp8_variance16x16 vp8_variance16x16_c
    289 
    290 unsigned int vp8_variance16x8_c(const unsigned char *src_ptr, int source_stride, const unsigned char *ref_ptr, int  ref_stride, unsigned int *sse);
    291 #define vp8_variance16x8 vp8_variance16x8_c
    292 
    293 unsigned int vp8_variance4x4_c(const unsigned char *src_ptr, int source_stride, const unsigned char *ref_ptr, int  ref_stride, unsigned int *sse);
    294 #define vp8_variance4x4 vp8_variance4x4_c
    295 
    296 unsigned int vp8_variance8x16_c(const unsigned char *src_ptr, int source_stride, const unsigned char *ref_ptr, int  ref_stride, unsigned int *sse);
    297 #define vp8_variance8x16 vp8_variance8x16_c
    298 
    299 unsigned int vp8_variance8x8_c(const unsigned char *src_ptr, int source_stride, const unsigned char *ref_ptr, int  ref_stride, unsigned int *sse);
    300 #define vp8_variance8x8 vp8_variance8x8_c
    301 
    302 unsigned int vp8_variance_halfpixvar16x16_h_c(const unsigned char *src_ptr, int source_stride, const unsigned char *ref_ptr, int  ref_stride, unsigned int *sse);
    303 #define vp8_variance_halfpixvar16x16_h vp8_variance_halfpixvar16x16_h_c
    304 
    305 unsigned int vp8_variance_halfpixvar16x16_hv_c(const unsigned char *src_ptr, int source_stride, const unsigned char *ref_ptr, int  ref_stride, unsigned int *sse);
    306 #define vp8_variance_halfpixvar16x16_hv vp8_variance_halfpixvar16x16_hv_c
    307 
    308 unsigned int vp8_variance_halfpixvar16x16_v_c(const unsigned char *src_ptr, int source_stride, const unsigned char *ref_ptr, int  ref_stride, unsigned int *sse);
    309 #define vp8_variance_halfpixvar16x16_v vp8_variance_halfpixvar16x16_v_c
    310 
    311 void vp8_yv12_copy_partial_frame_c(struct yv12_buffer_config *src_ybc, struct yv12_buffer_config *dst_ybc);
    312 #define vp8_yv12_copy_partial_frame vp8_yv12_copy_partial_frame_c
    313 
    314 void vp8_rtcd(void);
    315 
    316 #include "vpx_config.h"
    317 
    318 #ifdef RTCD_C
    319 static void setup_rtcd_internal(void)
    320 {
    321 #if HAVE_DSPR2
    322 #if CONFIG_VP8
    323 void dsputil_static_init();
    324 dsputil_static_init();
    325 #endif
    326 #if CONFIG_VP9
    327 void vp9_dsputil_static_init();
    328 vp9_dsputil_static_init();
    329 #endif
    330 #endif
    331 }
    332 #endif
    333 
    334 #ifdef __cplusplus
    335 }  // extern "C"
    336 #endif
    337 
    338 #endif
    339