llvm.org GIT mirror llvm / 8975f51 test / CodeGen / X86 / fp-trunc.ll
8975f51

Tree @8975f51 (Download .tar.gz)

fp-trunc.ll @8975f51raw · history · blame

; RUN: llc < %s -march=x86 -mattr=+sse2,-avx | FileCheck %s

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
}