vp9_rtcd.h (10878B)
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 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); 50 void vp9_apply_temporal_filter_neon(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); 51 #define vp9_apply_temporal_filter vp9_apply_temporal_filter_neon 52 53 int64_t vp9_block_error_c(const tran_low_t *coeff, const tran_low_t *dqcoeff, intptr_t block_size, int64_t *ssz); 54 int64_t vp9_block_error_neon(const tran_low_t *coeff, const tran_low_t *dqcoeff, intptr_t block_size, int64_t *ssz); 55 int64_t vp9_block_error_sve(const tran_low_t *coeff, const tran_low_t *dqcoeff, intptr_t block_size, int64_t *ssz); 56 RTCD_EXTERN int64_t (*vp9_block_error)(const tran_low_t *coeff, const tran_low_t *dqcoeff, intptr_t block_size, int64_t *ssz); 57 58 int64_t vp9_block_error_fp_c(const tran_low_t *coeff, const tran_low_t *dqcoeff, int block_size); 59 int64_t vp9_block_error_fp_neon(const tran_low_t *coeff, const tran_low_t *dqcoeff, int block_size); 60 int64_t vp9_block_error_fp_sve(const tran_low_t *coeff, const tran_low_t *dqcoeff, int block_size); 61 RTCD_EXTERN int64_t (*vp9_block_error_fp)(const tran_low_t *coeff, const tran_low_t *dqcoeff, int block_size); 62 63 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); 64 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); 65 #define vp9_diamond_search_sad vp9_diamond_search_sad_neon 66 67 void vp9_fht16x16_c(const int16_t *input, tran_low_t *output, int stride, int tx_type); 68 void vp9_fht16x16_neon(const int16_t *input, tran_low_t *output, int stride, int tx_type); 69 #define vp9_fht16x16 vp9_fht16x16_neon 70 71 void vp9_fht4x4_c(const int16_t *input, tran_low_t *output, int stride, int tx_type); 72 void vp9_fht4x4_neon(const int16_t *input, tran_low_t *output, int stride, int tx_type); 73 #define vp9_fht4x4 vp9_fht4x4_neon 74 75 void vp9_fht8x8_c(const int16_t *input, tran_low_t *output, int stride, int tx_type); 76 void vp9_fht8x8_neon(const int16_t *input, tran_low_t *output, int stride, int tx_type); 77 #define vp9_fht8x8 vp9_fht8x8_neon 78 79 void vp9_fwht4x4_c(const int16_t *input, tran_low_t *output, int stride); 80 #define vp9_fwht4x4 vp9_fwht4x4_c 81 82 void vp9_iht16x16_256_add_c(const tran_low_t *input, uint8_t *dest, int stride, int tx_type); 83 void vp9_iht16x16_256_add_neon(const tran_low_t *input, uint8_t *dest, int stride, int tx_type); 84 #define vp9_iht16x16_256_add vp9_iht16x16_256_add_neon 85 86 void vp9_iht4x4_16_add_c(const tran_low_t *input, uint8_t *dest, int stride, int tx_type); 87 void vp9_iht4x4_16_add_neon(const tran_low_t *input, uint8_t *dest, int stride, int tx_type); 88 #define vp9_iht4x4_16_add vp9_iht4x4_16_add_neon 89 90 void vp9_iht8x8_64_add_c(const tran_low_t *input, uint8_t *dest, int stride, int tx_type); 91 void vp9_iht8x8_64_add_neon(const tran_low_t *input, uint8_t *dest, int stride, int tx_type); 92 #define vp9_iht8x8_64_add vp9_iht8x8_64_add_neon 93 94 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); 95 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); 96 #define vp9_quantize_fp vp9_quantize_fp_neon 97 98 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); 99 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); 100 #define vp9_quantize_fp_32x32 vp9_quantize_fp_32x32_neon 101 102 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); 103 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); 104 #define vp9_scale_and_extend_frame vp9_scale_and_extend_frame_neon 105 106 void vpx_convolve12_c(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const InterpKernel12 *filter, int x0_q4, int x_step_q4, int y0_q4, int y_step_q4, int w, int h); 107 void vpx_convolve12_neon(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const InterpKernel12 *filter, int x0_q4, int x_step_q4, int y0_q4, int y_step_q4, int w, int h); 108 void vpx_convolve12_neon_dotprod(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const InterpKernel12 *filter, int x0_q4, int x_step_q4, int y0_q4, int y_step_q4, int w, int h); 109 void vpx_convolve12_neon_i8mm(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const InterpKernel12 *filter, int x0_q4, int x_step_q4, int y0_q4, int y_step_q4, int w, int h); 110 RTCD_EXTERN void (*vpx_convolve12)(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const InterpKernel12 *filter, int x0_q4, int x_step_q4, int y0_q4, int y_step_q4, int w, int h); 111 112 void vpx_convolve12_horiz_c(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const InterpKernel12 *filter, int x0_q4, int x_step_q4, int y0_q4, int y_step_q4, int w, int h); 113 void vpx_convolve12_horiz_neon(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const InterpKernel12 *filter, int x0_q4, int x_step_q4, int y0_q4, int y_step_q4, int w, int h); 114 void vpx_convolve12_horiz_neon_dotprod(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const InterpKernel12 *filter, int x0_q4, int x_step_q4, int y0_q4, int y_step_q4, int w, int h); 115 void vpx_convolve12_horiz_neon_i8mm(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const InterpKernel12 *filter, int x0_q4, int x_step_q4, int y0_q4, int y_step_q4, int w, int h); 116 RTCD_EXTERN void (*vpx_convolve12_horiz)(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const InterpKernel12 *filter, int x0_q4, int x_step_q4, int y0_q4, int y_step_q4, int w, int h); 117 118 void vpx_convolve12_vert_c(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const InterpKernel12 *filter, int x0_q4, int x_step_q4, int y0_q4, int y_step_q4, int w, int h); 119 void vpx_convolve12_vert_neon(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const InterpKernel12 *filter, int x0_q4, int x_step_q4, int y0_q4, int y_step_q4, int w, int h); 120 void vpx_convolve12_vert_neon_dotprod(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const InterpKernel12 *filter, int x0_q4, int x_step_q4, int y0_q4, int y_step_q4, int w, int h); 121 void vpx_convolve12_vert_neon_i8mm(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const InterpKernel12 *filter, int x0_q4, int x_step_q4, int y0_q4, int y_step_q4, int w, int h); 122 RTCD_EXTERN void (*vpx_convolve12_vert)(const uint8_t *src, ptrdiff_t src_stride, uint8_t *dst, ptrdiff_t dst_stride, const InterpKernel12 *filter, int x0_q4, int x_step_q4, int y0_q4, int y_step_q4, int w, int h); 123 124 void vp9_rtcd(void); 125 126 #include "vpx_config.h" 127 128 #ifdef RTCD_C 129 #include "vpx_ports/arm.h" 130 static void setup_rtcd_internal(void) 131 { 132 int flags = arm_cpu_caps(); 133 134 (void)flags; 135 136 vp9_block_error = vp9_block_error_neon; 137 if (flags & HAS_SVE) vp9_block_error = vp9_block_error_sve; 138 vp9_block_error_fp = vp9_block_error_fp_neon; 139 if (flags & HAS_SVE) vp9_block_error_fp = vp9_block_error_fp_sve; 140 vpx_convolve12 = vpx_convolve12_neon; 141 if (flags & HAS_NEON_DOTPROD) vpx_convolve12 = vpx_convolve12_neon_dotprod; 142 if (flags & HAS_NEON_I8MM) vpx_convolve12 = vpx_convolve12_neon_i8mm; 143 vpx_convolve12_horiz = vpx_convolve12_horiz_neon; 144 if (flags & HAS_NEON_DOTPROD) vpx_convolve12_horiz = vpx_convolve12_horiz_neon_dotprod; 145 if (flags & HAS_NEON_I8MM) vpx_convolve12_horiz = vpx_convolve12_horiz_neon_i8mm; 146 vpx_convolve12_vert = vpx_convolve12_vert_neon; 147 if (flags & HAS_NEON_DOTPROD) vpx_convolve12_vert = vpx_convolve12_vert_neon_dotprod; 148 if (flags & HAS_NEON_I8MM) vpx_convolve12_vert = vpx_convolve12_vert_neon_i8mm; 149 } 150 #endif 151 152 #ifdef __cplusplus 153 } // extern "C" 154 #endif 155 156 #endif // VP9_RTCD_H_