summaryrefslogtreecommitdiffstats
path: root/llvm/test/CodeGen/X86/vec_insert.ll
diff options
context:
space:
mode:
authorEvan Cheng <evan.cheng@apple.com>2007-12-12 07:55:34 +0000
committerEvan Cheng <evan.cheng@apple.com>2007-12-12 07:55:34 +0000
commit0f42730722715555e082b854996b01b9b5655720 (patch)
treeaaf37ae6fc87e142c1781ef9ac1582c4c5770029 /llvm/test/CodeGen/X86/vec_insert.ll
parent0a1254f634d928e7ec5c485b3fd845275506b577 (diff)
downloadbcm5719-llvm-0f42730722715555e082b854996b01b9b5655720.tar.gz
bcm5719-llvm-0f42730722715555e082b854996b01b9b5655720.zip
Use shuffles to implement insert_vector_elt for i32, i64, f32, and f64.
llvm-svn: 44929
Diffstat (limited to 'llvm/test/CodeGen/X86/vec_insert.ll')
-rw-r--r--llvm/test/CodeGen/X86/vec_insert.ll23
1 files changed, 11 insertions, 12 deletions
diff --git a/llvm/test/CodeGen/X86/vec_insert.ll b/llvm/test/CodeGen/X86/vec_insert.ll
index 8ee0484fda1..c8c9f141ec1 100644
--- a/llvm/test/CodeGen/X86/vec_insert.ll
+++ b/llvm/test/CodeGen/X86/vec_insert.ll
@@ -1,20 +1,19 @@
-; RUN: llvm-upgrade < %s | llvm-as | llc -march=x86 -mattr=+sse2 -o %t -f
-; RUN: grep movss %t | count 1
-; RUN: grep pinsrw %t | count 2
+; RUN: llvm-as < %s | llc -march=x86 -mattr=+sse2 | grep movss | count 1
+; RUN: llvm-as < %s | llc -march=x86 -mattr=+sse2 | not grep pinsrw
-void %test(<4 x float>* %F, int %I) {
- %tmp = load <4 x float>* %F
- %f = cast int %I to float
- %tmp1 = insertelement <4 x float> %tmp, float %f, uint 0
- %tmp18 = add <4 x float> %tmp1, %tmp1
+define void @test(<4 x float>* %F, i32 %I) {
+ %tmp = load <4 x float>* %F ; <<4 x float>> [#uses=1]
+ %f = sitofp i32 %I to float ; <float> [#uses=1]
+ %tmp1 = insertelement <4 x float> %tmp, float %f, i32 0 ; <<4 x float>> [#uses=2]
+ %tmp18 = add <4 x float> %tmp1, %tmp1 ; <<4 x float>> [#uses=1]
store <4 x float> %tmp18, <4 x float>* %F
ret void
}
-void %test2(<4 x float>* %F, int %I, float %g) {
- %tmp = load <4 x float>* %F
- %f = cast int %I to float
- %tmp1 = insertelement <4 x float> %tmp, float %f, uint 2
+define void @test2(<4 x float>* %F, i32 %I, float %g) {
+ %tmp = load <4 x float>* %F ; <<4 x float>> [#uses=1]
+ %f = sitofp i32 %I to float ; <float> [#uses=1]
+ %tmp1 = insertelement <4 x float> %tmp, float %f, i32 2 ; <<4 x float>> [#uses=1]
store <4 x float> %tmp1, <4 x float>* %F
ret void
}
OpenPOWER on IntegriCloud