From: Thomas Koenig Date: Mon, 8 Apr 2013 19:36:43 +0000 (+0000) Subject: re PR fortran/56872 (Incorrect SUM evaluation, involving implied-do loop, with -ffron... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=a2d0800a410ddd6dd321fd6b92c0e21f029fcbab;p=gcc.git re PR fortran/56872 (Incorrect SUM evaluation, involving implied-do loop, with -ffrontend-optimize) 2013-04-08 Thomas Koenig PR fortran/56782 * frontend-passes.c (callback_reduction): Dont't do any simplification if there is only a single element which has an iterator. 2013-04-08 Thomas Koenig PR fortran/56782 * gfortran.dg/array_constructor_44.f90: New test. From-SVN: r197610 --- diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index bf6f7d890d5..538ce473bc6 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,10 @@ +2013-04-08 Thomas Koenig + + PR fortran/56782 + * frontend-passes.c (callback_reduction): Dont't do + any simplification if there is only a single element + which has an iterator. + 2013-04-07 Tobias Burnus PR fortran/56849 diff --git a/gcc/fortran/frontend-passes.c b/gcc/fortran/frontend-passes.c index a77afc58e4b..b2d01169e3b 100644 --- a/gcc/fortran/frontend-passes.c +++ b/gcc/fortran/frontend-passes.c @@ -300,7 +300,12 @@ callback_reduction (gfc_expr **e, int *walk_subtrees ATTRIBUTE_UNUSED, c = gfc_constructor_first (arg->value.constructor); - if (c == NULL) + /* Don't do any simplififcation if we have + - no element in the constructor or + - only have a single element in the array which contains an + iterator. */ + + if (c == NULL || (c->iterator != NULL && gfc_constructor_next (c) == NULL)) return 0; res = copy_walk_reduction_arg (c->expr, fn); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 9fdbdfc0ba1..73935171e31 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2013-04-08 Thomas Koenig + + PR fortran/56782 + * gfortran.dg/array_constructor_44.f90: New test. + 2013-04-08 Paolo Carlini PR c++/56871 diff --git a/gcc/testsuite/gfortran.dg/array_constructor_44.f90 b/gcc/testsuite/gfortran.dg/array_constructor_44.f90 new file mode 100644 index 00000000000..e0cffd168be --- /dev/null +++ b/gcc/testsuite/gfortran.dg/array_constructor_44.f90 @@ -0,0 +1,12 @@ +! { dg-do run } +! { dg-options "-ffrontend-optimize" } +! PR 56872 - wrong front-end optimization with a single constructor. +! Original bug report by Rich Townsend. + integer :: k + real :: s + integer :: m + s = 2.0 + m = 4 + res = SUM([(s**(REAL(k-1)/REAL(m-1)),k=1,m)]) + if (abs(res - 5.84732246) > 1e-6) call abort + end