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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
|
! { dg-additional-options "-fdump-tree-original -fdump-tree-gimple" }
subroutine f
implicit none
type t
integer :: i
end type t
integer, target :: scalar
integer, target :: array(5)
integer, pointer :: ptr1, ptr2(:)
integer, allocatable :: alloc1, alloc2(:)
type(t) :: agg1, agg2(2)
scalar = 1
array = [1,2,3,4,5]
ptr1 => scalar
ptr2 => array
alloc1 = 5
alloc2 = [1,2]
agg1%i = 1
agg2(:)%i = [1,2]
! firstprivate + unspecified modifer.
!$omp target defaultmap(firstprivate)
block
scalar = 1;
array(1) = 2;
if (associated(ptr1)) &
agg1%i = 3;
if (associated(ptr2)) &
agg2(1)%i = 3;
if (allocated(alloc1)) &
alloc2(1) = 0
end block
! equivalent: firstprivate + ALL modifer.
!$omp target defaultmap(firstprivate : all)
block
scalar = 1;
array(1) = 2;
if (associated(ptr1)) &
agg1%i = 3;
if (associated(ptr2)) &
agg2(1)%i = 3;
if (allocated(alloc1)) &
alloc2(1) = 0
end block
! tofrom + ALL modifer.
!$omp target defaultmap(tofrom : all)
block
scalar = 1;
array(1) = 2;
if (associated(ptr1)) &
agg1%i = 3;
if (associated(ptr2)) &
agg2(1)%i = 3;
if (allocated(alloc1)) &
alloc2(1) = 0
end block
end subroutine
! { dg-final { scan-tree-dump-times "#pragma omp target defaultmap\\(firstprivate\\)" 1 "original" } }
! { dg-final { scan-tree-dump-times "#pragma omp target defaultmap\\(firstprivate:all\\)" 1 "original" } }
! { dg-final { scan-tree-dump-times "#pragma omp target defaultmap\\(tofrom:all\\)" 1 "original" } }
! { dg-final { scan-tree-dump-times "#pragma omp target.* defaultmap\\(firstprivate\\) firstprivate\\(scalar\\) firstprivate\\(ptr2\\) firstprivate\\(ptr1\\) firstprivate\\(array\\) firstprivate\\(alloc2\\) firstprivate\\(alloc1\\) firstprivate\\(agg2\\) firstprivate\\(agg1\\)" 1 "gimple" } }
! { dg-final { scan-tree-dump-times "#pragma omp target.* defaultmap\\(firstprivate:all\\) firstprivate\\(scalar\\) firstprivate\\(ptr2\\) firstprivate\\(ptr1\\) firstprivate\\(array\\) firstprivate\\(alloc2\\) firstprivate\\(alloc1\\) firstprivate\\(agg2\\) firstprivate\\(agg1\\)" 1 "gimple" } }
! { dg-final { scan-tree-dump-times "#pragma omp target.* defaultmap\\(tofrom:all\\) map\\(tofrom:scalar \\\[len: .\\\] \\\[runtime_implicit\\\]\\) map\\(tofrom:.*ptr2.data \\\[len: .*\\\] \\\[runtime_implicit\\\]\\) map\\(to:ptr2 \\\[pointer set, len: ..\\\]\\) map\\(always_pointer:.*ptr2.data \\\[pointer assign, bias: 0\\\]\\) map\\(tofrom:\\*ptr1 \\\[len: .\\\] \\\[runtime_implicit\\\]\\) map\\(alloc:ptr1 \\\[pointer assign, bias: 0\\\]\\) map\\(tofrom:array \\\[len: ..\\\] \\\[runtime_implicit\\\]\\) map\\(tofrom:.*alloc2.data \\\[len: .*\\\] \\\[runtime_implicit\\\]\\) map\\(to:alloc2 \\\[pointer set, len: ..\\\]\\) map\\(alloc:.*alloc2.data \\\[pointer assign, bias: 0\\\]\\) map\\(tofrom:\\*alloc1 \\\[len: .\\\] \\\[runtime_implicit\\\]\\) map\\(alloc:alloc1 \\\[pointer assign, bias: 0\\\]\\) map\\(tofrom:agg2 \\\[len: .\\\] \\\[runtime_implicit\\\]\\) map\\(tofrom:agg1 \\\[len: .\\\] \\\[runtime_implicit\\\]\\)" 1 "gimple" } }
|