blob: 122e3035719e9d5aea61b1f0149cfbe55e9599b8 [file] [log] [blame]
Scott Michel58c58182008-01-17 20:38:41 +00001; RUN: llvm-as -o - %s | llc -march=cellspu > %t1.s
2; RUN: grep mpy %t1.s | count 44 &&
3; RUN: grep mpyu %t1.s | count 4 &&
4; RUN: grep mpyh %t1.s | count 10 &&
5; RUN: grep mpyhh %t1.s | count 2 &&
6; RUN: grep rotma %t1.s | count 12 &&
7; RUN: grep rotmahi %t1.s | count 4 &&
8; RUN: grep and %t1.s | count 2 &&
9; RUN: grep selb %t1.s | count 6 &&
10; RUN: grep fsmbi %t1.s | count 4 &&
11; RUN: grep shli %t1.s | count 4 &&
12; RUN: grep shlhi %t1.s | count 4 &&
13; RUN: grep ila %t1.s | count 2 &&
14; RUN: grep xsbh %t1.s | count 8 &&
15; RUN: grep xshw %t1.s | count 4
16target datalayout = "E-p:32:32:128-f64:64:128-f32:32:128-i64:32:128-i32:32:128-i16:16:128-i8:8:128-i1:8:128-a0:0:128-v128:128:128-s0:128:128"
17target triple = "spu"
18
19; 32-bit multiply instruction generation:
20define <4 x i32> @mpy_v4i32_1(<4 x i32> %arg1, <4 x i32> %arg2) {
21entry:
22 %A = mul <4 x i32> %arg1, %arg2
23 ret <4 x i32> %A
24}
25
26define <4 x i32> @mpy_v4i32_2(<4 x i32> %arg1, <4 x i32> %arg2) {
27entry:
28 %A = mul <4 x i32> %arg2, %arg1
29 ret <4 x i32> %A
30}
31
32define <8 x i16> @mpy_v8i16_1(<8 x i16> %arg1, <8 x i16> %arg2) {
33entry:
34 %A = mul <8 x i16> %arg1, %arg2
35 ret <8 x i16> %A
36}
37
38define <8 x i16> @mpy_v8i16_2(<8 x i16> %arg1, <8 x i16> %arg2) {
39entry:
40 %A = mul <8 x i16> %arg2, %arg1
41 ret <8 x i16> %A
42}
43
44define <16 x i8> @mul_v16i8_1(<16 x i8> %arg1, <16 x i8> %arg2) {
45entry:
46 %A = mul <16 x i8> %arg2, %arg1
47 ret <16 x i8> %A
48}
49
50define <16 x i8> @mul_v16i8_2(<16 x i8> %arg1, <16 x i8> %arg2) {
51entry:
52 %A = mul <16 x i8> %arg1, %arg2
53 ret <16 x i8> %A
54}
55
56define i32 @mul_i32_1(i32 %arg1, i32 %arg2) {
57entry:
58 %A = mul i32 %arg2, %arg1
59 ret i32 %A
60}
61
62define i32 @mul_i32_2(i32 %arg1, i32 %arg2) {
63entry:
64 %A = mul i32 %arg1, %arg2
65 ret i32 %A
66}
67
68define i16 @mul_i16_1(i16 %arg1, i16 %arg2) {
69entry:
70 %A = mul i16 %arg2, %arg1
71 ret i16 %A
72}
73
74define i16 @mul_i16_2(i16 %arg1, i16 %arg2) {
75entry:
76 %A = mul i16 %arg1, %arg2
77 ret i16 %A
78}
79
80define i8 @mul_i8_1(i8 %arg1, i8 %arg2) {
81entry:
82 %A = mul i8 %arg2, %arg1
83 ret i8 %A
84}
85
86define i8 @mul_i8_2(i8 %arg1, i8 %arg2) {
87entry:
88 %A = mul i8 %arg1, %arg2
89 ret i8 %A
90}