diff options
author | Richard Smith <richard-llvm@metafoo.co.uk> | 2012-03-02 23:27:11 +0000 |
---|---|---|
committer | Richard Smith <richard-llvm@metafoo.co.uk> | 2012-03-02 23:27:11 +0000 |
commit | a3ca41f0c2bd1c4a752df88b283332f3b757d21e (patch) | |
tree | 8aab234057f7a0c60c5d1bc20ad31ebb07d5977e /lib/CodeGen/CGExprScalar.cpp | |
parent | 067cc40308a9643400fd291fc8678c4a6785e90c (diff) |
Reinstate r151879, r151880, reverted in r151922, along with a bugfix for
scalar emission of DeclRefExprs to const bools: emit scalar bools as i1,
not as i8.
In addition to the extra unit testing, this has successfully bootstrapped.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@151955 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/CGExprScalar.cpp')
-rw-r--r-- | lib/CodeGen/CGExprScalar.cpp | 24 |
1 files changed, 15 insertions, 9 deletions
diff --git a/lib/CodeGen/CGExprScalar.cpp b/lib/CodeGen/CGExprScalar.cpp index 125e431bff..f7ab880e6c 100644 --- a/lib/CodeGen/CGExprScalar.cpp +++ b/lib/CodeGen/CGExprScalar.cpp @@ -212,18 +212,21 @@ public: // l-values. Value *VisitDeclRefExpr(DeclRefExpr *E) { Expr::EvalResult Result; - if (!E->EvaluateAsRValue(Result, CGF.getContext())) - return EmitLoadOfLValue(E); + bool IsReferenceConstant = false; + QualType EvalTy = E->getType(); + if (!E->EvaluateAsRValue(Result, CGF.getContext())) { + // If this is a reference, try to determine what it is bound to. + if (!E->getDecl()->getType()->isReferenceType() || + !E->EvaluateAsLValue(Result, CGF.getContext())) + return EmitLoadOfLValue(E); + + IsReferenceConstant = true; + EvalTy = E->getDecl()->getType(); + } assert(!Result.HasSideEffects && "Constant declref with side-effect?!"); - llvm::Constant *C; - if (Result.Val.isInt()) - C = Builder.getInt(Result.Val.getInt()); - else if (Result.Val.isFloat()) - C = llvm::ConstantFP::get(VMContext, Result.Val.getFloat()); - else - return EmitLoadOfLValue(E); + llvm::Constant *C = CGF.CGM.EmitConstantValue(Result.Val, EvalTy, &CGF); // Make sure we emit a debug reference to the global variable. if (VarDecl *VD = dyn_cast<VarDecl>(E->getDecl())) { @@ -233,6 +236,9 @@ public: CGF.EmitDeclRefExprDbgValue(E, C); } + if (IsReferenceConstant) + return EmitLoadOfLValue(CGF.MakeNaturalAlignAddrLValue(C, E->getType())); + return C; } Value *VisitObjCSelectorExpr(ObjCSelectorExpr *E) { |