
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
21 lines
734 B
C
21 lines
734 B
C
// RUN: %clang_cc1 -no-opaque-pointers %s -emit-llvm -o - -fblocks -triple x86_64-apple-darwin10 | FileCheck %s
|
|
// rdar://10033986
|
|
|
|
typedef void (^BLOCK)(void);
|
|
int main (void)
|
|
{
|
|
_Complex double c;
|
|
BLOCK b = ^() {
|
|
_Complex double z;
|
|
z = z + c;
|
|
};
|
|
b();
|
|
}
|
|
|
|
// CHECK-LABEL: define internal void @__main_block_invoke
|
|
// CHECK: [[C1:%.*]] = alloca { double, double }, align 8
|
|
// CHECK: [[RP:%.*]] = getelementptr inbounds { double, double }, { double, double }* [[C1]], i32 0, i32 0
|
|
// CHECK-NEXT: [[R:%.*]] = load double, double* [[RP]]
|
|
// CHECK-NEXT: [[IP:%.*]] = getelementptr inbounds { double, double }, { double, double }* [[C1]], i32 0, i32 1
|
|
// CHECK-NEXT: [[I:%.*]] = load double, double* [[IP]]
|