Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / AArch64 / fast-isel-branch-cond-split.ll
blobd92bbfd7a21d6619eeaf75b9979a0c9866d53bf7
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc -mtriple=aarch64-apple-darwin -fast-isel -fast-isel-abort=1 -verify-machineinstrs < %s | FileCheck %s
4 define i64 @test_or(i32 %a, i32 %b) {
5 ; CHECK-LABEL: test_or:
6 ; CHECK:       ; %bb.0: ; %bb1
7 ; CHECK-NEXT:    mov w8, w0
8 ; CHECK-NEXT:    mov x0, xzr
9 ; CHECK-NEXT:    cbnz w8, LBB0_2
10 ; CHECK-NEXT:  LBB0_1: ; %common.ret
11 ; CHECK-NEXT:    ret
12 ; CHECK-NEXT:  LBB0_2: ; %bb1.cond.split
13 ; CHECK-NEXT:    mov x0, xzr
14 ; CHECK-NEXT:    cbz w1, LBB0_1
15 ; CHECK-NEXT:  ; %bb.3: ; %bb4
16 ; CHECK-NEXT:    stp x29, x30, [sp, #-16]! ; 16-byte Folded Spill
17 ; CHECK-NEXT:    .cfi_def_cfa_offset 16
18 ; CHECK-NEXT:    .cfi_offset w30, -8
19 ; CHECK-NEXT:    .cfi_offset w29, -16
20 ; CHECK-NEXT:    bl _bar
21 ; CHECK-NEXT:    ldp x29, x30, [sp], #16 ; 16-byte Folded Reload
22 ; CHECK-NEXT:    ret
23 bb1:
24   %0 = icmp eq i32 %a, 0
25   %1 = icmp eq i32 %b, 0
26   %or.cond = or i1 %0, %1
27   br i1 %or.cond, label %bb3, label %bb4, !prof !0
29 bb3:
30   ret i64 0
32 bb4:
33   %2 = call i64 @bar()
34   ret i64 %2
37 define i64 @test_or_select(i32 %a, i32 %b) {
38 ; CHECK-LABEL: test_or_select:
39 ; CHECK:       ; %bb.0: ; %bb1
40 ; CHECK-NEXT:    mov w8, w0
41 ; CHECK-NEXT:    mov x0, xzr
42 ; CHECK-NEXT:    cbnz w8, LBB1_2
43 ; CHECK-NEXT:  LBB1_1: ; %common.ret
44 ; CHECK-NEXT:    ret
45 ; CHECK-NEXT:  LBB1_2: ; %bb1.cond.split
46 ; CHECK-NEXT:    mov x0, xzr
47 ; CHECK-NEXT:    cbz w1, LBB1_1
48 ; CHECK-NEXT:  ; %bb.3: ; %bb4
49 ; CHECK-NEXT:    stp x29, x30, [sp, #-16]! ; 16-byte Folded Spill
50 ; CHECK-NEXT:    .cfi_def_cfa_offset 16
51 ; CHECK-NEXT:    .cfi_offset w30, -8
52 ; CHECK-NEXT:    .cfi_offset w29, -16
53 ; CHECK-NEXT:    bl _bar
54 ; CHECK-NEXT:    ldp x29, x30, [sp], #16 ; 16-byte Folded Reload
55 ; CHECK-NEXT:    ret
56 bb1:
57   %0 = icmp eq i32 %a, 0
58   %1 = icmp eq i32 %b, 0
59   %or.cond = select i1 %0, i1 true, i1 %1
60   br i1 %or.cond, label %bb3, label %bb4, !prof !0
62 bb3:
63   ret i64 0
65 bb4:
66   %2 = call i64 @bar()
67   ret i64 %2
70 define i64 @test_and(i32 %a, i32 %b) {
71 ; CHECK-LABEL: test_and:
72 ; CHECK:       ; %bb.0: ; %bb1
73 ; CHECK-NEXT:    mov w8, w0
74 ; CHECK-NEXT:    mov x0, xzr
75 ; CHECK-NEXT:    cbnz w8, LBB2_2
76 ; CHECK-NEXT:  LBB2_1: ; %common.ret
77 ; CHECK-NEXT:    ret
78 ; CHECK-NEXT:  LBB2_2: ; %bb1.cond.split
79 ; CHECK-NEXT:    mov x0, xzr
80 ; CHECK-NEXT:    cbz w1, LBB2_1
81 ; CHECK-NEXT:  ; %bb.3: ; %bb4
82 ; CHECK-NEXT:    stp x29, x30, [sp, #-16]! ; 16-byte Folded Spill
83 ; CHECK-NEXT:    .cfi_def_cfa_offset 16
84 ; CHECK-NEXT:    .cfi_offset w30, -8
85 ; CHECK-NEXT:    .cfi_offset w29, -16
86 ; CHECK-NEXT:    bl _bar
87 ; CHECK-NEXT:    ldp x29, x30, [sp], #16 ; 16-byte Folded Reload
88 ; CHECK-NEXT:    ret
89 bb1:
90   %0 = icmp ne i32 %a, 0
91   %1 = icmp ne i32 %b, 0
92   %or.cond = and i1 %0, %1
93   br i1 %or.cond, label %bb4, label %bb3, !prof !1
95 bb3:
96   ret i64 0
98 bb4:
99   %2 = call i64 @bar()
100   ret i64 %2
103 define i64 @test_and_select(i32 %a, i32 %b) {
104 ; CHECK-LABEL: test_and_select:
105 ; CHECK:       ; %bb.0: ; %bb1
106 ; CHECK-NEXT:    mov w8, w0
107 ; CHECK-NEXT:    mov x0, xzr
108 ; CHECK-NEXT:    cbnz w8, LBB3_2
109 ; CHECK-NEXT:  LBB3_1: ; %common.ret
110 ; CHECK-NEXT:    ret
111 ; CHECK-NEXT:  LBB3_2: ; %bb1.cond.split
112 ; CHECK-NEXT:    mov x0, xzr
113 ; CHECK-NEXT:    cbz w1, LBB3_1
114 ; CHECK-NEXT:  ; %bb.3: ; %bb4
115 ; CHECK-NEXT:    stp x29, x30, [sp, #-16]! ; 16-byte Folded Spill
116 ; CHECK-NEXT:    .cfi_def_cfa_offset 16
117 ; CHECK-NEXT:    .cfi_offset w30, -8
118 ; CHECK-NEXT:    .cfi_offset w29, -16
119 ; CHECK-NEXT:    bl _bar
120 ; CHECK-NEXT:    ldp x29, x30, [sp], #16 ; 16-byte Folded Reload
121 ; CHECK-NEXT:    ret
122 bb1:
123   %0 = icmp ne i32 %a, 0
124   %1 = icmp ne i32 %b, 0
125   %or.cond = select i1 %0, i1 %1, i1 false
126   br i1 %or.cond, label %bb4, label %bb3, !prof !1
128 bb3:
129   ret i64 0
131 bb4:
132   %2 = call i64 @bar()
133   ret i64 %2
136 ; If the branch is unpredictable, don't add another branch.
138 define i64 @test_or_unpredictable(i32 %a, i32 %b) {
139 ; CHECK-LABEL: test_or_unpredictable:
140 ; CHECK:       ; %bb.0: ; %bb1
141 ; CHECK-NEXT:    cmp w0, #0
142 ; CHECK-NEXT:    mov x0, xzr
143 ; CHECK-NEXT:    cset w8, eq
144 ; CHECK-NEXT:    cmp w1, #0
145 ; CHECK-NEXT:    cset w9, eq
146 ; CHECK-NEXT:    orr w8, w8, w9
147 ; CHECK-NEXT:    tbnz w8, #0, LBB4_2
148 ; CHECK-NEXT:  ; %bb.1: ; %bb4
149 ; CHECK-NEXT:    stp x29, x30, [sp, #-16]! ; 16-byte Folded Spill
150 ; CHECK-NEXT:    .cfi_def_cfa_offset 16
151 ; CHECK-NEXT:    .cfi_offset w30, -8
152 ; CHECK-NEXT:    .cfi_offset w29, -16
153 ; CHECK-NEXT:    bl _bar
154 ; CHECK-NEXT:    ldp x29, x30, [sp], #16 ; 16-byte Folded Reload
155 ; CHECK-NEXT:  LBB4_2: ; %common.ret
156 ; CHECK-NEXT:    ret
157 bb1:
158   %0 = icmp eq i32 %a, 0
159   %1 = icmp eq i32 %b, 0
160   %or.cond = or i1 %0, %1
161   br i1 %or.cond, label %bb3, label %bb4, !unpredictable !2
163 bb3:
164   ret i64 0
166 bb4:
167   %2 = call i64 @bar()
168   ret i64 %2
171 define i64 @test_and_unpredictable(i32 %a, i32 %b) {
172 ; CHECK-LABEL: test_and_unpredictable:
173 ; CHECK:       ; %bb.0: ; %bb1
174 ; CHECK-NEXT:    cmp w0, #0
175 ; CHECK-NEXT:    mov x0, xzr
176 ; CHECK-NEXT:    cset w8, ne
177 ; CHECK-NEXT:    cmp w1, #0
178 ; CHECK-NEXT:    cset w9, ne
179 ; CHECK-NEXT:    and w8, w8, w9
180 ; CHECK-NEXT:    tbz w8, #0, LBB5_2
181 ; CHECK-NEXT:  ; %bb.1: ; %bb4
182 ; CHECK-NEXT:    stp x29, x30, [sp, #-16]! ; 16-byte Folded Spill
183 ; CHECK-NEXT:    .cfi_def_cfa_offset 16
184 ; CHECK-NEXT:    .cfi_offset w30, -8
185 ; CHECK-NEXT:    .cfi_offset w29, -16
186 ; CHECK-NEXT:    bl _bar
187 ; CHECK-NEXT:    ldp x29, x30, [sp], #16 ; 16-byte Folded Reload
188 ; CHECK-NEXT:  LBB5_2: ; %common.ret
189 ; CHECK-NEXT:    ret
190 bb1:
191   %0 = icmp ne i32 %a, 0
192   %1 = icmp ne i32 %b, 0
193   %or.cond = and i1 %0, %1
194   br i1 %or.cond, label %bb4, label %bb3, !unpredictable !2
196 bb3:
197   ret i64 0
199 bb4:
200   %2 = call i64 @bar()
201   ret i64 %2
204 declare i64 @bar()
206 !0 = !{!"branch_weights", i32 5128, i32 32}
207 !1 = !{!"branch_weights", i32 1024, i32 4136}
208 !2 = !{}