| OLD | NEW | 
|---|
|  | (Empty) | 
| 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 /* |  | 
| 11  * VP8 |  | 
| 12  */ |  | 
| 13 |  | 
| 14 struct blockd; |  | 
| 15 struct macroblockd; |  | 
| 16 struct loop_filter_info; |  | 
| 17 |  | 
| 18 /* Encoder forward decls */ |  | 
| 19 struct block; |  | 
| 20 struct macroblock; |  | 
| 21 struct variance_vtable; |  | 
| 22 union int_mv; |  | 
| 23 struct yv12_buffer_config; |  | 
| 24 |  | 
| 25 #ifdef __cplusplus |  | 
| 26 extern "C" { |  | 
| 27 #endif |  | 
| 28 |  | 
| 29 void vp8_bilinear_predict16x16_c(unsigned char *src, int src_pitch, int xofst, i
     nt yofst, unsigned char *dst, int dst_pitch); |  | 
| 30 void vp8_bilinear_predict16x16_armv6(unsigned char *src, int src_pitch, int xofs
     t, int yofst, unsigned char *dst, int dst_pitch); |  | 
| 31 void vp8_bilinear_predict16x16_neon(unsigned char *src, int src_pitch, int xofst
     , int yofst, unsigned char *dst, int dst_pitch); |  | 
| 32 RTCD_EXTERN void (*vp8_bilinear_predict16x16)(unsigned char *src, int src_pitch,
      int xofst, int yofst, unsigned char *dst, int dst_pitch); |  | 
| 33 |  | 
| 34 void vp8_bilinear_predict4x4_c(unsigned char *src, int src_pitch, int xofst, int
      yofst, unsigned char *dst, int dst_pitch); |  | 
| 35 void vp8_bilinear_predict4x4_armv6(unsigned char *src, int src_pitch, int xofst,
      int yofst, unsigned char *dst, int dst_pitch); |  | 
| 36 #define vp8_bilinear_predict4x4 vp8_bilinear_predict4x4_armv6 |  | 
| 37 |  | 
| 38 void vp8_bilinear_predict8x4_c(unsigned char *src, int src_pitch, int xofst, int
      yofst, unsigned char *dst, int dst_pitch); |  | 
| 39 void vp8_bilinear_predict8x4_armv6(unsigned char *src, int src_pitch, int xofst,
      int yofst, unsigned char *dst, int dst_pitch); |  | 
| 40 void vp8_bilinear_predict8x4_neon(unsigned char *src, int src_pitch, int xofst, 
     int yofst, unsigned char *dst, int dst_pitch); |  | 
| 41 RTCD_EXTERN void (*vp8_bilinear_predict8x4)(unsigned char *src, int src_pitch, i
     nt xofst, int yofst, unsigned char *dst, int dst_pitch); |  | 
| 42 |  | 
| 43 void vp8_bilinear_predict8x8_c(unsigned char *src, int src_pitch, int xofst, int
      yofst, unsigned char *dst, int dst_pitch); |  | 
| 44 void vp8_bilinear_predict8x8_armv6(unsigned char *src, int src_pitch, int xofst,
      int yofst, unsigned char *dst, int dst_pitch); |  | 
| 45 void vp8_bilinear_predict8x8_neon(unsigned char *src, int src_pitch, int xofst, 
     int yofst, unsigned char *dst, int dst_pitch); |  | 
| 46 RTCD_EXTERN void (*vp8_bilinear_predict8x8)(unsigned char *src, int src_pitch, i
     nt xofst, int yofst, unsigned char *dst, int dst_pitch); |  | 
| 47 |  | 
| 48 void vp8_blend_b_c(unsigned char *y, unsigned char *u, unsigned char *v, int y1,
      int u1, int v1, int alpha, int stride); |  | 
| 49 #define vp8_blend_b vp8_blend_b_c |  | 
| 50 |  | 
| 51 void vp8_blend_mb_inner_c(unsigned char *y, unsigned char *u, unsigned char *v, 
     int y1, int u1, int v1, int alpha, int stride); |  | 
| 52 #define vp8_blend_mb_inner vp8_blend_mb_inner_c |  | 
| 53 |  | 
| 54 void vp8_blend_mb_outer_c(unsigned char *y, unsigned char *u, unsigned char *v, 
     int y1, int u1, int v1, int alpha, int stride); |  | 
| 55 #define vp8_blend_mb_outer vp8_blend_mb_outer_c |  | 
| 56 |  | 
| 57 int vp8_block_error_c(short *coeff, short *dqcoeff); |  | 
| 58 #define vp8_block_error vp8_block_error_c |  | 
| 59 |  | 
| 60 void vp8_clear_system_state_c(); |  | 
| 61 #define vp8_clear_system_state vp8_clear_system_state_c |  | 
| 62 |  | 
| 63 void vp8_copy_mem16x16_c(unsigned char *src, int src_pitch, unsigned char *dst, 
     int dst_pitch); |  | 
| 64 void vp8_copy_mem16x16_v6(unsigned char *src, int src_pitch, unsigned char *dst,
      int dst_pitch); |  | 
| 65 void vp8_copy_mem16x16_neon(unsigned char *src, int src_pitch, unsigned char *ds
     t, int dst_pitch); |  | 
| 66 RTCD_EXTERN void (*vp8_copy_mem16x16)(unsigned char *src, int src_pitch, unsigne
     d char *dst, int dst_pitch); |  | 
| 67 |  | 
| 68 void vp8_copy_mem8x4_c(unsigned char *src, int src_pitch, unsigned char *dst, in
     t dst_pitch); |  | 
| 69 void vp8_copy_mem8x4_v6(unsigned char *src, int src_pitch, unsigned char *dst, i
     nt dst_pitch); |  | 
| 70 void vp8_copy_mem8x4_neon(unsigned char *src, int src_pitch, unsigned char *dst,
      int dst_pitch); |  | 
| 71 RTCD_EXTERN void (*vp8_copy_mem8x4)(unsigned char *src, int src_pitch, unsigned 
     char *dst, int dst_pitch); |  | 
| 72 |  | 
| 73 void vp8_copy_mem8x8_c(unsigned char *src, int src_pitch, unsigned char *dst, in
     t dst_pitch); |  | 
| 74 void vp8_copy_mem8x8_v6(unsigned char *src, int src_pitch, unsigned char *dst, i
     nt dst_pitch); |  | 
| 75 void vp8_copy_mem8x8_neon(unsigned char *src, int src_pitch, unsigned char *dst,
      int dst_pitch); |  | 
| 76 RTCD_EXTERN void (*vp8_copy_mem8x8)(unsigned char *src, int src_pitch, unsigned 
     char *dst, int dst_pitch); |  | 
| 77 |  | 
| 78 void vp8_dc_only_idct_add_c(short input, unsigned char *pred, int pred_stride, u
     nsigned char *dst, int dst_stride); |  | 
| 79 void vp8_dc_only_idct_add_v6(short input, unsigned char *pred, int pred_stride, 
     unsigned char *dst, int dst_stride); |  | 
| 80 void vp8_dc_only_idct_add_neon(short input, unsigned char *pred, int pred_stride
     , unsigned char *dst, int dst_stride); |  | 
| 81 RTCD_EXTERN void (*vp8_dc_only_idct_add)(short input, unsigned char *pred, int p
     red_stride, unsigned char *dst, int dst_stride); |  | 
| 82 |  | 
| 83 int vp8_denoiser_filter_c(unsigned char *mc_running_avg_y, int mc_avg_y_stride, 
     unsigned char *running_avg_y, int avg_y_stride, unsigned char *sig, int sig_stri
     de, unsigned int motion_magnitude, int increase_denoising); |  | 
| 84 int vp8_denoiser_filter_neon(unsigned char *mc_running_avg_y, int mc_avg_y_strid
     e, unsigned char *running_avg_y, int avg_y_stride, unsigned char *sig, int sig_s
     tride, unsigned int motion_magnitude, int increase_denoising); |  | 
| 85 RTCD_EXTERN int (*vp8_denoiser_filter)(unsigned char *mc_running_avg_y, int mc_a
     vg_y_stride, unsigned char *running_avg_y, int avg_y_stride, unsigned char *sig,
      int sig_stride, unsigned int motion_magnitude, int increase_denoising); |  | 
| 86 |  | 
| 87 int vp8_denoiser_filter_uv_c(unsigned char *mc_running_avg, int mc_avg_stride, u
     nsigned char *running_avg, int avg_stride, unsigned char *sig, int sig_stride, u
     nsigned int motion_magnitude, int increase_denoising); |  | 
| 88 int vp8_denoiser_filter_uv_neon(unsigned char *mc_running_avg, int mc_avg_stride
     , unsigned char *running_avg, int avg_stride, unsigned char *sig, int sig_stride
     , unsigned int motion_magnitude, int increase_denoising); |  | 
| 89 RTCD_EXTERN int (*vp8_denoiser_filter_uv)(unsigned char *mc_running_avg, int mc_
     avg_stride, unsigned char *running_avg, int avg_stride, unsigned char *sig, int 
     sig_stride, unsigned int motion_magnitude, int increase_denoising); |  | 
| 90 |  | 
| 91 void vp8_dequant_idct_add_c(short *input, short *dq, unsigned char *output, int 
     stride); |  | 
| 92 void vp8_dequant_idct_add_v6(short *input, short *dq, unsigned char *output, int
      stride); |  | 
| 93 void vp8_dequant_idct_add_neon(short *input, short *dq, unsigned char *output, i
     nt stride); |  | 
| 94 RTCD_EXTERN void (*vp8_dequant_idct_add)(short *input, short *dq, unsigned char 
     *output, int stride); |  | 
| 95 |  | 
| 96 void vp8_dequant_idct_add_uv_block_c(short *q, short *dq, unsigned char *dst_u, 
     unsigned char *dst_v, int stride, char *eobs); |  | 
| 97 void vp8_dequant_idct_add_uv_block_v6(short *q, short *dq, unsigned char *dst_u,
      unsigned char *dst_v, int stride, char *eobs); |  | 
| 98 void vp8_dequant_idct_add_uv_block_neon(short *q, short *dq, unsigned char *dst_
     u, unsigned char *dst_v, int stride, char *eobs); |  | 
| 99 RTCD_EXTERN void (*vp8_dequant_idct_add_uv_block)(short *q, short *dq, unsigned 
     char *dst_u, unsigned char *dst_v, int stride, char *eobs); |  | 
| 100 |  | 
| 101 void vp8_dequant_idct_add_y_block_c(short *q, short *dq, unsigned char *dst, int
      stride, char *eobs); |  | 
| 102 void vp8_dequant_idct_add_y_block_v6(short *q, short *dq, unsigned char *dst, in
     t stride, char *eobs); |  | 
| 103 void vp8_dequant_idct_add_y_block_neon(short *q, short *dq, unsigned char *dst, 
     int stride, char *eobs); |  | 
| 104 RTCD_EXTERN void (*vp8_dequant_idct_add_y_block)(short *q, short *dq, unsigned c
     har *dst, int stride, char *eobs); |  | 
| 105 |  | 
| 106 void vp8_dequantize_b_c(struct blockd*, short *dqc); |  | 
| 107 void vp8_dequantize_b_v6(struct blockd*, short *dqc); |  | 
| 108 void vp8_dequantize_b_neon(struct blockd*, short *dqc); |  | 
| 109 RTCD_EXTERN void (*vp8_dequantize_b)(struct blockd*, short *dqc); |  | 
| 110 |  | 
| 111 int vp8_diamond_search_sad_c(struct macroblock *x, struct block *b, struct block
     d *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); |  | 
| 112 #define vp8_diamond_search_sad vp8_diamond_search_sad_c |  | 
| 113 |  | 
| 114 void vp8_fast_quantize_b_c(struct block *, struct blockd *); |  | 
| 115 void vp8_fast_quantize_b_neon(struct block *, struct blockd *); |  | 
| 116 RTCD_EXTERN void (*vp8_fast_quantize_b)(struct block *, struct blockd *); |  | 
| 117 |  | 
| 118 void vp8_filter_by_weight16x16_c(unsigned char *src, int src_stride, unsigned ch
     ar *dst, int dst_stride, int src_weight); |  | 
| 119 #define vp8_filter_by_weight16x16 vp8_filter_by_weight16x16_c |  | 
| 120 |  | 
| 121 void vp8_filter_by_weight4x4_c(unsigned char *src, int src_stride, unsigned char
      *dst, int dst_stride, int src_weight); |  | 
| 122 #define vp8_filter_by_weight4x4 vp8_filter_by_weight4x4_c |  | 
| 123 |  | 
| 124 void vp8_filter_by_weight8x8_c(unsigned char *src, int src_stride, unsigned char
      *dst, int dst_stride, int src_weight); |  | 
| 125 #define vp8_filter_by_weight8x8 vp8_filter_by_weight8x8_c |  | 
| 126 |  | 
| 127 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); |  | 
| 128 #define vp8_full_search_sad vp8_full_search_sad_c |  | 
| 129 |  | 
| 130 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); |  | 
| 131 void vp8_loop_filter_bh_armv6(unsigned char *y, unsigned char *u, unsigned char 
     *v, int ystride, int uv_stride, struct loop_filter_info *lfi); |  | 
