! { dg-do run } program main implicit none integer, parameter :: n = 1024 integer, dimension (0:n-1) :: a, b, c integer :: i, ii ! Parallelism dimensions: compiler/runtime decides. !$acc kernels copyout (a(0:n-1)) do i = 0, n - 1 a(i) = i * 2 end do !$acc end kernels ! Parallelism dimensions: variable. !$acc kernels copyout (b(0:n-1)) & !$acc num_gangs (3 + a(3)) num_workers (5 + a(5)) vector_length (7 + a(7)) ! { dg-prune-output "using vector_length \\(32\\), ignoring runtime setting" } do i = 0, n -1 b(i) = i * 4 end do !$acc end kernels ! Parallelism dimensions: literal. !$acc kernels copyin (a(0:n-1), b(0:n-1)) copyout (c(0:n-1)) & !$acc num_gangs (3) num_workers (5) vector_length (7) ! { dg-prune-output "using vector_length \\(32\\), ignoring 7" } do ii = 0, n - 1 c(ii) = a(ii) + b(ii) end do !$acc end kernels do i = 0, n - 1 if (a(i) .ne. i * 2) STOP 1 if (b(i) .ne. i * 4) STOP 2 if (c(i) .ne. a(i) + b(i)) STOP 3 end do end program main