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)
+2019-10-08 Tobias Burnus <tobias@codesourcery.com>
+
+ Backported from mainline
+ 2019-10-08 Tobias Burnus <tobias@codesourcery.com>
+
+ * parse.c (parse_executable): Add missing ST_OMP_TARGET_SIMD.
+
2019-10-08 Tobias Burnus <tobias@codesourcery.com>
Backported from mainline
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:
+2019-10-08 Tobias Burnus <tobias@codesourcery.com>
+
+ Backported from mainline
+ 2019-10-08 Tobias Burnus <tobias@codesourcery.com>
+
+ * testsuite/libgomp.fortran/target-simd.f90: New.
+
2019-10-08 Tobias Burnus <tobias@codesourcery.com>
Backported from mainline
--- /dev/null
+! { 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