[InstCombine] Signed saturation patterns
[llvm-complete.git] / test / CodeGen / PowerPC / float-to-int.ll
blob54f9cecbc8fed1fff7d814a5f2ae0310b4938a7c
1 ; RUN: llc -verify-machineinstrs < %s -mtriple=powerpc64-unknown-linux-gnu \
2 ; RUN:   -mcpu=a2 | FileCheck %s
3 ; RUN: llc -verify-machineinstrs < %s -mtriple=powerpc64-unknown-linux-gnu \
4 ; RUN:   -mcpu=pwr7 -mattr=+vsx | FileCheck -check-prefix=CHECK-VSX %s
5 ; RUN: llc -verify-machineinstrs < %s -mtriple=powerpc64-unknown-linux-gnu \
6 ; RUN:   -mcpu=g5
7 ; RUN: llc -verify-machineinstrs < %s -mtriple=powerpc64-unknown-linux-gnu \
8 ; RUN:   -mcpu=pwr9 -mattr=-direct-move | FileCheck -check-prefix=CHECK-P9 %s
9 target datalayout = "E-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-f128:128:128-v128:128:128-n32:64"
10 target triple = "powerpc64-unknown-linux-gnu"
12 define i64 @foo(float %a) nounwind {
13   %x = fptosi float %a to i64
14   ret i64 %x
16 ; CHECK: @foo
17 ; CHECK: fctidz [[REG:[0-9]+]], 1
18 ; CHECK: stfd [[REG]],
19 ; CHECK: ld 3,
20 ; CHECK: blr
22 ; CHECK-VSX: @foo
23 ; CHECK-VSX: xscvdpsxds [[REG:[0-9]+]], 1
24 ; CHECK-VSX: stfd [[REG]],
25 ; CHECK-VSX: ld 3,
26 ; CHECK-VSX: blr
28 ; CHECK-LABEL-P9: @foo
29 ; CHECK-P9: xscvdpsxds [[REG:[0-9]+]], 1
30 ; CHECK-P9: stfd [[REG]],
31 ; CHECK-P9: ld 3,
32 ; CHECK-P9: blr
35 define i64 @foo2(double %a) nounwind {
36   %x = fptosi double %a to i64
37   ret i64 %x
39 ; CHECK: @foo2
40 ; CHECK: fctidz [[REG:[0-9]+]], 1
41 ; CHECK: stfd [[REG]],
42 ; CHECK: ld 3,
43 ; CHECK: blr
45 ; CHECK-VSX: @foo2
46 ; CHECK-VSX: xscvdpsxds [[REG:[0-9]+]], 1
47 ; CHECK-VSX: stfd [[REG]],
48 ; CHECK-VSX: ld 3,
49 ; CHECK-VSX: blr
51 ; CHECK-LABEL-P9: @foo2
52 ; CHECK-P9: xscvdpsxds [[REG:[0-9]+]], 1
53 ; CHECK-P9: stfd [[REG]],
54 ; CHECK-P9: ld 3,
55 ; CHECK-P9: blr
58 define i64 @foo3(float %a) nounwind {
59   %x = fptoui float %a to i64
60   ret i64 %x
62 ; CHECK: @foo3
63 ; CHECK: fctiduz [[REG:[0-9]+]], 1
64 ; CHECK: stfd [[REG]],
65 ; CHECK: ld 3,
66 ; CHECK: blr
68 ; CHECK-VSX: @foo3
69 ; CHECK-VSX: xscvdpuxds [[REG:[0-9]+]], 1
70 ; CHECK-VSX: stfd [[REG]],
71 ; CHECK-VSX: ld 3,
72 ; CHECK-VSX: blr
74 ; CHECK-LABEL-P9: @foo3
75 ; CHECK-P9: xscvdpuxds [[REG:[0-9]+]], 1
76 ; CHECK-P9: stfd [[REG]],
77 ; CHECK-P9: ld 3,
78 ; CHECK-P9: blr
81 define i64 @foo4(double %a) nounwind {
82   %x = fptoui double %a to i64
83   ret i64 %x
85 ; CHECK: @foo4
86 ; CHECK: fctiduz [[REG:[0-9]+]], 1
87 ; CHECK: stfd [[REG]],
88 ; CHECK: ld 3,
89 ; CHECK: blr
91 ; CHECK-VSX: @foo4
92 ; CHECK-VSX: xscvdpuxds [[REG:[0-9]+]], 1
93 ; CHECK-VSX: stfd [[REG]],
94 ; CHECK-VSX: ld 3,
95 ; CHECK-VSX: blr
97 ; CHECK-LABEL-P9: @foo4
98 ; CHECK-P9: xscvdpuxds [[REG:[0-9]+]], 1
99 ; CHECK-P9: stfd [[REG]],
100 ; CHECK-P9: ld 3,
101 ; CHECK-P9: blr
104 define i32 @goo(float %a) nounwind {
105   %x = fptosi float %a to i32
106   ret i32 %x
108 ; CHECK: @goo
109 ; CHECK: fctiwz [[REG:[0-9]+]], 1
110 ; CHECK: stfiwx [[REG]],
111 ; CHECK: lwz 3,
112 ; CHECK: blr
114 ; CHECK-VSX: @goo
115 ; CHECK-VSX: xscvdpsxws [[REG:[0-9]+]], 1
116 ; CHECK-VSX: stfiwx [[REG]],
117 ; CHECK-VSX: lwz 3,
118 ; CHECK-VSX: blr
121 define i32 @goo2(double %a) nounwind {
122   %x = fptosi double %a to i32
123   ret i32 %x
125 ; CHECK: @goo2
126 ; CHECK: fctiwz [[REG:[0-9]+]], 1
127 ; CHECK: stfiwx [[REG]],
128 ; CHECK: lwz 3,
129 ; CHECK: blr
131 ; CHECK-VSX: @goo2
132 ; CHECK-VSX: xscvdpsxws [[REG:[0-9]+]], 1
133 ; CHECK-VSX: stfiwx [[REG]],
134 ; CHECK-VSX: lwz 3,
135 ; CHECK-VSX: blr
138 define i32 @goo3(float %a) nounwind {
139   %x = fptoui float %a to i32
140   ret i32 %x
142 ; CHECK: @goo3
143 ; CHECK: fctiwuz [[REG:[0-9]+]], 1
144 ; CHECK: stfiwx [[REG]],
145 ; CHECK: lwz 3,
146 ; CHECK: blr
148 ; CHECK-VSX: @goo3
149 ; CHECK-VSX: xscvdpuxws [[REG:[0-9]+]], 1
150 ; CHECK-VSX: stfiwx [[REG]],
151 ; CHECK-VSX: lwz 3,
152 ; CHECK-VSX: blr
155 define i32 @goo4(double %a) nounwind {
156   %x = fptoui double %a to i32
157   ret i32 %x
159 ; CHECK: @goo4
160 ; CHECK: fctiwuz [[REG:[0-9]+]], 1
161 ; CHECK: stfiwx [[REG]],
162 ; CHECK: lwz 3,
163 ; CHECK: blr
165 ; CHECK-VSX: @goo4
166 ; CHECK-VSX: xscvdpuxws [[REG:[0-9]+]], 1
167 ; CHECK-VSX: stfiwx [[REG]],
168 ; CHECK-VSX: lwz 3,
169 ; CHECK-VSX: blr