forked from OSchip/llvm-project
36 lines
791 B
LLVM
36 lines
791 B
LLVM
|
; RUN: llc < %s -march=x86 -mattr=+sse2,-avx
|
||
|
|
||
|
define <1 x float> @test1(<1 x double> %x) nounwind {
|
||
|
; CHECK: cvtsd2ss
|
||
|
; CHECK: ret
|
||
|
%y = fptrunc <1 x double> %x to <1 x float>
|
||
|
ret <1 x float> %y
|
||
|
}
|
||
|
|
||
|
|
||
|
define <2 x float> @test2(<2 x double> %x) nounwind {
|
||
|
; FIXME: It would be nice if this compiled down to a cvtpd2ps
|
||
|
; CHECK: cvtsd2ss
|
||
|
; CHECK: cvtsd2ss
|
||
|
; CHECK: ret
|
||
|
%y = fptrunc <2 x double> %x to <2 x float>
|
||
|
ret <2 x float> %y
|
||
|
}
|
||
|
|
||
|
define <8 x float> @test3(<8 x double> %x) nounwind {
|
||
|
; FIXME: It would be nice if this compiled down to a series of cvtpd2ps
|
||
|
; CHECK: cvtsd2ss
|
||
|
; CHECK: cvtsd2ss
|
||
|
; CHECK: cvtsd2ss
|
||
|
; CHECK: cvtsd2ss
|
||
|
; CHECK: cvtsd2ss
|
||
|
; CHECK: cvtsd2ss
|
||
|
; CHECK: cvtsd2ss
|
||
|
; CHECK: cvtsd2ss
|
||
|
; CHECK: ret
|
||
|
%y = fptrunc <8 x double> %x to <8 x float>
|
||
|
ret <8 x float> %y
|
||
|
}
|
||
|
|
||
|
|