[InstCombine] Signed saturation patterns
[llvm-core.git] / test / CodeGen / ARC / alu.ll
bloba5e07636fec0818c82f13329ee6b82f34d62510a
1 ; RUN: llc -march=arc < %s | FileCheck %s
3 ; CHECK-LABEL: add_r
4 ; CHECK: add %r0, %r{{[01]}}, %r{{[01]}}
5 define i32 @add_r(i32 %a, i32 %b) nounwind {
6 entry:
7   %v = add i32 %a, %b
8   ret i32 %v
11 ; CHECK-LABEL: add_u6
12 ; CHECK: add %r0, %r0, 15
13 define i32 @add_u6(i32 %a) nounwind {
14   %v = add i32 %a, 15
15   ret i32 %v
18 ; CHECK-LABEL: add_limm
19 ; CHECK: add %r0, %r0, 12345
20 define i32 @add_limm(i32 %a) nounwind {
21   %v = add i32 %a, 12345
22   ret i32 %v
25 ; CHECK-LABEL: mpy_r
26 ; CHECK: mpy %r0, %r{{[01]}}, %r{{[01]}}
27 define i32 @mpy_r(i32 %a, i32 %b) nounwind {
28 entry:
29   %v = mul i32 %a, %b
30   ret i32 %v
33 ; CHECK-LABEL: mpy_u6
34 ; CHECK: mpy %r0, %r0, 10
35 define i32 @mpy_u6(i32 %a) nounwind {
36   %v = mul i32 %a, 10
37   ret i32 %v
40 ; CHECK-LABEL: mpy_limm
41 ; CHECK: mpy %r0, %r0, 12345
42 define i32 @mpy_limm(i32 %a) nounwind {
43   %v = mul i32 %a, 12345
44   ret i32 %v
47 ; CHECK-LABEL: max_r
48 ; CHECK: max %r0, %r{{[01]}}, %r{{[01]}}
49 define i32 @max_r(i32 %a, i32 %b) nounwind {
50   %i = icmp sgt i32 %a, %b
51   %v = select i1 %i, i32 %a, i32 %b
52   ret i32 %v
55 ; CHECK-LABEL: max_u6
56 ; CHECK: max %r0, %r0, 12
57 define i32 @max_u6(i32 %a) nounwind {
58   %i = icmp sgt i32 %a, 12
59   %v = select i1 %i, i32 %a, i32 12
60   ret i32 %v
63 ; CHECK-LABEL: max_limm
64 ; CHECK: max %r0, %r0, 2345
65 define i32 @max_limm(i32 %a) nounwind {
66   %i = icmp sgt i32 %a, 2345
67   %v = select i1 %i, i32 %a, i32 2345
68   ret i32 %v
71 ; CHECK-LABEL: min_r
72 ; CHECK: min %r0, %r{{[01]}}, %r{{[01]}}
73 define i32 @min_r(i32 %a, i32 %b) nounwind {
74   %i = icmp slt i32 %a, %b
75   %v = select i1 %i, i32 %a, i32 %b
76   ret i32 %v
79 ; CHECK-LABEL: min_u6
80 ; CHECK: min %r0, %r0, 20
81 define i32 @min_u6(i32 %a) nounwind {
82   %i = icmp slt i32 %a, 20
83   %v = select i1 %i, i32 %a, i32 20
84   ret i32 %v
87 ; CHECK-LABEL: min_limm
88 ; CHECK: min %r0, %r0, 2040
89 define i32 @min_limm(i32 %a) nounwind {
90   %i = icmp slt i32 %a, 2040
91   %v = select i1 %i, i32 %a, i32 2040
92   ret i32 %v
95 ; CHECK-LABEL: and_r
96 ; CHECK: and %r0, %r{{[01]}}, %r{{[01]}}
97 define i32 @and_r(i32 %a, i32 %b) nounwind {
98   %v = and i32 %a, %b
99   ret i32 %v
102 ; CHECK-LABEL: and_u6
103 ; CHECK: and %r0, %r0, 7
104 define i32 @and_u6(i32 %a) nounwind {
105   %v = and i32 %a, 7
106   ret i32 %v
109 ; 0xfffff == 1048575
110 ; CHECK-LABEL: and_limm
111 ; CHECK: and %r0, %r0, 1048575 
112 define i32 @and_limm(i32 %a) nounwind {
113   %v = and i32 %a, 1048575
114   ret i32 %v
117 ; CHECK-LABEL: or_r
118 ; CHECK: or %r0, %r{{[01]}}, %r{{[01]}}
119 define i32 @or_r(i32 %a, i32 %b) nounwind {
120   %v = or i32 %a, %b
121   ret i32 %v
124 ; CHECK-LABEL: or_u6
125 ; CHECK: or %r0, %r0, 7
126 define i32 @or_u6(i32 %a) nounwind {
127   %v = or i32 %a, 7
128   ret i32 %v
131 ; 0xf0f0f == 986895
132 ; CHECK-LABEL: or_limm
133 define i32 @or_limm(i32 %a) nounwind {
134   %v = or i32 %a, 986895
135   ret i32 %v
138 ; CHECK-LABEL: xor_r
139 ; CHECK: xor %r0, %r{{[01]}}, %r{{[01]}}
140 define i32 @xor_r(i32 %a, i32 %b) nounwind {
141   %v = xor i32 %a, %b
142   ret i32 %v
145 ; CHECK-LABEL: xor_u6
146 ; CHECK: xor %r0, %r0, 3
147 define i32 @xor_u6(i32 %a) nounwind {
148   %v = xor i32 %a, 3
149   ret i32 %v
152 ; CHECK-LABEL: xor_limm
153 ; CHECK: xor %r0, %r0, 986895
154 define i32 @xor_limm(i32 %a) nounwind {
155   %v = xor i32 %a, 986895
156   ret i32 %v
159 ; CHECK-LABEL: asl_r
160 ; CHECK: asl %r0, %r{{[01]}}, %r{{[01]}}
161 define i32 @asl_r(i32 %a, i32 %b) nounwind {
162   %v = shl i32 %a, %b
163   ret i32 %v
166 ; CHECK-LABEL: asl_u6
167 ; CHECK: asl %r0, %r0, 4
168 define i32 @asl_u6(i32 %a) nounwind {
169   %v = shl i32 %a, 4
170   ret i32 %v
173 ; CHECK-LABEL: lsr_r
174 ; CHECK: lsr %r0, %r{{[01]}}, %r{{[01]}}
175 define i32 @lsr_r(i32 %a, i32 %b) nounwind {
176   %v = lshr i32 %a, %b
177   ret i32 %v
180 ; CHECK-LABEL: lsr_u6
181 ; CHECK: lsr %r0, %r0, 6
182 define i32 @lsr_u6(i32 %a) nounwind {
183   %v = lshr i32 %a, 6
184   ret i32 %v
187 ; CHECK-LABEL: asr_r
188 ; CHECK: asr %r0, %r{{[01]}}, %r{{[01]}}
189 define i32 @asr_r(i32 %a, i32 %b) nounwind {
190   %v = ashr i32 %a, %b
191   ret i32 %v
194 ; CHECK-LABEL: asr_u6
195 ; CHECK: asr %r0, %r0, 8
196 define i32 @asr_u6(i32 %a) nounwind {
197   %v = ashr i32 %a, 8
198   ret i32 %v
201 ; CHECK-LABEL: ror_r
202 ; CHECK: ror %r0, %r{{[01]}}, %r{{[01]}}
203 define i32 @ror_r(i32 %a, i32 %b) nounwind {
204   %v1 = lshr i32 %a, %b
205   %ls = sub i32 32, %b
206   %v2 = shl i32 %a, %ls
207   %v = or i32 %v1, %v2
208   ret i32 %v
211 ; CHECK-LABEL: ror_u6
212 ; CHECK: ror %r0, %r0, 10
213 define i32 @ror_u6(i32 %a) nounwind {
214   %v1 = lshr i32 %a, 10
215   %v2 = shl i32 %a, 22
216   %v = or i32 %v1, %v2
217   ret i32 %v
220 ; CHECK-LABEL: sexh_r
221 ; CHECK: sexh %r0, %r0
222 define i32 @sexh_r(i32 %a) nounwind {
223   %v1 = shl i32 %a, 16
224   %v = ashr i32 %v1, 16
225   ret i32 %v
228 ; CHECK-LABEL: sexb_r
229 ; CHECK: sexb %r0, %r0
230 define i32 @sexb_r(i32 %a) nounwind {
231   %v1 = shl i32 %a, 24
232   %v = ashr i32 %v1, 24
233   ret i32 %v
236 ; CHECK-LABEL: mulu64
237 ; CHECK-DAG: mpy %r[[REG:[0-9]+]], %r{{[01]}}, %r{{[01]}}
238 ; CHECK-DAG: mpymu %r[[REG:[0-9]+]], %r{{[01]}}, %r{{[01]}}
239 define i64 @mulu64(i32 %a, i32 %b) nounwind {
240   %a64 = zext i32 %a to i64
241   %b64 = zext i32 %b to i64
242   %v = mul i64 %a64, %b64
243   ret i64 %v
246 ; CHECK-LABEL: muls64
247 ; CHECK-DAG: mpy %r[[REG:[0-9]+]], %r{{[01]}}, %r{{[01]}}
248 ; CHECK-DAG: mpym %r[[REG:[0-9]+]], %r{{[01]}}, %r{{[01]}}
249 define i64 @muls64(i32 %a, i32 %b) nounwind {
250   %a64 = sext i32 %a to i64
251   %b64 = sext i32 %b to i64
252   %v = mul i64 %a64, %b64
253   ret i64 %v