1 // This file is generated. Do not edit.
2 #ifndef VP9_RTCD_H_
3 #define VP9_RTCD_H_
4 
5 #ifdef RTCD_C
6 #define RTCD_EXTERN
7 #else
8 #define RTCD_EXTERN extern
9 #endif
10 
11 /*
12  * VP9
13  */
14 
15 #include "vp9_common.h"
16 #include "vp9_enums.h"
17 #include "vp9_filter.h"
18 #include "vpx_dsp_common.h"
19 #include "vpx_dsp_rtcd.h"
20 #include "EbDefinitions.h"
21 
22 struct macroblockd;
23 
24 /* Encoder forward decls */
25 struct macroblock;
26 struct vp9_variance_vtable;
27 struct search_site_config;
28 struct mv;
29 union int_mv;
30 struct yv12_buffer_config;
31 
32 #ifdef __cplusplus
33 extern "C" {
34 #endif
35 
36     int64_t eb_vp9_block_error_c(const tran_low_t *coeff, const tran_low_t *dqcoeff, intptr_t block_size, int64_t *ssz);
37     int64_t eb_vp9_block_error_avx2(const tran_low_t *coeff, const tran_low_t *dqcoeff, intptr_t block_size, int64_t *ssz);
38     RTCD_EXTERN int64_t(*eb_vp9_block_error)(const tran_low_t *coeff, const tran_low_t *dqcoeff, intptr_t block_size, int64_t *ssz);
39 
40     int64_t eb_vp9_block_error_fp_c(const tran_low_t *coeff, const tran_low_t *dqcoeff, int block_size);
41     int64_t eb_vp9_block_error_fp_avx2(const tran_low_t *coeff, const tran_low_t *dqcoeff, int block_size);
42     RTCD_EXTERN int64_t(*eb_vp9_block_error_fp)(const tran_low_t *coeff, const tran_low_t *dqcoeff, int block_size);
43 
44     int eb_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);
45     int eb_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);
46     RTCD_EXTERN int(*eb_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);
47 
48     void 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);
49     void vp9_fdct8x8_quant_ssse3(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);
50     RTCD_EXTERN void(*vp9_fdct8x8_quant)(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);
51 
52     void eb_vp9_fht16x16_c(const int16_t *input, tran_low_t *output, int stride, int tx_type);
53     void vp9_fht16x16_avx2(const int16_t *input, tran_low_t *output, int stride, int tx_type);
54     RTCD_EXTERN void(*vp9_fht16x16)(const int16_t *input, tran_low_t *output, int stride, int tx_type);
55 
56     void eb_vp9_fht4x4_c(const int16_t *input, tran_low_t *output, int stride, int tx_type);
57     void eb_vp9_fht4x4_sse2(const int16_t *input, tran_low_t *output, int stride, int tx_type);
58     RTCD_EXTERN void(*vp9_fht4x4)(const int16_t *input, tran_low_t *output, int stride, int tx_type);
59 
60     void eb_vp9_fht8x8_c(const int16_t *input, tran_low_t *output, int stride, int tx_type);
61     void vp9_fht8x8_avx2(const int16_t *input, tran_low_t *output, int stride, int tx_type);
62     RTCD_EXTERN void(*vp9_fht8x8)(const int16_t *input, tran_low_t *output, int stride, int tx_type);
63 
64     void eb_vp9_fwht4x4_c(const int16_t *input, tran_low_t *output, int stride);
65     void vp9_fwht4x4_sse2(const int16_t *input, tran_low_t *output, int stride);
66     RTCD_EXTERN void(*vp9_fwht4x4)(const int16_t *input, tran_low_t *output, int stride);
67 
68     void eb_vp9_iht16x16_256_add_c(const tran_low_t *input, uint8_t *output, int pitch, int tx_type);
69     void vp9_iht16x16_256_add_avx2(const tran_low_t *input, uint8_t *output, int pitch, int tx_type);
70     RTCD_EXTERN void(*vp9_iht16x16_256_add)(const tran_low_t *input, uint8_t *output, int pitch, int tx_type);
71 
72     void eb_vp9_iht4x4_16_add_c(const tran_low_t *input, uint8_t *dest, int stride, int tx_type);
73     void eb_vp9_iht4x4_16_add_sse2(const tran_low_t *input, uint8_t *dest, int stride, int tx_type);
74     RTCD_EXTERN void(*vp9_iht4x4_16_add)(const tran_low_t *input, uint8_t *dest, int stride, int tx_type);
75 
76     void eb_vp9_iht8x8_64_add_c(const tran_low_t *input, uint8_t *dest, int stride, int tx_type);
77     void eb_vp9_iht8x8_64_add_sse2(const tran_low_t *input, uint8_t *dest, int stride, int tx_type);
78     RTCD_EXTERN void(*vp9_iht8x8_64_add)(const tran_low_t *input, uint8_t *dest, int stride, int tx_type);
79 
80     void eb_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);
81     void eb_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);
82     RTCD_EXTERN void(*eb_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);
83 
84     void eb_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);
85     RTCD_EXTERN void(*eb_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);
86 
87     void eb_vp9_scale_and_extend_frame_c(const struct yv12_buffer_config *src, struct yv12_buffer_config *dst, INTERP_FILTER filter_type, int phase_scaler);
88     void eb_vp9_scale_and_extend_frame_ssse3(const struct yv12_buffer_config *src, struct yv12_buffer_config *dst, INTERP_FILTER filter_type, int phase_scaler);
89     RTCD_EXTERN void(*eb_vp9_scale_and_extend_frame)(const struct yv12_buffer_config *src, struct yv12_buffer_config *dst, INTERP_FILTER filter_type, int phase_scaler);
90 
91     void 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);
92     void vp9_temporal_filter_apply_sse4_1(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);
93     RTCD_EXTERN void(*vp9_temporal_filter_apply)(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);
94 
95     void vp9_rtcd(void);
96 
97 #ifdef RTCD_C
98 
setup_rtcd_internal_vp9(uint32_t asm_type)99     static void setup_rtcd_internal_vp9(uint32_t asm_type)
100     {
101 
102         int flags = 0;
103 
104         if (asm_type > AVX2_MASK)
105         {
106             flags |= HAS_AVX2;
107             flags |= HAS_AVX;
108             flags |= HAS_SSE4_1;
109             flags |= HAS_SSSE3;
110             flags |= HAS_SSE3;
111             flags |= HAS_SSE2;
112             flags |= HAS_SSE;
113             flags |= HAS_MMX;
114         }
115         else if (asm_type > PREAVX2_MASK)
116         {
117             flags |= HAS_AVX;
118             flags |= HAS_SSE4_1;
119             flags |= HAS_SSSE3;
120             flags |= HAS_SSE3;
121             flags |= HAS_SSE2;
122             flags |= HAS_SSE;
123             flags |= HAS_MMX;
124         }
125 
126 #if 0
127         eb_vp9_block_error = eb_vp9_block_error_c;
128         if (flags & HAS_AVX2) eb_vp9_block_error = eb_vp9_block_error_avx2;
129         eb_vp9_block_error_fp = eb_vp9_block_error_fp_c;
130         if (flags & HAS_AVX2) eb_vp9_block_error_fp = eb_vp9_block_error_fp_avx2;
131         eb_vp9_diamond_search_sad = eb_vp9_diamond_search_sad_c;
132         if (flags & HAS_AVX) eb_vp9_diamond_search_sad = eb_vp9_diamond_search_sad_avx;
133         vp9_fdct8x8_quant = vp9_fdct8x8_quant_c;
134         if (flags & HAS_SSSE3) vp9_fdct8x8_quant = vp9_fdct8x8_quant_ssse3;
135 #endif
136         vp9_fht16x16 = eb_vp9_fht16x16_c;
137         if (flags & HAS_AVX2) vp9_fht16x16 = vp9_fht16x16_avx2;
138         vp9_fht4x4 = eb_vp9_fht4x4_c;
139         if (flags & HAS_SSE2) vp9_fht4x4 = eb_vp9_fht4x4_sse2;
140         vp9_fht8x8 = eb_vp9_fht8x8_c;
141         if (flags & HAS_AVX2) vp9_fht8x8 = vp9_fht8x8_avx2;
142 #if 0
143         vp9_fwht4x4 = eb_vp9_fwht4x4_c;
144         if (flags & HAS_SSE2) vp9_fwht4x4 = vp9_fwht4x4_sse2;
145 #endif
146         vp9_iht16x16_256_add = eb_vp9_iht16x16_256_add_c;
147         if (flags & HAS_AVX2) vp9_iht16x16_256_add = vp9_iht16x16_256_add_avx2;
148         vp9_iht4x4_16_add = eb_vp9_iht4x4_16_add_c;
149         if (flags & HAS_SSE2) vp9_iht4x4_16_add = eb_vp9_iht4x4_16_add_sse2;
150         vp9_iht8x8_64_add = eb_vp9_iht8x8_64_add_c;
151         if (flags & HAS_SSE2) vp9_iht8x8_64_add = eb_vp9_iht8x8_64_add_sse2;
152 #if 0
153         eb_vp9_quantize_fp = eb_vp9_quantize_fp_c;
154         if (flags & HAS_AVX2) eb_vp9_quantize_fp = eb_vp9_quantize_fp_avx2;
155         eb_vp9_quantize_fp_32x32 = eb_vp9_quantize_fp_32x32_c;
156         eb_vp9_scale_and_extend_frame = eb_vp9_scale_and_extend_frame_c;
157         if (flags & HAS_SSSE3) eb_vp9_scale_and_extend_frame = eb_vp9_scale_and_extend_frame_ssse3;
158         vp9_temporal_filter_apply = vp9_temporal_filter_apply_c;
159         if (flags & HAS_SSE4_1) vp9_temporal_filter_apply = vp9_temporal_filter_apply_sse4_1;
160 #endif
161 
162     }
163 
164 #endif
165 
166 #ifdef __cplusplus
167 }  // extern "C"
168 #endif
169 
170 #endif
171