Don't try to constant fold libm functions with non-finite arguments.

Usually we wouldn't do this anyway because llvm_fenv_testexcept would return an
exception, but we have seen some cases where neither errno nor fenv detect an
exception on arm-linux.

llvm-svn: 114893
This commit is contained in:
Jakob Stoklund Olesen 2010-09-27 21:29:20 +00:00
parent 11fed543c9
commit 1083573796
2 changed files with 7 additions and 5 deletions

View File

@ -1094,6 +1094,13 @@ llvm::ConstantFoldCall(Function *F,
if (!Ty->isFloatTy() && !Ty->isDoubleTy())
return 0;
/// We only fold functions with finite arguments. Folding NaN and inf is
/// likely to be aborted with an exception anyway, and some host libms
/// have known errors raising exceptions.
if (Op->getValueAPF().isNaN() || Op->getValueAPF().isInfinity())
return 0;
/// Currently APFloat versions of these functions do not exist, so we use
/// the host native double versions. Float versions are not called
/// directly but for all these it is true (float)(f((double)arg)) ==

View File

@ -1,10 +1,5 @@
; RUN: opt -instcombine -S < %s | FileCheck %s
; This test is inexplicably still failing, which suggests a bug in the host
; libm. It appears that sin(inf) returns NaN without setting a floating point
; exception.
; XFAIL: arm-pc-linux-gnu
; This shouldn't fold, because sin(inf) is invalid.
; CHECK: @foo
; CHECK: %t = call double @sin(double 0x7FF0000000000000)