kernels-private-vars-loop-gang-1.f90 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. ! Test of gang-private variables declared on loop directive.
  2. ! { dg-do run }
  3. ! { dg-additional-options "--param=openacc-kernels=decompose" }
  4. ! { dg-additional-options "-fopt-info-omp-all" }
  5. ! { dg-additional-options "-foffload=-fopt-info-omp-all" }
  6. ! { dg-additional-options "--param=openacc-privatization=noisy" }
  7. ! { dg-additional-options "-foffload=--param=openacc-privatization=noisy" }
  8. ! Prune a few: uninteresting:
  9. ! { dg-prune-output {note: variable 'D\.[0-9]+' declared in block isn't candidate for adjusting OpenACC privatization level: not addressable} }
  10. ! It's only with Tcl 8.5 (released in 2007) that "the variable 'varName'
  11. ! passed to 'incr' may be unset, and in that case, it will be set to [...]",
  12. ! so to maintain compatibility with earlier Tcl releases, we manually
  13. ! initialize counter variables:
  14. ! { dg-line l_dummy[variable c_compute 0 c_loop_i 0 c_loop_j 0 c_loop_k 0] }
  15. ! { dg-message "dummy" "" { target iN-VAl-Id } l_dummy } to avoid
  16. ! "WARNING: dg-line var l_dummy defined, but not used".
  17. program main
  18. integer :: x, i, arr(32)
  19. do i = 1, 32
  20. arr(i) = i
  21. end do
  22. !$acc kernels copy(arr)
  23. ! { dg-note {forwarded loop nest in OpenACC 'kernels' region to 'parloops' for analysis} {} { target *-*-* } .+1 }
  24. !$acc loop gang(num:32) private(x) ! { dg-line l_loop_i[incr c_loop_i] }
  25. ! { dg-note {variable 'i' in 'private' clause isn't candidate for adjusting OpenACC privatization level: not addressable} {} { target *-*-* } l_loop_i$c_loop_i }
  26. ! { dg-note {variable 'x' in 'private' clause isn't candidate for adjusting OpenACC privatization level: not addressable} {} { target *-*-* } l_loop_i$c_loop_i }
  27. do i = 1, 32
  28. x = i * 2;
  29. arr(i) = arr(i) + x;
  30. end do
  31. ! { dg-optimized {assigned OpenACC seq loop parallelism} {} { target *-*-* } l_loop_i$c_loop_i }
  32. !$acc end kernels
  33. do i = 1, 32
  34. if (arr(i) .ne. i * 3) stop 1
  35. end do
  36. end program main