Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / SystemZ / fp-conv-14.ll
blob0d1f951994d27137a8185d31a64ffe0e0c12dad1
1 ; Test conversion of floating-point values to unsigned integers.
3 ; RUN: llc < %s -mtriple=s390x-linux-gnu -mcpu=z196 | FileCheck %s
5 ; Test f32->i32.
6 define i32 @f1(float %f) {
7 ; CHECK-LABEL: f1:
8 ; CHECK: clfebr %r2, 5, %f0, 0
9 ; CHECK: br %r14
10   %conv = fptoui float %f to i32
11   ret i32 %conv
14 ; Test f64->i32.
15 define i32 @f2(double %f) {
16 ; CHECK-LABEL: f2:
17 ; CHECK: clfdbr %r2, 5, %f0, 0
18 ; CHECK: br %r14
19   %conv = fptoui double %f to i32
20   ret i32 %conv
23 ; Test f128->i32.
24 define i32 @f3(ptr %src) {
25 ; CHECK-LABEL: f3:
26 ; CHECK-DAG: ld %f0, 0(%r2)
27 ; CHECK-DAG: ld %f2, 8(%r2)
28 ; CHECK: clfxbr %r2, 5, %f0, 0
29 ; CHECK: br %r14
30   %f = load fp128, ptr %src
31   %conv = fptoui fp128 %f to i32
32   ret i32 %conv
35 ; Test f32->i64.
36 define i64 @f4(float %f) {
37 ; CHECK-LABEL: f4:
38 ; CHECK: clgebr %r2, 5, %f0, 0
39 ; CHECK: br %r14
40   %conv = fptoui float %f to i64
41   ret i64 %conv
44 ; Test f64->i64.
45 define i64 @f5(double %f) {
46 ; CHECK-LABEL: f5:
47 ; CHECK: clgdbr %r2, 5, %f0, 0
48 ; CHECK: br %r14
49   %conv = fptoui double %f to i64
50   ret i64 %conv
53 ; Test f128->i64.
54 define i64 @f6(ptr %src) {
55 ; CHECK-LABEL: f6:
56 ; CHECK-DAG: ld %f0, 0(%r2)
57 ; CHECK-DAG: ld %f2, 8(%r2)
58 ; CHECK: clgxbr %r2, 5, %f0, 0
59 ; CHECK: br %r14
60   %f = load fp128, ptr %src
61   %conv = fptoui fp128 %f to i64
62   ret i64 %conv