From: Mike Stump Date: Fri, 13 Feb 2009 19:36:03 +0000 (+0000) Subject: Move DescriptorUniqueCount into CGM. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=324699105567f2948db316c3a3dc4c1d38a3657e;p=clang Move DescriptorUniqueCount into CGM. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@64481 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/CGBlocks.cpp b/lib/CodeGen/CGBlocks.cpp index d6c248dcef..e82569e281 100644 --- a/lib/CodeGen/CGBlocks.cpp +++ b/lib/CodeGen/CGBlocks.cpp @@ -65,10 +65,8 @@ llvm::Constant *CodeGenFunction::BuildDescriptorBlockDecl() { C = llvm::ConstantStruct::get(Elts); - // FIXME: Should be in module? - static int desc_unique_count; char Name[32]; - sprintf(Name, "__block_descriptor_tmp_%d", ++desc_unique_count); + sprintf(Name, "__block_descriptor_tmp_%d", CGM.getDescriptorUniqueCount()); C = new llvm::GlobalVariable(C->getType(), true, llvm::GlobalValue::InternalLinkage, C, Name, &CGM.getModule()); diff --git a/lib/CodeGen/CodeGenModule.cpp b/lib/CodeGen/CodeGenModule.cpp index 091158daba..2dbee58a82 100644 --- a/lib/CodeGen/CodeGenModule.cpp +++ b/lib/CodeGen/CodeGenModule.cpp @@ -52,6 +52,7 @@ CodeGenModule::CodeGenModule(ASTContext &C, const LangOptions &LO, DebugInfo = GenerateDebugInfo ? new CGDebugInfo(this) : 0; Block.GlobalUniqueCount = 0; + Block.DescriptorUniqueCount = 0; } CodeGenModule::~CodeGenModule() { diff --git a/lib/CodeGen/CodeGenModule.h b/lib/CodeGen/CodeGenModule.h index e79d18990d..020f74cddd 100644 --- a/lib/CodeGen/CodeGenModule.h +++ b/lib/CodeGen/CodeGenModule.h @@ -128,9 +128,10 @@ class CodeGenModule { llvm::Constant *NSConcreteStackBlock; const llvm::Type *BlockDescriptorType; - const llvm::Type * GenericBlockLiteralType; + const llvm::Type *GenericBlockLiteralType; struct { int GlobalUniqueCount; + int DescriptorUniqueCount; } Block; std::vector BuiltinFunctions; @@ -147,6 +148,7 @@ public: llvm::Constant *getNSConcreteGlobalBlock(); llvm::Constant *getNSConcreteStackBlock(); int getGlobalUniqueCount() { return ++Block.GlobalUniqueCount; } + int getDescriptorUniqueCount() { return ++Block.DescriptorUniqueCount; } const llvm::Type *getBlockDescriptorType(); const llvm::Type *getGenericBlockLiteralType();