Fold 15 tiny test cases into a single file that implements the
[oota-llvm.git] / test / CodeGen / X86 / vec_insert.ll
index fbe604d5a1e49d1b7ce5cc06e6e1ea42d407eebd..4e5d445ff62394a5d83aaec0e61c8a441b4ac50e 100644 (file)
@@ -1,19 +1,19 @@
-; RUN: llvm-upgrade < %s | llvm-as | llc -march=x86 -mattr=+sse2 | grep movss  | wc -l | grep 1 &&
-; RUN: llvm-upgrade < %s | llvm-as | llc -march=x86 -mattr=+sse2 | grep pinsrw | wc -l | grep 2
+; RUN: llc < %s -march=x86 -mattr=+sse2,-sse41 | grep movss | count 1
+; RUN: llc < %s -march=x86 -mattr=+sse2,-sse41 | 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) nounwind {
+       %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 = fadd <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) nounwind {
+       %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
 }