aboutsummaryrefslogtreecommitdiff
path: root/gcc/fortran/simplify.c
diff options
context:
space:
mode:
authorSteven G. Kargl <kargls@comcast.net>2005-04-07 18:26:37 +0000
committerSteven G. Kargl <kargl@gcc.gnu.org>2005-04-07 18:26:37 +0000
commit01ae893012ce58112229ac1e3bd1050d5afec72b (patch)
tree27d6b666571261da74732c902515eb5906f5a39d /gcc/fortran/simplify.c
parent03359b57f439670c05cc0050690884e1ac03bca4 (diff)
downloadgcc-01ae893012ce58112229ac1e3bd1050d5afec72b.zip
gcc-01ae893012ce58112229ac1e3bd1050d5afec72b.tar.gz
gcc-01ae893012ce58112229ac1e3bd1050d5afec72b.tar.bz2
simplify.c (gfc_simplify_exponent): Fix exponent(tiny(x))
From-SVN: r97792
Diffstat (limited to 'gcc/fortran/simplify.c')
-rw-r--r--gcc/fortran/simplify.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/gcc/fortran/simplify.c b/gcc/fortran/simplify.c
index c211714..add391f 100644
--- a/gcc/fortran/simplify.c
+++ b/gcc/fortran/simplify.c
@@ -967,6 +967,7 @@ gfc_simplify_exp (gfc_expr * x)
gfc_expr *
gfc_simplify_exponent (gfc_expr * x)
{
+ int i;
mpfr_t tmp;
gfc_expr *result;
@@ -991,6 +992,12 @@ gfc_simplify_exponent (gfc_expr * x)
gfc_mpfr_to_mpz (result->value.integer, tmp);
+ /* The model number for tiny(x) is b**(emin - 1) where b is the base and emin
+ is the smallest exponent value. So, we need to add 1 if x is tiny(x). */
+ i = gfc_validate_kind (x->ts.type, x->ts.kind, false);
+ if (mpfr_cmp (x->value.real, gfc_real_kinds[i].tiny) == 0)
+ mpz_add_ui (result->value.integer,result->value.integer, 1);
+
mpfr_clear (tmp);
return range_check (result, "EXPONENT");