libm: allow long double wrappers for all architectures
[uclibc-ng.git] / libc / sysdeps / linux / mips / bits / mathdef.h
blob09e2ca6f178695ef70208c33ef3dcfd928a48d92
1 /* Copyright (C) 1997, 1998, 1999, 2000, 2002, 2003, 2004
2 Free Software Foundation, Inc.
3 This file is part of the GNU C Library.
5 The GNU C Library is free software; you can redistribute it and/or
6 modify it under the terms of the GNU Lesser General Public
7 License as published by the Free Software Foundation; either
8 version 2.1 of the License, or (at your option) any later version.
10 The GNU C Library is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Lesser General Public License for more details.
15 You should have received a copy of the GNU Lesser General Public
16 License along with the GNU C Library; if not, see
17 <http://www.gnu.org/licenses/>. */
19 #if !defined _MATH_H && !defined _COMPLEX_H
20 # error "Never use <bits/mathdef.h> directly; include <math.h> instead"
21 #endif
23 #include <sgidefs.h>
25 #if defined __USE_ISOC99 && defined _MATH_H && !defined _MATH_H_MATHDEF
26 # define _MATH_H_MATHDEF 1
28 /* MIPS has both `float' and `double' arithmetic. */
29 typedef float float_t; /* `float' expressions are evaluated as
30 `float'. */
31 typedef double double_t; /* `double' expressions are evaluated as
32 `double'. */
34 /* The values returned by `ilogb' for 0 and NaN respectively. */
35 # define FP_ILOGB0 (-2147483647)
36 # define FP_ILOGBNAN 2147483647
38 #endif /* ISO C99 */
40 #if !defined __NO_LONG_DOUBLE_MATH && !defined __UCLIBC_HAS_LONG_DOUBLE_MATH__
41 # define __NO_LONG_DOUBLE_MATH 1
42 #endif