mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-27 00:26:06 +00:00

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
28 lines
894 B
C++
28 lines
894 B
C++
// RUN: %clang_cc1 -no-opaque-pointers -triple armv7-apple-ios -emit-llvm -o - %s | FileCheck %s
|
|
struct Empty {};
|
|
|
|
Empty emptyvar;
|
|
|
|
int take_args(int a, ...) {
|
|
__builtin_va_list l;
|
|
__builtin_va_start(l, a);
|
|
// CHECK: call void @llvm.va_start
|
|
|
|
emptyvar = __builtin_va_arg(l, Empty);
|
|
// CHECK: load i8*, i8**
|
|
// CHECK-NOT: getelementptr
|
|
// CHECK: [[EMPTY_PTR:%[a-zA-Z0-9._]+]] = bitcast i8* {{%[a-zA-Z0-9._]+}} to %struct.Empty*
|
|
|
|
// It's conceivable that EMPTY_PTR may not actually be a valid pointer
|
|
// (e.g. it's at the very bottom of the stack and the next page is
|
|
// invalid). This doesn't matter provided it's never loaded (there's no
|
|
// well-defined way to tell), but it becomes a problem if we do try to use it.
|
|
// CHECK-NOT: load %struct.Empty, %struct.Empty* [[EMPTY_PTR]]
|
|
|
|
int i = __builtin_va_arg(l, int);
|
|
// CHECK: load i32, i32*
|
|
|
|
__builtin_va_end(l);
|
|
return i;
|
|
}
|