vp9_rtcd.h (5453B)
1 /* 2 * Copyright (c) 2025 The WebM project authors. All Rights Reserved. 3 * 4 * Use of this source code is governed by a BSD-style license 5 * that can be found in the LICENSE file in the root of the source 6 * tree. An additional intellectual property rights grant can be found 7 * in the file PATENTS. All contributing project authors may 8 * be found in the AUTHORS file in the root of the source tree. 9 */ 10 11 // This file is generated. Do not edit. 12 #ifndef VP9_RTCD_H_ 13 #define VP9_RTCD_H_ 14 15 #ifdef RTCD_C 16 #define RTCD_EXTERN 17 #else 18 #define RTCD_EXTERN extern 19 #endif 20 21 /* 22 * VP9 23 */ 24 25 #include "vpx/vpx_integer.h" 26 #include "vp9/common/vp9_common.h" 27 #include "vp9/common/vp9_enums.h" 28 #include "vp9/common/vp9_filter.h" 29 #if !CONFIG_REALTIME_ONLY && CONFIG_VP9_ENCODER 30 #include "vp9/encoder/vp9_temporal_filter.h" 31 #endif 32 33 struct macroblockd; 34 35 /* Encoder forward decls */ 36 struct macroblock; 37 struct macroblock_plane; 38 struct vp9_sad_table; 39 struct ScanOrder; 40 struct search_site_config; 41 struct mv; 42 union int_mv; 43 struct yv12_buffer_config; 44 45 #ifdef __cplusplus 46 extern "C" { 47 #endif 48 49 int64_t vp9_block_error_c(const tran_low_t *coeff, const tran_low_t *dqcoeff, intptr_t block_size, int64_t *ssz); 50 int64_t vp9_block_error_neon(const tran_low_t *coeff, const tran_low_t *dqcoeff, intptr_t block_size, int64_t *ssz); 51 #define vp9_block_error vp9_block_error_neon 52 53 int64_t vp9_block_error_fp_c(const tran_low_t *coeff, const tran_low_t *dqcoeff, int block_size); 54 int64_t vp9_block_error_fp_neon(const tran_low_t *coeff, const tran_low_t *dqcoeff, int block_size); 55 #define vp9_block_error_fp vp9_block_error_fp_neon 56 57 int vp9_diamond_search_sad_c(const struct macroblock *x, const struct search_site_config *cfg, struct mv *ref_mv, uint32_t start_mv_sad, struct mv *best_mv, int search_param, int sad_per_bit, int *num00, const struct vp9_sad_table *sad_fn_ptr, const struct mv *center_mv); 58 int vp9_diamond_search_sad_neon(const struct macroblock *x, const struct search_site_config *cfg, struct mv *ref_mv, uint32_t start_mv_sad, struct mv *best_mv, int search_param, int sad_per_bit, int *num00, const struct vp9_sad_table *sad_fn_ptr, const struct mv *center_mv); 59 #define vp9_diamond_search_sad vp9_diamond_search_sad_neon 60 61 void vp9_fht16x16_c(const int16_t *input, tran_low_t *output, int stride, int tx_type); 62 void vp9_fht16x16_neon(const int16_t *input, tran_low_t *output, int stride, int tx_type); 63 #define vp9_fht16x16 vp9_fht16x16_neon 64 65 void vp9_fht4x4_c(const int16_t *input, tran_low_t *output, int stride, int tx_type); 66 void vp9_fht4x4_neon(const int16_t *input, tran_low_t *output, int stride, int tx_type); 67 #define vp9_fht4x4 vp9_fht4x4_neon 68 69 void vp9_fht8x8_c(const int16_t *input, tran_low_t *output, int stride, int tx_type); 70 void vp9_fht8x8_neon(const int16_t *input, tran_low_t *output, int stride, int tx_type); 71 #define vp9_fht8x8 vp9_fht8x8_neon 72 73 void vp9_fwht4x4_c(const int16_t *input, tran_low_t *output, int stride); 74 #define vp9_fwht4x4 vp9_fwht4x4_c 75 76 void vp9_iht16x16_256_add_c(const tran_low_t *input, uint8_t *dest, int stride, int tx_type); 77 void vp9_iht16x16_256_add_neon(const tran_low_t *input, uint8_t *dest, int stride, int tx_type); 78 #define vp9_iht16x16_256_add vp9_iht16x16_256_add_neon 79 80 void vp9_iht4x4_16_add_c(const tran_low_t *input, uint8_t *dest, int stride, int tx_type); 81 void vp9_iht4x4_16_add_neon(const tran_low_t *input, uint8_t *dest, int stride, int tx_type); 82 #define vp9_iht4x4_16_add vp9_iht4x4_16_add_neon 83 84 void vp9_iht8x8_64_add_c(const tran_low_t *input, uint8_t *dest, int stride, int tx_type); 85 void vp9_iht8x8_64_add_neon(const tran_low_t *input, uint8_t *dest, int stride, int tx_type); 86 #define vp9_iht8x8_64_add vp9_iht8x8_64_add_neon 87 88 void vp9_quantize_fp_c(const tran_low_t *coeff_ptr, intptr_t n_coeffs, const struct macroblock_plane *const mb_plane, tran_low_t *qcoeff_ptr, tran_low_t *dqcoeff_ptr, const int16_t *dequant_ptr, uint16_t *eob_ptr, const struct ScanOrder *const scan_order); 89 void vp9_quantize_fp_neon(const tran_low_t *coeff_ptr, intptr_t n_coeffs, const struct macroblock_plane *const mb_plane, tran_low_t *qcoeff_ptr, tran_low_t *dqcoeff_ptr, const int16_t *dequant_ptr, uint16_t *eob_ptr, const struct ScanOrder *const scan_order); 90 #define vp9_quantize_fp vp9_quantize_fp_neon 91 92 void vp9_quantize_fp_32x32_c(const tran_low_t *coeff_ptr, intptr_t n_coeffs, const struct macroblock_plane *const mb_plane, tran_low_t *qcoeff_ptr, tran_low_t *dqcoeff_ptr, const int16_t *dequant_ptr, uint16_t *eob_ptr, const struct ScanOrder *const scan_order); 93 void vp9_quantize_fp_32x32_neon(const tran_low_t *coeff_ptr, intptr_t n_coeffs, const struct macroblock_plane *const mb_plane, tran_low_t *qcoeff_ptr, tran_low_t *dqcoeff_ptr, const int16_t *dequant_ptr, uint16_t *eob_ptr, const struct ScanOrder *const scan_order); 94 #define vp9_quantize_fp_32x32 vp9_quantize_fp_32x32_neon 95 96 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); 97 void vp9_scale_and_extend_frame_neon(const struct yv12_buffer_config *src, struct yv12_buffer_config *dst, INTERP_FILTER filter_type, int phase_scaler); 98 #define vp9_scale_and_extend_frame vp9_scale_and_extend_frame_neon 99 100 void vp9_rtcd(void); 101 102 #include "vpx_config.h" 103 104 #ifdef RTCD_C 105 #include "vpx_ports/arm.h" 106 static void setup_rtcd_internal(void) 107 { 108 int flags = arm_cpu_caps(); 109 110 (void)flags; 111 112 } 113 #endif 114 115 #ifdef __cplusplus 116 } // extern "C" 117 #endif 118 119 #endif // VP9_RTCD_H_