| 132 void vp8_loop_filter_bh_neon(unsigned char *y, unsigned char *u, unsigned char *
     v, int ystride, int uv_stride, struct loop_filter_info *lfi); |  | 
| 133 RTCD_EXTERN void (*vp8_loop_filter_bh)(unsigned char *y, unsigned char *u, unsig
     ned char *v, int ystride, int uv_stride, struct loop_filter_info *lfi); |  | 
| 134 |  | 
| 135 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); |  | 
| 136 void vp8_loop_filter_bv_armv6(unsigned char *y, unsigned char *u, unsigned char 
     *v, int ystride, int uv_stride, struct loop_filter_info *lfi); |  | 
| 137 void vp8_loop_filter_bv_neon(unsigned char *y, unsigned char *u, unsigned char *
     v, int ystride, int uv_stride, struct loop_filter_info *lfi); |  | 
| 138 RTCD_EXTERN void (*vp8_loop_filter_bv)(unsigned char *y, unsigned char *u, unsig
     ned char *v, int ystride, int uv_stride, struct loop_filter_info *lfi); |  | 
| 139 |  | 
| 140 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); |  | 
| 141 void vp8_loop_filter_mbh_armv6(unsigned char *y, unsigned char *u, unsigned char
      *v, int ystride, int uv_stride, struct loop_filter_info *lfi); |  | 
