[ORC] Add std::tuple support to SimplePackedSerialization.
[llvm-project.git] / llvm / test / Transforms / InstSimplify / smul_fix.ll
blob5ca4129008a13ac158406b8d1a9bf2bbf99f718b
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt < %s -S -instsimplify | FileCheck %s
4 declare i16 @llvm.smul.fix.i16(i16, i16, i32)
5 declare i16 @llvm.smul.fix.sat.i16(i16, i16, i32)
6 declare <2 x i16> @llvm.smul.fix.v2i16(<2 x i16>, <2 x i16>, i32)
7 declare <2 x i16> @llvm.smul.fix.sat.v2i16(<2 x i16>, <2 x i16>, i32)
9 ;;
10 ;; llvm.smul.fix (scalar)
13 ; X * 0 -> X
14 define i16 @smul_fix_0(i16 %arg) {
15 ; CHECK-LABEL: @smul_fix_0(
16 ; CHECK-NEXT:    ret i16 0
18   %res = call i16 @llvm.smul.fix.i16(i16 %arg, i16 0, i32 15)
19   ret i16 %res
22 ; 0 * X -> X
23 define i16 @smul_fix_1(i16 %arg) {
24 ; CHECK-LABEL: @smul_fix_1(
25 ; CHECK-NEXT:    ret i16 0
27   %res = call i16 @llvm.smul.fix.i16(i16 0, i16 %arg, i32 15)
28   ret i16 %res
31 ; X * undef -> undef
32 define i16 @smul_fix_2(i16 %arg) {
33 ; CHECK-LABEL: @smul_fix_2(
34 ; CHECK-NEXT:    ret i16 0
36   %res = call i16 @llvm.smul.fix.i16(i16 %arg, i16 undef, i32 15)
37   ret i16 %res
40 ; undef * X -> undef
41 define i16 @smul_fix_3(i16 %arg) {
42 ; CHECK-LABEL: @smul_fix_3(
43 ; CHECK-NEXT:    ret i16 0
45   %res = call i16 @llvm.smul.fix.i16(i16 undef, i16 %arg, i32 15)
46   ret i16 %res
49 ; X * 1 -> X
50 define i16 @smul_fix_4(i16 %arg) {
51 ; CHECK-LABEL: @smul_fix_4(
52 ; CHECK-NEXT:    ret i16 [[ARG:%.*]]
54   %res = call i16 @llvm.smul.fix.i16(i16 %arg, i16 16384, i32 14)
55   ret i16 %res
58 ; 1 * X -> X
59 define i16 @smul_fix_5(i16 %arg) {
60 ; CHECK-LABEL: @smul_fix_5(
61 ; CHECK-NEXT:    ret i16 [[ARG:%.*]]
63   %res = call i16 @llvm.smul.fix.i16(i16 2, i16 %arg, i32 1)
64   ret i16 %res
68 ;; llvm.smul.fix.sat (scalar)
71 ; X * 0 -> X
72 define i16 @smul_fix_sat_0(i16 %arg) {
73 ; CHECK-LABEL: @smul_fix_sat_0(
74 ; CHECK-NEXT:    ret i16 0
76   %res = call i16 @llvm.smul.fix.sat.i16(i16 %arg, i16 0, i32 15)
77   ret i16 %res
80 ; 0 * X -> X
81 define i16 @smul_fix_sat_1(i16 %arg) {
82 ; CHECK-LABEL: @smul_fix_sat_1(
83 ; CHECK-NEXT:    ret i16 0
85   %res = call i16 @llvm.smul.fix.sat.i16(i16 0, i16 %arg, i32 15)
86   ret i16 %res
89 ; X * undef -> undef
90 define i16 @smul_fix_sat_2(i16 %arg) {
91 ; CHECK-LABEL: @smul_fix_sat_2(
92 ; CHECK-NEXT:    ret i16 0
94   %res = call i16 @llvm.smul.fix.sat.i16(i16 %arg, i16 undef, i32 15)
95   ret i16 %res
98 ; undef * X -> undef
99 define i16 @smul_fix_sat_3(i16 %arg) {
100 ; CHECK-LABEL: @smul_fix_sat_3(
101 ; CHECK-NEXT:    ret i16 0
103   %res = call i16 @llvm.smul.fix.sat.i16(i16 undef, i16 %arg, i32 15)
104   ret i16 %res
107 ; X * 1 -> X
108 define i16 @smul_fix_sat_4(i16 %arg) {
109 ; CHECK-LABEL: @smul_fix_sat_4(
110 ; CHECK-NEXT:    ret i16 [[ARG:%.*]]
112   %res = call i16 @llvm.smul.fix.sat.i16(i16 %arg, i16 16384, i32 14)
113   ret i16 %res
116 ; 1 * X -> X
117 define i16 @smul_fix_sat_5(i16 %arg) {
118 ; CHECK-LABEL: @smul_fix_sat_5(
119 ; CHECK-NEXT:    ret i16 [[ARG:%.*]]
121   %res = call i16 @llvm.smul.fix.sat.i16(i16 2, i16 %arg, i32 1)
122   ret i16 %res
126 ;; llvm.smul.fix (vector)
129 ; X * 0 -> X
130 define <2 x i16> @smul_fix_vec_0(<2 x i16> %arg) {
131 ; CHECK-LABEL: @smul_fix_vec_0(
132 ; CHECK-NEXT:    ret <2 x i16> zeroinitializer
134   %res = call <2 x i16> @llvm.smul.fix.v2i16(<2 x i16> %arg, <2 x i16> zeroinitializer, i32 15)
135   ret <2 x i16> %res
138 ; 0 * X -> X
139 define <2 x i16> @smul_fix_vec_1(<2 x i16> %arg) {
140 ; CHECK-LABEL: @smul_fix_vec_1(
141 ; CHECK-NEXT:    ret <2 x i16> zeroinitializer
143   %res = call <2 x i16> @llvm.smul.fix.v2i16(<2 x i16> zeroinitializer, <2 x i16> %arg, i32 15)
144   ret <2 x i16> %res
147 ; X * undef -> undef
148 define <2 x i16> @smul_fix_vec_2(<2 x i16> %arg) {
149 ; CHECK-LABEL: @smul_fix_vec_2(
150 ; CHECK-NEXT:    ret <2 x i16> zeroinitializer
152   %res = call <2 x i16> @llvm.smul.fix.v2i16(<2 x i16> %arg, <2 x i16> undef, i32 15)
153   ret <2 x i16> %res
156 ; undef * X -> undef
157 define <2 x i16> @smul_fix_vec_3(<2 x i16> %arg) {
158 ; CHECK-LABEL: @smul_fix_vec_3(
159 ; CHECK-NEXT:    ret <2 x i16> zeroinitializer
161   %res = call <2 x i16> @llvm.smul.fix.v2i16(<2 x i16> undef, <2 x i16> %arg, i32 15)
162   ret <2 x i16> %res
165 ; X * 1 -> X
166 define <2 x i16> @smul_fix_vec_4(<2 x i16> %arg) {
167 ; CHECK-LABEL: @smul_fix_vec_4(
168 ; CHECK-NEXT:    ret <2 x i16> [[ARG:%.*]]
170   %res = call <2 x i16> @llvm.smul.fix.v2i16(<2 x i16> %arg, <2 x i16> <i16 16384, i16 16384>, i32 14)
171   ret <2 x i16> %res
174 ; 1 * X -> X
175 define <2 x i16> @smul_fix_vec_5(<2 x i16> %arg) {
176 ; CHECK-LABEL: @smul_fix_vec_5(
177 ; CHECK-NEXT:    ret <2 x i16> [[ARG:%.*]]
179   %res = call <2 x i16> @llvm.smul.fix.v2i16(<2 x i16> <i16 2, i16 2>, <2 x i16> %arg, i32 1)
180   ret <2 x i16> %res
184 ;; llvm.smul.fix.sat (vector)
187 ; X * 0 -> X
188 define <2 x i16> @smul_fix_sat_vec_0(<2 x i16> %arg) {
189 ; CHECK-LABEL: @smul_fix_sat_vec_0(
190 ; CHECK-NEXT:    ret <2 x i16> zeroinitializer
192   %res = call <2 x i16> @llvm.smul.fix.sat.v2i16(<2 x i16> %arg, <2 x i16> zeroinitializer, i32 15)
193   ret <2 x i16> %res
196 ; 0 * X -> X
197 define <2 x i16> @smul_fix_sat_vec_1(<2 x i16> %arg) {
198 ; CHECK-LABEL: @smul_fix_sat_vec_1(
199 ; CHECK-NEXT:    ret <2 x i16> zeroinitializer
201   %res = call <2 x i16> @llvm.smul.fix.sat.v2i16(<2 x i16> zeroinitializer, <2 x i16> %arg, i32 15)
202   ret <2 x i16> %res
205 ; X * undef -> undef
206 define <2 x i16> @smul_fix_sat_vec_2(<2 x i16> %arg) {
207 ; CHECK-LABEL: @smul_fix_sat_vec_2(
208 ; CHECK-NEXT:    ret <2 x i16> zeroinitializer
210   %res = call <2 x i16> @llvm.smul.fix.sat.v2i16(<2 x i16> %arg, <2 x i16> undef, i32 15)
211   ret <2 x i16> %res
214 ; undef * X -> undef
215 define <2 x i16> @smul_fix_sat_vec_3(<2 x i16> %arg) {
216 ; CHECK-LABEL: @smul_fix_sat_vec_3(
217 ; CHECK-NEXT:    ret <2 x i16> zeroinitializer
219   %res = call <2 x i16> @llvm.smul.fix.sat.v2i16(<2 x i16> undef, <2 x i16> %arg, i32 15)
220   ret <2 x i16> %res
223 ; X * 1 -> X
224 define <2 x i16> @smul_fix_sat_vec_4(<2 x i16> %arg) {
225 ; CHECK-LABEL: @smul_fix_sat_vec_4(
226 ; CHECK-NEXT:    ret <2 x i16> [[ARG:%.*]]
228   %res = call <2 x i16> @llvm.smul.fix.sat.v2i16(<2 x i16> %arg, <2 x i16> <i16 16384, i16 16384>, i32 14)
229   ret <2 x i16> %res
232 ; 1 * X -> X
233 define <2 x i16> @smul_fix_sat_vec_5(<2 x i16> %arg) {
234 ; CHECK-LABEL: @smul_fix_sat_vec_5(
235 ; CHECK-NEXT:    ret <2 x i16> [[ARG:%.*]]
237   %res = call <2 x i16> @llvm.smul.fix.sat.v2i16(<2 x i16> <i16 2, i16 2>, <2 x i16> %arg, i32 1)
238   ret <2 x i16> %res