vp9_rtcd.h 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. // This file is generated. Do not edit.
  2. #ifndef VP9_RTCD_H_
  3. #define VP9_RTCD_H_
  4. #ifdef RTCD_C
  5. #define RTCD_EXTERN
  6. #else
  7. #define RTCD_EXTERN extern
  8. #endif
  9. /*
  10. * VP9
  11. */
  12. #include "vpx/vpx_integer.h"
  13. #include "vp9/common/vp9_common.h"
  14. #include "vp9/common/vp9_enums.h"
  15. #include "vp9/common/vp9_filter.h"
  16. struct macroblockd;
  17. /* Encoder forward decls */
  18. struct macroblock;
  19. struct vp9_variance_vtable;
  20. struct search_site_config;
  21. struct mv;
  22. union int_mv;
  23. struct yv12_buffer_config;
  24. #ifdef __cplusplus
  25. extern "C" {
  26. #endif
  27. void vp9_apply_temporal_filter_c(const uint8_t *y_src, int y_src_stride, const uint8_t *y_pre, int y_pre_stride, const uint8_t *u_src, const uint8_t *v_src, int uv_src_stride, const uint8_t *u_pre, const uint8_t *v_pre, int uv_pre_stride, unsigned int block_width, unsigned int block_height, int ss_x, int ss_y, int strength, const int *const blk_fw, int use_32x32, uint32_t *y_accumulator, uint16_t *y_count, uint32_t *u_accumulator, uint16_t *u_count, uint32_t *v_accumulator, uint16_t *v_count);
  28. void vp9_apply_temporal_filter_sse4_1(const uint8_t *y_src, int y_src_stride, const uint8_t *y_pre, int y_pre_stride, const uint8_t *u_src, const uint8_t *v_src, int uv_src_stride, const uint8_t *u_pre, const uint8_t *v_pre, int uv_pre_stride, unsigned int block_width, unsigned int block_height, int ss_x, int ss_y, int strength, const int *const blk_fw, int use_32x32, uint32_t *y_accumulator, uint16_t *y_count, uint32_t *u_accumulator, uint16_t *u_count, uint32_t *v_accumulator, uint16_t *v_count);
  29. RTCD_EXTERN void (*vp9_apply_temporal_filter)(const uint8_t *y_src, int y_src_stride, const uint8_t *y_pre, int y_pre_stride, const uint8_t *u_src, const uint8_t *v_src, int uv_src_stride, const uint8_t *u_pre, const uint8_t *v_pre, int uv_pre_stride, unsigned int block_width, unsigned int block_height, int ss_x, int ss_y, int strength, const int *const blk_fw, int use_32x32, uint32_t *y_accumulator, uint16_t *y_count, uint32_t *u_accumulator, uint16_t *u_count, uint32_t *v_accumulator, uint16_t *v_count);
  30. int64_t vp9_block_error_c(const tran_low_t *coeff, const tran_low_t *dqcoeff, intptr_t block_size, int64_t *ssz);
  31. int64_t vp9_block_error_sse2(const tran_low_t *coeff, const tran_low_t *dqcoeff, intptr_t block_size, int64_t *ssz);
  32. int64_t vp9_block_error_avx2(const tran_low_t *coeff, const tran_low_t *dqcoeff, intptr_t block_size, int64_t *ssz);
  33. RTCD_EXTERN int64_t (*vp9_block_error)(const tran_low_t *coeff, const tran_low_t *dqcoeff, intptr_t block_size, int64_t *ssz);
  34. int64_t vp9_block_error_fp_c(const tran_low_t *coeff, const tran_low_t *dqcoeff, int block_size);
  35. int64_t vp9_block_error_fp_sse2(const tran_low_t *coeff, const tran_low_t *dqcoeff, int block_size);
  36. int64_t vp9_block_error_fp_avx2(const tran_low_t *coeff, const tran_low_t *dqcoeff, int block_size);
  37. RTCD_EXTERN int64_t (*vp9_block_error_fp)(const tran_low_t *coeff, const tran_low_t *dqcoeff, int block_size);
  38. 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);
  39. int vp9_diamond_search_sad_avx(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);
  40. RTCD_EXTERN int (*vp9_diamond_search_sad)(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. void vp9_fht16x16_c(const int16_t *input, tran_low_t *output, int stride, int tx_type);
  42. void vp9_fht16x16_sse2(const int16_t *input, tran_low_t *output, int stride, int tx_type);
  43. #define vp9_fht16x16 vp9_fht16x16_sse2
  44. void vp9_fht4x4_c(const int16_t *input, tran_low_t *output, int stride, int tx_type);
  45. void vp9_fht4x4_sse2(const int16_t *input, tran_low_t *output, int stride, int tx_type);
  46. #define vp9_fht4x4 vp9_fht4x4_sse2
  47. void vp9_fht8x8_c(const int16_t *input, tran_low_t *output, int stride, int tx_type);
  48. void vp9_fht8x8_sse2(const int16_t *input, tran_low_t *output, int stride, int tx_type);
  49. #define vp9_fht8x8 vp9_fht8x8_sse2
  50. void vp9_fwht4x4_c(const int16_t *input, tran_low_t *output, int stride);
  51. void vp9_fwht4x4_sse2(const int16_t *input, tran_low_t *output, int stride);
  52. #define vp9_fwht4x4 vp9_fwht4x4_sse2
  53. void vp9_iht16x16_256_add_c(const tran_low_t *input, uint8_t *dest, int stride, int tx_type);
  54. void vp9_iht16x16_256_add_sse2(const tran_low_t *input, uint8_t *dest, int stride, int tx_type);
  55. #define vp9_iht16x16_256_add vp9_iht16x16_256_add_sse2
  56. void vp9_iht4x4_16_add_c(const tran_low_t *input, uint8_t *dest, int stride, int tx_type);
  57. void vp9_iht4x4_16_add_sse2(const tran_low_t *input, uint8_t *dest, int stride, int tx_type);
  58. #define vp9_iht4x4_16_add vp9_iht4x4_16_add_sse2
  59. void vp9_iht8x8_64_add_c(const tran_low_t *input, uint8_t *dest, int stride, int tx_type);
  60. void vp9_iht8x8_64_add_sse2(const tran_low_t *input, uint8_t *dest, int stride, int tx_type);
  61. #define vp9_iht8x8_64_add vp9_iht8x8_64_add_sse2
  62. 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);
  63. void vp9_quantize_fp_sse2(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);
  64. void vp9_quantize_fp_ssse3(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);
  65. void vp9_quantize_fp_avx2(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);
  66. RTCD_EXTERN void (*vp9_quantize_fp)(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);
  67. 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);
  68. void vp9_quantize_fp_32x32_ssse3(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);
  69. RTCD_EXTERN void (*vp9_quantize_fp_32x32)(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);
  70. 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);
  71. void vp9_scale_and_extend_frame_ssse3(const struct yv12_buffer_config *src, struct yv12_buffer_config *dst, INTERP_FILTER filter_type, int phase_scaler);
  72. RTCD_EXTERN void (*vp9_scale_and_extend_frame)(const struct yv12_buffer_config *src, struct yv12_buffer_config *dst, INTERP_FILTER filter_type, int phase_scaler);
  73. void vp9_rtcd(void);
  74. #ifdef RTCD_C
  75. #include "vpx_ports/x86.h"
  76. static void setup_rtcd_internal(void)
  77. {
  78. int flags = x86_simd_caps();
  79. (void)flags;
  80. vp9_apply_temporal_filter = vp9_apply_temporal_filter_c;
  81. if (flags & HAS_SSE4_1) vp9_apply_temporal_filter = vp9_apply_temporal_filter_sse4_1;
  82. vp9_block_error = vp9_block_error_sse2;
  83. if (flags & HAS_AVX2) vp9_block_error = vp9_block_error_avx2;
  84. vp9_block_error_fp = vp9_block_error_fp_sse2;
  85. if (flags & HAS_AVX2) vp9_block_error_fp = vp9_block_error_fp_avx2;
  86. vp9_diamond_search_sad = vp9_diamond_search_sad_c;
  87. if (flags & HAS_AVX) vp9_diamond_search_sad = vp9_diamond_search_sad_avx;
  88. vp9_quantize_fp = vp9_quantize_fp_sse2;
  89. if (flags & HAS_SSSE3) vp9_quantize_fp = vp9_quantize_fp_ssse3;
  90. if (flags & HAS_AVX2) vp9_quantize_fp = vp9_quantize_fp_avx2;
  91. vp9_quantize_fp_32x32 = vp9_quantize_fp_32x32_c;
  92. if (flags & HAS_SSSE3) vp9_quantize_fp_32x32 = vp9_quantize_fp_32x32_ssse3;
  93. vp9_scale_and_extend_frame = vp9_scale_and_extend_frame_c;
  94. if (flags & HAS_SSSE3) vp9_scale_and_extend_frame = vp9_scale_and_extend_frame_ssse3;
  95. }
  96. #endif
  97. #ifdef __cplusplus
  98. } // extern "C"
  99. #endif
  100. #endif