| 142 void vp8_loop_filter_mbh_neon(unsigned char *y, unsigned char *u, unsigned char 
     *v, int ystride, int uv_stride, struct loop_filter_info *lfi); |  | 
| 143 RTCD_EXTERN void (*vp8_loop_filter_mbh)(unsigned char *y, unsigned char *u, unsi
     gned char *v, int ystride, int uv_stride, struct loop_filter_info *lfi); |  | 
| 144 |  | 
| 145 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); |  | 
| 146 void vp8_loop_filter_mbv_armv6(unsigned char *y, unsigned char *u, unsigned char
      *v, int ystride, int uv_stride, struct loop_filter_info *lfi); |  | 
| 147 void vp8_loop_filter_mbv_neon(unsigned char *y, unsigned char *u, unsigned char 
     *v, int ystride, int uv_stride, struct loop_filter_info *lfi); |  | 
| 148 RTCD_EXTERN void (*vp8_loop_filter_mbv)(unsigned char *y, unsigned char *u, unsi
     gned char *v, int ystride, int uv_stride, struct loop_filter_info *lfi); |  | 
| 149 |  | 
| 150 void vp8_loop_filter_bhs_c(unsigned char *y, int ystride, const unsigned char *b
     limit); |  | 
| 151 void vp8_loop_filter_bhs_armv6(unsigned char *y, int ystride, const unsigned cha
     r *blimit); |  | 
