Fix PR5391: support early clobber physical register def tied with a use (ewwww)
[oota-llvm.git] / test / CodeGen / X86 / vec_insert.ll
index 021685e509e2498e559297a32f9f788c0f04807e..a7274a900044534d194b589ace828ff8b9caccac 100644 (file)
@@ -1,20 +1,19 @@
-; RUN: llvm-upgrade < %s | llvm-as | llc -march=x86 -mattr=+sse2 -o %t -f
-; RUN: grep movss  %t | wc -l | grep 1
-; RUN: grep pinsrw %t | 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) {
+       %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) {
+       %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
 }