blob: 9c5b89613df9220eb1f9f8ff67cc9d3ecb03bf59 [file] [log] [blame]
Kalle Raiskila82fe4672010-08-02 08:54:39 +00001;RUN: llc --march=cellspu %s -o - | FileCheck %s
2%vec = type <2 x i32>
3
4define %vec @test_ret(%vec %param)
5{
6;CHECK: bi $lr
7 ret %vec %param
8}
9
10define %vec @test_add(%vec %param)
11{
Nadav Rotem8fb06b32011-10-16 20:31:33 +000012;CHECK: shufb
13;CHECK: addx
Kalle Raiskila82fe4672010-08-02 08:54:39 +000014 %1 = add %vec %param, %param
15;CHECK: bi $lr
16 ret %vec %1
17}
18
19define %vec @test_sub(%vec %param)
20{
Kalle Raiskila82fe4672010-08-02 08:54:39 +000021 %1 = sub %vec %param, <i32 1, i32 1>
Kalle Raiskila82fe4672010-08-02 08:54:39 +000022;CHECK: bi $lr
23 ret %vec %1
24}
25
26define %vec @test_mul(%vec %param)
27{
Kalle Raiskila82fe4672010-08-02 08:54:39 +000028 %1 = mul %vec %param, %param
Kalle Raiskila82fe4672010-08-02 08:54:39 +000029;CHECK: bi $lr
30 ret %vec %1
31}
32
33define <2 x i32> @test_splat(i32 %param ) {
Kalle Raiskila1cd1b0b2010-09-16 12:29:33 +000034;see svn log for why this is here...
35;CHECK-NOT: or $3, $3, $3
Kalle Raiskila82fe4672010-08-02 08:54:39 +000036;CHECK: lqa
37;CHECK: shufb
38 %sv = insertelement <1 x i32> undef, i32 %param, i32 0
39 %rv = shufflevector <1 x i32> %sv, <1 x i32> undef, <2 x i32> zeroinitializer
40;CHECK: bi $lr
41 ret <2 x i32> %rv
42}
43
44define i32 @test_extract() {
45;CHECK: shufb $3
46 %rv = extractelement <2 x i32> zeroinitializer, i32 undef ; <i32> [#uses=1]
47;CHECK: bi $lr
48 ret i32 %rv
49}
50
Kalle Raiskilabc2697c2010-08-04 13:59:48 +000051define void @test_store( %vec %val, %vec* %ptr)
52{
Kalle Raiskilabc2697c2010-08-04 13:59:48 +000053 store %vec %val, %vec* %ptr
54 ret void
55}
Kalle Raiskila505faa62010-10-26 10:45:47 +000056
Kalle Raiskila505faa62010-10-26 10:45:47 +000057define <2 x i32>* @test_alignment( [2 x <2 x i32>]* %ptr)
58{
Kalle Raiskila505faa62010-10-26 10:45:47 +000059 %rv = getelementptr [2 x <2 x i32>]* %ptr, i32 0, i32 1
60 ret <2 x i32>* %rv
61}