| 152 void vp8_loop_filter_bhs_neon(unsigned char *y, int ystride, const unsigned char
      *blimit); |  | 
| 153 RTCD_EXTERN void (*vp8_loop_filter_simple_bh)(unsigned char *y, int ystride, con
     st unsigned char *blimit); |  | 
| 154 |  | 
| 155 void vp8_loop_filter_bvs_c(unsigned char *y, int ystride, const unsigned char *b
     limit); |  | 
| 156 void vp8_loop_filter_bvs_armv6(unsigned char *y, int ystride, const unsigned cha
     r *blimit); |  | 
| 157 void vp8_loop_filter_bvs_neon(unsigned char *y, int ystride, const unsigned char
      *blimit); |  | 
| 158 RTCD_EXTERN void (*vp8_loop_filter_simple_bv)(unsigned char *y, int ystride, con
     st unsigned char *blimit); |  | 
| 159 |  | 
| 160 void vp8_loop_filter_simple_horizontal_edge_c(unsigned char *y, int ystride, con
     st unsigned char *blimit); |  | 
| 161 void vp8_loop_filter_simple_horizontal_edge_armv6(unsigned char *y, int ystride,
      const unsigned char *blimit); |  | 
| 162 void vp8_loop_filter_mbhs_neon(unsigned char *y, int ystride, const unsigned cha
     r *blimit); |  | 
