From: Richard Smith Date: Wed, 7 Mar 2012 01:58:44 +0000 (+0000) Subject: Don't even try to directly emit the value of a DeclRefExpr if that declaration X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=946e2726f91c17574d248f9c4b3eeea41e892a22;p=clang Don't even try to directly emit the value of a DeclRefExpr if that declaration is not usable in a constant expression. ~2.5% speedup on 403.gcc / combine.c. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@152193 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/CGExprScalar.cpp b/lib/CodeGen/CGExprScalar.cpp index d5ef402d22..8ed36aac5f 100644 --- a/lib/CodeGen/CGExprScalar.cpp +++ b/lib/CodeGen/CGExprScalar.cpp @@ -214,6 +214,14 @@ public: // l-values. Value *VisitDeclRefExpr(DeclRefExpr *E) { + VarDecl *VD = dyn_cast(E->getDecl()); + if (!VD && !isa(E->getDecl())) + return EmitLoadOfLValue(E); + if (VD && !VD->isUsableInConstantExpressions()) + return EmitLoadOfLValue(E); + + // This is an enumerator or a variable which is usable in constant + // expressions. Try to emit its value instead. Expr::EvalResult Result; bool IsReferenceConstant = false; QualType EvalTy = E->getType(); @@ -232,10 +240,11 @@ public: 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(E->getDecl())) { + if (VD) { if (!CGF.getContext().DeclMustBeEmitted(VD)) CGF.EmitDeclRefExprDbgValue(E, C); - } else if (isa(E->getDecl())) { + } else { + assert(isa(E->getDecl())); CGF.EmitDeclRefExprDbgValue(E, C); } diff --git a/test/CodeGenCXX/const-init-cxx11.cpp b/test/CodeGenCXX/const-init-cxx11.cpp index a1486c1175..8d92b81feb 100644 --- a/test/CodeGenCXX/const-init-cxx11.cpp +++ b/test/CodeGenCXX/const-init-cxx11.cpp @@ -370,7 +370,7 @@ namespace InitFromConst { const bool b = true; const int n = 5; - const double d = 4.3; + constexpr double d = 4.3; struct S { int n = 7; S *p = 0; }; constexpr S s = S();