1 #ifndef VP9_RTCD_H_ 2 #define VP9_RTCD_H_ 3 4 #ifdef RTCD_C 5 #define RTCD_EXTERN 6 #else 7 #define RTCD_EXTERN extern 8 #endif 9 10 /* 11 * VP9 12 */ 13 14 #include "vpx/vpx_integer.h" 15 #include "vp9/common/vp9_common.h" 16 #include "vp9/common/vp9_enums.h" 17 #include "vp9/common/vp9_filter.h" 18 19 struct macroblockd; 20 21 /* Encoder forward decls */ 22 struct macroblock; 23 struct vp9_variance_vtable; 24 struct search_site_config; 25 struct mv; 26 union int_mv; 27 struct yv12_buffer_config; 28 29 #ifdef __cplusplus 30 extern "C" { 31 #endif 32 33 int64_t vp9_block_error_c(const tran_low_t *coeff, const tran_low_t *dqcoeff, intptr_t block_size, int64_t *ssz); 34 int64_t vp9_block_error_msa(const tran_low_t *coeff, const tran_low_t *dqcoeff, intptr_t block_size, int64_t *ssz); 35 #define vp9_block_error vp9_block_error_msa 36 37 int64_t vp9_block_error_fp_c(const int16_t *coeff, const int16_t *dqcoeff, int block_size); 38 #define vp9_block_error_fp vp9_block_error_fp_c 39 40 int vp9_diamond_search_sad_c(const struct macroblock *x, const struct search_site_config *cfg, struct mv *ref_mv, struct mv *best_mv, int search_param, int sad_per_bit, int *num00, const struct vp9_variance_vtable *fn_ptr, const struct mv *center_mv); 41 #define vp9_diamond_search_sad vp9_diamond_search_sad_c 42 43 void vp9_fdct8x8_quant_c(const int16_t *input, int stride, tran_low_t *coeff_ptr, intptr_t n_coeffs, int skip_block, const int16_t *round_ptr, const int16_t *quant_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); 44 #define vp9_fdct8x8_quant vp9_fdct8x8_quant_c 45 46 void vp9_fht16x16_c(const int16_t *input, tran_low_t *output, int stride, int tx_type); 47 void vp9_fht16x16_msa(const int16_t *input, tran_low_t *output, int stride, int tx_type); 48 #define vp9_fht16x16 vp9_fht16x16_msa 49 50 void vp9_fht4x4_c(const int16_t *input, tran_low_t *output, int stride, int tx_type); 51 void vp9_fht4x4_msa(const int16_t *input, tran_low_t *output, int stride, int tx_type); 52 #define vp9_fht4x4 vp9_fht4x4_msa 53 54 void vp9_fht8x8_c(const int16_t *input, tran_low_t *output, int stride, int tx_type); 55 void vp9_fht8x8_msa(const int16_t *input, tran_low_t *output, int stride, int tx_type); 56 #define vp9_fht8x8 vp9_fht8x8_msa 57 58 int vp9_full_search_sad_c(const struct macroblock *x, const struct mv *ref_mv, int sad_per_bit, int distance, const struct vp9_variance_vtable *fn_ptr, const struct mv *center_mv, struct mv *best_mv); 59 #define vp9_full_search_sad vp9_full_search_sad_c 60 61 void vp9_fwht4x4_c(const int16_t *input, tran_low_t *output, int stride); 62 void vp9_fwht4x4_msa(const int16_t *input, tran_low_t *output, int stride); 63 #define vp9_fwht4x4 vp9_fwht4x4_msa 64 65 void vp9_iht16x16_256_add_c(const tran_low_t *input, uint8_t *output, int pitch, int tx_type); 66 void vp9_iht16x16_256_add_msa(const tran_low_t *input, uint8_t *output, int pitch, int tx_type); 67 #define vp9_iht16x16_256_add vp9_iht16x16_256_add_msa 68 69 void vp9_iht4x4_16_add_c(const tran_low_t *input, uint8_t *dest, int stride, int tx_type); 70 void vp9_iht4x4_16_add_msa(const tran_low_t *input, uint8_t *dest, int stride, int tx_type); 71 #define vp9_iht4x4_16_add vp9_iht4x4_16_add_msa 72 73 void vp9_iht8x8_64_add_c(const tran_low_t *input, uint8_t *dest, int stride, int tx_type); 74 void vp9_iht8x8_64_add_msa(const tran_low_t *input, uint8_t *dest, int stride, int tx_type); 75 #define vp9_iht8x8_64_add vp9_iht8x8_64_add_msa 76 77 void vp9_quantize_fp_c(const tran_low_t *coeff_ptr, intptr_t n_coeffs, int skip_block, const int16_t *round_ptr, const int16_t *quant_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); 78 #define vp9_quantize_fp vp9_quantize_fp_c 79 80 void vp9_quantize_fp_32x32_c(const tran_low_t *coeff_ptr, intptr_t n_coeffs, int skip_block, const int16_t *round_ptr, const int16_t *quant_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); 81 #define vp9_quantize_fp_32x32 vp9_quantize_fp_32x32_c 82 83 void vp9_scale_and_extend_frame_c(const struct yv12_buffer_config *src, struct yv12_buffer_config *dst, INTERP_FILTER filter_type, int phase_scaler); 84 #define vp9_scale_and_extend_frame vp9_scale_and_extend_frame_c 85 86 void vp9_temporal_filter_apply_c(const uint8_t *frame1, unsigned int stride, const uint8_t *frame2, unsigned int block_width, unsigned int block_height, int strength, int filter_weight, uint32_t *accumulator, uint16_t *count); 87 #define vp9_temporal_filter_apply vp9_temporal_filter_apply_c 88 89 void vp9_rtcd(void); 90 91 #include "vpx_config.h" 92 93 #ifdef RTCD_C 94 static void setup_rtcd_internal(void) 95 { 96 #if HAVE_DSPR2 97 void vpx_dsputil_static_init(); 98 #if CONFIG_VP8 99 void dsputil_static_init(); 100 #endif 101 102 vpx_dsputil_static_init(); 103 #if CONFIG_VP8 104 dsputil_static_init(); 105 #endif 106 #endif 107 } 108 #endif 109 110 #ifdef __cplusplus 111 } // extern "C" 112 #endif 113 114 #endif 115