xref: /rk3399_ARM-atf/lib/compiler-rt/builtins/int_math.h (revision 0e14a7fbeb3014e719302c9b7f6a24c4030dfaf0)
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