diff options
author | Chris Lattner <sabre@nondot.org> | 2008-10-06 06:56:41 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2008-10-06 06:56:41 +0000 |
commit | 564ea2a99b3afeac9ded332730a56db1f6358a58 (patch) | |
tree | 206833022bc3024869f3126b93ef6633a970cbec | |
parent | 6b47561af738b33c55c60776c3b095f049902308 (diff) |
always try to fold a builtin before emitting it. In the future
it is possible that a builtin could sometimes be folded (e.g. __builtin_clz)
if it's operand is a constant.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@57161 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/CodeGen/CGBuiltin.cpp | 23 |
1 files changed, 5 insertions, 18 deletions
diff --git a/lib/CodeGen/CGBuiltin.cpp b/lib/CodeGen/CGBuiltin.cpp index 99a3463a22..fc7cc02710 100644 --- a/lib/CodeGen/CGBuiltin.cpp +++ b/lib/CodeGen/CGBuiltin.cpp @@ -37,30 +37,17 @@ static RValue EmitBinaryAtomic(CodeGenFunction& CFG, } RValue CodeGenFunction::EmitBuiltinExpr(unsigned BuiltinID, const CallExpr *E) { - switch (BuiltinID) { - default: break; // Handle intrinsics and libm functions below. - - case Builtin::BI__builtin_huge_val: - case Builtin::BI__builtin_huge_valf: - case Builtin::BI__builtin_huge_vall: - 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; - if (!E->tryEvaluate(Result, CGM.getContext())) - break; // Not a constant, expand below. - + // See if we can constant fold this builtin. If so, don't emit it at all. + APValue Result; + if (E->tryEvaluate(Result, CGM.getContext())) { if (Result.isInt()) return RValue::get(llvm::ConstantInt::get(Result.getInt())); assert(Result.isFloat() && "Unsupported constant type"); return RValue::get(llvm::ConstantFP::get(Result.getFloat())); } + switch (BuiltinID) { + default: break; // Handle intrinsics and libm functions below. case Builtin::BI__builtin___CFStringMakeConstantString: { const Expr *Arg = E->getArg(0); |