vec_insert.ll   [plain text]


; RUN: llc < %s -march=x86 -mattr=+sse2,-sse41 | grep movss | count 1
; RUN: llc < %s -march=x86 -mattr=+sse2,-sse41 | not grep pinsrw

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
}

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
}