]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
openacc: Fix race condition in Fortran loop collapse tests
authorJulian Brown <julian@codesourcery.com>
Thu, 25 Jun 2020 14:40:53 +0000 (07:40 -0700)
committerJulian Brown <julian@codesourcery.com>
Wed, 15 Jul 2020 17:19:29 +0000 (10:19 -0700)
The gangs participating in a gang-partitioned loop are not all guaranteed
to complete before some given gang continues to execute beyond that loop.
This means that two existing test cases contain a race condition,
because a loop that may be gang-partitioned is followed immediately by
another loop.  The fix is to place the loops in separate parallel regions.

2020-07-15  Julian Brown  <julian@codesourcery.com>

libgomp/
* testsuite/libgomp.oacc-fortran/collapse-1.f90: Fix race condition.
* testsuite/libgomp.oacc-fortran/collapse-2.f90: Likewise.

libgomp/ChangeLog.omp
libgomp/testsuite/libgomp.oacc-fortran/collapse-1.f90
libgomp/testsuite/libgomp.oacc-fortran/collapse-2.f90

index 55ea30fb60a16753211f84a803d8fab8bee216fd..c5df8200935ecdd3cefae361a12518c3e0a72fb1 100644 (file)
@@ -1,3 +1,8 @@
+2020-07-15  Julian Brown  <julian@codesourcery.com>
+
+       * testsuite/libgomp.oacc-fortran/collapse-1.f90: Fix race condition.
+       * testsuite/libgomp.oacc-fortran/collapse-2.f90: Likewise.
+
 2020-07-15  Tobias Burnus  <tobias@codesourcery.com>
 
        Backport from mainline
index 918c5d0d5b1c5b0401e3d11d02748d20fceed2a9..4857752f1b0a3d11b04ecd8cf813d5a385a82c51 100644 (file)
@@ -14,6 +14,9 @@ program collapse1
         end do
       end do
     end do
+  !$acc end parallel
+
+  !$acc parallel
   !$acc loop collapse(2) reduction(.or.:l)
     do i = 1, 3
       do j = 4, 6
index 98b6987750ec89bf6363a4b673f882b507d2e373..0a543909127e6c3097fafc9f9a193f757d96c00c 100644 (file)
@@ -13,6 +13,9 @@ program collapse2
         do 164 k = 5, 7
           a(i, j, k) = i + j + k
 164      end do
+  !$acc end parallel
+
+  !$acc parallel
   !$acc loop collapse(2) reduction(.or.:l)
 firstdo: do i = 1, 3
       do j = 4, 6