1 // RUN: %clang_cc1 %s -triple=thumbv7k-apple-watchos -emit-llvm -o - -target-abi aapcs16 | FileCheck %s
2 // RUN: %clang_cc1 %s -triple=thumbv7k-apple-watchos -emit-llvm -o - -target-abi aapcs16 | FileCheck -check-prefix=CHECK-GLOBALS %s
4 // RUN: %clang_cc1 %s -triple=arm64_32-apple-ios -emit-llvm -o - -target-abi darwinpcs | FileCheck %s
5 // RUN: %clang_cc1 %s -triple=arm64_32-apple-ios -emit-llvm -o - -target-abi darwinpcs | FileCheck -check-prefix=CHECK-GLOBALS %s
7 // __cxa_guard_acquire argument is 64-bit
14 // CHECK: call i32 @__cxa_guard_acquire(i32*
18 // ARM64 uses the C++11 definition of POD.
21 // This class is POD in C++11 and cannot have objects allocated in
36 // CHECK: define{{.*}} i32 @_ZN5test14testEv()
44 // ARM64 uses string comparisons for what would otherwise be
45 // default-visibility weak RTTI. rdar://12650568
51 // Tested below because these globals get kindof oddly rearranged.
53 struct __attribute__((visibility("hidden"))) B
{};
54 const std::type_info
&b0
= typeid(B
);
55 // CHECK-GLOBALS: @_ZTSN5test21BE = linkonce_odr hidden constant
56 // CHECK-GLOBALS: @_ZTIN5test21BE = linkonce_odr hidden constant { {{.*}}, i8* getelementptr inbounds ([11 x i8], [11 x i8]* @_ZTSN5test21BE, i32 0, i32 0) }
58 const std::type_info
&b1
= typeid(B
*);
59 // CHECK-GLOBALS: @_ZTSPN5test21BE = linkonce_odr hidden constant
60 // CHECK-GLOBALS: @_ZTIPN5test21BE = linkonce_odr hidden constant { {{.*}}, i8* getelementptr inbounds ([12 x i8], [12 x i8]* @_ZTSPN5test21BE, i32 0, i32 0), i32 0, i8* bitcast
63 const std::type_info
&c0
= typeid(C
);
64 // CHECK-GLOBALS: @_ZTSN5test21CE = linkonce_odr constant [11 x i8] c"N5test21CE\00"
65 // CHECK-GLOBALS: @_ZTIN5test21CE = linkonce_odr constant { {{.*}}, i8* getelementptr inbounds ([11 x i8], [11 x i8]* @_ZTSN5test21CE, i32 0, i32 0) }
68 // va_list should be based on "char *" rather than "void *".
70 // CHECK: define{{.*}} void @_Z11whatsVaListPc
71 void whatsVaList(__builtin_va_list l
) {}