aboutsummaryrefslogtreecommitdiff
path: root/lib/CodeGen/CGExprConstant.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2008-10-06 05:59:01 +0000
committerChris Lattner <sabre@nondot.org>2008-10-06 05:59:01 +0000
commitf6b24ea67b5898295e2fc645327837037462a0fd (patch)
treee331b7f2d7f0aeccea367a1d53b97c0b76ee3ec1 /lib/CodeGen/CGExprConstant.cpp
parent34a74ab81600a40c6324fd76adb724b803dfaf91 (diff)
instead of making codegen try to know about all of the builtins to generate
constants for them, just use the constant evaluator to do the job. This also fixes crashes on 'unknown constant builtins'. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@57155 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/CGExprConstant.cpp')
-rw-r--r--lib/CodeGen/CGExprConstant.cpp31
1 files changed, 8 insertions, 23 deletions
diff --git a/lib/CodeGen/CGExprConstant.cpp b/lib/CodeGen/CGExprConstant.cpp
index e0c39c9cba..50f0d12240 100644
--- a/lib/CodeGen/CGExprConstant.cpp
+++ b/lib/CodeGen/CGExprConstant.cpp
@@ -14,6 +14,7 @@
#include "CodeGenFunction.h"
#include "CodeGenModule.h"
#include "CGObjCRuntime.h"
+#include "clang/AST/APValue.h"
#include "clang/AST/ASTContext.h"
#include "clang/AST/StmtVisitor.h"
#include "llvm/Constants.h"
@@ -608,14 +609,13 @@ public:
}
llvm::Constant *VisitCallExpr(const CallExpr *E) {
- if (const ImplicitCastExpr *IcExpr =
- dyn_cast<const ImplicitCastExpr>(E->getCallee()))
- if (const DeclRefExpr *DRExpr =
- dyn_cast<const DeclRefExpr>(IcExpr->getSubExpr()))
- if (const FunctionDecl *FDecl =
- dyn_cast<const FunctionDecl>(DRExpr->getDecl()))
- if (unsigned builtinID = FDecl->getIdentifier()->getBuiltinID())
- return EmitBuiltinExpr(builtinID, E);
+ APValue Result;
+ if (E->tryEvaluate(Result, CGM.getContext())) {
+ if (Result.isInt())
+ return llvm::ConstantInt::get(Result.getInt());
+ if (Result.isFloat())
+ return llvm::ConstantFP::get(Result.getFloat());
+ }
CGM.ErrorUnsupported(E, "constant call expression");
return llvm::Constant::getNullValue(ConvertType(E->getType()));
@@ -818,21 +818,6 @@ public:
llvm::Type *Ty = llvm::PointerType::getUnqual(ConvertType(E->getType()));
return llvm::UndefValue::get(Ty);
}
-
- llvm::Constant *EmitBuiltinExpr(unsigned BuiltinID, const CallExpr *E)
- {
- switch (BuiltinID) {
- default:
- CGM.ErrorUnsupported(E, "constant builtin function");
- return 0;
- case Builtin::BI__builtin_huge_valf: {
- const llvm::fltSemantics &Sem =
- CGM.getContext().getFloatTypeSemantics(E->getType());
- return llvm::ConstantFP::get(llvm::APFloat::getInf(Sem));
- }
- }
- }
-
};
} // end anonymous namespace.