RISC-V: Make FRM as global register [PR118103]
[gcc.git] / libstdc++-v3 / src / c++98 / math_stubs_long_double.cc
blobfd3107c2902140180eb5f230aa5d1798bf7411f3
1 // Stub definitions for long double math.
3 // Copyright (C) 2001-2025 Free Software Foundation, Inc.
4 //
5 // This file is part of the GNU ISO C++ Library. This library is free
6 // software; you can redistribute it and/or modify it under the
7 // terms of the GNU General Public License as published by the
8 // Free Software Foundation; either version 3, or (at your option)
9 // any later version.
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 // GNU General Public License for more details.
16 // Under Section 7 of GPL version 3, you are granted additional
17 // permissions described in the GCC Runtime Library Exception, version
18 // 3.1, as published by the Free Software Foundation.
20 // You should have received a copy of the GNU General Public License and
21 // a copy of the GCC Runtime Library Exception along with this program;
22 // see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
23 // <http://www.gnu.org/licenses/>.
25 #include <cmath>
27 // For targets which do not have support for long double versions,
28 // we use the following crude approximations. We keep saying that we'll do
29 // better later, but never do.
31 extern "C"
33 #ifndef _GLIBCXX_HAVE_FABSL
34 long double
35 fabsl(long double x)
37 return fabs((double) x);
39 #endif
41 #ifndef _GLIBCXX_HAVE_ACOSL
42 long double
43 acosl(long double x)
45 return acos((double) x);
47 #endif
49 #ifndef _GLIBCXX_HAVE_ASINL
50 long double
51 asinl(long double x)
53 return asin((double) x);
55 #endif
57 #ifndef _GLIBCXX_HAVE_ATANL
58 long double
59 atanl(long double x)
61 return atan ((double) x);
63 #endif
65 #ifndef _GLIBCXX_HAVE_ATAN2L
66 long double
67 atan2l(long double x, long double y)
69 return atan2((double) x, (double) y);
71 #endif
73 #ifndef _GLIBCXX_HAVE_CEILL
74 long double
75 ceill(long double x)
77 return ceil((double) x);
79 #endif
81 #ifndef _GLIBCXX_HAVE_COSL
82 long double
83 cosl(long double x)
85 return cos((double) x);
87 #endif
89 #ifndef _GLIBCXX_HAVE_COSHL
90 long double
91 coshl(long double x)
93 return cosh((double) x);
95 #endif
97 #ifndef _GLIBCXX_HAVE_EXPL
98 long double
99 expl(long double x)
101 return exp((double) x);
103 #endif
105 #ifndef _GLIBCXX_HAVE_FLOORL
106 long double
107 floorl(long double x)
109 return floor((double) x);
111 #endif
113 #ifndef _GLIBCXX_HAVE_FMODL
114 long double
115 fmodl(long double x, long double y)
117 return fmod((double) x, (double) y);
119 #endif
121 #ifndef _GLIBCXX_HAVE_FREXPL
122 long double
123 frexpl(long double x, int *exp)
125 return frexp((double) x, exp);
127 #endif
129 #ifndef _GLIBCXX_HAVE_SQRTL
130 long double
131 sqrtl(long double x)
133 return sqrt((double) x);
135 #endif
137 #ifndef _GLIBCXX_HAVE_HYPOTL
138 long double
139 hypotl(long double x, long double y)
141 long double s = fabsl(x) + fabsl(y);
142 if (s == 0.0L)
143 return s;
144 x /= s; y /= s;
145 return s * sqrtl(x * x + y * y);
147 #endif
149 #ifndef _GLIBCXX_HAVE_LDEXPL
150 long double
151 ldexpl(long double x, int exp)
153 return ldexp((double) x, exp);
155 #endif
157 #ifndef _GLIBCXX_HAVE_LOGL
158 long double
159 logl(long double x)
161 return log((double) x);
163 #endif
165 #ifndef _GLIBCXX_HAVE_LOG10L
166 long double
167 log10l(long double x)
169 return log10((double) x);
171 #endif
173 #ifndef _GLIBCXX_HAVE_MODFL
174 long double
175 modfl(long double x, long double *iptr)
177 double result, temp;
179 result = modf((double) x, &temp);
180 *iptr = temp;
181 return result;
183 #endif
185 #ifndef _GLIBCXX_HAVE_POWL
186 long double
187 powl(long double x, long double y)
189 return pow((double) x, (double) y);
191 #endif
193 #ifndef _GLIBCXX_HAVE_SINL
194 long double
195 sinl(long double x)
197 return sin((double) x);
199 #endif
201 #ifndef _GLIBCXX_HAVE_SINHL
202 long double
203 sinhl(long double x)
205 return sinh((double) x);
207 #endif
209 #ifndef _GLIBCXX_HAVE_TANL
210 long double
211 tanl(long double x)
213 return tan((double) x);
215 #endif
217 #ifndef _GLIBCXX_HAVE_TANHL
218 long double
219 tanhl(long double x)
221 return tanh((double) x);
223 #endif
224 } // extern "C"