[AMDGPU] Add True16 register classes.
[llvm-project.git] / llvm / test / Transforms / ObjCARC / apelim.ll
blob2ac5d15d0df858373db42edd6822fbaa7cd57a98
1 ; RUN: opt -S -passes=objc-arc-apelim < %s | FileCheck %s
2 ; rdar://10227311
4 @llvm.global_ctors = appending global [2 x { i32, ptr, ptr }] [{ i32, ptr, ptr } { i32 65535, ptr @_GLOBAL__I_x, ptr null }, { i32, ptr, ptr } { i32 65535, ptr @_GLOBAL__I_y, ptr null }]
6 @x = global i32 0
8 declare i32 @bar() nounwind
10 define i32 @foo() nounwind {
11 entry:
12   ret i32 5
15 define internal void @__cxx_global_var_init() {
16 entry:
17   %call = call i32 @foo()
18   store i32 %call, ptr @x, align 4
19   ret void
22 define internal void @__dxx_global_var_init() {
23 entry:
24   %call = call i32 @bar()
25   store i32 %call, ptr @x, align 4
26   ret void
29 ; CHECK: define internal void @_GLOBAL__I_x() {
30 ; CHECK-NOT: @objc
31 ; CHECK: }
32 define internal void @_GLOBAL__I_x() {
33 entry:
34   %0 = call ptr @llvm.objc.autoreleasePoolPush() nounwind
35   call void @__cxx_global_var_init()
36   call void @llvm.objc.autoreleasePoolPop(ptr %0) nounwind
37   ret void
40 ; CHECK: define internal void @_GLOBAL__I_y() {
41 ; CHECK: %0 = call ptr @llvm.objc.autoreleasePoolPush() [[NUW:#[0-9]+]]
42 ; CHECK: call void @llvm.objc.autoreleasePoolPop(ptr %0) [[NUW]]
43 ; CHECK: }
44 define internal void @_GLOBAL__I_y() {
45 entry:
46   %0 = call ptr @llvm.objc.autoreleasePoolPush() nounwind
47   call void @__dxx_global_var_init()
48   call void @llvm.objc.autoreleasePoolPop(ptr %0) nounwind
49   ret void
52 declare ptr @llvm.objc.autoreleasePoolPush()
53 declare void @llvm.objc.autoreleasePoolPop(ptr)
55 ; CHECK: attributes #0 = { nounwind }