diff options
| author | Daniel Dunbar <daniel@zuster.org> | 2012-03-02 16:24:25 +0000 | 
|---|---|---|
| committer | Daniel Dunbar <daniel@zuster.org> | 2012-03-02 16:24:25 +0000 | 
| commit | d01281fe0d14d65be578c5302319e386890c18ca (patch) | |
| tree | 3b2cd5905ec7a2e9a050694769bbaa1e71473c49 /clang/lib/CodeGen | |
| parent | 9370ecff74f35a6f352e072520dc6a2136083c5c (diff) | |
| download | bcm5719-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.cpp | 24 | 
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) { | 

