Rebase.
[official-gcc.git] / gcc / testsuite / gfortran.dg / coarray_atomic_2.f90
blobc66827b63149c1702939f41cfef663b0738300d1
1 ! { dg-do compile }
2 ! { dg-options "-fcoarray=single -std=f2008" }
4 use iso_fortran_env, only: atomic_int_kind, atomic_logical_kind
5 implicit none
7 intrinsic :: atomic_define
8 intrinsic :: atomic_ref
9 intrinsic :: atomic_cas ! { dg-error "not available in the current standard settings but new in TS 29113/TS 18508." }
10 intrinsic :: atomic_add ! { dg-error "not available in the current standard settings but new in TS 29113/TS 18508." }
11 intrinsic :: atomic_and ! { dg-error "not available in the current standard settings but new in TS 29113/TS 18508." }
12 intrinsic :: atomic_or ! { dg-error "not available in the current standard settings but new in TS 29113/TS 18508." }
13 intrinsic :: atomic_xor ! { dg-error "not available in the current standard settings but new in TS 29113/TS 18508." }
14 intrinsic :: atomic_fetch_add ! { dg-error "not available in the current standard settings but new in TS 29113/TS 18508." }
15 intrinsic :: atomic_fetch_and ! { dg-error "not available in the current standard settings but new in TS 29113/TS 18508." }
16 intrinsic :: atomic_fetch_or ! { dg-error "not available in the current standard settings but new in TS 29113/TS 18508." }
17 intrinsic :: atomic_fetch_xor ! { dg-error "not available in the current standard settings but new in TS 29113/TS 18508." }
18 integer(atomic_int_kind) :: caf[*], var
19 logical(atomic_logical_kind) :: caf_log[*], var2
20 integer :: stat
21 integer(1) :: stat2
23 call atomic_define(caf, 5, stat=stat) ! { dg-error "STAT= argument to atomic_define" }
24 call atomic_define(caf_log, .true., stat=stat2) ! { dg-error "must be of kind 4" }
25 call atomic_ref(var, caf[1], stat=stat2) ! { dg-error "must be of kind 4" }
26 call atomic_ref(var2, caf_log[1], stat=stat) ! { dg-error "STAT= argument to atomic_ref" }
27 end