Add a test for the MachineCopyPropagation change landed in r238518.
[oota-llvm.git] / test / CodeGen / X86 / vec_set.ll
index f955707f3ec4fbc311123616abc9612f6b3a371c..53d880b4bbdd9ef49870bddc7ef859433cbcbaa1 100644 (file)
@@ -1,14 +1,15 @@
-; RUN: llvm-upgrade < %s | llvm-as | llc -march=x86 -mattr=+sse2 | grep punpckl | count 7
+; RUN: llc < %s -march=x86 -mattr=+sse2,-sse4.1 | grep punpckl | count 7
 
-void %test(<8 x short>* %b, short %a0, short %a1, short %a2, short %a3, short %a4, short %a5, short %a6, short %a7) {
-       %tmp = insertelement <8 x short> zeroinitializer, short %a0, uint 0
-       %tmp2 = insertelement <8 x short> %tmp, short %a1, uint 1
-       %tmp4 = insertelement <8 x short> %tmp2, short %a2, uint 2
-       %tmp6 = insertelement <8 x short> %tmp4, short %a3, uint 3
-       %tmp8 = insertelement <8 x short> %tmp6, short %a4, uint 4
-       %tmp10 = insertelement <8 x short> %tmp8, short %a5, uint 5
-       %tmp12 = insertelement <8 x short> %tmp10, short %a6, uint 6
-       %tmp14 = insertelement <8 x short> %tmp12, short %a7, uint 7
-       store <8 x short> %tmp14, <8 x short>* %b
-       ret void
+define void @test(<8 x i16>* %b, i16 %a0, i16 %a1, i16 %a2, i16 %a3, i16 %a4, i16 %a5, i16 %a6, i16 %a7) nounwind {
+        %tmp = insertelement <8 x i16> zeroinitializer, i16 %a0, i32 0          ; <<8 x i16>> [#uses=1]
+        %tmp2 = insertelement <8 x i16> %tmp, i16 %a1, i32 1            ; <<8 x i16>> [#uses=1]
+        %tmp4 = insertelement <8 x i16> %tmp2, i16 %a2, i32 2           ; <<8 x i16>> [#uses=1]
+        %tmp6 = insertelement <8 x i16> %tmp4, i16 %a3, i32 3           ; <<8 x i16>> [#uses=1]
+        %tmp8 = insertelement <8 x i16> %tmp6, i16 %a4, i32 4           ; <<8 x i16>> [#uses=1]
+        %tmp10 = insertelement <8 x i16> %tmp8, i16 %a5, i32 5          ; <<8 x i16>> [#uses=1]
+        %tmp12 = insertelement <8 x i16> %tmp10, i16 %a6, i32 6         ; <<8 x i16>> [#uses=1]
+        %tmp14 = insertelement <8 x i16> %tmp12, i16 %a7, i32 7         ; <<8 x i16>> [#uses=1]
+        store <8 x i16> %tmp14, <8 x i16>* %b
+        ret void
 }
+