]> rtime.felk.cvut.cz Git - l4.git/blob - l4/pkg/l4re-core/uclibc/lib/contrib/uclibc/libc/sysdeps/linux/x86_64/bits/mathdef.h
Update
[l4.git] / l4 / pkg / l4re-core / uclibc / lib / contrib / uclibc / libc / sysdeps / linux / x86_64 / bits / mathdef.h
1 /* Copyright (C) 2001, 2004 Free Software Foundation, Inc.
2    This file is part of the GNU C Library.
3
4    The GNU C Library is free software; you can redistribute it and/or
5    modify it under the terms of the GNU Lesser General Public
6    License as published by the Free Software Foundation; either
7    version 2.1 of the License, or (at your option) any later version.
8
9    The GNU C Library is distributed in the hope that it will be useful,
10    but WITHOUT ANY WARRANTY; without even the implied warranty of
11    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12    Lesser General Public License for more details.
13
14    You should have received a copy of the GNU Lesser General Public
15    License along with the GNU C Library; if not, see
16    <http://www.gnu.org/licenses/>.  */
17
18 #if !defined _MATH_H && !defined _COMPLEX_H
19 # error "Never use <bits/mathdef.h> directly; include <math.h> instead"
20 #endif
21
22 #if defined __USE_ISOC99 && defined _MATH_H && !defined _MATH_H_MATHDEF
23 # define _MATH_H_MATHDEF        1
24
25 # include <bits/wordsize.h>
26
27 # if __WORDSIZE == 64 || (defined __FLT_EVAL_METHOD__ && __FLT_EVAL_METHOD__ == 0)
28 /* The x86-64 architecture computes values with the precission of the
29    used type.  Similarly for -m32 -mfpmath=sse.  */
30 typedef float float_t;          /* `float' expressions are evaluated as `float'.  */
31 typedef double double_t;        /* `double' expressions are evaluated
32                                    as `double'.  */
33 # else
34 /* The ix87 FPUs evaluate all values in the 80 bit floating-point format
35    which is also available for the user as `long double'.  Therefore we
36    define:  */
37 typedef long double float_t;    /* `float' expressions are evaluated as
38                                    `long double'.  */
39 typedef long double double_t;   /* `double' expressions are evaluated as
40                                    `long double'.  */
41 # endif
42
43 /* The values returned by `ilogb' for 0 and NaN respectively.  */
44 # define FP_ILOGB0      (-2147483647 - 1)
45 # define FP_ILOGBNAN    (-2147483647 - 1)
46
47 #endif  /* ISO C99 */
48
49 #if !defined __NO_LONG_DOUBLE_MATH && !defined __UCLIBC_HAS_LONG_DOUBLE_MATH__
50 # define __NO_LONG_DOUBLE_MATH  1
51 #endif