summaryrefslogtreecommitdiffstats
path: root/clang/lib/CodeGen
diff options
context:
space:
mode:
authorDaniel Dunbar <daniel@zuster.org>2012-03-02 16:24:25 +0000
committerDaniel Dunbar <daniel@zuster.org>2012-03-02 16:24:25 +0000
commitd01281fe0d14d65be578c5302319e386890c18ca (patch)
tree3b2cd5905ec7a2e9a050694769bbaa1e71473c49 /clang/lib/CodeGen
parent9370ecff74f35a6f352e072520dc6a2136083c5c (diff)
downloadbcm5719-llvm-d01281fe0d14d65be578c5302319e386890c18ca.tar.gz
bcm5719-llvm-d01281fe0d14d65be578c5302319e386890c18ca.zip
Revert r151879, r151880, "PR12145: Avoid emitting loads of constexpr variables in contexts where there" and "Fix buildbot: make this test less dependent on the value names in the produced IR."
They broke bootstrap. llvm-svn: 151922
Diffstat (limited to 'clang/lib/CodeGen')
-rw-r--r--clang/lib/CodeGen/CGExprScalar.cpp24
1 files changed, 9 insertions, 15 deletions
diff --git a/clang/lib/CodeGen/CGExprScalar.cpp b/clang/lib/CodeGen/CGExprScalar.cpp
index f7ab880e6cd..125e431bff0 100644
--- a/clang/lib/CodeGen/CGExprScalar.cpp
+++ b/clang/lib/CodeGen/CGExprScalar.cpp
@@ -212,21 +212,18 @@ public:
// l-values.
Value *VisitDeclRefExpr(DeclRefExpr *E) {
Expr::EvalResult Result;
- 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();
- }
+ if (!E->EvaluateAsRValue(Result, CGF.getContext()))
+ return EmitLoadOfLValue(E);
assert(!Result.HasSideEffects && "Constant declref with side-effect?!");
- llvm::Constant *C = CGF.CGM.EmitConstantValue(Result.Val, EvalTy, &CGF);
+ 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);
// Make sure we emit a debug reference to the global variable.
if (VarDecl *VD = dyn_cast<VarDecl>(E->getDecl())) {
@@ -236,9 +233,6 @@ public:
CGF.EmitDeclRefExprDbgValue(E, C);
}
- if (IsReferenceConstant)
- return EmitLoadOfLValue(CGF.MakeNaturalAlignAddrLValue(C, E->getType()));
-
return C;
}
Value *VisitObjCSelectorExpr(ObjCSelectorExpr *E) {
OpenPOWER on IntegriCloud