| ! Offloading test with a target region mapping a declare target Fortran array |
| ! writing some values to it and checking the host correctly receives the |
| ! updates made on the device. |
| ! REQUIRES: flang, amdgpu |
| |
| ! RUN: %libomptarget-compile-fortran-run-and-check-generic |
| module test_0 |
| implicit none |
| INTEGER :: arr1(10) = (/0,0,0,0,0,0,0,0,0,0/) |
| INTEGER :: arr2(10) = (/0,0,0,0,0,0,0,0,0,0/) |
| !$omp declare target link(arr1) enter(arr2) |
| INTEGER :: scalar = 1 |
| !$omp declare target link(scalar) |
| end module test_0 |
| |
| subroutine test_with_array_link_and_tofrom() |
| use test_0 |
| integer :: i = 1 |
| integer :: j = 11 |
| !$omp target map(tofrom:arr1, i, j) |
| do while (i <= j) |
| arr1(i) = i; |
| i = i + 1 |
| end do |
| !$omp end target |
| |
| ! CHECK: 1 2 3 4 5 6 7 8 9 10 |
| PRINT *, arr1(:) |
| end subroutine test_with_array_link_and_tofrom |
| |
| subroutine test_with_array_link_only() |
| use test_0 |
| integer :: i = 1 |
| integer :: j = 11 |
| !$omp target map(i, j) |
| do while (i <= j) |
| arr1(i) = i + 1; |
| i = i + 1 |
| end do |
| !$omp end target |
| |
| ! CHECK: 2 3 4 5 6 7 8 9 10 11 |
| PRINT *, arr1(:) |
| end subroutine test_with_array_link_only |
| |
| subroutine test_with_array_enter_only() |
| use test_0 |
| integer :: i = 1 |
| integer :: j = 11 |
| !$omp target map(i, j) |
| do while (i <= j) |
| arr2(i) = i + 1; |
| i = i + 1 |
| end do |
| !$omp end target |
| |
| ! CHECK: 0 0 0 0 0 0 0 0 0 0 |
| PRINT *, arr2(:) |
| end subroutine test_with_array_enter_only |
| |
| subroutine test_with_scalar_link_only() |
| use test_0 |
| !$omp target |
| scalar = 10 |
| !$omp end target |
| |
| ! CHECK: 10 |
| PRINT *, scalar |
| end subroutine test_with_scalar_link_only |
| |
| program main |
| call test_with_array_link_and_tofrom() |
| call test_with_array_link_only() |
| call test_with_array_enter_only() |
| call test_with_scalar_link_only() |
| end program |