diff options
author | Janis Johnson <janis187@us.ibm.com> | 2006-11-29 18:34:56 +0000 |
---|---|---|
committer | Janis Johnson <janis@gcc.gnu.org> | 2006-11-29 18:34:56 +0000 |
commit | 240e6b6bd06f94341224a54acb2576188b737d6e (patch) | |
tree | 0e45af83e880d77674ad22929e17ff16e2f1a5e4 /gcc | |
parent | 07c02828326880b3df56dd0dfbf00847688351c3 (diff) | |
download | gcc-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/ChangeLog | 7 | ||||
-rw-r--r-- | gcc/config/dfp-bit.c | 14 | ||||
-rw-r--r-- | gcc/config/dfp-bit.h | 8 | ||||
-rw-r--r-- | gcc/mklibgcc.in | 5 |
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 |