re PR fortran/78279 (ICE in identical_array_ref, at fortran/dependency.c:104)
authorSteven G. Kargl <kargl@gcc.gnu.org>
Thu, 1 Dec 2016 20:37:55 +0000 (20:37 +0000)
committerSteven G. Kargl <kargl@gcc.gnu.org>
Thu, 1 Dec 2016 20:37:55 +0000 (20:37 +0000)
2016-12-01  Steven G. Kargl  <kargl@gcc.gnu.org>

PR fortran/78279
* dependency.c (identical_array_ref): Convert gcc_assert to conditional
and gfc_internal_error.

2016-12-01  Steven G. Kargl  <kargl@gcc.gnu.org>

PR fortran/78279
* gfortran.dg/pr78279.f90: New test.

From-SVN: r243131

gcc/fortran/ChangeLog
gcc/fortran/dependency.c
gcc/testsuite/ChangeLog
gcc/testsuite/gfortran.dg/pr78279.f90 [new file with mode: 0644]

index 278c08f0c892f0027dc003fb0b20748974033180..d410392710010f4056fdcbfd9686cd845621b602 100644 (file)
@@ -1,3 +1,9 @@
+2016-12-01  Steven G. Kargl  <kargl@gcc.gnu.org>
+
+       PR fortran/78279
+       * dependency.c (identical_array_ref): Convert gcc_assert to conditional
+       and gfc_internal_error.
+
 2016-11-30  Andre Vehreschild  <vehre@gcc.gnu.org>
 
        * check.c (gfc_check_allocated): By pass the caf_get call and check on
index 82c5e6b573325e4a2b110db1c2b8c7052501435e..4a3c1a793c15aefdb3f6947689d21ccc13ea8530 100644 (file)
@@ -101,7 +101,9 @@ identical_array_ref (gfc_array_ref *a1, gfc_array_ref *a2)
 
   if (a1->type == AR_ELEMENT && a2->type == AR_ELEMENT)
     {
-      gcc_assert (a1->dimen == a2->dimen);
+      if (a1->dimen != a2->dimen)
+       gfc_internal_error ("identical_array_ref(): inconsistent dimensions");
+
       for (i = 0; i < a1->dimen; i++)
        {
          if (gfc_dep_compare_expr (a1->start[i], a2->start[i]) != 0)
index d6e5ac478815ae3526bf04f1ffc481c9aff15020..321a48a8eab40a974a5aee9e9fffc441964d2b67 100644 (file)
@@ -1,3 +1,8 @@
+2016-12-01  Steven G. Kargl  <kargl@gcc.gnu.org>
+
+       PR fortran/78279
+       * gfortran.dg/pr78279.f90: New test.
+
 2016-12-01  David Edelsohn  <dje.gcc@gmail.com>
 
        * g++.dg/tls/pr77285-1.C: dg-add-options tls
diff --git a/gcc/testsuite/gfortran.dg/pr78279.f90 b/gcc/testsuite/gfortran.dg/pr78279.f90
new file mode 100644 (file)
index 0000000..cb01752
--- /dev/null
@@ -0,0 +1,10 @@
+! { dg-do compile }
+! { dg-options "-Ofast" }
+program p
+   integer :: i
+   real :: z(2,4)
+   z = 0.0
+   do i = 1, 3
+      if ( z(i) > z(1,i+1) ) print *, i   ! { dg-error "mismatch in array reference" }
+   end do
+end