about summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog8
-rw-r--r--bits/mathdef.h20
-rw-r--r--math/math.h5
-rw-r--r--sysdeps/generic/bits/mathdef.h20
-rw-r--r--sysdeps/i386/fpu/bits/mathdef.h16
-rw-r--r--sysdeps/m68k/fpu/bits/mathdef.h16
6 files changed, 55 insertions, 30 deletions
diff --git a/ChangeLog b/ChangeLog
index f41a7d1686..39072c7285 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,13 @@
 1998-11-05  Ulrich Drepper  <drepper@cygnus.com>
 
+	* math/math.h: Unconditionally include bits/mathdef.h.  Declare
+	long double functions only if __NO_LONG_DOUBLE_MATH is not
+	defined.
+	* sysdeps/generic/bits/mathdef.h: Define only if __USE_ISOC9X.
+	Define __NO_LONG_DOUBLE_MATH.
+	* sysdeps/m68k/fpu/bits/mathdef.h: Define only if __USE_ISOC9X.
+	* sysdeps/i386/fpu/bits/mathdef.h: Likewise.
+
 	* elf/rtld.c: Add a few __builtin_expects where they will improve
 	a lot.
 
diff --git a/bits/mathdef.h b/bits/mathdef.h
index 15140997c0..b034c5c99d 100644
--- a/bits/mathdef.h
+++ b/bits/mathdef.h
@@ -1,4 +1,4 @@
-/* Copyright (C) 1997 Free Software Foundation, Inc.
+/* Copyright (C) 1997, 1998 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
 
    The GNU C Library is free software; you can redistribute it and/or
@@ -20,7 +20,7 @@
 # error "Never use <bits/mathdef.h> directly; include <math.h> instead"
 #endif
 
-
+#ifdef __USE_ISOC9X
 /* Normally, there is no long double type and the `float' and `double'
    expressions are evaluated as `double'.  */
 typedef double float_t;		/* `float' expressions are evaluated as
@@ -29,15 +29,21 @@ typedef double double_t;	/* `double' expressions are evaluated as
 				   `double'.  */
 
 /* Signal that both types are `double'.  */
-#define FLT_EVAL_METHOD	1
+# define FLT_EVAL_METHOD	1
 
 /* Define `INFINITY' as value of type `float'.  */
-#define INFINITY	HUGE_VALF
+# define INFINITY	HUGE_VALF
 
 
 /* The values returned by `ilogb' for 0 and NaN respectively.  */
-#define FP_ILOGB0	0x80000001
-#define FP_ILOGBNAN	0x7fffffff
+# define FP_ILOGB0	0x80000001
+# define FP_ILOGBNAN	0x7fffffff
 
 /* Number of decimal digits for the `double' type.  */
-#define DECIMAL_DIG	15
+# define DECIMAL_DIG	15
+
+#endif	/* ISO C 9X */
+
+/* Signal that we do not really have a `long double'.  The disables the
+   declaration of all the `long double' function variants.  */
+#define __NO_LONG_DOUBLE_MATH	1
diff --git a/math/math.h b/math/math.h
index 2a5f8d3821..42f32eef14 100644
--- a/math/math.h
+++ b/math/math.h
@@ -36,6 +36,8 @@ __BEGIN_DECLS
 #ifdef	 __USE_ISOC9X
 # include <bits/nan.h>
 #endif
+/* Get general and ISO C 9X specific information.  */
+#include <bits/mathdef.h>
 
 
 /* The file <bits/mathcalls.h> contains the prototypes for all the
@@ -81,7 +83,7 @@ __BEGIN_DECLS
 # undef	_Mdouble_
 # undef	__MATH_PRECNAME
 
-# if __STDC__ - 0 || __GNUC__ - 0
+# if __STDC__ - 0 || __GNUC__ - 0 && !defined __NO_LONG_DOUBLE_MATH
 /* Include the file of declarations again, this time using `long double'
    instead of `double' and appending l to each function name.  */
 
@@ -147,7 +149,6 @@ extern int signgam;
 		decimal and all internal floating-point formats.
 
 */
-# include <bits/mathdef.h>
 
 /* All floating-point numbers can be put in one of these categories.  */
 enum
diff --git a/sysdeps/generic/bits/mathdef.h b/sysdeps/generic/bits/mathdef.h
index 15140997c0..b034c5c99d 100644
--- a/sysdeps/generic/bits/mathdef.h
+++ b/sysdeps/generic/bits/mathdef.h
@@ -1,4 +1,4 @@
-/* Copyright (C) 1997 Free Software Foundation, Inc.
+/* Copyright (C) 1997, 1998 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
 
    The GNU C Library is free software; you can redistribute it and/or
@@ -20,7 +20,7 @@
 # error "Never use <bits/mathdef.h> directly; include <math.h> instead"
 #endif
 
-
+#ifdef __USE_ISOC9X
 /* Normally, there is no long double type and the `float' and `double'
    expressions are evaluated as `double'.  */
 typedef double float_t;		/* `float' expressions are evaluated as
@@ -29,15 +29,21 @@ typedef double double_t;	/* `double' expressions are evaluated as
 				   `double'.  */
 
 /* Signal that both types are `double'.  */
