chris@162
|
1 /**
|
chris@162
|
2 * Copyright (c) 2014, 2015, Enzien Audio Ltd.
|
chris@162
|
3 *
|
chris@162
|
4 * Permission to use, copy, modify, and/or distribute this software for any
|
chris@162
|
5 * purpose with or without fee is hereby granted, provided that the above
|
chris@162
|
6 * copyright notice and this permission notice appear in all copies.
|
chris@162
|
7 *
|
chris@162
|
8 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
|
chris@162
|
9 * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
|
chris@162
|
10 * AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
|
chris@162
|
11 * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
|
chris@162
|
12 * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
chris@162
|
13 * OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
chris@162
|
14 * PERFORMANCE OF THIS SOFTWARE.
|
chris@162
|
15 */
|
chris@162
|
16
|
chris@162
|
17 #ifndef _HEAVY_UTILS_H_
|
chris@162
|
18 #define _HEAVY_UTILS_H_
|
chris@162
|
19
|
chris@162
|
20 // Type definitions
|
chris@162
|
21 #if _WIN32 || _WIN64 || WINAPI_FAMILY
|
chris@162
|
22 #define HV_WIN 1
|
chris@162
|
23 #include <stddef.h>
|
chris@162
|
24 #if defined (_MSC_VER)
|
chris@162
|
25 #define HV_MSVC 1
|
chris@162
|
26 #endif
|
chris@162
|
27 #define hv_size_t unsigned long
|
chris@162
|
28 #define hv_uint32_t unsigned int
|
chris@162
|
29 #define hv_uint16_t unsigned short
|
chris@162
|
30 #define hv_int32_t int
|
chris@162
|
31 #elif __APPLE__ && __MACH__
|
chris@162
|
32 #define HV_APPLE 1
|
chris@162
|
33 #include <stddef.h>
|
chris@162
|
34 #define hv_size_t size_t
|
chris@162
|
35 #define hv_uint32_t unsigned int
|
chris@162
|
36 #define hv_uint16_t unsigned short
|
chris@162
|
37 #define hv_int32_t int
|
chris@162
|
38 #elif __unix__ || __unix
|
chris@162
|
39 #define HV_UNIX 1
|
chris@162
|
40 #include <stddef.h>
|
chris@162
|
41 #include <stdint.h>
|
chris@162
|
42 #define hv_size_t size_t
|
chris@162
|
43 #define hv_uint32_t uint32_t
|
chris@162
|
44 #define hv_uint16_t uint16_t
|
chris@162
|
45 #define hv_int32_t int32_t
|
chris@162
|
46 #else
|
chris@162
|
47 #error Unsupported platform
|
chris@162
|
48 #endif
|
chris@162
|
49
|
chris@162
|
50 // Memory management
|
chris@162
|
51 extern void *hv_alloca(hv_size_t numbytes);
|
chris@162
|
52 extern void *hv_malloc(hv_size_t numbytes); // allocates memory on 16 byte boundaries and clears it to zero
|
chris@162
|
53 extern void hv_free(void *ptr); // frees aligned memory
|
chris@162
|
54 extern void *hv_realloc(void *ptr, hv_size_t numBytes);
|
chris@162
|
55 extern void *hv_memcpy(void *dest, const void *src, hv_size_t numbytes);
|
chris@162
|
56 extern void *hv_memset(void *ptr, hv_size_t numbytes); // sets everything to 0
|
chris@162
|
57
|
chris@162
|
58 // String handling
|
chris@162
|
59 extern hv_size_t hv_strlen(const char *str);
|
chris@162
|
60 extern char *hv_strncat(char *dest, const char *str, hv_size_t n);
|
chris@162
|
61 extern char *hv_strncpy(char *dest, const char *str, hv_size_t n);
|
chris@162
|
62 extern int hv_strcmp(const char *str1, const char *str2);
|
chris@162
|
63 extern int hv_strncmp(const char *str1, const char *str2, hv_size_t n);
|
chris@162
|
64 extern int hv_snprintf(char *dest, hv_size_t n, const char *format, ...);
|
chris@162
|
65
|
chris@162
|
66 // Math
|
chris@162
|
67 extern int hv_max_i(int x, int y);
|
chris@162
|
68 extern hv_size_t hv_max_ui(hv_size_t x, hv_size_t y);
|
chris@162
|
69 extern int hv_min_i(int x, int y);
|
chris@162
|
70 extern hv_size_t hv_min_ui(hv_size_t x, hv_size_t y);
|
chris@162
|
71 extern float hv_max_f(float x, float y);
|
chris@162
|
72 extern float hv_min_f(float x, float y);
|
chris@162
|
73 extern double hv_max_d(double x, double y);
|
chris@162
|
74 extern double hv_min_d(double x, double y);
|
chris@162
|
75 extern float hv_sin_f(float x);
|
chris@162
|
76 extern float hv_sinh_f(float x);
|
chris@162
|
77 extern float hv_cos_f(float x);
|
chris@162
|
78 extern float hv_cosh_f(float x);
|
chris@162
|
79 extern float hv_tan_f(float x);
|
chris@162
|
80 extern float hv_tanh_f(float x);
|
chris@162
|
81 extern float hv_asin_f(float x);
|
chris@162
|
82 extern float hv_asinh_f(float x);
|
chris@162
|
83 extern float hv_acos_f(float x);
|
chris@162
|
84 extern float hv_acosh_f(float x);
|
chris@162
|
85 extern float hv_atan_f(float x);
|
chris@162
|
86 extern float hv_atanh_f(float x);
|
chris@162
|
87 extern float hv_atan2_f(float x, float y);
|
chris@162
|
88 extern float hv_exp_f(float x);
|
chris@162
|
89 extern float hv_abs_f(float x);
|
chris@162
|
90 extern float hv_sqrt_f(float x);
|
chris@162
|
91 extern float hv_log_f(float x);
|
chris@162
|
92 extern float hv_log2_f(float x);
|
chris@162
|
93 extern float hv_log10_f(float x);
|
chris@162
|
94 extern float hv_ceil_f(float x);
|
chris@162
|
95 extern float hv_floor_f(float x);
|
chris@162
|
96 extern float hv_round_f(float x);
|
chris@162
|
97 extern float hv_pow_f(float x, float y);
|
chris@162
|
98 extern float hv_fma_f(float x, float y, float z);
|
chris@162
|
99
|
chris@162
|
100 // Utilities
|
chris@162
|
101 extern void hv_assert(int e);
|
chris@162
|
102 extern void hv_clear_buffer(float *b, int n);
|
chris@162
|
103 extern hv_uint32_t hv_min_max_log2(hv_uint32_t x);
|
chris@162
|
104
|
chris@162
|
105 // SIMD
|
chris@162
|
106 #ifndef HV_SIMD_NONE
|
chris@162
|
107 #define HV_SIMD_NEON __ARM_NEON__
|
chris@162
|
108 #define HV_SIMD_SSE (__SSE__ && __SSE2__ && __SSE3__ && __SSSE3__ && __SSE4_1__)
|
chris@162
|
109 #define HV_SIMD_AVX (__AVX__ && HV_SIMD_SSE) // it is required that if AVX exists then SSE will also be available
|
chris@162
|
110 #define HV_SIMD_FMA __FMA__
|
chris@162
|
111 #endif
|
chris@162
|
112
|
chris@162
|
113 #ifdef HV_WIN
|
chris@162
|
114 #include "Utils_windows.h"
|
chris@162
|
115 #elif HV_APPLE
|
chris@162
|
116 #include "Utils_mac.h"
|
chris@162
|
117 #elif HV_UNIX
|
chris@162
|
118 #include "Utils_unix.h"
|
chris@162
|
119 #else
|
chris@162
|
120 #error Unsupported platform
|
chris@162
|
121 #endif
|
chris@162
|
122
|
chris@162
|
123 #if HV_SIMD_NEON // NEON
|
chris@162
|
124 #define HV_N_SIMD 4
|
chris@162
|
125 #define hv_bufferf_t float32x4_t
|
chris@162
|
126 #define hv_bufferi_t int32x4_t
|
chris@162
|
127 #define hv_bInf_t float32x4_t
|
chris@162
|
128 #define hv_bOutf_t float32x4_t*
|
chris@162
|
129 #define hv_bIni_t int32x4_t
|
chris@162
|
130 #define hv_bOuti_t int32x4_t*
|
chris@162
|
131 #define VIf(_x) (_x)
|
chris@162
|
132 #define VOf(_x) (&_x)
|
chris@162
|
133 #define VIi(_x) (_x)
|
chris@162
|
134 #define VOi(_x) (&_x)
|
chris@162
|
135 #elif HV_SIMD_AVX // AVX
|
chris@162
|
136 #define HV_N_SIMD 8
|
chris@162
|
137 #define hv_bufferf_t __m256
|
chris@162
|
138 #define hv_bufferi_t __m256i
|
chris@162
|
139 #define hv_bInf_t __m256
|
chris@162
|
140 #define hv_bOutf_t __m256*
|
chris@162
|
141 #define hv_bIni_t __m256i
|
chris@162
|
142 #define hv_bOuti_t __m256i*
|
chris@162
|
143 #define VIf(_x) (_x)
|
chris@162
|
144 #define VOf(_x) (&_x)
|
chris@162
|
145 #define VIi(_x) (_x)
|
chris@162
|
146 #define VOi(_x) (&_x)
|
chris@162
|
147 #elif HV_SIMD_SSE // SSE
|
chris@162
|
148 #define HV_N_SIMD 4
|
chris@162
|
149 #define hv_bufferf_t __m128
|
chris@162
|
150 #define hv_bufferi_t __m128i
|
chris@162
|
151 #define hv_bInf_t __m128
|
chris@162
|
152 #define hv_bOutf_t __m128*
|
chris@162
|
153 #define hv_bIni_t __m128i
|
chris@162
|
154 #define hv_bOuti_t __m128i*
|
chris@162
|
155 #define VIf(_x) (_x)
|
chris@162
|
156 #define VOf(_x) (&_x)
|
chris@162
|
157 #define VIi(_x) (_x)
|
chris@162
|
158 #define VOi(_x) (&_x)
|
chris@162
|
159 #else // DEFAULT
|
chris@162
|
160 #define HV_N_SIMD 1
|
chris@162
|
161 #undef HV_SIMD_NONE
|
chris@162
|
162 #define HV_SIMD_NONE 1
|
chris@162
|
163 #define hv_bufferf_t float
|
chris@162
|
164 #define hv_bufferi_t int
|
chris@162
|
165 #define hv_bInf_t float
|
chris@162
|
166 #define hv_bOutf_t float*
|
chris@162
|
167 #define hv_bIni_t int
|
chris@162
|
168 #define hv_bOuti_t int*
|
chris@162
|
169 #define VIf(_x) (_x)
|
chris@162
|
170 #define VOf(_x) (&_x)
|
chris@162
|
171 #define VIi(_x) (_x)
|
chris@162
|
172 #define VOi(_x) (&_x)
|
chris@162
|
173 #endif
|
chris@162
|
174
|
chris@162
|
175 #define HV_N_SIMD_MASK (HV_N_SIMD-1)
|
chris@162
|
176
|
chris@162
|
177 #endif // _HEAVY_UTILS_H_
|