diff options
author | Jerry DeLisle <jvdelisle@gcc.gnu.org> | 2009-05-20 00:16:38 +0000 |
---|---|---|
committer | Jerry DeLisle <jvdelisle@gcc.gnu.org> | 2009-05-20 00:16:38 +0000 |
commit | 3a546d4d9bea0eef0b2871663fb00c76ab9bb7da (patch) | |
tree | 147a1da531e050168dc543615b8d712ddb441320 | |
parent | 5cfd5d9b8f7885b1010c829e1062dd2ff0fecdf1 (diff) | |
download | gcc-3a546d4d9bea0eef0b2871663fb00c76ab9bb7da.zip gcc-3a546d4d9bea0eef0b2871663fb00c76ab9bb7da.tar.gz gcc-3a546d4d9bea0eef0b2871663fb00c76ab9bb7da.tar.bz2 |
re PR libfortran/37754 (READ I/O Performance regression from 4.3 to 4.4/4.5)
2009-05-19 Jerry DeLisle <jvdelisle@gcc.gnu.org>
PR libfortran/37754
* io/write_float.def: Simplify format calculation.
From-SVN: r147725
-rw-r--r-- | libgfortran/ChangeLog | 5 | ||||
-rw-r--r-- | libgfortran/io/write_float.def | 9 |
2 files changed, 9 insertions, 5 deletions
diff --git a/libgfortran/ChangeLog b/libgfortran/ChangeLog index 3835279..e9acb8b 100644 --- a/libgfortran/ChangeLog +++ b/libgfortran/ChangeLog @@ -1,3 +1,8 @@ +2009-05-19 Jerry DeLisle <jvdelisle@gcc.gnu.org> + + PR libfortran/37754 + * io/write_float.def: Simplify format calculation. + 2009-05-07 Francois-Xavier Coudert <fxcoudert@gcc.gnu.org> PR fortran/22423 diff --git a/libgfortran/io/write_float.def b/libgfortran/io/write_float.def index acf47fb..9804d7b 100644 --- a/libgfortran/io/write_float.def +++ b/libgfortran/io/write_float.def @@ -603,7 +603,7 @@ output_float_FMT_G_ ## x (st_parameter_dt *dtp, const fnode *f, \ int d = f->u.real.d;\ int w = f->u.real.w;\ fnode *newf;\ - GFC_REAL_ ## x exp_d;\ + GFC_REAL_ ## x rexp_d;\ int low, high, mid;\ int ubound, lbound;\ char *p;\ @@ -612,8 +612,8 @@ output_float_FMT_G_ ## x (st_parameter_dt *dtp, const fnode *f, \ save_scale_factor = dtp->u.p.scale_factor;\ newf = (fnode *) get_mem (sizeof (fnode));\ \ - exp_d = calculate_exp_ ## x (d);\ - if ((m > 0.0 && m < 0.1 - 0.05 / exp_d) || (m >= exp_d - 0.5 ) ||\ + rexp_d = calculate_exp_ ## x (-d);\ + if ((m > 0.0 && m < 0.1 - 0.05 * rexp_d) || (rexp_d * (m + 0.5) >= 1.0) ||\ ((m == 0.0) && !(compile_options.allow_std & GFC_STD_F2003)))\ { \ newf->format = FMT_E;\ @@ -635,8 +635,7 @@ output_float_FMT_G_ ## x (st_parameter_dt *dtp, const fnode *f, \ GFC_REAL_ ## x temp;\ mid = (low + high) / 2;\ \ - temp = (calculate_exp_ ## x (mid) - \ - 5 * calculate_exp_ ## x (mid - d - 1)) / 10;\ + temp = (calculate_exp_ ## x (mid - 1) * (1 - 0.5 * rexp_d));\ \ if (m < temp)\ { \ |