7e45c49f48f7555b42d0c8baf5eba2b990ba5b6f
[oota-llvm.git] / test / CodeGen / X86 / fast-isel-cmp-branch2.ll
1 ; RUN: llc < %s                             -mtriple=x86_64-apple-darwin10 | FileCheck %s
2 ; RUN: llc < %s -fast-isel -fast-isel-abort -mtriple=x86_64-apple-darwin10 | FileCheck %s
3
4 define i32 @fcmp_oeq(float %x, float %y) {
5 ; CHECK-LABEL: fcmp_oeq
6 ; CHECK:       ucomiss  %xmm1, %xmm0
7 ; CHECK-NEXT:  jne {{LBB.+_1}}
8 ; CHECK-NEXT:  jnp {{LBB.+_2}}
9   %1 = fcmp oeq float %x, %y
10   br i1 %1, label %bb1, label %bb2
11 bb2:
12   ret i32 1
13 bb1:
14   ret i32 0
15 }
16
17 define i32 @fcmp_ogt(float %x, float %y) {
18 ; CHECK-LABEL: fcmp_ogt
19 ; CHECK:       ucomiss  %xmm1, %xmm0
20 ; CHECK-NEXT:  jbe {{LBB.+_1}}
21   %1 = fcmp ogt float %x, %y
22   br i1 %1, label %bb1, label %bb2
23 bb2:
24   ret i32 1
25 bb1:
26   ret i32 0
27 }
28
29 define i32 @fcmp_oge(float %x, float %y) {
30 ; CHECK-LABEL: fcmp_oge
31 ; CHECK:       ucomiss  %xmm1, %xmm0
32 ; CHECK-NEXT:  jb {{LBB.+_1}}
33   %1 = fcmp oge float %x, %y
34   br i1 %1, label %bb1, label %bb2
35 bb2:
36   ret i32 1
37 bb1:
38   ret i32 0
39 }
40
41 define i32 @fcmp_olt(float %x, float %y) {
42 ; CHECK-LABEL: fcmp_olt
43 ; CHECK:       ucomiss  %xmm0, %xmm1
44 ; CHECK-NEXT:  jbe {{LBB.+_1}}
45   %1 = fcmp olt float %x, %y
46   br i1 %1, label %bb1, label %bb2
47 bb2:
48   ret i32 1
49 bb1:
50   ret i32 0
51 }
52
53 define i32 @fcmp_ole(float %x, float %y) {
54 ; CHECK-LABEL: fcmp_ole
55 ; CHECK:       ucomiss  %xmm0, %xmm1
56 ; CHECK-NEXT:  jb {{LBB.+_1}}
57   %1 = fcmp ole float %x, %y
58   br i1 %1, label %bb1, label %bb2
59 bb2:
60   ret i32 1
61 bb1:
62   ret i32 0
63 }
64
65 define i32 @fcmp_one(float %x, float %y) {
66 ; CHECK-LABEL: fcmp_one
67 ; CHECK:       ucomiss  %xmm1, %xmm0
68 ; CHECK-NEXT:  je {{LBB.+_1}}
69   %1 = fcmp one float %x, %y
70   br i1 %1, label %bb1, label %bb2
71 bb2:
72   ret i32 1
73 bb1:
74   ret i32 0
75 }
76
77 define i32 @fcmp_ord(float %x, float %y) {
78 ; CHECK-LABEL: fcmp_ord
79 ; CHECK:       ucomiss  %xmm1, %xmm0
80 ; CHECK-NEXT:  jp {{LBB.+_1}}
81   %1 = fcmp ord float %x, %y
82   br i1 %1, label %bb1, label %bb2
83 bb2:
84   ret i32 1
85 bb1:
86   ret i32 0
87 }
88
89 define i32 @fcmp_uno(float %x, float %y) {
90 ; CHECK-LABEL: fcmp_uno
91 ; CHECK:       ucomiss  %xmm1, %xmm0
92 ; CHECK-NEXT:  jp {{LBB.+_2}}
93   %1 = fcmp uno float %x, %y
94   br i1 %1, label %bb1, label %bb2
95 bb2:
96   ret i32 1
97 bb1:
98   ret i32 0
99 }
100
101 define i32 @fcmp_ueq(float %x, float %y) {
102 ; CHECK-LABEL: fcmp_ueq
103 ; CHECK:       ucomiss  %xmm1, %xmm0
104 ; CHECK-NEXT:  je {{LBB.+_2}}
105   %1 = fcmp ueq float %x, %y
106   br i1 %1, label %bb1, label %bb2
107 bb2:
108   ret i32 1
109 bb1:
110   ret i32 0
111 }
112
113 define i32 @fcmp_ugt(float %x, float %y) {
114 ; CHECK-LABEL: fcmp_ugt
115 ; CHECK:       ucomiss  %xmm0, %xmm1
116 ; CHECK-NEXT:  jae {{LBB.+_1}}
117   %1 = fcmp ugt float %x, %y
118   br i1 %1, label %bb1, label %bb2
119 bb2:
120   ret i32 1
121 bb1:
122   ret i32 0
123 }
124
125 define i32 @fcmp_uge(float %x, float %y) {
126 ; CHECK-LABEL: fcmp_uge
127 ; CHECK:       ucomiss  %xmm0, %xmm1
128 ; CHECK-NEXT:  ja {{LBB.+_1}}
129   %1 = fcmp uge float %x, %y
130   br i1 %1, label %bb1, label %bb2
131 bb2:
132   ret i32 1
133 bb1:
134   ret i32 0
135 }
136
137 define i32 @fcmp_ult(float %x, float %y) {
138 ; CHECK-LABEL: fcmp_ult
139 ; CHECK:       ucomiss  %xmm1, %xmm0
140 ; CHECK-NEXT:  jae {{LBB.+_1}}
141   %1 = fcmp ult float %x, %y
142   br i1 %1, label %bb1, label %bb2
143 bb2:
144   ret i32 1
145 bb1:
146   ret i32 0
147 }
148
149 define i32 @fcmp_ule(float %x, float %y) {
150 ; CHECK-LABEL: fcmp_ule
151 ; CHECK:       ucomiss  %xmm1, %xmm0
152 ; CHECK-NEXT:  ja {{LBB.+_1}}
153   %1 = fcmp ule float %x, %y
154   br i1 %1, label %bb1, label %bb2
155 bb2:
156   ret i32 1
157 bb1:
158   ret i32 0
159 }
160
161 define i32 @fcmp_une(float %x, float %y) {
162 ; CHECK-LABEL: fcmp_une
163 ; CHECK:       ucomiss  %xmm1, %xmm0
164 ; CHECK-NEXT:  jne {{LBB.+_2}}
165 ; CHECK-NEXT:  jp  {{LBB.+_2}}
166 ; CHECK-NEXT:  jmp {{LBB.+_1}}
167   %1 = fcmp une float %x, %y
168   br i1 %1, label %bb1, label %bb2
169 bb2:
170   ret i32 1
171 bb1:
172   ret i32 0
173 }
174
175 define i32 @icmp_eq(i32 %x, i32 %y) {
176 ; CHECK-LABEL: icmp_eq
177 ; CHECK:       cmpl %esi, %edi
178 ; CHECK-NEXT:  jne {{LBB.+_1}}
179   %1 = icmp eq i32 %x, %y
180   br i1 %1, label %bb1, label %bb2
181 bb2:
182   ret i32 1
183 bb1:
184   ret i32 0
185 }
186
187 define i32 @icmp_ne(i32 %x, i32 %y) {
188 ; CHECK-LABEL: icmp_ne
189 ; CHECK:       cmpl %esi, %edi
190 ; CHECK-NEXT:  je {{LBB.+_1}}
191   %1 = icmp ne i32 %x, %y
192   br i1 %1, label %bb1, label %bb2
193 bb2:
194   ret i32 1
195 bb1:
196   ret i32 0
197 }
198
199 define i32 @icmp_ugt(i32 %x, i32 %y) {
200 ; CHECK-LABEL: icmp_ugt
201 ; CHECK:       cmpl %esi, %edi
202 ; CHECK-NEXT:  jbe {{LBB.+_1}}
203   %1 = icmp ugt i32 %x, %y
204   br i1 %1, label %bb1, label %bb2
205 bb2:
206   ret i32 1
207 bb1:
208   ret i32 0
209 }
210
211 define i32 @icmp_uge(i32 %x, i32 %y) {
212 ; CHECK-LABEL: icmp_uge
213 ; CHECK:       cmpl %esi, %edi
214 ; CHECK-NEXT:  jb {{LBB.+_1}}
215   %1 = icmp uge i32 %x, %y
216   br i1 %1, label %bb1, label %bb2
217 bb2:
218   ret i32 1
219 bb1:
220   ret i32 0
221 }
222
223 define i32 @icmp_ult(i32 %x, i32 %y) {
224 ; CHECK-LABEL: icmp_ult
225 ; CHECK:       cmpl %esi, %edi
226 ; CHECK-NEXT:  jae {{LBB.+_1}}
227   %1 = icmp ult i32 %x, %y
228   br i1 %1, label %bb1, label %bb2
229 bb2:
230   ret i32 1
231 bb1:
232   ret i32 0
233 }
234
235 define i32 @icmp_ule(i32 %x, i32 %y) {
236 ; CHECK-LABEL: icmp_ule
237 ; CHECK:       cmpl %esi, %edi
238 ; CHECK-NEXT:  ja {{LBB.+_1}}
239   %1 = icmp ule i32 %x, %y
240   br i1 %1, label %bb1, label %bb2
241 bb2:
242   ret i32 1
243 bb1:
244   ret i32 0
245 }
246
247 define i32 @icmp_sgt(i32 %x, i32 %y) {
248 ; CHECK-LABEL: icmp_sgt
249 ; CHECK:       cmpl %esi, %edi
250 ; CHECK-NEXT:  jle {{LBB.+_1}}
251   %1 = icmp sgt i32 %x, %y
252   br i1 %1, label %bb1, label %bb2
253 bb2:
254   ret i32 1
255 bb1:
256   ret i32 0
257 }
258
259 define i32 @icmp_sge(i32 %x, i32 %y) {
260 ; CHECK-LABEL: icmp_sge
261 ; CHECK:       cmpl %esi, %edi
262 ; CHECK-NEXT:  jl {{LBB.+_1}}
263   %1 = icmp sge i32 %x, %y
264   br i1 %1, label %bb1, label %bb2
265 bb2:
266   ret i32 1
267 bb1:
268   ret i32 0
269 }
270
271 define i32 @icmp_slt(i32 %x, i32 %y) {
272 ; CHECK-LABEL: icmp_slt
273 ; CHECK:       cmpl %esi, %edi
274 ; CHECK-NEXT:  jge {{LBB.+_1}}
275   %1 = icmp slt i32 %x, %y
276   br i1 %1, label %bb1, label %bb2
277 bb2:
278   ret i32 1
279 bb1:
280   ret i32 0
281 }
282
283 define i32 @icmp_sle(i32 %x, i32 %y) {
284 ; CHECK-LABEL: icmp_sle
285 ; CHECK:       cmpl %esi, %edi
286 ; CHECK-NEXT:  jg {{LBB.+_1}}
287   %1 = icmp sle i32 %x, %y
288   br i1 %1, label %bb1, label %bb2
289 bb2:
290   ret i32 1
291 bb1:
292   ret i32 0
293 }
294