From 0c0df4b3f017b53fb9a0760ce8c68c293a573a76 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tobias=20Schl=C3=BCter?= Date: Thu, 15 Jul 2004 21:55:05 +0200 Subject: [PATCH] re PR fortran/13792 (lbound/ubound generates internal compiler error) fortran/ PR fortran/13792 * simplify.c (gfc_simplify_bound): Copy the bound expression. testsuite/ PR fortran/13792 * gfortran.fortran-torture/execute/bounds.f90: Add check for compile-time simplification. From-SVN: r84773 --- gcc/fortran/ChangeLog | 5 ++++- gcc/fortran/simplify.c | 4 ++-- gcc/testsuite/ChangeLog | 4 ++++ gcc/testsuite/gfortran.fortran-torture/execute/bounds.f90 | 3 +++ 4 files changed, 13 insertions(+), 3 deletions(-) diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index e69b5de1e20..fd67582631b 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -6,7 +6,10 @@ PR fortran/15140 * trans-decl.c (gfc_trans_deferred_vars): Remove bogus assertion. - + + PR fortran/13792 + * simplify.c (gfc_simplify_bound): Copy the bound expression. + 2004-07-15 Tobias Schlueter PR fortran/15324 diff --git a/gcc/fortran/simplify.c b/gcc/fortran/simplify.c index a90d05d0460..d67b5c68ace 100644 --- a/gcc/fortran/simplify.c +++ b/gcc/fortran/simplify.c @@ -1892,9 +1892,9 @@ gfc_simplify_bound (gfc_expr * array, gfc_expr * dim, int upper) i = mpz_get_si (dim->value.integer); if (upper) - return as->upper[i-1]; + return gfc_copy_expr (as->upper[i-1]); else - return as->lower[i-1]; + return gfc_copy_expr (as->lower[i-1]); } diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index ccda3e53332..8626dbb85ea 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -9,6 +9,10 @@ PR fortran/15140 * gfortran.dg/pr15140.f90: New test. + PR fortran/13792 + * gfortran.fortran-torture/execute/bounds.f90: Add check for + compile-time simplification. + 2004-07-14 Mike Stump * gcc.dg/20020426-2.c: Improve type safety wrt unsignedness. diff --git a/gcc/testsuite/gfortran.fortran-torture/execute/bounds.f90 b/gcc/testsuite/gfortran.fortran-torture/execute/bounds.f90 index b1ad840738c..894cd5d56b2 100644 --- a/gcc/testsuite/gfortran.fortran-torture/execute/bounds.f90 +++ b/gcc/testsuite/gfortran.fortran-torture/execute/bounds.f90 @@ -5,6 +5,9 @@ program testbounds integer, dimension(5) :: j integer i + ! Check compile time simplification + if (lbound(j,1).ne.1 .or. ubound(j,1).ne.5) call abort () + allocate (a(3:8, 6:7)) ! With one parameter