summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorjanis <janis@138bc75d-0d04-0410-961f-82ee72b054a4>2006-11-29 18:34:56 +0000
committerjanis <janis@138bc75d-0d04-0410-961f-82ee72b054a4>2006-11-29 18:34:56 +0000
commit9dfa4821f3b10eb367d1694e4f6b18e7f4a36c44 (patch)
tree0e45af83e880d77674ad22929e17ff16e2f1a5e4
parent3953ee1cd1c9fd6023d4548fe5a5d9ff3f230785 (diff)
downloadgcc-9dfa4821f3b10eb367d1694e4f6b18e7f4a36c44.tar.gz
libdecnumber/
* decRound.c: Move declarations to new file, update comments. * decRound.h: New file. gcc/ * mklibgcc.in: Fix dependencies for dfp-bit.c. * config/dfp-bit.h (CONTEXT_ROUND): Delete. (DFP_INIT_ROUNDMODE): Define. * config/dfp-bit.c: Replace CONTEXT_ROUND with DFP_INIT_ROUNDMODE. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@119329 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r--gcc/ChangeLog7
-rw-r--r--gcc/config/dfp-bit.c14
-rw-r--r--gcc/config/dfp-bit.h8
-rw-r--r--gcc/mklibgcc.in5
-rw-r--r--libdecnumber/ChangeLog5
-rw-r--r--libdecnumber/decRound.c14
-rw-r--r--libdecnumber/decRound.h28
7 files changed, 63 insertions, 18 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 5145756ff87..e80cb3c00fd 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,10 @@
+2006-11-29 Janis Johnson <janis187@us.ibm.com>
+
+ * config/dfp-bit.h (CONTEXT_ROUND): Delete.
+ (DFP_INIT_ROUNDMODE): Define.
+ * config/dfp-bit.c: Replace CONTEXT_ROUND with DFP_INIT_ROUNDMODE.
+ * mklibgcc.in: Fix dependencies for dfp-bit.c.
+
2006-11-29 Tehila Meyzels <tehila@il.ibm.com>
* haifa-sched.c: Remove define LINE_NOTE(INSN). Remove line_note_head.
diff --git a/gcc/config/dfp-bit.c b/gcc/config/dfp-bit.c
index fc75a8bc604..9ffdd8a13f9 100644
--- a/gcc/config/dfp-bit.c
+++ b/gcc/config/dfp-bit.c
@@ -81,7 +81,7 @@ dfp_unary_op (dfp_unary_func op, DFP_C_TYPE arg)
HOST_TO_IEEE (arg, &a);
decContextDefault (&context, CONTEXT_INIT);
- context.round = CONTEXT_ROUND;
+ DFP_INIT_ROUNDMODE (context.round);
TO_INTERNAL (&a, &arg1);
@@ -107,7 +107,7 @@ dfp_binary_op (dfp_binary_func op, DFP_C_TYPE arg_a, DFP_C_TYPE arg_b)
HOST_TO_IEEE (arg_b, &b);
decContextDefault (&context, CONTEXT_INIT);
- context.round = CONTEXT_ROUND;
+ DFP_INIT_ROUNDMODE (context.round);
TO_INTERNAL (&a, &arg1);
TO_INTERNAL (&b, &arg2);
@@ -134,7 +134,7 @@ dfp_compare_op (dfp_binary_func op, DFP_C_TYPE arg_a, DFP_C_TYPE arg_b)
HOST_TO_IEEE (arg_b, &b);
decContextDefault (&context, CONTEXT_INIT);
- context.round = CONTEXT_ROUND;
+ DFP_INIT_ROUNDMODE (context.round);
TO_INTERNAL (&a, &arg1);
TO_INTERNAL (&b, &arg2);
@@ -365,7 +365,7 @@ DFP_TO_DFP (DFP_C_TYPE f_from)
decContext context;
decContextDefault (&context, CONTEXT_INIT);
- context.round = CONTEXT_ROUND;
+ DFP_INIT_ROUNDMODE (context.round);
HOST_TO_IEEE (f_from, &s_from);
TO_INTERNAL (&s_from, &d);
@@ -394,7 +394,7 @@ DFP_TO_INT (DFP_C_TYPE x)
decContextDefault (&context, CONTEXT_INIT);
/* Need non-default rounding mode here. */
- context.round = DEC_ROUND_DOWN;
+ DFP_INIT_ROUNDMODE (context.round);
HOST_TO_IEEE (x, &s);
TO_INTERNAL (&s, &n1);
@@ -428,7 +428,7 @@ INT_TO_DFP (INT_TYPE i)
decContext context;
decContextDefault (&context, CONTEXT_INIT);
- context.round = CONTEXT_ROUND;
+ DFP_INIT_ROUNDMODE (context.round);
/* Use a C library function to get a floating point string. */
sprintf (buf, INT_FMT ".0", CAST_FOR_FMT(i));
@@ -470,7 +470,7 @@ BFP_TO_DFP (BFP_TYPE x)
decContext context;
decContextDefault (&context, CONTEXT_INIT);
- context.round = CONTEXT_ROUND;
+ DFP_INIT_ROUNDMODE (context.round);
/* Use a C library function to write the floating point value to a string. */
#ifdef BFP_VIA_TYPE
diff --git a/gcc/config/dfp-bit.h b/gcc/config/dfp-bit.h
index dfad7d308b1..e68f7df416b 100644
--- a/gcc/config/dfp-bit.h
+++ b/gcc/config/dfp-bit.h
@@ -30,6 +30,8 @@ Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA
#ifndef _DFPBIT_H
#define _DFPBIT_H
+#include <fenv.h>
+#include <decRound.h>
#include "tconfig.h"
#include "coretypes.h"
#include "tm.h"
@@ -114,9 +116,9 @@ Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA
#define CONTEXT_INIT DEC_INIT_DECIMAL128
#endif
-/* Define CONTEXT_ROUND to obtain the current decNumber rounding mode. */
-extern enum rounding __decGetRound (void);
-#define CONTEXT_ROUND __decGetRound ()
+#ifndef DFP_INIT_ROUNDMODE
+#define DFP_INIT_ROUNDMODE(A) A = DEC_ROUND_HALF_EVEN
+#endif
/* Conversions between different decimal float types use WIDTH_TO to
determine additional macros to define. */
diff --git a/gcc/mklibgcc.in b/gcc/mklibgcc.in
index 60e390500ea..8987ff9a2ad 100644
--- a/gcc/mklibgcc.in
+++ b/gcc/mklibgcc.in
@@ -145,6 +145,9 @@ decnumber_dep='stmp-dirs $(srcdir)/../libdecnumber/decContext.h $(srcdir)/../lib
$(srcdir)/../libdecnumber/decNumberLocal.h $(srcdir)/../libdecnumber/decimal32.h $(srcdir)/../libdecnumber/decimal64.h
$(srcdir)/../libdecnumber/decimal128.h $(srcdir)/../libdecnumber/decDPD.h $(srcdir)/../libdecnumber/decUtility.h'
+# Dependencies for dfp-bit.c
+dfpbit_c_dep='$(srcdir)/../libdecnumber/decRound.h'" $libgcc_dep $decnumber_dep"
+
# Flag whether we need eh_dummy.c
need_eh_dummy=
@@ -456,7 +459,7 @@ for ml in $MULTILIBS; do
if [ "$dpbit" ]; then
for name in $dpfuncs; do
out="libgcc/${dir}/${name}${objext}"
- echo $out: config/dfp-bit.h config/dfp-bit.c $fpbit_c_dep
+ echo $out: config/dfp-bit.h config/dfp-bit.c $dfpbit_c_dep
echo " $gcc_compile" -DFINE_GRAINED_LIBRARIES $flags -DL$name -DWIDTH=$dpwidth \
$DFP_CFLAGS -c $\(srcdir\)/config/dfp-bit.c -o $out
echo $libgcc_a: $out
diff --git a/libdecnumber/ChangeLog b/libdecnumber/ChangeLog
index 0068a92bfad..0994aee40e7 100644
--- a/libdecnumber/ChangeLog
+++ b/libdecnumber/ChangeLog
@@ -1,3 +1,8 @@
+2006-11-29 Janis Johnson <janis187@us.ibm.com>
+
+ * decRound.c: Move declarations to new file, update comments.
+ * decRound.h: New file.
+
2006-11-21 Janis Johnson <janis187@us.ibm.com>
* decLibrary.c (__dec_type_swap): Add prototype.
diff --git a/libdecnumber/decRound.c b/libdecnumber/decRound.c
index 3a643f34af2..45c642f1c76 100644
--- a/libdecnumber/decRound.c
+++ b/libdecnumber/decRound.c
@@ -1,5 +1,6 @@
-/* Temporary support for a libc-like fp environment for decimal float.
- Copyright (C) 2005 Free Software Foundation, Inc.
+/* Internal testing support for rounding for decimal float.
+
+ Copyright (C) 2005, 2006 Free Software Foundation, Inc.
This file is part of GCC.
@@ -20,6 +21,10 @@
#include "config.h"
#include "decContext.h"
+#include "decRound.h"
+
+/* Internal, non-documented functions for testing libgcc functions.
+ This support is not sufficient for application use. */
#define FE_DEC_DOWNWARD 0
#define FE_DEC_TONEAREST 1
@@ -28,11 +33,6 @@
#define FE_DEC_UPWARD 4
#define FE_DEC_MAX 5
-extern void __dfp_set_round (int);
-extern int __dfp_get_round (void);
-extern enum rounding __decGetRound (void);
-
-/* FIXME: these should be in thread-local storage for runtime support. */
static enum rounding __dfp_rounding_mode = DEC_ROUND_HALF_EVEN;
/* Set the decNumber rounding mode from the FE_DEC_* value in MODE. */
diff --git a/libdecnumber/decRound.h b/libdecnumber/decRound.h
new file mode 100644
index 00000000000..2a708f8cb17
--- /dev/null
+++ b/libdecnumber/decRound.h
@@ -0,0 +1,28 @@
+/* Internal testing support for rounding for decimal float.
+
+ Copyright (C) 2006 Free Software Foundation, Inc.
+
+ This file is part of GCC.
+
+ GCC is free software; you can redistribute it and/or modify it
+ under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2, or (at your option)
+ any later version.
+
+ GCC is distributed in the hope that it will be useful, but WITHOUT
+ ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
+ or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
+ License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with GCC; see the file COPYING. If not, write to the Free
+ Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA
+ 02110-1301, USA. */
+
+#include "decContext.h"
+
+#define DFP_INIT_ROUNDMODE(A) A = __decGetRound()
+
+extern void __dfp_set_round (int);
+extern int __dfp_get_round (void);
+extern enum rounding __decGetRound (void);