| 163 RTCD_EXTERN void (*vp8_loop_filter_simple_mbh)(unsigned char *y, int ystride, co
     nst unsigned char *blimit); |  | 
| 164 |  | 
| 165 void vp8_loop_filter_simple_vertical_edge_c(unsigned char *y, int ystride, const
      unsigned char *blimit); |  | 
| 166 void vp8_loop_filter_simple_vertical_edge_armv6(unsigned char *y, int ystride, c
     onst unsigned char *blimit); |  | 
| 167 void vp8_loop_filter_mbvs_neon(unsigned char *y, int ystride, const unsigned cha
     r *blimit); |  | 
| 168 RTCD_EXTERN void (*vp8_loop_filter_simple_mbv)(unsigned char *y, int ystride, co
     nst unsigned char *blimit); |  | 
| 169 |  | 
| 170 int vp8_mbblock_error_c(struct macroblock *mb, int dc); |  | 
| 171 #define vp8_mbblock_error vp8_mbblock_error_c |  | 
| 172 |  | 
| 173 void vp8_mbpost_proc_across_ip_c(unsigned char *dst, int pitch, int rows, int co
     ls,int flimit); |  | 
| 174 #define vp8_mbpost_proc_across_ip vp8_mbpost_proc_across_ip_c |  | 
| 175 |  | 
| 176 void vp8_mbpost_proc_down_c(unsigned char *dst, int pitch, int rows, int cols,in
     t flimit); |  | 
| 177 #define vp8_mbpost_proc_down vp8_mbpost_proc_down_c |  | 
| 178 |  | 
| 179 int vp8_mbuverror_c(struct macroblock *mb); |  | 
| 180 #define vp8_mbuverror vp8_mbuverror_c |  | 
| 181 |  | 
| 182 void vp8_plane_add_noise_c(unsigned char *s, char *noise, char blackclamp[16], c
     har whiteclamp[16], char bothclamp[16], unsigned int w, unsigned int h, int pitc
     h); |  | 
| 183 #define vp8_plane_add_noise vp8_plane_add_noise_c |  | 
| 184 |  | 
| 185 void vp8_post_proc_down_and_across_mb_row_c(unsigned char *src, unsigned char *d
     st, int src_pitch, int dst_pitch, int cols, unsigned char *flimits, int size); |  | 
| 186 #define vp8_post_proc_down_and_across_mb_row vp8_post_proc_down_and_across_mb_ro
     w_c |  | 
| 187 |  | 
| 188 int vp8_refining_search_sad_c(struct macroblock *x, struct block *b, struct bloc
     kd *d, union int_mv *ref_mv, int sad_per_bit, int distance, struct variance_vtab
     le *fn_ptr, int *mvcost[2], union int_mv *center_mv); |  | 
| 189 #define vp8_refining_search_sad vp8_refining_search_sad_c |  | 
| 190 |  | 
| 191 void vp8_regular_quantize_b_c(struct block *, struct blockd *); |  | 
| 192 #define vp8_regular_quantize_b vp8_regular_quantize_b_c |  | 
| 193 |  | 
| 194 void vp8_short_fdct4x4_c(short *input, short *output, int pitch); |  | 
| 195 void vp8_short_fdct4x4_armv6(short *input, short *output, int pitch); |  | 
| 196 void vp8_short_fdct4x4_neon(short *input, short *output, int pitch); |  | 
| 197 RTCD_EXTERN void (*vp8_short_fdct4x4)(short *input, short *output, int pitch); |  | 
| 198 |  | 
| 199 void vp8_short_fdct8x4_c(short *input, short *output, int pitch); |  | 
| 200 void vp8_short_fdct8x4_armv6(short *input, short *output, int pitch); |  | 
| 201 void vp8_short_fdct8x4_neon(short *input, short *output, int pitch); |  | 
| 202 RTCD_EXTERN void (*vp8_short_fdct8x4)(short *input, short *output, int pitch); |  | 
| 203 |  | 
| 204 void vp8_short_idct4x4llm_c(short *input, unsigned char *pred, int pitch, unsign
     ed char *dst, int dst_stride); |  | 
