* openmp.c (resolve_omp_do): Report not enough do loops for
collapse even if block->next is NULL.
* gfortran.dg/gomp/pr45595.f90: New test.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@164004
138bc75d-0d04-0410-961f-
82ee72b054a4
+2010-09-08 Jakub Jelinek <jakub@redhat.com>
+
+ PR fortran/45595
+ * openmp.c (resolve_omp_do): Report not enough do loops for
+ collapse even if block->next is NULL.
+
2010-09-07 Thomas Koenig <tkoenig@gcc.gnu.org>
PR fortran/45576
break;
}
do_code = do_code->next;
- if (do_code->op != EXEC_DO && do_code->op != EXEC_DO_WHILE)
+ if (do_code == NULL
+ || (do_code->op != EXEC_DO && do_code->op != EXEC_DO_WHILE))
{
gfc_error ("not enough DO loops for collapsed !$OMP DO at %L",
&code->loc);
+2010-09-08 Jakub Jelinek <jakub@redhat.com>
+
+ PR fortran/45595
+ * gfortran.dg/gomp/pr45595.f90: New test.
+
2010-09-08 Michael Matz <matz@suse.de>
* c-c++-common/uninit-17.c: Adjust.
--- /dev/null
+! PR fortran/45595
+! { dg-do compile }
+! { dg-options "-fopenmp" }
+
+subroutine foo(l,u)
+ integer :: k,l,u
+ !$omp parallel do shared(l,u) collapse(3) ! { dg-error "not enough DO loops" }
+ do k = l,u
+ end do
+end subroutine