llvm.org GIT mirror llvm / 0a6ee6d test / CodeGen / X86 / vec_insert.ll
0a6ee6d

Tree @0a6ee6d (Download .tar.gz)

vec_insert.ll @0a6ee6d

794405e
 
f4649a5
794405e
 
 
 
 
f4649a5
 
 
 
794405e
 
 
 
f4649a5
 
 
; RUN: llvm-as < %s | llc -march=x86 -mattr=+sse2 | grep movss | count 1
; RUN: llvm-as < %s | llc -march=x86 -mattr=+sse2 | not grep pinsrw

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 = add <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) {
	%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
}