1*0e14a7fbSdp-arm /* ===-- int_math.h - internal math inlines ---------------------------------=== 2*0e14a7fbSdp-arm * 3*0e14a7fbSdp-arm * The LLVM Compiler Infrastructure 4*0e14a7fbSdp-arm * 5*0e14a7fbSdp-arm * This file is dual licensed under the MIT and the University of Illinois Open 6*0e14a7fbSdp-arm * Source Licenses. See LICENSE.TXT for details. 7*0e14a7fbSdp-arm * 8*0e14a7fbSdp-arm * ===-----------------------------------------------------------------------=== 9*0e14a7fbSdp-arm * 10*0e14a7fbSdp-arm * This file is not part of the interface of this library. 11*0e14a7fbSdp-arm * 12*0e14a7fbSdp-arm * This file defines substitutes for the libm functions used in some of the 13*0e14a7fbSdp-arm * compiler-rt implementations, defined in such a way that there is not a direct 14*0e14a7fbSdp-arm * dependency on libm or math.h. Instead, we use the compiler builtin versions 15*0e14a7fbSdp-arm * where available. This reduces our dependencies on the system SDK by foisting 16*0e14a7fbSdp-arm * the responsibility onto the compiler. 17*0e14a7fbSdp-arm * 18*0e14a7fbSdp-arm * ===-----------------------------------------------------------------------=== 19*0e14a7fbSdp-arm */ 20*0e14a7fbSdp-arm 21*0e14a7fbSdp-arm #ifndef INT_MATH_H 22*0e14a7fbSdp-arm #define INT_MATH_H 23*0e14a7fbSdp-arm 24*0e14a7fbSdp-arm #ifndef __has_builtin 25*0e14a7fbSdp-arm # define __has_builtin(x) 0 26*0e14a7fbSdp-arm #endif 27*0e14a7fbSdp-arm 28*0e14a7fbSdp-arm #if defined(_MSC_VER) && !defined(__clang__) 29*0e14a7fbSdp-arm #include <math.h> 30*0e14a7fbSdp-arm #include <stdlib.h> 31*0e14a7fbSdp-arm #include <ymath.h> 32*0e14a7fbSdp-arm #endif 33*0e14a7fbSdp-arm 34*0e14a7fbSdp-arm #if defined(_MSC_VER) && !defined(__clang__) 35*0e14a7fbSdp-arm #define CRT_INFINITY INFINITY 36*0e14a7fbSdp-arm #else 37*0e14a7fbSdp-arm #define CRT_INFINITY __builtin_huge_valf() 38*0e14a7fbSdp-arm #endif 39*0e14a7fbSdp-arm 40*0e14a7fbSdp-arm #if defined(_MSC_VER) && !defined(__clang__) 41*0e14a7fbSdp-arm #define crt_isfinite(x) _finite((x)) 42*0e14a7fbSdp-arm #define crt_isinf(x) !_finite((x)) 43*0e14a7fbSdp-arm #define crt_isnan(x) _isnan((x)) 44*0e14a7fbSdp-arm #else 45*0e14a7fbSdp-arm /* Define crt_isfinite in terms of the builtin if available, otherwise provide 46*0e14a7fbSdp-arm * an alternate version in terms of our other functions. This supports some 47*0e14a7fbSdp-arm * versions of GCC which didn't have __builtin_isfinite. 48*0e14a7fbSdp-arm */ 49*0e14a7fbSdp-arm #if __has_builtin(__builtin_isfinite) 50*0e14a7fbSdp-arm # define crt_isfinite(x) __builtin_isfinite((x)) 51*0e14a7fbSdp-arm #elif defined(__GNUC__) 52*0e14a7fbSdp-arm # define crt_isfinite(x) \ 53*0e14a7fbSdp-arm __extension__(({ \ 54*0e14a7fbSdp-arm __typeof((x)) x_ = (x); \ 55*0e14a7fbSdp-arm !crt_isinf(x_) && !crt_isnan(x_); \ 56*0e14a7fbSdp-arm })) 57*0e14a7fbSdp-arm #else 58*0e14a7fbSdp-arm # error "Do not know how to check for infinity" 59*0e14a7fbSdp-arm #endif /* __has_builtin(__builtin_isfinite) */ 60*0e14a7fbSdp-arm #define crt_isinf(x) __builtin_isinf((x)) 61*0e14a7fbSdp-arm #define crt_isnan(x) __builtin_isnan((x)) 62*0e14a7fbSdp-arm #endif /* _MSC_VER */ 63*0e14a7fbSdp-arm 64*0e14a7fbSdp-arm #if defined(_MSC_VER) && !defined(__clang__) 65*0e14a7fbSdp-arm #define crt_copysign(x, y) copysign((x), (y)) 66*0e14a7fbSdp-arm #define crt_copysignf(x, y) copysignf((x), (y)) 67*0e14a7fbSdp-arm #define crt_copysignl(x, y) copysignl((x), (y)) 68*0e14a7fbSdp-arm #else 69*0e14a7fbSdp-arm #define crt_copysign(x, y) __builtin_copysign((x), (y)) 70*0e14a7fbSdp-arm #define crt_copysignf(x, y) __builtin_copysignf((x), (y)) 71*0e14a7fbSdp-arm #define crt_copysignl(x, y) __builtin_copysignl((x), (y)) 72*0e14a7fbSdp-arm #endif 73*0e14a7fbSdp-arm 74*0e14a7fbSdp-arm #if defined(_MSC_VER) && !defined(__clang__) 75*0e14a7fbSdp-arm #define crt_fabs(x) fabs((x)) 76*0e14a7fbSdp-arm #define crt_fabsf(x) fabsf((x)) 77*0e14a7fbSdp-arm #define crt_fabsl(x) fabs((x)) 78*0e14a7fbSdp-arm #else 79*0e14a7fbSdp-arm #define crt_fabs(x) __builtin_fabs((x)) 80*0e14a7fbSdp-arm #define crt_fabsf(x) __builtin_fabsf((x)) 81*0e14a7fbSdp-arm #define crt_fabsl(x) __builtin_fabsl((x)) 82*0e14a7fbSdp-arm #endif 83*0e14a7fbSdp-arm 84*0e14a7fbSdp-arm #if defined(_MSC_VER) && !defined(__clang__) 85*0e14a7fbSdp-arm #define crt_fmax(x, y) __max((x), (y)) 86*0e14a7fbSdp-arm #define crt_fmaxf(x, y) __max((x), (y)) 87*0e14a7fbSdp-arm #define crt_fmaxl(x, y) __max((x), (y)) 88*0e14a7fbSdp-arm #else 89*0e14a7fbSdp-arm #define crt_fmax(x, y) __builtin_fmax((x), (y)) 90*0e14a7fbSdp-arm #define crt_fmaxf(x, y) __builtin_fmaxf((x), (y)) 91*0e14a7fbSdp-arm #define crt_fmaxl(x, y) __builtin_fmaxl((x), (y)) 92*0e14a7fbSdp-arm #endif 93*0e14a7fbSdp-arm 94*0e14a7fbSdp-arm #if defined(_MSC_VER) && !defined(__clang__) 95*0e14a7fbSdp-arm #define crt_logb(x) logb((x)) 96*0e14a7fbSdp-arm #define crt_logbf(x) logbf((x)) 97*0e14a7fbSdp-arm #define crt_logbl(x) logbl((x)) 98*0e14a7fbSdp-arm #else 99*0e14a7fbSdp-arm #define crt_logb(x) __builtin_logb((x)) 100*0e14a7fbSdp-arm #define crt_logbf(x) __builtin_logbf((x)) 101*0e14a7fbSdp-arm #define crt_logbl(x) __builtin_logbl((x)) 102*0e14a7fbSdp-arm #endif 103*0e14a7fbSdp-arm 104*0e14a7fbSdp-arm #if defined(_MSC_VER) && !defined(__clang__) 105*0e14a7fbSdp-arm #define crt_scalbn(x, y) scalbn((x), (y)) 106*0e14a7fbSdp-arm #define crt_scalbnf(x, y) scalbnf((x), (y)) 107*0e14a7fbSdp-arm #define crt_scalbnl(x, y) scalbnl((x), (y)) 108*0e14a7fbSdp-arm #else 109*0e14a7fbSdp-arm #define crt_scalbn(x, y) __builtin_scalbn((x), (y)) 110*0e14a7fbSdp-arm #define crt_scalbnf(x, y) __builtin_scalbnf((x), (y)) 111*0e14a7fbSdp-arm #define crt_scalbnl(x, y) __builtin_scalbnl((x), (y)) 112*0e14a7fbSdp-arm #endif 113*0e14a7fbSdp-arm 114*0e14a7fbSdp-arm #endif /* INT_MATH_H */ 115