summaryrefslogtreecommitdiffstats
path: root/clang/lib/CodeGen/CGBuiltin.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2008-10-06 06:31:58 +0000
committerChris Lattner <sabre@nondot.org>2008-10-06 06:31:58 +0000
commit0b7282eafc08ca4b40cf364ee772c52ab6428b2a (patch)
treef4127cd9163a96ffe0e913bca1d7032f0818383f /clang/lib/CodeGen/CGBuiltin.cpp
parenta1518b1dfe63f459cafb38394c4728fb96643b31 (diff)
downloadbcm5719-llvm-0b7282eafc08ca4b40cf364ee772c52ab6428b2a.tar.gz
bcm5719-llvm-0b7282eafc08ca4b40cf364ee772c52ab6428b2a.zip
Move handling of __builtin_nan("") out of CGBuiltin.cpp into ExprConstant.cpp
llvm-svn: 57157
Diffstat (limited to 'clang/lib/CodeGen/CGBuiltin.cpp')
-rw-r--r--clang/lib/CodeGen/CGBuiltin.cpp23
1 files changed, 5 insertions, 18 deletions
diff --git a/clang/lib/CodeGen/CGBuiltin.cpp b/clang/lib/CodeGen/CGBuiltin.cpp
index 10b47f1a489..99a3463a221 100644
--- a/clang/lib/CodeGen/CGBuiltin.cpp
+++ b/clang/lib/CodeGen/CGBuiltin.cpp
@@ -46,11 +46,14 @@ RValue CodeGenFunction::EmitBuiltinExpr(unsigned BuiltinID, const CallExpr *E) {
case Builtin::BI__builtin_inf:
case Builtin::BI__builtin_inff:
case Builtin::BI__builtin_infl:
+ case Builtin::BI__builtin_nan:
+ case Builtin::BI__builtin_nanf:
+ case Builtin::BI__builtin_nanl:
case Builtin::BI__builtin_classify_type:
case Builtin::BI__builtin_constant_p: {
APValue Result;
- bool IsCst = E->tryEvaluate(Result, CGM.getContext());
- assert(IsCst && "These must all be constants!");
+ if (!E->tryEvaluate(Result, CGM.getContext()))
+ break; // Not a constant, expand below.
if (Result.isInt())
return RValue::get(llvm::ConstantInt::get(Result.getInt()));
@@ -231,22 +234,6 @@ RValue CodeGenFunction::EmitBuiltinExpr(unsigned BuiltinID, const CallExpr *E) {
return RValue::get(Builder.CreateCall(F));
}
- case Builtin::BI__builtin_nan:
- case Builtin::BI__builtin_nanf:
- case Builtin::BI__builtin_nanl: {
- // If this is __builtin_nan("") turn this into a simple nan, otherwise just
- // call libm nan.
- if (const StringLiteral *S =
- dyn_cast<StringLiteral>(E->getArg(0)->IgnoreParenCasts())) {
- if (!S->isWide() && S->getByteLength() == 0) { // empty string.
- const llvm::fltSemantics &Sem =
- CGM.getContext().getFloatTypeSemantics(E->getType());
- return RValue::get(ConstantFP::get(APFloat::getNaN(Sem)));
- }
- }
- // Otherwise, call libm 'nan'.
- break;
- }
case Builtin::BI__builtin_powi:
case Builtin::BI__builtin_powif:
case Builtin::BI__builtin_powil: {
OpenPOWER on IntegriCloud