Mercurial > hg > beaglert
comparison scripts/hvresources/HvUtils.h @ 321:4475c0bc2aaa Doxy prerelease
Merge
author | Robert Jack <robert.h.jack@gmail.com> |
---|---|
date | Fri, 27 May 2016 12:32:11 +0100 |
parents | 3d26df8a8a6c |
children | b6eb94378ca9 |
comparison
equal
deleted
inserted
replaced
298:634c1d1f37bc | 321:4475c0bc2aaa |
---|---|
23 #ifdef _MSC_VER | 23 #ifdef _MSC_VER |
24 #define HV_MSVC 1 | 24 #define HV_MSVC 1 |
25 #endif | 25 #endif |
26 #elif __APPLE__ | 26 #elif __APPLE__ |
27 #define HV_APPLE 1 | 27 #define HV_APPLE 1 |
28 #elif __ANDROID__ | |
29 #define HV_ANDROID 1 | |
28 #elif __unix__ || __unix | 30 #elif __unix__ || __unix |
29 #define HV_UNIX 1 | 31 #define HV_UNIX 1 |
30 #else | 32 #else |
31 #warning Could not detect platform. Assuming Unix-like. | 33 #warning Could not detect platform. Assuming Unix-like. |
32 #endif | 34 #endif |
43 #define hv_uint32_t uint32_t | 45 #define hv_uint32_t uint32_t |
44 #define hv_int32_t int32_t | 46 #define hv_int32_t int32_t |
45 #define hv_uint16_t uint16_t | 47 #define hv_uint16_t uint16_t |
46 | 48 |
47 // SIMD-specific includes | 49 // SIMD-specific includes |
48 #ifndef HV_SIMD_NONE | 50 #if !(HV_SIMD_NONE || HV_SIMD_NEON || HV_SIMD_SSE || HV_SIMD_AVX) |
49 #define HV_SIMD_NEON __ARM_NEON__ | 51 #define HV_SIMD_NEON __ARM_NEON__ |
50 #define HV_SIMD_SSE (__SSE__ && __SSE2__ && __SSE3__ && __SSSE3__ && __SSE4_1__) | 52 #define HV_SIMD_SSE (__SSE__ && __SSE2__ && __SSE3__ && __SSSE3__ && __SSE4_1__) |
51 #define HV_SIMD_AVX (__AVX__ && HV_SIMD_SSE) | 53 #define HV_SIMD_AVX (__AVX__ && HV_SIMD_SSE) |
54 #endif | |
55 #ifndef HV_SIMD_FMA | |
52 #define HV_SIMD_FMA __FMA__ | 56 #define HV_SIMD_FMA __FMA__ |
53 #endif | 57 #endif |
54 | 58 |
55 #if HV_SIMD_AVX || HV_SIMD_SSE | 59 #if HV_SIMD_AVX || HV_SIMD_SSE |
56 #include <immintrin.h> | 60 #include <immintrin.h> |
137 #define hv_free(_n) free(_n) | 141 #define hv_free(_n) free(_n) |
138 #endif | 142 #endif |
139 #elif HV_APPLE | 143 #elif HV_APPLE |
140 #define hv_alloca(_n) alloca(_n) | 144 #define hv_alloca(_n) alloca(_n) |
141 #if HV_SIMD_AVX | 145 #if HV_SIMD_AVX |
146 #include <mm_malloc.h> | |
142 #define hv_malloc(_n) _mm_malloc(_n, 32) | 147 #define hv_malloc(_n) _mm_malloc(_n, 32) |
143 #define hv_free(x) _mm_free(x) | 148 #define hv_free(x) _mm_free(x) |
144 #elif HV_SIMD_SSE || HV_SIMD_NEON | 149 #elif HV_SIMD_SSE |
150 #include <mm_malloc.h> | |
145 #define hv_malloc(_n) _mm_malloc(_n, 16) | 151 #define hv_malloc(_n) _mm_malloc(_n, 16) |
146 #define hv_free(x) _mm_free(x) | 152 #define hv_free(x) _mm_free(x) |
153 #elif HV_SIMD_NEON | |
154 // malloc on ios always has 16-byte alignment | |
155 #define hv_malloc(_n) malloc(_n) | |
156 #define hv_free(x) free(x) | |
147 #else // HV_SIMD_NONE | 157 #else // HV_SIMD_NONE |
148 #define hv_malloc(_n) malloc(_n) | 158 #define hv_malloc(_n) malloc(_n) |
149 #define hv_free(x) free(x) | 159 #define hv_free(x) free(x) |
150 #endif | 160 #endif |
151 #else | 161 #else |
152 #include <alloca.h> | 162 #include <alloca.h> |
153 #define hv_alloca(_n) alloca(_n) | 163 #define hv_alloca(_n) alloca(_n) |
154 #if HV_SIMD_AVX | 164 #if HV_SIMD_AVX |
155 #define hv_malloc(_n) aligned_alloc(32, _n) | 165 #define hv_malloc(_n) aligned_alloc(32, _n) |
156 #define hv_free(x) free(x) | 166 #define hv_free(x) free(x) |
157 #elif HV_SIMD_SSE || HV_SIMD_NEON | 167 #elif HV_SIMD_SSE |
158 //#define hv_malloc(_n) aligned_alloc(16, _n) | 168 #define hv_malloc(_n) aligned_alloc(16, _n) |
159 #define hv_malloc(_n) memalign(16, _n) | 169 #define hv_free(x) free(x) |
160 #define hv_free(x) free(x) | 170 #elif HV_SIMD_NEON |
171 #if HV_ANDROID | |
172 #define hv_malloc(_n) memalign(16, _n) | |
173 #define hv_free(x) free(x) | |
174 #else | |
175 //#define hv_malloc(_n) aligned_alloc(16, _n) | |
176 #define hv_malloc(_n) memalign(16, _n) | |
177 #define hv_free(x) free(x) | |
178 #endif | |
161 #else // HV_SIMD_NONE | 179 #else // HV_SIMD_NONE |
162 #define hv_malloc(_n) malloc(_n) | 180 #define hv_malloc(_n) malloc(_n) |
163 #define hv_free(_n) free(_n) | 181 #define hv_free(_n) free(_n) |
164 #endif | 182 #endif |
165 #endif | 183 #endif |
207 #define hv_atan2_f(a, b) atan2f(a, b) | 225 #define hv_atan2_f(a, b) atan2f(a, b) |
208 #define hv_exp_f(a) expf(a) | 226 #define hv_exp_f(a) expf(a) |
209 #define hv_abs_f(a) fabsf(a) | 227 #define hv_abs_f(a) fabsf(a) |
210 #define hv_sqrt_f(a) sqrtf(a) | 228 #define hv_sqrt_f(a) sqrtf(a) |
211 #define hv_log_f(a) logf(a) | 229 #define hv_log_f(a) logf(a) |
212 #define hv_log2_f(a) log2f(a) | 230 #if HV_ANDROID |
231 // NOTE(mhroth): for whatever silly reason, log2f is not defined! | |
232 #define hv_log2_f(a) (1.44269504088896f*logf(a)) | |
233 #else | |
234 #define hv_log2_f(a) log2f(a) | |
235 #endif // HV_ANDROID | |
213 #define hv_log10_f(a) log10f(a) | 236 #define hv_log10_f(a) log10f(a) |
214 #define hv_ceil_f(a) ceilf(a) | 237 #define hv_ceil_f(a) ceilf(a) |
215 #define hv_floor_f(a) floorf(a) | 238 #define hv_floor_f(a) floorf(a) |
216 #define hv_round_f(a) roundf(a) | 239 #define hv_round_f(a) roundf(a) |
217 #define hv_pow_f(a, b) powf(a, b) | 240 #define hv_pow_f(a, b) powf(a, b) |
229 return (hv_uint32_t) (32 - __builtin_clz(x-1)); | 252 return (hv_uint32_t) (32 - __builtin_clz(x-1)); |
230 } | 253 } |
231 #endif | 254 #endif |
232 #define hv_min_max_log2(a) __hv_utils_min_max_log2(a) | 255 #define hv_min_max_log2(a) __hv_utils_min_max_log2(a) |
233 | 256 |
257 // Atomics | |
258 #if HV_WIN | |
259 #include <Windows.h> | |
260 #define hv_atomic_bool volatile LONG | |
261 #define HV_SPINLOCK_ACQUIRE(_x) \ | |
262 while (InterlockedCompareExchange(&_x, true, false)) { } | |
263 #define HV_SPINLOCK_RELEASE(_x) (_x = false) | |
264 #elif defined(__has_include) | |
265 #if __has_include(<stdatomic.h>) | |
266 #include <stdatomic.h> | |
267 #define hv_atomic_bool volatile atomic_bool | |
268 #define HV_SPINLOCK_ACQUIRE(_x) \ | |
269 bool expected = false; \ | |
270 while (!atomic_compare_exchange_strong(&_x, &expected, true)) { expected = false; } | |
271 #define HV_SPINLOCK_RELEASE(_x) atomic_store(&_x, false) | |
272 #else | |
273 #define hv_atomic_bool volatile bool | |
274 #define HV_SPINLOCK_ACQUIRE(_x) _x = true; | |
275 #define HV_SPINLOCK_RELEASE(_x) _x = false; | |
276 #endif | |
277 #else | |
278 #define hv_atomic_bool volatile bool | |
279 #define HV_SPINLOCK_ACQUIRE(_x) _x = true; | |
280 #define HV_SPINLOCK_RELEASE(_x) _x = false; | |
281 #endif | |
282 | |
283 | |
234 #endif // _HEAVY_UTILS_H_ | 284 #endif // _HEAVY_UTILS_H_ |