llvm-6502/test/CodeGen/X86/fabs.ll
2006-12-02 04:23:10 +00:00

22 lines
652 B
LLVM

; Make sure this testcase codegens to the fabs instruction, not a call to fabsf
; RUN: llvm-upgrade < %s | llvm-as | llc -march=x86 -mattr=-sse2,-sse3 | grep 'fabs$' | wc -l | grep 1 &&
; RUN: llvm-upgrade < %s | llvm-as | llc -march=x86 -mattr=-sse2,-sse3 -enable-unsafe-fp-math | grep 'fabs$' | wc -l | grep 2
target endian = little
target pointersize = 32
declare float %fabsf(float)
float %test1(float %X) {
%Y = call float %fabsf(float %X)
ret float %Y
}
double %test2(double %X) {
%Y = setge double %X, -0.0
%Z = sub double -0.0, %X
%Q = select bool %Y, double %X, double %Z
ret double %Q
}