annotate test/CodeGen/ARC/alu.ll @ 146:3fc4d5c3e21e

set tail call flag for code segment in CGCAll
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Sun, 23 Dec 2018 19:23:36 +0900
parents 803732b1fca8
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
121
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
1 ; RUN: llc -march=arc < %s | FileCheck %s
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
2
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
3 ; CHECK-LABEL: add_r
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
4 ; CHECK: add %r0, %r{{[01]}}, %r{{[01]}}
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
5 define i32 @add_r(i32 %a, i32 %b) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
6 entry:
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
7 %v = add i32 %a, %b
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
8 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
9 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
10
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
11 ; CHECK-LABEL: add_u6
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
12 ; CHECK: add %r0, %r0, 15
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
13 define i32 @add_u6(i32 %a) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
14 %v = add i32 %a, 15
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
15 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
16 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
17
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
18 ; CHECK-LABEL: add_limm
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
19 ; CHECK: add %r0, %r0, 12345
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
20 define i32 @add_limm(i32 %a) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
21 %v = add i32 %a, 12345
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
22 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
23 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
24
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
25 ; CHECK-LABEL: mpy_r
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
26 ; CHECK: mpy %r0, %r{{[01]}}, %r{{[01]}}
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
27 define i32 @mpy_r(i32 %a, i32 %b) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
28 entry:
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
29 %v = mul i32 %a, %b
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
30 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
31 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
32
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
33 ; CHECK-LABEL: mpy_u6
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
34 ; CHECK: mpy %r0, %r0, 10
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
35 define i32 @mpy_u6(i32 %a) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
36 %v = mul i32 %a, 10
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
37 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
38 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
39
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
40 ; CHECK-LABEL: mpy_limm
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
41 ; CHECK: mpy %r0, %r0, 12345
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
42 define i32 @mpy_limm(i32 %a) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
43 %v = mul i32 %a, 12345
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
44 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
45 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
46
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
47 ; CHECK-LABEL: max_r
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
48 ; CHECK: max %r0, %r{{[01]}}, %r{{[01]}}
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
49 define i32 @max_r(i32 %a, i32 %b) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
50 %i = icmp sgt i32 %a, %b
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
51 %v = select i1 %i, i32 %a, i32 %b
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
52 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
53 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
54
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
55 ; CHECK-LABEL: max_u6
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
56 ; CHECK: max %r0, %r0, 12
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
57 define i32 @max_u6(i32 %a) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
58 %i = icmp sgt i32 %a, 12
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
59 %v = select i1 %i, i32 %a, i32 12
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
60 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
61 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
62
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
63 ; CHECK-LABEL: max_limm
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
64 ; CHECK: max %r0, %r0, 2345
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
65 define i32 @max_limm(i32 %a) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
66 %i = icmp sgt i32 %a, 2345
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
67 %v = select i1 %i, i32 %a, i32 2345
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
68 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
69 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
70
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
71 ; CHECK-LABEL: min_r
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
72 ; CHECK: min %r0, %r{{[01]}}, %r{{[01]}}
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
73 define i32 @min_r(i32 %a, i32 %b) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
74 %i = icmp slt i32 %a, %b
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
75 %v = select i1 %i, i32 %a, i32 %b
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
76 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
77 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
78
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
79 ; CHECK-LABEL: min_u6
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
80 ; CHECK: min %r0, %r0, 20
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
81 define i32 @min_u6(i32 %a) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
82 %i = icmp slt i32 %a, 20
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
83 %v = select i1 %i, i32 %a, i32 20
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
84 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
85 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
86
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
87 ; CHECK-LABEL: min_limm
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
88 ; CHECK: min %r0, %r0, 2040
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
89 define i32 @min_limm(i32 %a) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
90 %i = icmp slt i32 %a, 2040
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
91 %v = select i1 %i, i32 %a, i32 2040
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
92 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
93 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
94
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
95 ; CHECK-LABEL: and_r
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
96 ; CHECK: and %r0, %r{{[01]}}, %r{{[01]}}
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
97 define i32 @and_r(i32 %a, i32 %b) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
98 %v = and i32 %a, %b
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
99 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
100 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
101
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
102 ; CHECK-LABEL: and_u6
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
103 ; CHECK: and %r0, %r0, 7
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
104 define i32 @and_u6(i32 %a) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
105 %v = and i32 %a, 7
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
106 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
107 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
108
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
109 ; 0xfffff == 1048575
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
110 ; CHECK-LABEL: and_limm
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
111 ; CHECK: and %r0, %r0, 1048575
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
112 define i32 @and_limm(i32 %a) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
113 %v = and i32 %a, 1048575
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
114 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
115 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
116
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
117 ; CHECK-LABEL: or_r
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
118 ; CHECK: or %r0, %r{{[01]}}, %r{{[01]}}
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
119 define i32 @or_r(i32 %a, i32 %b) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
120 %v = or i32 %a, %b
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
121 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
122 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
123
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
124 ; CHECK-LABEL: or_u6
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
125 ; CHECK: or %r0, %r0, 7
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
126 define i32 @or_u6(i32 %a) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
127 %v = or i32 %a, 7
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
128 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
129 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
130
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
131 ; 0xf0f0f == 986895
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
132 ; CHECK-LABEL: or_limm
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
133 define i32 @or_limm(i32 %a) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
134 %v = or i32 %a, 986895
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
135 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
136 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
137
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
138 ; CHECK-LABEL: xor_r
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
139 ; CHECK: xor %r0, %r{{[01]}}, %r{{[01]}}
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
140 define i32 @xor_r(i32 %a, i32 %b) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
141 %v = xor i32 %a, %b
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
142 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
143 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
144
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
145 ; CHECK-LABEL: xor_u6
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
146 ; CHECK: xor %r0, %r0, 3
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
147 define i32 @xor_u6(i32 %a) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
148 %v = xor i32 %a, 3
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
149 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
150 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
151
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
152 ; CHECK-LABEL: xor_limm
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
153 ; CHECK: xor %r0, %r0, 986895
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
154 define i32 @xor_limm(i32 %a) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
155 %v = xor i32 %a, 986895
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
156 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
157 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
158
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
159 ; CHECK-LABEL: asl_r
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
160 ; CHECK: asl %r0, %r{{[01]}}, %r{{[01]}}
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
161 define i32 @asl_r(i32 %a, i32 %b) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
162 %v = shl i32 %a, %b
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
163 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
164 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
165
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
166 ; CHECK-LABEL: asl_u6
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
167 ; CHECK: asl %r0, %r0, 4
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
168 define i32 @asl_u6(i32 %a) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
169 %v = shl i32 %a, 4
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
170 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
171 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
172
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
173 ; CHECK-LABEL: lsr_r
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
174 ; CHECK: lsr %r0, %r{{[01]}}, %r{{[01]}}
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
175 define i32 @lsr_r(i32 %a, i32 %b) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
176 %v = lshr i32 %a, %b
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
177 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
178 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
179
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
180 ; CHECK-LABEL: lsr_u6
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
181 ; CHECK: lsr %r0, %r0, 6
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
182 define i32 @lsr_u6(i32 %a) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
183 %v = lshr i32 %a, 6
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
184 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
185 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
186
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
187 ; CHECK-LABEL: asr_r
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
188 ; CHECK: asr %r0, %r{{[01]}}, %r{{[01]}}
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
189 define i32 @asr_r(i32 %a, i32 %b) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
190 %v = ashr i32 %a, %b
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
191 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
192 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
193
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
194 ; CHECK-LABEL: asr_u6
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
195 ; CHECK: asr %r0, %r0, 8
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
196 define i32 @asr_u6(i32 %a) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
197 %v = ashr i32 %a, 8
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
198 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
199 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
200
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
201 ; CHECK-LABEL: ror_r
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
202 ; CHECK: ror %r0, %r{{[01]}}, %r{{[01]}}
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
203 define i32 @ror_r(i32 %a, i32 %b) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
204 %v1 = lshr i32 %a, %b
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
205 %ls = sub i32 32, %b
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
206 %v2 = shl i32 %a, %ls
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
207 %v = or i32 %v1, %v2
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
208 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
209 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
210
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
211 ; CHECK-LABEL: ror_u6
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
212 ; CHECK: ror %r0, %r0, 10
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
213 define i32 @ror_u6(i32 %a) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
214 %v1 = lshr i32 %a, 10
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
215 %v2 = shl i32 %a, 22
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
216 %v = or i32 %v1, %v2
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
217 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
218 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
219
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
220 ; CHECK-LABEL: sexh_r
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
221 ; CHECK: sexh %r0, %r0
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
222 define i32 @sexh_r(i32 %a) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
223 %v1 = shl i32 %a, 16
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
224 %v = ashr i32 %v1, 16
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
225 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
226 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
227
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
228 ; CHECK-LABEL: sexb_r
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
229 ; CHECK: sexb %r0, %r0
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
230 define i32 @sexb_r(i32 %a) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
231 %v1 = shl i32 %a, 24
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
232 %v = ashr i32 %v1, 24
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
233 ret i32 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
234 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
235
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
236 ; CHECK-LABEL: mulu64
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
237 ; CHECK-DAG: mpy %r[[REG:[0-9]+]], %r{{[01]}}, %r{{[01]}}
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
238 ; CHECK-DAG: mpymu %r[[REG:[0-9]+]], %r{{[01]}}, %r{{[01]}}
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
239 define i64 @mulu64(i32 %a, i32 %b) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
240 %a64 = zext i32 %a to i64
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
241 %b64 = zext i32 %b to i64
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
242 %v = mul i64 %a64, %b64
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
243 ret i64 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
244 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
245
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
246 ; CHECK-LABEL: muls64
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
247 ; CHECK-DAG: mpy %r[[REG:[0-9]+]], %r{{[01]}}, %r{{[01]}}
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
248 ; CHECK-DAG: mpym %r[[REG:[0-9]+]], %r{{[01]}}, %r{{[01]}}
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
249 define i64 @muls64(i32 %a, i32 %b) nounwind {
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
250 %a64 = sext i32 %a to i64
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
251 %b64 = sext i32 %b to i64
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
252 %v = mul i64 %a64, %b64
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
253 ret i64 %v
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
254 }
803732b1fca8 LLVM 5.0
kono
parents:
diff changeset
255