2018-01-03 05:34:16 +08:00
|
|
|
// RUN: %clang_cc1 -verify -fopenmp -x c++ -triple x86_64-pc-windows-msvc18.0.0 -std=c++11 -fms-compatibility-version=18 -fms-extensions -emit-llvm %s -fexceptions -fcxx-exceptions -o - | FileCheck %s
|
|
|
|
|
|
|
|
// RUN: %clang_cc1 -verify -fopenmp-simd -x c++ -triple x86_64-pc-windows-msvc18.0.0 -std=c++11 -fms-compatibility-version=18 -fms-extensions -emit-llvm %s -fexceptions -fcxx-exceptions -o - | FileCheck --check-prefix SIMD-ONLY0 %s
|
2017-12-30 02:07:07 +08:00
|
|
|
|
|
|
|
// SIMD-ONLY0-NOT: {{__kmpc|__tgt}}
|
2017-11-02 22:25:34 +08:00
|
|
|
// expected-no-diagnostics
|
|
|
|
|
|
|
|
void foo();
|
|
|
|
void bar();
|
|
|
|
|
2017-11-03 02:55:05 +08:00
|
|
|
struct Test {
|
|
|
|
static void main() {
|
|
|
|
int failed = 0;
|
|
|
|
int j = 2;
|
|
|
|
|
|
|
|
#pragma omp parallel
|
|
|
|
{
|
|
|
|
int local_j = 3;
|
|
|
|
#pragma omp single copyprivate(local_j)
|
|
|
|
{
|
|
|
|
local_j = 4;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Assure reports a data race, but value written to "j"
|
|
|
|
// should always be the same.
|
|
|
|
j = local_j;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2017-11-02 22:25:34 +08:00
|
|
|
// CHECK-LABEL: @main
|
|
|
|
int main() {
|
2017-11-03 02:55:05 +08:00
|
|
|
// CHECK: call void @{{.+}}main
|
|
|
|
Test::main();
|
|
|
|
// CHECK: call void (%ident_t*, i32, void (i32*, i32*, ...)*, ...) @__kmpc_fork_call(%ident_t* {{.*}}@0, i32 0, void (i32*, i32*, ...)* bitcast (void (i32*, i32*)* [[OUTLINED:@.+]] to void (i32*, i32*, ...)*))
|
2017-11-02 22:25:34 +08:00
|
|
|
#pragma omp parallel
|
|
|
|
{
|
|
|
|
try {
|
|
|
|
foo();
|
|
|
|
} catch (int t) {
|
|
|
|
#pragma omp critical
|
|
|
|
{
|
|
|
|
bar();
|
|
|
|
};
|
|
|
|
}
|
|
|
|
};
|
|
|
|
// CHECK: ret i32 0
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
// CHECK: define internal void [[OUTLINED]](
|
2017-11-03 02:55:05 +08:00
|
|
|
// CHECK: [[GID:%.+]] = {{.*}}call i32 @__kmpc_global_thread_num(%ident_t* {{.*}}@0)
|
2017-11-02 22:25:34 +08:00
|
|
|
// CHECK: invoke void @{{.+}}foo
|
2018-01-03 05:34:16 +08:00
|
|
|
// CHECK: [[CATCHSWITCH:%.+]] = catchswitch within none
|
|
|
|
// CHECK: [[CATCHPAD:%.+]] = catchpad within [[CATCHSWITCH]]
|
2017-11-03 02:55:05 +08:00
|
|
|
// CHECK: call void @__kmpc_critical(%ident_t* {{.*}}@0, i32 [[GID]],
|
2017-11-02 22:25:34 +08:00
|
|
|
// CHECK: invoke void @{{.+}}bar
|
2017-11-03 02:55:05 +08:00
|
|
|
// CHECK: call void @__kmpc_end_critical(%ident_t* {{.*}}@0, i32 [[GID]],
|
2018-01-03 05:34:16 +08:00
|
|
|
// CHECK: catchret from [[CATCHPAD]] to
|
|
|
|
// CHECK: cleanuppad within [[CATCHPAD]] []
|
|
|
|
// CHECK-NEXT: call void @__kmpc_end_critical(%ident_t* {{.*}}@0, i32 [[GID]],
|
|
|
|
// CHECK-NEXT: cleanupret from {{.*}} unwind label %[[CATCHTERM:[^ ]+]]
|
|
|
|
// CHECK: cleanuppad within none []
|
2018-03-17 04:36:49 +08:00
|
|
|
// CHECK-NEXT: call void @"?terminate@@YAXXZ"() #5 [ "funclet"(token %{{.*}}) ]
|
2018-01-03 05:34:16 +08:00
|
|
|
// CHECK-NEXT: unreachable
|
|
|
|
// CHECK: [[CATCHTERM]]
|
|
|
|
// CHECK-NEXT: cleanuppad within [[CATCHPAD]] []
|
2018-03-17 04:36:49 +08:00
|
|
|
// CHECK-NEXT: call void @"?terminate@@YAXXZ"() #5 [ "funclet"(token %{{.*}}) ]
|
2018-01-03 05:34:16 +08:00
|
|
|
// CHECK-NEXT: unreachable
|