1 ; RUN: llc -aarch64-enable-atomic-cfg-tidy=0 -mtriple=aarch64-apple-darwin < %s | FileCheck %s
2 ; RUN: llc -fast-isel -fast-isel-abort=1 -aarch64-enable-atomic-cfg-tidy=0 -mtriple=aarch64-apple-darwin < %s | FileCheck %s
4 define i32 @fcmp_oeq(float %x, float %y) {
5 ; CHECK-LABEL: fcmp_oeq
7 ; CHECK-NEXT: b.ne {{LBB.+_2}}
8 %1 = fcmp oeq float %x, %y
9 br i1 %1, label %bb1, label %bb2
16 define i32 @fcmp_ogt(float %x, float %y) {
17 ; CHECK-LABEL: fcmp_ogt
19 ; CHECK-NEXT: b.le {{LBB.+_2}}
20 %1 = fcmp ogt float %x, %y
21 br i1 %1, label %bb1, label %bb2
28 define i32 @fcmp_oge(float %x, float %y) {
29 ; CHECK-LABEL: fcmp_oge
31 ; CHECK-NEXT: b.lt {{LBB.+_2}}
32 %1 = fcmp oge float %x, %y
33 br i1 %1, label %bb1, label %bb2
40 define i32 @fcmp_olt(float %x, float %y) {
41 ; CHECK-LABEL: fcmp_olt
43 ; CHECK-NEXT: b.pl {{LBB.+_2}}
44 %1 = fcmp olt float %x, %y
45 br i1 %1, label %bb1, label %bb2
52 define i32 @fcmp_ole(float %x, float %y) {
53 ; CHECK-LABEL: fcmp_ole
55 ; CHECK-NEXT: b.hi {{LBB.+_2}}
56 %1 = fcmp ole float %x, %y
57 br i1 %1, label %bb1, label %bb2
64 define i32 @fcmp_one(float %x, float %y) {
65 ; CHECK-LABEL: fcmp_one
69 %1 = fcmp one float %x, %y
70 br i1 %1, label %bb1, label %bb2
77 define i32 @fcmp_ord(float %x, float %y) {
78 ; CHECK-LABEL: fcmp_ord
80 ; CHECK-NEXT: b.vs {{LBB.+_2}}
81 %1 = fcmp ord float %x, %y
82 br i1 %1, label %bb1, label %bb2
89 define i32 @fcmp_uno(float %x, float %y) {
90 ; CHECK-LABEL: fcmp_uno
92 ; CHECK-NEXT: b.vs {{LBB.+_2}}
93 %1 = fcmp uno float %x, %y
94 br i1 %1, label %bb1, label %bb2
101 define i32 @fcmp_ueq(float %x, float %y) {
102 ; CHECK-LABEL: fcmp_ueq
104 ; CHECK-NEXT: b.eq {{LBB.+_2}}
105 ; CHECK-NEXT: b.vs {{LBB.+_2}}
106 %1 = fcmp ueq float %x, %y
107 br i1 %1, label %bb1, label %bb2
114 define i32 @fcmp_ugt(float %x, float %y) {
115 ; CHECK-LABEL: fcmp_ugt
117 ; CHECK-NEXT: b.ls {{LBB.+_2}}
118 %1 = fcmp ugt float %x, %y
119 br i1 %1, label %bb1, label %bb2
126 define i32 @fcmp_uge(float %x, float %y) {
127 ; CHECK-LABEL: fcmp_uge
129 ; CHECK-NEXT: b.mi {{LBB.+_2}}
130 %1 = fcmp uge float %x, %y
131 br i1 %1, label %bb1, label %bb2
138 define i32 @fcmp_ult(float %x, float %y) {
139 ; CHECK-LABEL: fcmp_ult
141 ; CHECK-NEXT: b.ge {{LBB.+_2}}
142 %1 = fcmp ult float %x, %y
143 br i1 %1, label %bb1, label %bb2
150 define i32 @fcmp_ule(float %x, float %y) {
151 ; CHECK-LABEL: fcmp_ule
153 ; CHECK-NEXT: b.gt {{LBB.+_2}}
154 %1 = fcmp ule float %x, %y
155 br i1 %1, label %bb1, label %bb2
162 define i32 @fcmp_une(float %x, float %y) {
163 ; CHECK-LABEL: fcmp_une
165 ; CHECK-NEXT: b.eq {{LBB.+_2}}
166 %1 = fcmp une float %x, %y
167 br i1 %1, label %bb1, label %bb2
174 define i32 @icmp_eq(i32 %x, i32 %y) {
175 ; CHECK-LABEL: icmp_eq
177 ; CHECK-NEXT: b.ne {{LBB.+_2}}
178 %1 = icmp eq i32 %x, %y
179 br i1 %1, label %bb1, label %bb2
186 define i32 @icmp_ne(i32 %x, i32 %y) {
187 ; CHECK-LABEL: icmp_ne
189 ; CHECK-NEXT: b.eq {{LBB.+_2}}
190 %1 = icmp ne i32 %x, %y
191 br i1 %1, label %bb1, label %bb2
198 define i32 @icmp_ugt(i32 %x, i32 %y) {
199 ; CHECK-LABEL: icmp_ugt
201 ; CHECK-NEXT: b.ls {{LBB.+_2}}
202 %1 = icmp ugt i32 %x, %y
203 br i1 %1, label %bb1, label %bb2
210 define i32 @icmp_uge(i32 %x, i32 %y) {
211 ; CHECK-LABEL: icmp_uge
213 ; CHECK-NEXT: b.lo {{LBB.+_2}}
214 %1 = icmp uge i32 %x, %y
215 br i1 %1, label %bb1, label %bb2
222 define i32 @icmp_ult(i32 %x, i32 %y) {
223 ; CHECK-LABEL: icmp_ult
225 ; CHECK-NEXT: b.hs {{LBB.+_2}}
226 %1 = icmp ult i32 %x, %y
227 br i1 %1, label %bb1, label %bb2
234 define i32 @icmp_ule(i32 %x, i32 %y) {
235 ; CHECK-LABEL: icmp_ule
237 ; CHECK-NEXT: b.hi {{LBB.+_2}}
238 %1 = icmp ule i32 %x, %y
239 br i1 %1, label %bb1, label %bb2
246 define i32 @icmp_sgt(i32 %x, i32 %y) {
247 ; CHECK-LABEL: icmp_sgt
249 ; CHECK-NEXT: b.le {{LBB.+_2}}
250 %1 = icmp sgt i32 %x, %y
251 br i1 %1, label %bb1, label %bb2
258 define i32 @icmp_sge(i32 %x, i32 %y) {
259 ; CHECK-LABEL: icmp_sge
261 ; CHECK-NEXT: b.lt {{LBB.+_2}}
262 %1 = icmp sge i32 %x, %y
263 br i1 %1, label %bb1, label %bb2
270 define i32 @icmp_slt(i32 %x, i32 %y) {
271 ; CHECK-LABEL: icmp_slt
273 ; CHECK-NEXT: b.ge {{LBB.+_2}}
274 %1 = icmp slt i32 %x, %y
275 br i1 %1, label %bb1, label %bb2
282 define i32 @icmp_sle(i32 %x, i32 %y) {
283 ; CHECK-LABEL: icmp_sle
285 ; CHECK-NEXT: b.gt {{LBB.+_2}}
286 %1 = icmp sle i32 %x, %y
287 br i1 %1, label %bb1, label %bb2