! { dg-do run } ! { dg-skip-if "" { *-*-* } { "*" } { "-DACC_MEM_SHARED=0" } } program update use openacc implicit none integer, parameter :: N = 8 integer, parameter :: NDIV2 = N / 2 real :: a(N), b(N) integer i do i = 1, N a(i) = 3.0 b(i) = 0.0 end do !$acc enter data copyin (a, b) !$acc parallel present (a, b) do i = 1, N b(i) = a(i) end do !$acc end parallel !$acc update host (a, b) do i = 1, N if (a(i) .ne. 3.0) call abort if (b(i) .ne. 3.0) call abort end do if (acc_is_present (a) .neqv. .TRUE.) call abort if (acc_is_present (b) .neqv. .TRUE.) call abort do i = 1, N a(i) = 5.0 b(i) = 1.0 end do !$acc update device (a, b) !$acc parallel present (a, b) do i = 1, N b(i) = a(i) end do !$acc end parallel !$acc update host (a, b) do i = 1, N if (a(i) .ne. 5.0) call abort if (b(i) .ne. 5.0) call abort end do if (acc_is_present (a) .neqv. .TRUE.) call abort if (acc_is_present (b) .neqv. .TRUE.) call abort !$acc parallel present (a, b) do i = 1, N b(i) = a(i) end do !$acc end parallel !$acc update host (a, b) do i = 1, N if (a(i) .ne. 5.0) call abort if (b(i) .ne. 5.0) call abort end do if (acc_is_present (a) .neqv. .TRUE.) call abort if (acc_is_present (b) .neqv. .TRUE.) call abort do i = 1, N a(i) = 6.0 b(i) = 0.0 end do !$acc update device (a, b) do i = 1, N a(i) = 9.0 end do !$acc parallel present (a, b) do i = 1, N b(i) = a(i) end do !$acc end parallel !$acc update host (a, b) do i = 1, N if (a(i) .ne. 6.0) call abort if (b(i) .ne. 6.0) call abort end do if (acc_is_present (a) .neqv. .TRUE.) call abort if (acc_is_present (b) .neqv. .TRUE.) call abort do i = 1, N a(i) = 7.0 b(i) = 2.0 end do !$acc update device (a, b) do i = 1, N a(i) = 9.0 end do !$acc parallel present (a, b) do i = 1, N b(i) = a(i) end do !$acc end parallel !$acc update host (a, b) do i = 1, N if (a(i) .ne. 7.0) call abort if (b(i) .ne. 7.0) call abort end do do i = 1, N a(i) = 9.0 end do !$acc update device (a) !$acc parallel present (a, b) do i = 1, N b(i) = a(i) end do !$acc end parallel !$acc update host (a, b) do i = 1, N if (a(i) .ne. 9.0) call abort if (b(i) .ne. 9.0) call abort end do if (acc_is_present (a) .neqv. .TRUE.) call abort if (acc_is_present (b) .neqv. .TRUE.) call abort do i = 1, N a(i) = 5.0 end do !$acc update device (a) do i = 1, N a(i) = 6.0 end do !$acc update device (a(1:NDIV2)) !$acc parallel present (a, b) do i = 1, N b(i) = a(i) end do !$acc end parallel !$acc update host (a, b) do i = 1, NDIV2 if (a(i) .ne. 6.0) call abort if (b(i) .ne. 6.0) call abort end do do i = NDIV2 + 1, N if (a(i) .ne. 5.0) call abort if (b(i) .ne. 5.0) call abort end do if (acc_is_present (a) .neqv. .TRUE.) call abort if (acc_is_present (b) .neqv. .TRUE.) call abort do i = 1, N a(i) = 0.0 end do !$acc update device (a(1:4)) !$acc parallel present (a) do i = 1, N a(i) = a(i) + 1.0 end do !$acc end parallel !$acc update host (a(5:N)) do i = 1, NDIV2 if (a(i) .ne. 0.0) call abort end do do i = NDIV2 + 1, N if (a(i) .ne. 6.0) call abort end do !$acc update host (a(1:4)) do i = 1, NDIV2 if (a(i) .ne. 1.0) call abort end do do i = NDIV2 + 1, N if (a(i) .ne. 6.0) call abort end do a(3) = 9 a(4) = 9 a(5) = 9 a(6) = 9 !$acc update device (a(3:6)) !$acc parallel present (a(1:N)) do i = 1, N a(i) = a(i) + 1.0 end do !$acc end parallel !$acc update host (a(3:6)) do i = 1, 2 if (a(i) .ne. 1.0) call abort end do do i = 3, 6 if (a(i) .ne. 10.0) call abort end do do i = 7, N if (a(i) .ne. 6.0) call abort end do !$acc exit data delete (a, b) end program