From 47640221da40680d17b0b18d5ce61f4cd6382a14 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Sun, 22 Mar 2009 00:24:14 +0000 Subject: [PATCH] fix CreateTempAlloca to not set a name on the alloca for temporaries in release-assert builds. For automatic variables, explicitly set a name with setName that does not make a temporary std::string. This speeds up -emit-llvm-only -disable-free on PR3810 by 4.6% llvm-svn: 67459 --- clang/lib/CodeGen/CGDecl.cpp | 8 +++++--- clang/lib/CodeGen/CGExpr.cpp | 3 ++- clang/lib/CodeGen/CodeGenFunction.cpp | 6 ++++-- 3 files changed, 11 insertions(+), 6 deletions(-) diff --git a/clang/lib/CodeGen/CGDecl.cpp b/clang/lib/CodeGen/CGDecl.cpp index 8a4febeecfb3..49ac20a9bcde 100644 --- a/clang/lib/CodeGen/CGDecl.cpp +++ b/clang/lib/CodeGen/CGDecl.cpp @@ -232,8 +232,9 @@ void CodeGenFunction::EmitLocalBlockVarDecl(const VarDecl &D) { const llvm::Type *LTy = ConvertTypeForMem(Ty); if (isByRef) LTy = BuildByRefType(Ty, getContext().getDeclAlignInBytes(&D)); - llvm::AllocaInst *Alloc = - CreateTempAlloca(LTy, D.getNameAsString().c_str()); + llvm::AllocaInst *Alloc = CreateTempAlloca(LTy); + Alloc->setName(D.getNameAsString().c_str()); + if (isByRef) Alloc->setAlignment(std::max(getContext().getDeclAlignInBytes(&D), getContext().getTypeAlign(getContext().VoidPtrTy) / 8)); @@ -429,7 +430,8 @@ void CodeGenFunction::EmitParmDecl(const VarDecl &D, llvm::Value *Arg) { // TODO: Alignment std::string Name = D.getNameAsString(); Name += ".addr"; - DeclPtr = CreateTempAlloca(LTy, Name.c_str()); + DeclPtr = CreateTempAlloca(LTy); + DeclPtr->setName(Name.c_str()); // Store the initial value into the alloca. EmitStoreOfScalar(Arg, DeclPtr, Ty.isVolatileQualified()); diff --git a/clang/lib/CodeGen/CGExpr.cpp b/clang/lib/CodeGen/CGExpr.cpp index d34b0f5ea38b..45cd6a70a5de 100644 --- a/clang/lib/CodeGen/CGExpr.cpp +++ b/clang/lib/CodeGen/CGExpr.cpp @@ -29,7 +29,8 @@ using namespace CodeGen; /// block. llvm::AllocaInst *CodeGenFunction::CreateTempAlloca(const llvm::Type *Ty, const char *Name) { - // FIXME: Should not pass name if names are disabled in IRBuilder. + if (!Builder.isNamePreserving()) + Name = ""; return new llvm::AllocaInst(Ty, 0, Name, AllocaInsertPt); } diff --git a/clang/lib/CodeGen/CodeGenFunction.cpp b/clang/lib/CodeGen/CodeGenFunction.cpp index 441c9fcdbf6e..1d9f0f844eb7 100644 --- a/clang/lib/CodeGen/CodeGenFunction.cpp +++ b/clang/lib/CodeGen/CodeGenFunction.cpp @@ -163,9 +163,11 @@ void CodeGenFunction::StartFunction(const Decl *D, QualType RetTy, // later. Don't create this with the builder, because we don't want it // folded. llvm::Value *Undef = llvm::UndefValue::get(llvm::Type::Int32Ty); - AllocaInsertPt = new llvm::BitCastInst(Undef, llvm::Type::Int32Ty, "allocapt", + AllocaInsertPt = new llvm::BitCastInst(Undef, llvm::Type::Int32Ty, "", EntryBB); - + if (Builder.isNamePreserving()) + AllocaInsertPt->setName("allocapt"); + ReturnBlock = createBasicBlock("return"); ReturnValue = 0; if (!RetTy->isVoidType())