From b9ce8b3f1b34bace8a5201fb78a4f7f9fcbf079e Mon Sep 17 00:00:00 2001 From: Reid Spencer Date: Mon, 6 Dec 2004 22:18:37 +0000 Subject: [PATCH] For PR409: \ Test the range of float constants to ensure we are not attempting to create a \ float constant using a double value that is out of range for a float git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@18585 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/VMCore/Constants.cpp | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/lib/VMCore/Constants.cpp b/lib/VMCore/Constants.cpp index 97e4fa565c7..c97d9fc8d39 100644 --- a/lib/VMCore/Constants.cpp +++ b/lib/VMCore/Constants.cpp @@ -21,6 +21,7 @@ #include "llvm/ADT/StringExtras.h" #include #include +#include using namespace llvm; ConstantBool *ConstantBool::True = new ConstantBool(true); @@ -442,6 +443,16 @@ bool ConstantFP::isValueValidForType(const Type *Ty, double Val) { // TODO: Figure out how to test if a double can be cast to a float! case Type::FloatTyID: + return + (std::numeric_limits::has_infinity && + std::numeric_limits::has_infinity && + Val == std::numeric_limits::infinity()) || + (std::numeric_limits::has_quiet_NaN && + std::numeric_limits::has_quiet_NaN && + Val == std::numeric_limits::quiet_NaN()) || + (Val >= -std::numeric_limits::max() && + Val <= std::numeric_limits::max()); + case Type::DoubleTyID: return true; // This is the largest type... }