diff options
Diffstat (limited to 'test/OpenMP/critical_codegen.cpp')
| -rw-r--r-- | test/OpenMP/critical_codegen.cpp | 30 | 
1 files changed, 25 insertions, 5 deletions
| diff --git a/test/OpenMP/critical_codegen.cpp b/test/OpenMP/critical_codegen.cpp index dda532ca369b..d350d6e3aaea 100644 --- a/test/OpenMP/critical_codegen.cpp +++ b/test/OpenMP/critical_codegen.cpp @@ -1,6 +1,7 @@ -// RUN: %clang_cc1 -verify -fopenmp=libiomp5 -x c++ -emit-llvm %s -fexceptions -fcxx-exceptions -o - | FileCheck %s -// RUN: %clang_cc1 -fopenmp=libiomp5 -x c++ -std=c++11 -triple x86_64-unknown-unknown -fexceptions -fcxx-exceptions -emit-pch -o %t %s -// RUN: %clang_cc1 -fopenmp=libiomp5 -x c++ -triple x86_64-unknown-unknown -fexceptions -fcxx-exceptions -std=c++11 -include-pch %t -verify %s -emit-llvm -o - | FileCheck %s +// RUN: %clang_cc1 -verify -fopenmp -x c++ -emit-llvm %s -fexceptions -fcxx-exceptions -o - | FileCheck %s +// RUN: %clang_cc1 -fopenmp -x c++ -std=c++11 -triple x86_64-unknown-unknown -fexceptions -fcxx-exceptions -emit-pch -o %t %s +// RUN: %clang_cc1 -fopenmp -x c++ -triple x86_64-unknown-unknown -fexceptions -fcxx-exceptions -std=c++11 -include-pch %t -verify %s -emit-llvm -o - | FileCheck %s +// RUN: %clang_cc1 -verify -triple x86_64-apple-darwin10 -fopenmp -fexceptions -fcxx-exceptions -gline-tables-only -x c++ -emit-llvm %s -o - | FileCheck %s --check-prefix=TERM_DEBUG  // expected-no-diagnostics  #ifndef HEADER @@ -15,6 +16,7 @@  void foo() {}  // CHECK-LABEL: @main +// TERM_DEBUG-LABEL: @main  int main() {  // CHECK:       [[A_ADDR:%.+]] = alloca i8    char a; @@ -26,8 +28,8 @@ int main() {  #pragma omp critical    a = 2;  // CHECK:       call void @__kmpc_critical([[IDENT_T_TY]]* [[DEFAULT_LOC]], i32 [[GTID]], [8 x i32]* [[THE_NAME_LOCK]]) -// CHECK-NEXT:  call void [[FOO]]() -// CHECK-NEXT:  call void @__kmpc_end_critical([[IDENT_T_TY]]* [[DEFAULT_LOC]], i32 [[GTID]], [8 x i32]* [[THE_NAME_LOCK]]) +// CHECK-NEXT:  invoke void [[FOO]]() +// CHECK:       call void @__kmpc_end_critical([[IDENT_T_TY]]* [[DEFAULT_LOC]], i32 [[GTID]], [8 x i32]* [[THE_NAME_LOCK]])  #pragma omp critical(the_name)    foo();  // CHECK-NOT:   call void @__kmpc_critical @@ -35,4 +37,22 @@ int main() {    return a;  } +// CHECK-LABEL:      parallel_critical +// TERM_DEBUG-LABEL: parallel_critical +void parallel_critical() { +#pragma omp parallel +#pragma omp critical +  // TERM_DEBUG-NOT: __kmpc_global_thread_num +  // TERM_DEBUG:     call void @__kmpc_critical({{.+}}), !dbg [[DBG_LOC_START:![0-9]+]] +  // TERM_DEBUG:     invoke void {{.*}}foo{{.*}}() +  // TERM_DEBUG:     unwind label %[[TERM_LPAD:.+]], +  // TERM_DEBUG-NOT: __kmpc_global_thread_num +  // TERM_DEBUG:     call void @__kmpc_end_critical({{.+}}), !dbg [[DBG_LOC_END:![0-9]+]] +  // TERM_DEBUG:     [[TERM_LPAD]] +  // TERM_DEBUG:     call void @__clang_call_terminate +  // TERM_DEBUG:     unreachable +  foo(); +} +// TERM_DEBUG-DAG: [[DBG_LOC_START]] = !DILocation(line: [[@LINE-12]], +// TERM_DEBUG-DAG: [[DBG_LOC_END]] = !DILocation(line: [[@LINE-3]],  #endif | 
