2011-04-25 12:12:01 +02:00
|
|
|
; RUN: llc < %s -march=x86 -mattr=+sse2,-avx | FileCheck %s
|
2011-03-23 23:18:48 +01:00
|
|
|
|
|
|
|
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
|
|
|
|
}
|
|
|
|
|
|
|
|
|