1e46f0feeSAlexey Bataev // RUN: %clang_cc1 -verify -triple x86_64-apple-darwin10 -fopenmp -fopenmp-version=50 -emit-llvm -o - %s | FileCheck %s 2e46f0feeSAlexey Bataev // RUN: %clang_cc1 -fopenmp -triple x86_64-apple-darwin10 -fopenmp-version=50 -x c++ -std=c++11 -emit-pch -o %t %s 3e46f0feeSAlexey Bataev // RUN: %clang_cc1 -fopenmp -triple x86_64-apple-darwin10 -fopenmp-version=50 -std=c++11 -include-pch %t -verify %s -emit-llvm -o - | FileCheck %s 4e46f0feeSAlexey Bataev 5e46f0feeSAlexey Bataev // RUN: %clang_cc1 -verify -triple x86_64-apple-darwin10 -fopenmp-simd -fopenmp-version=50 -emit-llvm -o - %s | FileCheck --check-prefix SIMD-ONLY0 %s 6e46f0feeSAlexey Bataev // RUN: %clang_cc1 -fopenmp-simd -triple x86_64-apple-darwin10 -fopenmp-version=50 -x c++ -std=c++11 -emit-pch -o %t %s 7e46f0feeSAlexey Bataev // RUN: %clang_cc1 -fopenmp-simd -triple x86_64-apple-darwin10 -fopenmp-version=50 -std=c++11 -include-pch %t -verify %s -emit-llvm -o - | FileCheck --check-prefix SIMD-ONLY0 %s 8e46f0feeSAlexey Bataev // SIMD-ONLY0-NOT: {{__kmpc|__tgt}} 9e46f0feeSAlexey Bataev // expected-no-diagnostics 10e46f0feeSAlexey Bataev 11e46f0feeSAlexey Bataev #ifndef HEADER 12e46f0feeSAlexey Bataev #define HEADER 13e46f0feeSAlexey Bataev 14e46f0feeSAlexey Bataev // CHECK-DAG: [[MAIN_A:@.+]] = internal global i8* null, 15e46f0feeSAlexey Bataev // CHECK-DAG: [[TMAIN_A:@.+]] = linkonce_odr global i8* null, 16e46f0feeSAlexey Bataev 17e46f0feeSAlexey Bataev typedef void *omp_depend_t; 18e46f0feeSAlexey Bataev 19e46f0feeSAlexey Bataev void foo() {} 20e46f0feeSAlexey Bataev 21e46f0feeSAlexey Bataev template <class T> 22e46f0feeSAlexey Bataev T tmain(T argc) { 23e46f0feeSAlexey Bataev static T a; 245dadf577SAlexey Bataev void *argv; 25*7842e7ebSAlexey Bataev #pragma omp depobj(a) depend(in:argv, ([3][*(int*)argv][4])argv) 26e46f0feeSAlexey Bataev #pragma omp depobj(argc) destroy 27e46f0feeSAlexey Bataev #pragma omp depobj(argc) update(inout) 28e46f0feeSAlexey Bataev return argc; 29e46f0feeSAlexey Bataev } 30e46f0feeSAlexey Bataev 31e46f0feeSAlexey Bataev int main(int argc, char **argv) { 32e46f0feeSAlexey Bataev static omp_depend_t a; 33e46f0feeSAlexey Bataev omp_depend_t b; 34e46f0feeSAlexey Bataev #pragma omp depobj(a) depend(out:argc, argv) 35e46f0feeSAlexey Bataev #pragma omp depobj(b) destroy 36e46f0feeSAlexey Bataev #pragma omp depobj(b) update(mutexinoutset) 37e46f0feeSAlexey Bataev (void)tmain(a), tmain(b); 38e46f0feeSAlexey Bataev return 0; 39e46f0feeSAlexey Bataev } 40e46f0feeSAlexey Bataev 41e46f0feeSAlexey Bataev // CHECK-LABEL: @main 42b27ff4d0SAlexey Bataev // CHECK: [[B_ADDR:%.+]] = alloca i8*, 43e46f0feeSAlexey Bataev // CHECK: [[GTID:%.+]] = call i32 @__kmpc_global_thread_num( 44e46f0feeSAlexey Bataev // CHECK: [[DEP_ADDR_VOID:%.+]] = call i8* @__kmpc_alloc(i32 [[GTID]], i64 72, i8* null) 45e46f0feeSAlexey Bataev // CHECK: [[DEP_ADDR:%.+]] = bitcast i8* [[DEP_ADDR_VOID]] to [3 x %struct.kmp_depend_info]* 46e46f0feeSAlexey Bataev // CHECK: [[BASE_ADDR:%.+]] = getelementptr inbounds [3 x %struct.kmp_depend_info], [3 x %struct.kmp_depend_info]* [[DEP_ADDR]], i{{.+}} 0, i{{.+}} 0 47e46f0feeSAlexey Bataev // CHECK: [[SZ_BASE:%.+]] = getelementptr inbounds %struct.kmp_depend_info, %struct.kmp_depend_info* [[BASE_ADDR]], i{{.+}} 0, i{{.+}} 0 48e46f0feeSAlexey Bataev // CHECK: store i64 2, i64* [[SZ_BASE]], 49e46f0feeSAlexey Bataev // CHECK: [[BASE_ADDR:%.+]] = getelementptr inbounds [3 x %struct.kmp_depend_info], [3 x %struct.kmp_depend_info]* [[DEP_ADDR]], i{{.+}} 0, i{{.+}} 1 50e46f0feeSAlexey Bataev // CHECK: [[ADDR:%.+]] = getelementptr inbounds %struct.kmp_depend_info, %struct.kmp_depend_info* [[BASE_ADDR]], i{{.+}} 0, i{{.+}} 0 51e46f0feeSAlexey Bataev // CHECK: store i64 %{{.+}}, i64* [[ADDR]], 52e46f0feeSAlexey Bataev // CHECK: [[SZ_ADDR:%.+]] = getelementptr inbounds %struct.kmp_depend_info, %struct.kmp_depend_info* [[BASE_ADDR]], i{{.+}} 0, i{{.+}} 1 53e46f0feeSAlexey Bataev // CHECK: store i64 4, i64* [[SZ_ADDR]], 54e46f0feeSAlexey Bataev // CHECK: [[FLAGS_ADDR:%.+]] = getelementptr inbounds %struct.kmp_depend_info, %struct.kmp_depend_info* [[BASE_ADDR]], i{{.+}} 0, i{{.+}} 2 55e46f0feeSAlexey Bataev // CHECK: store i8 3, i8* [[FLAGS_ADDR]], 56e46f0feeSAlexey Bataev // CHECK: [[BASE_ADDR:%.+]] = getelementptr inbounds [3 x %struct.kmp_depend_info], [3 x %struct.kmp_depend_info]* [[DEP_ADDR]], i{{.+}} 0, i{{.+}} 2 57e46f0feeSAlexey Bataev // CHECK: [[ADDR:%.+]] = getelementptr inbounds %struct.kmp_depend_info, %struct.kmp_depend_info* [[BASE_ADDR]], i{{.+}} 0, i{{.+}} 0 58e46f0feeSAlexey Bataev // CHECK: store i64 %{{.+}}, i64* [[ADDR]], 59e46f0feeSAlexey Bataev // CHECK: [[SZ_ADDR:%.+]] = getelementptr inbounds %struct.kmp_depend_info, %struct.kmp_depend_info* [[BASE_ADDR]], i{{.+}} 0, i{{.+}} 1 60e46f0feeSAlexey Bataev // CHECK: store i64 8, i64* [[SZ_ADDR]], 61e46f0feeSAlexey Bataev // CHECK: [[FLAGS_ADDR:%.+]] = getelementptr inbounds %struct.kmp_depend_info, %struct.kmp_depend_info* [[BASE_ADDR]], i{{.+}} 0, i{{.+}} 2 62e46f0feeSAlexey Bataev // CHECK: store i8 3, i8* [[FLAGS_ADDR]], 63ea5b3ef5SAlexey Bataev // CHECK: [[BASE_ADDR:%.+]] = getelementptr inbounds [3 x %struct.kmp_depend_info], [3 x %struct.kmp_depend_info]* [[DEP_ADDR]], i{{.+}} 0, i{{.+}} 1 64e46f0feeSAlexey Bataev // CHECK: [[DEP:%.+]] = bitcast %struct.kmp_depend_info* [[BASE_ADDR]] to i8* 65e46f0feeSAlexey Bataev // CHECK: store i8* [[DEP]], i8** [[MAIN_A]], 66b27ff4d0SAlexey Bataev // CHECK: [[B:%.+]] = load i8*, i8** [[B_ADDR]], 67ea5b3ef5SAlexey Bataev // CHECK: [[B_BASE:%.+]] = bitcast i8* [[B]] to %struct.kmp_depend_info* 68ea5b3ef5SAlexey Bataev // CHECK: [[B_REF:%.+]] = getelementptr %struct.kmp_depend_info, %struct.kmp_depend_info* [[B_BASE]], i{{.+}} -1 69ea5b3ef5SAlexey Bataev // CHECK: [[B:%.+]] = bitcast %struct.kmp_depend_info* [[B_REF]] to i8* 70b27ff4d0SAlexey Bataev // CHECK: call void @__kmpc_free(i32 [[GTID]], i8* [[B]], i8* null) 718d7b1188SAlexey Bataev // CHECK: [[B:%.+]] = load i8*, i8** [[B_ADDR]], 728d7b1188SAlexey Bataev // CHECK: [[B_BASE:%.+]] = bitcast i8* [[B]] to %struct.kmp_depend_info* 738d7b1188SAlexey Bataev // CHECK: [[NUMDEPS_BASE:%.+]] = getelementptr %struct.kmp_depend_info, %struct.kmp_depend_info* [[B_BASE]], i64 -1 748d7b1188SAlexey Bataev // CHECK: [[NUMDEPS_ADDR:%.+]] = getelementptr inbounds %struct.kmp_depend_info, %struct.kmp_depend_info* [[NUMDEPS_BASE]], i{{.+}} 0, i{{.+}} 0 758d7b1188SAlexey Bataev // CHECK: [[NUMDEPS:%.+]] = load i64, i64* [[NUMDEPS_ADDR]], 768d7b1188SAlexey Bataev // CHECK: [[END:%.+]] = getelementptr %struct.kmp_depend_info, %struct.kmp_depend_info* [[B_BASE]], i64 [[NUMDEPS]] 778d7b1188SAlexey Bataev // CHECK: br label %[[BODY:.+]] 788d7b1188SAlexey Bataev // CHECK: [[BODY]]: 798d7b1188SAlexey Bataev // CHECK: [[EL:%.+]] = phi %struct.kmp_depend_info* [ [[B_BASE]], %{{.+}} ], [ [[EL_NEXT:%.+]], %[[BODY]] ] 808d7b1188SAlexey Bataev // CHECK: [[FLAG_BASE:%.+]] = getelementptr inbounds %struct.kmp_depend_info, %struct.kmp_depend_info* [[EL]], i{{.+}} 0, i{{.+}} 2 818d7b1188SAlexey Bataev // CHECK: store i8 4, i8* [[FLAG_BASE]], 828d7b1188SAlexey Bataev // CHECK: [[EL_NEXT]] = getelementptr %struct.kmp_depend_info, %struct.kmp_depend_info* [[EL]], i{{.+}} 1 838d7b1188SAlexey Bataev // CHECK: [[IS_DONE:%.+]] = icmp eq %struct.kmp_depend_info* [[EL_NEXT]], [[END]] 848d7b1188SAlexey Bataev // CHECK: br i1 [[IS_DONE]], label %[[DONE:.+]], label %[[BODY]] 858d7b1188SAlexey Bataev // CHECK: [[DONE]]: 86e46f0feeSAlexey Bataev 87e46f0feeSAlexey Bataev // CHECK-LABEL: tmain 88b27ff4d0SAlexey Bataev // CHECK: [[ARGC_ADDR:%.+]] = alloca i8*, 89e46f0feeSAlexey Bataev // CHECK: [[GTID:%.+]] = call i32 @__kmpc_global_thread_num( 90*7842e7ebSAlexey Bataev // CHECK: [[DEP_ADDR_VOID:%.+]] = call i8* @__kmpc_alloc(i32 [[GTID]], i64 72, i8* null) 91*7842e7ebSAlexey Bataev // CHECK: [[DEP_ADDR:%.+]] = bitcast i8* [[DEP_ADDR_VOID]] to [3 x %struct.kmp_depend_info]* 92*7842e7ebSAlexey Bataev // CHECK: [[BASE_ADDR:%.+]] = getelementptr inbounds [3 x %struct.kmp_depend_info], [3 x %struct.kmp_depend_info]* [[DEP_ADDR]], i{{.+}} 0, i{{.+}} 0 93e46f0feeSAlexey Bataev // CHECK: [[SZ_BASE:%.+]] = getelementptr inbounds %struct.kmp_depend_info, %struct.kmp_depend_info* [[BASE_ADDR]], i{{.+}} 0, i{{.+}} 0 94*7842e7ebSAlexey Bataev // CHECK: store i64 2, i64* [[SZ_BASE]], 95*7842e7ebSAlexey Bataev // CHECK: [[BASE_ADDR:%.+]] = getelementptr inbounds [3 x %struct.kmp_depend_info], [3 x %struct.kmp_depend_info]* [[DEP_ADDR]], i{{.+}} 0, i{{.+}} 1 96e46f0feeSAlexey Bataev // CHECK: [[ADDR:%.+]] = getelementptr inbounds %struct.kmp_depend_info, %struct.kmp_depend_info* [[BASE_ADDR]], i{{.+}} 0, i{{.+}} 0 97e46f0feeSAlexey Bataev // CHECK: store i64 %{{.+}}, i64* [[ADDR]], 98e46f0feeSAlexey Bataev // CHECK: [[SZ_ADDR:%.+]] = getelementptr inbounds %struct.kmp_depend_info, %struct.kmp_depend_info* [[BASE_ADDR]], i{{.+}} 0, i{{.+}} 1 99e46f0feeSAlexey Bataev // CHECK: store i64 8, i64* [[SZ_ADDR]], 100e46f0feeSAlexey Bataev // CHECK: [[FLAGS_ADDR:%.+]] = getelementptr inbounds %struct.kmp_depend_info, %struct.kmp_depend_info* [[BASE_ADDR]], i{{.+}} 0, i{{.+}} 2 101e46f0feeSAlexey Bataev // CHECK: store i8 1, i8* [[FLAGS_ADDR]], 102*7842e7ebSAlexey Bataev // CHECK: [[SHAPE_ADDR:%.+]] = load i8*, i8** [[ARGV_ADDR:%.+]], 103*7842e7ebSAlexey Bataev // CHECK: [[SZ1:%.+]] = mul nuw i64 3, %{{.+}} 104*7842e7ebSAlexey Bataev // CHECK: [[SZ:%.+]] = mul nuw i64 [[SZ1]], 4 105*7842e7ebSAlexey Bataev // CHECK: [[BASE_ADDR:%.+]] = getelementptr inbounds [3 x %struct.kmp_depend_info], [3 x %struct.kmp_depend_info]* [[DEP_ADDR]], i{{.+}} 0, i{{.+}} 2 106*7842e7ebSAlexey Bataev // CHECK: [[ADDR:%.+]] = getelementptr inbounds %struct.kmp_depend_info, %struct.kmp_depend_info* [[BASE_ADDR]], i{{.+}} 0, i{{.+}} 0 107*7842e7ebSAlexey Bataev // CHECK: [[SHAPE:%.+]] = ptrtoint i8* [[SHAPE_ADDR]] to i64 108*7842e7ebSAlexey Bataev // CHECK: store i64 [[SHAPE]], i64* [[ADDR]], 109*7842e7ebSAlexey Bataev // CHECK: [[SZ_ADDR:%.+]] = getelementptr inbounds %struct.kmp_depend_info, %struct.kmp_depend_info* [[BASE_ADDR]], i{{.+}} 0, i{{.+}} 1 110*7842e7ebSAlexey Bataev // CHECK: store i64 [[SZ]], i64* [[SZ_ADDR]], 111*7842e7ebSAlexey Bataev // CHECK: [[FLAGS_ADDR:%.+]] = getelementptr inbounds %struct.kmp_depend_info, %struct.kmp_depend_info* [[BASE_ADDR]], i{{.+}} 0, i{{.+}} 2 112*7842e7ebSAlexey Bataev // CHECK: store i8 1, i8* [[FLAGS_ADDR]], 113*7842e7ebSAlexey Bataev // CHECK: [[BASE_ADDR:%.+]] = getelementptr inbounds [3 x %struct.kmp_depend_info], [3 x %struct.kmp_depend_info]* [[DEP_ADDR]], i{{.+}} 0, i{{.+}} 1 114e46f0feeSAlexey Bataev // CHECK: [[DEP:%.+]] = bitcast %struct.kmp_depend_info* [[BASE_ADDR]] to i8* 115e46f0feeSAlexey Bataev // CHECK: store i8* [[DEP]], i8** [[TMAIN_A]], 116b27ff4d0SAlexey Bataev // CHECK: [[ARGC:%.+]] = load i8*, i8** [[ARGC_ADDR]], 117ea5b3ef5SAlexey Bataev // CHECK: [[ARGC_BASE:%.+]] = bitcast i8* [[ARGC]] to %struct.kmp_depend_info* 118ea5b3ef5SAlexey Bataev // CHECK: [[ARGC_REF:%.+]] = getelementptr %struct.kmp_depend_info, %struct.kmp_depend_info* [[ARGC_BASE]], i{{.+}} -1 119ea5b3ef5SAlexey Bataev // CHECK: [[ARGC:%.+]] = bitcast %struct.kmp_depend_info* [[ARGC_REF]] to i8* 120b27ff4d0SAlexey Bataev // CHECK: call void @__kmpc_free(i32 [[GTID]], i8* [[ARGC]], i8* null) 1218d7b1188SAlexey Bataev // CHECK: [[ARGC:%.+]] = load i8*, i8** [[ARGC_ADDR]], 1228d7b1188SAlexey Bataev // CHECK: [[ARGC_BASE:%.+]] = bitcast i8* [[ARGC]] to %struct.kmp_depend_info* 1238d7b1188SAlexey Bataev // CHECK: [[NUMDEPS_BASE:%.+]] = getelementptr %struct.kmp_depend_info, %struct.kmp_depend_info* [[ARGC_BASE]], i64 -1 1248d7b1188SAlexey Bataev // CHECK: [[NUMDEPS_ADDR:%.+]] = getelementptr inbounds %struct.kmp_depend_info, %struct.kmp_depend_info* [[NUMDEPS_BASE]], i{{.+}} 0, i{{.+}} 0 1258d7b1188SAlexey Bataev // CHECK: [[NUMDEPS:%.+]] = load i64, i64* [[NUMDEPS_ADDR]], 1268d7b1188SAlexey Bataev // CHECK: [[END:%.+]] = getelementptr %struct.kmp_depend_info, %struct.kmp_depend_info* [[ARGC_BASE]], i64 [[NUMDEPS]] 1278d7b1188SAlexey Bataev // CHECK: br label %[[BODY:.+]] 1288d7b1188SAlexey Bataev // CHECK: [[BODY]]: 1298d7b1188SAlexey Bataev // CHECK: [[EL:%.+]] = phi %struct.kmp_depend_info* [ [[ARGC_BASE]], %{{.+}} ], [ [[EL_NEXT:%.+]], %[[BODY]] ] 1308d7b1188SAlexey Bataev // CHECK: [[FLAG_BASE:%.+]] = getelementptr inbounds %struct.kmp_depend_info, %struct.kmp_depend_info* [[EL]], i{{.+}} 0, i{{.+}} 2 1318d7b1188SAlexey Bataev // CHECK: store i8 3, i8* [[FLAG_BASE]], 1328d7b1188SAlexey Bataev // CHECK: [[EL_NEXT]] = getelementptr %struct.kmp_depend_info, %struct.kmp_depend_info* [[EL]], i{{.+}} 1 1338d7b1188SAlexey Bataev // CHECK: [[IS_DONE:%.+]] = icmp eq %struct.kmp_depend_info* [[EL_NEXT]], [[END]] 1348d7b1188SAlexey Bataev // CHECK: br i1 [[IS_DONE]], label %[[DONE:.+]], label %[[BODY]] 1358d7b1188SAlexey Bataev // CHECK: [[DONE]]: 136e46f0feeSAlexey Bataev 137e46f0feeSAlexey Bataev #endif 138