1! { dg-additional-options "-fdump-tree-original" }
2
3! test for tree-dump-original and spaces-commas
4
5program test
6  implicit none
7  integer :: q, i, j, k, m, n, o, p, r, s, t, u, v, w
8  logical :: l = .true.
9
10  !$acc parallel if(l) async num_gangs(i) num_workers(i) vector_length(i) &
11  !$acc reduction(max:q), copy(i), copyin(j), copyout(k), create(m) &
12  !$acc no_create(n) &
13  !$acc present(o), pcopy(p), pcopyin(r), pcopyout(s), pcreate(t) &
14  !$acc deviceptr(u), private(v), firstprivate(w)
15  !$acc end parallel
16
17end program test
18
19! { dg-final { scan-tree-dump-times "pragma acc parallel" 1 "original" } }
20
21! { dg-final { scan-tree-dump-times "if" 1 "original" } }
22! { dg-final { scan-tree-dump-times "async" 1 "original" } }
23! { dg-final { scan-tree-dump-times "num_gangs" 1 "original" } }
24! { dg-final { scan-tree-dump-times "num_workers" 1 "original" } }
25! { dg-final { scan-tree-dump-times "vector_length" 1 "original" } }
26
27! { dg-final { scan-tree-dump-times "reduction\\(max:q\\)" 1 "original" } }
28! { dg-final { scan-tree-dump-times "map\\(tofrom:i\\)" 1 "original" } }
29! { dg-final { scan-tree-dump-times "map\\(to:j\\)" 1 "original" } }
30! { dg-final { scan-tree-dump-times "map\\(from:k\\)" 1 "original" } }
31! { dg-final { scan-tree-dump-times "map\\(alloc:m\\)" 1 "original" } }
32! { dg-final { scan-tree-dump-times "map\\(no_alloc:n\\)" 1 "original" } }
33! { dg-final { scan-tree-dump-times "map\\(force_present:o\\)" 1 "original" } }
34! { dg-final { scan-tree-dump-times "map\\(tofrom:p\\)" 1 "original" } }
35! { dg-final { scan-tree-dump-times "map\\(to:r\\)" 1 "original" } }
36! { dg-final { scan-tree-dump-times "map\\(from:s\\)" 1 "original" } }
37! { dg-final { scan-tree-dump-times "map\\(alloc:t\\)" 1 "original" } }
38
39! { dg-final { scan-tree-dump-times "map\\(force_deviceptr:u\\)" 1 "original" } }
40! { dg-final { scan-tree-dump-times "private\\(v\\)" 1 "original" } }
41