| 205 void vp8_short_idct4x4llm_v6_dual(short *input, unsigned char *pred, int pitch, 
     unsigned char *dst, int dst_stride); |  | 
| 206 void vp8_short_idct4x4llm_neon(short *input, unsigned char *pred, int pitch, uns
     igned char *dst, int dst_stride); |  | 
| 207 RTCD_EXTERN void (*vp8_short_idct4x4llm)(short *input, unsigned char *pred, int 
     pitch, unsigned char *dst, int dst_stride); |  | 
| 208 |  | 
| 209 void vp8_short_inv_walsh4x4_c(short *input, short *output); |  | 
| 210 void vp8_short_inv_walsh4x4_v6(short *input, short *output); |  | 
| 211 void vp8_short_inv_walsh4x4_neon(short *input, short *output); |  | 
| 212 RTCD_EXTERN void (*vp8_short_inv_walsh4x4)(short *input, short *output); |  | 
| 213 |  | 
| 214 void vp8_short_inv_walsh4x4_1_c(short *input, short *output); |  | 
| 215 #define vp8_short_inv_walsh4x4_1 vp8_short_inv_walsh4x4_1_c |  | 
| 216 |  | 
| 217 void vp8_short_walsh4x4_c(short *input, short *output, int pitch); |  | 
| 218 void vp8_short_walsh4x4_armv6(short *input, short *output, int pitch); |  | 
| 219 void vp8_short_walsh4x4_neon(short *input, short *output, int pitch); |  | 
| 220 RTCD_EXTERN void (*vp8_short_walsh4x4)(short *input, short *output, int pitch); |  | 
| 221 |  | 
| 222 void vp8_sixtap_predict16x16_c(unsigned char *src, int src_pitch, int xofst, int
      yofst, unsigned char *dst, int dst_pitch); |  | 
| 223 void vp8_sixtap_predict16x16_armv6(unsigned char *src, int src_pitch, int xofst,
      int yofst, unsigned char *dst, int dst_pitch); |  | 
| 224 void vp8_sixtap_predict16x16_neon(unsigned char *src, int src_pitch, int xofst, 
     int yofst, unsigned char *dst, int dst_pitch); |  | 
| 225 RTCD_EXTERN void (*vp8_sixtap_predict16x16)(unsigned char *src, int src_pitch, i
     nt xofst, int yofst, unsigned char *dst, int dst_pitch); |  | 
| 226 |  | 
| 227 void vp8_sixtap_predict4x4_c(unsigned char *src, int src_pitch, int xofst, int y
     ofst, unsigned char *dst, int dst_pitch); |  | 
| 228 void vp8_sixtap_predict4x4_armv6(unsigned char *src, int src_pitch, int xofst, i
     nt yofst, unsigned char *dst, int dst_pitch); |  | 
| 229 #define vp8_sixtap_predict4x4 vp8_sixtap_predict4x4_armv6 |  | 
| 230 |  | 
| 231 void vp8_sixtap_predict8x4_c(unsigned char *src, int src_pitch, int xofst, int y
     ofst, unsigned char *dst, int dst_pitch); |  | 
| 232 void vp8_sixtap_predict8x4_armv6(unsigned char *src, int src_pitch, int xofst, i
     nt yofst, unsigned char *dst, int dst_pitch); |  | 
| 233 void vp8_sixtap_predict8x4_neon(unsigned char *src, int src_pitch, int xofst, in
     t yofst, unsigned char *dst, int dst_pitch); |  | 
| 234 RTCD_EXTERN void (*vp8_sixtap_predict8x4)(unsigned char *src, int src_pitch, int
      xofst, int yofst, unsigned char *dst, int dst_pitch); |  | 
| 235 |  | 
| 236 void vp8_sixtap_predict8x8_c(unsigned char *src, int src_pitch, int xofst, int y
     ofst, unsigned char *dst, int dst_pitch); |  | 
