vp9_rtcd.h (4920B)
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 #define vp9_apply_temporal_filter vp9_apply_temporal_filter_c 51 52 int64_t vp9_block_error_c(const tran_low_t *coeff, const tran_low_t *dqcoeff, intptr_t block_size, int64_t *ssz); 53 #define vp9_block_error vp9_block_error_c 54 55 int64_t vp9_block_error_fp_c(const tran_low_t *coeff, const tran_low_t *dqcoeff, int block_size); 56 #define vp9_block_error_fp vp9_block_error_fp_c 57 58 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); 59 #define vp9_diamond_search_sad vp9_diamond_search_sad_c 60 61 void vp9_fht16x16_c(const int16_t *input, tran_low_t *output, int stride, int tx_type); 62 #define vp9_fht16x16 vp9_fht16x16_c 63 64 void vp9_fht4x4_c(const int16_t *input, tran_low_t *output, int stride, int tx_type); 65 #define vp9_fht4x4 vp9_fht4x4_c 66 67 void vp9_fht8x8_c(const int16_t *input, tran_low_t *output, int stride, int tx_type); 68 #define vp9_fht8x8 vp9_fht8x8_c 69 70 void vp9_fwht4x4_c(const int16_t *input, tran_low_t *output, int stride); 71 #define vp9_fwht4x4 vp9_fwht4x4_c 72 73 void vp9_iht16x16_256_add_c(const tran_low_t *input, uint8_t *dest, int stride, int tx_type); 74 #define vp9_iht16x16_256_add vp9_iht16x16_256_add_c 75 76 void vp9_iht4x4_16_add_c(const tran_low_t *input, uint8_t *dest, int stride, int tx_type); 77 #define vp9_iht4x4_16_add vp9_iht4x4_16_add_c 78 79 void vp9_iht8x8_64_add_c(const tran_low_t *input, uint8_t *dest, int stride, int tx_type); 80 #define vp9_iht8x8_64_add vp9_iht8x8_64_add_c 81 82 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); 83 #define vp9_quantize_fp vp9_quantize_fp_c 84 85 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); 86 #define vp9_quantize_fp_32x32 vp9_quantize_fp_32x32_c 87 88 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); 89 #define vp9_scale_and_extend_frame vp9_scale_and_extend_frame_c 90 91 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); 92 #define vpx_convolve12 vpx_convolve12_c 93 94 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); 95 #define vpx_convolve12_horiz vpx_convolve12_horiz_c 96 97 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); 98 #define vpx_convolve12_vert vpx_convolve12_vert_c 99 100 void vp9_rtcd(void); 101 102 #include "vpx_config.h" 103 104 #ifdef RTCD_C 105 static void setup_rtcd_internal(void) 106 { 107 } 108 #endif 109 110 #ifdef __cplusplus 111 } // extern "C" 112 #endif 113 114 #endif // VP9_RTCD_H_