1 // RUN: %clang_cc1 -DCHECK -verify -fopenmp -x c++ -triple powerpc64le-unknown-unknown -fopenmp-targets=powerpc64le-ibm-linux-gnu -emit-llvm %s -o - | FileCheck -allow-deprecated-dag-overlap %s --check-prefix CHECK --check-prefix CHECK-64 2 // RUN: %clang_cc1 -DCHECK -fopenmp -x c++ -std=c++11 -triple powerpc64le-unknown-unknown -fopenmp-targets=powerpc64le-ibm-linux-gnu -emit-pch -o %t %s 3 // RUN: %clang_cc1 -DCHECK -fopenmp -x c++ -triple powerpc64le-unknown-unknown -fopenmp-targets=powerpc64le-ibm-linux-gnu -std=c++11 -include-pch %t -verify %s -emit-llvm -o - | FileCheck -allow-deprecated-dag-overlap %s --check-prefix CHECK --check-prefix CHECK-64 4 // RUN: %clang_cc1 -DCHECK -verify -fopenmp -x c++ -triple i386-unknown-unknown -fopenmp-targets=i386-pc-linux-gnu -emit-llvm %s -o - | FileCheck -allow-deprecated-dag-overlap %s --check-prefix CHECK --check-prefix CHECK-32 5 // RUN: %clang_cc1 -DCHECK -fopenmp -x c++ -std=c++11 -triple i386-unknown-unknown -fopenmp-targets=i386-pc-linux-gnu -emit-pch -o %t %s 6 // RUN: %clang_cc1 -DCHECK -fopenmp -x c++ -triple i386-unknown-unknown -fopenmp-targets=i386-pc-linux-gnu -std=c++11 -include-pch %t -verify %s -emit-llvm -o - | FileCheck -allow-deprecated-dag-overlap %s --check-prefix CHECK --check-prefix CHECK-32 7 8 // RUN: %clang_cc1 -DCHECK -verify -fopenmp-simd -x c++ -triple powerpc64le-unknown-unknown -fopenmp-targets=powerpc64le-ibm-linux-gnu -emit-llvm %s -o - | FileCheck -allow-deprecated-dag-overlap --check-prefix SIMD-ONLY0 %s 9 // RUN: %clang_cc1 -DCHECK -fopenmp-simd -x c++ -std=c++11 -triple powerpc64le-unknown-unknown -fopenmp-targets=powerpc64le-ibm-linux-gnu -emit-pch -o %t %s 10 // RUN: %clang_cc1 -DCHECK -fopenmp-simd -x c++ -triple powerpc64le-unknown-unknown -fopenmp-targets=powerpc64le-ibm-linux-gnu -std=c++11 -include-pch %t -verify %s -emit-llvm -o - | FileCheck -allow-deprecated-dag-overlap --check-prefix SIMD-ONLY0 %s 11 // RUN: %clang_cc1 -DCHECK -verify -fopenmp-simd -x c++ -triple i386-unknown-unknown -fopenmp-targets=i386-pc-linux-gnu -emit-llvm %s -o - | FileCheck -allow-deprecated-dag-overlap --check-prefix SIMD-ONLY0 %s 12 // RUN: %clang_cc1 -DCHECK -fopenmp-simd -x c++ -std=c++11 -triple i386-unknown-unknown -fopenmp-targets=i386-pc-linux-gnu -emit-pch -o %t %s 13 // RUN: %clang_cc1 -DCHECK -fopenmp-simd -x c++ -triple i386-unknown-unknown -fopenmp-targets=i386-pc-linux-gnu -std=c++11 -include-pch %t -verify %s -emit-llvm -o - | FileCheck -allow-deprecated-dag-overlap --check-prefix SIMD-ONLY0 %s 14 // SIMD-ONLY0-NOT: {{__kmpc|__tgt}} 15 16 // RUN: %clang_cc1 -DLAMBDA -verify -fopenmp -x c++ -std=c++11 -triple powerpc64le-unknown-unknown -fopenmp-targets=powerpc64le-ibm-linux-gnu -emit-llvm %s -o - | FileCheck -allow-deprecated-dag-overlap %s --check-prefix LAMBDA --check-prefix LAMBDA-64 17 // RUN: %clang_cc1 -DLAMBDA -fopenmp -x c++ -std=c++11 -triple powerpc64le-unknown-unknown -fopenmp-targets=powerpc64le-ibm-linux-gnu -emit-pch -o %t %s 18 // RUN: %clang_cc1 -DLAMBDA -fopenmp -x c++ -std=c++11 -triple powerpc64le-unknown-unknown -fopenmp-targets=powerpc64le-ibm-linux-gnu -std=c++11 -include-pch %t -verify %s -emit-llvm -o - | FileCheck -allow-deprecated-dag-overlap %s --check-prefix LAMBDA --check-prefix LAMBDA-64 19 20 // RUN: %clang_cc1 -DLAMBDA -verify -fopenmp-simd -x c++ -std=c++11 -triple powerpc64le-unknown-unknown -fopenmp-targets=powerpc64le-ibm-linux-gnu -emit-llvm %s -o - | FileCheck -allow-deprecated-dag-overlap --check-prefix SIMD-ONLY1 %s 21 // RUN: %clang_cc1 -DLAMBDA -fopenmp-simd -x c++ -std=c++11 -triple powerpc64le-unknown-unknown -fopenmp-targets=powerpc64le-ibm-linux-gnu -emit-pch -o %t %s 22 // RUN: %clang_cc1 -DLAMBDA -fopenmp-simd -x c++ -std=c++11 -triple powerpc64le-unknown-unknown -fopenmp-targets=powerpc64le-ibm-linux-gnu -std=c++11 -include-pch %t -verify %s -emit-llvm -o - | FileCheck -allow-deprecated-dag-overlap --check-prefix SIMD-ONLY1 %s 23 // SIMD-ONLY1-NOT: {{__kmpc|__tgt}} 24 25 // expected-no-diagnostics 26 #ifndef HEADER 27 #define HEADER 28 29 struct St { 30 int a, b; 31 St() : a(0), b(0) {} 32 St(const St &st) : a(st.a + st.b), b(0) {} 33 ~St() {} 34 }; 35 36 volatile int g = 1212; 37 volatile int &g1 = g; 38 39 template <class T> 40 struct S { 41 T f; 42 S(T a) : f(a + g) {} 43 S() : f(g) {} 44 S(const S &s, St t = St()) : f(s.f + t.a) {} 45 operator T() { return T(); } 46 ~S() {} 47 }; 48 49 // CHECK-DAG: [[S_FLOAT_TY:%.+]] = type { float } 50 // CHECK-DAG: [[S_INT_TY:%.+]] = type { i{{[0-9]+}} } 51 52 template <typename T> 53 T tmain() { 54 S<T> test; 55 T t_var = T(); 56 T vec[] = {1, 2}; 57 S<T> s_arr[] = {1, 2}; 58 S<T> &var = test; 59 #pragma omp target 60 #pragma omp teams distribute parallel for private(t_var, vec, s_arr, var) 61 for (int i = 0; i < 2; ++i) { 62 vec[i] = t_var; 63 s_arr[i] = var; 64 } 65 return T(); 66 } 67 68 // CHECK-DAG: [[TEST:@.+]] = global [[S_FLOAT_TY]] zeroinitializer, 69 S<float> test; 70 // CHECK-DAG: [[T_VAR:@.+]] = global i{{[0-9]+}} 333, 71 int t_var = 333; 72 // CHECK-DAG: [[VEC:@.+]] = global [2 x i{{[0-9]+}}] [i{{[0-9]+}} 1, i{{[0-9]+}} 2], 73 int vec[] = {1, 2}; 74 // CHECK-DAG: [[S_ARR:@.+]] = global [2 x [[S_FLOAT_TY]]] zeroinitializer, 75 S<float> s_arr[] = {1, 2}; 76 // CHECK-DAG: [[VAR:@.+]] = global [[S_FLOAT_TY]] zeroinitializer, 77 S<float> var(3); 78 // CHECK-DAG: [[SIVAR:@.+]] = internal global i{{[0-9]+}} 0, 79 80 int main() { 81 static int sivar; 82 #ifdef LAMBDA 83 // LAMBDA: [[G:@.+]] = global i{{[0-9]+}} 1212, 84 // LAMBDA-LABEL: @main 85 // LAMBDA: call void [[OUTER_LAMBDA:@.+]]( 86 [&]() { 87 // LAMBDA: define{{.*}} internal{{.*}} void [[OUTER_LAMBDA]]( 88 // LAMBDA: call i32 @__tgt_target_teams_mapper(i64 -1, i8* @{{[^,]+}}, i32 1, i8** %{{[^,]+}}, i8** %{{[^,]+}}, i{{64|32}}* {{.+}}@{{[^,]+}}, i32 0, i32 0), i64* {{.+}}@{{[^,]+}}, i32 0, i32 0), i8** null, i32 0, i32 0) 89 // LAMBDA: call void @[[LOFFL1:.+]]( 90 // LAMBDA: ret 91 #pragma omp target 92 #pragma omp teams distribute parallel for private(g, g1, sivar) 93 for (int i = 0; i < 2; ++i) { 94 // LAMBDA: define{{.*}} internal{{.*}} void @[[LOFFL1]](i{{64|32}} {{%.+}}) 95 // LAMBDA: call void {{.+}} @__kmpc_fork_teams({{.+}}, i32 0, {{.+}} @[[LOUTL1:.+]] to {{.+}}) 96 // LAMBDA: ret void 97 98 // LAMBDA: define internal void @[[LOUTL1]]({{.+}}) 99 // Skip global, bound tid and loop vars 100 // LAMBDA: {{.+}} = alloca i32*, 101 // LAMBDA: {{.+}} = alloca i32*, 102 // LAMBDA: alloca i32, 103 // LAMBDA: alloca i32, 104 // LAMBDA: alloca i32, 105 // LAMBDA: alloca i32, 106 // LAMBDA: alloca i32, 107 // LAMBDA: alloca i32, 108 // LAMBDA: [[G_PRIV:%.+]] = alloca i{{[0-9]+}}, 109 // LAMBDA: [[G1_PRIV:%.+]] = alloca i{{[0-9]+}} 110 // LAMBDA: [[TMP:%.+]] = alloca i{{[0-9]+}}*, 111 // LAMBDA: [[SIVAR_PRIV:%.+]] = alloca i{{[0-9]+}}, 112 // LAMBDA: store{{.+}} [[G1_PRIV]], {{.+}} [[TMP]], 113 114 g = 1; 115 g1 = 1; 116 sivar = 2; 117 // LAMBDA: call void @__kmpc_for_static_init_4( 118 // LAMBDA: call void {{.+}} @__kmpc_fork_call({{.+}}, {{.+}}, {{.+}} @[[LPAR_OUTL:.+]] to 119 // LAMBDA: call void @__kmpc_for_static_fini( 120 // LAMBDA: ret void 121 122 // LAMBDA: define internal void @[[LPAR_OUTL]]({{.+}}) 123 // Skip global, bound tid and loop vars 124 // LAMBDA: {{.+}} = alloca i32*, 125 // LAMBDA: {{.+}} = alloca i32*, 126 // LAMBDA: alloca i{{[0-9]+}}, 127 // LAMBDA: alloca i{{[0-9]+}}, 128 // LAMBDA: alloca i32, 129 // LAMBDA: alloca i32, 130 // LAMBDA: alloca i32, 131 // LAMBDA: alloca i32, 132 // LAMBDA: alloca i32, 133 // LAMBDA: alloca i32, 134 // LAMBDA: [[G_PRIV:%.+]] = alloca i{{[0-9]+}}, 135 // LAMBDA: [[G1_PRIV:%.+]] = alloca i{{[0-9]+}} 136 // LAMBDA: [[TMP:%.+]] = alloca i{{[0-9]+}}*, 137 // LAMBDA: [[SIVAR_PRIV:%.+]] = alloca i{{[0-9]+}}, 138 // LAMBDA: store{{.+}} [[G1_PRIV]], {{.+}} [[TMP]], 139 // LAMBDA-DAG: store{{.+}} 1, {{.+}} [[G_PRIV]], 140 // LAMBDA-DAG: store{{.+}} 2, {{.+}} [[SIVAR_PRIV]], 141 // LAMBDA-DAG: [[G1_REF:%.+]] = load{{.+}}, {{.+}} [[TMP]], 142 // LAMBDA-DAG: store{{.+}} 1, {{.+}} [[G1_REF]], 143 // LAMBDA: call void [[INNER_LAMBDA:@.+]]( 144 // LAMBDA: call void @__kmpc_for_static_fini( 145 // LAMBDA: ret void 146 [&]() { 147 // LAMBDA: define {{.+}} void [[INNER_LAMBDA]](%{{.+}}* [[ARG_PTR:%.+]]) 148 // LAMBDA: store %{{.+}}* [[ARG_PTR]], %{{.+}}** [[ARG_PTR_REF:%.+]], 149 g = 2; 150 g1 = 2; 151 sivar = 4; 152 // LAMBDA: [[ARG_PTR:%.+]] = load %{{.+}}*, %{{.+}}** [[ARG_PTR_REF]] 153 154 // LAMBDA: [[G_PTR_REF:%.+]] = getelementptr inbounds %{{.+}}, %{{.+}}* [[ARG_PTR]], i{{[0-9]+}} 0, i{{[0-9]+}} 0 155 // LAMBDA: [[G_REF:%.+]] = load i{{[0-9]+}}*, i{{[0-9]+}}** [[G_PTR_REF]] 156 // LAMBDA: store i{{[0-9]+}} 2, i{{[0-9]+}}* [[G_REF]] 157 // LAMBDA: [[G1_PTR_REF:%.+]] = getelementptr inbounds %{{.+}}, %{{.+}}* [[ARG_PTR]], i{{[0-9]+}} 0, i{{[0-9]+}} 1 158 // LAMBDA: [[G1_REF:%.+]] = load i{{[0-9]+}}*, i{{[0-9]+}}** [[G1_PTR_REF]] 159 // LAMBDA: store i{{[0-9]+}} 2, i{{[0-9]+}}* [[G1_REF]] 160 // LAMBDA: [[SIVAR_PTR_REF:%.+]] = getelementptr inbounds %{{.+}}, %{{.+}}* [[ARG_PTR]], i{{[0-9]+}} 0, i{{[0-9]+}} 2 161 // LAMBDA: [[SIVAR_REF:%.+]] = load i{{[0-9]+}}*, i{{[0-9]+}}** [[SIVAR_PTR_REF]] 162 // LAMBDA: store i{{[0-9]+}} 4, i{{[0-9]+}}* [[SIVAR_REF]] 163 }(); 164 } 165 }(); 166 return 0; 167 #else 168 #pragma omp target 169 #pragma omp teams distribute parallel for private(t_var, vec, s_arr, var, sivar) 170 for (int i = 0; i < 2; ++i) { 171 vec[i] = t_var; 172 s_arr[i] = var; 173 sivar += i; 174 } 175 return tmain<int>(); 176 #endif 177 } 178 179 // CHECK: define {{.*}}i{{[0-9]+}} @main() 180 // CHECK: call i32 @__tgt_target_teams_mapper(i64 -1, i8* @{{[^,]+}}, i32 0, i8** null, i8** null, i{{64|32}}* null, i64* null, i8** null, i32 0, i32 0) 181 // CHECK: call void @[[OFFL1:.+]]() 182 // CHECK: {{%.+}} = call{{.*}} i32 @[[TMAIN_INT:.+]]() 183 // CHECK: ret 184 185 // CHECK: define{{.*}} void @[[OFFL1]]() 186 // CHECK: call void {{.+}} @__kmpc_fork_teams({{.+}}, i32 0, {{.+}} @[[OUTL1:.+]] to {{.+}}) 187 // CHECK: ret void 188 189 // CHECK: define internal void @[[OUTL1]]({{.+}}) 190 // Skip global, bound tid and loop vars 191 // CHECK: {{.+}} = alloca i32*, 192 // CHECK: {{.+}} = alloca i32*, 193 // CHECK: {{.+}} = alloca i32, 194 // CHECK: {{.+}} = alloca i32, 195 // CHECK: {{.+}} = alloca i32, 196 // CHECK: {{.+}} = alloca i32, 197 // CHECK: {{.+}} = alloca i32, 198 // CHECK-DAG: [[T_VAR_PRIV:%.+]] = alloca i{{[0-9]+}}, 199 // CHECK-DAG: [[VEC_PRIV:%.+]] = alloca [2 x i{{[0-9]+}}], 200 // CHECK-DAG: [[S_ARR_PRIV:%.+]] = alloca [2 x [[S_FLOAT_TY]]], 201 // CHECK-DAG: [[VAR_PRIV:%.+]] = alloca [[S_FLOAT_TY]], 202 // CHECK-DAG: [[SIVAR_PRIV:%.+]] = alloca i{{[0-9]+}}, 203 // CHECK: alloca i32, 204 205 // private(s_arr) 206 // CHECK-DAG: [[S_ARR_PRIV_BGN:%.+]] = getelementptr{{.*}} [2 x [[S_FLOAT_TY]]], [2 x [[S_FLOAT_TY]]]* [[S_ARR_PRIV]], 207 // CHECK-DAG: [[S_ARR_PTR_ALLOC:%.+]] = phi{{.+}} [ [[S_ARR_PRIV_BGN]], {{.+}} ], [ [[S_ARR_NEXT:%.+]], {{.+}} ] 208 // CHECK-DAG: call void @{{.+}}({{.+}} [[S_ARR_PTR_ALLOC]]) 209 // CHECK-DAG: [[S_ARR_NEXT]] = getelementptr {{.+}} [[S_ARR_PTR_ALLOC]], 210 211 // private(var) 212 // CHECK-DAG: call void @{{.+}}({{.+}} [[VAR_PRIV]]) 213 214 // CHECK: call void @__kmpc_for_static_init_4( 215 // CHECK: call void {{.+}} @__kmpc_fork_call({{.+}}, {{.+}}, {{.+}} @[[PAR_OUTL1:.+]] to 216 // CHECK: call void @__kmpc_for_static_fini( 217 // CHECK: ret void 218 219 // CHECK: define internal void @[[PAR_OUTL1]]({{.+}}) 220 // Skip global, bound tid and loop vars 221 // CHECK: {{.+}} = alloca i32*, 222 // CHECK: {{.+}} = alloca i32*, 223 // CHECK: {{.+}} = alloca i{{[0-9]+}}, 224 // CHECK: {{.+}} = alloca i{{[0-9]+}}, 225 // CHECK: {{.+}} = alloca i32, 226 // CHECK: {{.+}} = alloca i32, 227 // CHECK: {{.+}} = alloca i32, 228 // CHECK: {{.+}} = alloca i32, 229 // CHECK: {{.+}} = alloca i32, 230 // CHECK: {{.+}} = alloca i32, 231 // CHECK-DAG: [[T_VAR_PRIV:%.+]] = alloca i{{[0-9]+}}, 232 // CHECK-DAG: [[VEC_PRIV:%.+]] = alloca [2 x i{{[0-9]+}}], 233 // CHECK-DAG: [[S_ARR_PRIV:%.+]] = alloca [2 x [[S_FLOAT_TY]]], 234 // CHECK-DAG: [[VAR_PRIV:%.+]] = alloca [[S_FLOAT_TY]], 235 // CHECK-DAG: [[SIVAR_PRIV:%.+]] = alloca i{{[0-9]+}}, 236 // CHECK: alloca i32, 237 238 // private(s_arr) 239 // CHECK-DAG: [[S_ARR_PRIV_BGN:%.+]] = getelementptr{{.*}} [2 x [[S_FLOAT_TY]]], [2 x [[S_FLOAT_TY]]]* [[S_ARR_PRIV]], 240 // CHECK-DAG: [[S_ARR_PTR_ALLOC:%.+]] = phi{{.+}} [ [[S_ARR_PRIV_BGN]], {{.+}} ], [ [[S_ARR_NEXT:%.+]], {{.+}} ] 241 // CHECK-DAG: call void @{{.+}}({{.+}} [[S_ARR_PTR_ALLOC]]) 242 // CHECK-DAG: [[S_ARR_NEXT]] = getelementptr {{.+}} [[S_ARR_PTR_ALLOC]], 243 244 // private(var) 245 // CHECK-DAG: call void @{{.+}}({{.+}} [[VAR_PRIV]]) 246 247 // CHECK: call void @__kmpc_for_static_init_4( 248 // CHECK-DAG: {{.+}} = {{.+}} [[T_VAR_PRIV]] 249 // CHECK-DAG: {{.+}} = {{.+}} [[VEC_PRIV]] 250 // CHECK-DAG: {{.+}} = {{.+}} [[S_ARR_PRIV]] 251 // CHECK-DAG: {{.+}} = {{.+}} [[VAR_PRIV]] 252 // CHECK-DAG: {{.+}} = {{.+}} [[SIVAR_PRIV]] 253 // CHECK: call void @__kmpc_for_static_fini( 254 // CHECK: ret void 255 256 // CHECK: define{{.*}} i{{[0-9]+}} @[[TMAIN_INT]]() 257 // CHECK: call i32 @__tgt_target_teams_mapper(i64 -1, i8* @{{[^,]+}}, i32 0, 258 // CHECK: call void @[[TOFFL1:.+]]() 259 // CHECK: ret 260 261 // CHECK: define {{.*}}void @[[TOFFL1]]() 262 // CHECK: call void {{.+}} @__kmpc_fork_teams({{.+}}, i32 0, {{.+}} @[[TOUTL1:.+]] to {{.+}}) 263 // CHECK: ret void 264 265 // CHECK: define internal void @[[TOUTL1]]({{.+}}) 266 // Skip global, bound tid and loop vars 267 // CHECK: {{.+}} = alloca i32*, 268 // CHECK: {{.+}} = alloca i32*, 269 // CHECK: alloca i{{[0-9]+}}, 270 // CHECK: alloca i{{[0-9]+}}, 271 // CHECK: alloca i{{[0-9]+}}, 272 // CHECK: alloca i{{[0-9]+}}, 273 // CHECK: alloca i{{[0-9]+}}, 274 // CHECK: alloca i32, 275 // CHECK: [[T_VAR_PRIV:%.+]] = alloca i{{[0-9]+}}, 276 // CHECK: [[VEC_PRIV:%.+]] = alloca [2 x i{{[0-9]+}}], 277 // CHECK: [[S_ARR_PRIV:%.+]] = alloca [2 x [[S_INT_TY]]], 278 // CHECK: [[VAR_PRIV:%.+]] = alloca [[S_INT_TY]], 279 // CHECK: [[TMP:%.+]] = alloca [[S_INT_TY]]*, 280 281 // private(s_arr) 282 // CHECK-DAG: [[S_ARR_PRIV_BGN:%.+]] = getelementptr{{.*}} [2 x [[S_INT_TY]]], [2 x [[S_INT_TY]]]* [[S_ARR_PRIV]], 283 // CHECK-DAG: [[S_ARR_PTR_ALLOC:%.+]] = phi{{.+}} [ [[S_ARR_PRIV_BGN]], {{.+}} ], [ [[S_ARR_NEXT:%.+]], {{.+}} ] 284 // CHECK-DAG: call void @{{.+}}({{.+}} [[S_ARR_PTR_ALLOC]]) 285 // CHECK-DAG: [[S_ARR_NEXT]] = getelementptr {{.+}} [[S_ARR_PTR_ALLOC]], 286 287 // CHECK-DAG: [[S_ARR_PRIV_BGN:%.+]] = getelementptr{{.*}} [2 x [[S_INT_TY]]], [2 x [[S_INT_TY]]]* [[S_ARR_PRIV]], 288 // CHECK-DAG: [[S_ARR_PTR_ALLOC:%.+]] = phi{{.+}} [ [[S_ARR_PRIV_BGN]], {{.+}} ], [ [[S_ARR_NEXT:%.+]], {{.+}} ] 289 // CHECK-DAG: call void @{{.+}}({{.+}} [[S_ARR_PTR_ALLOC]]) 290 // CHECK-DAG: [[S_ARR_NEXT]] = getelementptr {{.+}} [[S_ARR_PTR_ALLOC]], 291 292 // private(var) 293 // CHECK-DAG: call void @{{.+}}({{.+}} [[VAR_PRIV]]) 294 // CHECK-DAG: store{{.+}} [[VAR_PRIV]], {{.+}} [[TMP]] 295 296 // CHECK: call void @__kmpc_for_static_init_4( 297 // CHECK: call void {{.+}} @__kmpc_fork_call({{.+}}, {{.+}}, {{.+}} @[[TPAR_OUTL1:.+]] to 298 // CHECK: call void @__kmpc_for_static_fini( 299 // CHECK: ret void 300 301 // CHECK: define internal void @[[TPAR_OUTL1]]({{.+}}) 302 // Skip global, bound tid and loop vars 303 // CHECK: {{.+}} = alloca i32*, 304 // CHECK: {{.+}} = alloca i32*, 305 // prev lb and ub 306 // CHECK: alloca i{{[0-9]+}}, 307 // CHECK: alloca i{{[0-9]+}}, 308 // iter variables 309 // CHECK: alloca i{{[0-9]+}}, 310 // CHECK: alloca i{{[0-9]+}}, 311 // CHECK: alloca i{{[0-9]+}}, 312 // CHECK: alloca i{{[0-9]+}}, 313 // CHECK: alloca i{{[0-9]+}}, 314 // CHECK: alloca i32, 315 // CHECK: [[T_VAR_PRIV:%.+]] = alloca i{{[0-9]+}}, 316 // CHECK: [[VEC_PRIV:%.+]] = alloca [2 x i{{[0-9]+}}], 317 // CHECK: [[S_ARR_PRIV:%.+]] = alloca [2 x [[S_INT_TY]]], 318 // CHECK: [[VAR_PRIV:%.+]] = alloca [[S_INT_TY]], 319 // CHECK: [[TMP:%.+]] = alloca [[S_INT_TY]]*, 320 321 // private(s_arr) 322 // CHECK-DAG: [[S_ARR_PRIV_BGN:%.+]] = getelementptr{{.*}} [2 x [[S_INT_TY]]], [2 x [[S_INT_TY]]]* [[S_ARR_PRIV]], 323 // CHECK-DAG: [[S_ARR_PTR_ALLOC:%.+]] = phi{{.+}} [ [[S_ARR_PRIV_BGN]], {{.+}} ], [ [[S_ARR_NEXT:%.+]], {{.+}} ] 324 // CHECK-DAG: call void @{{.+}}({{.+}} [[S_ARR_PTR_ALLOC]]) 325 // CHECK-DAG: [[S_ARR_NEXT]] = getelementptr {{.+}} [[S_ARR_PTR_ALLOC]], 326 327 // CHECK-DAG: [[S_ARR_PRIV_BGN:%.+]] = getelementptr{{.*}} [2 x [[S_INT_TY]]], [2 x [[S_INT_TY]]]* [[S_ARR_PRIV]], 328 // CHECK-DAG: [[S_ARR_PTR_ALLOC:%.+]] = phi{{.+}} [ [[S_ARR_PRIV_BGN]], {{.+}} ], [ [[S_ARR_NEXT:%.+]], {{.+}} ] 329 // CHECK-DAG: call void @{{.+}}({{.+}} [[S_ARR_PTR_ALLOC]]) 330 // CHECK-DAG: [[S_ARR_NEXT]] = getelementptr {{.+}} [[S_ARR_PTR_ALLOC]], 331 332 // private(var) 333 // CHECK-DAG: call void @{{.+}}({{.+}} [[VAR_PRIV]]) 334 // CHECK-DAG: store{{.+}} [[VAR_PRIV]], {{.+}} [[TMP]] 335 336 // CHECK: call void @__kmpc_for_static_init_4( 337 // CHECK-DAG: {{.+}} = {{.+}} [[T_VAR_PRIV]] 338 // CHECK-DAG: {{.+}} = {{.+}} [[VEC_PRIV]] 339 // CHECK-DAG: {{.+}} = {{.+}} [[S_ARR_PRIV]] 340 // CHECK-DAG: {{.+}} = {{.+}} [[TMP]] 341 // CHECK: call void @__kmpc_for_static_fini( 342 // CHECK: ret void 343 344 345 #endif 346