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 19struct macroblockd; 20 21/* Encoder forward decls */ 22struct macroblock; 23struct vp9_variance_vtable; 24struct search_site_config; 25struct mv; 26union int_mv; 27struct yv12_buffer_config; 28 29#ifdef __cplusplus 30extern "C" { 31#endif 32 33int64_t vp9_block_error_c(const tran_low_t *coeff, const tran_low_t *dqcoeff, intptr_t block_size, int64_t *ssz); 34int64_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 37int64_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 40int 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 43void 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 46void vp9_fht16x16_c(const int16_t *input, tran_low_t *output, int stride, int tx_type); 47void vp9_fht16x16_msa(const int16_t *input, tran_low_t *output, int stride, int tx_type); 48#define vp9_fht16x16 vp9_fht16x16_msa 49 50void vp9_fht4x4_c(const int16_t *input, tran_low_t *output, int stride, int tx_type); 51void vp9_fht4x4_msa(const int16_t *input, tran_low_t *output, int stride, int tx_type); 52#define vp9_fht4x4 vp9_fht4x4_msa 53 54void vp9_fht8x8_c(const int16_t *input, tran_low_t *output, int stride, int tx_type); 55void vp9_fht8x8_msa(const int16_t *input, tran_low_t *output, int stride, int tx_type); 56#define vp9_fht8x8 vp9_fht8x8_msa 57 58int 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 61void vp9_fwht4x4_c(const int16_t *input, tran_low_t *output, int stride); 62void vp9_fwht4x4_msa(const int16_t *input, tran_low_t *output, int stride); 63#define vp9_fwht4x4 vp9_fwht4x4_msa 64 65void vp9_iht16x16_256_add_c(const tran_low_t *input, uint8_t *output, int pitch, int tx_type); 66void 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 69void vp9_iht4x4_16_add_c(const tran_low_t *input, uint8_t *dest, int stride, int tx_type); 70void 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 73void vp9_iht8x8_64_add_c(const tran_low_t *input, uint8_t *dest, int stride, int tx_type); 74void 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 77void 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 80void 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 83void 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 86void 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 89void vp9_rtcd(void); 90 91#include "vpx_config.h" 92 93#ifdef RTCD_C 94static void setup_rtcd_internal(void) 95{ 96#if HAVE_DSPR2 97void vpx_dsputil_static_init(); 98#if CONFIG_VP8 99void dsputil_static_init(); 100#endif 101 102vpx_dsputil_static_init(); 103#if CONFIG_VP8 104dsputil_static_init(); 105#endif 106#endif 107} 108#endif 109 110#ifdef __cplusplus 111} // extern "C" 112#endif 113 114#endif 115