Add a neat little two's complement hack for x86.
[oota-llvm.git] / test / CodeGen / X86 / vec_insert-4.ll
index 29c304039499ac30e555da1bd6cd61ec4448165c..2c31e56b4af6db06c423cc20465dc8c5cf04db21 100644 (file)
@@ -1,12 +1,11 @@
-; RUN: llvm-as < %s | llc -march=x86 -mattr=sse41 | grep pinsrd | count 1
-; RUN: llvm-as < %s | llc -march=x86 -mattr=sse41 | grep pinsrb | count 1
+; RUN: llc < %s -march=x86 -mcpu=yonah | grep 1084227584 | count 1
 
-define <4 x i32> @t1(i32 %s, <4 x i32> %tmp) nounwind {
-        %tmp1 = insertelement <4 x i32> %tmp, i32 %s, i32 1
-        ret <4 x i32> %tmp1
-}
+; ModuleID = '<stdin>'
+target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:128:128"
+target triple = "i686-apple-darwin9.2.2"
 
-define <16 x i8> @t2(i8 %s, <16 x i8> %tmp) nounwind {
-        %tmp1 = insertelement <16 x i8> %tmp, i8 %s, i32 1
-        ret <16 x i8> %tmp1
+define <8 x float> @f(<8 x float> %a, i32 %b) nounwind  {
+entry:
+       %vecins = insertelement <8 x float> %a, float 5.000000e+00, i32 %b              ; <<4 x float>> [#uses=1]
+       ret <8 x float> %vecins
 }