Line | Count | Source (jump to first uncovered line) |
1 | | /* Copyright (c) 2003-2008 Jean-Marc Valin |
2 | | Copyright (c) 2007-2008 CSIRO |
3 | | Copyright (c) 2007-2009 Xiph.Org Foundation |
4 | | Written by Jean-Marc Valin */ |
5 | | /** |
6 | | @file arch.h |
7 | | @brief Various architecture definitions for CELT |
8 | | */ |
9 | | /* |
10 | | Redistribution and use in source and binary forms, with or without |
11 | | modification, are permitted provided that the following conditions |
12 | | are met: |
13 | | |
14 | | - Redistributions of source code must retain the above copyright |
15 | | notice, this list of conditions and the following disclaimer. |
16 | | |
17 | | - Redistributions in binary form must reproduce the above copyright |
18 | | notice, this list of conditions and the following disclaimer in the |
19 | | documentation and/or other materials provided with the distribution. |
20 | | |
21 | | THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
22 | | ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
23 | | LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
24 | | A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER |
25 | | OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, |
26 | | EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
27 | | PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR |
28 | | PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF |
29 | | LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |
30 | | NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS |
31 | | SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
32 | | */ |
33 | | |
34 | | #ifndef ARCH_H |
35 | | #define ARCH_H |
36 | | |
37 | | #include "opus_types.h" |
38 | | #include "opus_defines.h" |
39 | | |
40 | | # if !defined(__GNUC_PREREQ) |
41 | | # if defined(__GNUC__)&&defined(__GNUC_MINOR__) |
42 | | # define __GNUC_PREREQ(_maj,_min) \ |
43 | | ((__GNUC__<<16)+__GNUC_MINOR__>=((_maj)<<16)+(_min)) |
44 | | # else |
45 | | # define __GNUC_PREREQ(_maj,_min) 0 |
46 | | # endif |
47 | | # endif |
48 | | |
49 | | #if OPUS_GNUC_PREREQ(3, 0) |
50 | 0 | #define opus_likely(x) (__builtin_expect(!!(x), 1)) |
51 | 0 | #define opus_unlikely(x) (__builtin_expect(!!(x), 0)) |
52 | | #else |
53 | | #define opus_likely(x) (!!(x)) |
54 | | #define opus_unlikely(x) (!!(x)) |
55 | | #endif |
56 | | |
57 | 1.16G | #define CELT_SIG_SCALE 32768.f |
58 | | |
59 | 0 | #define CELT_FATAL(str) celt_fatal(str, __FILE__, __LINE__) |
60 | | |
61 | | #if defined(ENABLE_ASSERTIONS) || defined(ENABLE_HARDENING) |
62 | | #ifdef __GNUC__ |
63 | | __attribute__((noreturn)) |
64 | | #endif |
65 | | void celt_fatal(const char *str, const char *file, int line); |
66 | | |
67 | | #if defined(CELT_C) && !defined(OVERRIDE_celt_fatal) |
68 | | #include <stdio.h> |
69 | | #include <stdlib.h> |
70 | | #ifdef __GNUC__ |
71 | | __attribute__((noreturn)) |
72 | | #endif |
73 | | void celt_fatal(const char *str, const char *file, int line) |
74 | 0 | { |
75 | 0 | fprintf (stderr, "Fatal (internal) error in %s, line %d: %s\n", file, line, str); |
76 | | #if defined(_MSC_VER) |
77 | | _set_abort_behavior( 0, _WRITE_ABORT_MSG); |
78 | | #endif |
79 | 0 | abort(); |
80 | 0 | } |
81 | | #endif |
82 | | |
83 | 68.8M | #define celt_assert(cond) {if (!(cond)) {CELT_FATAL("assertion failed: " #cond);}} |
84 | 2.26M | #define celt_assert2(cond, message) {if (!(cond)) {CELT_FATAL("assertion failed: " #cond "\n" message);}} |
85 | 2.10M | #define MUST_SUCCEED(call) celt_assert((call) == OPUS_OK) |
86 | | #else |
87 | | #define celt_assert(cond) |
88 | | #define celt_assert2(cond, message) |
89 | | #define MUST_SUCCEED(call) do {if((call) != OPUS_OK) {RESTORE_STACK; return OPUS_INTERNAL_ERROR;} } while (0) |
90 | | #endif |
91 | | |
92 | | #if defined(ENABLE_ASSERTIONS) |
93 | | #define celt_sig_assert(cond) {if (!(cond)) {CELT_FATAL("signal assertion failed: " #cond);}} |
94 | | #else |
95 | | #define celt_sig_assert(cond) |
96 | | #endif |
97 | | |
98 | 117M | #define IMUL32(a,b) ((a)*(b)) |
99 | | |
100 | 39.9k | #define MIN16(a,b) ((a) < (b) ? (a) : (b)) /**< Minimum 16-bit value. */ |
101 | 138k | #define MAX16(a,b) ((a) > (b) ? (a) : (b)) /**< Maximum 16-bit value. */ |
102 | 705M | #define MIN32(a,b) ((a) < (b) ? (a) : (b)) /**< Minimum 32-bit value. */ |
103 | 711M | #define MAX32(a,b) ((a) > (b) ? (a) : (b)) /**< Maximum 32-bit value. */ |
104 | 23.9M | #define IMIN(a,b) ((a) < (b) ? (a) : (b)) /**< Minimum int value. */ |
105 | 17.5M | #define IMAX(a,b) ((a) > (b) ? (a) : (b)) /**< Maximum int value. */ |
106 | 692M | #define FMIN(a,b) ((a) < (b) ? (a) : (b)) /**< Minimum float value. */ |
107 | 692M | #define FMAX(a,b) ((a) > (b) ? (a) : (b)) /**< Maximum float value. */ |
108 | | #define UADD32(a,b) ((a)+(b)) |
109 | | #define USUB32(a,b) ((a)-(b)) |
110 | 6.55M | #define MAXG(a,b) MAX32(a, b) |
111 | 5.48M | #define MING(a,b) MIN32(a, b) |
112 | | |
113 | | /* Throughout the code, we use the following scaling for signals: |
114 | | FLOAT: used for float API, normalized to +/-1. |
115 | | INT16: used for 16-bit API, normalized to +/- 32768 |
116 | | RES: internal Opus resolution, defined as +/-1. in float builds, or either 16-bit or 24-bit int for fixed-point builds |
117 | | SIG: internal CELT resolution: defined as +/- 32768. in float builds, or Q27 in fixed-point builds (int16 shifted by 12) |
118 | | */ |
119 | | |
120 | | |
121 | | /* Set this if opus_int64 is a native type of the CPU. */ |
122 | | /* Assume that all LP64 architectures have fast 64-bit types; also x86_64 |
123 | | (which can be ILP32 for x32) and Win64 (which is LLP64). */ |
124 | | #if defined(__x86_64__) || defined(__LP64__) || defined(_WIN64) || defined (__mips) |
125 | | #define OPUS_FAST_INT64 1 |
126 | | #else |
127 | | #define OPUS_FAST_INT64 0 |
128 | | #endif |
129 | | |
130 | | #ifdef FIXED_POINT |
131 | | #define ARG_FIXED(arg) , arg |
132 | | #else |
133 | | #define ARG_FIXED(arg) |
134 | | #endif |
135 | | |
136 | | #define PRINT_MIPS(file) |
137 | | |
138 | | #ifdef FIXED_POINT |
139 | | |
140 | | typedef opus_int16 opus_val16; |
141 | | typedef opus_int32 opus_val32; |
142 | | typedef opus_int64 opus_val64; |
143 | | |
144 | | typedef opus_val32 celt_sig; |
145 | | typedef opus_val16 celt_norm; |
146 | | typedef opus_val32 celt_ener; |
147 | | typedef opus_val32 celt_glog; |
148 | | |
149 | | #ifdef ENABLE_RES24 |
150 | | typedef opus_val32 opus_res; |
151 | | #define RES_SHIFT 8 |
152 | | #define SIG2RES(a) PSHR32(a, SIG_SHIFT-RES_SHIFT) |
153 | | #define RES2INT16(a) SAT16(PSHR32(a, RES_SHIFT)) |
154 | | #define RES2INT24(a) (a) |
155 | | #define RES2FLOAT(a) ((1.f/32768.f/256.)*(a)) |
156 | | #define INT16TORES(a) SHL32(EXTEND32(a), RES_SHIFT) |
157 | | #define INT24TORES(a) (a) |
158 | | #define ADD_RES(a, b) ADD32(a, b) |
159 | | #define FLOAT2RES(a) float2int(32768.f*256.f*(a)) |
160 | | #define RES2SIG(a) SHL32((a), SIG_SHIFT-RES_SHIFT) |
161 | | #define MULT16_RES_Q15(a,b) MULT16_32_Q15(a,b) |
162 | | #define MAX_ENCODING_DEPTH 24 |
163 | | #else |
164 | | typedef opus_val16 opus_res; |
165 | | #define RES_SHIFT 0 |
166 | | #define SIG2RES(a) SIG2WORD16(a) |
167 | | #define RES2INT16(a) (a) |
168 | | #define RES2INT24(a) SHL32(EXTEND32(a), 8) |
169 | | #define RES2FLOAT(a) ((1.f/32768.f)*(a)) |
170 | | #define INT16TORES(a) (a) |
171 | | #define INT24TORES(a) SAT16(PSHR32(a, 8)) |
172 | | #define ADD_RES(a, b) SAT16(ADD32((a), (b))); |
173 | | #define FLOAT2RES(a) FLOAT2INT16(a) |
174 | | #define RES2SIG(a) SHL32(EXTEND32(a), SIG_SHIFT) |
175 | | #define MULT16_RES_Q15(a,b) MULT16_16_Q15(a,b) |
176 | | #define MAX_ENCODING_DEPTH 16 |
177 | | #endif |
178 | | |
179 | | #define RES2VAL16(a) RES2INT16(a) |
180 | | #define FLOAT2SIG(a) float2int(((opus_int32)32768<<SIG_SHIFT)*(a)) |
181 | | #define INT16TOSIG(a) SHL32(EXTEND32(a), SIG_SHIFT) |
182 | | #define INT24TOSIG(a) SHL32(a, SIG_SHIFT-8) |
183 | | |
184 | | #ifdef ENABLE_QEXT |
185 | | typedef opus_val32 celt_coef; |
186 | | #define COEF_ONE Q31ONE |
187 | | #define MULT_COEF_32(a, b) MULT32_32_P31(a,b) |
188 | | #define MAC_COEF_32_ARM(c, a, b) ADD32((c), MULT32_32_Q32(a,b)) |
189 | | #define MULT_COEF(a, b) MULT32_32_Q31(a,b) |
190 | | #define MULT_COEF_TAPS(a, b) SHL32(MULT16_16(a,b), 1) |
191 | | #define COEF2VAL16(x) EXTRACT16(SHR32(x, 16)) |
192 | | #else |
193 | | typedef opus_val16 celt_coef; |
194 | | #define COEF_ONE Q15ONE |
195 | | #define MULT_COEF_32(a, b) MULT16_32_Q15(a,b) |
196 | | #define MAC_COEF_32_ARM(a, b, c) MAC16_32_Q16(a,b,c) |
197 | | #define MULT_COEF(a, b) MULT16_16_Q15(a,b) |
198 | | #define MULT_COEF_TAPS(a, b) MULT16_16_P15(a,b) |
199 | | #define COEF2VAL16(x) (x) |
200 | | #endif |
201 | | |
202 | | #define celt_isnan(x) 0 |
203 | | |
204 | | #define Q15ONE 32767 |
205 | | #define Q31ONE 2147483647 |
206 | | |
207 | | #define SIG_SHIFT 12 |
208 | | /* Safe saturation value for 32-bit signals. We need to make sure that we can |
209 | | add two sig values and that the first stages of the MDCT don't cause an overflow. |
210 | | The most constraining is the ARM_ASM comb filter where we shift left by one |
211 | | and then add two values. Because of that, we use 2^29-1. SIG_SAT must be large |
212 | | enough to fit a full-scale high-freq tone through the prefilter and comb filter, |
213 | | meaning 1.85*1.75*2^(15+SIG_SHIFT) = 434529895. |
214 | | so the limit should be about 2^31*sqrt(.5). */ |
215 | | #define SIG_SAT (536870911) |
216 | | |
217 | | #define NORM_SCALING 16384 |
218 | | |
219 | | #define DB_SHIFT 24 |
220 | | |
221 | | #define EPSILON 1 |
222 | | #define VERY_SMALL 0 |
223 | | #define VERY_LARGE16 ((opus_val16)32767) |
224 | | #define Q15_ONE ((opus_val16)32767) |
225 | | |
226 | | |
227 | | #define ABS16(x) ((x) < 0 ? (-(x)) : (x)) |
228 | | #define ABS32(x) ((x) < 0 ? (-(x)) : (x)) |
229 | | |
230 | | static OPUS_INLINE opus_int16 SAT16(opus_int32 x) { |
231 | | return x > 32767 ? 32767 : x < -32768 ? -32768 : (opus_int16)x; |
232 | | } |
233 | | |
234 | | #ifdef FIXED_DEBUG |
235 | | #include "fixed_debug.h" |
236 | | #else |
237 | | |
238 | | #include "fixed_generic.h" |
239 | | |
240 | | #ifdef OPUS_ARM_PRESUME_AARCH64_NEON_INTR |
241 | | #include "arm/fixed_arm64.h" |
242 | | #elif defined (OPUS_ARM_INLINE_EDSP) |
243 | | #include "arm/fixed_armv5e.h" |
244 | | #elif defined (OPUS_ARM_INLINE_ASM) |
245 | | #include "arm/fixed_armv4.h" |
246 | | #elif defined (BFIN_ASM) |
247 | | #include "fixed_bfin.h" |
248 | | #elif defined (TI_C5X_ASM) |
249 | | #include "fixed_c5x.h" |
250 | | #elif defined (TI_C6X_ASM) |
251 | | #include "fixed_c6x.h" |
252 | | #endif |
253 | | |
254 | | #endif |
255 | | |
256 | | #else /* FIXED_POINT */ |
257 | | |
258 | | typedef float opus_val16; |
259 | | typedef float opus_val32; |
260 | | typedef float opus_val64; |
261 | | |
262 | | typedef float celt_sig; |
263 | | typedef float celt_norm; |
264 | | typedef float celt_ener; |
265 | | typedef float celt_glog; |
266 | | |
267 | | typedef float opus_res; |
268 | | typedef float celt_coef; |
269 | | |
270 | | #ifdef FLOAT_APPROX |
271 | | /* This code should reliably detect NaN/inf even when -ffast-math is used. |
272 | | Assumes IEEE 754 format. */ |
273 | | static OPUS_INLINE int celt_isnan(float x) |
274 | 0 | { |
275 | 0 | union {float f; opus_uint32 i;} in; |
276 | 0 | in.f = x; |
277 | 0 | return ((in.i>>23)&0xFF)==0xFF && (in.i&0x007FFFFF)!=0; |
278 | 0 | } Unexecuted instantiation: celt.c:celt_isnan Unexecuted instantiation: pitch_sse.c:celt_isnan Unexecuted instantiation: opus_multistream_decoder.c:celt_isnan Unexecuted instantiation: opus.c:celt_isnan Unexecuted instantiation: opus_decoder.c:celt_isnan Unexecuted instantiation: opus_multistream.c:celt_isnan Unexecuted instantiation: celt_decoder.c:celt_isnan Unexecuted instantiation: entcode.c:celt_isnan Unexecuted instantiation: entdec.c:celt_isnan Unexecuted instantiation: mathops.c:celt_isnan Unexecuted instantiation: mdct.c:celt_isnan Unexecuted instantiation: modes.c:celt_isnan Unexecuted instantiation: pitch.c:celt_isnan Unexecuted instantiation: celt_lpc.c:celt_isnan Unexecuted instantiation: quant_bands.c:celt_isnan Unexecuted instantiation: rate.c:celt_isnan Unexecuted instantiation: vq.c:celt_isnan Unexecuted instantiation: x86cpu.c:celt_isnan Unexecuted instantiation: x86_celt_map.c:celt_isnan Unexecuted instantiation: vq_sse2.c:celt_isnan Unexecuted instantiation: pitch_avx.c:celt_isnan Unexecuted instantiation: dec_API.c:celt_isnan Unexecuted instantiation: tables_other.c:celt_isnan Unexecuted instantiation: stereo_MS_to_LR.c:celt_isnan Unexecuted instantiation: resampler.c:celt_isnan Unexecuted instantiation: resampler_private_down_FIR.c:celt_isnan Unexecuted instantiation: resampler_private_IIR_FIR.c:celt_isnan Unexecuted instantiation: resampler_private_up2_HQ.c:celt_isnan Unexecuted instantiation: resampler_rom.c:celt_isnan Unexecuted instantiation: stereo_decode_pred.c:celt_isnan Unexecuted instantiation: bands.c:celt_isnan Unexecuted instantiation: cwrs.c:celt_isnan Unexecuted instantiation: entenc.c:celt_isnan Unexecuted instantiation: kiss_fft.c:celt_isnan Unexecuted instantiation: laplace.c:celt_isnan Unexecuted instantiation: init_decoder.c:celt_isnan Unexecuted instantiation: decode_frame.c:celt_isnan Unexecuted instantiation: decode_parameters.c:celt_isnan Unexecuted instantiation: decode_indices.c:celt_isnan Unexecuted instantiation: decode_pulses.c:celt_isnan Unexecuted instantiation: decoder_set_fs.c:celt_isnan Unexecuted instantiation: gain_quant.c:celt_isnan Unexecuted instantiation: NLSF_decode.c:celt_isnan Unexecuted instantiation: PLC.c:celt_isnan Unexecuted instantiation: shell_coder.c:celt_isnan Unexecuted instantiation: tables_gain.c:celt_isnan Unexecuted instantiation: tables_LTP.c:celt_isnan Unexecuted instantiation: tables_NLSF_CB_NB_MB.c:celt_isnan Unexecuted instantiation: tables_NLSF_CB_WB.c:celt_isnan Unexecuted instantiation: tables_pitch_lag.c:celt_isnan Unexecuted instantiation: tables_pulses_per_block.c:celt_isnan Unexecuted instantiation: NLSF_unpack.c:celt_isnan Unexecuted instantiation: bwexpander.c:celt_isnan Unexecuted instantiation: decode_pitch.c:celt_isnan Unexecuted instantiation: lin2log.c:celt_isnan Unexecuted instantiation: log2lin.c:celt_isnan Unexecuted instantiation: LPC_analysis_filter.c:celt_isnan Unexecuted instantiation: LPC_inv_pred_gain.c:celt_isnan Unexecuted instantiation: NLSF2A.c:celt_isnan Unexecuted instantiation: NLSF_stabilize.c:celt_isnan Unexecuted instantiation: pitch_est_tables.c:celt_isnan Unexecuted instantiation: resampler_private_AR2.c:celt_isnan Unexecuted instantiation: sort.c:celt_isnan Unexecuted instantiation: sum_sqr_shift.c:celt_isnan Unexecuted instantiation: LPC_fit.c:celt_isnan Unexecuted instantiation: CNG.c:celt_isnan Unexecuted instantiation: code_signs.c:celt_isnan Unexecuted instantiation: decode_core.c:celt_isnan Unexecuted instantiation: bwexpander_32.c:celt_isnan Unexecuted instantiation: table_LSF_cos.c:celt_isnan Unexecuted instantiation: opus_multistream_encoder.c:celt_isnan Unexecuted instantiation: repacketizer.c:celt_isnan Unexecuted instantiation: celt_encoder.c:celt_isnan Unexecuted instantiation: opus_encoder.c:celt_isnan Unexecuted instantiation: extensions.c:celt_isnan Unexecuted instantiation: analysis.c:celt_isnan Unexecuted instantiation: mlp.c:celt_isnan Unexecuted instantiation: enc_API.c:celt_isnan Unexecuted instantiation: encode_indices.c:celt_isnan Unexecuted instantiation: encode_pulses.c:celt_isnan Unexecuted instantiation: HP_variable_cutoff.c:celt_isnan Unexecuted instantiation: stereo_LR_to_MS.c:celt_isnan Unexecuted instantiation: check_control_input.c:celt_isnan Unexecuted instantiation: control_SNR.c:celt_isnan Unexecuted instantiation: init_encoder.c:celt_isnan Unexecuted instantiation: control_codec.c:celt_isnan Unexecuted instantiation: stereo_encode_pred.c:celt_isnan Unexecuted instantiation: stereo_find_predictor.c:celt_isnan Unexecuted instantiation: stereo_quant_pred.c:celt_isnan Unexecuted instantiation: encode_frame_FLP.c:celt_isnan Unexecuted instantiation: find_pitch_lags_FLP.c:celt_isnan Unexecuted instantiation: find_pred_coefs_FLP.c:celt_isnan Unexecuted instantiation: LPC_analysis_filter_FLP.c:celt_isnan Unexecuted instantiation: LTP_analysis_filter_FLP.c:celt_isnan Unexecuted instantiation: LTP_scale_ctrl_FLP.c:celt_isnan Unexecuted instantiation: noise_shape_analysis_FLP.c:celt_isnan Unexecuted instantiation: process_gains_FLP.c:celt_isnan Unexecuted instantiation: residual_energy_FLP.c:celt_isnan Unexecuted instantiation: warped_autocorrelation_FLP.c:celt_isnan Unexecuted instantiation: wrappers_FLP.c:celt_isnan Unexecuted instantiation: autocorrelation_FLP.c:celt_isnan Unexecuted instantiation: bwexpander_FLP.c:celt_isnan Unexecuted instantiation: energy_FLP.c:celt_isnan Unexecuted instantiation: k2a_FLP.c:celt_isnan Unexecuted instantiation: pitch_analysis_core_FLP.c:celt_isnan Unexecuted instantiation: scale_copy_vector_FLP.c:celt_isnan Unexecuted instantiation: schur_FLP.c:celt_isnan Unexecuted instantiation: sort_FLP.c:celt_isnan Unexecuted instantiation: x86_silk_map.c:celt_isnan Unexecuted instantiation: NSQ_del_dec_avx2.c:celt_isnan Unexecuted instantiation: LP_variable_cutoff.c:celt_isnan Unexecuted instantiation: NSQ.c:celt_isnan Unexecuted instantiation: NSQ_del_dec.c:celt_isnan Unexecuted instantiation: VAD.c:celt_isnan Unexecuted instantiation: control_audio_bandwidth.c:celt_isnan Unexecuted instantiation: quant_LTP_gains.c:celt_isnan Unexecuted instantiation: VQ_WMat_EC.c:celt_isnan Unexecuted instantiation: process_NLSFs.c:celt_isnan Unexecuted instantiation: A2NLSF.c:celt_isnan Unexecuted instantiation: ana_filt_bank_1.c:celt_isnan Unexecuted instantiation: biquad_alt.c:celt_isnan Unexecuted instantiation: inner_prod_aligned.c:celt_isnan Unexecuted instantiation: NLSF_VQ_weights_laroia.c:celt_isnan Unexecuted instantiation: resampler_down2_3.c:celt_isnan Unexecuted instantiation: resampler_down2.c:celt_isnan Unexecuted instantiation: sigm_Q15.c:celt_isnan Unexecuted instantiation: apply_sine_window_FLP.c:celt_isnan Unexecuted instantiation: find_LPC_FLP.c:celt_isnan Unexecuted instantiation: find_LTP_FLP.c:celt_isnan Unexecuted instantiation: burg_modified_FLP.c:celt_isnan Unexecuted instantiation: inner_product_FLP.c:celt_isnan Unexecuted instantiation: scale_vector_FLP.c:celt_isnan Unexecuted instantiation: NSQ_sse4_1.c:celt_isnan Unexecuted instantiation: NSQ_del_dec_sse4_1.c:celt_isnan Unexecuted instantiation: VAD_sse4_1.c:celt_isnan Unexecuted instantiation: VQ_WMat_EC_sse4_1.c:celt_isnan Unexecuted instantiation: inner_product_FLP_avx2.c:celt_isnan Unexecuted instantiation: interpolate.c:celt_isnan Unexecuted instantiation: NLSF_encode.c:celt_isnan Unexecuted instantiation: NLSF_VQ.c:celt_isnan Unexecuted instantiation: NLSF_del_dec_quant.c:celt_isnan Unexecuted instantiation: corrMatrix_FLP.c:celt_isnan |
279 | | #else |
280 | | #ifdef __FAST_MATH__ |
281 | | #error Cannot build libopus with -ffast-math unless FLOAT_APPROX is defined. This could result in crashes on extreme (e.g. NaN) input |
282 | | #endif |
283 | | #define celt_isnan(x) ((x)!=(x)) |
284 | | #endif |
285 | | |
286 | 1.56M | #define Q15ONE 1.0f |
287 | 3.92M | #define Q31ONE 1.0f |
288 | | #define COEF_ONE 1.0f |
289 | 4.03M | #define COEF2VAL16(x) (x) |
290 | | |
291 | 230k | #define NORM_SCALING 1.f |
292 | | |
293 | 3.11M | #define EPSILON 1e-15f |
294 | 0 | #define VERY_SMALL 1e-30f |
295 | | #define VERY_LARGE16 1e15f |
296 | | #define Q15_ONE ((opus_val16)1.f) |
297 | | |
298 | | /* This appears to be the same speed as C99's fabsf() but it's more portable. */ |
299 | 6.37M | #define ABS16(x) ((float)fabs(x)) |
300 | 0 | #define ABS32(x) ((float)fabs(x)) |
301 | | |
302 | 14.8M | #define QCONST16(x,bits) (x) |
303 | 667k | #define QCONST32(x,bits) (x) |
304 | 144M | #define GCONST(x) (x) |
305 | | |
306 | 184k | #define NEG16(x) (-(x)) |
307 | | #define NEG32(x) (-(x)) |
308 | 23.3M | #define NEG32_ovflw(x) (-(x)) |
309 | 107M | #define EXTRACT16(x) (x) |
310 | 0 | #define EXTEND32(x) (x) |
311 | 191k | #define SHR16(a,shift) (a) |
312 | | #define SHL16(a,shift) (a) |
313 | 262M | #define SHR32(a,shift) (a) |
314 | 133M | #define SHL32(a,shift) (a) |
315 | 0 | #define PSHR32(a,shift) (a) |
316 | 4.60M | #define VSHR32(a,shift) (a) |
317 | | |
318 | 0 | #define SHR64(a,shift) (a) |
319 | | |
320 | | #define PSHR(a,shift) (a) |
321 | | #define SHR(a,shift) (a) |
322 | | #define SHL(a,shift) (a) |
323 | 435M | #define SATURATE(x,a) (x) |
324 | | #define SATURATE16(x) (x) |
325 | | |
326 | 18.9M | #define ROUND16(a,shift) (a) |
327 | 348M | #define SROUND16(a,shift) (a) |
328 | 75.8k | #define HALF16(x) (.5f*(x)) |
329 | 216k | #define HALF32(x) (.5f*(x)) |
330 | | |
331 | 142k | #define ADD16(a,b) ((a)+(b)) |
332 | 142k | #define SUB16(a,b) ((a)-(b)) |
333 | 88.9M | #define ADD32(a,b) ((a)+(b)) |
334 | 0 | #define SUB32(a,b) ((a)-(b)) |
335 | 394M | #define ADD32_ovflw(a,b) ((a)+(b)) |
336 | 363M | #define SUB32_ovflw(a,b) ((a)-(b)) |
337 | 184M | #define SHL32_ovflw(a,shift) (a) |
338 | 184M | #define PSHR32_ovflw(a,shift) (a) |
339 | | |
340 | | #define MULT16_16_16(a,b) ((a)*(b)) |
341 | 34.2M | #define MULT16_16(a,b) ((opus_val32)(a)*(opus_val32)(b)) |
342 | 203M | #define MAC16_16(c,a,b) ((c)+(opus_val32)(a)*(opus_val32)(b)) |
343 | | |
344 | 251M | #define MULT16_32_Q15(a,b) ((a)*(b)) |
345 | | #define MULT16_32_Q16(a,b) ((a)*(b)) |
346 | | |
347 | | #define MULT32_32_Q16(a,b) ((a)*(b)) |
348 | 14.4M | #define MULT32_32_Q31(a,b) ((a)*(b)) |
349 | | #define MULT32_32_P31(a,b) ((a)*(b)) |
350 | | |
351 | 0 | #define MAC16_32_Q15(c,a,b) ((c)+(a)*(b)) |
352 | | #define MAC16_32_Q16(c,a,b) ((c)+(a)*(b)) |
353 | | #define MAC_COEF_32_ARM(c,a,b) ((c)+(a)*(b)) |
354 | | |
355 | | #define MULT16_16_Q11_32(a,b) ((a)*(b)) |
356 | | #define MULT16_16_Q11(a,b) ((a)*(b)) |
357 | | #define MULT16_16_Q13(a,b) ((a)*(b)) |
358 | 0 | #define MULT16_16_Q14(a,b) ((a)*(b)) |
359 | 32.8M | #define MULT16_16_Q15(a,b) ((a)*(b)) |
360 | 11.9k | #define MULT16_16_P15(a,b) ((a)*(b)) |
361 | | #define MULT16_16_P13(a,b) ((a)*(b)) |
362 | | #define MULT16_16_P14(a,b) ((a)*(b)) |
363 | 12.6M | #define MULT16_32_P16(a,b) ((a)*(b)) |
364 | | |
365 | 18.2M | #define MULT_COEF_32(a, b) ((a)*(b)) |
366 | 3.04M | #define MULT_COEF(a, b) ((a)*(b)) |
367 | 316k | #define MULT_COEF_TAPS(a, b) ((a)*(b)) |
368 | | |
369 | 0 | #define DIV32_16(a,b) (((opus_val32)(a))/(opus_val16)(b)) |
370 | 0 | #define DIV32(a,b) (((opus_val32)(a))/(opus_val32)(b)) |
371 | | |
372 | 168M | #define SIG2RES(a) ((1/CELT_SIG_SCALE)*(a)) |
373 | 695M | #define RES2INT16(a) FLOAT2INT16(a) |
374 | 0 | #define RES2INT24(a) float2int(32768.f*256.f*(a)) |
375 | 0 | #define RES2FLOAT(a) (a) |
376 | 302M | #define INT16TORES(a) ((a)*(1/CELT_SIG_SCALE)) |
377 | 0 | #define INT24TORES(a) ((1.f/32768.f/256.)*(a)) |
378 | 65.8M | #define ADD_RES(a, b) ADD32(a, b) |
379 | 0 | #define FLOAT2RES(a) (a) |
380 | 0 | #define RES2SIG(a) (CELT_SIG_SCALE*(a)) |
381 | 0 | #define MULT16_RES_Q15(a,b) MULT16_16_Q15(a,b) |
382 | | |
383 | 0 | #define RES2VAL16(a) (a) |
384 | 0 | #define FLOAT2SIG(a) ((a)*CELT_SIG_SCALE) |
385 | 0 | #define INT16TOSIG(a) ((float)(a)) |
386 | 0 | #define INT24TOSIG(a) ((float)(a)*(1.f/256.f)) |
387 | 0 | #define MAX_ENCODING_DEPTH 24 |
388 | | |
389 | | #endif /* !FIXED_POINT */ |
390 | | |
391 | | #ifndef GLOBAL_STACK_SIZE |
392 | | #ifdef FIXED_POINT |
393 | | #define GLOBAL_STACK_SIZE 120000 |
394 | | #else |
395 | | #define GLOBAL_STACK_SIZE 120000 |
396 | | #endif |
397 | | #endif |
398 | | |
399 | | #endif /* ARCH_H */ |