From: Tobias Burnus Date: Tue, 8 Oct 2019 12:44:53 +0000 (+0200) Subject: Fortran - fix OpenMP 'target simd' X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=4f4c1ea2d278ee5050b32e0a9d429b060c6eaddb;p=thirdparty%2Fgcc.git Fortran - fix OpenMP 'target simd' Backported from mainline. gcc/fortran/ * parse.c (parse_executable): Add missing ST_OMP_TARGET_SIMD. libgomp/ * testsuite/libgomp.fortran/target-simd.f90: New. (cherry picked from openacc-gcc-9-branch commit 54fbada7d4d38e420efb5a10d39e03b02533b1e7) --- diff --git a/gcc/fortran/ChangeLog.omp b/gcc/fortran/ChangeLog.omp index fe2cf26c1172..4bcd912811be 100644 --- a/gcc/fortran/ChangeLog.omp +++ b/gcc/fortran/ChangeLog.omp @@ -1,3 +1,10 @@ +2019-10-08 Tobias Burnus + + Backported from mainline + 2019-10-08 Tobias Burnus + + * parse.c (parse_executable): Add missing ST_OMP_TARGET_SIMD. + 2019-10-08 Tobias Burnus Backported from mainline diff --git a/gcc/fortran/parse.c b/gcc/fortran/parse.c index 3b50c2174c9d..66df3843b9db 100644 --- a/gcc/fortran/parse.c +++ b/gcc/fortran/parse.c @@ -5447,6 +5447,7 @@ parse_executable (gfc_statement st) case ST_OMP_SIMD: case ST_OMP_TARGET_PARALLEL_DO: case ST_OMP_TARGET_PARALLEL_DO_SIMD: + case ST_OMP_TARGET_SIMD: case ST_OMP_TARGET_TEAMS_DISTRIBUTE: case ST_OMP_TARGET_TEAMS_DISTRIBUTE_PARALLEL_DO: case ST_OMP_TARGET_TEAMS_DISTRIBUTE_PARALLEL_DO_SIMD: diff --git a/gcc/testsuite/ChangeLog.omp b/gcc/testsuite/ChangeLog.omp index bd26e3d91e03..a208c8f56fd5 100644 --- a/gcc/testsuite/ChangeLog.omp +++ b/gcc/testsuite/ChangeLog.omp @@ -1,3 +1,10 @@ +2019-10-08 Tobias Burnus + + Backported from mainline + 2019-10-08 Tobias Burnus + + * testsuite/libgomp.fortran/target-simd.f90: New. + 2019-10-08 Tobias Burnus Backported from mainline diff --git a/gcc/testsuite/gfortran.dg/gomp/target-simd.f90 b/gcc/testsuite/gfortran.dg/gomp/target-simd.f90 new file mode 100644 index 000000000000..733420f4cc7d --- /dev/null +++ b/gcc/testsuite/gfortran.dg/gomp/target-simd.f90 @@ -0,0 +1,26 @@ +! { dg-do compile } + +program test + implicit none + real, allocatable :: a(:), b(:) + integer :: i + + a = [(i, i = 1, 100)] + allocate(b, mold=a) + b = 0 + + !$omp target simd map(to:a) map(from:b) + do i = 0, size(a) + b(i) = 5.0 * a(i) + end do + + if (any (b - 5.0 *a > 10.0*epsilon(a))) call abort() + + !$omp target simd map(to:a) map(from:b) + do i = 0, size(a) + b(i) = 2.0 * a(i) + end do + !$omp end target simd + + if (any (b - 2.0 *a > 10.0*epsilon(a))) call abort() +end program test