blob: f368762b46d49d1552f1df814c5adeea63a831ec (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
! Offloading test checking interaction of mapping a full common block in a
! target region
! REQUIRES: flang, amdgcn-amd-amdhsa
! UNSUPPORTED: nvptx64-nvidia-cuda
! UNSUPPORTED: nvptx64-nvidia-cuda-LTO
! UNSUPPORTED: aarch64-unknown-linux-gnu
! UNSUPPORTED: aarch64-unknown-linux-gnu-LTO
! UNSUPPORTED: x86_64-unknown-linux-gnu
! UNSUPPORTED: x86_64-unknown-linux-gnu-LTO
! RUN: %libomptarget-compile-fortran-run-and-check-generic
program main
implicit none
common /var_common/ var1, var2
integer :: var1, var2
call modify_1
!$omp target map(tofrom: /var_common/)
var1 = var1 + 20
var2 = var2 + 50
!$omp end target
call modify_2
print *, var1
print *, var2
end program
subroutine modify_1
common /var_common/ var1, var2
integer :: var1, var2
!$omp target map(tofrom: /var_common/)
var1 = var1 + 20
var2 = var2 + 30
!$omp end target
end
subroutine modify_2
common /var_common/ var1, var2
integer :: var1, var2
!$omp target map(tofrom: /var_common/)
var1 = var1 * 10
var2 = var2 * 10
!$omp end target
end
!CHECK: 400
!CHECK: 800
|