Fortran: error recovery when simplifying EOSHIFT
authorHarald Anlauf <anlauf@gmx.de>
Tue, 1 Feb 2022 20:36:42 +0000 (21:36 +0100)
committerHarald Anlauf <anlauf@gmx.de>
Tue, 1 Feb 2022 20:36:42 +0000 (21:36 +0100)
gcc/fortran/ChangeLog:

PR fortran/104331
* simplify.cc (gfc_simplify_eoshift): Avoid NULL pointer
dereference when shape is not set.

gcc/testsuite/ChangeLog:

PR fortran/104331
* gfortran.dg/eoshift_9.f90: New test.

gcc/fortran/simplify.cc
gcc/testsuite/gfortran.dg/eoshift_9.f90 [new file with mode: 0644]

index 8604162..6483f9c 100644 (file)
@@ -2572,6 +2572,9 @@ gfc_simplify_eoshift (gfc_expr *array, gfc_expr *shift, gfc_expr *boundary,
   if (arraysize == 0)
     goto final;
 
+  if (array->shape == NULL)
+    goto final;
+
   arrayvec = XCNEWVEC (gfc_expr *, arraysize);
   array_ctor = gfc_constructor_first (array->value.constructor);
   for (i = 0; i < arraysize; i++)
diff --git a/gcc/testsuite/gfortran.dg/eoshift_9.f90 b/gcc/testsuite/gfortran.dg/eoshift_9.f90
new file mode 100644 (file)
index 0000000..f711b04
--- /dev/null
@@ -0,0 +1,8 @@
+! { dg-do compile }
+! PR fortran/104331 - ICE in gfc_simplify_eoshift
+! Contributed by G.Steinmetz
+
+program p
+  character(3), parameter :: a(:) = ['123'] ! { dg-error "deferred shape" }
+  character(3), parameter :: b(*) = eoshift(a, 1)
+end