1 // RUN: %clang_cc1 -DCK1 -verify -Wno-vla -fopenmp -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -triple powerpc64le-unknown-unknown -emit-llvm %s -o - | FileCheck %s
2 // RUN: %clang_cc1 -DCK1 -fopenmp -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -std=c++11 -triple powerpc64le-unknown-unknown -emit-pch -o %t %s
3 // RUN: %clang_cc1 -fopenmp -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -triple powerpc64le-unknown-unknown -std=c++11 -include-pch %t -verify -Wno-vla %s -emit-llvm -o - | FileCheck %s
5 // RUN: %clang_cc1 -DCK1 -verify -Wno-vla -fopenmp-simd -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -triple powerpc64le-unknown-unknown -emit-llvm %s -o - | FileCheck --check-prefix SIMD-ONLY0 %s
6 // RUN: %clang_cc1 -DCK1 -fopenmp-simd -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -std=c++11 -triple powerpc64le-unknown-unknown -emit-pch -o %t %s
7 // RUN: %clang_cc1 -fopenmp-simd -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -triple powerpc64le-unknown-unknown -std=c++11 -include-pch %t -verify -Wno-vla %s -emit-llvm -o - | FileCheck --check-prefix SIMD-ONLY0 %s
8 // SIMD-ONLY0-NOT: {{__kmpc|__tgt}}
9 // expected-no-diagnostics
14 // CHECK-DAG: [[SIZES1:@.+]] = private unnamed_addr constant [6 x i64] [i64 4, i64 16, i64 4, i64 4, i64 0, i64 4]
15 // 64 = 0x40 = OMP_MAP_RETURN_PARAM
16 // CHECK-DAG: [[MAPTYPES1:@.+]] = private unnamed_addr constant [6 x i64] [i64 67, i64 67, i64 3, i64 67, i64 67, i64 67]
17 // CHECK-DAG: [[SIZES2:@.+]] = private unnamed_addr constant [6 x i64] [i64 0, i64 4, i64 16, i64 4, i64 4, i64 0]
19 // 281474976710720 = 0x1000000000040 = OMP_MAP_MEMBER_OF | OMP_MAP_RETURN_PARAM
20 // CHECK-DAG: [[MAPTYPES2:@.+]] = private unnamed_addr constant [6 x i64] [i64 0, i64 281474976710723, i64 281474976710739, i64 281474976710739, i64 281474976710675, i64 281474976710723]
28 #pragma omp target data map(tofrom: a, ptr [3:4], ref, ptr[0], arr[:a]) use_device_addr(a, ptr [3:4], ref, ptr[0], arr[:a])
29 ++a
, ++*ptr
, ++ref
, ++arr
[0];
41 #pragma omp target data map(tofrom: a, ptr [3:4], ref, ptr[0], arr[:(int)a], vla[0]) use_device_addr(a, ptr [3:4], ref, ptr[0], arr[:(int)a], vla[0])
42 ++a
, ++*ptr
, ++ref
, ++arr
[0], ++vla
[0];
46 // CHECK-LABEL: @main()
47 // CHECK: [[A_ADDR:%.+]] = alloca float,
48 // CHECK: [[PTR_ADDR:%.+]] = alloca ptr,
49 // CHECK: [[REF_ADDR:%.+]] = alloca ptr,
50 // CHECK: [[ARR_ADDR:%.+]] = alloca [4 x float],
51 // CHECK: [[BPTRS:%.+]] = alloca [6 x ptr],
52 // CHECK: [[PTRS:%.+]] = alloca [6 x ptr],
53 // CHECK: [[MAP_PTRS:%.+]] = alloca [6 x ptr],
54 // CHECK: [[SIZES:%.+]] = alloca [6 x i64],
55 // CHECK: [[VLA_ADDR:%.+]] = alloca float, i64 %{{.+}},
56 // CHECK: [[PTR:%.+]] = load ptr, ptr [[PTR_ADDR]],
57 // CHECK-NEXT: [[P4:%.+]] = load ptr, ptr [[PTR_ADDR]], align 8
58 // CHECK-NEXT: [[ARR_IDX:%.+]] = getelementptr inbounds float, ptr [[P4]], i64 3
59 // CHECK: [[P5:%.+]] = load ptr, ptr [[PTR_ADDR]], align 8
60 // CHECK-NEXT: [[P6:%.+]] = load ptr, ptr [[PTR_ADDR]], align 8
61 // CHECK-NEXT: [[ARR_IDX1:%.+]] = getelementptr inbounds float, ptr [[P6]], i64 0
62 // CHECK: [[P7:%.+]] = load ptr, ptr [[REF_ADDR]],
63 // CHECK-NEXT: [[REF:%.+]] = load ptr, ptr [[REF_ADDR]],
64 // CHECK-NEXT: [[ARR_IDX2:%.+]] = getelementptr inbounds [4 x float], ptr [[ARR_ADDR]], i64 0, i64 0
65 // CHECK: [[P10:%.+]] = mul nuw i64 {{.+}}, 4
66 // CHECK-NEXT: [[ARR_IDX5:%.+]] = getelementptr inbounds float, ptr [[VLA_ADDR]], i64 0
67 // CHECK-NEXT: call void @llvm.memcpy.p0.p0.i64(ptr align 8 [[SIZES]], ptr align 8 [[SIZES1]], i64 48, i1 false)
68 // CHECK: [[BPTR0:%.+]] = getelementptr inbounds [6 x ptr], ptr [[BPTRS]], i32 0, i32 0
69 // CHECK: store ptr [[A_ADDR]], ptr [[BPTR0]],
70 // CHECK: [[PTR0:%.+]] = getelementptr inbounds [6 x ptr], ptr [[PTRS]], i32 0, i32 0
71 // CHECK: store ptr [[A_ADDR]], ptr [[PTR0]],
72 // CHECK: [[BPTR1:%.+]] = getelementptr inbounds [6 x ptr], ptr [[BPTRS]], i32 0, i32 1
73 // CHECK: store ptr [[PTR]], ptr [[BPTR1]],
74 // CHECK: [[PTR1:%.+]] = getelementptr inbounds [6 x ptr], ptr [[PTRS]], i32 0, i32 1
75 // CHECK: store ptr [[ARR_IDX]], ptr [[PTR1]],
76 // CHECK: [[BPTR2:%.+]] = getelementptr inbounds [6 x ptr], ptr [[BPTRS]], i32 0, i32 2
77 // CHECK: store ptr [[P5]], ptr [[BPTR2]],
78 // CHECK: [[PTR2:%.+]] = getelementptr inbounds [6 x ptr], ptr [[PTRS]], i32 0, i32 2
79 // CHECK: store ptr [[ARR_IDX1]], ptr [[PTR2]],
80 // CHECK: [[BPTR3:%.+]] = getelementptr inbounds [6 x ptr], ptr [[BPTRS]], i32 0, i32 3
81 // CHECK: store ptr [[P7]], ptr [[BPTR3]],
82 // CHECK: [[PTR3:%.+]] = getelementptr inbounds [6 x ptr], ptr [[PTRS]], i32 0, i32 3
83 // CHECK: store ptr [[REF]], ptr [[PTR3]],
84 // CHECK: [[BPTR4:%.+]] = getelementptr inbounds [6 x ptr], ptr [[BPTRS]], i32 0, i32 4
85 // CHECK: store ptr [[ARR_ADDR]], ptr [[BPTR4]], align
86 // CHECK: [[PTR4:%.+]] = getelementptr inbounds [6 x ptr], ptr [[PTRS]], i32 0, i32 4
87 // CHECK: store ptr [[ARR_IDX2]], ptr [[PTR4]], align 8
88 // CHECK: [[SIZE_PTR:%.+]] = getelementptr inbounds [6 x i64], ptr [[SIZES]], i32 0, i32 4
89 // CHECK: store i64 [[P10:%.+]], ptr [[SIZE_PTR]], align 8
90 // CHECK: [[MAP_PTR:%.+]] = getelementptr inbounds [6 x ptr], ptr [[MAP_PTRS]], i64 0, i64 4
91 // CHECK: store ptr null, ptr [[MAP_PTR]], align 8
92 // CHECK: [[BPTR5:%.+]] = getelementptr inbounds [6 x ptr], ptr [[BPTRS]], i32 0, i32 5
93 // CHECK: store ptr [[VLA_ADDR]], ptr [[BPTR5]],
94 // CHECK: [[PTR5:%.+]] = getelementptr inbounds [6 x ptr], ptr [[PTRS]], i32 0, i32 5
95 // CHECK: store ptr [[ARR_IDX5]], ptr [[PTR5]],
97 // CHECK: [[BPTR:%.+]] = getelementptr inbounds [6 x ptr], ptr [[BPTRS]], i32 0, i32 0
98 // CHECK: [[PTR:%.+]] = getelementptr inbounds [6 x ptr], ptr [[PTRS]], i32 0, i32 0
99 // CHECK: [[SIZE:%.+]] = getelementptr inbounds [6 x i64], ptr [[SIZES]], i32 0, i32 0
100 // CHECK: call void @__tgt_target_data_begin_mapper(ptr @{{.+}}, i64 -1, i32 6, ptr [[BPTR]], ptr [[PTR]], ptr [[SIZE]], ptr [[MAPTYPES1]], ptr null, ptr null)
101 // CHECK: [[A_REF:%.+]] = load ptr, ptr [[BPTR0]],
102 // CHECK: [[REF_REF:%.+]] = load ptr, ptr [[BPTR3]],
103 // CHECK: store ptr [[REF_REF]], ptr [[TMP_REF_ADDR:%.+]],
104 // CHECK: [[ARR_REF:%.+]] = load ptr, ptr [[BPTR4]],
105 // CHECK: [[VLA_REF:%.+]] = load ptr, ptr [[BPTR5]],
106 // CHECK: [[A:%.+]] = load float, ptr [[A_REF]],
107 // CHECK: [[INC:%.+]] = fadd float [[A]], 1.000000e+00
108 // CHECK: store float [[INC]], ptr [[A_REF]],
109 // CHECK: [[PTR:%.+]] = load ptr, ptr [[BPTR1]],
110 // CHECK: [[VAL:%.+]] = load float, ptr [[PTR]],
111 // CHECK: [[INC:%.+]] = fadd float [[VAL]], 1.000000e+00
112 // CHECK: store float [[INC]], ptr [[PTR]],
113 // CHECK: [[REF_ADDR:%.+]] = load ptr, ptr [[TMP_REF_ADDR]],
114 // CHECK: [[REF:%.+]] = load float, ptr [[REF_ADDR]],
115 // CHECK: [[INC:%.+]] = fadd float [[REF]], 1.000000e+00
116 // CHECK: store float [[INC]], ptr [[REF_ADDR]],
117 // CHECK: [[ARR0_ADDR:%.+]] = getelementptr inbounds [4 x float], ptr [[ARR_REF]], i64 0, i64 0
118 // CHECK: [[ARR0:%.+]] = load float, ptr [[ARR0_ADDR]],
119 // CHECK: [[INC:%.+]] = fadd float [[ARR0]], 1.000000e+00
120 // CHECK: store float [[INC]], ptr [[ARR0_ADDR]],
121 // CHECK: [[VLA0_ADDR:%.+]] = getelementptr inbounds float, ptr [[VLA_REF]], i64 0
122 // CHECK: [[VLA0:%.+]] = load float, ptr [[VLA0_ADDR]],
123 // CHECK: [[INC:%.+]] = fadd float [[VLA0]], 1.000000e+00
124 // CHECK: store float [[INC]], ptr [[VLA0_ADDR]],
125 // CHECK: [[BPTR:%.+]] = getelementptr inbounds [6 x ptr], ptr [[BPTRS]], i32 0, i32 0
126 // CHECK: [[PTR:%.+]] = getelementptr inbounds [6 x ptr], ptr [[PTRS]], i32 0, i32 0
127 // CHECK: [[SIZE:%.+]] = getelementptr inbounds [6 x i64], ptr [[SIZES]], i32 0, i32 0
128 // CHECK: call void @__tgt_target_data_end_mapper(ptr @{{.+}}, i64 -1, i32 6, ptr [[BPTR]], ptr [[PTR]], ptr [[SIZE]], ptr [[MAPTYPES1]], ptr null, ptr null)
131 // CHECK: [[BPTRS:%.+]] = alloca [6 x ptr],
132 // CHECK: [[PTRS:%.+]] = alloca [6 x ptr],
133 // CHECK: [[MAP_PTRS:%.+]] = alloca [6 x ptr],
134 // CHECK: [[SIZES:%.+]] = alloca [6 x i64],
135 // CHECK: [[A_ADDR:%.+]] = getelementptr inbounds %struct.S, ptr [[THIS:%.+]], i32 0, i32 0
136 // CHECK: [[PTR_ADDR:%.+]] = getelementptr inbounds %struct.S, ptr [[THIS]], i32 0, i32 1
137 // CHECK: [[ARR_IDX:%.+]] = getelementptr inbounds i32, ptr %{{.+}}, i64 3
138 // CHECK: [[REF_REF:%.+]] = getelementptr inbounds %struct.S, ptr [[THIS]], i32 0, i32 2
139 // CHECK: [[REF_PTR:%.+]] = load ptr, ptr [[REF_REF]],
140 // CHECK-NEXT: [[P3:%.+]] = getelementptr inbounds %struct.S, ptr [[THIS]], i32 0, i32 1
141 // CHECK: [[ARR_IDX5:%.+]] = getelementptr inbounds i32, ptr {{.+}}, i64 0
142 // CHECK: [[ARR_ADDR:%.+]] = getelementptr inbounds %struct.S, ptr [[THIS]], i32 0, i32 3
144 // CHECK: [[ARR_IDX6:%.+]] = getelementptr inbounds [4 x i32], ptr [[ARR_ADDR]], i64 0, i64 0
145 // CHECK: [[A_ADDR2:%.+]] = getelementptr inbounds %struct.S, ptr [[THIS]], i32 0, i32 0
146 // CHECK: [[P4:%.+]] = mul nuw i64 [[CONV:%.+]], 4
147 // CHECK: [[ARR_END:%.+]] = getelementptr i32, ptr [[ARR_IDX6]], i32 1
148 // CHECK: [[E:%.+]] = ptrtoint ptr [[ARR_END]] to i64
149 // CHECK: [[B:%.+]] = ptrtoint ptr [[A_ADDR]] to i64
150 // CHECK: [[DIFF:%.+]] = sub i64 [[E]], [[B]]
151 // CHECK: [[SZ:%.+]] = sdiv exact i64 [[DIFF]], ptrtoint (ptr getelementptr (i8, ptr null, i32 1) to i64)
152 // CHECK: [[BPTR0:%.+]] = getelementptr inbounds [6 x ptr], ptr [[BPTRS]], i32 0, i32 0
153 // CHECK: store ptr [[THIS]], ptr [[BPTR0]],
154 // CHECK: [[PTR0:%.+]] = getelementptr inbounds [6 x ptr], ptr [[PTRS]], i32 0, i32 0
155 // CHECK: store ptr [[A_ADDR]], ptr [[PTR0]],
156 // CHECK: [[SIZE0:%.+]] = getelementptr inbounds [6 x i64], ptr [[SIZES]], i32 0, i32 0
157 // CHECK: store i64 [[SZ]], ptr [[SIZE0]],
158 // CHECK: [[BPTR1:%.+]] = getelementptr inbounds [6 x ptr], ptr [[BPTRS]], i32 0, i32 1
159 // CHECK: store ptr [[THIS]], ptr [[BPTR1]]
160 // CHECK: [[PTR1:%.+]] = getelementptr inbounds [6 x ptr], ptr [[PTRS]], i32 0, i32 1
161 // CHECK: store ptr [[A_ADDR]], ptr [[PTR1]],
162 // CHECK: [[BPTR2:%.+]] = getelementptr inbounds [6 x ptr], ptr [[BPTRS]], i32 0, i32 2
163 // CHECK: store ptr [[PTR_ADDR]], ptr [[BPTR2]],
164 // CHECK: [[PTR2:%.+]] = getelementptr inbounds [6 x ptr], ptr [[PTRS]], i32 0, i32 2
165 // CHECK: store ptr [[ARR_IDX]], ptr [[PTR2]],
166 // CHECK: [[BPTR3:%.+]] = getelementptr inbounds [6 x ptr], ptr [[BPTRS]], i32 0, i32 3
167 // CHECK: store ptr [[THIS]], ptr [[BPTR3]]
168 // CHECK: [[PTR3:%.+]] = getelementptr inbounds [6 x ptr], ptr [[PTRS]], i32 0, i32 3
169 // CHECK: store ptr [[REF_PTR]], ptr [[PTR3]],
170 // CHECK: [[BPTR4:%.+]] = getelementptr inbounds [6 x ptr], ptr [[BPTRS]], i32 0, i32 4
171 // CHECK: store ptr [[P3]], ptr [[BPTR4]],
172 // CHECK: [[PTR4:%.+]] = getelementptr inbounds [6 x ptr], ptr [[PTRS]], i32 0, i32 4
173 // CHECK: store ptr [[ARR_IDX5]], ptr [[PTR4]]
175 // CHECK: [[BPTR5:%.+]] = getelementptr inbounds [6 x ptr], ptr [[BPTRS]], i32 0, i32 5
176 // CHECK: store ptr [[THIS]], ptr [[BPTR5]], align 8
177 // CHECK: [[PTR5:%.+]] = getelementptr inbounds [6 x ptr], ptr [[PTRS]], i32 0, i32 5
178 // CHECK: store ptr [[ARR_IDX6]], ptr [[PTR5]], align 8
179 // CHECK: [[SIZE1:%.+]] = getelementptr inbounds [6 x i64], ptr [[SIZES]], i32 0, i32 5
180 // CHECK: store i64 [[P4]], ptr [[SIZE1]], align 8
181 // CHECK: [[BPTR:%.+]] = getelementptr inbounds [6 x ptr], ptr [[BPTRS]], i32 0, i32 0
182 // CHECK: [[PTR:%.+]] = getelementptr inbounds [6 x ptr], ptr [[PTRS]], i32 0, i32 0
183 // CHECK: [[SIZE:%.+]] = getelementptr inbounds [6 x i64], ptr [[SIZES]], i32 0, i32 0
184 // CHECK: call void @__tgt_target_data_begin_mapper(ptr @{{.+}}, i64 -1, i32 6, ptr [[BPTR]], ptr [[PTR]], ptr [[SIZE]], ptr [[MAPTYPES2]], ptr null, ptr null)
185 // CHECK: [[A_ADDR:%.+]] = load ptr, ptr [[BPTR1]],
186 // CHECK: store ptr [[A_ADDR]], ptr [[A_REF:%.+]],
187 // CHECK: [[PTR_ADDR:%.+]] = load ptr, ptr [[BPTR2]],
188 // CHECK: store ptr [[PTR_ADDR]], ptr [[PTR_REF:%.+]],
189 // CHECK: [[REF_PTR:%.+]] = load ptr, ptr [[BPTR3]],
190 // CHECK: store ptr [[REF_PTR]], ptr [[REF_REF:%.+]],
191 // CHECK: [[PTR_ADDR:%.+]] = load ptr, ptr [[BPTR2]],
192 // CHECK: store ptr [[PTR_ADDR]], ptr [[PTR_REF2:%.+]],
193 // CHECK: [[ARR_ADDR:%.+]] = load ptr, ptr [[BPTR5]],
194 // CHECK: store ptr [[ARR_ADDR]], ptr [[ARR_REF:%.+]],
195 // CHECK: [[A_ADDR:%.+]] = load ptr, ptr [[A_REF]],
196 // CHECK: [[A:%.+]] = load i32, ptr [[A_ADDR]],
197 // CHECK: [[INC:%.+]] = add nsw i32 [[A]], 1
198 // CHECK: store i32 [[INC]], ptr [[A_ADDR]],
199 // CHECK: [[PTR_PTR:%.+]] = load ptr, ptr [[PTR_REF2]],
200 // CHECK: [[PTR:%.+]] = load ptr, ptr [[PTR_PTR]],
201 // CHECK: [[VAL:%.+]] = load i32, ptr [[PTR]],
202 // CHECK: [[INC:%.+]] = add nsw i32 [[VAL]], 1
203 // CHECK: store i32 [[INC]], ptr [[PTR]],
204 // CHECK: [[REF_PTR:%.+]] = load ptr, ptr [[REF_REF]],
205 // CHECK: [[VAL:%.+]] = load i32, ptr [[REF_PTR]],
206 // CHECK: [[INC:%.+]] = add nsw i32 [[VAL]], 1
207 // CHECK: store i32 [[INC]], ptr [[REF_PTR]],
208 // CHECK: [[ARR_ADDR:%.+]] = load ptr, ptr [[ARR_REF]],
209 // CHECK: [[ARR0_ADDR:%.+]] = getelementptr inbounds [4 x i32], ptr [[ARR_ADDR]], i64 0, i64 0
210 // CHECK: [[VAL:%.+]] = load i32, ptr [[ARR0_ADDR]],
211 // CHECK: [[INC:%.+]] = add nsw i32 [[VAL]], 1
212 // CHECK: store i32 [[INC]], ptr [[ARR0_ADDR]],
213 // CHECK: [[BPTR:%.+]] = getelementptr inbounds [6 x ptr], ptr [[BPTRS]], i32 0, i32 0
214 // CHECK: [[PTR:%.+]] = getelementptr inbounds [6 x ptr], ptr [[PTRS]], i32 0, i32 0
215 // CHECK: [[SIZE:%.+]] = getelementptr inbounds [6 x i64], ptr [[SIZES]], i32 0, i32 0
216 // CHECK: call void @__tgt_target_data_end_mapper(ptr @{{.+}}, i64 -1, i32 6, ptr [[BPTR]], ptr [[PTR]], ptr [[SIZE]], ptr [[MAPTYPES2]], ptr null, ptr null)