Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / X86 / fptoui-sat-scalar.ll
blobe334af71397ff4f3de43358a700db28010eba6e6
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s -mtriple=i686-linux | FileCheck %s --check-prefix=X86-X87
3 ; RUN: llc < %s -mtriple=i686-linux -mattr=+sse2 | FileCheck %s --check-prefix=X86-SSE
4 ; RUN: llc < %s -mtriple=x86_64-linux | FileCheck %s --check-prefix=X64
7 ; 32-bit float to unsigned integer
10 declare   i1 @llvm.fptoui.sat.i1.f32  (float)
11 declare   i8 @llvm.fptoui.sat.i8.f32  (float)
12 declare  i13 @llvm.fptoui.sat.i13.f32 (float)
13 declare  i16 @llvm.fptoui.sat.i16.f32 (float)
14 declare  i19 @llvm.fptoui.sat.i19.f32 (float)
15 declare  i32 @llvm.fptoui.sat.i32.f32 (float)
16 declare  i50 @llvm.fptoui.sat.i50.f32 (float)
17 declare  i64 @llvm.fptoui.sat.i64.f32 (float)
18 declare i100 @llvm.fptoui.sat.i100.f32(float)
19 declare i128 @llvm.fptoui.sat.i128.f32(float)
21 define i1 @test_unsigned_i1_f32(float %f) nounwind {
22 ; X86-X87-LABEL: test_unsigned_i1_f32:
23 ; X86-X87:       # %bb.0:
24 ; X86-X87-NEXT:    subl $8, %esp
25 ; X86-X87-NEXT:    flds {{[0-9]+}}(%esp)
26 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
27 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
28 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
29 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
30 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
31 ; X86-X87-NEXT:    fists {{[0-9]+}}(%esp)
32 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
33 ; X86-X87-NEXT:    fldz
34 ; X86-X87-NEXT:    fxch %st(1)
35 ; X86-X87-NEXT:    fucom %st(1)
36 ; X86-X87-NEXT:    fstp %st(1)
37 ; X86-X87-NEXT:    fnstsw %ax
38 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
39 ; X86-X87-NEXT:    sahf
40 ; X86-X87-NEXT:    jb .LBB0_1
41 ; X86-X87-NEXT:  # %bb.2:
42 ; X86-X87-NEXT:    movzbl {{[0-9]+}}(%esp), %ecx
43 ; X86-X87-NEXT:    jmp .LBB0_3
44 ; X86-X87-NEXT:  .LBB0_1:
45 ; X86-X87-NEXT:    xorl %ecx, %ecx
46 ; X86-X87-NEXT:  .LBB0_3:
47 ; X86-X87-NEXT:    fld1
48 ; X86-X87-NEXT:    fxch %st(1)
49 ; X86-X87-NEXT:    fucompp
50 ; X86-X87-NEXT:    fnstsw %ax
51 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
52 ; X86-X87-NEXT:    sahf
53 ; X86-X87-NEXT:    movb $1, %al
54 ; X86-X87-NEXT:    ja .LBB0_5
55 ; X86-X87-NEXT:  # %bb.4:
56 ; X86-X87-NEXT:    movl %ecx, %eax
57 ; X86-X87-NEXT:  .LBB0_5:
58 ; X86-X87-NEXT:    addl $8, %esp
59 ; X86-X87-NEXT:    retl
61 ; X86-SSE-LABEL: test_unsigned_i1_f32:
62 ; X86-SSE:       # %bb.0:
63 ; X86-SSE-NEXT:    xorps %xmm0, %xmm0
64 ; X86-SSE-NEXT:    maxss {{[0-9]+}}(%esp), %xmm0
65 ; X86-SSE-NEXT:    movss {{.*#+}} xmm1 = mem[0],zero,zero,zero
66 ; X86-SSE-NEXT:    minss %xmm0, %xmm1
67 ; X86-SSE-NEXT:    cvttss2si %xmm1, %eax
68 ; X86-SSE-NEXT:    # kill: def $al killed $al killed $eax
69 ; X86-SSE-NEXT:    retl
71 ; X64-LABEL: test_unsigned_i1_f32:
72 ; X64:       # %bb.0:
73 ; X64-NEXT:    xorps %xmm1, %xmm1
74 ; X64-NEXT:    maxss %xmm0, %xmm1
75 ; X64-NEXT:    movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
76 ; X64-NEXT:    minss %xmm1, %xmm0
77 ; X64-NEXT:    cvttss2si %xmm0, %eax
78 ; X64-NEXT:    # kill: def $al killed $al killed $eax
79 ; X64-NEXT:    retq
80     %x = call i1 @llvm.fptoui.sat.i1.f32(float %f)
81     ret i1 %x
84 define i8 @test_unsigned_i8_f32(float %f) nounwind {
85 ; X86-X87-LABEL: test_unsigned_i8_f32:
86 ; X86-X87:       # %bb.0:
87 ; X86-X87-NEXT:    subl $8, %esp
88 ; X86-X87-NEXT:    flds {{[0-9]+}}(%esp)
89 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
90 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
91 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
92 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
93 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
94 ; X86-X87-NEXT:    fists {{[0-9]+}}(%esp)
95 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
96 ; X86-X87-NEXT:    fldz
97 ; X86-X87-NEXT:    fxch %st(1)
98 ; X86-X87-NEXT:    fucom %st(1)
99 ; X86-X87-NEXT:    fstp %st(1)
100 ; X86-X87-NEXT:    fnstsw %ax
101 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
102 ; X86-X87-NEXT:    sahf
103 ; X86-X87-NEXT:    jb .LBB1_1
104 ; X86-X87-NEXT:  # %bb.2:
105 ; X86-X87-NEXT:    movzbl {{[0-9]+}}(%esp), %ecx
106 ; X86-X87-NEXT:    jmp .LBB1_3
107 ; X86-X87-NEXT:  .LBB1_1:
108 ; X86-X87-NEXT:    xorl %ecx, %ecx
109 ; X86-X87-NEXT:  .LBB1_3:
110 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
111 ; X86-X87-NEXT:    fxch %st(1)
112 ; X86-X87-NEXT:    fucompp
113 ; X86-X87-NEXT:    fnstsw %ax
114 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
115 ; X86-X87-NEXT:    sahf
116 ; X86-X87-NEXT:    movb $-1, %al
117 ; X86-X87-NEXT:    ja .LBB1_5
118 ; X86-X87-NEXT:  # %bb.4:
119 ; X86-X87-NEXT:    movl %ecx, %eax
120 ; X86-X87-NEXT:  .LBB1_5:
121 ; X86-X87-NEXT:    addl $8, %esp
122 ; X86-X87-NEXT:    retl
124 ; X86-SSE-LABEL: test_unsigned_i8_f32:
125 ; X86-SSE:       # %bb.0:
126 ; X86-SSE-NEXT:    xorps %xmm0, %xmm0
127 ; X86-SSE-NEXT:    maxss {{[0-9]+}}(%esp), %xmm0
128 ; X86-SSE-NEXT:    movss {{.*#+}} xmm1 = mem[0],zero,zero,zero
129 ; X86-SSE-NEXT:    minss %xmm0, %xmm1
130 ; X86-SSE-NEXT:    cvttss2si %xmm1, %eax
131 ; X86-SSE-NEXT:    # kill: def $al killed $al killed $eax
132 ; X86-SSE-NEXT:    retl
134 ; X64-LABEL: test_unsigned_i8_f32:
135 ; X64:       # %bb.0:
136 ; X64-NEXT:    xorps %xmm1, %xmm1
137 ; X64-NEXT:    maxss %xmm0, %xmm1
138 ; X64-NEXT:    movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
139 ; X64-NEXT:    minss %xmm1, %xmm0
140 ; X64-NEXT:    cvttss2si %xmm0, %eax
141 ; X64-NEXT:    # kill: def $al killed $al killed $eax
142 ; X64-NEXT:    retq
143     %x = call i8 @llvm.fptoui.sat.i8.f32(float %f)
144     ret i8 %x
147 define i13 @test_unsigned_i13_f32(float %f) nounwind {
148 ; X86-X87-LABEL: test_unsigned_i13_f32:
149 ; X86-X87:       # %bb.0:
150 ; X86-X87-NEXT:    subl $8, %esp
151 ; X86-X87-NEXT:    flds {{[0-9]+}}(%esp)
152 ; X86-X87-NEXT:    fnstcw (%esp)
153 ; X86-X87-NEXT:    movzwl (%esp), %eax
154 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
155 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
156 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
157 ; X86-X87-NEXT:    fistl {{[0-9]+}}(%esp)
158 ; X86-X87-NEXT:    fldcw (%esp)
159 ; X86-X87-NEXT:    fldz
160 ; X86-X87-NEXT:    fxch %st(1)
161 ; X86-X87-NEXT:    fucom %st(1)
162 ; X86-X87-NEXT:    fstp %st(1)
163 ; X86-X87-NEXT:    fnstsw %ax
164 ; X86-X87-NEXT:    xorl %ecx, %ecx
165 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
166 ; X86-X87-NEXT:    sahf
167 ; X86-X87-NEXT:    jb .LBB2_2
168 ; X86-X87-NEXT:  # %bb.1:
169 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
170 ; X86-X87-NEXT:  .LBB2_2:
171 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
172 ; X86-X87-NEXT:    fxch %st(1)
173 ; X86-X87-NEXT:    fucompp
174 ; X86-X87-NEXT:    fnstsw %ax
175 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
176 ; X86-X87-NEXT:    sahf
177 ; X86-X87-NEXT:    movl $8191, %eax # imm = 0x1FFF
178 ; X86-X87-NEXT:    ja .LBB2_4
179 ; X86-X87-NEXT:  # %bb.3:
180 ; X86-X87-NEXT:    movl %ecx, %eax
181 ; X86-X87-NEXT:  .LBB2_4:
182 ; X86-X87-NEXT:    # kill: def $ax killed $ax killed $eax
183 ; X86-X87-NEXT:    addl $8, %esp
184 ; X86-X87-NEXT:    retl
186 ; X86-SSE-LABEL: test_unsigned_i13_f32:
187 ; X86-SSE:       # %bb.0:
188 ; X86-SSE-NEXT:    xorps %xmm0, %xmm0
189 ; X86-SSE-NEXT:    maxss {{[0-9]+}}(%esp), %xmm0
190 ; X86-SSE-NEXT:    movss {{.*#+}} xmm1 = mem[0],zero,zero,zero
191 ; X86-SSE-NEXT:    minss %xmm0, %xmm1
192 ; X86-SSE-NEXT:    cvttss2si %xmm1, %eax
193 ; X86-SSE-NEXT:    # kill: def $ax killed $ax killed $eax
194 ; X86-SSE-NEXT:    retl
196 ; X64-LABEL: test_unsigned_i13_f32:
197 ; X64:       # %bb.0:
198 ; X64-NEXT:    xorps %xmm1, %xmm1
199 ; X64-NEXT:    maxss %xmm0, %xmm1
200 ; X64-NEXT:    movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
201 ; X64-NEXT:    minss %xmm1, %xmm0
202 ; X64-NEXT:    cvttss2si %xmm0, %eax
203 ; X64-NEXT:    # kill: def $ax killed $ax killed $eax
204 ; X64-NEXT:    retq
205     %x = call i13 @llvm.fptoui.sat.i13.f32(float %f)
206     ret i13 %x
209 define i16 @test_unsigned_i16_f32(float %f) nounwind {
210 ; X86-X87-LABEL: test_unsigned_i16_f32:
211 ; X86-X87:       # %bb.0:
212 ; X86-X87-NEXT:    subl $8, %esp
213 ; X86-X87-NEXT:    flds {{[0-9]+}}(%esp)
214 ; X86-X87-NEXT:    fnstcw (%esp)
215 ; X86-X87-NEXT:    movzwl (%esp), %eax
216 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
217 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
218 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
219 ; X86-X87-NEXT:    fistl {{[0-9]+}}(%esp)
220 ; X86-X87-NEXT:    fldcw (%esp)
221 ; X86-X87-NEXT:    fldz
222 ; X86-X87-NEXT:    fxch %st(1)
223 ; X86-X87-NEXT:    fucom %st(1)
224 ; X86-X87-NEXT:    fstp %st(1)
225 ; X86-X87-NEXT:    fnstsw %ax
226 ; X86-X87-NEXT:    xorl %ecx, %ecx
227 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
228 ; X86-X87-NEXT:    sahf
229 ; X86-X87-NEXT:    jb .LBB3_2
230 ; X86-X87-NEXT:  # %bb.1:
231 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
232 ; X86-X87-NEXT:  .LBB3_2:
233 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
234 ; X86-X87-NEXT:    fxch %st(1)
235 ; X86-X87-NEXT:    fucompp
236 ; X86-X87-NEXT:    fnstsw %ax
237 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
238 ; X86-X87-NEXT:    sahf
239 ; X86-X87-NEXT:    movl $65535, %eax # imm = 0xFFFF
240 ; X86-X87-NEXT:    ja .LBB3_4
241 ; X86-X87-NEXT:  # %bb.3:
242 ; X86-X87-NEXT:    movl %ecx, %eax
243 ; X86-X87-NEXT:  .LBB3_4:
244 ; X86-X87-NEXT:    # kill: def $ax killed $ax killed $eax
245 ; X86-X87-NEXT:    addl $8, %esp
246 ; X86-X87-NEXT:    retl
248 ; X86-SSE-LABEL: test_unsigned_i16_f32:
249 ; X86-SSE:       # %bb.0:
250 ; X86-SSE-NEXT:    xorps %xmm0, %xmm0
251 ; X86-SSE-NEXT:    maxss {{[0-9]+}}(%esp), %xmm0
252 ; X86-SSE-NEXT:    movss {{.*#+}} xmm1 = mem[0],zero,zero,zero
253 ; X86-SSE-NEXT:    minss %xmm0, %xmm1
254 ; X86-SSE-NEXT:    cvttss2si %xmm1, %eax
255 ; X86-SSE-NEXT:    # kill: def $ax killed $ax killed $eax
256 ; X86-SSE-NEXT:    retl
258 ; X64-LABEL: test_unsigned_i16_f32:
259 ; X64:       # %bb.0:
260 ; X64-NEXT:    xorps %xmm1, %xmm1
261 ; X64-NEXT:    maxss %xmm0, %xmm1
262 ; X64-NEXT:    movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
263 ; X64-NEXT:    minss %xmm1, %xmm0
264 ; X64-NEXT:    cvttss2si %xmm0, %eax
265 ; X64-NEXT:    # kill: def $ax killed $ax killed $eax
266 ; X64-NEXT:    retq
267     %x = call i16 @llvm.fptoui.sat.i16.f32(float %f)
268     ret i16 %x
271 define i19 @test_unsigned_i19_f32(float %f) nounwind {
272 ; X86-X87-LABEL: test_unsigned_i19_f32:
273 ; X86-X87:       # %bb.0:
274 ; X86-X87-NEXT:    subl $20, %esp
275 ; X86-X87-NEXT:    flds {{[0-9]+}}(%esp)
276 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
277 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
278 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
279 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
280 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
281 ; X86-X87-NEXT:    fld %st(0)
282 ; X86-X87-NEXT:    fistpll {{[0-9]+}}(%esp)
283 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
284 ; X86-X87-NEXT:    fldz
285 ; X86-X87-NEXT:    fxch %st(1)
286 ; X86-X87-NEXT:    fucom %st(1)
287 ; X86-X87-NEXT:    fstp %st(1)
288 ; X86-X87-NEXT:    fnstsw %ax
289 ; X86-X87-NEXT:    xorl %ecx, %ecx
290 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
291 ; X86-X87-NEXT:    sahf
292 ; X86-X87-NEXT:    jb .LBB4_2
293 ; X86-X87-NEXT:  # %bb.1:
294 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
295 ; X86-X87-NEXT:  .LBB4_2:
296 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
297 ; X86-X87-NEXT:    fxch %st(1)
298 ; X86-X87-NEXT:    fucompp
299 ; X86-X87-NEXT:    fnstsw %ax
300 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
301 ; X86-X87-NEXT:    sahf
302 ; X86-X87-NEXT:    movl $524287, %eax # imm = 0x7FFFF
303 ; X86-X87-NEXT:    ja .LBB4_4
304 ; X86-X87-NEXT:  # %bb.3:
305 ; X86-X87-NEXT:    movl %ecx, %eax
306 ; X86-X87-NEXT:  .LBB4_4:
307 ; X86-X87-NEXT:    addl $20, %esp
308 ; X86-X87-NEXT:    retl
310 ; X86-SSE-LABEL: test_unsigned_i19_f32:
311 ; X86-SSE:       # %bb.0:
312 ; X86-SSE-NEXT:    movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
313 ; X86-SSE-NEXT:    xorps %xmm1, %xmm1
314 ; X86-SSE-NEXT:    maxss %xmm1, %xmm0
315 ; X86-SSE-NEXT:    minss {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
316 ; X86-SSE-NEXT:    cvttss2si %xmm0, %eax
317 ; X86-SSE-NEXT:    retl
319 ; X64-LABEL: test_unsigned_i19_f32:
320 ; X64:       # %bb.0:
321 ; X64-NEXT:    xorps %xmm1, %xmm1
322 ; X64-NEXT:    maxss %xmm1, %xmm0
323 ; X64-NEXT:    minss {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm0
324 ; X64-NEXT:    cvttss2si %xmm0, %eax
325 ; X64-NEXT:    retq
326     %x = call i19 @llvm.fptoui.sat.i19.f32(float %f)
327     ret i19 %x
330 define i32 @test_unsigned_i32_f32(float %f) nounwind {
331 ; X86-X87-LABEL: test_unsigned_i32_f32:
332 ; X86-X87:       # %bb.0:
333 ; X86-X87-NEXT:    subl $20, %esp
334 ; X86-X87-NEXT:    flds {{[0-9]+}}(%esp)
335 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
336 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
337 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
338 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
339 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
340 ; X86-X87-NEXT:    fld %st(0)
341 ; X86-X87-NEXT:    fistpll {{[0-9]+}}(%esp)
342 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
343 ; X86-X87-NEXT:    fldz
344 ; X86-X87-NEXT:    fxch %st(1)
345 ; X86-X87-NEXT:    fucom %st(1)
346 ; X86-X87-NEXT:    fstp %st(1)
347 ; X86-X87-NEXT:    fnstsw %ax
348 ; X86-X87-NEXT:    xorl %ecx, %ecx
349 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
350 ; X86-X87-NEXT:    sahf
351 ; X86-X87-NEXT:    jb .LBB5_2
352 ; X86-X87-NEXT:  # %bb.1:
353 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
354 ; X86-X87-NEXT:  .LBB5_2:
355 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
356 ; X86-X87-NEXT:    fxch %st(1)
357 ; X86-X87-NEXT:    fucompp
358 ; X86-X87-NEXT:    fnstsw %ax
359 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
360 ; X86-X87-NEXT:    sahf
361 ; X86-X87-NEXT:    movl $-1, %eax
362 ; X86-X87-NEXT:    ja .LBB5_4
363 ; X86-X87-NEXT:  # %bb.3:
364 ; X86-X87-NEXT:    movl %ecx, %eax
365 ; X86-X87-NEXT:  .LBB5_4:
366 ; X86-X87-NEXT:    addl $20, %esp
367 ; X86-X87-NEXT:    retl
369 ; X86-SSE-LABEL: test_unsigned_i32_f32:
370 ; X86-SSE:       # %bb.0:
371 ; X86-SSE-NEXT:    movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
372 ; X86-SSE-NEXT:    cvttss2si %xmm0, %eax
373 ; X86-SSE-NEXT:    movl %eax, %ecx
374 ; X86-SSE-NEXT:    sarl $31, %ecx
375 ; X86-SSE-NEXT:    movaps %xmm0, %xmm1
376 ; X86-SSE-NEXT:    subss {{\.?LCPI[0-9]+_[0-9]+}}, %xmm1
377 ; X86-SSE-NEXT:    cvttss2si %xmm1, %edx
378 ; X86-SSE-NEXT:    andl %ecx, %edx
379 ; X86-SSE-NEXT:    orl %eax, %edx
380 ; X86-SSE-NEXT:    xorl %ecx, %ecx
381 ; X86-SSE-NEXT:    xorps %xmm1, %xmm1
382 ; X86-SSE-NEXT:    ucomiss %xmm1, %xmm0
383 ; X86-SSE-NEXT:    cmovael %edx, %ecx
384 ; X86-SSE-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
385 ; X86-SSE-NEXT:    movl $-1, %eax
386 ; X86-SSE-NEXT:    cmovbel %ecx, %eax
387 ; X86-SSE-NEXT:    retl
389 ; X64-LABEL: test_unsigned_i32_f32:
390 ; X64:       # %bb.0:
391 ; X64-NEXT:    cvttss2si %xmm0, %rax
392 ; X64-NEXT:    xorl %ecx, %ecx
393 ; X64-NEXT:    xorps %xmm1, %xmm1
394 ; X64-NEXT:    ucomiss %xmm1, %xmm0
395 ; X64-NEXT:    cmovael %eax, %ecx
396 ; X64-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm0
397 ; X64-NEXT:    movl $-1, %eax
398 ; X64-NEXT:    cmovbel %ecx, %eax
399 ; X64-NEXT:    retq
400     %x = call i32 @llvm.fptoui.sat.i32.f32(float %f)
401     ret i32 %x
404 define i50 @test_unsigned_i50_f32(float %f) nounwind {
405 ; X86-X87-LABEL: test_unsigned_i50_f32:
406 ; X86-X87:       # %bb.0:
407 ; X86-X87-NEXT:    pushl %esi
408 ; X86-X87-NEXT:    subl $16, %esp
409 ; X86-X87-NEXT:    flds {{[0-9]+}}(%esp)
410 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
411 ; X86-X87-NEXT:    fucom %st(1)
412 ; X86-X87-NEXT:    fnstsw %ax
413 ; X86-X87-NEXT:    xorl %ecx, %ecx
414 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
415 ; X86-X87-NEXT:    sahf
416 ; X86-X87-NEXT:    setbe %al
417 ; X86-X87-NEXT:    fldz
418 ; X86-X87-NEXT:    jbe .LBB6_2
419 ; X86-X87-NEXT:  # %bb.1:
420 ; X86-X87-NEXT:    fstp %st(1)
421 ; X86-X87-NEXT:    fld %st(0)
422 ; X86-X87-NEXT:    fxch %st(1)
423 ; X86-X87-NEXT:  .LBB6_2:
424 ; X86-X87-NEXT:    fxch %st(1)
425 ; X86-X87-NEXT:    fsubr %st(2), %st
426 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
427 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %edx
428 ; X86-X87-NEXT:    orl $3072, %edx # imm = 0xC00
429 ; X86-X87-NEXT:    movw %dx, {{[0-9]+}}(%esp)
430 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
431 ; X86-X87-NEXT:    fistpll {{[0-9]+}}(%esp)
432 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
433 ; X86-X87-NEXT:    movb %al, %cl
434 ; X86-X87-NEXT:    shll $31, %ecx
435 ; X86-X87-NEXT:    xorl {{[0-9]+}}(%esp), %ecx
436 ; X86-X87-NEXT:    fxch %st(1)
437 ; X86-X87-NEXT:    fucom %st(1)
438 ; X86-X87-NEXT:    fstp %st(1)
439 ; X86-X87-NEXT:    fnstsw %ax
440 ; X86-X87-NEXT:    xorl %edx, %edx
441 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
442 ; X86-X87-NEXT:    sahf
443 ; X86-X87-NEXT:    movl $0, %esi
444 ; X86-X87-NEXT:    jb .LBB6_4
445 ; X86-X87-NEXT:  # %bb.3:
446 ; X86-X87-NEXT:    movl %ecx, %esi
447 ; X86-X87-NEXT:  .LBB6_4:
448 ; X86-X87-NEXT:    jb .LBB6_6
449 ; X86-X87-NEXT:  # %bb.5:
450 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %edx
451 ; X86-X87-NEXT:  .LBB6_6:
452 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
453 ; X86-X87-NEXT:    fxch %st(1)
454 ; X86-X87-NEXT:    fucompp
455 ; X86-X87-NEXT:    fnstsw %ax
456 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
457 ; X86-X87-NEXT:    sahf
458 ; X86-X87-NEXT:    movl $-1, %eax
459 ; X86-X87-NEXT:    ja .LBB6_8
460 ; X86-X87-NEXT:  # %bb.7:
461 ; X86-X87-NEXT:    movl %edx, %eax
462 ; X86-X87-NEXT:  .LBB6_8:
463 ; X86-X87-NEXT:    movl $262143, %edx # imm = 0x3FFFF
464 ; X86-X87-NEXT:    ja .LBB6_10
465 ; X86-X87-NEXT:  # %bb.9:
466 ; X86-X87-NEXT:    movl %esi, %edx
467 ; X86-X87-NEXT:  .LBB6_10:
468 ; X86-X87-NEXT:    addl $16, %esp
469 ; X86-X87-NEXT:    popl %esi
470 ; X86-X87-NEXT:    retl
472 ; X86-SSE-LABEL: test_unsigned_i50_f32:
473 ; X86-SSE:       # %bb.0:
474 ; X86-SSE-NEXT:    pushl %esi
475 ; X86-SSE-NEXT:    subl $16, %esp
476 ; X86-SSE-NEXT:    movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
477 ; X86-SSE-NEXT:    movss {{.*#+}} xmm2 = mem[0],zero,zero,zero
478 ; X86-SSE-NEXT:    ucomiss %xmm0, %xmm2
479 ; X86-SSE-NEXT:    xorps %xmm1, %xmm1
480 ; X86-SSE-NEXT:    jbe .LBB6_2
481 ; X86-SSE-NEXT:  # %bb.1:
482 ; X86-SSE-NEXT:    xorps %xmm2, %xmm2
483 ; X86-SSE-NEXT:  .LBB6_2:
484 ; X86-SSE-NEXT:    movaps %xmm0, %xmm3
485 ; X86-SSE-NEXT:    subss %xmm2, %xmm3
486 ; X86-SSE-NEXT:    movss %xmm3, {{[0-9]+}}(%esp)
487 ; X86-SSE-NEXT:    setbe %cl
488 ; X86-SSE-NEXT:    flds {{[0-9]+}}(%esp)
489 ; X86-SSE-NEXT:    fnstcw {{[0-9]+}}(%esp)
490 ; X86-SSE-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
491 ; X86-SSE-NEXT:    orl $3072, %eax # imm = 0xC00
492 ; X86-SSE-NEXT:    movw %ax, {{[0-9]+}}(%esp)
493 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
494 ; X86-SSE-NEXT:    fistpll {{[0-9]+}}(%esp)
495 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
496 ; X86-SSE-NEXT:    xorl %eax, %eax
497 ; X86-SSE-NEXT:    ucomiss %xmm1, %xmm0
498 ; X86-SSE-NEXT:    movl $0, %esi
499 ; X86-SSE-NEXT:    jb .LBB6_4
500 ; X86-SSE-NEXT:  # %bb.3:
501 ; X86-SSE-NEXT:    movzbl %cl, %eax
502 ; X86-SSE-NEXT:    shll $31, %eax
503 ; X86-SSE-NEXT:    xorl {{[0-9]+}}(%esp), %eax
504 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %esi
505 ; X86-SSE-NEXT:  .LBB6_4:
506 ; X86-SSE-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
507 ; X86-SSE-NEXT:    movl $262143, %edx # imm = 0x3FFFF
508 ; X86-SSE-NEXT:    cmovbel %eax, %edx
509 ; X86-SSE-NEXT:    movl $-1, %eax
510 ; X86-SSE-NEXT:    cmovbel %esi, %eax
511 ; X86-SSE-NEXT:    addl $16, %esp
512 ; X86-SSE-NEXT:    popl %esi
513 ; X86-SSE-NEXT:    retl
515 ; X64-LABEL: test_unsigned_i50_f32:
516 ; X64:       # %bb.0:
517 ; X64-NEXT:    cvttss2si %xmm0, %rax
518 ; X64-NEXT:    xorl %ecx, %ecx
519 ; X64-NEXT:    xorps %xmm1, %xmm1
520 ; X64-NEXT:    ucomiss %xmm1, %xmm0
521 ; X64-NEXT:    cmovaeq %rax, %rcx
522 ; X64-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm0
523 ; X64-NEXT:    movabsq $1125899906842623, %rax # imm = 0x3FFFFFFFFFFFF
524 ; X64-NEXT:    cmovbeq %rcx, %rax
525 ; X64-NEXT:    retq
526     %x = call i50 @llvm.fptoui.sat.i50.f32(float %f)
527     ret i50 %x
530 define i64 @test_unsigned_i64_f32(float %f) nounwind {
531 ; X86-X87-LABEL: test_unsigned_i64_f32:
532 ; X86-X87:       # %bb.0:
533 ; X86-X87-NEXT:    pushl %edi
534 ; X86-X87-NEXT:    pushl %esi
535 ; X86-X87-NEXT:    subl $20, %esp
536 ; X86-X87-NEXT:    flds {{[0-9]+}}(%esp)
537 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
538 ; X86-X87-NEXT:    fucom %st(1)
539 ; X86-X87-NEXT:    fnstsw %ax
540 ; X86-X87-NEXT:    xorl %ecx, %ecx
541 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
542 ; X86-X87-NEXT:    sahf
543 ; X86-X87-NEXT:    setbe %al
544 ; X86-X87-NEXT:    fldz
545 ; X86-X87-NEXT:    jbe .LBB7_2
546 ; X86-X87-NEXT:  # %bb.1:
547 ; X86-X87-NEXT:    fstp %st(1)
548 ; X86-X87-NEXT:    fld %st(0)
549 ; X86-X87-NEXT:    fxch %st(1)
550 ; X86-X87-NEXT:  .LBB7_2:
551 ; X86-X87-NEXT:    fxch %st(1)
552 ; X86-X87-NEXT:    fsubr %st(2), %st
553 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
554 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %edx
555 ; X86-X87-NEXT:    orl $3072, %edx # imm = 0xC00
556 ; X86-X87-NEXT:    movw %dx, {{[0-9]+}}(%esp)
557 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
558 ; X86-X87-NEXT:    fistpll {{[0-9]+}}(%esp)
559 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
560 ; X86-X87-NEXT:    movb %al, %cl
561 ; X86-X87-NEXT:    shll $31, %ecx
562 ; X86-X87-NEXT:    xorl {{[0-9]+}}(%esp), %ecx
563 ; X86-X87-NEXT:    fxch %st(1)
564 ; X86-X87-NEXT:    fucom %st(1)
565 ; X86-X87-NEXT:    fstp %st(1)
566 ; X86-X87-NEXT:    fnstsw %ax
567 ; X86-X87-NEXT:    xorl %esi, %esi
568 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
569 ; X86-X87-NEXT:    sahf
570 ; X86-X87-NEXT:    movl $0, %edi
571 ; X86-X87-NEXT:    jb .LBB7_4
572 ; X86-X87-NEXT:  # %bb.3:
573 ; X86-X87-NEXT:    movl %ecx, %edi
574 ; X86-X87-NEXT:  .LBB7_4:
575 ; X86-X87-NEXT:    jb .LBB7_6
576 ; X86-X87-NEXT:  # %bb.5:
577 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %esi
578 ; X86-X87-NEXT:  .LBB7_6:
579 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
580 ; X86-X87-NEXT:    fxch %st(1)
581 ; X86-X87-NEXT:    fucompp
582 ; X86-X87-NEXT:    fnstsw %ax
583 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
584 ; X86-X87-NEXT:    sahf
585 ; X86-X87-NEXT:    movl $-1, %eax
586 ; X86-X87-NEXT:    movl $-1, %edx
587 ; X86-X87-NEXT:    ja .LBB7_8
588 ; X86-X87-NEXT:  # %bb.7:
589 ; X86-X87-NEXT:    movl %esi, %eax
590 ; X86-X87-NEXT:    movl %edi, %edx
591 ; X86-X87-NEXT:  .LBB7_8:
592 ; X86-X87-NEXT:    addl $20, %esp
593 ; X86-X87-NEXT:    popl %esi
594 ; X86-X87-NEXT:    popl %edi
595 ; X86-X87-NEXT:    retl
597 ; X86-SSE-LABEL: test_unsigned_i64_f32:
598 ; X86-SSE:       # %bb.0:
599 ; X86-SSE-NEXT:    subl $20, %esp
600 ; X86-SSE-NEXT:    movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
601 ; X86-SSE-NEXT:    movss {{.*#+}} xmm2 = mem[0],zero,zero,zero
602 ; X86-SSE-NEXT:    ucomiss %xmm0, %xmm2
603 ; X86-SSE-NEXT:    xorps %xmm1, %xmm1
604 ; X86-SSE-NEXT:    jbe .LBB7_2
605 ; X86-SSE-NEXT:  # %bb.1:
606 ; X86-SSE-NEXT:    xorps %xmm2, %xmm2
607 ; X86-SSE-NEXT:  .LBB7_2:
608 ; X86-SSE-NEXT:    movaps %xmm0, %xmm3
609 ; X86-SSE-NEXT:    subss %xmm2, %xmm3
610 ; X86-SSE-NEXT:    movss %xmm3, {{[0-9]+}}(%esp)
611 ; X86-SSE-NEXT:    setbe %cl
612 ; X86-SSE-NEXT:    flds {{[0-9]+}}(%esp)
613 ; X86-SSE-NEXT:    fnstcw {{[0-9]+}}(%esp)
614 ; X86-SSE-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
615 ; X86-SSE-NEXT:    orl $3072, %eax # imm = 0xC00
616 ; X86-SSE-NEXT:    movw %ax, {{[0-9]+}}(%esp)
617 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
618 ; X86-SSE-NEXT:    fistpll {{[0-9]+}}(%esp)
619 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
620 ; X86-SSE-NEXT:    xorl %edx, %edx
621 ; X86-SSE-NEXT:    ucomiss %xmm1, %xmm0
622 ; X86-SSE-NEXT:    movl $0, %eax
623 ; X86-SSE-NEXT:    jb .LBB7_4
624 ; X86-SSE-NEXT:  # %bb.3:
625 ; X86-SSE-NEXT:    movzbl %cl, %edx
626 ; X86-SSE-NEXT:    shll $31, %edx
627 ; X86-SSE-NEXT:    xorl {{[0-9]+}}(%esp), %edx
628 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %eax
629 ; X86-SSE-NEXT:  .LBB7_4:
630 ; X86-SSE-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
631 ; X86-SSE-NEXT:    movl $-1, %ecx
632 ; X86-SSE-NEXT:    cmoval %ecx, %edx
633 ; X86-SSE-NEXT:    cmoval %ecx, %eax
634 ; X86-SSE-NEXT:    addl $20, %esp
635 ; X86-SSE-NEXT:    retl
637 ; X64-LABEL: test_unsigned_i64_f32:
638 ; X64:       # %bb.0:
639 ; X64-NEXT:    cvttss2si %xmm0, %rax
640 ; X64-NEXT:    movq %rax, %rcx
641 ; X64-NEXT:    sarq $63, %rcx
642 ; X64-NEXT:    movaps %xmm0, %xmm1
643 ; X64-NEXT:    subss {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm1
644 ; X64-NEXT:    cvttss2si %xmm1, %rdx
645 ; X64-NEXT:    andq %rcx, %rdx
646 ; X64-NEXT:    orq %rax, %rdx
647 ; X64-NEXT:    xorl %ecx, %ecx
648 ; X64-NEXT:    xorps %xmm1, %xmm1
649 ; X64-NEXT:    ucomiss %xmm1, %xmm0
650 ; X64-NEXT:    cmovaeq %rdx, %rcx
651 ; X64-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm0
652 ; X64-NEXT:    movq $-1, %rax
653 ; X64-NEXT:    cmovbeq %rcx, %rax
654 ; X64-NEXT:    retq
655     %x = call i64 @llvm.fptoui.sat.i64.f32(float %f)
656     ret i64 %x
659 define i100 @test_unsigned_i100_f32(float %f) nounwind {
660 ; X86-X87-LABEL: test_unsigned_i100_f32:
661 ; X86-X87:       # %bb.0:
662 ; X86-X87-NEXT:    pushl %ebp
663 ; X86-X87-NEXT:    pushl %ebx
664 ; X86-X87-NEXT:    pushl %edi
665 ; X86-X87-NEXT:    pushl %esi
666 ; X86-X87-NEXT:    subl $44, %esp
667 ; X86-X87-NEXT:    flds {{[0-9]+}}(%esp)
668 ; X86-X87-NEXT:    fsts {{[0-9]+}}(%esp)
669 ; X86-X87-NEXT:    leal {{[0-9]+}}(%esp), %eax
670 ; X86-X87-NEXT:    movl %eax, (%esp)
671 ; X86-X87-NEXT:    fldz
672 ; X86-X87-NEXT:    fxch %st(1)
673 ; X86-X87-NEXT:    fsts {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Folded Spill
674 ; X86-X87-NEXT:    fucompp
675 ; X86-X87-NEXT:    fnstsw %ax
676 ; X86-X87-NEXT:    movl %eax, %ebx
677 ; X86-X87-NEXT:    calll __fixunssfti
678 ; X86-X87-NEXT:    subl $4, %esp
679 ; X86-X87-NEXT:    xorl %edi, %edi
680 ; X86-X87-NEXT:    movb %bh, %ah
681 ; X86-X87-NEXT:    sahf
682 ; X86-X87-NEXT:    movl $0, %eax
683 ; X86-X87-NEXT:    jb .LBB8_2
684 ; X86-X87-NEXT:  # %bb.1:
685 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %eax
686 ; X86-X87-NEXT:  .LBB8_2:
687 ; X86-X87-NEXT:    movl $0, %esi
688 ; X86-X87-NEXT:    movl $0, %ebx
689 ; X86-X87-NEXT:    jb .LBB8_4
690 ; X86-X87-NEXT:  # %bb.3:
691 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ebx
692 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %esi
693 ; X86-X87-NEXT:  .LBB8_4:
694 ; X86-X87-NEXT:    jb .LBB8_6
695 ; X86-X87-NEXT:  # %bb.5:
696 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %edi
697 ; X86-X87-NEXT:  .LBB8_6:
698 ; X86-X87-NEXT:    movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill
699 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
700 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
701 ; X86-X87-NEXT:    flds {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Folded Reload
702 ; X86-X87-NEXT:    fucompp
703 ; X86-X87-NEXT:    fnstsw %ax
704 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
705 ; X86-X87-NEXT:    sahf
706 ; X86-X87-NEXT:    movl $15, %eax
707 ; X86-X87-NEXT:    ja .LBB8_8
708 ; X86-X87-NEXT:  # %bb.7:
709 ; X86-X87-NEXT:    movl %edi, %eax
710 ; X86-X87-NEXT:  .LBB8_8:
711 ; X86-X87-NEXT:    movl $-1, %edi
712 ; X86-X87-NEXT:    movl $-1, %ebp
713 ; X86-X87-NEXT:    movl $-1, %edx
714 ; X86-X87-NEXT:    ja .LBB8_10
715 ; X86-X87-NEXT:  # %bb.9:
716 ; X86-X87-NEXT:    movl %ebx, %edi
717 ; X86-X87-NEXT:    movl %esi, %ebp
718 ; X86-X87-NEXT:    movl {{[-0-9]+}}(%e{{[sb]}}p), %edx # 4-byte Reload
719 ; X86-X87-NEXT:  .LBB8_10:
720 ; X86-X87-NEXT:    movl %edx, 8(%ecx)
721 ; X86-X87-NEXT:    movl %ebp, 4(%ecx)
722 ; X86-X87-NEXT:    movl %edi, (%ecx)
723 ; X86-X87-NEXT:    andl $15, %eax
724 ; X86-X87-NEXT:    movb %al, 12(%ecx)
725 ; X86-X87-NEXT:    movl %ecx, %eax
726 ; X86-X87-NEXT:    addl $44, %esp
727 ; X86-X87-NEXT:    popl %esi
728 ; X86-X87-NEXT:    popl %edi
729 ; X86-X87-NEXT:    popl %ebx
730 ; X86-X87-NEXT:    popl %ebp
731 ; X86-X87-NEXT:    retl $4
733 ; X86-SSE-LABEL: test_unsigned_i100_f32:
734 ; X86-SSE:       # %bb.0:
735 ; X86-SSE-NEXT:    pushl %ebx
736 ; X86-SSE-NEXT:    pushl %edi
737 ; X86-SSE-NEXT:    pushl %esi
738 ; X86-SSE-NEXT:    subl $32, %esp
739 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %esi
740 ; X86-SSE-NEXT:    movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
741 ; X86-SSE-NEXT:    movss %xmm0, {{[0-9]+}}(%esp)
742 ; X86-SSE-NEXT:    leal {{[0-9]+}}(%esp), %eax
743 ; X86-SSE-NEXT:    movl %eax, (%esp)
744 ; X86-SSE-NEXT:    calll __fixunssfti
745 ; X86-SSE-NEXT:    subl $4, %esp
746 ; X86-SSE-NEXT:    xorl %eax, %eax
747 ; X86-SSE-NEXT:    xorps %xmm0, %xmm0
748 ; X86-SSE-NEXT:    movss {{.*#+}} xmm1 = mem[0],zero,zero,zero
749 ; X86-SSE-NEXT:    ucomiss %xmm0, %xmm1
750 ; X86-SSE-NEXT:    movaps %xmm1, %xmm0
751 ; X86-SSE-NEXT:    movl $0, %ecx
752 ; X86-SSE-NEXT:    movl $0, %edx
753 ; X86-SSE-NEXT:    movl $0, %edi
754 ; X86-SSE-NEXT:    jb .LBB8_2
755 ; X86-SSE-NEXT:  # %bb.1:
756 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %eax
757 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %ecx
758 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %edx
759 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %edi
760 ; X86-SSE-NEXT:  .LBB8_2:
761 ; X86-SSE-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
762 ; X86-SSE-NEXT:    movl $15, %ebx
763 ; X86-SSE-NEXT:    cmovbel %edi, %ebx
764 ; X86-SSE-NEXT:    movl $-1, %edi
765 ; X86-SSE-NEXT:    cmoval %edi, %edx
766 ; X86-SSE-NEXT:    cmoval %edi, %ecx
767 ; X86-SSE-NEXT:    cmoval %edi, %eax
768 ; X86-SSE-NEXT:    movl %eax, 8(%esi)
769 ; X86-SSE-NEXT:    movl %ecx, 4(%esi)
770 ; X86-SSE-NEXT:    movl %edx, (%esi)
771 ; X86-SSE-NEXT:    andl $15, %ebx
772 ; X86-SSE-NEXT:    movb %bl, 12(%esi)
773 ; X86-SSE-NEXT:    movl %esi, %eax
774 ; X86-SSE-NEXT:    addl $32, %esp
775 ; X86-SSE-NEXT:    popl %esi
776 ; X86-SSE-NEXT:    popl %edi
777 ; X86-SSE-NEXT:    popl %ebx
778 ; X86-SSE-NEXT:    retl $4
780 ; X64-LABEL: test_unsigned_i100_f32:
781 ; X64:       # %bb.0:
782 ; X64-NEXT:    pushq %rax
783 ; X64-NEXT:    movss %xmm0, {{[-0-9]+}}(%r{{[sb]}}p) # 4-byte Spill
784 ; X64-NEXT:    callq __fixunssfti@PLT
785 ; X64-NEXT:    xorl %ecx, %ecx
786 ; X64-NEXT:    xorps %xmm0, %xmm0
787 ; X64-NEXT:    movss {{[-0-9]+}}(%r{{[sb]}}p), %xmm1 # 4-byte Reload
788 ; X64-NEXT:    # xmm1 = mem[0],zero,zero,zero
789 ; X64-NEXT:    ucomiss %xmm0, %xmm1
790 ; X64-NEXT:    cmovbq %rcx, %rdx
791 ; X64-NEXT:    cmovbq %rcx, %rax
792 ; X64-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm1
793 ; X64-NEXT:    movq $-1, %rcx
794 ; X64-NEXT:    cmovaq %rcx, %rax
795 ; X64-NEXT:    movabsq $68719476735, %rcx # imm = 0xFFFFFFFFF
796 ; X64-NEXT:    cmovaq %rcx, %rdx
797 ; X64-NEXT:    popq %rcx
798 ; X64-NEXT:    retq
799     %x = call i100 @llvm.fptoui.sat.i100.f32(float %f)
800     ret i100 %x
803 define i128 @test_unsigned_i128_f32(float %f) nounwind {
804 ; X86-X87-LABEL: test_unsigned_i128_f32:
805 ; X86-X87:       # %bb.0:
806 ; X86-X87-NEXT:    pushl %ebp
807 ; X86-X87-NEXT:    pushl %ebx
808 ; X86-X87-NEXT:    pushl %edi
809 ; X86-X87-NEXT:    pushl %esi
810 ; X86-X87-NEXT:    subl $60, %esp
811 ; X86-X87-NEXT:    flds {{[0-9]+}}(%esp)
812 ; X86-X87-NEXT:    fsts {{[0-9]+}}(%esp)
813 ; X86-X87-NEXT:    leal {{[0-9]+}}(%esp), %eax
814 ; X86-X87-NEXT:    movl %eax, (%esp)
815 ; X86-X87-NEXT:    fldz
816 ; X86-X87-NEXT:    fxch %st(1)
817 ; X86-X87-NEXT:    fsts {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Folded Spill
818 ; X86-X87-NEXT:    fucompp
819 ; X86-X87-NEXT:    fnstsw %ax
820 ; X86-X87-NEXT:    movl %eax, %ebx
821 ; X86-X87-NEXT:    calll __fixunssfti
822 ; X86-X87-NEXT:    subl $4, %esp
823 ; X86-X87-NEXT:    xorl %edx, %edx
824 ; X86-X87-NEXT:    movb %bh, %ah
825 ; X86-X87-NEXT:    sahf
826 ; X86-X87-NEXT:    movl $0, %eax
827 ; X86-X87-NEXT:    jb .LBB9_2
828 ; X86-X87-NEXT:  # %bb.1:
829 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %eax
830 ; X86-X87-NEXT:  .LBB9_2:
831 ; X86-X87-NEXT:    movl $0, %ecx
832 ; X86-X87-NEXT:    jb .LBB9_4
833 ; X86-X87-NEXT:  # %bb.3:
834 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
835 ; X86-X87-NEXT:  .LBB9_4:
836 ; X86-X87-NEXT:    movl %ecx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill
837 ; X86-X87-NEXT:    movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill
838 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
839 ; X86-X87-NEXT:    movl $0, %ebx
840 ; X86-X87-NEXT:    jb .LBB9_6
841 ; X86-X87-NEXT:  # %bb.5:
842 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ebx
843 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %edx
844 ; X86-X87-NEXT:  .LBB9_6:
845 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
846 ; X86-X87-NEXT:    flds {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Folded Reload
847 ; X86-X87-NEXT:    fucompp
848 ; X86-X87-NEXT:    fnstsw %ax
849 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
850 ; X86-X87-NEXT:    sahf
851 ; X86-X87-NEXT:    movl $-1, %eax
852 ; X86-X87-NEXT:    movl $-1, %ebp
853 ; X86-X87-NEXT:    movl $-1, %edi
854 ; X86-X87-NEXT:    movl $-1, %esi
855 ; X86-X87-NEXT:    ja .LBB9_8
856 ; X86-X87-NEXT:  # %bb.7:
857 ; X86-X87-NEXT:    movl %ebx, %eax
858 ; X86-X87-NEXT:    movl %edx, %ebp
859 ; X86-X87-NEXT:    movl {{[-0-9]+}}(%e{{[sb]}}p), %edi # 4-byte Reload
860 ; X86-X87-NEXT:    movl {{[-0-9]+}}(%e{{[sb]}}p), %esi # 4-byte Reload
861 ; X86-X87-NEXT:  .LBB9_8:
862 ; X86-X87-NEXT:    movl %esi, 12(%ecx)
863 ; X86-X87-NEXT:    movl %edi, 8(%ecx)
864 ; X86-X87-NEXT:    movl %ebp, 4(%ecx)
865 ; X86-X87-NEXT:    movl %eax, (%ecx)
866 ; X86-X87-NEXT:    movl %ecx, %eax
867 ; X86-X87-NEXT:    addl $60, %esp
868 ; X86-X87-NEXT:    popl %esi
869 ; X86-X87-NEXT:    popl %edi
870 ; X86-X87-NEXT:    popl %ebx
871 ; X86-X87-NEXT:    popl %ebp
872 ; X86-X87-NEXT:    retl $4
874 ; X86-SSE-LABEL: test_unsigned_i128_f32:
875 ; X86-SSE:       # %bb.0:
876 ; X86-SSE-NEXT:    pushl %ebx
877 ; X86-SSE-NEXT:    pushl %edi
878 ; X86-SSE-NEXT:    pushl %esi
879 ; X86-SSE-NEXT:    subl $32, %esp
880 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %esi
881 ; X86-SSE-NEXT:    movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
882 ; X86-SSE-NEXT:    movss %xmm0, {{[0-9]+}}(%esp)
883 ; X86-SSE-NEXT:    leal {{[0-9]+}}(%esp), %eax
884 ; X86-SSE-NEXT:    movl %eax, (%esp)
885 ; X86-SSE-NEXT:    calll __fixunssfti
886 ; X86-SSE-NEXT:    subl $4, %esp
887 ; X86-SSE-NEXT:    xorl %eax, %eax
888 ; X86-SSE-NEXT:    xorps %xmm0, %xmm0
889 ; X86-SSE-NEXT:    movss {{.*#+}} xmm1 = mem[0],zero,zero,zero
890 ; X86-SSE-NEXT:    ucomiss %xmm0, %xmm1
891 ; X86-SSE-NEXT:    movaps %xmm1, %xmm0
892 ; X86-SSE-NEXT:    movl $0, %ecx
893 ; X86-SSE-NEXT:    movl $0, %edx
894 ; X86-SSE-NEXT:    movl $0, %edi
895 ; X86-SSE-NEXT:    jb .LBB9_2
896 ; X86-SSE-NEXT:  # %bb.1:
897 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %eax
898 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %ecx
899 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %edx
900 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %edi
901 ; X86-SSE-NEXT:  .LBB9_2:
902 ; X86-SSE-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
903 ; X86-SSE-NEXT:    movl $-1, %ebx
904 ; X86-SSE-NEXT:    cmoval %ebx, %edi
905 ; X86-SSE-NEXT:    cmoval %ebx, %edx
906 ; X86-SSE-NEXT:    cmoval %ebx, %ecx
907 ; X86-SSE-NEXT:    cmoval %ebx, %eax
908 ; X86-SSE-NEXT:    movl %eax, 12(%esi)
909 ; X86-SSE-NEXT:    movl %ecx, 8(%esi)
910 ; X86-SSE-NEXT:    movl %edx, 4(%esi)
911 ; X86-SSE-NEXT:    movl %edi, (%esi)
912 ; X86-SSE-NEXT:    movl %esi, %eax
913 ; X86-SSE-NEXT:    addl $32, %esp
914 ; X86-SSE-NEXT:    popl %esi
915 ; X86-SSE-NEXT:    popl %edi
916 ; X86-SSE-NEXT:    popl %ebx
917 ; X86-SSE-NEXT:    retl $4
919 ; X64-LABEL: test_unsigned_i128_f32:
920 ; X64:       # %bb.0:
921 ; X64-NEXT:    pushq %rax
922 ; X64-NEXT:    movss %xmm0, {{[-0-9]+}}(%r{{[sb]}}p) # 4-byte Spill
923 ; X64-NEXT:    callq __fixunssfti@PLT
924 ; X64-NEXT:    xorl %ecx, %ecx
925 ; X64-NEXT:    xorps %xmm0, %xmm0
926 ; X64-NEXT:    movss {{[-0-9]+}}(%r{{[sb]}}p), %xmm1 # 4-byte Reload
927 ; X64-NEXT:    # xmm1 = mem[0],zero,zero,zero
928 ; X64-NEXT:    ucomiss %xmm0, %xmm1
929 ; X64-NEXT:    cmovbq %rcx, %rdx
930 ; X64-NEXT:    cmovbq %rcx, %rax
931 ; X64-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm1
932 ; X64-NEXT:    movq $-1, %rcx
933 ; X64-NEXT:    cmovaq %rcx, %rax
934 ; X64-NEXT:    cmovaq %rcx, %rdx
935 ; X64-NEXT:    popq %rcx
936 ; X64-NEXT:    retq
937     %x = call i128 @llvm.fptoui.sat.i128.f32(float %f)
938     ret i128 %x
942 ; 64-bit float to unsigned integer
945 declare   i1 @llvm.fptoui.sat.i1.f64  (double)
946 declare   i8 @llvm.fptoui.sat.i8.f64  (double)
947 declare  i13 @llvm.fptoui.sat.i13.f64 (double)
948 declare  i16 @llvm.fptoui.sat.i16.f64 (double)
949 declare  i19 @llvm.fptoui.sat.i19.f64 (double)
950 declare  i32 @llvm.fptoui.sat.i32.f64 (double)
951 declare  i50 @llvm.fptoui.sat.i50.f64 (double)
952 declare  i64 @llvm.fptoui.sat.i64.f64 (double)
953 declare i100 @llvm.fptoui.sat.i100.f64(double)
954 declare i128 @llvm.fptoui.sat.i128.f64(double)
956 define i1 @test_unsigned_i1_f64(double %f) nounwind {
957 ; X86-X87-LABEL: test_unsigned_i1_f64:
958 ; X86-X87:       # %bb.0:
959 ; X86-X87-NEXT:    subl $8, %esp
960 ; X86-X87-NEXT:    fldl {{[0-9]+}}(%esp)
961 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
962 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
963 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
964 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
965 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
966 ; X86-X87-NEXT:    fists {{[0-9]+}}(%esp)
967 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
968 ; X86-X87-NEXT:    fldz
969 ; X86-X87-NEXT:    fxch %st(1)
970 ; X86-X87-NEXT:    fucom %st(1)
971 ; X86-X87-NEXT:    fstp %st(1)
972 ; X86-X87-NEXT:    fnstsw %ax
973 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
974 ; X86-X87-NEXT:    sahf
975 ; X86-X87-NEXT:    jb .LBB10_1
976 ; X86-X87-NEXT:  # %bb.2:
977 ; X86-X87-NEXT:    movzbl {{[0-9]+}}(%esp), %ecx
978 ; X86-X87-NEXT:    jmp .LBB10_3
979 ; X86-X87-NEXT:  .LBB10_1:
980 ; X86-X87-NEXT:    xorl %ecx, %ecx
981 ; X86-X87-NEXT:  .LBB10_3:
982 ; X86-X87-NEXT:    fld1
983 ; X86-X87-NEXT:    fxch %st(1)
984 ; X86-X87-NEXT:    fucompp
985 ; X86-X87-NEXT:    fnstsw %ax
986 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
987 ; X86-X87-NEXT:    sahf
988 ; X86-X87-NEXT:    movb $1, %al
989 ; X86-X87-NEXT:    ja .LBB10_5
990 ; X86-X87-NEXT:  # %bb.4:
991 ; X86-X87-NEXT:    movl %ecx, %eax
992 ; X86-X87-NEXT:  .LBB10_5:
993 ; X86-X87-NEXT:    addl $8, %esp
994 ; X86-X87-NEXT:    retl
996 ; X86-SSE-LABEL: test_unsigned_i1_f64:
997 ; X86-SSE:       # %bb.0:
998 ; X86-SSE-NEXT:    xorpd %xmm0, %xmm0
999 ; X86-SSE-NEXT:    maxsd {{[0-9]+}}(%esp), %xmm0
1000 ; X86-SSE-NEXT:    movsd {{.*#+}} xmm1 = mem[0],zero
1001 ; X86-SSE-NEXT:    minsd %xmm0, %xmm1
1002 ; X86-SSE-NEXT:    cvttsd2si %xmm1, %eax
1003 ; X86-SSE-NEXT:    # kill: def $al killed $al killed $eax
1004 ; X86-SSE-NEXT:    retl
1006 ; X64-LABEL: test_unsigned_i1_f64:
1007 ; X64:       # %bb.0:
1008 ; X64-NEXT:    xorpd %xmm1, %xmm1
1009 ; X64-NEXT:    maxsd %xmm0, %xmm1
1010 ; X64-NEXT:    movsd {{.*#+}} xmm0 = mem[0],zero
1011 ; X64-NEXT:    minsd %xmm1, %xmm0
1012 ; X64-NEXT:    cvttsd2si %xmm0, %eax
1013 ; X64-NEXT:    # kill: def $al killed $al killed $eax
1014 ; X64-NEXT:    retq
1015     %x = call i1 @llvm.fptoui.sat.i1.f64(double %f)
1016     ret i1 %x
1019 define i8 @test_unsigned_i8_f64(double %f) nounwind {
1020 ; X86-X87-LABEL: test_unsigned_i8_f64:
1021 ; X86-X87:       # %bb.0:
1022 ; X86-X87-NEXT:    subl $8, %esp
1023 ; X86-X87-NEXT:    fldl {{[0-9]+}}(%esp)
1024 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
1025 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
1026 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
1027 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
1028 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
1029 ; X86-X87-NEXT:    fists {{[0-9]+}}(%esp)
1030 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
1031 ; X86-X87-NEXT:    fldz
1032 ; X86-X87-NEXT:    fxch %st(1)
1033 ; X86-X87-NEXT:    fucom %st(1)
1034 ; X86-X87-NEXT:    fstp %st(1)
1035 ; X86-X87-NEXT:    fnstsw %ax
1036 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
1037 ; X86-X87-NEXT:    sahf
1038 ; X86-X87-NEXT:    jb .LBB11_1
1039 ; X86-X87-NEXT:  # %bb.2:
1040 ; X86-X87-NEXT:    movzbl {{[0-9]+}}(%esp), %ecx
1041 ; X86-X87-NEXT:    jmp .LBB11_3
1042 ; X86-X87-NEXT:  .LBB11_1:
1043 ; X86-X87-NEXT:    xorl %ecx, %ecx
1044 ; X86-X87-NEXT:  .LBB11_3:
1045 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
1046 ; X86-X87-NEXT:    fxch %st(1)
1047 ; X86-X87-NEXT:    fucompp
1048 ; X86-X87-NEXT:    fnstsw %ax
1049 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
1050 ; X86-X87-NEXT:    sahf
1051 ; X86-X87-NEXT:    movb $-1, %al
1052 ; X86-X87-NEXT:    ja .LBB11_5
1053 ; X86-X87-NEXT:  # %bb.4:
1054 ; X86-X87-NEXT:    movl %ecx, %eax
1055 ; X86-X87-NEXT:  .LBB11_5:
1056 ; X86-X87-NEXT:    addl $8, %esp
1057 ; X86-X87-NEXT:    retl
1059 ; X86-SSE-LABEL: test_unsigned_i8_f64:
1060 ; X86-SSE:       # %bb.0:
1061 ; X86-SSE-NEXT:    xorpd %xmm0, %xmm0
1062 ; X86-SSE-NEXT:    maxsd {{[0-9]+}}(%esp), %xmm0
1063 ; X86-SSE-NEXT:    movsd {{.*#+}} xmm1 = mem[0],zero
1064 ; X86-SSE-NEXT:    minsd %xmm0, %xmm1
1065 ; X86-SSE-NEXT:    cvttsd2si %xmm1, %eax
1066 ; X86-SSE-NEXT:    # kill: def $al killed $al killed $eax
1067 ; X86-SSE-NEXT:    retl
1069 ; X64-LABEL: test_unsigned_i8_f64:
1070 ; X64:       # %bb.0:
1071 ; X64-NEXT:    xorpd %xmm1, %xmm1
1072 ; X64-NEXT:    maxsd %xmm0, %xmm1
1073 ; X64-NEXT:    movsd {{.*#+}} xmm0 = mem[0],zero
1074 ; X64-NEXT:    minsd %xmm1, %xmm0
1075 ; X64-NEXT:    cvttsd2si %xmm0, %eax
1076 ; X64-NEXT:    # kill: def $al killed $al killed $eax
1077 ; X64-NEXT:    retq
1078     %x = call i8 @llvm.fptoui.sat.i8.f64(double %f)
1079     ret i8 %x
1082 define i13 @test_unsigned_i13_f64(double %f) nounwind {
1083 ; X86-X87-LABEL: test_unsigned_i13_f64:
1084 ; X86-X87:       # %bb.0:
1085 ; X86-X87-NEXT:    subl $8, %esp
1086 ; X86-X87-NEXT:    fldl {{[0-9]+}}(%esp)
1087 ; X86-X87-NEXT:    fnstcw (%esp)
1088 ; X86-X87-NEXT:    movzwl (%esp), %eax
1089 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
1090 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
1091 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
1092 ; X86-X87-NEXT:    fistl {{[0-9]+}}(%esp)
1093 ; X86-X87-NEXT:    fldcw (%esp)
1094 ; X86-X87-NEXT:    fldz
1095 ; X86-X87-NEXT:    fxch %st(1)
1096 ; X86-X87-NEXT:    fucom %st(1)
1097 ; X86-X87-NEXT:    fstp %st(1)
1098 ; X86-X87-NEXT:    fnstsw %ax
1099 ; X86-X87-NEXT:    xorl %ecx, %ecx
1100 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
1101 ; X86-X87-NEXT:    sahf
1102 ; X86-X87-NEXT:    jb .LBB12_2
1103 ; X86-X87-NEXT:  # %bb.1:
1104 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
1105 ; X86-X87-NEXT:  .LBB12_2:
1106 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
1107 ; X86-X87-NEXT:    fxch %st(1)
1108 ; X86-X87-NEXT:    fucompp
1109 ; X86-X87-NEXT:    fnstsw %ax
1110 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
1111 ; X86-X87-NEXT:    sahf
1112 ; X86-X87-NEXT:    movl $8191, %eax # imm = 0x1FFF
1113 ; X86-X87-NEXT:    ja .LBB12_4
1114 ; X86-X87-NEXT:  # %bb.3:
1115 ; X86-X87-NEXT:    movl %ecx, %eax
1116 ; X86-X87-NEXT:  .LBB12_4:
1117 ; X86-X87-NEXT:    # kill: def $ax killed $ax killed $eax
1118 ; X86-X87-NEXT:    addl $8, %esp
1119 ; X86-X87-NEXT:    retl
1121 ; X86-SSE-LABEL: test_unsigned_i13_f64:
1122 ; X86-SSE:       # %bb.0:
1123 ; X86-SSE-NEXT:    xorpd %xmm0, %xmm0
1124 ; X86-SSE-NEXT:    maxsd {{[0-9]+}}(%esp), %xmm0
1125 ; X86-SSE-NEXT:    movsd {{.*#+}} xmm1 = mem[0],zero
1126 ; X86-SSE-NEXT:    minsd %xmm0, %xmm1
1127 ; X86-SSE-NEXT:    cvttsd2si %xmm1, %eax
1128 ; X86-SSE-NEXT:    # kill: def $ax killed $ax killed $eax
1129 ; X86-SSE-NEXT:    retl
1131 ; X64-LABEL: test_unsigned_i13_f64:
1132 ; X64:       # %bb.0:
1133 ; X64-NEXT:    xorpd %xmm1, %xmm1
1134 ; X64-NEXT:    maxsd %xmm0, %xmm1
1135 ; X64-NEXT:    movsd {{.*#+}} xmm0 = mem[0],zero
1136 ; X64-NEXT:    minsd %xmm1, %xmm0
1137 ; X64-NEXT:    cvttsd2si %xmm0, %eax
1138 ; X64-NEXT:    # kill: def $ax killed $ax killed $eax
1139 ; X64-NEXT:    retq
1140     %x = call i13 @llvm.fptoui.sat.i13.f64(double %f)
1141     ret i13 %x
1144 define i16 @test_unsigned_i16_f64(double %f) nounwind {
1145 ; X86-X87-LABEL: test_unsigned_i16_f64:
1146 ; X86-X87:       # %bb.0:
1147 ; X86-X87-NEXT:    subl $8, %esp
1148 ; X86-X87-NEXT:    fldl {{[0-9]+}}(%esp)
1149 ; X86-X87-NEXT:    fnstcw (%esp)
1150 ; X86-X87-NEXT:    movzwl (%esp), %eax
1151 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
1152 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
1153 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
1154 ; X86-X87-NEXT:    fistl {{[0-9]+}}(%esp)
1155 ; X86-X87-NEXT:    fldcw (%esp)
1156 ; X86-X87-NEXT:    fldz
1157 ; X86-X87-NEXT:    fxch %st(1)
1158 ; X86-X87-NEXT:    fucom %st(1)
1159 ; X86-X87-NEXT:    fstp %st(1)
1160 ; X86-X87-NEXT:    fnstsw %ax
1161 ; X86-X87-NEXT:    xorl %ecx, %ecx
1162 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
1163 ; X86-X87-NEXT:    sahf
1164 ; X86-X87-NEXT:    jb .LBB13_2
1165 ; X86-X87-NEXT:  # %bb.1:
1166 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
1167 ; X86-X87-NEXT:  .LBB13_2:
1168 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
1169 ; X86-X87-NEXT:    fxch %st(1)
1170 ; X86-X87-NEXT:    fucompp
1171 ; X86-X87-NEXT:    fnstsw %ax
1172 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
1173 ; X86-X87-NEXT:    sahf
1174 ; X86-X87-NEXT:    movl $65535, %eax # imm = 0xFFFF
1175 ; X86-X87-NEXT:    ja .LBB13_4
1176 ; X86-X87-NEXT:  # %bb.3:
1177 ; X86-X87-NEXT:    movl %ecx, %eax
1178 ; X86-X87-NEXT:  .LBB13_4:
1179 ; X86-X87-NEXT:    # kill: def $ax killed $ax killed $eax
1180 ; X86-X87-NEXT:    addl $8, %esp
1181 ; X86-X87-NEXT:    retl
1183 ; X86-SSE-LABEL: test_unsigned_i16_f64:
1184 ; X86-SSE:       # %bb.0:
1185 ; X86-SSE-NEXT:    xorpd %xmm0, %xmm0
1186 ; X86-SSE-NEXT:    maxsd {{[0-9]+}}(%esp), %xmm0
1187 ; X86-SSE-NEXT:    movsd {{.*#+}} xmm1 = mem[0],zero
1188 ; X86-SSE-NEXT:    minsd %xmm0, %xmm1
1189 ; X86-SSE-NEXT:    cvttsd2si %xmm1, %eax
1190 ; X86-SSE-NEXT:    # kill: def $ax killed $ax killed $eax
1191 ; X86-SSE-NEXT:    retl
1193 ; X64-LABEL: test_unsigned_i16_f64:
1194 ; X64:       # %bb.0:
1195 ; X64-NEXT:    xorpd %xmm1, %xmm1
1196 ; X64-NEXT:    maxsd %xmm0, %xmm1
1197 ; X64-NEXT:    movsd {{.*#+}} xmm0 = mem[0],zero
1198 ; X64-NEXT:    minsd %xmm1, %xmm0
1199 ; X64-NEXT:    cvttsd2si %xmm0, %eax
1200 ; X64-NEXT:    # kill: def $ax killed $ax killed $eax
1201 ; X64-NEXT:    retq
1202     %x = call i16 @llvm.fptoui.sat.i16.f64(double %f)
1203     ret i16 %x
1206 define i19 @test_unsigned_i19_f64(double %f) nounwind {
1207 ; X86-X87-LABEL: test_unsigned_i19_f64:
1208 ; X86-X87:       # %bb.0:
1209 ; X86-X87-NEXT:    subl $20, %esp
1210 ; X86-X87-NEXT:    fldl {{[0-9]+}}(%esp)
1211 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
1212 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
1213 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
1214 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
1215 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
1216 ; X86-X87-NEXT:    fld %st(0)
1217 ; X86-X87-NEXT:    fistpll {{[0-9]+}}(%esp)
1218 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
1219 ; X86-X87-NEXT:    fldz
1220 ; X86-X87-NEXT:    fxch %st(1)
1221 ; X86-X87-NEXT:    fucom %st(1)
1222 ; X86-X87-NEXT:    fstp %st(1)
1223 ; X86-X87-NEXT:    fnstsw %ax
1224 ; X86-X87-NEXT:    xorl %ecx, %ecx
1225 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
1226 ; X86-X87-NEXT:    sahf
1227 ; X86-X87-NEXT:    jb .LBB14_2
1228 ; X86-X87-NEXT:  # %bb.1:
1229 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
1230 ; X86-X87-NEXT:  .LBB14_2:
1231 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
1232 ; X86-X87-NEXT:    fxch %st(1)
1233 ; X86-X87-NEXT:    fucompp
1234 ; X86-X87-NEXT:    fnstsw %ax
1235 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
1236 ; X86-X87-NEXT:    sahf
1237 ; X86-X87-NEXT:    movl $524287, %eax # imm = 0x7FFFF
1238 ; X86-X87-NEXT:    ja .LBB14_4
1239 ; X86-X87-NEXT:  # %bb.3:
1240 ; X86-X87-NEXT:    movl %ecx, %eax
1241 ; X86-X87-NEXT:  .LBB14_4:
1242 ; X86-X87-NEXT:    addl $20, %esp
1243 ; X86-X87-NEXT:    retl
1245 ; X86-SSE-LABEL: test_unsigned_i19_f64:
1246 ; X86-SSE:       # %bb.0:
1247 ; X86-SSE-NEXT:    movsd {{.*#+}} xmm0 = mem[0],zero
1248 ; X86-SSE-NEXT:    xorpd %xmm1, %xmm1
1249 ; X86-SSE-NEXT:    maxsd %xmm1, %xmm0
1250 ; X86-SSE-NEXT:    minsd {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
1251 ; X86-SSE-NEXT:    cvttsd2si %xmm0, %eax
1252 ; X86-SSE-NEXT:    retl
1254 ; X64-LABEL: test_unsigned_i19_f64:
1255 ; X64:       # %bb.0:
1256 ; X64-NEXT:    xorpd %xmm1, %xmm1
1257 ; X64-NEXT:    maxsd %xmm1, %xmm0
1258 ; X64-NEXT:    minsd {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm0
1259 ; X64-NEXT:    cvttsd2si %xmm0, %eax
1260 ; X64-NEXT:    retq
1261     %x = call i19 @llvm.fptoui.sat.i19.f64(double %f)
1262     ret i19 %x
1265 define i32 @test_unsigned_i32_f64(double %f) nounwind {
1266 ; X86-X87-LABEL: test_unsigned_i32_f64:
1267 ; X86-X87:       # %bb.0:
1268 ; X86-X87-NEXT:    subl $20, %esp
1269 ; X86-X87-NEXT:    fldl {{[0-9]+}}(%esp)
1270 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
1271 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
1272 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
1273 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
1274 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
1275 ; X86-X87-NEXT:    fld %st(0)
1276 ; X86-X87-NEXT:    fistpll {{[0-9]+}}(%esp)
1277 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
1278 ; X86-X87-NEXT:    fldz
1279 ; X86-X87-NEXT:    fxch %st(1)
1280 ; X86-X87-NEXT:    fucom %st(1)
1281 ; X86-X87-NEXT:    fstp %st(1)
1282 ; X86-X87-NEXT:    fnstsw %ax
1283 ; X86-X87-NEXT:    xorl %ecx, %ecx
1284 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
1285 ; X86-X87-NEXT:    sahf
1286 ; X86-X87-NEXT:    jb .LBB15_2
1287 ; X86-X87-NEXT:  # %bb.1:
1288 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
1289 ; X86-X87-NEXT:  .LBB15_2:
1290 ; X86-X87-NEXT:    fldl {{\.?LCPI[0-9]+_[0-9]+}}
1291 ; X86-X87-NEXT:    fxch %st(1)
1292 ; X86-X87-NEXT:    fucompp
1293 ; X86-X87-NEXT:    fnstsw %ax
1294 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
1295 ; X86-X87-NEXT:    sahf
1296 ; X86-X87-NEXT:    movl $-1, %eax
1297 ; X86-X87-NEXT:    ja .LBB15_4
1298 ; X86-X87-NEXT:  # %bb.3:
1299 ; X86-X87-NEXT:    movl %ecx, %eax
1300 ; X86-X87-NEXT:  .LBB15_4:
1301 ; X86-X87-NEXT:    addl $20, %esp
1302 ; X86-X87-NEXT:    retl
1304 ; X86-SSE-LABEL: test_unsigned_i32_f64:
1305 ; X86-SSE:       # %bb.0:
1306 ; X86-SSE-NEXT:    movsd {{.*#+}} xmm0 = mem[0],zero
1307 ; X86-SSE-NEXT:    xorpd %xmm1, %xmm1
1308 ; X86-SSE-NEXT:    maxsd %xmm1, %xmm0
1309 ; X86-SSE-NEXT:    minsd {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
1310 ; X86-SSE-NEXT:    cvttsd2si %xmm0, %ecx
1311 ; X86-SSE-NEXT:    movl %ecx, %edx
1312 ; X86-SSE-NEXT:    sarl $31, %edx
1313 ; X86-SSE-NEXT:    subsd {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
1314 ; X86-SSE-NEXT:    cvttsd2si %xmm0, %eax
1315 ; X86-SSE-NEXT:    andl %edx, %eax
1316 ; X86-SSE-NEXT:    orl %ecx, %eax
1317 ; X86-SSE-NEXT:    retl
1319 ; X64-LABEL: test_unsigned_i32_f64:
1320 ; X64:       # %bb.0:
1321 ; X64-NEXT:    xorpd %xmm1, %xmm1
1322 ; X64-NEXT:    maxsd %xmm0, %xmm1
1323 ; X64-NEXT:    movsd {{.*#+}} xmm0 = mem[0],zero
1324 ; X64-NEXT:    minsd %xmm1, %xmm0
1325 ; X64-NEXT:    cvttsd2si %xmm0, %rax
1326 ; X64-NEXT:    # kill: def $eax killed $eax killed $rax
1327 ; X64-NEXT:    retq
1328     %x = call i32 @llvm.fptoui.sat.i32.f64(double %f)
1329     ret i32 %x
1332 define i50 @test_unsigned_i50_f64(double %f) nounwind {
1333 ; X86-X87-LABEL: test_unsigned_i50_f64:
1334 ; X86-X87:       # %bb.0:
1335 ; X86-X87-NEXT:    pushl %esi
1336 ; X86-X87-NEXT:    subl $16, %esp
1337 ; X86-X87-NEXT:    fldl {{[0-9]+}}(%esp)
1338 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
1339 ; X86-X87-NEXT:    fucom %st(1)
1340 ; X86-X87-NEXT:    fnstsw %ax
1341 ; X86-X87-NEXT:    xorl %ecx, %ecx
1342 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
1343 ; X86-X87-NEXT:    sahf
1344 ; X86-X87-NEXT:    setbe %al
1345 ; X86-X87-NEXT:    fldz
1346 ; X86-X87-NEXT:    jbe .LBB16_2
1347 ; X86-X87-NEXT:  # %bb.1:
1348 ; X86-X87-NEXT:    fstp %st(1)
1349 ; X86-X87-NEXT:    fld %st(0)
1350 ; X86-X87-NEXT:    fxch %st(1)
1351 ; X86-X87-NEXT:  .LBB16_2:
1352 ; X86-X87-NEXT:    fxch %st(1)
1353 ; X86-X87-NEXT:    fsubr %st(2), %st
1354 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
1355 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %edx
1356 ; X86-X87-NEXT:    orl $3072, %edx # imm = 0xC00
1357 ; X86-X87-NEXT:    movw %dx, {{[0-9]+}}(%esp)
1358 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
1359 ; X86-X87-NEXT:    fistpll {{[0-9]+}}(%esp)
1360 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
1361 ; X86-X87-NEXT:    movb %al, %cl
1362 ; X86-X87-NEXT:    shll $31, %ecx
1363 ; X86-X87-NEXT:    xorl {{[0-9]+}}(%esp), %ecx
1364 ; X86-X87-NEXT:    fxch %st(1)
1365 ; X86-X87-NEXT:    fucom %st(1)
1366 ; X86-X87-NEXT:    fstp %st(1)
1367 ; X86-X87-NEXT:    fnstsw %ax
1368 ; X86-X87-NEXT:    xorl %edx, %edx
1369 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
1370 ; X86-X87-NEXT:    sahf
1371 ; X86-X87-NEXT:    movl $0, %esi
1372 ; X86-X87-NEXT:    jb .LBB16_4
1373 ; X86-X87-NEXT:  # %bb.3:
1374 ; X86-X87-NEXT:    movl %ecx, %esi
1375 ; X86-X87-NEXT:  .LBB16_4:
1376 ; X86-X87-NEXT:    jb .LBB16_6
1377 ; X86-X87-NEXT:  # %bb.5:
1378 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %edx
1379 ; X86-X87-NEXT:  .LBB16_6:
1380 ; X86-X87-NEXT:    fldl {{\.?LCPI[0-9]+_[0-9]+}}
1381 ; X86-X87-NEXT:    fxch %st(1)
1382 ; X86-X87-NEXT:    fucompp
1383 ; X86-X87-NEXT:    fnstsw %ax
1384 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
1385 ; X86-X87-NEXT:    sahf
1386 ; X86-X87-NEXT:    movl $-1, %eax
1387 ; X86-X87-NEXT:    ja .LBB16_8
1388 ; X86-X87-NEXT:  # %bb.7:
1389 ; X86-X87-NEXT:    movl %edx, %eax
1390 ; X86-X87-NEXT:  .LBB16_8:
1391 ; X86-X87-NEXT:    movl $262143, %edx # imm = 0x3FFFF
1392 ; X86-X87-NEXT:    ja .LBB16_10
1393 ; X86-X87-NEXT:  # %bb.9:
1394 ; X86-X87-NEXT:    movl %esi, %edx
1395 ; X86-X87-NEXT:  .LBB16_10:
1396 ; X86-X87-NEXT:    addl $16, %esp
1397 ; X86-X87-NEXT:    popl %esi
1398 ; X86-X87-NEXT:    retl
1400 ; X86-SSE-LABEL: test_unsigned_i50_f64:
1401 ; X86-SSE:       # %bb.0:
1402 ; X86-SSE-NEXT:    pushl %esi
1403 ; X86-SSE-NEXT:    subl $16, %esp
1404 ; X86-SSE-NEXT:    movsd {{.*#+}} xmm0 = mem[0],zero
1405 ; X86-SSE-NEXT:    movsd {{.*#+}} xmm2 = mem[0],zero
1406 ; X86-SSE-NEXT:    ucomisd %xmm0, %xmm2
1407 ; X86-SSE-NEXT:    xorpd %xmm1, %xmm1
1408 ; X86-SSE-NEXT:    jbe .LBB16_2
1409 ; X86-SSE-NEXT:  # %bb.1:
1410 ; X86-SSE-NEXT:    xorpd %xmm2, %xmm2
1411 ; X86-SSE-NEXT:  .LBB16_2:
1412 ; X86-SSE-NEXT:    movapd %xmm0, %xmm3
1413 ; X86-SSE-NEXT:    subsd %xmm2, %xmm3
1414 ; X86-SSE-NEXT:    movsd %xmm3, {{[0-9]+}}(%esp)
1415 ; X86-SSE-NEXT:    setbe %cl
1416 ; X86-SSE-NEXT:    fldl {{[0-9]+}}(%esp)
1417 ; X86-SSE-NEXT:    fnstcw {{[0-9]+}}(%esp)
1418 ; X86-SSE-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
1419 ; X86-SSE-NEXT:    orl $3072, %eax # imm = 0xC00
1420 ; X86-SSE-NEXT:    movw %ax, {{[0-9]+}}(%esp)
1421 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
1422 ; X86-SSE-NEXT:    fistpll {{[0-9]+}}(%esp)
1423 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
1424 ; X86-SSE-NEXT:    xorl %eax, %eax
1425 ; X86-SSE-NEXT:    ucomisd %xmm1, %xmm0
1426 ; X86-SSE-NEXT:    movl $0, %esi
1427 ; X86-SSE-NEXT:    jb .LBB16_4
1428 ; X86-SSE-NEXT:  # %bb.3:
1429 ; X86-SSE-NEXT:    movzbl %cl, %eax
1430 ; X86-SSE-NEXT:    shll $31, %eax
1431 ; X86-SSE-NEXT:    xorl {{[0-9]+}}(%esp), %eax
1432 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %esi
1433 ; X86-SSE-NEXT:  .LBB16_4:
1434 ; X86-SSE-NEXT:    ucomisd {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
1435 ; X86-SSE-NEXT:    movl $262143, %edx # imm = 0x3FFFF
1436 ; X86-SSE-NEXT:    cmovbel %eax, %edx
1437 ; X86-SSE-NEXT:    movl $-1, %eax
1438 ; X86-SSE-NEXT:    cmovbel %esi, %eax
1439 ; X86-SSE-NEXT:    addl $16, %esp
1440 ; X86-SSE-NEXT:    popl %esi
1441 ; X86-SSE-NEXT:    retl
1443 ; X64-LABEL: test_unsigned_i50_f64:
1444 ; X64:       # %bb.0:
1445 ; X64-NEXT:    xorpd %xmm1, %xmm1
1446 ; X64-NEXT:    maxsd %xmm1, %xmm0
1447 ; X64-NEXT:    minsd {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm0
1448 ; X64-NEXT:    cvttsd2si %xmm0, %rax
1449 ; X64-NEXT:    retq
1450     %x = call i50 @llvm.fptoui.sat.i50.f64(double %f)
1451     ret i50 %x
1454 define i64 @test_unsigned_i64_f64(double %f) nounwind {
1455 ; X86-X87-LABEL: test_unsigned_i64_f64:
1456 ; X86-X87:       # %bb.0:
1457 ; X86-X87-NEXT:    pushl %edi
1458 ; X86-X87-NEXT:    pushl %esi
1459 ; X86-X87-NEXT:    subl $20, %esp
1460 ; X86-X87-NEXT:    fldl {{[0-9]+}}(%esp)
1461 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
1462 ; X86-X87-NEXT:    fucom %st(1)
1463 ; X86-X87-NEXT:    fnstsw %ax
1464 ; X86-X87-NEXT:    xorl %ecx, %ecx
1465 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
1466 ; X86-X87-NEXT:    sahf
1467 ; X86-X87-NEXT:    setbe %al
1468 ; X86-X87-NEXT:    fldz
1469 ; X86-X87-NEXT:    jbe .LBB17_2
1470 ; X86-X87-NEXT:  # %bb.1:
1471 ; X86-X87-NEXT:    fstp %st(1)
1472 ; X86-X87-NEXT:    fld %st(0)
1473 ; X86-X87-NEXT:    fxch %st(1)
1474 ; X86-X87-NEXT:  .LBB17_2:
1475 ; X86-X87-NEXT:    fxch %st(1)
1476 ; X86-X87-NEXT:    fsubr %st(2), %st
1477 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
1478 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %edx
1479 ; X86-X87-NEXT:    orl $3072, %edx # imm = 0xC00
1480 ; X86-X87-NEXT:    movw %dx, {{[0-9]+}}(%esp)
1481 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
1482 ; X86-X87-NEXT:    fistpll {{[0-9]+}}(%esp)
1483 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
1484 ; X86-X87-NEXT:    movb %al, %cl
1485 ; X86-X87-NEXT:    shll $31, %ecx
1486 ; X86-X87-NEXT:    xorl {{[0-9]+}}(%esp), %ecx
1487 ; X86-X87-NEXT:    fxch %st(1)
1488 ; X86-X87-NEXT:    fucom %st(1)
1489 ; X86-X87-NEXT:    fstp %st(1)
1490 ; X86-X87-NEXT:    fnstsw %ax
1491 ; X86-X87-NEXT:    xorl %esi, %esi
1492 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
1493 ; X86-X87-NEXT:    sahf
1494 ; X86-X87-NEXT:    movl $0, %edi
1495 ; X86-X87-NEXT:    jb .LBB17_4
1496 ; X86-X87-NEXT:  # %bb.3:
1497 ; X86-X87-NEXT:    movl %ecx, %edi
1498 ; X86-X87-NEXT:  .LBB17_4:
1499 ; X86-X87-NEXT:    jb .LBB17_6
1500 ; X86-X87-NEXT:  # %bb.5:
1501 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %esi
1502 ; X86-X87-NEXT:  .LBB17_6:
1503 ; X86-X87-NEXT:    fldl {{\.?LCPI[0-9]+_[0-9]+}}
1504 ; X86-X87-NEXT:    fxch %st(1)
1505 ; X86-X87-NEXT:    fucompp
1506 ; X86-X87-NEXT:    fnstsw %ax
1507 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
1508 ; X86-X87-NEXT:    sahf
1509 ; X86-X87-NEXT:    movl $-1, %eax
1510 ; X86-X87-NEXT:    movl $-1, %edx
1511 ; X86-X87-NEXT:    ja .LBB17_8
1512 ; X86-X87-NEXT:  # %bb.7:
1513 ; X86-X87-NEXT:    movl %esi, %eax
1514 ; X86-X87-NEXT:    movl %edi, %edx
1515 ; X86-X87-NEXT:  .LBB17_8:
1516 ; X86-X87-NEXT:    addl $20, %esp
1517 ; X86-X87-NEXT:    popl %esi
1518 ; X86-X87-NEXT:    popl %edi
1519 ; X86-X87-NEXT:    retl
1521 ; X86-SSE-LABEL: test_unsigned_i64_f64:
1522 ; X86-SSE:       # %bb.0:
1523 ; X86-SSE-NEXT:    subl $20, %esp
1524 ; X86-SSE-NEXT:    movsd {{.*#+}} xmm0 = mem[0],zero
1525 ; X86-SSE-NEXT:    movsd {{.*#+}} xmm2 = mem[0],zero
1526 ; X86-SSE-NEXT:    ucomisd %xmm0, %xmm2
1527 ; X86-SSE-NEXT:    xorpd %xmm1, %xmm1
1528 ; X86-SSE-NEXT:    jbe .LBB17_2
1529 ; X86-SSE-NEXT:  # %bb.1:
1530 ; X86-SSE-NEXT:    xorpd %xmm2, %xmm2
1531 ; X86-SSE-NEXT:  .LBB17_2:
1532 ; X86-SSE-NEXT:    movapd %xmm0, %xmm3
1533 ; X86-SSE-NEXT:    subsd %xmm2, %xmm3
1534 ; X86-SSE-NEXT:    movsd %xmm3, {{[0-9]+}}(%esp)
1535 ; X86-SSE-NEXT:    setbe %cl
1536 ; X86-SSE-NEXT:    fldl {{[0-9]+}}(%esp)
1537 ; X86-SSE-NEXT:    fnstcw {{[0-9]+}}(%esp)
1538 ; X86-SSE-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
1539 ; X86-SSE-NEXT:    orl $3072, %eax # imm = 0xC00
1540 ; X86-SSE-NEXT:    movw %ax, {{[0-9]+}}(%esp)
1541 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
1542 ; X86-SSE-NEXT:    fistpll {{[0-9]+}}(%esp)
1543 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
1544 ; X86-SSE-NEXT:    xorl %edx, %edx
1545 ; X86-SSE-NEXT:    ucomisd %xmm1, %xmm0
1546 ; X86-SSE-NEXT:    movl $0, %eax
1547 ; X86-SSE-NEXT:    jb .LBB17_4
1548 ; X86-SSE-NEXT:  # %bb.3:
1549 ; X86-SSE-NEXT:    movzbl %cl, %edx
1550 ; X86-SSE-NEXT:    shll $31, %edx
1551 ; X86-SSE-NEXT:    xorl {{[0-9]+}}(%esp), %edx
1552 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %eax
1553 ; X86-SSE-NEXT:  .LBB17_4:
1554 ; X86-SSE-NEXT:    ucomisd {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
1555 ; X86-SSE-NEXT:    movl $-1, %ecx
1556 ; X86-SSE-NEXT:    cmoval %ecx, %edx
1557 ; X86-SSE-NEXT:    cmoval %ecx, %eax
1558 ; X86-SSE-NEXT:    addl $20, %esp
1559 ; X86-SSE-NEXT:    retl
1561 ; X64-LABEL: test_unsigned_i64_f64:
1562 ; X64:       # %bb.0:
1563 ; X64-NEXT:    cvttsd2si %xmm0, %rax
1564 ; X64-NEXT:    movq %rax, %rcx
1565 ; X64-NEXT:    sarq $63, %rcx
1566 ; X64-NEXT:    movapd %xmm0, %xmm1
1567 ; X64-NEXT:    subsd {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm1
1568 ; X64-NEXT:    cvttsd2si %xmm1, %rdx
1569 ; X64-NEXT:    andq %rcx, %rdx
1570 ; X64-NEXT:    orq %rax, %rdx
1571 ; X64-NEXT:    xorl %ecx, %ecx
1572 ; X64-NEXT:    xorpd %xmm1, %xmm1
1573 ; X64-NEXT:    ucomisd %xmm1, %xmm0
1574 ; X64-NEXT:    cmovaeq %rdx, %rcx
1575 ; X64-NEXT:    ucomisd {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm0
1576 ; X64-NEXT:    movq $-1, %rax
1577 ; X64-NEXT:    cmovbeq %rcx, %rax
1578 ; X64-NEXT:    retq
1579     %x = call i64 @llvm.fptoui.sat.i64.f64(double %f)
1580     ret i64 %x
1583 define i100 @test_unsigned_i100_f64(double %f) nounwind {
1584 ; X86-X87-LABEL: test_unsigned_i100_f64:
1585 ; X86-X87:       # %bb.0:
1586 ; X86-X87-NEXT:    pushl %ebp
1587 ; X86-X87-NEXT:    pushl %ebx
1588 ; X86-X87-NEXT:    pushl %edi
1589 ; X86-X87-NEXT:    pushl %esi
1590 ; X86-X87-NEXT:    subl $44, %esp
1591 ; X86-X87-NEXT:    fldl {{[0-9]+}}(%esp)
1592 ; X86-X87-NEXT:    fstl {{[0-9]+}}(%esp)
1593 ; X86-X87-NEXT:    leal {{[0-9]+}}(%esp), %eax
1594 ; X86-X87-NEXT:    movl %eax, (%esp)
1595 ; X86-X87-NEXT:    fldz
1596 ; X86-X87-NEXT:    fxch %st(1)
1597 ; X86-X87-NEXT:    fstl {{[-0-9]+}}(%e{{[sb]}}p) # 8-byte Folded Spill
1598 ; X86-X87-NEXT:    fucompp
1599 ; X86-X87-NEXT:    fnstsw %ax
1600 ; X86-X87-NEXT:    movl %eax, %ebx
1601 ; X86-X87-NEXT:    calll __fixunsdfti
1602 ; X86-X87-NEXT:    subl $4, %esp
1603 ; X86-X87-NEXT:    xorl %edi, %edi
1604 ; X86-X87-NEXT:    movb %bh, %ah
1605 ; X86-X87-NEXT:    sahf
1606 ; X86-X87-NEXT:    movl $0, %eax
1607 ; X86-X87-NEXT:    jb .LBB18_2
1608 ; X86-X87-NEXT:  # %bb.1:
1609 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %eax
1610 ; X86-X87-NEXT:  .LBB18_2:
1611 ; X86-X87-NEXT:    movl $0, %esi
1612 ; X86-X87-NEXT:    movl $0, %ebx
1613 ; X86-X87-NEXT:    jb .LBB18_4
1614 ; X86-X87-NEXT:  # %bb.3:
1615 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ebx
1616 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %esi
1617 ; X86-X87-NEXT:  .LBB18_4:
1618 ; X86-X87-NEXT:    jb .LBB18_6
1619 ; X86-X87-NEXT:  # %bb.5:
1620 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %edi
1621 ; X86-X87-NEXT:  .LBB18_6:
1622 ; X86-X87-NEXT:    movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill
1623 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
1624 ; X86-X87-NEXT:    fldl {{\.?LCPI[0-9]+_[0-9]+}}
1625 ; X86-X87-NEXT:    fldl {{[-0-9]+}}(%e{{[sb]}}p) # 8-byte Folded Reload
1626 ; X86-X87-NEXT:    fucompp
1627 ; X86-X87-NEXT:    fnstsw %ax
1628 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
1629 ; X86-X87-NEXT:    sahf
1630 ; X86-X87-NEXT:    movl $15, %eax
1631 ; X86-X87-NEXT:    ja .LBB18_8
1632 ; X86-X87-NEXT:  # %bb.7:
1633 ; X86-X87-NEXT:    movl %edi, %eax
1634 ; X86-X87-NEXT:  .LBB18_8:
1635 ; X86-X87-NEXT:    movl $-1, %edi
1636 ; X86-X87-NEXT:    movl $-1, %ebp
1637 ; X86-X87-NEXT:    movl $-1, %edx
1638 ; X86-X87-NEXT:    ja .LBB18_10
1639 ; X86-X87-NEXT:  # %bb.9:
1640 ; X86-X87-NEXT:    movl %ebx, %edi
1641 ; X86-X87-NEXT:    movl %esi, %ebp
1642 ; X86-X87-NEXT:    movl {{[-0-9]+}}(%e{{[sb]}}p), %edx # 4-byte Reload
1643 ; X86-X87-NEXT:  .LBB18_10:
1644 ; X86-X87-NEXT:    movl %edx, 8(%ecx)
1645 ; X86-X87-NEXT:    movl %ebp, 4(%ecx)
1646 ; X86-X87-NEXT:    movl %edi, (%ecx)
1647 ; X86-X87-NEXT:    andl $15, %eax
1648 ; X86-X87-NEXT:    movb %al, 12(%ecx)
1649 ; X86-X87-NEXT:    movl %ecx, %eax
1650 ; X86-X87-NEXT:    addl $44, %esp
1651 ; X86-X87-NEXT:    popl %esi
1652 ; X86-X87-NEXT:    popl %edi
1653 ; X86-X87-NEXT:    popl %ebx
1654 ; X86-X87-NEXT:    popl %ebp
1655 ; X86-X87-NEXT:    retl $4
1657 ; X86-SSE-LABEL: test_unsigned_i100_f64:
1658 ; X86-SSE:       # %bb.0:
1659 ; X86-SSE-NEXT:    pushl %ebx
1660 ; X86-SSE-NEXT:    pushl %edi
1661 ; X86-SSE-NEXT:    pushl %esi
1662 ; X86-SSE-NEXT:    subl $32, %esp
1663 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %esi
1664 ; X86-SSE-NEXT:    movsd {{.*#+}} xmm0 = mem[0],zero
1665 ; X86-SSE-NEXT:    movsd %xmm0, {{[0-9]+}}(%esp)
1666 ; X86-SSE-NEXT:    leal {{[0-9]+}}(%esp), %eax
1667 ; X86-SSE-NEXT:    movl %eax, (%esp)
1668 ; X86-SSE-NEXT:    calll __fixunsdfti
1669 ; X86-SSE-NEXT:    subl $4, %esp
1670 ; X86-SSE-NEXT:    xorl %eax, %eax
1671 ; X86-SSE-NEXT:    xorpd %xmm0, %xmm0
1672 ; X86-SSE-NEXT:    movsd {{.*#+}} xmm1 = mem[0],zero
1673 ; X86-SSE-NEXT:    ucomisd %xmm0, %xmm1
1674 ; X86-SSE-NEXT:    movapd %xmm1, %xmm0
1675 ; X86-SSE-NEXT:    movl $0, %ecx
1676 ; X86-SSE-NEXT:    movl $0, %edx
1677 ; X86-SSE-NEXT:    movl $0, %edi
1678 ; X86-SSE-NEXT:    jb .LBB18_2
1679 ; X86-SSE-NEXT:  # %bb.1:
1680 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %eax
1681 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %ecx
1682 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %edx
1683 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %edi
1684 ; X86-SSE-NEXT:  .LBB18_2:
1685 ; X86-SSE-NEXT:    ucomisd {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
1686 ; X86-SSE-NEXT:    movl $15, %ebx
1687 ; X86-SSE-NEXT:    cmovbel %edi, %ebx
1688 ; X86-SSE-NEXT:    movl $-1, %edi
1689 ; X86-SSE-NEXT:    cmoval %edi, %edx
1690 ; X86-SSE-NEXT:    cmoval %edi, %ecx
1691 ; X86-SSE-NEXT:    cmoval %edi, %eax
1692 ; X86-SSE-NEXT:    movl %eax, 8(%esi)
1693 ; X86-SSE-NEXT:    movl %ecx, 4(%esi)
1694 ; X86-SSE-NEXT:    movl %edx, (%esi)
1695 ; X86-SSE-NEXT:    andl $15, %ebx
1696 ; X86-SSE-NEXT:    movb %bl, 12(%esi)
1697 ; X86-SSE-NEXT:    movl %esi, %eax
1698 ; X86-SSE-NEXT:    addl $32, %esp
1699 ; X86-SSE-NEXT:    popl %esi
1700 ; X86-SSE-NEXT:    popl %edi
1701 ; X86-SSE-NEXT:    popl %ebx
1702 ; X86-SSE-NEXT:    retl $4
1704 ; X64-LABEL: test_unsigned_i100_f64:
1705 ; X64:       # %bb.0:
1706 ; X64-NEXT:    pushq %rax
1707 ; X64-NEXT:    movsd %xmm0, (%rsp) # 8-byte Spill
1708 ; X64-NEXT:    callq __fixunsdfti@PLT
1709 ; X64-NEXT:    xorl %ecx, %ecx
1710 ; X64-NEXT:    xorpd %xmm0, %xmm0
1711 ; X64-NEXT:    movsd (%rsp), %xmm1 # 8-byte Reload
1712 ; X64-NEXT:    # xmm1 = mem[0],zero
1713 ; X64-NEXT:    ucomisd %xmm0, %xmm1
1714 ; X64-NEXT:    cmovbq %rcx, %rdx
1715 ; X64-NEXT:    cmovbq %rcx, %rax
1716 ; X64-NEXT:    ucomisd {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm1
1717 ; X64-NEXT:    movq $-1, %rcx
1718 ; X64-NEXT:    cmovaq %rcx, %rax
1719 ; X64-NEXT:    movabsq $68719476735, %rcx # imm = 0xFFFFFFFFF
1720 ; X64-NEXT:    cmovaq %rcx, %rdx
1721 ; X64-NEXT:    popq %rcx
1722 ; X64-NEXT:    retq
1723     %x = call i100 @llvm.fptoui.sat.i100.f64(double %f)
1724     ret i100 %x
1727 define i128 @test_unsigned_i128_f64(double %f) nounwind {
1728 ; X86-X87-LABEL: test_unsigned_i128_f64:
1729 ; X86-X87:       # %bb.0:
1730 ; X86-X87-NEXT:    pushl %ebp
1731 ; X86-X87-NEXT:    pushl %ebx
1732 ; X86-X87-NEXT:    pushl %edi
1733 ; X86-X87-NEXT:    pushl %esi
1734 ; X86-X87-NEXT:    subl $60, %esp
1735 ; X86-X87-NEXT:    fldl {{[0-9]+}}(%esp)
1736 ; X86-X87-NEXT:    fstl {{[0-9]+}}(%esp)
1737 ; X86-X87-NEXT:    leal {{[0-9]+}}(%esp), %eax
1738 ; X86-X87-NEXT:    movl %eax, (%esp)
1739 ; X86-X87-NEXT:    fldz
1740 ; X86-X87-NEXT:    fxch %st(1)
1741 ; X86-X87-NEXT:    fstl {{[-0-9]+}}(%e{{[sb]}}p) # 8-byte Folded Spill
1742 ; X86-X87-NEXT:    fucompp
1743 ; X86-X87-NEXT:    fnstsw %ax
1744 ; X86-X87-NEXT:    movl %eax, %ebx
1745 ; X86-X87-NEXT:    calll __fixunsdfti
1746 ; X86-X87-NEXT:    subl $4, %esp
1747 ; X86-X87-NEXT:    xorl %edx, %edx
1748 ; X86-X87-NEXT:    movb %bh, %ah
1749 ; X86-X87-NEXT:    sahf
1750 ; X86-X87-NEXT:    movl $0, %eax
1751 ; X86-X87-NEXT:    jb .LBB19_2
1752 ; X86-X87-NEXT:  # %bb.1:
1753 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %eax
1754 ; X86-X87-NEXT:  .LBB19_2:
1755 ; X86-X87-NEXT:    movl $0, %ecx
1756 ; X86-X87-NEXT:    jb .LBB19_4
1757 ; X86-X87-NEXT:  # %bb.3:
1758 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
1759 ; X86-X87-NEXT:  .LBB19_4:
1760 ; X86-X87-NEXT:    movl %ecx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill
1761 ; X86-X87-NEXT:    movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill
1762 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
1763 ; X86-X87-NEXT:    movl $0, %ebx
1764 ; X86-X87-NEXT:    jb .LBB19_6
1765 ; X86-X87-NEXT:  # %bb.5:
1766 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ebx
1767 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %edx
1768 ; X86-X87-NEXT:  .LBB19_6:
1769 ; X86-X87-NEXT:    fldl {{\.?LCPI[0-9]+_[0-9]+}}
1770 ; X86-X87-NEXT:    fldl {{[-0-9]+}}(%e{{[sb]}}p) # 8-byte Folded Reload
1771 ; X86-X87-NEXT:    fucompp
1772 ; X86-X87-NEXT:    fnstsw %ax
1773 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
1774 ; X86-X87-NEXT:    sahf
1775 ; X86-X87-NEXT:    movl $-1, %eax
1776 ; X86-X87-NEXT:    movl $-1, %ebp
1777 ; X86-X87-NEXT:    movl $-1, %edi
1778 ; X86-X87-NEXT:    movl $-1, %esi
1779 ; X86-X87-NEXT:    ja .LBB19_8
1780 ; X86-X87-NEXT:  # %bb.7:
1781 ; X86-X87-NEXT:    movl %ebx, %eax
1782 ; X86-X87-NEXT:    movl %edx, %ebp
1783 ; X86-X87-NEXT:    movl {{[-0-9]+}}(%e{{[sb]}}p), %edi # 4-byte Reload
1784 ; X86-X87-NEXT:    movl {{[-0-9]+}}(%e{{[sb]}}p), %esi # 4-byte Reload
1785 ; X86-X87-NEXT:  .LBB19_8:
1786 ; X86-X87-NEXT:    movl %esi, 12(%ecx)
1787 ; X86-X87-NEXT:    movl %edi, 8(%ecx)
1788 ; X86-X87-NEXT:    movl %ebp, 4(%ecx)
1789 ; X86-X87-NEXT:    movl %eax, (%ecx)
1790 ; X86-X87-NEXT:    movl %ecx, %eax
1791 ; X86-X87-NEXT:    addl $60, %esp
1792 ; X86-X87-NEXT:    popl %esi
1793 ; X86-X87-NEXT:    popl %edi
1794 ; X86-X87-NEXT:    popl %ebx
1795 ; X86-X87-NEXT:    popl %ebp
1796 ; X86-X87-NEXT:    retl $4
1798 ; X86-SSE-LABEL: test_unsigned_i128_f64:
1799 ; X86-SSE:       # %bb.0:
1800 ; X86-SSE-NEXT:    pushl %ebx
1801 ; X86-SSE-NEXT:    pushl %edi
1802 ; X86-SSE-NEXT:    pushl %esi
1803 ; X86-SSE-NEXT:    subl $32, %esp
1804 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %esi
1805 ; X86-SSE-NEXT:    movsd {{.*#+}} xmm0 = mem[0],zero
1806 ; X86-SSE-NEXT:    movsd %xmm0, {{[0-9]+}}(%esp)
1807 ; X86-SSE-NEXT:    leal {{[0-9]+}}(%esp), %eax
1808 ; X86-SSE-NEXT:    movl %eax, (%esp)
1809 ; X86-SSE-NEXT:    calll __fixunsdfti
1810 ; X86-SSE-NEXT:    subl $4, %esp
1811 ; X86-SSE-NEXT:    xorl %eax, %eax
1812 ; X86-SSE-NEXT:    xorpd %xmm0, %xmm0
1813 ; X86-SSE-NEXT:    movsd {{.*#+}} xmm1 = mem[0],zero
1814 ; X86-SSE-NEXT:    ucomisd %xmm0, %xmm1
1815 ; X86-SSE-NEXT:    movapd %xmm1, %xmm0
1816 ; X86-SSE-NEXT:    movl $0, %ecx
1817 ; X86-SSE-NEXT:    movl $0, %edx
1818 ; X86-SSE-NEXT:    movl $0, %edi
1819 ; X86-SSE-NEXT:    jb .LBB19_2
1820 ; X86-SSE-NEXT:  # %bb.1:
1821 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %eax
1822 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %ecx
1823 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %edx
1824 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %edi
1825 ; X86-SSE-NEXT:  .LBB19_2:
1826 ; X86-SSE-NEXT:    ucomisd {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
1827 ; X86-SSE-NEXT:    movl $-1, %ebx
1828 ; X86-SSE-NEXT:    cmoval %ebx, %edi
1829 ; X86-SSE-NEXT:    cmoval %ebx, %edx
1830 ; X86-SSE-NEXT:    cmoval %ebx, %ecx
1831 ; X86-SSE-NEXT:    cmoval %ebx, %eax
1832 ; X86-SSE-NEXT:    movl %eax, 12(%esi)
1833 ; X86-SSE-NEXT:    movl %ecx, 8(%esi)
1834 ; X86-SSE-NEXT:    movl %edx, 4(%esi)
1835 ; X86-SSE-NEXT:    movl %edi, (%esi)
1836 ; X86-SSE-NEXT:    movl %esi, %eax
1837 ; X86-SSE-NEXT:    addl $32, %esp
1838 ; X86-SSE-NEXT:    popl %esi
1839 ; X86-SSE-NEXT:    popl %edi
1840 ; X86-SSE-NEXT:    popl %ebx
1841 ; X86-SSE-NEXT:    retl $4
1843 ; X64-LABEL: test_unsigned_i128_f64:
1844 ; X64:       # %bb.0:
1845 ; X64-NEXT:    pushq %rax
1846 ; X64-NEXT:    movsd %xmm0, (%rsp) # 8-byte Spill
1847 ; X64-NEXT:    callq __fixunsdfti@PLT
1848 ; X64-NEXT:    xorl %ecx, %ecx
1849 ; X64-NEXT:    xorpd %xmm0, %xmm0
1850 ; X64-NEXT:    movsd (%rsp), %xmm1 # 8-byte Reload
1851 ; X64-NEXT:    # xmm1 = mem[0],zero
1852 ; X64-NEXT:    ucomisd %xmm0, %xmm1
1853 ; X64-NEXT:    cmovbq %rcx, %rdx
1854 ; X64-NEXT:    cmovbq %rcx, %rax
1855 ; X64-NEXT:    ucomisd {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm1
1856 ; X64-NEXT:    movq $-1, %rcx
1857 ; X64-NEXT:    cmovaq %rcx, %rax
1858 ; X64-NEXT:    cmovaq %rcx, %rdx
1859 ; X64-NEXT:    popq %rcx
1860 ; X64-NEXT:    retq
1861     %x = call i128 @llvm.fptoui.sat.i128.f64(double %f)
1862     ret i128 %x
1866 ; 16-bit float to unsigned integer
1869 declare   i1 @llvm.fptoui.sat.i1.f16  (half)
1870 declare   i8 @llvm.fptoui.sat.i8.f16  (half)
1871 declare  i13 @llvm.fptoui.sat.i13.f16 (half)
1872 declare  i16 @llvm.fptoui.sat.i16.f16 (half)
1873 declare  i19 @llvm.fptoui.sat.i19.f16 (half)
1874 declare  i32 @llvm.fptoui.sat.i32.f16 (half)
1875 declare  i50 @llvm.fptoui.sat.i50.f16 (half)
1876 declare  i64 @llvm.fptoui.sat.i64.f16 (half)
1877 declare i100 @llvm.fptoui.sat.i100.f16(half)
1878 declare i128 @llvm.fptoui.sat.i128.f16(half)
1880 define i1 @test_unsigned_i1_f16(half %f) nounwind {
1881 ; X86-X87-LABEL: test_unsigned_i1_f16:
1882 ; X86-X87:       # %bb.0:
1883 ; X86-X87-NEXT:    subl $12, %esp
1884 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
1885 ; X86-X87-NEXT:    movl %eax, (%esp)
1886 ; X86-X87-NEXT:    calll __gnu_h2f_ieee
1887 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
1888 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
1889 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
1890 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
1891 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
1892 ; X86-X87-NEXT:    fists {{[0-9]+}}(%esp)
1893 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
1894 ; X86-X87-NEXT:    fldz
1895 ; X86-X87-NEXT:    fxch %st(1)
1896 ; X86-X87-NEXT:    fucom %st(1)
1897 ; X86-X87-NEXT:    fstp %st(1)
1898 ; X86-X87-NEXT:    fnstsw %ax
1899 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
1900 ; X86-X87-NEXT:    sahf
1901 ; X86-X87-NEXT:    jb .LBB20_1
1902 ; X86-X87-NEXT:  # %bb.2:
1903 ; X86-X87-NEXT:    movzbl {{[0-9]+}}(%esp), %ecx
1904 ; X86-X87-NEXT:    jmp .LBB20_3
1905 ; X86-X87-NEXT:  .LBB20_1:
1906 ; X86-X87-NEXT:    xorl %ecx, %ecx
1907 ; X86-X87-NEXT:  .LBB20_3:
1908 ; X86-X87-NEXT:    fld1
1909 ; X86-X87-NEXT:    fxch %st(1)
1910 ; X86-X87-NEXT:    fucompp
1911 ; X86-X87-NEXT:    fnstsw %ax
1912 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
1913 ; X86-X87-NEXT:    sahf
1914 ; X86-X87-NEXT:    movb $1, %al
1915 ; X86-X87-NEXT:    ja .LBB20_5
1916 ; X86-X87-NEXT:  # %bb.4:
1917 ; X86-X87-NEXT:    movl %ecx, %eax
1918 ; X86-X87-NEXT:  .LBB20_5:
1919 ; X86-X87-NEXT:    addl $12, %esp
1920 ; X86-X87-NEXT:    retl
1922 ; X86-SSE-LABEL: test_unsigned_i1_f16:
1923 ; X86-SSE:       # %bb.0:
1924 ; X86-SSE-NEXT:    subl $12, %esp
1925 ; X86-SSE-NEXT:    pinsrw $0, {{[0-9]+}}(%esp), %xmm0
1926 ; X86-SSE-NEXT:    pextrw $0, %xmm0, %eax
1927 ; X86-SSE-NEXT:    movw %ax, (%esp)
1928 ; X86-SSE-NEXT:    calll __extendhfsf2
1929 ; X86-SSE-NEXT:    fstps {{[0-9]+}}(%esp)
1930 ; X86-SSE-NEXT:    movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
1931 ; X86-SSE-NEXT:    cvttss2si %xmm0, %eax
1932 ; X86-SSE-NEXT:    xorl %ecx, %ecx
1933 ; X86-SSE-NEXT:    xorps %xmm1, %xmm1
1934 ; X86-SSE-NEXT:    ucomiss %xmm1, %xmm0
1935 ; X86-SSE-NEXT:    cmovael %eax, %ecx
1936 ; X86-SSE-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
1937 ; X86-SSE-NEXT:    movl $1, %eax
1938 ; X86-SSE-NEXT:    cmovbel %ecx, %eax
1939 ; X86-SSE-NEXT:    # kill: def $al killed $al killed $eax
1940 ; X86-SSE-NEXT:    addl $12, %esp
1941 ; X86-SSE-NEXT:    retl
1943 ; X64-LABEL: test_unsigned_i1_f16:
1944 ; X64:       # %bb.0:
1945 ; X64-NEXT:    pushq %rax
1946 ; X64-NEXT:    callq __extendhfsf2@PLT
1947 ; X64-NEXT:    cvttss2si %xmm0, %eax
1948 ; X64-NEXT:    xorl %ecx, %ecx
1949 ; X64-NEXT:    xorps %xmm1, %xmm1
1950 ; X64-NEXT:    ucomiss %xmm1, %xmm0
1951 ; X64-NEXT:    cmovael %eax, %ecx
1952 ; X64-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm0
1953 ; X64-NEXT:    movl $1, %eax
1954 ; X64-NEXT:    cmovbel %ecx, %eax
1955 ; X64-NEXT:    # kill: def $al killed $al killed $eax
1956 ; X64-NEXT:    popq %rcx
1957 ; X64-NEXT:    retq
1958     %x = call i1 @llvm.fptoui.sat.i1.f16(half %f)
1959     ret i1 %x
1962 define i8 @test_unsigned_i8_f16(half %f) nounwind {
1963 ; X86-X87-LABEL: test_unsigned_i8_f16:
1964 ; X86-X87:       # %bb.0:
1965 ; X86-X87-NEXT:    subl $12, %esp
1966 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
1967 ; X86-X87-NEXT:    movl %eax, (%esp)
1968 ; X86-X87-NEXT:    calll __gnu_h2f_ieee
1969 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
1970 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
1971 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
1972 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
1973 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
1974 ; X86-X87-NEXT:    fists {{[0-9]+}}(%esp)
1975 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
1976 ; X86-X87-NEXT:    fldz
1977 ; X86-X87-NEXT:    fxch %st(1)
1978 ; X86-X87-NEXT:    fucom %st(1)
1979 ; X86-X87-NEXT:    fstp %st(1)
1980 ; X86-X87-NEXT:    fnstsw %ax
1981 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
1982 ; X86-X87-NEXT:    sahf
1983 ; X86-X87-NEXT:    jb .LBB21_1
1984 ; X86-X87-NEXT:  # %bb.2:
1985 ; X86-X87-NEXT:    movzbl {{[0-9]+}}(%esp), %ecx
1986 ; X86-X87-NEXT:    jmp .LBB21_3
1987 ; X86-X87-NEXT:  .LBB21_1:
1988 ; X86-X87-NEXT:    xorl %ecx, %ecx
1989 ; X86-X87-NEXT:  .LBB21_3:
1990 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
1991 ; X86-X87-NEXT:    fxch %st(1)
1992 ; X86-X87-NEXT:    fucompp
1993 ; X86-X87-NEXT:    fnstsw %ax
1994 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
1995 ; X86-X87-NEXT:    sahf
1996 ; X86-X87-NEXT:    movb $-1, %al
1997 ; X86-X87-NEXT:    ja .LBB21_5
1998 ; X86-X87-NEXT:  # %bb.4:
1999 ; X86-X87-NEXT:    movl %ecx, %eax
2000 ; X86-X87-NEXT:  .LBB21_5:
2001 ; X86-X87-NEXT:    addl $12, %esp
2002 ; X86-X87-NEXT:    retl
2004 ; X86-SSE-LABEL: test_unsigned_i8_f16:
2005 ; X86-SSE:       # %bb.0:
2006 ; X86-SSE-NEXT:    subl $12, %esp
2007 ; X86-SSE-NEXT:    pinsrw $0, {{[0-9]+}}(%esp), %xmm0
2008 ; X86-SSE-NEXT:    pextrw $0, %xmm0, %eax
2009 ; X86-SSE-NEXT:    movw %ax, (%esp)
2010 ; X86-SSE-NEXT:    calll __extendhfsf2
2011 ; X86-SSE-NEXT:    fstps {{[0-9]+}}(%esp)
2012 ; X86-SSE-NEXT:    movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
2013 ; X86-SSE-NEXT:    cvttss2si %xmm0, %eax
2014 ; X86-SSE-NEXT:    xorl %ecx, %ecx
2015 ; X86-SSE-NEXT:    xorps %xmm1, %xmm1
2016 ; X86-SSE-NEXT:    ucomiss %xmm1, %xmm0
2017 ; X86-SSE-NEXT:    cmovael %eax, %ecx
2018 ; X86-SSE-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
2019 ; X86-SSE-NEXT:    movl $255, %eax
2020 ; X86-SSE-NEXT:    cmovbel %ecx, %eax
2021 ; X86-SSE-NEXT:    # kill: def $al killed $al killed $eax
2022 ; X86-SSE-NEXT:    addl $12, %esp
2023 ; X86-SSE-NEXT:    retl
2025 ; X64-LABEL: test_unsigned_i8_f16:
2026 ; X64:       # %bb.0:
2027 ; X64-NEXT:    pushq %rax
2028 ; X64-NEXT:    callq __extendhfsf2@PLT
2029 ; X64-NEXT:    cvttss2si %xmm0, %eax
2030 ; X64-NEXT:    xorl %ecx, %ecx
2031 ; X64-NEXT:    xorps %xmm1, %xmm1
2032 ; X64-NEXT:    ucomiss %xmm1, %xmm0
2033 ; X64-NEXT:    cmovael %eax, %ecx
2034 ; X64-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm0
2035 ; X64-NEXT:    movl $255, %eax
2036 ; X64-NEXT:    cmovbel %ecx, %eax
2037 ; X64-NEXT:    # kill: def $al killed $al killed $eax
2038 ; X64-NEXT:    popq %rcx
2039 ; X64-NEXT:    retq
2040     %x = call i8 @llvm.fptoui.sat.i8.f16(half %f)
2041     ret i8 %x
2044 define i13 @test_unsigned_i13_f16(half %f) nounwind {
2045 ; X86-X87-LABEL: test_unsigned_i13_f16:
2046 ; X86-X87:       # %bb.0:
2047 ; X86-X87-NEXT:    subl $12, %esp
2048 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
2049 ; X86-X87-NEXT:    movl %eax, (%esp)
2050 ; X86-X87-NEXT:    calll __gnu_h2f_ieee
2051 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
2052 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
2053 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
2054 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
2055 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
2056 ; X86-X87-NEXT:    fistl {{[0-9]+}}(%esp)
2057 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
2058 ; X86-X87-NEXT:    fldz
2059 ; X86-X87-NEXT:    fxch %st(1)
2060 ; X86-X87-NEXT:    fucom %st(1)
2061 ; X86-X87-NEXT:    fstp %st(1)
2062 ; X86-X87-NEXT:    fnstsw %ax
2063 ; X86-X87-NEXT:    xorl %ecx, %ecx
2064 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
2065 ; X86-X87-NEXT:    sahf
2066 ; X86-X87-NEXT:    jb .LBB22_2
2067 ; X86-X87-NEXT:  # %bb.1:
2068 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
2069 ; X86-X87-NEXT:  .LBB22_2:
2070 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
2071 ; X86-X87-NEXT:    fxch %st(1)
2072 ; X86-X87-NEXT:    fucompp
2073 ; X86-X87-NEXT:    fnstsw %ax
2074 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
2075 ; X86-X87-NEXT:    sahf
2076 ; X86-X87-NEXT:    movl $8191, %eax # imm = 0x1FFF
2077 ; X86-X87-NEXT:    ja .LBB22_4
2078 ; X86-X87-NEXT:  # %bb.3:
2079 ; X86-X87-NEXT:    movl %ecx, %eax
2080 ; X86-X87-NEXT:  .LBB22_4:
2081 ; X86-X87-NEXT:    # kill: def $ax killed $ax killed $eax
2082 ; X86-X87-NEXT:    addl $12, %esp
2083 ; X86-X87-NEXT:    retl
2085 ; X86-SSE-LABEL: test_unsigned_i13_f16:
2086 ; X86-SSE:       # %bb.0:
2087 ; X86-SSE-NEXT:    subl $12, %esp
2088 ; X86-SSE-NEXT:    pinsrw $0, {{[0-9]+}}(%esp), %xmm0
2089 ; X86-SSE-NEXT:    pextrw $0, %xmm0, %eax
2090 ; X86-SSE-NEXT:    movw %ax, (%esp)
2091 ; X86-SSE-NEXT:    calll __extendhfsf2
2092 ; X86-SSE-NEXT:    fstps {{[0-9]+}}(%esp)
2093 ; X86-SSE-NEXT:    movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
2094 ; X86-SSE-NEXT:    cvttss2si %xmm0, %eax
2095 ; X86-SSE-NEXT:    xorl %ecx, %ecx
2096 ; X86-SSE-NEXT:    xorps %xmm1, %xmm1
2097 ; X86-SSE-NEXT:    ucomiss %xmm1, %xmm0
2098 ; X86-SSE-NEXT:    cmovael %eax, %ecx
2099 ; X86-SSE-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
2100 ; X86-SSE-NEXT:    movl $8191, %eax # imm = 0x1FFF
2101 ; X86-SSE-NEXT:    cmovbel %ecx, %eax
2102 ; X86-SSE-NEXT:    # kill: def $ax killed $ax killed $eax
2103 ; X86-SSE-NEXT:    addl $12, %esp
2104 ; X86-SSE-NEXT:    retl
2106 ; X64-LABEL: test_unsigned_i13_f16:
2107 ; X64:       # %bb.0:
2108 ; X64-NEXT:    pushq %rax
2109 ; X64-NEXT:    callq __extendhfsf2@PLT
2110 ; X64-NEXT:    cvttss2si %xmm0, %eax
2111 ; X64-NEXT:    xorl %ecx, %ecx
2112 ; X64-NEXT:    xorps %xmm1, %xmm1
2113 ; X64-NEXT:    ucomiss %xmm1, %xmm0
2114 ; X64-NEXT:    cmovael %eax, %ecx
2115 ; X64-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm0
2116 ; X64-NEXT:    movl $8191, %eax # imm = 0x1FFF
2117 ; X64-NEXT:    cmovbel %ecx, %eax
2118 ; X64-NEXT:    # kill: def $ax killed $ax killed $eax
2119 ; X64-NEXT:    popq %rcx
2120 ; X64-NEXT:    retq
2121     %x = call i13 @llvm.fptoui.sat.i13.f16(half %f)
2122     ret i13 %x
2125 define i16 @test_unsigned_i16_f16(half %f) nounwind {
2126 ; X86-X87-LABEL: test_unsigned_i16_f16:
2127 ; X86-X87:       # %bb.0:
2128 ; X86-X87-NEXT:    subl $12, %esp
2129 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
2130 ; X86-X87-NEXT:    movl %eax, (%esp)
2131 ; X86-X87-NEXT:    calll __gnu_h2f_ieee
2132 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
2133 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
2134 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
2135 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
2136 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
2137 ; X86-X87-NEXT:    fistl {{[0-9]+}}(%esp)
2138 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
2139 ; X86-X87-NEXT:    fldz
2140 ; X86-X87-NEXT:    fxch %st(1)
2141 ; X86-X87-NEXT:    fucom %st(1)
2142 ; X86-X87-NEXT:    fstp %st(1)
2143 ; X86-X87-NEXT:    fnstsw %ax
2144 ; X86-X87-NEXT:    xorl %ecx, %ecx
2145 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
2146 ; X86-X87-NEXT:    sahf
2147 ; X86-X87-NEXT:    jb .LBB23_2
2148 ; X86-X87-NEXT:  # %bb.1:
2149 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
2150 ; X86-X87-NEXT:  .LBB23_2:
2151 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
2152 ; X86-X87-NEXT:    fxch %st(1)
2153 ; X86-X87-NEXT:    fucompp
2154 ; X86-X87-NEXT:    fnstsw %ax
2155 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
2156 ; X86-X87-NEXT:    sahf
2157 ; X86-X87-NEXT:    movl $65535, %eax # imm = 0xFFFF
2158 ; X86-X87-NEXT:    ja .LBB23_4
2159 ; X86-X87-NEXT:  # %bb.3:
2160 ; X86-X87-NEXT:    movl %ecx, %eax
2161 ; X86-X87-NEXT:  .LBB23_4:
2162 ; X86-X87-NEXT:    # kill: def $ax killed $ax killed $eax
2163 ; X86-X87-NEXT:    addl $12, %esp
2164 ; X86-X87-NEXT:    retl
2166 ; X86-SSE-LABEL: test_unsigned_i16_f16:
2167 ; X86-SSE:       # %bb.0:
2168 ; X86-SSE-NEXT:    subl $12, %esp
2169 ; X86-SSE-NEXT:    pinsrw $0, {{[0-9]+}}(%esp), %xmm0
2170 ; X86-SSE-NEXT:    pextrw $0, %xmm0, %eax
2171 ; X86-SSE-NEXT:    movw %ax, (%esp)
2172 ; X86-SSE-NEXT:    calll __extendhfsf2
2173 ; X86-SSE-NEXT:    fstps {{[0-9]+}}(%esp)
2174 ; X86-SSE-NEXT:    movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
2175 ; X86-SSE-NEXT:    cvttss2si %xmm0, %eax
2176 ; X86-SSE-NEXT:    xorl %ecx, %ecx
2177 ; X86-SSE-NEXT:    xorps %xmm1, %xmm1
2178 ; X86-SSE-NEXT:    ucomiss %xmm1, %xmm0
2179 ; X86-SSE-NEXT:    cmovael %eax, %ecx
2180 ; X86-SSE-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
2181 ; X86-SSE-NEXT:    movl $65535, %eax # imm = 0xFFFF
2182 ; X86-SSE-NEXT:    cmovbel %ecx, %eax
2183 ; X86-SSE-NEXT:    # kill: def $ax killed $ax killed $eax
2184 ; X86-SSE-NEXT:    addl $12, %esp
2185 ; X86-SSE-NEXT:    retl
2187 ; X64-LABEL: test_unsigned_i16_f16:
2188 ; X64:       # %bb.0:
2189 ; X64-NEXT:    pushq %rax
2190 ; X64-NEXT:    callq __extendhfsf2@PLT
2191 ; X64-NEXT:    cvttss2si %xmm0, %eax
2192 ; X64-NEXT:    xorl %ecx, %ecx
2193 ; X64-NEXT:    xorps %xmm1, %xmm1
2194 ; X64-NEXT:    ucomiss %xmm1, %xmm0
2195 ; X64-NEXT:    cmovael %eax, %ecx
2196 ; X64-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm0
2197 ; X64-NEXT:    movl $65535, %eax # imm = 0xFFFF
2198 ; X64-NEXT:    cmovbel %ecx, %eax
2199 ; X64-NEXT:    # kill: def $ax killed $ax killed $eax
2200 ; X64-NEXT:    popq %rcx
2201 ; X64-NEXT:    retq
2202     %x = call i16 @llvm.fptoui.sat.i16.f16(half %f)
2203     ret i16 %x
2206 define i19 @test_unsigned_i19_f16(half %f) nounwind {
2207 ; X86-X87-LABEL: test_unsigned_i19_f16:
2208 ; X86-X87:       # %bb.0:
2209 ; X86-X87-NEXT:    subl $28, %esp
2210 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
2211 ; X86-X87-NEXT:    movl %eax, (%esp)
2212 ; X86-X87-NEXT:    calll __gnu_h2f_ieee
2213 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
2214 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
2215 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
2216 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
2217 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
2218 ; X86-X87-NEXT:    fld %st(0)
2219 ; X86-X87-NEXT:    fistpll {{[0-9]+}}(%esp)
2220 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
2221 ; X86-X87-NEXT:    fldz
2222 ; X86-X87-NEXT:    fxch %st(1)
2223 ; X86-X87-NEXT:    fucom %st(1)
2224 ; X86-X87-NEXT:    fstp %st(1)
2225 ; X86-X87-NEXT:    fnstsw %ax
2226 ; X86-X87-NEXT:    xorl %ecx, %ecx
2227 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
2228 ; X86-X87-NEXT:    sahf
2229 ; X86-X87-NEXT:    jb .LBB24_2
2230 ; X86-X87-NEXT:  # %bb.1:
2231 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
2232 ; X86-X87-NEXT:  .LBB24_2:
2233 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
2234 ; X86-X87-NEXT:    fxch %st(1)
2235 ; X86-X87-NEXT:    fucompp
2236 ; X86-X87-NEXT:    fnstsw %ax
2237 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
2238 ; X86-X87-NEXT:    sahf
2239 ; X86-X87-NEXT:    movl $524287, %eax # imm = 0x7FFFF
2240 ; X86-X87-NEXT:    ja .LBB24_4
2241 ; X86-X87-NEXT:  # %bb.3:
2242 ; X86-X87-NEXT:    movl %ecx, %eax
2243 ; X86-X87-NEXT:  .LBB24_4:
2244 ; X86-X87-NEXT:    addl $28, %esp
2245 ; X86-X87-NEXT:    retl
2247 ; X86-SSE-LABEL: test_unsigned_i19_f16:
2248 ; X86-SSE:       # %bb.0:
2249 ; X86-SSE-NEXT:    subl $12, %esp
2250 ; X86-SSE-NEXT:    pinsrw $0, {{[0-9]+}}(%esp), %xmm0
2251 ; X86-SSE-NEXT:    pextrw $0, %xmm0, %eax
2252 ; X86-SSE-NEXT:    movw %ax, (%esp)
2253 ; X86-SSE-NEXT:    calll __extendhfsf2
2254 ; X86-SSE-NEXT:    fstps {{[0-9]+}}(%esp)
2255 ; X86-SSE-NEXT:    movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
2256 ; X86-SSE-NEXT:    cvttss2si %xmm0, %eax
2257 ; X86-SSE-NEXT:    movl %eax, %ecx
2258 ; X86-SSE-NEXT:    sarl $31, %ecx
2259 ; X86-SSE-NEXT:    movaps %xmm0, %xmm1
2260 ; X86-SSE-NEXT:    subss {{\.?LCPI[0-9]+_[0-9]+}}, %xmm1
2261 ; X86-SSE-NEXT:    cvttss2si %xmm1, %edx
2262 ; X86-SSE-NEXT:    andl %ecx, %edx
2263 ; X86-SSE-NEXT:    orl %eax, %edx
2264 ; X86-SSE-NEXT:    xorl %ecx, %ecx
2265 ; X86-SSE-NEXT:    xorps %xmm1, %xmm1
2266 ; X86-SSE-NEXT:    ucomiss %xmm1, %xmm0
2267 ; X86-SSE-NEXT:    cmovael %edx, %ecx
2268 ; X86-SSE-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
2269 ; X86-SSE-NEXT:    movl $524287, %eax # imm = 0x7FFFF
2270 ; X86-SSE-NEXT:    cmovbel %ecx, %eax
2271 ; X86-SSE-NEXT:    addl $12, %esp
2272 ; X86-SSE-NEXT:    retl
2274 ; X64-LABEL: test_unsigned_i19_f16:
2275 ; X64:       # %bb.0:
2276 ; X64-NEXT:    pushq %rax
2277 ; X64-NEXT:    callq __extendhfsf2@PLT
2278 ; X64-NEXT:    cvttss2si %xmm0, %rax
2279 ; X64-NEXT:    xorl %ecx, %ecx
2280 ; X64-NEXT:    xorps %xmm1, %xmm1
2281 ; X64-NEXT:    ucomiss %xmm1, %xmm0
2282 ; X64-NEXT:    cmovael %eax, %ecx
2283 ; X64-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm0
2284 ; X64-NEXT:    movl $524287, %eax # imm = 0x7FFFF
2285 ; X64-NEXT:    cmovbel %ecx, %eax
2286 ; X64-NEXT:    popq %rcx
2287 ; X64-NEXT:    retq
2288     %x = call i19 @llvm.fptoui.sat.i19.f16(half %f)
2289     ret i19 %x
2292 define i32 @test_unsigned_i32_f16(half %f) nounwind {
2293 ; X86-X87-LABEL: test_unsigned_i32_f16:
2294 ; X86-X87:       # %bb.0:
2295 ; X86-X87-NEXT:    subl $28, %esp
2296 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
2297 ; X86-X87-NEXT:    movl %eax, (%esp)
2298 ; X86-X87-NEXT:    calll __gnu_h2f_ieee
2299 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
2300 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
2301 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
2302 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
2303 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
2304 ; X86-X87-NEXT:    fld %st(0)
2305 ; X86-X87-NEXT:    fistpll {{[0-9]+}}(%esp)
2306 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
2307 ; X86-X87-NEXT:    fldz
2308 ; X86-X87-NEXT:    fxch %st(1)
2309 ; X86-X87-NEXT:    fucom %st(1)
2310 ; X86-X87-NEXT:    fstp %st(1)
2311 ; X86-X87-NEXT:    fnstsw %ax
2312 ; X86-X87-NEXT:    xorl %ecx, %ecx
2313 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
2314 ; X86-X87-NEXT:    sahf
2315 ; X86-X87-NEXT:    jb .LBB25_2
2316 ; X86-X87-NEXT:  # %bb.1:
2317 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
2318 ; X86-X87-NEXT:  .LBB25_2:
2319 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
2320 ; X86-X87-NEXT:    fxch %st(1)
2321 ; X86-X87-NEXT:    fucompp
2322 ; X86-X87-NEXT:    fnstsw %ax
2323 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
2324 ; X86-X87-NEXT:    sahf
2325 ; X86-X87-NEXT:    movl $-1, %eax
2326 ; X86-X87-NEXT:    ja .LBB25_4
2327 ; X86-X87-NEXT:  # %bb.3:
2328 ; X86-X87-NEXT:    movl %ecx, %eax
2329 ; X86-X87-NEXT:  .LBB25_4:
2330 ; X86-X87-NEXT:    addl $28, %esp
2331 ; X86-X87-NEXT:    retl
2333 ; X86-SSE-LABEL: test_unsigned_i32_f16:
2334 ; X86-SSE:       # %bb.0:
2335 ; X86-SSE-NEXT:    subl $12, %esp
2336 ; X86-SSE-NEXT:    pinsrw $0, {{[0-9]+}}(%esp), %xmm0
2337 ; X86-SSE-NEXT:    pextrw $0, %xmm0, %eax
2338 ; X86-SSE-NEXT:    movw %ax, (%esp)
2339 ; X86-SSE-NEXT:    calll __extendhfsf2
2340 ; X86-SSE-NEXT:    fstps {{[0-9]+}}(%esp)
2341 ; X86-SSE-NEXT:    movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
2342 ; X86-SSE-NEXT:    cvttss2si %xmm0, %eax
2343 ; X86-SSE-NEXT:    movl %eax, %ecx
2344 ; X86-SSE-NEXT:    sarl $31, %ecx
2345 ; X86-SSE-NEXT:    movaps %xmm0, %xmm1
2346 ; X86-SSE-NEXT:    subss {{\.?LCPI[0-9]+_[0-9]+}}, %xmm1
2347 ; X86-SSE-NEXT:    cvttss2si %xmm1, %edx
2348 ; X86-SSE-NEXT:    andl %ecx, %edx
2349 ; X86-SSE-NEXT:    orl %eax, %edx
2350 ; X86-SSE-NEXT:    xorl %ecx, %ecx
2351 ; X86-SSE-NEXT:    xorps %xmm1, %xmm1
2352 ; X86-SSE-NEXT:    ucomiss %xmm1, %xmm0
2353 ; X86-SSE-NEXT:    cmovael %edx, %ecx
2354 ; X86-SSE-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
2355 ; X86-SSE-NEXT:    movl $-1, %eax
2356 ; X86-SSE-NEXT:    cmovbel %ecx, %eax
2357 ; X86-SSE-NEXT:    addl $12, %esp
2358 ; X86-SSE-NEXT:    retl
2360 ; X64-LABEL: test_unsigned_i32_f16:
2361 ; X64:       # %bb.0:
2362 ; X64-NEXT:    pushq %rax
2363 ; X64-NEXT:    callq __extendhfsf2@PLT
2364 ; X64-NEXT:    cvttss2si %xmm0, %rax
2365 ; X64-NEXT:    xorl %ecx, %ecx
2366 ; X64-NEXT:    xorps %xmm1, %xmm1
2367 ; X64-NEXT:    ucomiss %xmm1, %xmm0
2368 ; X64-NEXT:    cmovael %eax, %ecx
2369 ; X64-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm0
2370 ; X64-NEXT:    movl $-1, %eax
2371 ; X64-NEXT:    cmovbel %ecx, %eax
2372 ; X64-NEXT:    popq %rcx
2373 ; X64-NEXT:    retq
2374     %x = call i32 @llvm.fptoui.sat.i32.f16(half %f)
2375     ret i32 %x
2378 define i50 @test_unsigned_i50_f16(half %f) nounwind {
2379 ; X86-X87-LABEL: test_unsigned_i50_f16:
2380 ; X86-X87:       # %bb.0:
2381 ; X86-X87-NEXT:    pushl %esi
2382 ; X86-X87-NEXT:    subl $24, %esp
2383 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
2384 ; X86-X87-NEXT:    movl %eax, (%esp)
2385 ; X86-X87-NEXT:    calll __gnu_h2f_ieee
2386 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
2387 ; X86-X87-NEXT:    fxch %st(1)
2388 ; X86-X87-NEXT:    fucom %st(1)
2389 ; X86-X87-NEXT:    fnstsw %ax
2390 ; X86-X87-NEXT:    xorl %ecx, %ecx
2391 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
2392 ; X86-X87-NEXT:    sahf
2393 ; X86-X87-NEXT:    setae %al
2394 ; X86-X87-NEXT:    fldz
2395 ; X86-X87-NEXT:    jae .LBB26_2
2396 ; X86-X87-NEXT:  # %bb.1:
2397 ; X86-X87-NEXT:    fstp %st(2)
2398 ; X86-X87-NEXT:    fld %st(1)
2399 ; X86-X87-NEXT:    fxch %st(2)
2400 ; X86-X87-NEXT:  .LBB26_2:
2401 ; X86-X87-NEXT:    fxch %st(2)
2402 ; X86-X87-NEXT:    fsubr %st(1), %st
2403 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
2404 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %edx
2405 ; X86-X87-NEXT:    orl $3072, %edx # imm = 0xC00
2406 ; X86-X87-NEXT:    movw %dx, {{[0-9]+}}(%esp)
2407 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
2408 ; X86-X87-NEXT:    fistpll {{[0-9]+}}(%esp)
2409 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
2410 ; X86-X87-NEXT:    movb %al, %cl
2411 ; X86-X87-NEXT:    shll $31, %ecx
2412 ; X86-X87-NEXT:    xorl {{[0-9]+}}(%esp), %ecx
2413 ; X86-X87-NEXT:    fucom %st(1)
2414 ; X86-X87-NEXT:    fstp %st(1)
2415 ; X86-X87-NEXT:    fnstsw %ax
2416 ; X86-X87-NEXT:    xorl %edx, %edx
2417 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
2418 ; X86-X87-NEXT:    sahf
2419 ; X86-X87-NEXT:    movl $0, %esi
2420 ; X86-X87-NEXT:    jb .LBB26_4
2421 ; X86-X87-NEXT:  # %bb.3:
2422 ; X86-X87-NEXT:    movl %ecx, %esi
2423 ; X86-X87-NEXT:  .LBB26_4:
2424 ; X86-X87-NEXT:    jb .LBB26_6
2425 ; X86-X87-NEXT:  # %bb.5:
2426 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %edx
2427 ; X86-X87-NEXT:  .LBB26_6:
2428 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
2429 ; X86-X87-NEXT:    fxch %st(1)
2430 ; X86-X87-NEXT:    fucompp
2431 ; X86-X87-NEXT:    fnstsw %ax
2432 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
2433 ; X86-X87-NEXT:    sahf
2434 ; X86-X87-NEXT:    movl $-1, %eax
2435 ; X86-X87-NEXT:    ja .LBB26_8
2436 ; X86-X87-NEXT:  # %bb.7:
2437 ; X86-X87-NEXT:    movl %edx, %eax
2438 ; X86-X87-NEXT:  .LBB26_8:
2439 ; X86-X87-NEXT:    movl $262143, %edx # imm = 0x3FFFF
2440 ; X86-X87-NEXT:    ja .LBB26_10
2441 ; X86-X87-NEXT:  # %bb.9:
2442 ; X86-X87-NEXT:    movl %esi, %edx
2443 ; X86-X87-NEXT:  .LBB26_10:
2444 ; X86-X87-NEXT:    addl $24, %esp
2445 ; X86-X87-NEXT:    popl %esi
2446 ; X86-X87-NEXT:    retl
2448 ; X86-SSE-LABEL: test_unsigned_i50_f16:
2449 ; X86-SSE:       # %bb.0:
2450 ; X86-SSE-NEXT:    pushl %esi
2451 ; X86-SSE-NEXT:    subl $24, %esp
2452 ; X86-SSE-NEXT:    pinsrw $0, {{[0-9]+}}(%esp), %xmm0
2453 ; X86-SSE-NEXT:    pextrw $0, %xmm0, %eax
2454 ; X86-SSE-NEXT:    movw %ax, (%esp)
2455 ; X86-SSE-NEXT:    calll __extendhfsf2
2456 ; X86-SSE-NEXT:    fstps {{[0-9]+}}(%esp)
2457 ; X86-SSE-NEXT:    movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
2458 ; X86-SSE-NEXT:    movss {{.*#+}} xmm2 = mem[0],zero,zero,zero
2459 ; X86-SSE-NEXT:    ucomiss %xmm2, %xmm0
2460 ; X86-SSE-NEXT:    xorps %xmm1, %xmm1
2461 ; X86-SSE-NEXT:    jae .LBB26_2
2462 ; X86-SSE-NEXT:  # %bb.1:
2463 ; X86-SSE-NEXT:    xorps %xmm2, %xmm2
2464 ; X86-SSE-NEXT:  .LBB26_2:
2465 ; X86-SSE-NEXT:    movaps %xmm0, %xmm3
2466 ; X86-SSE-NEXT:    subss %xmm2, %xmm3
2467 ; X86-SSE-NEXT:    movss %xmm3, {{[0-9]+}}(%esp)
2468 ; X86-SSE-NEXT:    setae %cl
2469 ; X86-SSE-NEXT:    flds {{[0-9]+}}(%esp)
2470 ; X86-SSE-NEXT:    fnstcw {{[0-9]+}}(%esp)
2471 ; X86-SSE-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
2472 ; X86-SSE-NEXT:    orl $3072, %eax # imm = 0xC00
2473 ; X86-SSE-NEXT:    movw %ax, {{[0-9]+}}(%esp)
2474 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
2475 ; X86-SSE-NEXT:    fistpll {{[0-9]+}}(%esp)
2476 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
2477 ; X86-SSE-NEXT:    xorl %eax, %eax
2478 ; X86-SSE-NEXT:    ucomiss %xmm1, %xmm0
2479 ; X86-SSE-NEXT:    movl $0, %esi
2480 ; X86-SSE-NEXT:    jb .LBB26_4
2481 ; X86-SSE-NEXT:  # %bb.3:
2482 ; X86-SSE-NEXT:    movzbl %cl, %eax
2483 ; X86-SSE-NEXT:    shll $31, %eax
2484 ; X86-SSE-NEXT:    xorl {{[0-9]+}}(%esp), %eax
2485 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %esi
2486 ; X86-SSE-NEXT:  .LBB26_4:
2487 ; X86-SSE-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
2488 ; X86-SSE-NEXT:    movl $262143, %edx # imm = 0x3FFFF
2489 ; X86-SSE-NEXT:    cmovbel %eax, %edx
2490 ; X86-SSE-NEXT:    movl $-1, %eax
2491 ; X86-SSE-NEXT:    cmovbel %esi, %eax
2492 ; X86-SSE-NEXT:    addl $24, %esp
2493 ; X86-SSE-NEXT:    popl %esi
2494 ; X86-SSE-NEXT:    retl
2496 ; X64-LABEL: test_unsigned_i50_f16:
2497 ; X64:       # %bb.0:
2498 ; X64-NEXT:    pushq %rax
2499 ; X64-NEXT:    callq __extendhfsf2@PLT
2500 ; X64-NEXT:    cvttss2si %xmm0, %rax
2501 ; X64-NEXT:    movq %rax, %rcx
2502 ; X64-NEXT:    sarq $63, %rcx
2503 ; X64-NEXT:    movaps %xmm0, %xmm1
2504 ; X64-NEXT:    subss {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm1
2505 ; X64-NEXT:    cvttss2si %xmm1, %rdx
2506 ; X64-NEXT:    andq %rcx, %rdx
2507 ; X64-NEXT:    orq %rax, %rdx
2508 ; X64-NEXT:    xorl %ecx, %ecx
2509 ; X64-NEXT:    xorps %xmm1, %xmm1
2510 ; X64-NEXT:    ucomiss %xmm1, %xmm0
2511 ; X64-NEXT:    cmovaeq %rdx, %rcx
2512 ; X64-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm0
2513 ; X64-NEXT:    movabsq $1125899906842623, %rax # imm = 0x3FFFFFFFFFFFF
2514 ; X64-NEXT:    cmovbeq %rcx, %rax
2515 ; X64-NEXT:    popq %rcx
2516 ; X64-NEXT:    retq
2517     %x = call i50 @llvm.fptoui.sat.i50.f16(half %f)
2518     ret i50 %x
2521 define i64 @test_unsigned_i64_f16(half %f) nounwind {
2522 ; X86-X87-LABEL: test_unsigned_i64_f16:
2523 ; X86-X87:       # %bb.0:
2524 ; X86-X87-NEXT:    pushl %edi
2525 ; X86-X87-NEXT:    pushl %esi
2526 ; X86-X87-NEXT:    subl $20, %esp
2527 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
2528 ; X86-X87-NEXT:    movl %eax, (%esp)
2529 ; X86-X87-NEXT:    calll __gnu_h2f_ieee
2530 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
2531 ; X86-X87-NEXT:    fxch %st(1)
2532 ; X86-X87-NEXT:    fucom %st(1)
2533 ; X86-X87-NEXT:    fnstsw %ax
2534 ; X86-X87-NEXT:    xorl %ecx, %ecx
2535 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
2536 ; X86-X87-NEXT:    sahf
2537 ; X86-X87-NEXT:    setae %al
2538 ; X86-X87-NEXT:    fldz
2539 ; X86-X87-NEXT:    jae .LBB27_2
2540 ; X86-X87-NEXT:  # %bb.1:
2541 ; X86-X87-NEXT:    fstp %st(2)
2542 ; X86-X87-NEXT:    fld %st(1)
2543 ; X86-X87-NEXT:    fxch %st(2)
2544 ; X86-X87-NEXT:  .LBB27_2:
2545 ; X86-X87-NEXT:    fxch %st(2)
2546 ; X86-X87-NEXT:    fsubr %st(1), %st
2547 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
2548 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %edx
2549 ; X86-X87-NEXT:    orl $3072, %edx # imm = 0xC00
2550 ; X86-X87-NEXT:    movw %dx, {{[0-9]+}}(%esp)
2551 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
2552 ; X86-X87-NEXT:    fistpll {{[0-9]+}}(%esp)
2553 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
2554 ; X86-X87-NEXT:    movb %al, %cl
2555 ; X86-X87-NEXT:    shll $31, %ecx
2556 ; X86-X87-NEXT:    xorl {{[0-9]+}}(%esp), %ecx
2557 ; X86-X87-NEXT:    fucom %st(1)
2558 ; X86-X87-NEXT:    fstp %st(1)
2559 ; X86-X87-NEXT:    fnstsw %ax
2560 ; X86-X87-NEXT:    xorl %esi, %esi
2561 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
2562 ; X86-X87-NEXT:    sahf
2563 ; X86-X87-NEXT:    movl $0, %edi
2564 ; X86-X87-NEXT:    jb .LBB27_4
2565 ; X86-X87-NEXT:  # %bb.3:
2566 ; X86-X87-NEXT:    movl %ecx, %edi
2567 ; X86-X87-NEXT:  .LBB27_4:
2568 ; X86-X87-NEXT:    jb .LBB27_6
2569 ; X86-X87-NEXT:  # %bb.5:
2570 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %esi
2571 ; X86-X87-NEXT:  .LBB27_6:
2572 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
2573 ; X86-X87-NEXT:    fxch %st(1)
2574 ; X86-X87-NEXT:    fucompp
2575 ; X86-X87-NEXT:    fnstsw %ax
2576 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
2577 ; X86-X87-NEXT:    sahf
2578 ; X86-X87-NEXT:    movl $-1, %eax
2579 ; X86-X87-NEXT:    movl $-1, %edx
2580 ; X86-X87-NEXT:    ja .LBB27_8
2581 ; X86-X87-NEXT:  # %bb.7:
2582 ; X86-X87-NEXT:    movl %esi, %eax
2583 ; X86-X87-NEXT:    movl %edi, %edx
2584 ; X86-X87-NEXT:  .LBB27_8:
2585 ; X86-X87-NEXT:    addl $20, %esp
2586 ; X86-X87-NEXT:    popl %esi
2587 ; X86-X87-NEXT:    popl %edi
2588 ; X86-X87-NEXT:    retl
2590 ; X86-SSE-LABEL: test_unsigned_i64_f16:
2591 ; X86-SSE:       # %bb.0:
2592 ; X86-SSE-NEXT:    subl $28, %esp
2593 ; X86-SSE-NEXT:    pinsrw $0, {{[0-9]+}}(%esp), %xmm0
2594 ; X86-SSE-NEXT:    pextrw $0, %xmm0, %eax
2595 ; X86-SSE-NEXT:    movw %ax, (%esp)
2596 ; X86-SSE-NEXT:    calll __extendhfsf2
2597 ; X86-SSE-NEXT:    fstps {{[0-9]+}}(%esp)
2598 ; X86-SSE-NEXT:    movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
2599 ; X86-SSE-NEXT:    movss {{.*#+}} xmm2 = mem[0],zero,zero,zero
2600 ; X86-SSE-NEXT:    ucomiss %xmm2, %xmm0
2601 ; X86-SSE-NEXT:    xorps %xmm1, %xmm1
2602 ; X86-SSE-NEXT:    jae .LBB27_2
2603 ; X86-SSE-NEXT:  # %bb.1:
2604 ; X86-SSE-NEXT:    xorps %xmm2, %xmm2
2605 ; X86-SSE-NEXT:  .LBB27_2:
2606 ; X86-SSE-NEXT:    movaps %xmm0, %xmm3
2607 ; X86-SSE-NEXT:    subss %xmm2, %xmm3
2608 ; X86-SSE-NEXT:    movss %xmm3, {{[0-9]+}}(%esp)
2609 ; X86-SSE-NEXT:    setae %cl
2610 ; X86-SSE-NEXT:    flds {{[0-9]+}}(%esp)
2611 ; X86-SSE-NEXT:    fnstcw {{[0-9]+}}(%esp)
2612 ; X86-SSE-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
2613 ; X86-SSE-NEXT:    orl $3072, %eax # imm = 0xC00
2614 ; X86-SSE-NEXT:    movw %ax, {{[0-9]+}}(%esp)
2615 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
2616 ; X86-SSE-NEXT:    fistpll {{[0-9]+}}(%esp)
2617 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
2618 ; X86-SSE-NEXT:    xorl %edx, %edx
2619 ; X86-SSE-NEXT:    ucomiss %xmm1, %xmm0
2620 ; X86-SSE-NEXT:    movl $0, %eax
2621 ; X86-SSE-NEXT:    jb .LBB27_4
2622 ; X86-SSE-NEXT:  # %bb.3:
2623 ; X86-SSE-NEXT:    movzbl %cl, %edx
2624 ; X86-SSE-NEXT:    shll $31, %edx
2625 ; X86-SSE-NEXT:    xorl {{[0-9]+}}(%esp), %edx
2626 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %eax
2627 ; X86-SSE-NEXT:  .LBB27_4:
2628 ; X86-SSE-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
2629 ; X86-SSE-NEXT:    movl $-1, %ecx
2630 ; X86-SSE-NEXT:    cmoval %ecx, %edx
2631 ; X86-SSE-NEXT:    cmoval %ecx, %eax
2632 ; X86-SSE-NEXT:    addl $28, %esp
2633 ; X86-SSE-NEXT:    retl
2635 ; X64-LABEL: test_unsigned_i64_f16:
2636 ; X64:       # %bb.0:
2637 ; X64-NEXT:    pushq %rax
2638 ; X64-NEXT:    callq __extendhfsf2@PLT
2639 ; X64-NEXT:    cvttss2si %xmm0, %rax
2640 ; X64-NEXT:    movq %rax, %rcx
2641 ; X64-NEXT:    sarq $63, %rcx
2642 ; X64-NEXT:    movaps %xmm0, %xmm1
2643 ; X64-NEXT:    subss {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm1
2644 ; X64-NEXT:    cvttss2si %xmm1, %rdx
2645 ; X64-NEXT:    andq %rcx, %rdx
2646 ; X64-NEXT:    orq %rax, %rdx
2647 ; X64-NEXT:    xorl %ecx, %ecx
2648 ; X64-NEXT:    xorps %xmm1, %xmm1
2649 ; X64-NEXT:    ucomiss %xmm1, %xmm0
2650 ; X64-NEXT:    cmovaeq %rdx, %rcx
2651 ; X64-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm0
2652 ; X64-NEXT:    movq $-1, %rax
2653 ; X64-NEXT:    cmovbeq %rcx, %rax
2654 ; X64-NEXT:    popq %rcx
2655 ; X64-NEXT:    retq
2656     %x = call i64 @llvm.fptoui.sat.i64.f16(half %f)
2657     ret i64 %x
2660 define i100 @test_unsigned_i100_f16(half %f) nounwind {
2661 ; X86-X87-LABEL: test_unsigned_i100_f16:
2662 ; X86-X87:       # %bb.0:
2663 ; X86-X87-NEXT:    pushl %ebp
2664 ; X86-X87-NEXT:    pushl %ebx
2665 ; X86-X87-NEXT:    pushl %edi
2666 ; X86-X87-NEXT:    pushl %esi
2667 ; X86-X87-NEXT:    subl $44, %esp
2668 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
2669 ; X86-X87-NEXT:    movl %eax, (%esp)
2670 ; X86-X87-NEXT:    calll __gnu_h2f_ieee
2671 ; X86-X87-NEXT:    leal {{[0-9]+}}(%esp), %eax
2672 ; X86-X87-NEXT:    movl %eax, (%esp)
2673 ; X86-X87-NEXT:    fsts {{[0-9]+}}(%esp)
2674 ; X86-X87-NEXT:    fldz
2675 ; X86-X87-NEXT:    fxch %st(1)
2676 ; X86-X87-NEXT:    fsts {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Folded Spill
2677 ; X86-X87-NEXT:    fucompp
2678 ; X86-X87-NEXT:    fnstsw %ax
2679 ; X86-X87-NEXT:    movl %eax, %ebx
2680 ; X86-X87-NEXT:    calll __fixunssfti
2681 ; X86-X87-NEXT:    subl $4, %esp
2682 ; X86-X87-NEXT:    xorl %edi, %edi
2683 ; X86-X87-NEXT:    movb %bh, %ah
2684 ; X86-X87-NEXT:    sahf
2685 ; X86-X87-NEXT:    movl $0, %eax
2686 ; X86-X87-NEXT:    jb .LBB28_2
2687 ; X86-X87-NEXT:  # %bb.1:
2688 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %eax
2689 ; X86-X87-NEXT:  .LBB28_2:
2690 ; X86-X87-NEXT:    movl $0, %esi
2691 ; X86-X87-NEXT:    movl $0, %ebx
2692 ; X86-X87-NEXT:    jb .LBB28_4
2693 ; X86-X87-NEXT:  # %bb.3:
2694 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ebx
2695 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %esi
2696 ; X86-X87-NEXT:  .LBB28_4:
2697 ; X86-X87-NEXT:    jb .LBB28_6
2698 ; X86-X87-NEXT:  # %bb.5:
2699 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %edi
2700 ; X86-X87-NEXT:  .LBB28_6:
2701 ; X86-X87-NEXT:    movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill
2702 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
2703 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
2704 ; X86-X87-NEXT:    flds {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Folded Reload
2705 ; X86-X87-NEXT:    fucompp
2706 ; X86-X87-NEXT:    fnstsw %ax
2707 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
2708 ; X86-X87-NEXT:    sahf
2709 ; X86-X87-NEXT:    movl $15, %eax
2710 ; X86-X87-NEXT:    ja .LBB28_8
2711 ; X86-X87-NEXT:  # %bb.7:
2712 ; X86-X87-NEXT:    movl %edi, %eax
2713 ; X86-X87-NEXT:  .LBB28_8:
2714 ; X86-X87-NEXT:    movl $-1, %edi
2715 ; X86-X87-NEXT:    movl $-1, %ebp
2716 ; X86-X87-NEXT:    movl $-1, %edx
2717 ; X86-X87-NEXT:    ja .LBB28_10
2718 ; X86-X87-NEXT:  # %bb.9:
2719 ; X86-X87-NEXT:    movl %ebx, %edi
2720 ; X86-X87-NEXT:    movl %esi, %ebp
2721 ; X86-X87-NEXT:    movl {{[-0-9]+}}(%e{{[sb]}}p), %edx # 4-byte Reload
2722 ; X86-X87-NEXT:  .LBB28_10:
2723 ; X86-X87-NEXT:    movl %edx, 8(%ecx)
2724 ; X86-X87-NEXT:    movl %ebp, 4(%ecx)
2725 ; X86-X87-NEXT:    movl %edi, (%ecx)
2726 ; X86-X87-NEXT:    andl $15, %eax
2727 ; X86-X87-NEXT:    movb %al, 12(%ecx)
2728 ; X86-X87-NEXT:    movl %ecx, %eax
2729 ; X86-X87-NEXT:    addl $44, %esp
2730 ; X86-X87-NEXT:    popl %esi
2731 ; X86-X87-NEXT:    popl %edi
2732 ; X86-X87-NEXT:    popl %ebx
2733 ; X86-X87-NEXT:    popl %ebp
2734 ; X86-X87-NEXT:    retl $4
2736 ; X86-SSE-LABEL: test_unsigned_i100_f16:
2737 ; X86-SSE:       # %bb.0:
2738 ; X86-SSE-NEXT:    pushl %ebx
2739 ; X86-SSE-NEXT:    pushl %edi
2740 ; X86-SSE-NEXT:    pushl %esi
2741 ; X86-SSE-NEXT:    subl $32, %esp
2742 ; X86-SSE-NEXT:    pinsrw $0, {{[0-9]+}}(%esp), %xmm0
2743 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %esi
2744 ; X86-SSE-NEXT:    pextrw $0, %xmm0, %eax
2745 ; X86-SSE-NEXT:    movw %ax, (%esp)
2746 ; X86-SSE-NEXT:    calll __extendhfsf2
2747 ; X86-SSE-NEXT:    leal {{[0-9]+}}(%esp), %eax
2748 ; X86-SSE-NEXT:    movl %eax, (%esp)
2749 ; X86-SSE-NEXT:    fstps {{[0-9]+}}(%esp)
2750 ; X86-SSE-NEXT:    movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
2751 ; X86-SSE-NEXT:    movss %xmm0, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill
2752 ; X86-SSE-NEXT:    movss %xmm0, {{[0-9]+}}(%esp)
2753 ; X86-SSE-NEXT:    calll __fixunssfti
2754 ; X86-SSE-NEXT:    subl $4, %esp
2755 ; X86-SSE-NEXT:    xorl %eax, %eax
2756 ; X86-SSE-NEXT:    xorps %xmm0, %xmm0
2757 ; X86-SSE-NEXT:    movss {{[-0-9]+}}(%e{{[sb]}}p), %xmm1 # 4-byte Reload
2758 ; X86-SSE-NEXT:    # xmm1 = mem[0],zero,zero,zero
2759 ; X86-SSE-NEXT:    ucomiss %xmm0, %xmm1
2760 ; X86-SSE-NEXT:    movaps %xmm1, %xmm0
2761 ; X86-SSE-NEXT:    movl $0, %ecx
2762 ; X86-SSE-NEXT:    movl $0, %edx
2763 ; X86-SSE-NEXT:    movl $0, %edi
2764 ; X86-SSE-NEXT:    jb .LBB28_2
2765 ; X86-SSE-NEXT:  # %bb.1:
2766 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %eax
2767 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %ecx
2768 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %edx
2769 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %edi
2770 ; X86-SSE-NEXT:  .LBB28_2:
2771 ; X86-SSE-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
2772 ; X86-SSE-NEXT:    movl $15, %ebx
2773 ; X86-SSE-NEXT:    cmovbel %edi, %ebx
2774 ; X86-SSE-NEXT:    movl $-1, %edi
2775 ; X86-SSE-NEXT:    cmoval %edi, %edx
2776 ; X86-SSE-NEXT:    cmoval %edi, %ecx
2777 ; X86-SSE-NEXT:    cmoval %edi, %eax
2778 ; X86-SSE-NEXT:    movl %eax, 8(%esi)
2779 ; X86-SSE-NEXT:    movl %ecx, 4(%esi)
2780 ; X86-SSE-NEXT:    movl %edx, (%esi)
2781 ; X86-SSE-NEXT:    andl $15, %ebx
2782 ; X86-SSE-NEXT:    movb %bl, 12(%esi)
2783 ; X86-SSE-NEXT:    movl %esi, %eax
2784 ; X86-SSE-NEXT:    addl $32, %esp
2785 ; X86-SSE-NEXT:    popl %esi
2786 ; X86-SSE-NEXT:    popl %edi
2787 ; X86-SSE-NEXT:    popl %ebx
2788 ; X86-SSE-NEXT:    retl $4
2790 ; X64-LABEL: test_unsigned_i100_f16:
2791 ; X64:       # %bb.0:
2792 ; X64-NEXT:    pushq %rax
2793 ; X64-NEXT:    callq __extendhfsf2@PLT
2794 ; X64-NEXT:    movss %xmm0, {{[-0-9]+}}(%r{{[sb]}}p) # 4-byte Spill
2795 ; X64-NEXT:    callq __fixunssfti@PLT
2796 ; X64-NEXT:    xorl %ecx, %ecx
2797 ; X64-NEXT:    xorps %xmm0, %xmm0
2798 ; X64-NEXT:    movss {{[-0-9]+}}(%r{{[sb]}}p), %xmm1 # 4-byte Reload
2799 ; X64-NEXT:    # xmm1 = mem[0],zero,zero,zero
2800 ; X64-NEXT:    ucomiss %xmm0, %xmm1
2801 ; X64-NEXT:    cmovbq %rcx, %rdx
2802 ; X64-NEXT:    cmovbq %rcx, %rax
2803 ; X64-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm1
2804 ; X64-NEXT:    movq $-1, %rcx
2805 ; X64-NEXT:    cmovaq %rcx, %rax
2806 ; X64-NEXT:    movabsq $68719476735, %rcx # imm = 0xFFFFFFFFF
2807 ; X64-NEXT:    cmovaq %rcx, %rdx
2808 ; X64-NEXT:    popq %rcx
2809 ; X64-NEXT:    retq
2810     %x = call i100 @llvm.fptoui.sat.i100.f16(half %f)
2811     ret i100 %x
2814 define i128 @test_unsigned_i128_f16(half %f) nounwind {
2815 ; X86-X87-LABEL: test_unsigned_i128_f16:
2816 ; X86-X87:       # %bb.0:
2817 ; X86-X87-NEXT:    pushl %ebp
2818 ; X86-X87-NEXT:    pushl %ebx
2819 ; X86-X87-NEXT:    pushl %edi
2820 ; X86-X87-NEXT:    pushl %esi
2821 ; X86-X87-NEXT:    subl $60, %esp
2822 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
2823 ; X86-X87-NEXT:    movl %eax, (%esp)
2824 ; X86-X87-NEXT:    calll __gnu_h2f_ieee
2825 ; X86-X87-NEXT:    leal {{[0-9]+}}(%esp), %eax
2826 ; X86-X87-NEXT:    movl %eax, (%esp)
2827 ; X86-X87-NEXT:    fsts {{[0-9]+}}(%esp)
2828 ; X86-X87-NEXT:    fldz
2829 ; X86-X87-NEXT:    fxch %st(1)
2830 ; X86-X87-NEXT:    fsts {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Folded Spill
2831 ; X86-X87-NEXT:    fucompp
2832 ; X86-X87-NEXT:    fnstsw %ax
2833 ; X86-X87-NEXT:    movl %eax, %ebx
2834 ; X86-X87-NEXT:    calll __fixunssfti
2835 ; X86-X87-NEXT:    subl $4, %esp
2836 ; X86-X87-NEXT:    xorl %edx, %edx
2837 ; X86-X87-NEXT:    movb %bh, %ah
2838 ; X86-X87-NEXT:    sahf
2839 ; X86-X87-NEXT:    movl $0, %eax
2840 ; X86-X87-NEXT:    jb .LBB29_2
2841 ; X86-X87-NEXT:  # %bb.1:
2842 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %eax
2843 ; X86-X87-NEXT:  .LBB29_2:
2844 ; X86-X87-NEXT:    movl $0, %ecx
2845 ; X86-X87-NEXT:    jb .LBB29_4
2846 ; X86-X87-NEXT:  # %bb.3:
2847 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
2848 ; X86-X87-NEXT:  .LBB29_4:
2849 ; X86-X87-NEXT:    movl %ecx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill
2850 ; X86-X87-NEXT:    movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill
2851 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
2852 ; X86-X87-NEXT:    movl $0, %ebx
2853 ; X86-X87-NEXT:    jb .LBB29_6
2854 ; X86-X87-NEXT:  # %bb.5:
2855 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ebx
2856 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %edx
2857 ; X86-X87-NEXT:  .LBB29_6:
2858 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
2859 ; X86-X87-NEXT:    flds {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Folded Reload
2860 ; X86-X87-NEXT:    fucompp
2861 ; X86-X87-NEXT:    fnstsw %ax
2862 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
2863 ; X86-X87-NEXT:    sahf
2864 ; X86-X87-NEXT:    movl $-1, %eax
2865 ; X86-X87-NEXT:    movl $-1, %ebp
2866 ; X86-X87-NEXT:    movl $-1, %edi
2867 ; X86-X87-NEXT:    movl $-1, %esi
2868 ; X86-X87-NEXT:    ja .LBB29_8
2869 ; X86-X87-NEXT:  # %bb.7:
2870 ; X86-X87-NEXT:    movl %ebx, %eax
2871 ; X86-X87-NEXT:    movl %edx, %ebp
2872 ; X86-X87-NEXT:    movl {{[-0-9]+}}(%e{{[sb]}}p), %edi # 4-byte Reload
2873 ; X86-X87-NEXT:    movl {{[-0-9]+}}(%e{{[sb]}}p), %esi # 4-byte Reload
2874 ; X86-X87-NEXT:  .LBB29_8:
2875 ; X86-X87-NEXT:    movl %esi, 12(%ecx)
2876 ; X86-X87-NEXT:    movl %edi, 8(%ecx)
2877 ; X86-X87-NEXT:    movl %ebp, 4(%ecx)
2878 ; X86-X87-NEXT:    movl %eax, (%ecx)
2879 ; X86-X87-NEXT:    movl %ecx, %eax
2880 ; X86-X87-NEXT:    addl $60, %esp
2881 ; X86-X87-NEXT:    popl %esi
2882 ; X86-X87-NEXT:    popl %edi
2883 ; X86-X87-NEXT:    popl %ebx
2884 ; X86-X87-NEXT:    popl %ebp
2885 ; X86-X87-NEXT:    retl $4
2887 ; X86-SSE-LABEL: test_unsigned_i128_f16:
2888 ; X86-SSE:       # %bb.0:
2889 ; X86-SSE-NEXT:    pushl %ebx
2890 ; X86-SSE-NEXT:    pushl %edi
2891 ; X86-SSE-NEXT:    pushl %esi
2892 ; X86-SSE-NEXT:    subl $32, %esp
2893 ; X86-SSE-NEXT:    pinsrw $0, {{[0-9]+}}(%esp), %xmm0
2894 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %esi
2895 ; X86-SSE-NEXT:    pextrw $0, %xmm0, %eax
2896 ; X86-SSE-NEXT:    movw %ax, (%esp)
2897 ; X86-SSE-NEXT:    calll __extendhfsf2
2898 ; X86-SSE-NEXT:    leal {{[0-9]+}}(%esp), %eax
2899 ; X86-SSE-NEXT:    movl %eax, (%esp)
2900 ; X86-SSE-NEXT:    fstps {{[0-9]+}}(%esp)
2901 ; X86-SSE-NEXT:    movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
2902 ; X86-SSE-NEXT:    movss %xmm0, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill
2903 ; X86-SSE-NEXT:    movss %xmm0, {{[0-9]+}}(%esp)
2904 ; X86-SSE-NEXT:    calll __fixunssfti
2905 ; X86-SSE-NEXT:    subl $4, %esp
2906 ; X86-SSE-NEXT:    xorl %eax, %eax
2907 ; X86-SSE-NEXT:    xorps %xmm0, %xmm0
2908 ; X86-SSE-NEXT:    movss {{[-0-9]+}}(%e{{[sb]}}p), %xmm1 # 4-byte Reload
2909 ; X86-SSE-NEXT:    # xmm1 = mem[0],zero,zero,zero
2910 ; X86-SSE-NEXT:    ucomiss %xmm0, %xmm1
2911 ; X86-SSE-NEXT:    movaps %xmm1, %xmm0
2912 ; X86-SSE-NEXT:    movl $0, %ecx
2913 ; X86-SSE-NEXT:    movl $0, %edx
2914 ; X86-SSE-NEXT:    movl $0, %edi
2915 ; X86-SSE-NEXT:    jb .LBB29_2
2916 ; X86-SSE-NEXT:  # %bb.1:
2917 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %eax
2918 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %ecx
2919 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %edx
2920 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %edi
2921 ; X86-SSE-NEXT:  .LBB29_2:
2922 ; X86-SSE-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}, %xmm0
2923 ; X86-SSE-NEXT:    movl $-1, %ebx
2924 ; X86-SSE-NEXT:    cmoval %ebx, %edi
2925 ; X86-SSE-NEXT:    cmoval %ebx, %edx
2926 ; X86-SSE-NEXT:    cmoval %ebx, %ecx
2927 ; X86-SSE-NEXT:    cmoval %ebx, %eax
2928 ; X86-SSE-NEXT:    movl %eax, 12(%esi)
2929 ; X86-SSE-NEXT:    movl %ecx, 8(%esi)
2930 ; X86-SSE-NEXT:    movl %edx, 4(%esi)
2931 ; X86-SSE-NEXT:    movl %edi, (%esi)
2932 ; X86-SSE-NEXT:    movl %esi, %eax
2933 ; X86-SSE-NEXT:    addl $32, %esp
2934 ; X86-SSE-NEXT:    popl %esi
2935 ; X86-SSE-NEXT:    popl %edi
2936 ; X86-SSE-NEXT:    popl %ebx
2937 ; X86-SSE-NEXT:    retl $4
2939 ; X64-LABEL: test_unsigned_i128_f16:
2940 ; X64:       # %bb.0:
2941 ; X64-NEXT:    pushq %rax
2942 ; X64-NEXT:    callq __extendhfsf2@PLT
2943 ; X64-NEXT:    movss %xmm0, {{[-0-9]+}}(%r{{[sb]}}p) # 4-byte Spill
2944 ; X64-NEXT:    callq __fixunssfti@PLT
2945 ; X64-NEXT:    xorl %ecx, %ecx
2946 ; X64-NEXT:    xorps %xmm0, %xmm0
2947 ; X64-NEXT:    movss {{[-0-9]+}}(%r{{[sb]}}p), %xmm1 # 4-byte Reload
2948 ; X64-NEXT:    # xmm1 = mem[0],zero,zero,zero
2949 ; X64-NEXT:    ucomiss %xmm0, %xmm1
2950 ; X64-NEXT:    cmovbq %rcx, %rdx
2951 ; X64-NEXT:    cmovbq %rcx, %rax
2952 ; X64-NEXT:    ucomiss {{\.?LCPI[0-9]+_[0-9]+}}(%rip), %xmm1
2953 ; X64-NEXT:    movq $-1, %rcx
2954 ; X64-NEXT:    cmovaq %rcx, %rax
2955 ; X64-NEXT:    cmovaq %rcx, %rdx
2956 ; X64-NEXT:    popq %rcx
2957 ; X64-NEXT:    retq
2958     %x = call i128 @llvm.fptoui.sat.i128.f16(half %f)
2959     ret i128 %x
2963 ; 80-bit float to unsigned integer
2966 declare   i1 @llvm.fptoui.sat.i1.f80  (x86_fp80)
2967 declare   i8 @llvm.fptoui.sat.i8.f80  (x86_fp80)
2968 declare  i13 @llvm.fptoui.sat.i13.f80 (x86_fp80)
2969 declare  i16 @llvm.fptoui.sat.i16.f80 (x86_fp80)
2970 declare  i19 @llvm.fptoui.sat.i19.f80 (x86_fp80)
2971 declare  i32 @llvm.fptoui.sat.i32.f80 (x86_fp80)
2972 declare  i50 @llvm.fptoui.sat.i50.f80 (x86_fp80)
2973 declare  i64 @llvm.fptoui.sat.i64.f80 (x86_fp80)
2974 declare i100 @llvm.fptoui.sat.i100.f80(x86_fp80)
2975 declare i128 @llvm.fptoui.sat.i128.f80(x86_fp80)
2977 define i1 @test_unsigned_i1_f80(x86_fp80 %f) nounwind {
2978 ; X86-X87-LABEL: test_unsigned_i1_f80:
2979 ; X86-X87:       # %bb.0:
2980 ; X86-X87-NEXT:    subl $8, %esp
2981 ; X86-X87-NEXT:    fldt {{[0-9]+}}(%esp)
2982 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
2983 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
2984 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
2985 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
2986 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
2987 ; X86-X87-NEXT:    fists {{[0-9]+}}(%esp)
2988 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
2989 ; X86-X87-NEXT:    fldz
2990 ; X86-X87-NEXT:    fxch %st(1)
2991 ; X86-X87-NEXT:    fucom %st(1)
2992 ; X86-X87-NEXT:    fstp %st(1)
2993 ; X86-X87-NEXT:    fnstsw %ax
2994 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
2995 ; X86-X87-NEXT:    sahf
2996 ; X86-X87-NEXT:    jb .LBB30_1
2997 ; X86-X87-NEXT:  # %bb.2:
2998 ; X86-X87-NEXT:    movzbl {{[0-9]+}}(%esp), %ecx
2999 ; X86-X87-NEXT:    jmp .LBB30_3
3000 ; X86-X87-NEXT:  .LBB30_1:
3001 ; X86-X87-NEXT:    xorl %ecx, %ecx
3002 ; X86-X87-NEXT:  .LBB30_3:
3003 ; X86-X87-NEXT:    fld1
3004 ; X86-X87-NEXT:    fxch %st(1)
3005 ; X86-X87-NEXT:    fucompp
3006 ; X86-X87-NEXT:    fnstsw %ax
3007 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
3008 ; X86-X87-NEXT:    sahf
3009 ; X86-X87-NEXT:    movb $1, %al
3010 ; X86-X87-NEXT:    ja .LBB30_5
3011 ; X86-X87-NEXT:  # %bb.4:
3012 ; X86-X87-NEXT:    movl %ecx, %eax
3013 ; X86-X87-NEXT:  .LBB30_5:
3014 ; X86-X87-NEXT:    addl $8, %esp
3015 ; X86-X87-NEXT:    retl
3017 ; X86-SSE-LABEL: test_unsigned_i1_f80:
3018 ; X86-SSE:       # %bb.0:
3019 ; X86-SSE-NEXT:    subl $8, %esp
3020 ; X86-SSE-NEXT:    fldt {{[0-9]+}}(%esp)
3021 ; X86-SSE-NEXT:    fnstcw {{[0-9]+}}(%esp)
3022 ; X86-SSE-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
3023 ; X86-SSE-NEXT:    orl $3072, %eax # imm = 0xC00
3024 ; X86-SSE-NEXT:    movw %ax, {{[0-9]+}}(%esp)
3025 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
3026 ; X86-SSE-NEXT:    fists {{[0-9]+}}(%esp)
3027 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
3028 ; X86-SSE-NEXT:    movzbl {{[0-9]+}}(%esp), %eax
3029 ; X86-SSE-NEXT:    xorl %ecx, %ecx
3030 ; X86-SSE-NEXT:    fldz
3031 ; X86-SSE-NEXT:    fxch %st(1)
3032 ; X86-SSE-NEXT:    fucomi %st(1), %st
3033 ; X86-SSE-NEXT:    fstp %st(1)
3034 ; X86-SSE-NEXT:    cmovael %eax, %ecx
3035 ; X86-SSE-NEXT:    fld1
3036 ; X86-SSE-NEXT:    fxch %st(1)
3037 ; X86-SSE-NEXT:    fucompi %st(1), %st
3038 ; X86-SSE-NEXT:    fstp %st(0)
3039 ; X86-SSE-NEXT:    movl $1, %eax
3040 ; X86-SSE-NEXT:    cmovbel %ecx, %eax
3041 ; X86-SSE-NEXT:    # kill: def $al killed $al killed $eax
3042 ; X86-SSE-NEXT:    addl $8, %esp
3043 ; X86-SSE-NEXT:    retl
3045 ; X64-LABEL: test_unsigned_i1_f80:
3046 ; X64:       # %bb.0:
3047 ; X64-NEXT:    fldt {{[0-9]+}}(%rsp)
3048 ; X64-NEXT:    fnstcw -{{[0-9]+}}(%rsp)
3049 ; X64-NEXT:    movzwl -{{[0-9]+}}(%rsp), %eax
3050 ; X64-NEXT:    orl $3072, %eax # imm = 0xC00
3051 ; X64-NEXT:    movw %ax, -{{[0-9]+}}(%rsp)
3052 ; X64-NEXT:    fldcw -{{[0-9]+}}(%rsp)
3053 ; X64-NEXT:    fists -{{[0-9]+}}(%rsp)
3054 ; X64-NEXT:    fldcw -{{[0-9]+}}(%rsp)
3055 ; X64-NEXT:    movzbl -{{[0-9]+}}(%rsp), %eax
3056 ; X64-NEXT:    xorl %ecx, %ecx
3057 ; X64-NEXT:    fldz
3058 ; X64-NEXT:    fxch %st(1)
3059 ; X64-NEXT:    fucomi %st(1), %st
3060 ; X64-NEXT:    fstp %st(1)
3061 ; X64-NEXT:    cmovael %eax, %ecx
3062 ; X64-NEXT:    fld1
3063 ; X64-NEXT:    fxch %st(1)
3064 ; X64-NEXT:    fucompi %st(1), %st
3065 ; X64-NEXT:    fstp %st(0)
3066 ; X64-NEXT:    movl $1, %eax
3067 ; X64-NEXT:    cmovbel %ecx, %eax
3068 ; X64-NEXT:    # kill: def $al killed $al killed $eax
3069 ; X64-NEXT:    retq
3070     %x = call i1 @llvm.fptoui.sat.i1.f80(x86_fp80 %f)
3071     ret i1 %x
3074 define i8 @test_unsigned_i8_f80(x86_fp80 %f) nounwind {
3075 ; X86-X87-LABEL: test_unsigned_i8_f80:
3076 ; X86-X87:       # %bb.0:
3077 ; X86-X87-NEXT:    subl $8, %esp
3078 ; X86-X87-NEXT:    fldt {{[0-9]+}}(%esp)
3079 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
3080 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
3081 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
3082 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
3083 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
3084 ; X86-X87-NEXT:    fists {{[0-9]+}}(%esp)
3085 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
3086 ; X86-X87-NEXT:    fldz
3087 ; X86-X87-NEXT:    fxch %st(1)
3088 ; X86-X87-NEXT:    fucom %st(1)
3089 ; X86-X87-NEXT:    fstp %st(1)
3090 ; X86-X87-NEXT:    fnstsw %ax
3091 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
3092 ; X86-X87-NEXT:    sahf
3093 ; X86-X87-NEXT:    jb .LBB31_1
3094 ; X86-X87-NEXT:  # %bb.2:
3095 ; X86-X87-NEXT:    movzbl {{[0-9]+}}(%esp), %ecx
3096 ; X86-X87-NEXT:    jmp .LBB31_3
3097 ; X86-X87-NEXT:  .LBB31_1:
3098 ; X86-X87-NEXT:    xorl %ecx, %ecx
3099 ; X86-X87-NEXT:  .LBB31_3:
3100 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
3101 ; X86-X87-NEXT:    fxch %st(1)
3102 ; X86-X87-NEXT:    fucompp
3103 ; X86-X87-NEXT:    fnstsw %ax
3104 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
3105 ; X86-X87-NEXT:    sahf
3106 ; X86-X87-NEXT:    movb $-1, %al
3107 ; X86-X87-NEXT:    ja .LBB31_5
3108 ; X86-X87-NEXT:  # %bb.4:
3109 ; X86-X87-NEXT:    movl %ecx, %eax
3110 ; X86-X87-NEXT:  .LBB31_5:
3111 ; X86-X87-NEXT:    addl $8, %esp
3112 ; X86-X87-NEXT:    retl
3114 ; X86-SSE-LABEL: test_unsigned_i8_f80:
3115 ; X86-SSE:       # %bb.0:
3116 ; X86-SSE-NEXT:    subl $8, %esp
3117 ; X86-SSE-NEXT:    fldt {{[0-9]+}}(%esp)
3118 ; X86-SSE-NEXT:    fnstcw {{[0-9]+}}(%esp)
3119 ; X86-SSE-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
3120 ; X86-SSE-NEXT:    orl $3072, %eax # imm = 0xC00
3121 ; X86-SSE-NEXT:    movw %ax, {{[0-9]+}}(%esp)
3122 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
3123 ; X86-SSE-NEXT:    fists {{[0-9]+}}(%esp)
3124 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
3125 ; X86-SSE-NEXT:    movzbl {{[0-9]+}}(%esp), %eax
3126 ; X86-SSE-NEXT:    xorl %ecx, %ecx
3127 ; X86-SSE-NEXT:    fldz
3128 ; X86-SSE-NEXT:    fxch %st(1)
3129 ; X86-SSE-NEXT:    fucomi %st(1), %st
3130 ; X86-SSE-NEXT:    fstp %st(1)
3131 ; X86-SSE-NEXT:    cmovael %eax, %ecx
3132 ; X86-SSE-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
3133 ; X86-SSE-NEXT:    fxch %st(1)
3134 ; X86-SSE-NEXT:    fucompi %st(1), %st
3135 ; X86-SSE-NEXT:    fstp %st(0)
3136 ; X86-SSE-NEXT:    movl $255, %eax
3137 ; X86-SSE-NEXT:    cmovbel %ecx, %eax
3138 ; X86-SSE-NEXT:    # kill: def $al killed $al killed $eax
3139 ; X86-SSE-NEXT:    addl $8, %esp
3140 ; X86-SSE-NEXT:    retl
3142 ; X64-LABEL: test_unsigned_i8_f80:
3143 ; X64:       # %bb.0:
3144 ; X64-NEXT:    fldt {{[0-9]+}}(%rsp)
3145 ; X64-NEXT:    fnstcw -{{[0-9]+}}(%rsp)
3146 ; X64-NEXT:    movzwl -{{[0-9]+}}(%rsp), %eax
3147 ; X64-NEXT:    orl $3072, %eax # imm = 0xC00
3148 ; X64-NEXT:    movw %ax, -{{[0-9]+}}(%rsp)
3149 ; X64-NEXT:    fldcw -{{[0-9]+}}(%rsp)
3150 ; X64-NEXT:    fists -{{[0-9]+}}(%rsp)
3151 ; X64-NEXT:    fldcw -{{[0-9]+}}(%rsp)
3152 ; X64-NEXT:    movzbl -{{[0-9]+}}(%rsp), %eax
3153 ; X64-NEXT:    xorl %ecx, %ecx
3154 ; X64-NEXT:    fldz
3155 ; X64-NEXT:    fxch %st(1)
3156 ; X64-NEXT:    fucomi %st(1), %st
3157 ; X64-NEXT:    fstp %st(1)
3158 ; X64-NEXT:    cmovael %eax, %ecx
3159 ; X64-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}(%rip)
3160 ; X64-NEXT:    fxch %st(1)
3161 ; X64-NEXT:    fucompi %st(1), %st
3162 ; X64-NEXT:    fstp %st(0)
3163 ; X64-NEXT:    movl $255, %eax
3164 ; X64-NEXT:    cmovbel %ecx, %eax
3165 ; X64-NEXT:    # kill: def $al killed $al killed $eax
3166 ; X64-NEXT:    retq
3167     %x = call i8 @llvm.fptoui.sat.i8.f80(x86_fp80 %f)
3168     ret i8 %x
3171 define i13 @test_unsigned_i13_f80(x86_fp80 %f) nounwind {
3172 ; X86-X87-LABEL: test_unsigned_i13_f80:
3173 ; X86-X87:       # %bb.0:
3174 ; X86-X87-NEXT:    subl $8, %esp
3175 ; X86-X87-NEXT:    fldt {{[0-9]+}}(%esp)
3176 ; X86-X87-NEXT:    fnstcw (%esp)
3177 ; X86-X87-NEXT:    movzwl (%esp), %eax
3178 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
3179 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
3180 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
3181 ; X86-X87-NEXT:    fistl {{[0-9]+}}(%esp)
3182 ; X86-X87-NEXT:    fldcw (%esp)
3183 ; X86-X87-NEXT:    fldz
3184 ; X86-X87-NEXT:    fxch %st(1)
3185 ; X86-X87-NEXT:    fucom %st(1)
3186 ; X86-X87-NEXT:    fstp %st(1)
3187 ; X86-X87-NEXT:    fnstsw %ax
3188 ; X86-X87-NEXT:    xorl %ecx, %ecx
3189 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
3190 ; X86-X87-NEXT:    sahf
3191 ; X86-X87-NEXT:    jb .LBB32_2
3192 ; X86-X87-NEXT:  # %bb.1:
3193 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
3194 ; X86-X87-NEXT:  .LBB32_2:
3195 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
3196 ; X86-X87-NEXT:    fxch %st(1)
3197 ; X86-X87-NEXT:    fucompp
3198 ; X86-X87-NEXT:    fnstsw %ax
3199 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
3200 ; X86-X87-NEXT:    sahf
3201 ; X86-X87-NEXT:    movl $8191, %eax # imm = 0x1FFF
3202 ; X86-X87-NEXT:    ja .LBB32_4
3203 ; X86-X87-NEXT:  # %bb.3:
3204 ; X86-X87-NEXT:    movl %ecx, %eax
3205 ; X86-X87-NEXT:  .LBB32_4:
3206 ; X86-X87-NEXT:    # kill: def $ax killed $ax killed $eax
3207 ; X86-X87-NEXT:    addl $8, %esp
3208 ; X86-X87-NEXT:    retl
3210 ; X86-SSE-LABEL: test_unsigned_i13_f80:
3211 ; X86-SSE:       # %bb.0:
3212 ; X86-SSE-NEXT:    subl $8, %esp
3213 ; X86-SSE-NEXT:    fldt {{[0-9]+}}(%esp)
3214 ; X86-SSE-NEXT:    fnstcw (%esp)
3215 ; X86-SSE-NEXT:    movzwl (%esp), %eax
3216 ; X86-SSE-NEXT:    orl $3072, %eax # imm = 0xC00
3217 ; X86-SSE-NEXT:    movw %ax, {{[0-9]+}}(%esp)
3218 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
3219 ; X86-SSE-NEXT:    fistl {{[0-9]+}}(%esp)
3220 ; X86-SSE-NEXT:    fldcw (%esp)
3221 ; X86-SSE-NEXT:    xorl %ecx, %ecx
3222 ; X86-SSE-NEXT:    fldz
3223 ; X86-SSE-NEXT:    fxch %st(1)
3224 ; X86-SSE-NEXT:    fucomi %st(1), %st
3225 ; X86-SSE-NEXT:    fstp %st(1)
3226 ; X86-SSE-NEXT:    jb .LBB32_2
3227 ; X86-SSE-NEXT:  # %bb.1:
3228 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %ecx
3229 ; X86-SSE-NEXT:  .LBB32_2:
3230 ; X86-SSE-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
3231 ; X86-SSE-NEXT:    fxch %st(1)
3232 ; X86-SSE-NEXT:    fucompi %st(1), %st
3233 ; X86-SSE-NEXT:    fstp %st(0)
3234 ; X86-SSE-NEXT:    movl $8191, %eax # imm = 0x1FFF
3235 ; X86-SSE-NEXT:    cmovbel %ecx, %eax
3236 ; X86-SSE-NEXT:    # kill: def $ax killed $ax killed $eax
3237 ; X86-SSE-NEXT:    addl $8, %esp
3238 ; X86-SSE-NEXT:    retl
3240 ; X64-LABEL: test_unsigned_i13_f80:
3241 ; X64:       # %bb.0:
3242 ; X64-NEXT:    fldt {{[0-9]+}}(%rsp)
3243 ; X64-NEXT:    fnstcw -{{[0-9]+}}(%rsp)
3244 ; X64-NEXT:    movzwl -{{[0-9]+}}(%rsp), %eax
3245 ; X64-NEXT:    orl $3072, %eax # imm = 0xC00
3246 ; X64-NEXT:    movw %ax, -{{[0-9]+}}(%rsp)
3247 ; X64-NEXT:    fldcw -{{[0-9]+}}(%rsp)
3248 ; X64-NEXT:    fistl -{{[0-9]+}}(%rsp)
3249 ; X64-NEXT:    fldcw -{{[0-9]+}}(%rsp)
3250 ; X64-NEXT:    xorl %ecx, %ecx
3251 ; X64-NEXT:    fldz
3252 ; X64-NEXT:    fxch %st(1)
3253 ; X64-NEXT:    fucomi %st(1), %st
3254 ; X64-NEXT:    fstp %st(1)
3255 ; X64-NEXT:    jb .LBB32_2
3256 ; X64-NEXT:  # %bb.1:
3257 ; X64-NEXT:    movl -{{[0-9]+}}(%rsp), %ecx
3258 ; X64-NEXT:  .LBB32_2:
3259 ; X64-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}(%rip)
3260 ; X64-NEXT:    fxch %st(1)
3261 ; X64-NEXT:    fucompi %st(1), %st
3262 ; X64-NEXT:    fstp %st(0)
3263 ; X64-NEXT:    movl $8191, %eax # imm = 0x1FFF
3264 ; X64-NEXT:    cmovbel %ecx, %eax
3265 ; X64-NEXT:    # kill: def $ax killed $ax killed $eax
3266 ; X64-NEXT:    retq
3267     %x = call i13 @llvm.fptoui.sat.i13.f80(x86_fp80 %f)
3268     ret i13 %x
3271 define i16 @test_unsigned_i16_f80(x86_fp80 %f) nounwind {
3272 ; X86-X87-LABEL: test_unsigned_i16_f80:
3273 ; X86-X87:       # %bb.0:
3274 ; X86-X87-NEXT:    subl $8, %esp
3275 ; X86-X87-NEXT:    fldt {{[0-9]+}}(%esp)
3276 ; X86-X87-NEXT:    fnstcw (%esp)
3277 ; X86-X87-NEXT:    movzwl (%esp), %eax
3278 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
3279 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
3280 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
3281 ; X86-X87-NEXT:    fistl {{[0-9]+}}(%esp)
3282 ; X86-X87-NEXT:    fldcw (%esp)
3283 ; X86-X87-NEXT:    fldz
3284 ; X86-X87-NEXT:    fxch %st(1)
3285 ; X86-X87-NEXT:    fucom %st(1)
3286 ; X86-X87-NEXT:    fstp %st(1)
3287 ; X86-X87-NEXT:    fnstsw %ax
3288 ; X86-X87-NEXT:    xorl %ecx, %ecx
3289 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
3290 ; X86-X87-NEXT:    sahf
3291 ; X86-X87-NEXT:    jb .LBB33_2
3292 ; X86-X87-NEXT:  # %bb.1:
3293 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
3294 ; X86-X87-NEXT:  .LBB33_2:
3295 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
3296 ; X86-X87-NEXT:    fxch %st(1)
3297 ; X86-X87-NEXT:    fucompp
3298 ; X86-X87-NEXT:    fnstsw %ax
3299 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
3300 ; X86-X87-NEXT:    sahf
3301 ; X86-X87-NEXT:    movl $65535, %eax # imm = 0xFFFF
3302 ; X86-X87-NEXT:    ja .LBB33_4
3303 ; X86-X87-NEXT:  # %bb.3:
3304 ; X86-X87-NEXT:    movl %ecx, %eax
3305 ; X86-X87-NEXT:  .LBB33_4:
3306 ; X86-X87-NEXT:    # kill: def $ax killed $ax killed $eax
3307 ; X86-X87-NEXT:    addl $8, %esp
3308 ; X86-X87-NEXT:    retl
3310 ; X86-SSE-LABEL: test_unsigned_i16_f80:
3311 ; X86-SSE:       # %bb.0:
3312 ; X86-SSE-NEXT:    subl $8, %esp
3313 ; X86-SSE-NEXT:    fldt {{[0-9]+}}(%esp)
3314 ; X86-SSE-NEXT:    fnstcw (%esp)
3315 ; X86-SSE-NEXT:    movzwl (%esp), %eax
3316 ; X86-SSE-NEXT:    orl $3072, %eax # imm = 0xC00
3317 ; X86-SSE-NEXT:    movw %ax, {{[0-9]+}}(%esp)
3318 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
3319 ; X86-SSE-NEXT:    fistl {{[0-9]+}}(%esp)
3320 ; X86-SSE-NEXT:    fldcw (%esp)
3321 ; X86-SSE-NEXT:    xorl %ecx, %ecx
3322 ; X86-SSE-NEXT:    fldz
3323 ; X86-SSE-NEXT:    fxch %st(1)
3324 ; X86-SSE-NEXT:    fucomi %st(1), %st
3325 ; X86-SSE-NEXT:    fstp %st(1)
3326 ; X86-SSE-NEXT:    jb .LBB33_2
3327 ; X86-SSE-NEXT:  # %bb.1:
3328 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %ecx
3329 ; X86-SSE-NEXT:  .LBB33_2:
3330 ; X86-SSE-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
3331 ; X86-SSE-NEXT:    fxch %st(1)
3332 ; X86-SSE-NEXT:    fucompi %st(1), %st
3333 ; X86-SSE-NEXT:    fstp %st(0)
3334 ; X86-SSE-NEXT:    movl $65535, %eax # imm = 0xFFFF
3335 ; X86-SSE-NEXT:    cmovbel %ecx, %eax
3336 ; X86-SSE-NEXT:    # kill: def $ax killed $ax killed $eax
3337 ; X86-SSE-NEXT:    addl $8, %esp
3338 ; X86-SSE-NEXT:    retl
3340 ; X64-LABEL: test_unsigned_i16_f80:
3341 ; X64:       # %bb.0:
3342 ; X64-NEXT:    fldt {{[0-9]+}}(%rsp)
3343 ; X64-NEXT:    fnstcw -{{[0-9]+}}(%rsp)
3344 ; X64-NEXT:    movzwl -{{[0-9]+}}(%rsp), %eax
3345 ; X64-NEXT:    orl $3072, %eax # imm = 0xC00
3346 ; X64-NEXT:    movw %ax, -{{[0-9]+}}(%rsp)
3347 ; X64-NEXT:    fldcw -{{[0-9]+}}(%rsp)
3348 ; X64-NEXT:    fistl -{{[0-9]+}}(%rsp)
3349 ; X64-NEXT:    fldcw -{{[0-9]+}}(%rsp)
3350 ; X64-NEXT:    xorl %ecx, %ecx
3351 ; X64-NEXT:    fldz
3352 ; X64-NEXT:    fxch %st(1)
3353 ; X64-NEXT:    fucomi %st(1), %st
3354 ; X64-NEXT:    fstp %st(1)
3355 ; X64-NEXT:    jb .LBB33_2
3356 ; X64-NEXT:  # %bb.1:
3357 ; X64-NEXT:    movl -{{[0-9]+}}(%rsp), %ecx
3358 ; X64-NEXT:  .LBB33_2:
3359 ; X64-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}(%rip)
3360 ; X64-NEXT:    fxch %st(1)
3361 ; X64-NEXT:    fucompi %st(1), %st
3362 ; X64-NEXT:    fstp %st(0)
3363 ; X64-NEXT:    movl $65535, %eax # imm = 0xFFFF
3364 ; X64-NEXT:    cmovbel %ecx, %eax
3365 ; X64-NEXT:    # kill: def $ax killed $ax killed $eax
3366 ; X64-NEXT:    retq
3367     %x = call i16 @llvm.fptoui.sat.i16.f80(x86_fp80 %f)
3368     ret i16 %x
3371 define i19 @test_unsigned_i19_f80(x86_fp80 %f) nounwind {
3372 ; X86-X87-LABEL: test_unsigned_i19_f80:
3373 ; X86-X87:       # %bb.0:
3374 ; X86-X87-NEXT:    subl $20, %esp
3375 ; X86-X87-NEXT:    fldt {{[0-9]+}}(%esp)
3376 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
3377 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
3378 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
3379 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
3380 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
3381 ; X86-X87-NEXT:    fld %st(0)
3382 ; X86-X87-NEXT:    fistpll {{[0-9]+}}(%esp)
3383 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
3384 ; X86-X87-NEXT:    fldz
3385 ; X86-X87-NEXT:    fxch %st(1)
3386 ; X86-X87-NEXT:    fucom %st(1)
3387 ; X86-X87-NEXT:    fstp %st(1)
3388 ; X86-X87-NEXT:    fnstsw %ax
3389 ; X86-X87-NEXT:    xorl %ecx, %ecx
3390 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
3391 ; X86-X87-NEXT:    sahf
3392 ; X86-X87-NEXT:    jb .LBB34_2
3393 ; X86-X87-NEXT:  # %bb.1:
3394 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
3395 ; X86-X87-NEXT:  .LBB34_2:
3396 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
3397 ; X86-X87-NEXT:    fxch %st(1)
3398 ; X86-X87-NEXT:    fucompp
3399 ; X86-X87-NEXT:    fnstsw %ax
3400 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
3401 ; X86-X87-NEXT:    sahf
3402 ; X86-X87-NEXT:    movl $524287, %eax # imm = 0x7FFFF
3403 ; X86-X87-NEXT:    ja .LBB34_4
3404 ; X86-X87-NEXT:  # %bb.3:
3405 ; X86-X87-NEXT:    movl %ecx, %eax
3406 ; X86-X87-NEXT:  .LBB34_4:
3407 ; X86-X87-NEXT:    addl $20, %esp
3408 ; X86-X87-NEXT:    retl
3410 ; X86-SSE-LABEL: test_unsigned_i19_f80:
3411 ; X86-SSE:       # %bb.0:
3412 ; X86-SSE-NEXT:    subl $20, %esp
3413 ; X86-SSE-NEXT:    fldt {{[0-9]+}}(%esp)
3414 ; X86-SSE-NEXT:    fnstcw {{[0-9]+}}(%esp)
3415 ; X86-SSE-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
3416 ; X86-SSE-NEXT:    orl $3072, %eax # imm = 0xC00
3417 ; X86-SSE-NEXT:    movw %ax, {{[0-9]+}}(%esp)
3418 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
3419 ; X86-SSE-NEXT:    fld %st(0)
3420 ; X86-SSE-NEXT:    fistpll {{[0-9]+}}(%esp)
3421 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
3422 ; X86-SSE-NEXT:    xorl %ecx, %ecx
3423 ; X86-SSE-NEXT:    fldz
3424 ; X86-SSE-NEXT:    fxch %st(1)
3425 ; X86-SSE-NEXT:    fucomi %st(1), %st
3426 ; X86-SSE-NEXT:    fstp %st(1)
3427 ; X86-SSE-NEXT:    jb .LBB34_2
3428 ; X86-SSE-NEXT:  # %bb.1:
3429 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %ecx
3430 ; X86-SSE-NEXT:  .LBB34_2:
3431 ; X86-SSE-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
3432 ; X86-SSE-NEXT:    fxch %st(1)
3433 ; X86-SSE-NEXT:    fucompi %st(1), %st
3434 ; X86-SSE-NEXT:    fstp %st(0)
3435 ; X86-SSE-NEXT:    movl $524287, %eax # imm = 0x7FFFF
3436 ; X86-SSE-NEXT:    cmovbel %ecx, %eax
3437 ; X86-SSE-NEXT:    addl $20, %esp
3438 ; X86-SSE-NEXT:    retl
3440 ; X64-LABEL: test_unsigned_i19_f80:
3441 ; X64:       # %bb.0:
3442 ; X64-NEXT:    fldt {{[0-9]+}}(%rsp)
3443 ; X64-NEXT:    fnstcw -{{[0-9]+}}(%rsp)
3444 ; X64-NEXT:    movzwl -{{[0-9]+}}(%rsp), %eax
3445 ; X64-NEXT:    orl $3072, %eax # imm = 0xC00
3446 ; X64-NEXT:    movw %ax, -{{[0-9]+}}(%rsp)
3447 ; X64-NEXT:    fldcw -{{[0-9]+}}(%rsp)
3448 ; X64-NEXT:    fld %st(0)
3449 ; X64-NEXT:    fistpll -{{[0-9]+}}(%rsp)
3450 ; X64-NEXT:    fldcw -{{[0-9]+}}(%rsp)
3451 ; X64-NEXT:    xorl %ecx, %ecx
3452 ; X64-NEXT:    fldz
3453 ; X64-NEXT:    fxch %st(1)
3454 ; X64-NEXT:    fucomi %st(1), %st
3455 ; X64-NEXT:    fstp %st(1)
3456 ; X64-NEXT:    jb .LBB34_2
3457 ; X64-NEXT:  # %bb.1:
3458 ; X64-NEXT:    movl -{{[0-9]+}}(%rsp), %ecx
3459 ; X64-NEXT:  .LBB34_2:
3460 ; X64-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}(%rip)
3461 ; X64-NEXT:    fxch %st(1)
3462 ; X64-NEXT:    fucompi %st(1), %st
3463 ; X64-NEXT:    fstp %st(0)
3464 ; X64-NEXT:    movl $524287, %eax # imm = 0x7FFFF
3465 ; X64-NEXT:    cmovbel %ecx, %eax
3466 ; X64-NEXT:    retq
3467     %x = call i19 @llvm.fptoui.sat.i19.f80(x86_fp80 %f)
3468     ret i19 %x
3471 define i32 @test_unsigned_i32_f80(x86_fp80 %f) nounwind {
3472 ; X86-X87-LABEL: test_unsigned_i32_f80:
3473 ; X86-X87:       # %bb.0:
3474 ; X86-X87-NEXT:    subl $20, %esp
3475 ; X86-X87-NEXT:    fldt {{[0-9]+}}(%esp)
3476 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
3477 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
3478 ; X86-X87-NEXT:    orl $3072, %eax # imm = 0xC00
3479 ; X86-X87-NEXT:    movw %ax, {{[0-9]+}}(%esp)
3480 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
3481 ; X86-X87-NEXT:    fld %st(0)
3482 ; X86-X87-NEXT:    fistpll {{[0-9]+}}(%esp)
3483 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
3484 ; X86-X87-NEXT:    fldz
3485 ; X86-X87-NEXT:    fxch %st(1)
3486 ; X86-X87-NEXT:    fucom %st(1)
3487 ; X86-X87-NEXT:    fstp %st(1)
3488 ; X86-X87-NEXT:    fnstsw %ax
3489 ; X86-X87-NEXT:    xorl %ecx, %ecx
3490 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
3491 ; X86-X87-NEXT:    sahf
3492 ; X86-X87-NEXT:    jb .LBB35_2
3493 ; X86-X87-NEXT:  # %bb.1:
3494 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
3495 ; X86-X87-NEXT:  .LBB35_2:
3496 ; X86-X87-NEXT:    fldl {{\.?LCPI[0-9]+_[0-9]+}}
3497 ; X86-X87-NEXT:    fxch %st(1)
3498 ; X86-X87-NEXT:    fucompp
3499 ; X86-X87-NEXT:    fnstsw %ax
3500 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
3501 ; X86-X87-NEXT:    sahf
3502 ; X86-X87-NEXT:    movl $-1, %eax
3503 ; X86-X87-NEXT:    ja .LBB35_4
3504 ; X86-X87-NEXT:  # %bb.3:
3505 ; X86-X87-NEXT:    movl %ecx, %eax
3506 ; X86-X87-NEXT:  .LBB35_4:
3507 ; X86-X87-NEXT:    addl $20, %esp
3508 ; X86-X87-NEXT:    retl
3510 ; X86-SSE-LABEL: test_unsigned_i32_f80:
3511 ; X86-SSE:       # %bb.0:
3512 ; X86-SSE-NEXT:    subl $20, %esp
3513 ; X86-SSE-NEXT:    fldt {{[0-9]+}}(%esp)
3514 ; X86-SSE-NEXT:    fnstcw {{[0-9]+}}(%esp)
3515 ; X86-SSE-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
3516 ; X86-SSE-NEXT:    orl $3072, %eax # imm = 0xC00
3517 ; X86-SSE-NEXT:    movw %ax, {{[0-9]+}}(%esp)
3518 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
3519 ; X86-SSE-NEXT:    fld %st(0)
3520 ; X86-SSE-NEXT:    fistpll {{[0-9]+}}(%esp)
3521 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
3522 ; X86-SSE-NEXT:    xorl %ecx, %ecx
3523 ; X86-SSE-NEXT:    fldz
3524 ; X86-SSE-NEXT:    fxch %st(1)
3525 ; X86-SSE-NEXT:    fucomi %st(1), %st
3526 ; X86-SSE-NEXT:    fstp %st(1)
3527 ; X86-SSE-NEXT:    jb .LBB35_2
3528 ; X86-SSE-NEXT:  # %bb.1:
3529 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %ecx
3530 ; X86-SSE-NEXT:  .LBB35_2:
3531 ; X86-SSE-NEXT:    fldl {{\.?LCPI[0-9]+_[0-9]+}}
3532 ; X86-SSE-NEXT:    fxch %st(1)
3533 ; X86-SSE-NEXT:    fucompi %st(1), %st
3534 ; X86-SSE-NEXT:    fstp %st(0)
3535 ; X86-SSE-NEXT:    movl $-1, %eax
3536 ; X86-SSE-NEXT:    cmovbel %ecx, %eax
3537 ; X86-SSE-NEXT:    addl $20, %esp
3538 ; X86-SSE-NEXT:    retl
3540 ; X64-LABEL: test_unsigned_i32_f80:
3541 ; X64:       # %bb.0:
3542 ; X64-NEXT:    fldt {{[0-9]+}}(%rsp)
3543 ; X64-NEXT:    fnstcw -{{[0-9]+}}(%rsp)
3544 ; X64-NEXT:    movzwl -{{[0-9]+}}(%rsp), %eax
3545 ; X64-NEXT:    orl $3072, %eax # imm = 0xC00
3546 ; X64-NEXT:    movw %ax, -{{[0-9]+}}(%rsp)
3547 ; X64-NEXT:    fldcw -{{[0-9]+}}(%rsp)
3548 ; X64-NEXT:    fld %st(0)
3549 ; X64-NEXT:    fistpll -{{[0-9]+}}(%rsp)
3550 ; X64-NEXT:    fldcw -{{[0-9]+}}(%rsp)
3551 ; X64-NEXT:    xorl %ecx, %ecx
3552 ; X64-NEXT:    fldz
3553 ; X64-NEXT:    fxch %st(1)
3554 ; X64-NEXT:    fucomi %st(1), %st
3555 ; X64-NEXT:    fstp %st(1)
3556 ; X64-NEXT:    jb .LBB35_2
3557 ; X64-NEXT:  # %bb.1:
3558 ; X64-NEXT:    movl -{{[0-9]+}}(%rsp), %ecx
3559 ; X64-NEXT:  .LBB35_2:
3560 ; X64-NEXT:    fldl {{\.?LCPI[0-9]+_[0-9]+}}(%rip)
3561 ; X64-NEXT:    fxch %st(1)
3562 ; X64-NEXT:    fucompi %st(1), %st
3563 ; X64-NEXT:    fstp %st(0)
3564 ; X64-NEXT:    movl $-1, %eax
3565 ; X64-NEXT:    cmovbel %ecx, %eax
3566 ; X64-NEXT:    retq
3567     %x = call i32 @llvm.fptoui.sat.i32.f80(x86_fp80 %f)
3568     ret i32 %x
3571 define i50 @test_unsigned_i50_f80(x86_fp80 %f) nounwind {
3572 ; X86-X87-LABEL: test_unsigned_i50_f80:
3573 ; X86-X87:       # %bb.0:
3574 ; X86-X87-NEXT:    pushl %esi
3575 ; X86-X87-NEXT:    subl $16, %esp
3576 ; X86-X87-NEXT:    fldt {{[0-9]+}}(%esp)
3577 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
3578 ; X86-X87-NEXT:    fucom %st(1)
3579 ; X86-X87-NEXT:    fnstsw %ax
3580 ; X86-X87-NEXT:    xorl %ecx, %ecx
3581 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
3582 ; X86-X87-NEXT:    sahf
3583 ; X86-X87-NEXT:    setbe %al
3584 ; X86-X87-NEXT:    fldz
3585 ; X86-X87-NEXT:    jbe .LBB36_2
3586 ; X86-X87-NEXT:  # %bb.1:
3587 ; X86-X87-NEXT:    fstp %st(1)
3588 ; X86-X87-NEXT:    fld %st(0)
3589 ; X86-X87-NEXT:    fxch %st(1)
3590 ; X86-X87-NEXT:  .LBB36_2:
3591 ; X86-X87-NEXT:    fxch %st(1)
3592 ; X86-X87-NEXT:    fsubr %st(2), %st
3593 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
3594 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %edx
3595 ; X86-X87-NEXT:    orl $3072, %edx # imm = 0xC00
3596 ; X86-X87-NEXT:    movw %dx, {{[0-9]+}}(%esp)
3597 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
3598 ; X86-X87-NEXT:    fistpll {{[0-9]+}}(%esp)
3599 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
3600 ; X86-X87-NEXT:    movb %al, %cl
3601 ; X86-X87-NEXT:    shll $31, %ecx
3602 ; X86-X87-NEXT:    xorl {{[0-9]+}}(%esp), %ecx
3603 ; X86-X87-NEXT:    fxch %st(1)
3604 ; X86-X87-NEXT:    fucom %st(1)
3605 ; X86-X87-NEXT:    fstp %st(1)
3606 ; X86-X87-NEXT:    fnstsw %ax
3607 ; X86-X87-NEXT:    xorl %edx, %edx
3608 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
3609 ; X86-X87-NEXT:    sahf
3610 ; X86-X87-NEXT:    movl $0, %esi
3611 ; X86-X87-NEXT:    jb .LBB36_4
3612 ; X86-X87-NEXT:  # %bb.3:
3613 ; X86-X87-NEXT:    movl %ecx, %esi
3614 ; X86-X87-NEXT:  .LBB36_4:
3615 ; X86-X87-NEXT:    jb .LBB36_6
3616 ; X86-X87-NEXT:  # %bb.5:
3617 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %edx
3618 ; X86-X87-NEXT:  .LBB36_6:
3619 ; X86-X87-NEXT:    fldl {{\.?LCPI[0-9]+_[0-9]+}}
3620 ; X86-X87-NEXT:    fxch %st(1)
3621 ; X86-X87-NEXT:    fucompp
3622 ; X86-X87-NEXT:    fnstsw %ax
3623 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
3624 ; X86-X87-NEXT:    sahf
3625 ; X86-X87-NEXT:    movl $-1, %eax
3626 ; X86-X87-NEXT:    ja .LBB36_8
3627 ; X86-X87-NEXT:  # %bb.7:
3628 ; X86-X87-NEXT:    movl %edx, %eax
3629 ; X86-X87-NEXT:  .LBB36_8:
3630 ; X86-X87-NEXT:    movl $262143, %edx # imm = 0x3FFFF
3631 ; X86-X87-NEXT:    ja .LBB36_10
3632 ; X86-X87-NEXT:  # %bb.9:
3633 ; X86-X87-NEXT:    movl %esi, %edx
3634 ; X86-X87-NEXT:  .LBB36_10:
3635 ; X86-X87-NEXT:    addl $16, %esp
3636 ; X86-X87-NEXT:    popl %esi
3637 ; X86-X87-NEXT:    retl
3639 ; X86-SSE-LABEL: test_unsigned_i50_f80:
3640 ; X86-SSE:       # %bb.0:
3641 ; X86-SSE-NEXT:    pushl %esi
3642 ; X86-SSE-NEXT:    subl $16, %esp
3643 ; X86-SSE-NEXT:    fldt {{[0-9]+}}(%esp)
3644 ; X86-SSE-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
3645 ; X86-SSE-NEXT:    xorl %eax, %eax
3646 ; X86-SSE-NEXT:    fucomi %st(1), %st
3647 ; X86-SSE-NEXT:    setbe %cl
3648 ; X86-SSE-NEXT:    fldz
3649 ; X86-SSE-NEXT:    fld %st(0)
3650 ; X86-SSE-NEXT:    fcmovbe %st(2), %st
3651 ; X86-SSE-NEXT:    fstp %st(2)
3652 ; X86-SSE-NEXT:    fxch %st(1)
3653 ; X86-SSE-NEXT:    fsubr %st(2), %st
3654 ; X86-SSE-NEXT:    fnstcw {{[0-9]+}}(%esp)
3655 ; X86-SSE-NEXT:    movzwl {{[0-9]+}}(%esp), %edx
3656 ; X86-SSE-NEXT:    orl $3072, %edx # imm = 0xC00
3657 ; X86-SSE-NEXT:    movw %dx, {{[0-9]+}}(%esp)
3658 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
3659 ; X86-SSE-NEXT:    fistpll {{[0-9]+}}(%esp)
3660 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
3661 ; X86-SSE-NEXT:    xorl %esi, %esi
3662 ; X86-SSE-NEXT:    fxch %st(1)
3663 ; X86-SSE-NEXT:    fucomi %st(1), %st
3664 ; X86-SSE-NEXT:    fstp %st(1)
3665 ; X86-SSE-NEXT:    movl $0, %edx
3666 ; X86-SSE-NEXT:    jb .LBB36_2
3667 ; X86-SSE-NEXT:  # %bb.1:
3668 ; X86-SSE-NEXT:    movb %cl, %al
3669 ; X86-SSE-NEXT:    shll $31, %eax
3670 ; X86-SSE-NEXT:    xorl {{[0-9]+}}(%esp), %eax
3671 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %edx
3672 ; X86-SSE-NEXT:    movl %eax, %esi
3673 ; X86-SSE-NEXT:  .LBB36_2:
3674 ; X86-SSE-NEXT:    fldl {{\.?LCPI[0-9]+_[0-9]+}}
3675 ; X86-SSE-NEXT:    fxch %st(1)
3676 ; X86-SSE-NEXT:    fucompi %st(1), %st
3677 ; X86-SSE-NEXT:    fstp %st(0)
3678 ; X86-SSE-NEXT:    movl $-1, %eax
3679 ; X86-SSE-NEXT:    cmovbel %edx, %eax
3680 ; X86-SSE-NEXT:    movl $262143, %edx # imm = 0x3FFFF
3681 ; X86-SSE-NEXT:    cmovbel %esi, %edx
3682 ; X86-SSE-NEXT:    addl $16, %esp
3683 ; X86-SSE-NEXT:    popl %esi
3684 ; X86-SSE-NEXT:    retl
3686 ; X64-LABEL: test_unsigned_i50_f80:
3687 ; X64:       # %bb.0:
3688 ; X64-NEXT:    fldt {{[0-9]+}}(%rsp)
3689 ; X64-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}(%rip)
3690 ; X64-NEXT:    xorl %eax, %eax
3691 ; X64-NEXT:    fucomi %st(1), %st
3692 ; X64-NEXT:    setbe %al
3693 ; X64-NEXT:    fldz
3694 ; X64-NEXT:    fld %st(0)
3695 ; X64-NEXT:    fcmovbe %st(2), %st
3696 ; X64-NEXT:    fstp %st(2)
3697 ; X64-NEXT:    fxch %st(1)
3698 ; X64-NEXT:    fsubr %st(2), %st
3699 ; X64-NEXT:    fnstcw -{{[0-9]+}}(%rsp)
3700 ; X64-NEXT:    movzwl -{{[0-9]+}}(%rsp), %ecx
3701 ; X64-NEXT:    orl $3072, %ecx # imm = 0xC00
3702 ; X64-NEXT:    movw %cx, -{{[0-9]+}}(%rsp)
3703 ; X64-NEXT:    fldcw -{{[0-9]+}}(%rsp)
3704 ; X64-NEXT:    fistpll -{{[0-9]+}}(%rsp)
3705 ; X64-NEXT:    fldcw -{{[0-9]+}}(%rsp)
3706 ; X64-NEXT:    shlq $63, %rax
3707 ; X64-NEXT:    xorq -{{[0-9]+}}(%rsp), %rax
3708 ; X64-NEXT:    xorl %ecx, %ecx
3709 ; X64-NEXT:    fxch %st(1)
3710 ; X64-NEXT:    fucomi %st(1), %st
3711 ; X64-NEXT:    fstp %st(1)
3712 ; X64-NEXT:    cmovaeq %rax, %rcx
3713 ; X64-NEXT:    fldl {{\.?LCPI[0-9]+_[0-9]+}}(%rip)
3714 ; X64-NEXT:    fxch %st(1)
3715 ; X64-NEXT:    fucompi %st(1), %st
3716 ; X64-NEXT:    fstp %st(0)
3717 ; X64-NEXT:    movabsq $1125899906842623, %rax # imm = 0x3FFFFFFFFFFFF
3718 ; X64-NEXT:    cmovbeq %rcx, %rax
3719 ; X64-NEXT:    retq
3720     %x = call i50 @llvm.fptoui.sat.i50.f80(x86_fp80 %f)
3721     ret i50 %x
3724 define i64 @test_unsigned_i64_f80(x86_fp80 %f) nounwind {
3725 ; X86-X87-LABEL: test_unsigned_i64_f80:
3726 ; X86-X87:       # %bb.0:
3727 ; X86-X87-NEXT:    pushl %edi
3728 ; X86-X87-NEXT:    pushl %esi
3729 ; X86-X87-NEXT:    subl $20, %esp
3730 ; X86-X87-NEXT:    fldt {{[0-9]+}}(%esp)
3731 ; X86-X87-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
3732 ; X86-X87-NEXT:    fucom %st(1)
3733 ; X86-X87-NEXT:    fnstsw %ax
3734 ; X86-X87-NEXT:    xorl %ecx, %ecx
3735 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
3736 ; X86-X87-NEXT:    sahf
3737 ; X86-X87-NEXT:    setbe %al
3738 ; X86-X87-NEXT:    fldz
3739 ; X86-X87-NEXT:    jbe .LBB37_2
3740 ; X86-X87-NEXT:  # %bb.1:
3741 ; X86-X87-NEXT:    fstp %st(1)
3742 ; X86-X87-NEXT:    fld %st(0)
3743 ; X86-X87-NEXT:    fxch %st(1)
3744 ; X86-X87-NEXT:  .LBB37_2:
3745 ; X86-X87-NEXT:    fxch %st(1)
3746 ; X86-X87-NEXT:    fsubr %st(2), %st
3747 ; X86-X87-NEXT:    fnstcw {{[0-9]+}}(%esp)
3748 ; X86-X87-NEXT:    movzwl {{[0-9]+}}(%esp), %edx
3749 ; X86-X87-NEXT:    orl $3072, %edx # imm = 0xC00
3750 ; X86-X87-NEXT:    movw %dx, {{[0-9]+}}(%esp)
3751 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
3752 ; X86-X87-NEXT:    fistpll {{[0-9]+}}(%esp)
3753 ; X86-X87-NEXT:    fldcw {{[0-9]+}}(%esp)
3754 ; X86-X87-NEXT:    movb %al, %cl
3755 ; X86-X87-NEXT:    shll $31, %ecx
3756 ; X86-X87-NEXT:    xorl {{[0-9]+}}(%esp), %ecx
3757 ; X86-X87-NEXT:    fxch %st(1)
3758 ; X86-X87-NEXT:    fucom %st(1)
3759 ; X86-X87-NEXT:    fstp %st(1)
3760 ; X86-X87-NEXT:    fnstsw %ax
3761 ; X86-X87-NEXT:    xorl %esi, %esi
3762 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
3763 ; X86-X87-NEXT:    sahf
3764 ; X86-X87-NEXT:    movl $0, %edi
3765 ; X86-X87-NEXT:    jb .LBB37_4
3766 ; X86-X87-NEXT:  # %bb.3:
3767 ; X86-X87-NEXT:    movl %ecx, %edi
3768 ; X86-X87-NEXT:  .LBB37_4:
3769 ; X86-X87-NEXT:    jb .LBB37_6
3770 ; X86-X87-NEXT:  # %bb.5:
3771 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %esi
3772 ; X86-X87-NEXT:  .LBB37_6:
3773 ; X86-X87-NEXT:    fldt {{\.?LCPI[0-9]+_[0-9]+}}
3774 ; X86-X87-NEXT:    fxch %st(1)
3775 ; X86-X87-NEXT:    fucompp
3776 ; X86-X87-NEXT:    fnstsw %ax
3777 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
3778 ; X86-X87-NEXT:    sahf
3779 ; X86-X87-NEXT:    movl $-1, %eax
3780 ; X86-X87-NEXT:    movl $-1, %edx
3781 ; X86-X87-NEXT:    ja .LBB37_8
3782 ; X86-X87-NEXT:  # %bb.7:
3783 ; X86-X87-NEXT:    movl %esi, %eax
3784 ; X86-X87-NEXT:    movl %edi, %edx
3785 ; X86-X87-NEXT:  .LBB37_8:
3786 ; X86-X87-NEXT:    addl $20, %esp
3787 ; X86-X87-NEXT:    popl %esi
3788 ; X86-X87-NEXT:    popl %edi
3789 ; X86-X87-NEXT:    retl
3791 ; X86-SSE-LABEL: test_unsigned_i64_f80:
3792 ; X86-SSE:       # %bb.0:
3793 ; X86-SSE-NEXT:    pushl %ebx
3794 ; X86-SSE-NEXT:    subl $16, %esp
3795 ; X86-SSE-NEXT:    fldt {{[0-9]+}}(%esp)
3796 ; X86-SSE-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}
3797 ; X86-SSE-NEXT:    xorl %ecx, %ecx
3798 ; X86-SSE-NEXT:    fucomi %st(1), %st
3799 ; X86-SSE-NEXT:    setbe %bl
3800 ; X86-SSE-NEXT:    fldz
3801 ; X86-SSE-NEXT:    fld %st(0)
3802 ; X86-SSE-NEXT:    fcmovbe %st(2), %st
3803 ; X86-SSE-NEXT:    fstp %st(2)
3804 ; X86-SSE-NEXT:    fxch %st(1)
3805 ; X86-SSE-NEXT:    fsubr %st(2), %st
3806 ; X86-SSE-NEXT:    fnstcw {{[0-9]+}}(%esp)
3807 ; X86-SSE-NEXT:    movzwl {{[0-9]+}}(%esp), %eax
3808 ; X86-SSE-NEXT:    orl $3072, %eax # imm = 0xC00
3809 ; X86-SSE-NEXT:    movw %ax, {{[0-9]+}}(%esp)
3810 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
3811 ; X86-SSE-NEXT:    fistpll {{[0-9]+}}(%esp)
3812 ; X86-SSE-NEXT:    fldcw {{[0-9]+}}(%esp)
3813 ; X86-SSE-NEXT:    xorl %edx, %edx
3814 ; X86-SSE-NEXT:    fxch %st(1)
3815 ; X86-SSE-NEXT:    fucomi %st(1), %st
3816 ; X86-SSE-NEXT:    fstp %st(1)
3817 ; X86-SSE-NEXT:    movl $0, %eax
3818 ; X86-SSE-NEXT:    jb .LBB37_2
3819 ; X86-SSE-NEXT:  # %bb.1:
3820 ; X86-SSE-NEXT:    movb %bl, %cl
3821 ; X86-SSE-NEXT:    shll $31, %ecx
3822 ; X86-SSE-NEXT:    xorl {{[0-9]+}}(%esp), %ecx
3823 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %eax
3824 ; X86-SSE-NEXT:    movl %ecx, %edx
3825 ; X86-SSE-NEXT:  .LBB37_2:
3826 ; X86-SSE-NEXT:    fldt {{\.?LCPI[0-9]+_[0-9]+}}
3827 ; X86-SSE-NEXT:    fxch %st(1)
3828 ; X86-SSE-NEXT:    fucompi %st(1), %st
3829 ; X86-SSE-NEXT:    fstp %st(0)
3830 ; X86-SSE-NEXT:    movl $-1, %ecx
3831 ; X86-SSE-NEXT:    cmoval %ecx, %eax
3832 ; X86-SSE-NEXT:    cmoval %ecx, %edx
3833 ; X86-SSE-NEXT:    addl $16, %esp
3834 ; X86-SSE-NEXT:    popl %ebx
3835 ; X86-SSE-NEXT:    retl
3837 ; X64-LABEL: test_unsigned_i64_f80:
3838 ; X64:       # %bb.0:
3839 ; X64-NEXT:    fldt {{[0-9]+}}(%rsp)
3840 ; X64-NEXT:    flds {{\.?LCPI[0-9]+_[0-9]+}}(%rip)
3841 ; X64-NEXT:    xorl %eax, %eax
3842 ; X64-NEXT:    fucomi %st(1), %st
3843 ; X64-NEXT:    setbe %al
3844 ; X64-NEXT:    fldz
3845 ; X64-NEXT:    fld %st(0)
3846 ; X64-NEXT:    fcmovbe %st(2), %st
3847 ; X64-NEXT:    fstp %st(2)
3848 ; X64-NEXT:    fxch %st(1)
3849 ; X64-NEXT:    fsubr %st(2), %st
3850 ; X64-NEXT:    fnstcw -{{[0-9]+}}(%rsp)
3851 ; X64-NEXT:    movzwl -{{[0-9]+}}(%rsp), %ecx
3852 ; X64-NEXT:    orl $3072, %ecx # imm = 0xC00
3853 ; X64-NEXT:    movw %cx, -{{[0-9]+}}(%rsp)
3854 ; X64-NEXT:    fldcw -{{[0-9]+}}(%rsp)
3855 ; X64-NEXT:    fistpll -{{[0-9]+}}(%rsp)
3856 ; X64-NEXT:    fldcw -{{[0-9]+}}(%rsp)
3857 ; X64-NEXT:    shlq $63, %rax
3858 ; X64-NEXT:    xorq -{{[0-9]+}}(%rsp), %rax
3859 ; X64-NEXT:    xorl %ecx, %ecx
3860 ; X64-NEXT:    fxch %st(1)
3861 ; X64-NEXT:    fucomi %st(1), %st
3862 ; X64-NEXT:    fstp %st(1)
3863 ; X64-NEXT:    cmovaeq %rax, %rcx
3864 ; X64-NEXT:    fldt {{\.?LCPI[0-9]+_[0-9]+}}(%rip)
3865 ; X64-NEXT:    fxch %st(1)
3866 ; X64-NEXT:    fucompi %st(1), %st
3867 ; X64-NEXT:    fstp %st(0)
3868 ; X64-NEXT:    movq $-1, %rax
3869 ; X64-NEXT:    cmovbeq %rcx, %rax
3870 ; X64-NEXT:    retq
3871     %x = call i64 @llvm.fptoui.sat.i64.f80(x86_fp80 %f)
3872     ret i64 %x
3875 define i100 @test_unsigned_i100_f80(x86_fp80 %f) nounwind {
3876 ; X86-X87-LABEL: test_unsigned_i100_f80:
3877 ; X86-X87:       # %bb.0:
3878 ; X86-X87-NEXT:    pushl %ebp
3879 ; X86-X87-NEXT:    pushl %ebx
3880 ; X86-X87-NEXT:    pushl %edi
3881 ; X86-X87-NEXT:    pushl %esi
3882 ; X86-X87-NEXT:    subl $60, %esp
3883 ; X86-X87-NEXT:    fldt {{[0-9]+}}(%esp)
3884 ; X86-X87-NEXT:    fld %st(0)
3885 ; X86-X87-NEXT:    fstpt {{[0-9]+}}(%esp)
3886 ; X86-X87-NEXT:    leal {{[0-9]+}}(%esp), %eax
3887 ; X86-X87-NEXT:    movl %eax, (%esp)
3888 ; X86-X87-NEXT:    fldz
3889 ; X86-X87-NEXT:    fld %st(1)
3890 ; X86-X87-NEXT:    fstpt {{[-0-9]+}}(%e{{[sb]}}p) # 10-byte Folded Spill
3891 ; X86-X87-NEXT:    fxch %st(1)
3892 ; X86-X87-NEXT:    fucompp
3893 ; X86-X87-NEXT:    fnstsw %ax
3894 ; X86-X87-NEXT:    movl %eax, %ebx
3895 ; X86-X87-NEXT:    calll __fixunsxfti
3896 ; X86-X87-NEXT:    subl $4, %esp
3897 ; X86-X87-NEXT:    xorl %edi, %edi
3898 ; X86-X87-NEXT:    movb %bh, %ah
3899 ; X86-X87-NEXT:    sahf
3900 ; X86-X87-NEXT:    movl $0, %eax
3901 ; X86-X87-NEXT:    jb .LBB38_2
3902 ; X86-X87-NEXT:  # %bb.1:
3903 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %eax
3904 ; X86-X87-NEXT:  .LBB38_2:
3905 ; X86-X87-NEXT:    movl $0, %esi
3906 ; X86-X87-NEXT:    movl $0, %ebx
3907 ; X86-X87-NEXT:    jb .LBB38_4
3908 ; X86-X87-NEXT:  # %bb.3:
3909 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ebx
3910 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %esi
3911 ; X86-X87-NEXT:  .LBB38_4:
3912 ; X86-X87-NEXT:    jb .LBB38_6
3913 ; X86-X87-NEXT:  # %bb.5:
3914 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %edi
3915 ; X86-X87-NEXT:  .LBB38_6:
3916 ; X86-X87-NEXT:    movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill
3917 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
3918 ; X86-X87-NEXT:    fldt {{\.?LCPI[0-9]+_[0-9]+}}
3919 ; X86-X87-NEXT:    fldt {{[-0-9]+}}(%e{{[sb]}}p) # 10-byte Folded Reload
3920 ; X86-X87-NEXT:    fucompp
3921 ; X86-X87-NEXT:    fnstsw %ax
3922 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
3923 ; X86-X87-NEXT:    sahf
3924 ; X86-X87-NEXT:    movl $15, %eax
3925 ; X86-X87-NEXT:    ja .LBB38_8
3926 ; X86-X87-NEXT:  # %bb.7:
3927 ; X86-X87-NEXT:    movl %edi, %eax
3928 ; X86-X87-NEXT:  .LBB38_8:
3929 ; X86-X87-NEXT:    movl $-1, %edi
3930 ; X86-X87-NEXT:    movl $-1, %ebp
3931 ; X86-X87-NEXT:    movl $-1, %edx
3932 ; X86-X87-NEXT:    ja .LBB38_10
3933 ; X86-X87-NEXT:  # %bb.9:
3934 ; X86-X87-NEXT:    movl %ebx, %edi
3935 ; X86-X87-NEXT:    movl %esi, %ebp
3936 ; X86-X87-NEXT:    movl {{[-0-9]+}}(%e{{[sb]}}p), %edx # 4-byte Reload
3937 ; X86-X87-NEXT:  .LBB38_10:
3938 ; X86-X87-NEXT:    movl %edx, 8(%ecx)
3939 ; X86-X87-NEXT:    movl %ebp, 4(%ecx)
3940 ; X86-X87-NEXT:    movl %edi, (%ecx)
3941 ; X86-X87-NEXT:    andl $15, %eax
3942 ; X86-X87-NEXT:    movb %al, 12(%ecx)
3943 ; X86-X87-NEXT:    movl %ecx, %eax
3944 ; X86-X87-NEXT:    addl $60, %esp
3945 ; X86-X87-NEXT:    popl %esi
3946 ; X86-X87-NEXT:    popl %edi
3947 ; X86-X87-NEXT:    popl %ebx
3948 ; X86-X87-NEXT:    popl %ebp
3949 ; X86-X87-NEXT:    retl $4
3951 ; X86-SSE-LABEL: test_unsigned_i100_f80:
3952 ; X86-SSE:       # %bb.0:
3953 ; X86-SSE-NEXT:    pushl %ebx
3954 ; X86-SSE-NEXT:    pushl %edi
3955 ; X86-SSE-NEXT:    pushl %esi
3956 ; X86-SSE-NEXT:    subl $48, %esp
3957 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %esi
3958 ; X86-SSE-NEXT:    fldt {{[0-9]+}}(%esp)
3959 ; X86-SSE-NEXT:    fld %st(0)
3960 ; X86-SSE-NEXT:    fstpt {{[-0-9]+}}(%e{{[sb]}}p) # 10-byte Folded Spill
3961 ; X86-SSE-NEXT:    fstpt {{[0-9]+}}(%esp)
3962 ; X86-SSE-NEXT:    leal {{[0-9]+}}(%esp), %eax
3963 ; X86-SSE-NEXT:    movl %eax, (%esp)
3964 ; X86-SSE-NEXT:    calll __fixunsxfti
3965 ; X86-SSE-NEXT:    subl $4, %esp
3966 ; X86-SSE-NEXT:    fldt {{[-0-9]+}}(%e{{[sb]}}p) # 10-byte Folded Reload
3967 ; X86-SSE-NEXT:    xorl %eax, %eax
3968 ; X86-SSE-NEXT:    fldz
3969 ; X86-SSE-NEXT:    fxch %st(1)
3970 ; X86-SSE-NEXT:    fucomi %st(1), %st
3971 ; X86-SSE-NEXT:    fstp %st(1)
3972 ; X86-SSE-NEXT:    movl $0, %ecx
3973 ; X86-SSE-NEXT:    movl $0, %edx
3974 ; X86-SSE-NEXT:    movl $0, %edi
3975 ; X86-SSE-NEXT:    jb .LBB38_2
3976 ; X86-SSE-NEXT:  # %bb.1:
3977 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %eax
3978 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %ecx
3979 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %edx
3980 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %edi
3981 ; X86-SSE-NEXT:  .LBB38_2:
3982 ; X86-SSE-NEXT:    fldt {{\.?LCPI[0-9]+_[0-9]+}}
3983 ; X86-SSE-NEXT:    fxch %st(1)
3984 ; X86-SSE-NEXT:    fucompi %st(1), %st
3985 ; X86-SSE-NEXT:    fstp %st(0)
3986 ; X86-SSE-NEXT:    movl $15, %ebx
3987 ; X86-SSE-NEXT:    cmovbel %edi, %ebx
3988 ; X86-SSE-NEXT:    movl $-1, %edi
3989 ; X86-SSE-NEXT:    cmoval %edi, %edx
3990 ; X86-SSE-NEXT:    cmoval %edi, %ecx
3991 ; X86-SSE-NEXT:    cmoval %edi, %eax
3992 ; X86-SSE-NEXT:    movl %eax, 8(%esi)
3993 ; X86-SSE-NEXT:    movl %ecx, 4(%esi)
3994 ; X86-SSE-NEXT:    movl %edx, (%esi)
3995 ; X86-SSE-NEXT:    andl $15, %ebx
3996 ; X86-SSE-NEXT:    movb %bl, 12(%esi)
3997 ; X86-SSE-NEXT:    movl %esi, %eax
3998 ; X86-SSE-NEXT:    addl $48, %esp
3999 ; X86-SSE-NEXT:    popl %esi
4000 ; X86-SSE-NEXT:    popl %edi
4001 ; X86-SSE-NEXT:    popl %ebx
4002 ; X86-SSE-NEXT:    retl $4
4004 ; X64-LABEL: test_unsigned_i100_f80:
4005 ; X64:       # %bb.0:
4006 ; X64-NEXT:    subq $40, %rsp
4007 ; X64-NEXT:    fldt {{[0-9]+}}(%rsp)
4008 ; X64-NEXT:    fld %st(0)
4009 ; X64-NEXT:    fstpt {{[-0-9]+}}(%r{{[sb]}}p) # 10-byte Folded Spill
4010 ; X64-NEXT:    fstpt (%rsp)
4011 ; X64-NEXT:    callq __fixunsxfti@PLT
4012 ; X64-NEXT:    xorl %ecx, %ecx
4013 ; X64-NEXT:    fldz
4014 ; X64-NEXT:    fldt {{[-0-9]+}}(%r{{[sb]}}p) # 10-byte Folded Reload
4015 ; X64-NEXT:    fucomi %st(1), %st
4016 ; X64-NEXT:    fstp %st(1)
4017 ; X64-NEXT:    cmovbq %rcx, %rdx
4018 ; X64-NEXT:    cmovbq %rcx, %rax
4019 ; X64-NEXT:    fldt {{\.?LCPI[0-9]+_[0-9]+}}(%rip)
4020 ; X64-NEXT:    fxch %st(1)
4021 ; X64-NEXT:    fucompi %st(1), %st
4022 ; X64-NEXT:    fstp %st(0)
4023 ; X64-NEXT:    movq $-1, %rcx
4024 ; X64-NEXT:    cmovaq %rcx, %rax
4025 ; X64-NEXT:    movabsq $68719476735, %rcx # imm = 0xFFFFFFFFF
4026 ; X64-NEXT:    cmovaq %rcx, %rdx
4027 ; X64-NEXT:    addq $40, %rsp
4028 ; X64-NEXT:    retq
4029     %x = call i100 @llvm.fptoui.sat.i100.f80(x86_fp80 %f)
4030     ret i100 %x
4033 define i128 @test_unsigned_i128_f80(x86_fp80 %f) nounwind {
4034 ; X86-X87-LABEL: test_unsigned_i128_f80:
4035 ; X86-X87:       # %bb.0:
4036 ; X86-X87-NEXT:    pushl %ebp
4037 ; X86-X87-NEXT:    pushl %ebx
4038 ; X86-X87-NEXT:    pushl %edi
4039 ; X86-X87-NEXT:    pushl %esi
4040 ; X86-X87-NEXT:    subl $60, %esp
4041 ; X86-X87-NEXT:    fldt {{[0-9]+}}(%esp)
4042 ; X86-X87-NEXT:    fld %st(0)
4043 ; X86-X87-NEXT:    fstpt {{[0-9]+}}(%esp)
4044 ; X86-X87-NEXT:    leal {{[0-9]+}}(%esp), %eax
4045 ; X86-X87-NEXT:    movl %eax, (%esp)
4046 ; X86-X87-NEXT:    fldz
4047 ; X86-X87-NEXT:    fld %st(1)
4048 ; X86-X87-NEXT:    fstpt {{[-0-9]+}}(%e{{[sb]}}p) # 10-byte Folded Spill
4049 ; X86-X87-NEXT:    fxch %st(1)
4050 ; X86-X87-NEXT:    fucompp
4051 ; X86-X87-NEXT:    fnstsw %ax
4052 ; X86-X87-NEXT:    movl %eax, %ebx
4053 ; X86-X87-NEXT:    calll __fixunsxfti
4054 ; X86-X87-NEXT:    subl $4, %esp
4055 ; X86-X87-NEXT:    xorl %edx, %edx
4056 ; X86-X87-NEXT:    movb %bh, %ah
4057 ; X86-X87-NEXT:    sahf
4058 ; X86-X87-NEXT:    movl $0, %eax
4059 ; X86-X87-NEXT:    jb .LBB39_2
4060 ; X86-X87-NEXT:  # %bb.1:
4061 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %eax
4062 ; X86-X87-NEXT:  .LBB39_2:
4063 ; X86-X87-NEXT:    movl $0, %ecx
4064 ; X86-X87-NEXT:    jb .LBB39_4
4065 ; X86-X87-NEXT:  # %bb.3:
4066 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
4067 ; X86-X87-NEXT:  .LBB39_4:
4068 ; X86-X87-NEXT:    movl %ecx, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill
4069 ; X86-X87-NEXT:    movl %eax, {{[-0-9]+}}(%e{{[sb]}}p) # 4-byte Spill
4070 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ecx
4071 ; X86-X87-NEXT:    movl $0, %ebx
4072 ; X86-X87-NEXT:    jb .LBB39_6
4073 ; X86-X87-NEXT:  # %bb.5:
4074 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %ebx
4075 ; X86-X87-NEXT:    movl {{[0-9]+}}(%esp), %edx
4076 ; X86-X87-NEXT:  .LBB39_6:
4077 ; X86-X87-NEXT:    fldt {{\.?LCPI[0-9]+_[0-9]+}}
4078 ; X86-X87-NEXT:    fldt {{[-0-9]+}}(%e{{[sb]}}p) # 10-byte Folded Reload
4079 ; X86-X87-NEXT:    fucompp
4080 ; X86-X87-NEXT:    fnstsw %ax
4081 ; X86-X87-NEXT:    # kill: def $ah killed $ah killed $ax
4082 ; X86-X87-NEXT:    sahf
4083 ; X86-X87-NEXT:    movl $-1, %eax
4084 ; X86-X87-NEXT:    movl $-1, %ebp
4085 ; X86-X87-NEXT:    movl $-1, %edi
4086 ; X86-X87-NEXT:    movl $-1, %esi
4087 ; X86-X87-NEXT:    ja .LBB39_8
4088 ; X86-X87-NEXT:  # %bb.7:
4089 ; X86-X87-NEXT:    movl %ebx, %eax
4090 ; X86-X87-NEXT:    movl %edx, %ebp
4091 ; X86-X87-NEXT:    movl {{[-0-9]+}}(%e{{[sb]}}p), %edi # 4-byte Reload
4092 ; X86-X87-NEXT:    movl {{[-0-9]+}}(%e{{[sb]}}p), %esi # 4-byte Reload
4093 ; X86-X87-NEXT:  .LBB39_8:
4094 ; X86-X87-NEXT:    movl %esi, 12(%ecx)
4095 ; X86-X87-NEXT:    movl %edi, 8(%ecx)
4096 ; X86-X87-NEXT:    movl %ebp, 4(%ecx)
4097 ; X86-X87-NEXT:    movl %eax, (%ecx)
4098 ; X86-X87-NEXT:    movl %ecx, %eax
4099 ; X86-X87-NEXT:    addl $60, %esp
4100 ; X86-X87-NEXT:    popl %esi
4101 ; X86-X87-NEXT:    popl %edi
4102 ; X86-X87-NEXT:    popl %ebx
4103 ; X86-X87-NEXT:    popl %ebp
4104 ; X86-X87-NEXT:    retl $4
4106 ; X86-SSE-LABEL: test_unsigned_i128_f80:
4107 ; X86-SSE:       # %bb.0:
4108 ; X86-SSE-NEXT:    pushl %ebx
4109 ; X86-SSE-NEXT:    pushl %edi
4110 ; X86-SSE-NEXT:    pushl %esi
4111 ; X86-SSE-NEXT:    subl $48, %esp
4112 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %esi
4113 ; X86-SSE-NEXT:    fldt {{[0-9]+}}(%esp)
4114 ; X86-SSE-NEXT:    fld %st(0)
4115 ; X86-SSE-NEXT:    fstpt {{[-0-9]+}}(%e{{[sb]}}p) # 10-byte Folded Spill
4116 ; X86-SSE-NEXT:    fstpt {{[0-9]+}}(%esp)
4117 ; X86-SSE-NEXT:    leal {{[0-9]+}}(%esp), %eax
4118 ; X86-SSE-NEXT:    movl %eax, (%esp)
4119 ; X86-SSE-NEXT:    calll __fixunsxfti
4120 ; X86-SSE-NEXT:    subl $4, %esp
4121 ; X86-SSE-NEXT:    fldt {{[-0-9]+}}(%e{{[sb]}}p) # 10-byte Folded Reload
4122 ; X86-SSE-NEXT:    xorl %eax, %eax
4123 ; X86-SSE-NEXT:    fldz
4124 ; X86-SSE-NEXT:    fxch %st(1)
4125 ; X86-SSE-NEXT:    fucomi %st(1), %st
4126 ; X86-SSE-NEXT:    fstp %st(1)
4127 ; X86-SSE-NEXT:    movl $0, %ecx
4128 ; X86-SSE-NEXT:    movl $0, %edx
4129 ; X86-SSE-NEXT:    movl $0, %edi
4130 ; X86-SSE-NEXT:    jb .LBB39_2
4131 ; X86-SSE-NEXT:  # %bb.1:
4132 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %eax
4133 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %ecx
4134 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %edx
4135 ; X86-SSE-NEXT:    movl {{[0-9]+}}(%esp), %edi
4136 ; X86-SSE-NEXT:  .LBB39_2:
4137 ; X86-SSE-NEXT:    fldt {{\.?LCPI[0-9]+_[0-9]+}}
4138 ; X86-SSE-NEXT:    fxch %st(1)
4139 ; X86-SSE-NEXT:    fucompi %st(1), %st
4140 ; X86-SSE-NEXT:    fstp %st(0)
4141 ; X86-SSE-NEXT:    movl $-1, %ebx
4142 ; X86-SSE-NEXT:    cmoval %ebx, %edi
4143 ; X86-SSE-NEXT:    cmoval %ebx, %edx
4144 ; X86-SSE-NEXT:    cmoval %ebx, %ecx
4145 ; X86-SSE-NEXT:    cmoval %ebx, %eax
4146 ; X86-SSE-NEXT:    movl %eax, 12(%esi)
4147 ; X86-SSE-NEXT:    movl %ecx, 8(%esi)
4148 ; X86-SSE-NEXT:    movl %edx, 4(%esi)
4149 ; X86-SSE-NEXT:    movl %edi, (%esi)
4150 ; X86-SSE-NEXT:    movl %esi, %eax
4151 ; X86-SSE-NEXT:    addl $48, %esp
4152 ; X86-SSE-NEXT:    popl %esi
4153 ; X86-SSE-NEXT:    popl %edi
4154 ; X86-SSE-NEXT:    popl %ebx
4155 ; X86-SSE-NEXT:    retl $4
4157 ; X64-LABEL: test_unsigned_i128_f80:
4158 ; X64:       # %bb.0:
4159 ; X64-NEXT:    subq $40, %rsp
4160 ; X64-NEXT:    fldt {{[0-9]+}}(%rsp)
4161 ; X64-NEXT:    fld %st(0)
4162 ; X64-NEXT:    fstpt {{[-0-9]+}}(%r{{[sb]}}p) # 10-byte Folded Spill
4163 ; X64-NEXT:    fstpt (%rsp)
4164 ; X64-NEXT:    callq __fixunsxfti@PLT
4165 ; X64-NEXT:    xorl %ecx, %ecx
4166 ; X64-NEXT:    fldz
4167 ; X64-NEXT:    fldt {{[-0-9]+}}(%r{{[sb]}}p) # 10-byte Folded Reload
4168 ; X64-NEXT:    fucomi %st(1), %st
4169 ; X64-NEXT:    fstp %st(1)
4170 ; X64-NEXT:    cmovbq %rcx, %rdx
4171 ; X64-NEXT:    cmovbq %rcx, %rax
4172 ; X64-NEXT:    fldt {{\.?LCPI[0-9]+_[0-9]+}}(%rip)
4173 ; X64-NEXT:    fxch %st(1)
4174 ; X64-NEXT:    fucompi %st(1), %st
4175 ; X64-NEXT:    fstp %st(0)
4176 ; X64-NEXT:    movq $-1, %rcx
4177 ; X64-NEXT:    cmovaq %rcx, %rax
4178 ; X64-NEXT:    cmovaq %rcx, %rdx
4179 ; X64-NEXT:    addq $40, %rsp
4180 ; X64-NEXT:    retq
4181     %x = call i128 @llvm.fptoui.sat.i128.f80(x86_fp80 %f)
4182     ret i128 %x