This adds -no-opaque-pointers to clang tests whose output will change when opaque pointers are enabled by default. This is intended to be part of the migration approach described in https://discourse.llvm.org/t/enabling-opaque-pointers-by-default/61322/9. The patch has been produced by replacing %clang_cc1 with %clang_cc1 -no-opaque-pointers for tests that fail with opaque pointers enabled. Worth noting that this doesn't cover all tests, there's a remaining ~40 tests not using %clang_cc1 that will need a followup change. Differential Revision: https://reviews.llvm.org/D123115
32 lines
1.1 KiB
C++
32 lines
1.1 KiB
C++
// RUN: %clang_cc1 -no-opaque-pointers -triple powerpc-ibm-aix-xcoff -x c++ -emit-llvm \
|
|
// RUN: -fno-use-cxa-atexit < %s |\
|
|
// RUN: FileCheck %s
|
|
// RUN: %clang_cc1 -no-opaque-pointers -triple powerpc64-ibm-aix-xcoff -x c++ -emit-llvm \
|
|
// RUN: -fno-use-cxa-atexit < %s | \
|
|
// RUN: FileCheck %s
|
|
|
|
// CHECK: @llvm.global_ctors = appending global [4 x { i32, void ()*, i8* }] [{ i32, void ()*, i8* } { i32 65535, void ()* bitcast (i32 ()* @_Z4foo3v to void ()*), i8* null }, { i32, void ()*, i8* } { i32 180, void ()* bitcast (i32 ()* @_Z4foo2v to void ()*), i8* null }, { i32, void ()*, i8* } { i32 180, void ()* bitcast (i32 ()* @_Z3foov to void ()*), i8* null }, { i32, void ()*, i8* } { i32 65535, void ()* @_GLOBAL__sub_I__, i8* null }]
|
|
// CHECK: @llvm.global_dtors = appending global [1 x { i32, void ()*, i8* }] [{ i32, void ()*, i8* } { i32 65535, void ()* @_GLOBAL__D_a, i8* null }]
|
|
|
|
int foo() __attribute__((constructor(180)));
|
|
int foo2() __attribute__((constructor(180)));
|
|
int foo3() __attribute__((constructor(65535)));
|
|
|
|
struct Test {
|
|
public:
|
|
Test() {}
|
|
~Test() {}
|
|
} t;
|
|
|
|
int foo3() {
|
|
return 3;
|
|
}
|
|
|
|
int foo2() {
|
|
return 2;
|
|
}
|
|
|
|
int foo() {
|
|
return 1;
|
|
}
|