1; RUN: llc < %s -march=msp430
2; ModuleID = 'mult-alt-generic.c'
3target datalayout = "e-p:16:16:16-i8:8:8-i16:16:16-i32:16:32-n8:16"
4target triple = "msp430"
5
6@mout0 = common global i16 0, align 2
7@min1 = common global i16 0, align 2
8@marray = common global [2 x i16] zeroinitializer, align 2
9
10define void @single_m() nounwind {
11entry:
12  call void asm "foo $1,$0", "=*m,*m"(i16* @mout0, i16* @min1) nounwind
13  ret void
14}
15
16define void @single_o() nounwind {
17entry:
18  %out0 = alloca i16, align 2
19  %index = alloca i16, align 2
20  store i16 0, i16* %out0, align 2
21  store i16 1, i16* %index, align 2
22  ret void
23}
24
25define void @single_V() nounwind {
26entry:
27  ret void
28}
29
30define void @single_lt() nounwind {
31entry:
32  %out0 = alloca i16, align 2
33  %in1 = alloca i16, align 2
34  store i16 0, i16* %out0, align 2
35  store i16 1, i16* %in1, align 2
36  %tmp = load i16* %in1, align 2
37  %0 = call i16 asm "foo $1,$0", "=r,<r"(i16 %tmp) nounwind
38  store i16 %0, i16* %out0, align 2
39  %tmp1 = load i16* %in1, align 2
40  %1 = call i16 asm "foo $1,$0", "=r,r<"(i16 %tmp1) nounwind
41  store i16 %1, i16* %out0, align 2
42  ret void
43}
44
45define void @single_gt() nounwind {
46entry:
47  %out0 = alloca i16, align 2
48  %in1 = alloca i16, align 2
49  store i16 0, i16* %out0, align 2
50  store i16 1, i16* %in1, align 2
51  %tmp = load i16* %in1, align 2
52  %0 = call i16 asm "foo $1,$0", "=r,>r"(i16 %tmp) nounwind
53  store i16 %0, i16* %out0, align 2
54  %tmp1 = load i16* %in1, align 2
55  %1 = call i16 asm "foo $1,$0", "=r,r>"(i16 %tmp1) nounwind
56  store i16 %1, i16* %out0, align 2
57  ret void
58}
59
60define void @single_r() nounwind {
61entry:
62  %out0 = alloca i16, align 2
63  %in1 = alloca i16, align 2
64  store i16 0, i16* %out0, align 2
65  store i16 1, i16* %in1, align 2
66  %tmp = load i16* %in1, align 2
67  %0 = call i16 asm "foo $1,$0", "=r,r"(i16 %tmp) nounwind
68  store i16 %0, i16* %out0, align 2
69  ret void
70}
71
72define void @single_i() nounwind {
73entry:
74  %out0 = alloca i16, align 2
75  store i16 0, i16* %out0, align 2
76  %0 = call i16 asm "foo $1,$0", "=r,i"(i16 1) nounwind
77  store i16 %0, i16* %out0, align 2
78  ret void
79}
80
81define void @single_n() nounwind {
82entry:
83  %out0 = alloca i16, align 2
84  store i16 0, i16* %out0, align 2
85  %0 = call i16 asm "foo $1,$0", "=r,n"(i16 1) nounwind
86  store i16 %0, i16* %out0, align 2
87  ret void
88}
89
90define void @single_E() nounwind {
91entry:
92  %out0 = alloca double, align 8
93  store double 0.000000e+000, double* %out0, align 8
94; No lowering support.
95;  %0 = call double asm "foo $1,$0", "=r,E"(double 1.000000e+001) nounwind
96;  store double %0, double* %out0, align 8
97  ret void
98}
99
100define void @single_F() nounwind {
101entry:
102  %out0 = alloca double, align 8
103  store double 0.000000e+000, double* %out0, align 8
104; No lowering support.
105;  %0 = call double asm "foo $1,$0", "=r,F"(double 1.000000e+000) nounwind
106;  store double %0, double* %out0, align 8
107  ret void
108}
109
110define void @single_s() nounwind {
111entry:
112  %out0 = alloca i16, align 2
113  store i16 0, i16* %out0, align 2
114  ret void
115}
116
117define void @single_g() nounwind {
118entry:
119  %out0 = alloca i16, align 2
120  %in1 = alloca i16, align 2
121  store i16 0, i16* %out0, align 2
122  store i16 1, i16* %in1, align 2
123  %tmp = load i16* %in1, align 2
124  %0 = call i16 asm "foo $1,$0", "=r,imr"(i16 %tmp) nounwind
125  store i16 %0, i16* %out0, align 2
126  %tmp1 = load i16* @min1, align 2
127  %1 = call i16 asm "foo $1,$0", "=r,imr"(i16 %tmp1) nounwind
128  store i16 %1, i16* %out0, align 2
129  %2 = call i16 asm "foo $1,$0", "=r,imr"(i16 1) nounwind
130  store i16 %2, i16* %out0, align 2
131  ret void
132}
133
134define void @single_X() nounwind {
135entry:
136  %out0 = alloca i16, align 2
137  %in1 = alloca i16, align 2
138  store i16 0, i16* %out0, align 2
139  store i16 1, i16* %in1, align 2
140  %tmp = load i16* %in1, align 2
141  %0 = call i16 asm "foo $1,$0", "=r,X"(i16 %tmp) nounwind
142  store i16 %0, i16* %out0, align 2
143  %tmp1 = load i16* @min1, align 2
144  %1 = call i16 asm "foo $1,$0", "=r,X"(i16 %tmp1) nounwind
145  store i16 %1, i16* %out0, align 2
146  %2 = call i16 asm "foo $1,$0", "=r,X"(i16 1) nounwind
147  store i16 %2, i16* %out0, align 2
148  %3 = call i16 asm "foo $1,$0", "=r,X"(i16* getelementptr inbounds ([2 x i16]* @marray, i32 0, i32 0)) nounwind
149  store i16 %3, i16* %out0, align 2
150; No lowering support.
151;  %4 = call i16 asm "foo $1,$0", "=r,X"(double 1.000000e+001) nounwind
152;  store i16 %4, i16* %out0, align 2
153;  %5 = call i16 asm "foo $1,$0", "=r,X"(double 1.000000e+000) nounwind
154;  store i16 %5, i16* %out0, align 2
155  ret void
156}
157
158define void @single_p() nounwind {
159entry:
160  %out0 = alloca i16, align 2
161  store i16 0, i16* %out0, align 2
162  %0 = call i16 asm "foo $1,$0", "=r,r"(i16* getelementptr inbounds ([2 x i16]* @marray, i32 0, i32 0)) nounwind
163  store i16 %0, i16* %out0, align 2
164  ret void
165}
166
167define void @multi_m() nounwind {
168entry:
169  %tmp = load i16* @min1, align 2
170  call void asm "foo $1,$0", "=*m|r,m|r"(i16* @mout0, i16 %tmp) nounwind
171  ret void
172}
173
174define void @multi_o() nounwind {
175entry:
176  %out0 = alloca i16, align 2
177  %index = alloca i16, align 2
178  store i16 0, i16* %out0, align 2
179  store i16 1, i16* %index, align 2
180  ret void
181}
182
183define void @multi_V() nounwind {
184entry:
185  ret void
186}
187
188define void @multi_lt() nounwind {
189entry:
190  %out0 = alloca i16, align 2
191  %in1 = alloca i16, align 2
192  store i16 0, i16* %out0, align 2
193  store i16 1, i16* %in1, align 2
194  %tmp = load i16* %in1, align 2
195  %0 = call i16 asm "foo $1,$0", "=r|r,r|<r"(i16 %tmp) nounwind
196  store i16 %0, i16* %out0, align 2
197  %tmp1 = load i16* %in1, align 2
198  %1 = call i16 asm "foo $1,$0", "=r|r,r|r<"(i16 %tmp1) nounwind
199  store i16 %1, i16* %out0, align 2
200  ret void
201}
202
203define void @multi_gt() nounwind {
204entry:
205  %out0 = alloca i16, align 2
206  %in1 = alloca i16, align 2
207  store i16 0, i16* %out0, align 2
208  store i16 1, i16* %in1, align 2
209  %tmp = load i16* %in1, align 2
210  %0 = call i16 asm "foo $1,$0", "=r|r,r|>r"(i16 %tmp) nounwind
211  store i16 %0, i16* %out0, align 2
212  %tmp1 = load i16* %in1, align 2
213  %1 = call i16 asm "foo $1,$0", "=r|r,r|r>"(i16 %tmp1) nounwind
214  store i16 %1, i16* %out0, align 2
215  ret void
216}
217
218define void @multi_r() nounwind {
219entry:
220  %out0 = alloca i16, align 2
221  %in1 = alloca i16, align 2
222  store i16 0, i16* %out0, align 2
223  store i16 1, i16* %in1, align 2
224  %tmp = load i16* %in1, align 2
225  %0 = call i16 asm "foo $1,$0", "=r|r,r|m"(i16 %tmp) nounwind
226  store i16 %0, i16* %out0, align 2
227  ret void
228}
229
230define void @multi_i() nounwind {
231entry:
232  %out0 = alloca i16, align 2
233  store i16 0, i16* %out0, align 2
234  %0 = call i16 asm "foo $1,$0", "=r|r,r|i"(i16 1) nounwind
235  store i16 %0, i16* %out0, align 2
236  ret void
237}
238
239define void @multi_n() nounwind {
240entry:
241  %out0 = alloca i16, align 2
242  store i16 0, i16* %out0, align 2
243  %0 = call i16 asm "foo $1,$0", "=r|r,r|n"(i16 1) nounwind
244  store i16 %0, i16* %out0, align 2
245  ret void
246}
247
248define void @multi_E() nounwind {
249entry:
250  %out0 = alloca double, align 8
251  store double 0.000000e+000, double* %out0, align 8
252; No lowering support.
253;  %0 = call double asm "foo $1,$0", "=r|r,r|E"(double 1.000000e+001) nounwind
254;  store double %0, double* %out0, align 8
255  ret void
256}
257
258define void @multi_F() nounwind {
259entry:
260  %out0 = alloca double, align 8
261  store double 0.000000e+000, double* %out0, align 8
262; No lowering support.
263;  %0 = call double asm "foo $1,$0", "=r|r,r|F"(double 1.000000e+000) nounwind
264;  store double %0, double* %out0, align 8
265  ret void
266}
267
268define void @multi_s() nounwind {
269entry:
270  %out0 = alloca i16, align 2
271  store i16 0, i16* %out0, align 2
272  ret void
273}
274
275define void @multi_g() nounwind {
276entry:
277  %out0 = alloca i16, align 2
278  %in1 = alloca i16, align 2
279  store i16 0, i16* %out0, align 2
280  store i16 1, i16* %in1, align 2
281  %tmp = load i16* %in1, align 2
282  %0 = call i16 asm "foo $1,$0", "=r|r,r|imr"(i16 %tmp) nounwind
283  store i16 %0, i16* %out0, align 2
284  %tmp1 = load i16* @min1, align 2
285  %1 = call i16 asm "foo $1,$0", "=r|r,r|imr"(i16 %tmp1) nounwind
286  store i16 %1, i16* %out0, align 2
287  %2 = call i16 asm "foo $1,$0", "=r|r,r|imr"(i16 1) nounwind
288  store i16 %2, i16* %out0, align 2
289  ret void
290}
291
292define void @multi_X() nounwind {
293entry:
294  %out0 = alloca i16, align 2
295  %in1 = alloca i16, align 2
296  store i16 0, i16* %out0, align 2
297  store i16 1, i16* %in1, align 2
298  %tmp = load i16* %in1, align 2
299  %0 = call i16 asm "foo $1,$0", "=r|r,r|X"(i16 %tmp) nounwind
300  store i16 %0, i16* %out0, align 2
301  %tmp1 = load i16* @min1, align 2
302  %1 = call i16 asm "foo $1,$0", "=r|r,r|X"(i16 %tmp1) nounwind
303  store i16 %1, i16* %out0, align 2
304  %2 = call i16 asm "foo $1,$0", "=r|r,r|X"(i16 1) nounwind
305  store i16 %2, i16* %out0, align 2
306  %3 = call i16 asm "foo $1,$0", "=r|r,r|X"(i16* getelementptr inbounds ([2 x i16]* @marray, i32 0, i32 0)) nounwind
307  store i16 %3, i16* %out0, align 2
308; No lowering support.
309;  %4 = call i16 asm "foo $1,$0", "=r|r,r|X"(double 1.000000e+001) nounwind
310;  store i16 %4, i16* %out0, align 2
311;  %5 = call i16 asm "foo $1,$0", "=r|r,r|X"(double 1.000000e+000) nounwind
312;  store i16 %5, i16* %out0, align 2
313  ret void
314}
315
316define void @multi_p() nounwind {
317entry:
318  %out0 = alloca i16, align 2
319  store i16 0, i16* %out0, align 2
320  %0 = call i16 asm "foo $1,$0", "=r|r,r|r"(i16* getelementptr inbounds ([2 x i16]* @marray, i32 0, i32 0)) nounwind
321  store i16 %0, i16* %out0, align 2
322  ret void
323}
324