]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
Fortran: Fix coarray shared mem [PR121429]
authorAndre Vehreschild <vehre@gcc.gnu.org>
Sat, 14 Feb 2026 19:37:07 +0000 (11:37 -0800)
committerJerry DeLisle <jvdelisle@gcc.gnu.org>
Thu, 26 Feb 2026 17:18:24 +0000 (09:18 -0800)
PR fortran/121429

libgfortran/ChangeLog:

* caf/shmem.c (_gfortran_caf_deregister): Add a call to
sync_team.

gcc/testsuite/ChangeLog:

* gfortran.dg/coarray/deallocate_sync.f90: New test.

gcc/testsuite/gfortran.dg/coarray/deallocate_sync.f90 [new file with mode: 0644]
libgfortran/caf/shmem.c

diff --git a/gcc/testsuite/gfortran.dg/coarray/deallocate_sync.f90 b/gcc/testsuite/gfortran.dg/coarray/deallocate_sync.f90
new file mode 100644 (file)
index 0000000..8c6f2b7
--- /dev/null
@@ -0,0 +1,26 @@
+! { dg-do run }
+! Test case from pr121429 which failed because the deallocate was not
+! doing an implicit sync all.
+program main
+  implicit none
+  integer, allocatable, codimension[:] :: a(:), b(:)
+  integer :: n, i, left, right
+  integer :: k
+  n = num_images()
+  i = this_image()
+  !   We skip this test for -fcoarray=single
+  if (n .ne. 1) then
+    ! Verify in the testsuite that num_images = 8 as set in caf.exp
+    if (n .ne. 8) error stop "Need at least three images"
+    left = modulo(i+n-2,n)+1
+    right = modulo(i,n)+1
+    do k=1,1000
+       allocate(a(k+5)[*])
+       allocate(b(k)[*])
+       b(:)[right] = right + 1000 * k
+       deallocate (a)  ! This synchronizes automatically
+       if (any(b(:)[left] /= left + 1000 * k)) error stop "Test failed"
+       deallocate (b)
+    end do
+  end if
+end program main
index 9913db6d709a5665f0e8562f6581db2b158e6975..de6a2b2301717c5c35f89026b2d6aae428e83a38 100644 (file)
@@ -465,6 +465,7 @@ _gfortran_caf_deregister (caf_token_t *token, caf_deregister_t type, int *stat,
       free (ca);
       free (TOKEN (*token));
       *token = NULL;
+      sync_team (caf_current_team);
     }
   else
     {