This makes the C++ ABI depend entirely on the target: MS ABI for -win32 triples, Itanium otherwise. It's no longer possible to do weird combinations. To be able to run a test with a specific ABI without constraining it to a specific triple, new substitutions are added to lit: %itanium_abi_triple and %ms_abi_triple can be used to get the current target triple adjusted to the desired ABI. For example, if the test suite is running with the i686-pc-win32 target, %itanium_abi_triple will expand to i686-pc-mingw32. Differential Revision: http://llvm-reviews.chandlerc.com/D2545 llvm-svn: 199250
29 lines
1.1 KiB
C++
29 lines
1.1 KiB
C++
// RUN: %clang_cc1 -triple %itanium_abi_triple -emit-llvm -o - -fsanitize=thread %s | FileCheck %s
|
|
// RUN: %clang_cc1 -triple %itanium_abi_triple -emit-llvm -o - -O1 %s | FileCheck %s
|
|
// RUN: %clang_cc1 -triple %itanium_abi_triple -emit-llvm -o - -O1 -relaxed-aliasing -fsanitize=thread %s | FileCheck %s
|
|
//
|
|
// RUN: %clang_cc1 -triple %itanium_abi_triple -emit-llvm -o - %s | FileCheck %s --check-prefix=NOTBAA
|
|
// RUN: %clang_cc1 -triple %itanium_abi_triple -emit-llvm -o - -O2 -relaxed-aliasing %s | FileCheck %s --check-prefix=NOTBAA
|
|
//
|
|
// Check that we generate TBAA for vtable pointer loads and stores.
|
|
// When -fthread-sanitizer is used TBAA should be generated at all opt levels
|
|
// even if -relaxed-aliasing is present.
|
|
struct A {
|
|
virtual int foo() const ;
|
|
virtual ~A();
|
|
};
|
|
|
|
void CreateA() {
|
|
new A;
|
|
}
|
|
|
|
void CallFoo(A *a) {
|
|
a->foo();
|
|
}
|
|
|
|
// CHECK: %{{.*}} = load {{.*}} !tbaa ![[NUM:[0-9]+]]
|
|
// CHECK: store {{.*}} !tbaa ![[NUM]]
|
|
// CHECK: [[NUM]] = metadata !{metadata [[TYPE:!.*]], metadata [[TYPE]], i64 0}
|
|
// CHECK: [[TYPE]] = metadata !{metadata !"vtable pointer", metadata !{{.*}}
|
|
// NOTBAA-NOT: = metadata !{metadata !"Simple C/C++ TBAA"}
|