aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJanis Johnson <janis187@us.ibm.com>2006-11-29 18:34:56 +0000
committerJanis Johnson <janis@gcc.gnu.org>2006-11-29 18:34:56 +0000
commit240e6b6bd06f94341224a54acb2576188b737d6e (patch)
tree0e45af83e880d77674ad22929e17ff16e2f1a5e4 /gcc
parent07c02828326880b3df56dd0dfbf00847688351c3 (diff)
downloadgcc-240e6b6bd06f94341224a54acb2576188b737d6e.zip
gcc-240e6b6bd06f94341224a54acb2576188b737d6e.tar.gz
gcc-240e6b6bd06f94341224a54acb2576188b737d6e.tar.bz2
decRound.c: Move declarations to new file, update comments.
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. From-SVN: r119329
Diffstat (limited to 'gcc')
-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
4 files changed, 23 insertions, 11 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 5145756..e80cb3c 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 fc75a8b..9ffdd8a 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 dfad7d3..e68f7df 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 60e3905..8987ff9 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