-#define FLT_EVAL_METHOD	1
+# define FLT_EVAL_METHOD	1
 
 /* Define `INFINITY' as value of type `float'.  */
-#define INFINITY	HUGE_VALF
+# define INFINITY	HUGE_VALF
 
 
 /* The values returned by `ilogb' for 0 and NaN respectively.  */
-#define FP_ILOGB0	0x80000001
-#define FP_ILOGBNAN	0x7fffffff
+# define FP_ILOGB0	0x80000001
+# define FP_ILOGBNAN	0x7fffffff
 
 /* Number of decimal digits for the `double' type.  */
-#define DECIMAL_DIG	15
+# define DECIMAL_DIG	15
+
+#endif	/* ISO C 9X */
+
+/* Signal that we do not really have a `long double'.  The disables the
+   declaration of all the `long double' function variants.  */
+#define __NO_LONG_DOUBLE_MATH	1
diff --git a/sysdeps/i386/fpu/bits/mathdef.h b/sysdeps/i386/fpu/bits/mathdef.h
index 9d0bd840a3..7dec1ab222 100644
--- a/sysdeps/i386/fpu/bits/mathdef.h
+++ b/sysdeps/i386/fpu/bits/mathdef.h
@@ -1,4 +1,4 @@
-/* Copyright (C) 1997 Free Software Foundation, Inc.
+/* Copyright (C) 1997, 1998 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
 
    The GNU C Library is free software; you can redistribute it and/or
@@ -20,7 +20,7 @@
 # error "Never use <bits/mathdef.h> directly; include <math.h> instead"
 #endif
 
-
+#ifdef __USE_ISOC9X
 /* The ix87 FPUs evaluate all values in the 80 bit floating-point format
    which is also available for the user as `long double'.  Therefore we
    define:  */
@@ -30,14 +30,16 @@ typedef long double double_t;	/* `double' expressions are evaluated as
 				   `long double'.  */
 
 /* Signal that both types are `long double'.  */
-#define FLT_EVAL_METHOD	2
+# define FLT_EVAL_METHOD	2
 
 /* Define `INFINITY' as value of type `float'.  */
-#define INFINITY	HUGE_VALF
+# define INFINITY	HUGE_VALF
 
 /* The values returned by `ilogb' for 0 and NaN respectively.  */
-#define FP_ILOGB0	0x80000000
-#define FP_ILOGBNAN	0x80000000
+# define FP_ILOGB0	0x80000000
+# define FP_ILOGBNAN	0x80000000
 
 /* Number of decimal digits for the `long double' type.  */
-#define DECIMAL_DIG	18
+# define DECIMAL_DIG	18
+
+#endif	/* ISO C 9X */
diff --git a/sysdeps/m68k/fpu/bits/mathdef.h b/sysdeps/m68k/fpu/bits/mathdef.h
index e3d33a53a2..5bad57bcc3 100644
--- a/sysdeps/m68k/fpu/bits/mathdef.h
+++ b/sysdeps/m68k/fpu/bits/mathdef.h
@@ -1,4 +1,4 @@
-/* Copyright (C) 1997 Free Software Foundation, Inc.
+/* Copyright (C) 1997, 1998 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
 
    The GNU C Library is free software; you can redistribute it and/or
@@ -20,7 +20,7 @@
 # error "Never use <bits/mathdef.h> directly; include <math.h> instead"
 #endif
 
-
+#ifdef __USE_ISOC9X
 /* The m68k FPUs evaluate all values in the 96 bit floating-point format
    which is also available for the user as `long double'.  Therefore we
    define: */
@@ -30,14 +30,16 @@ typedef long double double_t;	/* `double' expressions are evaluated as
 				   `long double'.  */
 
 /* Signal that both types are `long double'.  */
-#define FLT_EVAL_METHOD	2
+# define FLT_EVAL_METHOD	2
 
 /* Define `INFINITY' as value of type `float'.  */
-#define INFINITY	HUGE_VALF
+# define INFINITY	HUGE_VALF
 
 /* The values returned by `ilogb' for 0 and NaN respectively.  */
-#define FP_ILOGB0	0x80000000
-#define FP_ILOGBNAN	0x7fffffff
+# define FP_ILOGB0	0x80000000
+# define FP_ILOGBNAN	0x7fffffff
 
 /* Number of decimal digits for the `long double' type.  */
-#define DECIMAL_DIG	18
+# define DECIMAL_DIG	18
+
+#endif	/* ISO C 9X */