1 // RUN: %clang_cc1 -verify -fopenmp -x c++ -triple x86_64-apple-darwin10 -emit-llvm %s -o - | FileCheck %s 2 // RUN: %clang_cc1 -fopenmp -x c++ -std=c++11 -triple x86_64-apple-darwin10 -emit-pch -o %t %s 3 // RUN: %clang_cc1 -fopenmp -x c++ -triple x86_64-apple-darwin10 -std=c++11 -include-pch %t -verify %s -emit-llvm -o - | FileCheck %s 4 // RUN: %clang_cc1 -verify -fopenmp -x c++ -std=c++11 -DLAMBDA -triple x86_64-apple-darwin10 -emit-llvm %s -o - | FileCheck -check-prefix=LAMBDA %s 5 // RUN: %clang_cc1 -verify -fopenmp -x c++ -fblocks -DBLOCKS -triple x86_64-apple-darwin10 -emit-llvm %s -o - | FileCheck -check-prefix=BLOCKS %s 6 // expected-no-diagnostics 7 #ifndef HEADER 8 #define HEADER 9 10 struct SS { 11 int a; 12 int b : 4; 13 int &c; 14 SS(int &d) : a(0), b(0), c(d) { 15 #pragma omp parallel 16 #pragma omp for lastprivate(a, b, c) 17 for (int i = 0; i < 2; ++i) 18 #ifdef LAMBDA 19 [&]() { 20 ++this->a, --b, (this)->c /= 1; 21 #pragma omp parallel 22 #pragma omp for lastprivate(a, b, c) 23 for (int i = 0; i < 2; ++i) 24 ++(this)->a, --b, this->c /= 1; 25 }(); 26 #elif defined(BLOCKS) 27 ^{ 28 ++a; 29 --this->b; 30 (this)->c /= 1; 31 #pragma omp parallel 32 #pragma omp for lastprivate(a, b, c) 33 for (int i = 0; i < 2; ++i) 34 ++(this)->a, --b, this->c /= 1; 35 }(); 36 #else 37 ++this->a, --b, c /= 1; 38 #endif 39 #pragma omp for 40 for (a = 0; a < 2; ++a) 41 #ifdef LAMBDA 42 [&]() { 43 ++this->a, --b, (this)->c /= 1; 44 #pragma omp parallel 45 #pragma omp for lastprivate(b) 46 for (b = 0; b < 2; ++b) 47 ++(this)->a, --b, this->c /= 1; 48 }(); 49 #elif defined(BLOCKS) 50 ^{ 51 ++a; 52 --this->b; 53 (this)->c /= 1; 54 #pragma omp parallel 55 #pragma omp for 56 for (c = 0; c < 2; ++c) 57 ++(this)->a, --b, this->c /= 1; 58 }(); 59 #else 60 ++this->a, --b, c /= 1; 61 #endif 62 } 63 }; 64 65 template <typename T> 66 struct SST { 67 T a; 68 SST() : a(T()) { 69 #pragma omp parallel 70 #pragma omp for lastprivate(a) 71 for (int i = 0; i < 2; ++i) 72 #ifdef LAMBDA 73 [&]() { 74 [&]() { 75 ++this->a; 76 #pragma omp parallel 77 #pragma omp for lastprivate(a) 78 for (int i = 0; i < 2; ++i) 79 ++(this)->a; 80 }(); 81 }(); 82 #elif defined(BLOCKS) 83 ^{ 84 ^{ 85 ++a; 86 #pragma omp parallel 87 #pragma omp for lastprivate(a) 88 for (int i = 0; i < 2; ++i) 89 ++(this)->a; 90 }(); 91 }(); 92 #else 93 ++(this)->a; 94 #endif 95 #pragma omp for 96 for (a = 0; a < 2; ++a) 97 #ifdef LAMBDA 98 [&]() { 99 ++this->a; 100 #pragma omp parallel 101 #pragma omp for 102 for (a = 0; a < 2; ++(this)->a) 103 ++(this)->a; 104 }(); 105 #elif defined(BLOCKS) 106 ^{ 107 ++a; 108 #pragma omp parallel 109 #pragma omp for 110 for (this->a = 0; a < 2; ++a) 111 ++(this)->a; 112 }(); 113 #else 114 ++(this)->a; 115 #endif 116 } 117 }; 118 119 template <class T> 120 struct S { 121 T f; 122 S(T a) : f(a) {} 123 S() : f() {} 124 S<T> &operator=(const S<T> &); 125 operator T() { return T(); } 126 ~S() {} 127 }; 128 129 volatile int g __attribute__((aligned(128)))= 1212; 130 volatile int &g1 = g; 131 float f; 132 char cnt; 133 134 // CHECK: [[SS_TY:%.+]] = type { i{{[0-9]+}}, i8 135 // LAMBDA: [[SS_TY:%.+]] = type { i{{[0-9]+}}, i8 136 // BLOCKS: [[SS_TY:%.+]] = type { i{{[0-9]+}}, i8 137 // CHECK: [[S_FLOAT_TY:%.+]] = type { float } 138 // CHECK: [[S_INT_TY:%.+]] = type { i32 } 139 // CHECK-DAG: [[IMPLICIT_BARRIER_LOC:@.+]] = private unnamed_addr constant %{{.+}} { i32 0, i32 66, i32 0, i32 0, i8* 140 // CHECK-DAG: [[X:@.+]] = global double 0.0 141 // CHECK-DAG: [[F:@.+]] = global float 0.0 142 // CHECK-DAG: [[CNT:@.+]] = global i8 0 143 template <typename T> 144 T tmain() { 145 S<T> test; 146 SST<T> sst; 147 T t_var __attribute__((aligned(128))) = T(); 148 T vec[] __attribute__((aligned(128))) = {1, 2}; 149 S<T> s_arr[] __attribute__((aligned(128))) = {1, 2}; 150 S<T> &var __attribute__((aligned(128))) = test; 151 #pragma omp parallel 152 #pragma omp for lastprivate(t_var, vec, s_arr, var) 153 for (int i = 0; i < 2; ++i) { 154 vec[i] = t_var; 155 s_arr[i] = var; 156 } 157 return T(); 158 } 159 160 namespace A { 161 double x; 162 } 163 namespace B { 164 using A::x; 165 } 166 167 int main() { 168 static int sivar; 169 SS ss(sivar); 170 #ifdef LAMBDA 171 // LAMBDA: [[G:@.+]] = global i{{[0-9]+}} 1212, 172 // LAMBDA: [[SIVAR:@.+]] = internal global i{{[0-9]+}} 0, 173 // LAMBDA-LABEL: @main 174 // LAMBDA: alloca [[SS_TY]], 175 // LAMBDA: alloca [[CAP_TY:%.+]], 176 // LAMBDA: call void [[OUTER_LAMBDA:@.+]]([[CAP_TY]]* 177 [&]() { 178 // LAMBDA: define{{.*}} internal{{.*}} void [[OUTER_LAMBDA]]( 179 // LAMBDA: call void {{.+}} @__kmpc_fork_call({{.+}}, i32 1, {{.+}}* [[OMP_REGION:@.+]] to {{.+}}, i32* %{{.+}}) 180 #pragma omp parallel 181 #pragma omp for lastprivate(g, g1, sivar) 182 for (int i = 0; i < 2; ++i) { 183 // LAMBDA: define {{.+}} @{{.+}}([[SS_TY]]* 184 // LAMBDA: getelementptr inbounds [[SS_TY]], [[SS_TY]]* %{{.+}}, i32 0, i32 0 185 // LAMBDA: store i{{[0-9]+}} 0, i{{[0-9]+}}* % 186 // LAMBDA: getelementptr inbounds [[SS_TY]], [[SS_TY]]* %{{.+}}, i32 0, i32 1 187 // LAMBDA: store i8 188 // LAMBDA: getelementptr inbounds [[SS_TY]], [[SS_TY]]* %{{.+}}, i32 0, i32 2 189 // LAMBDA: call void (%{{.+}}*, i{{[0-9]+}}, void (i{{[0-9]+}}*, i{{[0-9]+}}*, ...)*, ...) @__kmpc_fork_call(%{{.+}}* @{{.+}}, i{{[0-9]+}} 1, void (i{{[0-9]+}}*, i{{[0-9]+}}*, ...)* bitcast (void (i{{[0-9]+}}*, i{{[0-9]+}}*, [[SS_TY]]*)* [[SS_MICROTASK:@.+]] to void 190 // LAMBDA: call void @__kmpc_for_static_init_4( 191 // LAMBDA-NOT: getelementptr inbounds [[SS_TY]], [[SS_TY]]* %{{.+}}, i32 0, i32 0 192 // LAMBDA: call void {{.+}} [[SS_LAMBDA:@[^ ]+]] 193 // LAMBDA: call void @__kmpc_for_static_fini(% 194 // LAMBDA: ret 195 196 // LAMBDA: define internal void [[SS_MICROTASK]](i{{[0-9]+}}* noalias [[GTID_ADDR:%.+]], i{{[0-9]+}}* noalias %{{.+}}, [[SS_TY]]* %{{.+}}) 197 // LAMBDA: getelementptr {{.*}}[[SS_TY]], [[SS_TY]]* %{{.*}}, i32 0, i32 0 198 // LAMBDA-NOT: getelementptr {{.*}}[[SS_TY]], [[SS_TY]]* %{{.*}}, i32 0, i32 1 199 // LAMBDA: getelementptr {{.*}}[[SS_TY]], [[SS_TY]]* %{{.*}}, i32 0, i32 2 200 // LAMBDA: call void @__kmpc_for_static_init_4( 201 // LAMBDA-NOT: getelementptr {{.*}}[[SS_TY]], [[SS_TY]]* 202 // LAMBDA: call{{.*}} void 203 // LAMBDA: call void @__kmpc_for_static_fini( 204 // LAMBDA: br i1 205 // LAMBDA: [[B_REF:%.+]] = getelementptr {{.*}}[[SS_TY]], [[SS_TY]]* %{{.*}}, i32 0, i32 1 206 // LAMBDA: store i8 %{{.+}}, i8* [[B_REF]], 207 // LAMBDA: br label 208 // LAMBDA: ret void 209 210 // LAMBDA: define internal void @{{.+}}(i{{[0-9]+}}* noalias [[GTID_ADDR:%.+]], i{{[0-9]+}}* noalias %{{.+}}, [[SS_TY]]* %{{.+}}, i32* {{.+}}, i32* {{.+}}, i32* {{.+}}) 211 // LAMBDA: alloca i{{[0-9]+}}, 212 // LAMBDA: alloca i{{[0-9]+}}, 213 // LAMBDA: alloca i{{[0-9]+}}, 214 // LAMBDA: alloca i{{[0-9]+}}, 215 // LAMBDA: alloca i{{[0-9]+}}, 216 // LAMBDA: [[A_PRIV:%.+]] = alloca i{{[0-9]+}}, 217 // LAMBDA: [[B_PRIV:%.+]] = alloca i{{[0-9]+}}, 218 // LAMBDA: [[C_PRIV:%.+]] = alloca i{{[0-9]+}}, 219 // LAMBDA: store i{{[0-9]+}}* [[A_PRIV]], i{{[0-9]+}}** [[REFA:%.+]], 220 // LAMBDA: store i{{[0-9]+}}* [[C_PRIV]], i{{[0-9]+}}** [[REFC:%.+]], 221 // LAMBDA: call void @__kmpc_for_static_init_4( 222 // LAMBDA: [[A_PRIV:%.+]] = load i{{[0-9]+}}*, i{{[0-9]+}}** [[REFA]], 223 // LAMBDA-NEXT: [[A_VAL:%.+]] = load i{{[0-9]+}}, i{{[0-9]+}}* [[A_PRIV]], 224 // LAMBDA-NEXT: [[INC:%.+]] = add nsw i{{[0-9]+}} [[A_VAL]], 1 225 // LAMBDA-NEXT: store i{{[0-9]+}} [[INC]], i{{[0-9]+}}* [[A_PRIV]], 226 // LAMBDA-NEXT: [[B_VAL:%.+]] = load i{{[0-9]+}}, i{{[0-9]+}}* [[B_PRIV]], 227 // LAMBDA-NEXT: [[DEC:%.+]] = add nsw i{{[0-9]+}} [[B_VAL]], -1 228 // LAMBDA-NEXT: store i{{[0-9]+}} [[DEC]], i{{[0-9]+}}* [[B_PRIV]], 229 // LAMBDA-NEXT: [[C_PRIV:%.+]] = load i{{[0-9]+}}*, i{{[0-9]+}}** [[REFC]], 230 // LAMBDA-NEXT: [[C_VAL:%.+]] = load i{{[0-9]+}}, i{{[0-9]+}}* [[C_PRIV]], 231 // LAMBDA-NEXT: [[DIV:%.+]] = sdiv i{{[0-9]+}} [[C_VAL]], 1 232 // LAMBDA-NEXT: store i{{[0-9]+}} [[DIV]], i{{[0-9]+}}* [[C_PRIV]], 233 // LAMBDA: call void @__kmpc_for_static_fini( 234 // LAMBDA: br i1 235 // LAMBDA: br label 236 // LAMBDA: ret void 237 238 // LAMBDA: define{{.*}} internal{{.*}} void [[OMP_REGION]](i32* noalias %{{.+}}, i32* noalias %{{.+}}, i32* dereferenceable(4) [[SIVAR:%.+]]) 239 // LAMBDA: alloca i{{[0-9]+}}, 240 // LAMBDA: alloca i{{[0-9]+}}, 241 // LAMBDA: alloca i{{[0-9]+}}, 242 // LAMBDA: alloca i{{[0-9]+}}, 243 // LAMBDA: alloca i{{[0-9]+}}, 244 // LAMBDA: [[G_PRIVATE_ADDR:%.+]] = alloca i{{[0-9]+}}, align 128 245 // LAMBDA: [[G1_PRIVATE_ADDR:%.+]] = alloca i{{[0-9]+}}, 246 // LAMBDA: [[SIVAR_PRIVATE_ADDR:%.+]] = alloca i{{[0-9]+}}, 247 // LAMBDA: [[SIVAR_PRIVATE_ADDR_REF:%.+]] = load i{{[0-9]+}}*, i{{[0-9]+}}** %{{.+}}, 248 249 // LAMBDA: [[GTID_REF:%.+]] = load i{{[0-9]+}}*, i{{[0-9]+}}** %{{.+}} 250 // LAMBDA: [[GTID:%.+]] = load i{{[0-9]+}}, i{{[0-9]+}}* [[GTID_REF]] 251 252 // LAMBDA: call {{.+}} @__kmpc_for_static_init_4(%{{.+}}* @{{.+}}, i32 [[GTID]], i32 34, i32* [[IS_LAST_ADDR:%.+]], i32* %{{.+}}, i32* %{{.+}}, i32* %{{.+}}, i32 1, i32 1) 253 // LAMBDA: store i{{[0-9]+}} 1, i{{[0-9]+}}* [[G_PRIVATE_ADDR]], 254 // LAMBDA: store i{{[0-9]+}} 2, i{{[0-9]+}}* [[SIVAR_PRIVATE_ADDR]], 255 // LAMBDA: [[G_PRIVATE_ADDR_REF:%.+]] = getelementptr inbounds %{{.+}}, %{{.+}}* [[ARG:%.+]], i{{[0-9]+}} 0, i{{[0-9]+}} 0 256 // LAMBDA: store i{{[0-9]+}}* [[G_PRIVATE_ADDR]], i{{[0-9]+}}** [[G_PRIVATE_ADDR_REF]] 257 // LAMBDA: [[SIVAR_PRIVATE_ADDR_REF:%.+]] = getelementptr inbounds %{{.+}}, %{{.+}}* [[ARG:%.+]], i{{[0-9]+}} 0, i{{[0-9]+}} 1 258 // LAMBDA: store i{{[0-9]+}}* [[SIVAR_PRIVATE_ADDR]], i{{[0-9]+}}** [[SIVAR_PRIVATE_ADDR_REF]] 259 // LAMBDA: call void [[INNER_LAMBDA:@.+]](%{{.+}}* [[ARG]]) 260 // LAMBDA: call void @__kmpc_for_static_fini(%{{.+}}* @{{.+}}, i32 [[GTID]]) 261 g = 1; 262 g1 = 1; 263 sivar = 2; 264 // Check for final copying of private values back to original vars. 265 // LAMBDA: [[IS_LAST_VAL:%.+]] = load i32, i32* [[IS_LAST_ADDR]], 266 // LAMBDA: [[IS_LAST_ITER:%.+]] = icmp ne i32 [[IS_LAST_VAL]], 0 267 // LAMBDA: br i1 [[IS_LAST_ITER:%.+]], label %[[LAST_THEN:.+]], label %[[LAST_DONE:.+]] 268 // LAMBDA: [[LAST_THEN]] 269 // Actual copying. 270 271 // original g=private_g; 272 // LAMBDA: [[G_VAL:%.+]] = load i{{[0-9]+}}, i{{[0-9]+}}* [[G_PRIVATE_ADDR]], 273 // LAMBDA: store volatile i{{[0-9]+}} [[G_VAL]], i{{[0-9]+}}* [[G]], 274 275 // original sivar=private_sivar; 276 // LAMBDA: [[SIVAR_VAL:%.+]] = load i{{[0-9]+}}, i{{[0-9]+}}* [[SIVAR_PRIVATE_ADDR]], 277 // LAMBDA: store i{{[0-9]+}} [[SIVAR_VAL]], i{{[0-9]+}}* %{{.+}}, 278 // LAMBDA: br label %[[LAST_DONE]] 279 // LAMBDA: [[LAST_DONE]] 280 // LAMBDA: call void @__kmpc_barrier(%{{.+}}* @{{.+}}, i{{[0-9]+}} [[GTID]]) 281 [&]() { 282 // LAMBDA: define {{.+}} void [[INNER_LAMBDA]](%{{.+}}* [[ARG_PTR:%.+]]) 283 // LAMBDA: store %{{.+}}* [[ARG_PTR]], %{{.+}}** [[ARG_PTR_REF:%.+]], 284 g = 2; 285 g1 = 2; 286 sivar = 4; 287 // LAMBDA: [[ARG_PTR:%.+]] = load %{{.+}}*, %{{.+}}** [[ARG_PTR_REF]] 288 // LAMBDA: [[G_PTR_REF:%.+]] = getelementptr inbounds %{{.+}}, %{{.+}}* [[ARG_PTR]], i{{[0-9]+}} 0, i{{[0-9]+}} 0 289 // LAMBDA: [[G_REF:%.+]] = load i{{[0-9]+}}*, i{{[0-9]+}}** [[G_PTR_REF]] 290 // LAMBDA: store i{{[0-9]+}} 2, i{{[0-9]+}}* [[G_REF]] 291 // LAMBDA: [[SIVAR_PTR_REF:%.+]] = getelementptr inbounds %{{.+}}, %{{.+}}* [[ARG_PTR]], i{{[0-9]+}} 0, i{{[0-9]+}} 1 292 // LAMBDA: [[SIVAR_REF:%.+]] = load i{{[0-9]+}}*, i{{[0-9]+}}** [[SIVAR_PTR_REF]] 293 // LAMBDA: store i{{[0-9]+}} 4, i{{[0-9]+}}* [[SIVAR_REF]] 294 }(); 295 } 296 }(); 297 return 0; 298 #elif defined(BLOCKS) 299 // BLOCKS: [[G:@.+]] = global i{{[0-9]+}} 1212, 300 // BLOCKS-LABEL: @main 301 // BLOCKS: call 302 // BLOCKS: call void {{%.+}}(i8 303 ^{ 304 // BLOCKS: define{{.*}} internal{{.*}} void {{.+}}(i8* 305 // BLOCKS: call void {{.+}} @__kmpc_fork_call({{.+}}, i32 1, {{.+}}* [[OMP_REGION:@.+]] to {{.+}}) 306 #pragma omp parallel 307 #pragma omp for lastprivate(g, g1, sivar) 308 for (int i = 0; i < 2; ++i) { 309 // BLOCKS: define{{.*}} internal{{.*}} void [[OMP_REGION]](i32* noalias %{{.+}}, i32* noalias %{{.+}}, i32* dereferenceable(4) [[SIVAR:%.+]]) 310 // BLOCKS: alloca i{{[0-9]+}}, 311 // BLOCKS: alloca i{{[0-9]+}}, 312 // BLOCKS: alloca i{{[0-9]+}}, 313 // BLOCKS: alloca i{{[0-9]+}}, 314 // BLOCKS: alloca i{{[0-9]+}}, 315 // BLOCKS: [[G_PRIVATE_ADDR:%.+]] = alloca i{{[0-9]+}}, align 128 316 // BLOCKS: [[G1_PRIVATE_ADDR:%.+]] = alloca i{{[0-9]+}}, align 4 317 // BLOCKS: [[SIVAR_PRIVATE_ADDR:%.+]] = alloca i{{[0-9]+}}, 318 // BLOCKS: store i{{[0-9]+}}* [[SIVAR]], i{{[0-9]+}}** [[SIVAR_ADDR:%.+]], 319 // BLOCKS: {{.+}} = load i{{[0-9]+}}*, i{{[0-9]+}}** [[SIVAR_ADDR]] 320 // BLOCKS: [[GTID_REF:%.+]] = load i{{[0-9]+}}*, i{{[0-9]+}}** %{{.+}} 321 // BLOCKS: [[GTID:%.+]] = load i{{[0-9]+}}, i{{[0-9]+}}* [[GTID_REF]] 322 // BLOCKS: call {{.+}} @__kmpc_for_static_init_4(%{{.+}}* @{{.+}}, i32 [[GTID]], i32 34, i32* [[IS_LAST_ADDR:%.+]], i32* %{{.+}}, i32* %{{.+}}, i32* %{{.+}}, i32 1, i32 1) 323 // BLOCKS: store i{{[0-9]+}} 1, i{{[0-9]+}}* [[G_PRIVATE_ADDR]], 324 // BLOCKS-NOT: [[G]]{{[[^:word:]]}} 325 // BLOCKS: i{{[0-9]+}}* [[G_PRIVATE_ADDR]] 326 // BLOCKS-NOT: [[G]]{{[[^:word:]]}} 327 // BLOCKS: call void {{%.+}}(i8 328 // BLOCKS: call void @__kmpc_for_static_fini(%{{.+}}* @{{.+}}, i32 [[GTID]]) 329 g = 1; 330 g1 = 1; 331 sivar = 2; 332 // Check for final copying of private values back to original vars. 333 // BLOCKS: [[IS_LAST_VAL:%.+]] = load i32, i32* [[IS_LAST_ADDR]], 334 // BLOCKS: [[IS_LAST_ITER:%.+]] = icmp ne i32 [[IS_LAST_VAL]], 0 335 // BLOCKS: br i1 [[IS_LAST_ITER:%.+]], label %[[LAST_THEN:.+]], label %[[LAST_DONE:.+]] 336 // BLOCKS: [[LAST_THEN]] 337 // Actual copying. 338 339 // original g=private_g; 340 // BLOCKS: [[G_VAL:%.+]] = load i{{[0-9]+}}, i{{[0-9]+}}* [[G_PRIVATE_ADDR]], 341 // BLOCKS: store volatile i{{[0-9]+}} [[G_VAL]], i{{[0-9]+}}* [[G]], 342 // BLOCKS: [[SIVAR_VAL:%.+]] = load i{{[0-9]+}}, i{{[0-9]+}}* [[SIVAR_PRIVATE_ADDR]], 343 // BLOCKS: store i{{[0-9]+}} [[SIVAR_VAL]], i{{[0-9]+}}* %{{.+}}, 344 // BLOCKS: br label %[[LAST_DONE]] 345 // BLOCKS: [[LAST_DONE]] 346 // BLOCKS: call void @__kmpc_barrier(%{{.+}}* @{{.+}}, i{{[0-9]+}} [[GTID]]) 347 g = 1; 348 g1 = 1; 349 ^{ 350 // BLOCKS: define {{.+}} void {{@.+}}(i8* 351 g = 2; 352 g1 = 1; 353 sivar = 4; 354 // BLOCKS-NOT: [[G]]{{[[^:word:]]}} 355 // BLOCKS: store i{{[0-9]+}} 2, i{{[0-9]+}}* 356 // BLOCKS-NOT: [[G]]{{[[^:word:]]}} 357 // BLOCKS-NOT: [[SIVAR]]{{[[^:word:]]}} 358 // BLOCKS: store i{{[0-9]+}} 4, i{{[0-9]+}}* 359 // BLOCKS-NOT: [[SIVAR]]{{[[^:word:]]}} 360 // BLOCKS: ret 361 }(); 362 } 363 }(); 364 return 0; 365 // BLOCKS: define {{.+}} @{{.+}}([[SS_TY]]* 366 // BLOCKS: getelementptr inbounds [[SS_TY]], [[SS_TY]]* %{{.+}}, i32 0, i32 0 367 // BLOCKS: store i{{[0-9]+}} 0, i{{[0-9]+}}* % 368 // BLOCKS: getelementptr inbounds [[SS_TY]], [[SS_TY]]* %{{.+}}, i32 0, i32 1 369 // BLOCKS: store i8 370 // BLOCKS: getelementptr inbounds [[SS_TY]], [[SS_TY]]* %{{.+}}, i32 0, i32 2 371 // BLOCKS: call void (%{{.+}}*, i{{[0-9]+}}, void (i{{[0-9]+}}*, i{{[0-9]+}}*, ...)*, ...) @__kmpc_fork_call(%{{.+}}* @{{.+}}, i{{[0-9]+}} 1, void (i{{[0-9]+}}*, i{{[0-9]+}}*, ...)* bitcast (void (i{{[0-9]+}}*, i{{[0-9]+}}*, [[SS_TY]]*)* [[SS_MICROTASK:@.+]] to void 372 // BLOCKS: call void @__kmpc_for_static_init_4( 373 // BLOCKS-NOT: getelementptr inbounds [[SS_TY]], [[SS_TY]]* %{{.+}}, i32 0, i32 0 374 // BLOCKS: call void 375 // BLOCKS: call void @__kmpc_for_static_fini(% 376 // BLOCKS: ret 377 378 // BLOCKS: define internal void [[SS_MICROTASK]](i{{[0-9]+}}* noalias [[GTID_ADDR:%.+]], i{{[0-9]+}}* noalias %{{.+}}, [[SS_TY]]* %{{.+}}) 379 // BLOCKS: getelementptr {{.*}}[[SS_TY]], [[SS_TY]]* %{{.*}}, i32 0, i32 0 380 // BLOCKS-NOT: getelementptr {{.*}}[[SS_TY]], [[SS_TY]]* %{{.*}}, i32 0, i32 1 381 // BLOCKS: getelementptr {{.*}}[[SS_TY]], [[SS_TY]]* %{{.*}}, i32 0, i32 2 382 // BLOCKS: call void @__kmpc_for_static_init_4( 383 // BLOCKS-NOT: getelementptr {{.*}}[[SS_TY]], [[SS_TY]]* 384 // BLOCKS: call{{.*}} void 385 // BLOCKS: call void @__kmpc_for_static_fini( 386 // BLOCKS: br i1 387 // BLOCKS: [[B_REF:%.+]] = getelementptr {{.*}}[[SS_TY]], [[SS_TY]]* %{{.*}}, i32 0, i32 1 388 // BLOCKS: store i8 %{{.+}}, i8* [[B_REF]], 389 // BLOCKS: br label 390 // BLOCKS: ret void 391 392 // BLOCKS: define internal void @{{.+}}(i{{[0-9]+}}* noalias [[GTID_ADDR:%.+]], i{{[0-9]+}}* noalias %{{.+}}, [[SS_TY]]* %{{.+}}, i32* {{.+}}, i32* {{.+}}, i32* {{.+}}) 393 // BLOCKS: alloca i{{[0-9]+}}, 394 // BLOCKS: alloca i{{[0-9]+}}, 395 // BLOCKS: alloca i{{[0-9]+}}, 396 // BLOCKS: alloca i{{[0-9]+}}, 397 // BLOCKS: alloca i{{[0-9]+}}, 398 // BLOCKS: [[A_PRIV:%.+]] = alloca i{{[0-9]+}}, 399 // BLOCKS: [[B_PRIV:%.+]] = alloca i{{[0-9]+}}, 400 // BLOCKS: [[C_PRIV:%.+]] = alloca i{{[0-9]+}}, 401 // BLOCKS: store i{{[0-9]+}}* [[A_PRIV]], i{{[0-9]+}}** [[REFA:%.+]], 402 // BLOCKS: store i{{[0-9]+}}* [[C_PRIV]], i{{[0-9]+}}** [[REFC:%.+]], 403 // BLOCKS: call void @__kmpc_for_static_init_4( 404 // BLOCKS: [[A_PRIV:%.+]] = load i{{[0-9]+}}*, i{{[0-9]+}}** [[REFA]], 405 // BLOCKS-NEXT: [[A_VAL:%.+]] = load i{{[0-9]+}}, i{{[0-9]+}}* [[A_PRIV]], 406 // BLOCKS-NEXT: [[INC:%.+]] = add nsw i{{[0-9]+}} [[A_VAL]], 1 407 // BLOCKS-NEXT: store i{{[0-9]+}} [[INC]], i{{[0-9]+}}* [[A_PRIV]], 408 // BLOCKS-NEXT: [[B_VAL:%.+]] = load i{{[0-9]+}}, i{{[0-9]+}}* [[B_PRIV]], 409 // BLOCKS-NEXT: [[DEC:%.+]] = add nsw i{{[0-9]+}} [[B_VAL]], -1 410 // BLOCKS-NEXT: store i{{[0-9]+}} [[DEC]], i{{[0-9]+}}* [[B_PRIV]], 411 // BLOCKS-NEXT: [[C_PRIV:%.+]] = load i{{[0-9]+}}*, i{{[0-9]+}}** [[REFC]], 412 // BLOCKS-NEXT: [[C_VAL:%.+]] = load i{{[0-9]+}}, i{{[0-9]+}}* [[C_PRIV]], 413 // BLOCKS-NEXT: [[DIV:%.+]] = sdiv i{{[0-9]+}} [[C_VAL]], 1 414 // BLOCKS-NEXT: store i{{[0-9]+}} [[DIV]], i{{[0-9]+}}* [[C_PRIV]], 415 // BLOCKS: call void @__kmpc_for_static_fini( 416 // BLOCKS: br i1 417 // BLOCKS: br label 418 // BLOCKS: ret void 419 #else 420 S<float> test; 421 int t_var = 0; 422 int vec[] = {1, 2}; 423 S<float> s_arr[] = {1, 2}; 424 S<float> var(3); 425 #pragma omp parallel 426 #pragma omp for lastprivate(t_var, vec, s_arr, var, sivar) 427 for (int i = 0; i < 2; ++i) { 428 vec[i] = t_var; 429 s_arr[i] = var; 430 sivar += i; 431 } 432 #pragma omp parallel 433 #pragma omp for lastprivate(A::x, B::x) firstprivate(f) lastprivate(f) 434 for (int i = 0; i < 2; ++i) { 435 A::x++; 436 } 437 #pragma omp parallel 438 #pragma omp for firstprivate(f) lastprivate(f) 439 for (int i = 0; i < 2; ++i) { 440 A::x++; 441 } 442 #pragma omp parallel 443 #pragma omp for lastprivate(cnt) 444 for (cnt = 0; cnt < 2; ++cnt) { 445 A::x++; 446 } 447 return tmain<int>(); 448 #endif 449 } 450 451 // CHECK: define i{{[0-9]+}} @main() 452 // CHECK: [[TEST:%.+]] = alloca [[S_FLOAT_TY]], 453 // CHECK: call {{.*}} [[S_FLOAT_TY_DEF_CONSTR:@.+]]([[S_FLOAT_TY]]* [[TEST]]) 454 // CHECK: call void (%{{.+}}*, i{{[0-9]+}}, void (i{{[0-9]+}}*, i{{[0-9]+}}*, ...)*, ...) @__kmpc_fork_call(%{{.+}}* @{{.+}}, i{{[0-9]+}} 5, void (i{{[0-9]+}}*, i{{[0-9]+}}*, ...)* bitcast (void (i{{[0-9]+}}*, i{{[0-9]+}}*, i32*, [2 x i32]*, [2 x [[S_FLOAT_TY]]]*, [[S_FLOAT_TY]]*, i32*)* [[MAIN_MICROTASK:@.+]] to void 455 // CHECK: call void (%{{.+}}*, i{{[0-9]+}}, void (i{{[0-9]+}}*, i{{[0-9]+}}*, ...)*, ...) @__kmpc_fork_call(%{{.+}}* @{{.+}}, i{{[0-9]+}} 0, void (i{{[0-9]+}}*, i{{[0-9]+}}*, ...)* bitcast (void (i{{[0-9]+}}*, i{{[0-9]+}}*)* [[MAIN_MICROTASK1:@.+]] to void 456 // CHECK: call void (%{{.+}}*, i{{[0-9]+}}, void (i{{[0-9]+}}*, i{{[0-9]+}}*, ...)*, ...) @__kmpc_fork_call(%{{.+}}* @{{.+}}, i{{[0-9]+}} 0, void (i{{[0-9]+}}*, i{{[0-9]+}}*, ...)* bitcast (void (i{{[0-9]+}}*, i{{[0-9]+}}*)* [[MAIN_MICROTASK2:@.+]] to void 457 // CHECK: call void (%{{.+}}*, i{{[0-9]+}}, void (i{{[0-9]+}}*, i{{[0-9]+}}*, ...)*, ...) @__kmpc_fork_call(%{{.+}}* @{{.+}}, i{{[0-9]+}} 0, void (i{{[0-9]+}}*, i{{[0-9]+}}*, ...)* bitcast (void (i{{[0-9]+}}*, i{{[0-9]+}}*)* [[MAIN_MICROTASK3:@.+]] to void 458 // CHECK: = call {{.+}} [[TMAIN_INT:@.+]]() 459 // CHECK: call void [[S_FLOAT_TY_DESTR:@.+]]([[S_FLOAT_TY]]* 460 // CHECK: ret 461 462 // CHECK: define internal void [[MAIN_MICROTASK]](i32* noalias [[GTID_ADDR:%.+]], i32* noalias %{{.+}}, i32* dereferenceable(4) %{{.+}}, [2 x i32]* dereferenceable(8) %{{.+}}, [2 x [[S_FLOAT_TY]]]* dereferenceable(8) %{{.+}}, [[S_FLOAT_TY]]* dereferenceable(4) %{{.+}}) 463 // CHECK: alloca i{{[0-9]+}}, 464 // CHECK: alloca i{{[0-9]+}}, 465 // CHECK: alloca i{{[0-9]+}}, 466 // CHECK: alloca i{{[0-9]+}}, 467 // CHECK: alloca i{{[0-9]+}}, 468 // CHECK: [[T_VAR_PRIV:%.+]] = alloca i{{[0-9]+}}, 469 // CHECK: [[VEC_PRIV:%.+]] = alloca [2 x i{{[0-9]+}}], 470 // CHECK: [[S_ARR_PRIV:%.+]] = alloca [2 x [[S_FLOAT_TY]]], 471 // CHECK: [[VAR_PRIV:%.+]] = alloca [[S_FLOAT_TY]], 472 // CHECK: [[SIVAR_PRIV:%.+]] = alloca i{{[0-9]+}}, 473 // CHECK: store i{{[0-9]+}}* [[GTID_ADDR]], i{{[0-9]+}}** [[GTID_ADDR_REF:%.+]] 474 475 // CHECK: [[T_VAR_REF:%.+]] = load i{{[0-9]+}}*, i{{[0-9]+}}** % 476 // CHECK: [[VEC_REF:%.+]] = load [2 x i32]*, [2 x i32]** % 477 // CHECK: [[S_ARR_REF:%.+]] = load [2 x [[S_FLOAT_TY]]]*, [2 x [[S_FLOAT_TY]]]** % 478 // CHECK: [[VAR_REF:%.+]] = load [[S_FLOAT_TY]]*, [[S_FLOAT_TY]]** % 479 480 // Check for default initialization. 481 // CHECK-NOT: [[T_VAR_PRIV]] 482 // CHECK-NOT: [[VEC_PRIV]] 483 // CHECK: [[S_ARR_PRIV_ITEM:%.+]] = phi [[S_FLOAT_TY]]* 484 // CHECK: call {{.*}} [[S_FLOAT_TY_DEF_CONSTR]]([[S_FLOAT_TY]]* [[S_ARR_PRIV_ITEM]]) 485 // CHECK: call {{.*}} [[S_FLOAT_TY_DEF_CONSTR]]([[S_FLOAT_TY]]* [[VAR_PRIV]]) 486 // CHECK: call {{.+}} @__kmpc_for_static_init_4(%{{.+}}* @{{.+}}, i32 %{{.+}}, i32 34, i32* [[IS_LAST_ADDR:%.+]], i32* %{{.+}}, i32* %{{.+}}, i32* %{{.+}}, i32 1, i32 1) 487 // <Skip loop body> 488 // CHECK: call void @__kmpc_for_static_fini(%{{.+}}* @{{.+}}, i32 %{{.+}}) 489 490 // Check for final copying of private values back to original vars. 491 // CHECK: [[IS_LAST_VAL:%.+]] = load i32, i32* [[IS_LAST_ADDR]], 492 // CHECK: [[IS_LAST_ITER:%.+]] = icmp ne i32 [[IS_LAST_VAL]], 0 493 // CHECK: br i1 [[IS_LAST_ITER:%.+]], label %[[LAST_THEN:.+]], label %[[LAST_DONE:.+]] 494 // CHECK: [[LAST_THEN]] 495 // Actual copying. 496 497 // original t_var=private_t_var; 498 // CHECK: [[T_VAR_VAL:%.+]] = load i{{[0-9]+}}, i{{[0-9]+}}* [[T_VAR_PRIV]], 499 // CHECK: store i{{[0-9]+}} [[T_VAR_VAL]], i{{[0-9]+}}* [[T_VAR_REF]], 500 501 // original vec[]=private_vec[]; 502 // CHECK: [[VEC_DEST:%.+]] = bitcast [2 x i{{[0-9]+}}]* [[VEC_REF]] to i8* 503 // CHECK: [[VEC_SRC:%.+]] = bitcast [2 x i{{[0-9]+}}]* [[VEC_PRIV]] to i8* 504 // CHECK: call void @llvm.memcpy.{{.+}}(i8* [[VEC_DEST]], i8* [[VEC_SRC]], 505 506 // original s_arr[]=private_s_arr[]; 507 // CHECK: [[S_ARR_BEGIN:%.+]] = getelementptr inbounds [2 x [[S_FLOAT_TY]]], [2 x [[S_FLOAT_TY]]]* [[S_ARR_REF]], i{{[0-9]+}} 0, i{{[0-9]+}} 0 508 // CHECK: [[S_ARR_PRIV_BEGIN:%.+]] = bitcast [2 x [[S_FLOAT_TY]]]* [[S_ARR_PRIV]] to [[S_FLOAT_TY]]* 509 // CHECK: [[S_ARR_END:%.+]] = getelementptr [[S_FLOAT_TY]], [[S_FLOAT_TY]]* [[S_ARR_BEGIN]], i{{[0-9]+}} 2 510 // CHECK: [[IS_EMPTY:%.+]] = icmp eq [[S_FLOAT_TY]]* [[S_ARR_BEGIN]], [[S_ARR_END]] 511 // CHECK: br i1 [[IS_EMPTY]], label %[[S_ARR_BODY_DONE:.+]], label %[[S_ARR_BODY:.+]] 512 // CHECK: [[S_ARR_BODY]] 513 // CHECK: call {{.*}} [[S_FLOAT_TY_COPY_ASSIGN:@.+]]([[S_FLOAT_TY]]* {{.+}}, [[S_FLOAT_TY]]* {{.+}}) 514 // CHECK: br i1 {{.+}}, label %[[S_ARR_BODY_DONE]], label %[[S_ARR_BODY]] 515 // CHECK: [[S_ARR_BODY_DONE]] 516 517 // original var=private_var; 518 // CHECK: call {{.*}} [[S_FLOAT_TY_COPY_ASSIGN:@.+]]([[S_FLOAT_TY]]* [[VAR_REF]], [[S_FLOAT_TY]]* {{.*}} [[VAR_PRIV]]) 519 // CHECK: [[SIVAR_VAL:%.+]] = load i{{[0-9]+}}, i{{[0-9]+}}* [[SIVAR_PRIV]], 520 // CHECK: br label %[[LAST_DONE]] 521 // CHECK: [[LAST_DONE]] 522 // CHECK-DAG: call void [[S_FLOAT_TY_DESTR]]([[S_FLOAT_TY]]* [[VAR_PRIV]]) 523 // CHECK-DAG: call void [[S_FLOAT_TY_DESTR]]([[S_FLOAT_TY]]* 524 // CHECK: [[GTID_REF:%.+]] = load i{{[0-9]+}}*, i{{[0-9]+}}** [[GTID_ADDR_REF]] 525 // CHECK: [[GTID:%.+]] = load i{{[0-9]+}}, i{{[0-9]+}}* [[GTID_REF]] 526 // CHECK: call void @__kmpc_barrier(%{{.+}}* [[IMPLICIT_BARRIER_LOC]], i{{[0-9]+}} [[GTID]]) 527 // CHECK: ret void 528 529 // 530 // CHECK: define internal void [[MAIN_MICROTASK1]](i{{[0-9]+}}* noalias [[GTID_ADDR:%.+]], i{{[0-9]+}}* noalias %{{.+}}) 531 // CHECK: [[F_PRIV:%.+]] = alloca float, 532 // CHECK-NOT: alloca float 533 // CHECK: [[X_PRIV:%.+]] = alloca double, 534 // CHECK-NOT: alloca float 535 // CHECK-NOT: alloca double 536 537 // Check for default initialization. 538 // CHECK-NOT: [[X_PRIV]] 539 // CHECK: [[F_VAL:%.+]] = load float, float* [[F]], 540 // CHECK: store float [[F_VAL]], float* [[F_PRIV]], 541 // CHECK-NOT: [[X_PRIV]] 542 543 // CHECK: [[GTID_REF:%.+]] = load i{{[0-9]+}}*, i{{[0-9]+}}** [[GTID_ADDR_REF]] 544 // CHECK: [[GTID:%.+]] = load i{{[0-9]+}}, i{{[0-9]+}}* [[GTID_REF]] 545 // CHECK: call {{.+}} @__kmpc_for_static_init_4(%{{.+}}* @{{.+}}, i32 [[GTID]], i32 34, i32* [[IS_LAST_ADDR:%.+]], i32* %{{.+}}, i32* %{{.+}}, i32* %{{.+}}, i32 1, i32 1) 546 // <Skip loop body> 547 // CHECK: call void @__kmpc_for_static_fini(%{{.+}}* @{{.+}}, i32 [[GTID]]) 548 549 // Check for final copying of private values back to original vars. 550 // CHECK: [[IS_LAST_VAL:%.+]] = load i32, i32* [[IS_LAST_ADDR]], 551 // CHECK: [[IS_LAST_ITER:%.+]] = icmp ne i32 [[IS_LAST_VAL]], 0 552 // CHECK: br i1 [[IS_LAST_ITER:%.+]], label %[[LAST_THEN:.+]], label %[[LAST_DONE:.+]] 553 // CHECK: [[LAST_THEN]] 554 // Actual copying. 555 556 // original x=private_x; 557 // CHECK: [[X_VAL:%.+]] = load double, double* [[X_PRIV]], 558 // CHECK: store double [[X_VAL]], double* [[X]], 559 560 // original f=private_f; 561 // CHECK: [[F_VAL:%.+]] = load float, float* [[F_PRIV]], 562 // CHECK: store float [[F_VAL]], float* [[F]], 563 564 // CHECK-NEXT: br label %[[LAST_DONE]] 565 // CHECK: [[LAST_DONE]] 566 567 // CHECK: call void @__kmpc_barrier(%{{.+}}* [[IMPLICIT_BARRIER_LOC]], i{{[0-9]+}} [[GTID]]) 568 // CHECK: ret void 569 570 // CHECK: define internal void [[MAIN_MICROTASK2]](i{{[0-9]+}}* noalias [[GTID_ADDR:%.+]], i{{[0-9]+}}* noalias %{{.+}}) 571 // CHECK: [[F_PRIV:%.+]] = alloca float, 572 // CHECK-NOT: alloca float 573 574 // Check for default initialization. 575 // CHECK: [[F_VAL:%.+]] = load float, float* [[F]], 576 // CHECK: store float [[F_VAL]], float* [[F_PRIV]], 577 578 // CHECK: [[GTID_REF:%.+]] = load i{{[0-9]+}}*, i{{[0-9]+}}** [[GTID_ADDR_REF]] 579 // CHECK: [[GTID:%.+]] = load i{{[0-9]+}}, i{{[0-9]+}}* [[GTID_REF]] 580 // CHECK: call {{.+}} @__kmpc_for_static_init_4(%{{.+}}* @{{.+}}, i32 [[GTID]], i32 34, i32* [[IS_LAST_ADDR:%.+]], i32* %{{.+}}, i32* %{{.+}}, i32* %{{.+}}, i32 1, i32 1) 581 // <Skip loop body> 582 // CHECK: call void @__kmpc_for_static_fini(%{{.+}}* @{{.+}}, i32 [[GTID]]) 583 584 // Check for final copying of private values back to original vars. 585 // CHECK: [[IS_LAST_VAL:%.+]] = load i32, i32* [[IS_LAST_ADDR]], 586 // CHECK: [[IS_LAST_ITER:%.+]] = icmp ne i32 [[IS_LAST_VAL]], 0 587 // CHECK: br i1 [[IS_LAST_ITER:%.+]], label %[[LAST_THEN:.+]], label %[[LAST_DONE:.+]] 588 // CHECK: [[LAST_THEN]] 589 // Actual copying. 590 591 // original f=private_f; 592 // CHECK: [[F_VAL:%.+]] = load float, float* [[F_PRIV]], 593 // CHECK: store float [[F_VAL]], float* [[F]], 594 595 // CHECK-NEXT: br label %[[LAST_DONE]] 596 // CHECK: [[LAST_DONE]] 597 598 // CHECK: call void @__kmpc_barrier(%{{.+}}* [[IMPLICIT_BARRIER_LOC]], i{{[0-9]+}} [[GTID]]) 599 // CHECK: ret void 600 601 // CHECK: define internal void [[MAIN_MICROTASK3]](i{{[0-9]+}}* noalias [[GTID_ADDR:%.+]], i{{[0-9]+}}* noalias %{{.+}}) 602 // CHECK: [[CNT_PRIV:%.+]] = alloca i8, 603 604 // CHECK: [[GTID_REF:%.+]] = load i{{[0-9]+}}*, i{{[0-9]+}}** [[GTID_ADDR_REF]] 605 // CHECK: [[GTID:%.+]] = load i{{[0-9]+}}, i{{[0-9]+}}* [[GTID_REF]] 606 // CHECK: call {{.+}} @__kmpc_for_static_init_4(%{{.+}}* @{{.+}}, i32 [[GTID]], i32 34, i32* [[IS_LAST_ADDR:%.+]], i32* [[OMP_LB:%[^,]+]], i32* [[OMP_UB:%[^,]+]], i32* [[OMP_ST:%[^,]+]], i32 1, i32 1) 607 // UB = min(UB, GlobalUB) 608 // CHECK-NEXT: [[UB:%.+]] = load i32, i32* [[OMP_UB]] 609 // CHECK-NEXT: [[UBCMP:%.+]] = icmp sgt i32 [[UB]], 1 610 // CHECK-NEXT: br i1 [[UBCMP]], label [[UB_TRUE:%[^,]+]], label [[UB_FALSE:%[^,]+]] 611 // CHECK: [[UBRESULT:%.+]] = phi i32 [ 1, [[UB_TRUE]] ], [ [[UBVAL:%[^,]+]], [[UB_FALSE]] ] 612 // CHECK-NEXT: store i32 [[UBRESULT]], i32* [[OMP_UB]] 613 // CHECK-NEXT: [[LB:%.+]] = load i32, i32* [[OMP_LB]] 614 // CHECK-NEXT: store i32 [[LB]], i32* [[OMP_IV:[^,]+]] 615 // <Skip loop body> 616 // CHECK: call void @__kmpc_for_static_fini(%{{.+}}* @{{.+}}, i32 [[GTID]]) 617 618 // Check for final copying of private values back to original vars. 619 // CHECK: [[IS_LAST_VAL:%.+]] = load i32, i32* [[IS_LAST_ADDR]], 620 // CHECK: [[IS_LAST_ITER:%.+]] = icmp ne i32 [[IS_LAST_VAL]], 0 621 // CHECK: br i1 [[IS_LAST_ITER:%.+]], label %[[LAST_THEN:.+]], label %[[LAST_DONE:.+]] 622 // CHECK: [[LAST_THEN]] 623 624 // Calculate private cnt value. 625 // CHECK: store i8 2, i8* [[CNT_PRIV]] 626 // original cnt=private_cnt; 627 // CHECK: [[CNT_VAL:%.+]] = load i8, i8* [[CNT_PRIV]], 628 // CHECK: store i8 [[CNT_VAL]], i8* [[CNT]], 629 630 // CHECK-NEXT: br label %[[LAST_DONE]] 631 // CHECK: [[LAST_DONE]] 632 633 // CHECK: call void @__kmpc_barrier(%{{.+}}* [[IMPLICIT_BARRIER_LOC]], i{{[0-9]+}} [[GTID]]) 634 // CHECK: ret void 635 636 // CHECK: define {{.*}} i{{[0-9]+}} [[TMAIN_INT]]() 637 // CHECK: [[TEST:%.+]] = alloca [[S_INT_TY]], 638 // CHECK: call {{.*}} [[S_INT_TY_DEF_CONSTR:@.+]]([[S_INT_TY]]* [[TEST]]) 639 // CHECK: call void (%{{.+}}*, i{{[0-9]+}}, void (i{{[0-9]+}}*, i{{[0-9]+}}*, ...)*, ...) @__kmpc_fork_call(%{{.+}}* @{{.+}}, i{{[0-9]+}} 4, void (i{{[0-9]+}}*, i{{[0-9]+}}*, ...)* bitcast (void (i{{[0-9]+}}*, i{{[0-9]+}}*, i32*, [2 x i32]*, [2 x [[S_INT_TY]]]*, [[S_INT_TY]]*)* [[TMAIN_MICROTASK:@.+]] to void 640 // CHECK: call void [[S_INT_TY_DESTR:@.+]]([[S_INT_TY]]* 641 // CHECK: ret 642 643 // CHECK: define {{.+}} @{{.+}}([[SS_TY]]* 644 // CHECK: getelementptr inbounds [[SS_TY]], [[SS_TY]]* %{{.+}}, i32 0, i32 0 645 // CHECK: store i{{[0-9]+}} 0, i{{[0-9]+}}* % 646 // CHECK: getelementptr inbounds [[SS_TY]], [[SS_TY]]* %{{.+}}, i32 0, i32 1 647 // CHECK: store i8 648 // CHECK: getelementptr inbounds [[SS_TY]], [[SS_TY]]* %{{.+}}, i32 0, i32 2 649 // CHECK: call void (%{{.+}}*, i{{[0-9]+}}, void (i{{[0-9]+}}*, i{{[0-9]+}}*, ...)*, ...) @__kmpc_fork_call(%{{.+}}* @{{.+}}, i{{[0-9]+}} 1, void (i{{[0-9]+}}*, i{{[0-9]+}}*, ...)* bitcast (void (i{{[0-9]+}}*, i{{[0-9]+}}*, [[SS_TY]]*)* [[SS_MICROTASK:@.+]] to void 650 // CHECK: call void @__kmpc_for_static_init_4( 651 // CHECK-NOT: getelementptr inbounds [[SS_TY]], [[SS_TY]]* %{{.+}}, i32 0, i32 0 652 // CHECK: getelementptr inbounds [[SS_TY]], [[SS_TY]]* %{{.+}}, i32 0, i32 1 653 // CHECK: getelementptr inbounds [[SS_TY]], [[SS_TY]]* %{{.+}}, i32 0, i32 2 654 // CHECK: call void @__kmpc_for_static_fini(% 655 // CHECK: ret 656 657 // CHECK: define internal void [[SS_MICROTASK]](i{{[0-9]+}}* noalias [[GTID_ADDR:%.+]], i{{[0-9]+}}* noalias %{{.+}}, [[SS_TY]]* %{{.+}}) 658 // CHECK: alloca i{{[0-9]+}}, 659 // CHECK: alloca i{{[0-9]+}}, 660 // CHECK: alloca i{{[0-9]+}}, 661 // CHECK: alloca i{{[0-9]+}}, 662 // CHECK: alloca i{{[0-9]+}}, 663 // CHECK: alloca i{{[0-9]+}}, 664 // CHECK: [[A_PRIV:%.+]] = alloca i{{[0-9]+}}, 665 // CHECK: [[B_PRIV:%.+]] = alloca i{{[0-9]+}}, 666 // CHECK: [[C_PRIV:%.+]] = alloca i{{[0-9]+}}, 667 // CHECK: store i{{[0-9]+}}* [[A_PRIV]], i{{[0-9]+}}** [[REFA:%.+]], 668 // CHECK: store i{{[0-9]+}}* [[C_PRIV]], i{{[0-9]+}}** [[REFC:%.+]], 669 // CHECK: call void @__kmpc_for_static_init_4( 670 // CHECK: [[A_PRIV:%.+]] = load i{{[0-9]+}}*, i{{[0-9]+}}** [[REFA]], 671 // CHECK-NEXT: [[A_VAL:%.+]] = load i{{[0-9]+}}, i{{[0-9]+}}* [[A_PRIV]], 672 // CHECK-NEXT: [[INC:%.+]] = add nsw i{{[0-9]+}} [[A_VAL]], 1 673 // CHECK-NEXT: store i{{[0-9]+}} [[INC]], i{{[0-9]+}}* [[A_PRIV]], 674 // CHECK-NEXT: [[B_VAL:%.+]] = load i{{[0-9]+}}, i{{[0-9]+}}* [[B_PRIV]], 675 // CHECK-NEXT: [[DEC:%.+]] = add nsw i{{[0-9]+}} [[B_VAL]], -1 676 // CHECK-NEXT: store i{{[0-9]+}} [[DEC]], i{{[0-9]+}}* [[B_PRIV]], 677 // CHECK-NEXT: [[C_PRIV:%.+]] = load i{{[0-9]+}}*, i{{[0-9]+}}** [[REFC]], 678 // CHECK-NEXT: [[C_VAL:%.+]] = load i{{[0-9]+}}, i{{[0-9]+}}* [[C_PRIV]], 679 // CHECK-NEXT: [[DIV:%.+]] = sdiv i{{[0-9]+}} [[C_VAL]], 1 680 // CHECK-NEXT: store i{{[0-9]+}} [[DIV]], i{{[0-9]+}}* [[C_PRIV]], 681 // CHECK: call void @__kmpc_for_static_fini( 682 // CHECK: br i1 683 // CHECK: [[B_REF:%.+]] = getelementptr {{.*}}[[SS_TY]], [[SS_TY]]* %{{.*}}, i32 0, i32 1 684 // CHECK: store i8 %{{.+}}, i8* [[B_REF]], 685 // CHECK: br label 686 // CHECK: ret void 687 688 // CHECK: define internal void [[TMAIN_MICROTASK]](i{{[0-9]+}}* noalias [[GTID_ADDR:%.+]], i{{[0-9]+}}* noalias %{{.+}}, i32* dereferenceable(4) %{{.+}}, [2 x i32]* dereferenceable(8) %{{.+}}, [2 x [[S_INT_TY]]]* dereferenceable(8) %{{.+}}, [[S_INT_TY]]* dereferenceable(4) %{{.+}}) 689 // CHECK: alloca i{{[0-9]+}}, 690 // CHECK: alloca i{{[0-9]+}}, 691 // CHECK: alloca i{{[0-9]+}}, 692 // CHECK: alloca i{{[0-9]+}}, 693 // CHECK: alloca i{{[0-9]+}}, 694 // CHECK: [[T_VAR_PRIV:%.+]] = alloca i{{[0-9]+}}, align 128 695 // CHECK: [[VEC_PRIV:%.+]] = alloca [2 x i{{[0-9]+}}], align 128 696 // CHECK: [[S_ARR_PRIV:%.+]] = alloca [2 x [[S_INT_TY]]], align 128 697 // CHECK: [[VAR_PRIV:%.+]] = alloca [[S_INT_TY]], align 128 698 // CHECK: [[VAR_PRIV_REF:%.+]] = alloca [[S_INT_TY]]*, 699 // CHECK: store i{{[0-9]+}}* [[GTID_ADDR]], i{{[0-9]+}}** [[GTID_ADDR_REF:%.+]] 700 701 // CHECK: [[T_VAR_REF:%.+]] = load i{{[0-9]+}}*, i{{[0-9]+}}** % 702 // CHECK: [[VEC_REF:%.+]] = load [2 x i{{[0-9]+}}]*, [2 x i{{[0-9]+}}]** % 703 // CHECK: [[S_ARR_REF:%.+]] = load [2 x [[S_INT_TY]]]*, [2 x [[S_INT_TY]]]** % 704 705 // Check for default initialization. 706 // CHECK-NOT: [[T_VAR_PRIV]] 707 // CHECK-NOT: [[VEC_PRIV]] 708 // CHECK: [[S_ARR_PRIV_ITEM:%.+]] = phi [[S_INT_TY]]* 709 // CHECK: call {{.*}} [[S_INT_TY_DEF_CONSTR]]([[S_INT_TY]]* [[S_ARR_PRIV_ITEM]]) 710 // CHECK: [[VAR_REF:%.+]] = load [[S_INT_TY]]*, [[S_INT_TY]]** % 711 // CHECK: call {{.*}} [[S_INT_TY_DEF_CONSTR]]([[S_INT_TY]]* [[VAR_PRIV]]) 712 // CHECK: store [[S_INT_TY]]* [[VAR_PRIV]], [[S_INT_TY]]** [[VAR_PRIV_REF]] 713 // CHECK: call {{.+}} @__kmpc_for_static_init_4(%{{.+}}* @{{.+}}, i32 %{{.+}}, i32 34, i32* [[IS_LAST_ADDR:%.+]], i32* %{{.+}}, i32* %{{.+}}, i32* %{{.+}}, i32 1, i32 1) 714 // <Skip loop body> 715 // CHECK: call void @__kmpc_for_static_fini(%{{.+}}* @{{.+}}, i32 %{{.+}}) 716 717 // Check for final copying of private values back to original vars. 718 // CHECK: [[IS_LAST_VAL:%.+]] = load i32, i32* [[IS_LAST_ADDR]], 719 // CHECK: [[IS_LAST_ITER:%.+]] = icmp ne i32 [[IS_LAST_VAL]], 0 720 // CHECK: br i1 [[IS_LAST_ITER:%.+]], label %[[LAST_THEN:.+]], label %[[LAST_DONE:.+]] 721 // CHECK: [[LAST_THEN]] 722 // Actual copying. 723 724 // original t_var=private_t_var; 725 // CHECK: [[T_VAR_VAL:%.+]] = load i{{[0-9]+}}, i{{[0-9]+}}* [[T_VAR_PRIV]], 726 // CHECK: store i{{[0-9]+}} [[T_VAR_VAL]], i{{[0-9]+}}* [[T_VAR_REF]], 727 728 // original vec[]=private_vec[]; 729 // CHECK: [[VEC_DEST:%.+]] = bitcast [2 x i{{[0-9]+}}]* [[VEC_REF]] to i8* 730 // CHECK: [[VEC_SRC:%.+]] = bitcast [2 x i{{[0-9]+}}]* [[VEC_PRIV]] to i8* 731 // CHECK: call void @llvm.memcpy.{{.+}}(i8* [[VEC_DEST]], i8* [[VEC_SRC]], 732 733 // original s_arr[]=private_s_arr[]; 734 // CHECK: [[S_ARR_BEGIN:%.+]] = getelementptr inbounds [2 x [[S_INT_TY]]], [2 x [[S_INT_TY]]]* [[S_ARR_REF]], i{{[0-9]+}} 0, i{{[0-9]+}} 0 735 // CHECK: [[S_ARR_PRIV_BEGIN:%.+]] = bitcast [2 x [[S_INT_TY]]]* [[S_ARR_PRIV]] to [[S_INT_TY]]* 736 // CHECK: [[S_ARR_END:%.+]] = getelementptr [[S_INT_TY]], [[S_INT_TY]]* [[S_ARR_BEGIN]], i{{[0-9]+}} 2 737 // CHECK: [[IS_EMPTY:%.+]] = icmp eq [[S_INT_TY]]* [[S_ARR_BEGIN]], [[S_ARR_END]] 738 // CHECK: br i1 [[IS_EMPTY]], label %[[S_ARR_BODY_DONE:.+]], label %[[S_ARR_BODY:.+]] 739 // CHECK: [[S_ARR_BODY]] 740 // CHECK: call {{.*}} [[S_INT_TY_COPY_ASSIGN:@.+]]([[S_INT_TY]]* {{.+}}, [[S_INT_TY]]* {{.+}}) 741 // CHECK: br i1 {{.+}}, label %[[S_ARR_BODY_DONE]], label %[[S_ARR_BODY]] 742 // CHECK: [[S_ARR_BODY_DONE]] 743 744 // original var=private_var; 745 // CHECK: [[VAR_PRIV1:%.+]] = load [[S_INT_TY]]*, [[S_INT_TY]]** [[VAR_PRIV_REF]], 746 // CHECK: call {{.*}} [[S_INT_TY_COPY_ASSIGN:@.+]]([[S_INT_TY]]* [[VAR_REF]], [[S_INT_TY]]* {{.*}} [[VAR_PRIV1]]) 747 // CHECK: br label %[[LAST_DONE]] 748 // CHECK: [[LAST_DONE]] 749 // CHECK-DAG: call void [[S_INT_TY_DESTR]]([[S_INT_TY]]* [[VAR_PRIV]]) 750 // CHECK-DAG: call void [[S_INT_TY_DESTR]]([[S_INT_TY]]* 751 // CHECK: [[GTID_REF:%.+]] = load i{{[0-9]+}}*, i{{[0-9]+}}** [[GTID_ADDR_REF]] 752 // CHECK: [[GTID:%.+]] = load i{{[0-9]+}}, i{{[0-9]+}}* [[GTID_REF]] 753 // CHECK: call void @__kmpc_barrier(%{{.+}}* [[IMPLICIT_BARRIER_LOC]], i{{[0-9]+}} [[GTID]]) 754 // CHECK: ret void 755 #endif 756 757