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