aboutsummaryrefslogtreecommitdiffstats
path: root/test/CodeGen/CellSPU
diff options
context:
space:
mode:
authorKalle Raiskila <kalle.raiskila@nokia.com>2010-08-09 16:33:00 +0000
committerKalle Raiskila <kalle.raiskila@nokia.com>2010-08-09 16:33:00 +0000
commit99534bb81a0d945edd61d4db17549bde8449f94c (patch)
treefc6921c64831de5654d394a90f4f683aae28bf26 /test/CodeGen/CellSPU
parentc1f354dcb82e2365a5fd1c39f11199dd2344cfb8 (diff)
downloadexternal_llvm-99534bb81a0d945edd61d4db17549bde8449f94c.zip
external_llvm-99534bb81a0d945edd61d4db17549bde8449f94c.tar.gz
external_llvm-99534bb81a0d945edd61d4db17549bde8449f94c.tar.bz2
Have SPU handle halfvec stores aligned by 8 bytes.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@110576 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/CodeGen/CellSPU')
-rw-r--r--test/CodeGen/CellSPU/bigstack.ll6
-rw-r--r--test/CodeGen/CellSPU/v2f32.ll12
2 files changed, 15 insertions, 3 deletions
diff --git a/test/CodeGen/CellSPU/bigstack.ll b/test/CodeGen/CellSPU/bigstack.ll
index 5483f46..63293e2 100644
--- a/test/CodeGen/CellSPU/bigstack.ll
+++ b/test/CodeGen/CellSPU/bigstack.ll
@@ -1,7 +1,7 @@
; RUN: llc < %s -march=cellspu -o %t1.s
-; RUN: grep lqx %t1.s | count 4
-; RUN: grep il %t1.s | grep -v file | count 7
-; RUN: grep stqx %t1.s | count 2
+; RUN: grep lqx %t1.s | count 3
+; RUN: grep il %t1.s | grep -v file | count 5
+; RUN: grep stqx %t1.s | count 1
define i32 @bigstack() nounwind {
entry:
diff --git a/test/CodeGen/CellSPU/v2f32.ll b/test/CodeGen/CellSPU/v2f32.ll
index b32c23b..3249631 100644
--- a/test/CodeGen/CellSPU/v2f32.ll
+++ b/test/CodeGen/CellSPU/v2f32.ll
@@ -61,3 +61,15 @@ define %vec @test_insert(){
ret %vec %rv
}
+define void @test_unaligned_store() {
+;CHECK: cdd $3, 8($3)
+;CHECK: lqd
+;CHECK: shufb
+;CHECK: stqd
+ %data = alloca [4 x float], align 16 ; <[4 x float]*> [#uses=1]
+ %ptr = getelementptr [4 x float]* %data, i32 0, i32 2 ; <float*> [#uses=1]
+ %vptr = bitcast float* %ptr to <2 x float>* ; <[1 x <2 x float>]*> [#uses=1]
+ store <2 x float> undef, <2 x float>* %vptr
+ ret void
+}
+