From a9cb6261bf18eaadec77c52a275bd4de45a47aa6 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Sat, 21 Mar 2009 08:06:59 +0000 Subject: [PATCH] reduce redundant calls of getMangledName. llvm-svn: 67440 --- clang/lib/CodeGen/CodeGenModule.cpp | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/clang/lib/CodeGen/CodeGenModule.cpp b/clang/lib/CodeGen/CodeGenModule.cpp index 38b8d36ed516..04b423eeb322 100644 --- a/clang/lib/CodeGen/CodeGenModule.cpp +++ b/clang/lib/CodeGen/CodeGenModule.cpp @@ -398,13 +398,13 @@ void CodeGenModule::EmitAliases() { continue; } + const char *MangledName = getMangledName(D); llvm::GlobalValue *GA = new llvm::GlobalAlias(aliasee->getType(), llvm::Function::ExternalLinkage, - getMangledName(D), aliasee, - &getModule()); + MangledName, aliasee, &getModule()); - llvm::GlobalValue *&Entry = GlobalDeclMap[getMangledName(D)]; + llvm::GlobalValue *&Entry = GlobalDeclMap[MangledName]; if (Entry) { // If we created a dummy function for this then replace it. GA->takeName(Entry); @@ -597,7 +597,8 @@ void CodeGenModule::EmitGlobalDefinition(const ValueDecl *D) { const llvm::Type *Ty = getTypes().ConvertTypeForMem(ASTTy); // Lookup the entry, lazily creating it if necessary. - llvm::GlobalValue *&Entry = GlobalDeclMap[getMangledName(D)]; + const char *MangledName = getMangledName(D); + llvm::GlobalValue *&Entry = GlobalDeclMap[MangledName]; if (Entry) { const llvm::Type *PTy = llvm::PointerType::get(Ty, ASTTy.getAddressSpace()); @@ -610,7 +611,7 @@ void CodeGenModule::EmitGlobalDefinition(const ValueDecl *D) { llvm::GlobalVariable *GV = new llvm::GlobalVariable(Ty, false, llvm::GlobalValue::ExternalLinkage, - 0, getMangledName(D), &getModule(), + 0, MangledName, &getModule(), 0, ASTTy.getAddressSpace()); // Handle things which are present even on external declarations. @@ -665,13 +666,14 @@ void CodeGenModule::EmitGlobalVarDefinition(const VarDecl *D) { } const llvm::Type* InitType = Init->getType(); - llvm::GlobalValue *&Entry = GlobalDeclMap[getMangledName(D)]; + const char *MangledName = getMangledName(D); + llvm::GlobalValue *&Entry = GlobalDeclMap[MangledName]; llvm::GlobalVariable *GV = cast_or_null(Entry); if (!GV) { GV = new llvm::GlobalVariable(InitType, false, llvm::GlobalValue::ExternalLinkage, - 0, getMangledName(D), + 0, MangledName, &getModule(), 0, ASTTy.getAddressSpace()); } else if (GV->hasInitializer() && !GV->getInitializer()->isNullValue()) { @@ -715,7 +717,7 @@ void CodeGenModule::EmitGlobalVarDefinition(const VarDecl *D) { // Make a new global with the correct type GV = new llvm::GlobalVariable(InitType, false, llvm::GlobalValue::ExternalLinkage, - 0, getMangledName(D), + 0, MangledName, &getModule(), 0, ASTTy.getAddressSpace()); // Steal the name of the old global GV->takeName(OldGV);