re PR fortran/85631 (Runtime error message array bound mismatch with nonzero optimiza...
authorThomas Koenig <tkoenig@gcc.gnu.org>
Fri, 8 Jun 2018 22:04:11 +0000 (22:04 +0000)
committerThomas Koenig <tkoenig@gcc.gnu.org>
Fri, 8 Jun 2018 22:04:11 +0000 (22:04 +0000)
2018-06-08  Thomas Koenig  <tkoenig@gcc.gnu.org>

PR fortran/85631
* trans.h (gfc_ss): Add field no_bounds_check.
* trans-array.c (gfc_conv_ss_startstride): If flag_realloc_lhs and
ss->no_bounds_check is set, do not use runtime checks.
* trans-expr.c (gfc_trans_assignment_1): Set lss->no_bounds_check
for reallocatable lhs.

2018-06-08  Thomas Koenig  <tkoenig@gcc.gnu.org>

PR fortran/85631
* gfortran.dg/bounds_check_20.f90: New test.

From-SVN: r261348

gcc/fortran/ChangeLog
gcc/fortran/trans-array.c
gcc/fortran/trans-expr.c
gcc/fortran/trans.h
gcc/testsuite/ChangeLog
gcc/testsuite/gfortran.dg/bounds_check_20.f90 [new file with mode: 0644]

index dffc7f46b99f5c35117333ba849992089c0c1576..dbda6ef58d66972dcd5e97443a977d10fba62ddc 100644 (file)
@@ -1,6 +1,15 @@
+2018-06-08  Thomas Koenig  <tkoenig@gcc.gnu.org>
+
+       PR fortran/85631
+       * trans.h (gfc_ss): Add field no_bounds_check.
+       * trans-array.c (gfc_conv_ss_startstride): If flag_realloc_lhs and
+       ss->no_bounds_check is set, do not use runtime checks.
+       * trans-expr.c (gfc_trans_assignment_1): Set lss->no_bounds_check
+       for reallocatable lhs.
+
 2018-06-08  Steven G. Kargl  <kargl@gcc.gnu.org>
 
-       PR fortran/86059 
+       PR fortran/86059
        * array.c (match_array_cons_element): NULL() cannot be in an
        array constructor.
 
index 7e6cea15c6a00942f53434cf244dc8da7a174cd1..97c47252435d87eca1552352c1dd645bb3c5af9c 100644 (file)
@@ -4304,7 +4304,7 @@ done:
        }
     }
 
-  /* The rest is just runtime bound checking.  */
+  /* The rest is just runtime bounds checking.  */
   if (gfc_option.rtcheck & GFC_RTCHECK_BOUNDS)
     {
       stmtblock_t block;
@@ -4334,7 +4334,7 @@ done:
            continue;
 
          /* Catch allocatable lhs in f2003.  */
-         if (flag_realloc_lhs && ss->is_alloc_lhs)
+         if (flag_realloc_lhs && ss->no_bounds_check)
            continue;
 
          expr = ss_info->expr;
index 8bf550445cc19739804e20314b0570b4bf142911..f85595177c65e6d0c03dd2622ae13c10c03929bd 100644 (file)
@@ -9982,12 +9982,15 @@ gfc_trans_assignment_1 (gfc_expr * expr1, gfc_expr * expr2, bool init_flag,
 
   /* Walk the lhs.  */
   lss = gfc_walk_expr (expr1);
-  if (gfc_is_reallocatable_lhs (expr1)
-      && !(expr2->expr_type == EXPR_FUNCTION
-          && expr2->value.function.isym != NULL
-          && !(expr2->value.function.isym->elemental
-               || expr2->value.function.isym->conversion)))
-    lss->is_alloc_lhs = 1;
+  if (gfc_is_reallocatable_lhs (expr1))
+    {
+      lss->no_bounds_check = 1;
+      if (!(expr2->expr_type == EXPR_FUNCTION
+           && expr2->value.function.isym != NULL
+           && !(expr2->value.function.isym->elemental
+                || expr2->value.function.isym->conversion)))
+       lss->is_alloc_lhs = 1;
+    }
 
   rss = NULL;
 
index 049fcd6cd49eaa40fb986e3ac54c92b9e78e8396..1813882fe366bbc02c917984b86f3b36d945abfc 100644 (file)
@@ -330,6 +330,7 @@ typedef struct gfc_ss
   struct gfc_loopinfo *loop;
 
   unsigned is_alloc_lhs:1;
+  unsigned no_bounds_check:1;
 }
 gfc_ss;
 #define gfc_get_ss() XCNEW (gfc_ss)
index 20ac7c89c96bd2a45fde03cfb4e0d980a5b7827b..8b9b37f19703b6a604be04f9ad4bb775289dac8d 100644 (file)
@@ -1,3 +1,8 @@
+2018-06-08  Thomas Koenig  <tkoenig@gcc.gnu.org>
+
+       PR fortran/85631
+       * gfortran.dg/bounds_check_20.f90: New test.
+
 2018-06-08  Carl Love  <cel@us.ibm.com>
 
        * gcc.target/powerpc/p8vector-builtin-3.c: Add vec_pack test. Update
@@ -16,7 +21,7 @@
 
 2018-06-08  Steven G. Kargl  <kargl@gcc.gnu.org>
 
-       PR fortran/86059 
+       PR fortran/86059
        * gfortran.dg/associate_30.f90: Remove code tested ...
        * gfortran.dg/pr67803.f90: Ditto.
        * gfortran.dg/pr67805.f90: Ditto.
diff --git a/gcc/testsuite/gfortran.dg/bounds_check_20.f90 b/gcc/testsuite/gfortran.dg/bounds_check_20.f90
new file mode 100644 (file)
index 0000000..86a6d09
--- /dev/null
@@ -0,0 +1,24 @@
+! { dg-do  run }
+! { dg-additional-options "-fcheck=bounds -ffrontend-optimize" }
+! PR 85631 - this used to cause a runtime error with bounds checking.
+module x
+contains
+  subroutine sub(a, b)
+    real, dimension(:,:), intent(in) :: a
+    real, dimension(:,:), intent(out), allocatable :: b
+    b = transpose(a)
+  end subroutine sub
+end module x
+
+program main
+  use x
+  implicit none
+  real, dimension(2,2) :: a
+  real, dimension(:,:), allocatable :: b
+  data a /-2., 3., -5., 7./
+  call sub(a, b)
+  if (any (b /= reshape([-2., -5., 3., 7.], shape(b)))) stop 1
+  b = matmul(transpose(b), a)
+  if (any (b /= reshape([-11., 15., -25.,  34.], shape(b)))) stop 2
+end program
+