| 237 void vp8_sixtap_predict8x8_armv6(unsigned char *src, int src_pitch, int xofst, i
     nt yofst, unsigned char *dst, int dst_pitch); |  | 
| 238 void vp8_sixtap_predict8x8_neon(unsigned char *src, int src_pitch, int xofst, in
     t yofst, unsigned char *dst, int dst_pitch); |  | 
| 239 RTCD_EXTERN void (*vp8_sixtap_predict8x8)(unsigned char *src, int src_pitch, int
      xofst, int yofst, unsigned char *dst, int dst_pitch); |  | 
| 240 |  | 
| 241 void vp8_rtcd(void); |  | 
| 242 |  | 
| 243 #include "vpx_config.h" |  | 
| 244 |  | 
| 245 #ifdef RTCD_C |  | 
| 246 #include "vpx_ports/arm.h" |  | 
| 247 static void setup_rtcd_internal(void) |  | 
| 248 { |  | 
| 249     int flags = arm_cpu_caps(); |  | 
| 250 |  | 
| 251     (void)flags; |  | 
| 252 |  | 
| 253     vp8_bilinear_predict16x16 = vp8_bilinear_predict16x16_armv6; |  | 
| 254     if (flags & HAS_NEON) vp8_bilinear_predict16x16 = vp8_bilinear_predict16x16_
     neon; |  | 
| 255     vp8_bilinear_predict8x4 = vp8_bilinear_predict8x4_armv6; |  | 
| 256     if (flags & HAS_NEON) vp8_bilinear_predict8x4 = vp8_bilinear_predict8x4_neon
     ; |  | 
| 257     vp8_bilinear_predict8x8 = vp8_bilinear_predict8x8_armv6; |  | 
| 258     if (flags & HAS_NEON) vp8_bilinear_predict8x8 = vp8_bilinear_predict8x8_neon
     ; |  | 
| 259     vp8_copy_mem16x16 = vp8_copy_mem16x16_v6; |  | 
| 260     if (flags & HAS_NEON) vp8_copy_mem16x16 = vp8_copy_mem16x16_neon; |  | 
| 261     vp8_copy_mem8x4 = vp8_copy_mem8x4_v6; |  | 
| 262     if (flags & HAS_NEON) vp8_copy_mem8x4 = vp8_copy_mem8x4_neon; |  | 
| 263     vp8_copy_mem8x8 = vp8_copy_mem8x8_v6; |  | 
| 264     if (flags & HAS_NEON) vp8_copy_mem8x8 = vp8_copy_mem8x8_neon; |  | 
| 265     vp8_dc_only_idct_add = vp8_dc_only_idct_add_v6; |  | 
| 266     if (flags & HAS_NEON) vp8_dc_only_idct_add = vp8_dc_only_idct_add_neon; |  | 
| 267     vp8_denoiser_filter = vp8_denoiser_filter_c; |  | 
| 268     if (flags & HAS_NEON) vp8_denoiser_filter = vp8_denoiser_filter_neon; |  | 
| 269     vp8_denoiser_filter_uv = vp8_denoiser_filter_uv_c; |  | 
| 270     if (flags & HAS_NEON) vp8_denoiser_filter_uv = vp8_denoiser_filter_uv_neon; |  | 
| 271     vp8_dequant_idct_add = vp8_dequant_idct_add_v6; |  | 
| 272     if (flags & HAS_NEON) vp8_dequant_idct_add = vp8_dequant_idct_add_neon; |  | 
| 273     vp8_dequant_idct_add_uv_block = vp8_dequant_idct_add_uv_block_v6; |  | 
| 274     if (flags & HAS_NEON) vp8_dequant_idct_add_uv_block = vp8_dequant_idct_add_u
     v_block_neon; |  | 
| 275     vp8_dequant_idct_add_y_block = vp8_dequant_idct_add_y_block_v6; |  | 
| 276     if (flags & HAS_NEON) vp8_dequant_idct_add_y_block = vp8_dequant_idct_add_y_
     block_neon; |  | 
| 277     vp8_dequantize_b = vp8_dequantize_b_v6; |  | 
| 278     if (flags & HAS_NEON) vp8_dequantize_b = vp8_dequantize_b_neon; |  | 
| 279     vp8_fast_quantize_b = vp8_fast_quantize_b_c; |  | 
| 280     if (flags & HAS_NEON) vp8_fast_quantize_b = vp8_fast_quantize_b_neon; |  | 
| 281     vp8_loop_filter_bh = vp8_loop_filter_bh_armv6; |  | 
| 282     if (flags & HAS_NEON) vp8_loop_filter_bh = vp8_loop_filter_bh_neon; |  | 
| 283     vp8_loop_filter_bv = vp8_loop_filter_bv_armv6; |  | 
| 284     if (flags & HAS_NEON) vp8_loop_filter_bv = vp8_loop_filter_bv_neon; |  | 
| 285     vp8_loop_filter_mbh = vp8_loop_filter_mbh_armv6; |  | 
| 286     if (flags & HAS_NEON) vp8_loop_filter_mbh = vp8_loop_filter_mbh_neon; |  | 
| 287     vp8_loop_filter_mbv = vp8_loop_filter_mbv_armv6; |  | 
| 288     if (flags & HAS_NEON) vp8_loop_filter_mbv = vp8_loop_filter_mbv_neon; |  | 
| 289     vp8_loop_filter_simple_bh = vp8_loop_filter_bhs_armv6; |  | 
| 290     if (flags & HAS_NEON) vp8_loop_filter_simple_bh = vp8_loop_filter_bhs_neon; |  | 
| 291     vp8_loop_filter_simple_bv = vp8_loop_filter_bvs_armv6; |  | 
| 292     if (flags & HAS_NEON) vp8_loop_filter_simple_bv = vp8_loop_filter_bvs_neon; |  | 
| 293     vp8_loop_filter_simple_mbh = vp8_loop_filter_simple_horizontal_edge_armv6; |  | 
| 294     if (flags & HAS_NEON) vp8_loop_filter_simple_mbh = vp8_loop_filter_mbhs_neon
     ; |  | 
| 295     vp8_loop_filter_simple_mbv = vp8_loop_filter_simple_vertical_edge_armv6; |  | 
| 296     if (flags & HAS_NEON) vp8_loop_filter_simple_mbv = vp8_loop_filter_mbvs_neon
     ; |  | 
| 297     vp8_short_fdct4x4 = vp8_short_fdct4x4_armv6; |  | 
| 298     if (flags & HAS_NEON) vp8_short_fdct4x4 = vp8_short_fdct4x4_neon; |  | 
| 299     vp8_short_fdct8x4 = vp8_short_fdct8x4_armv6; |  | 
| 300     if (flags & HAS_NEON) vp8_short_fdct8x4 = vp8_short_fdct8x4_neon; |  | 
| 301     vp8_short_idct4x4llm = vp8_short_idct4x4llm_v6_dual; |  | 
| 302     if (flags & HAS_NEON) vp8_short_idct4x4llm = vp8_short_idct4x4llm_neon; |  | 
| 303     vp8_short_inv_walsh4x4 = vp8_short_inv_walsh4x4_v6; |  | 
| 304     if (flags & HAS_NEON) vp8_short_inv_walsh4x4 = vp8_short_inv_walsh4x4_neon; |  | 
| 305     vp8_short_walsh4x4 = vp8_short_walsh4x4_armv6; |  | 
| 306     if (flags & HAS_NEON) vp8_short_walsh4x4 = vp8_short_walsh4x4_neon; |  | 
| 307     vp8_sixtap_predict16x16 = vp8_sixtap_predict16x16_armv6; |  | 
| 308     if (flags & HAS_NEON) vp8_sixtap_predict16x16 = vp8_sixtap_predict16x16_neon
     ; |  | 
| 309     vp8_sixtap_predict8x4 = vp8_sixtap_predict8x4_armv6; |  | 
| 310     if (flags & HAS_NEON) vp8_sixtap_predict8x4 = vp8_sixtap_predict8x4_neon; |  | 
| 311     vp8_sixtap_predict8x8 = vp8_sixtap_predict8x8_armv6; |  | 
| 312     if (flags & HAS_NEON) vp8_sixtap_predict8x8 = vp8_sixtap_predict8x8_neon; |  | 
| 313 } |  | 
| 314 #endif |  | 
| 315 |  | 
| 316 #ifdef __cplusplus |  | 
| 317 }  // extern "C" |  | 
| 318 #endif |  | 
| 319 |  | 
| 320 #endif |  | 
| OLD | NEW | 
|---|