From 6beddd668adf8e6bddbbc58ec02e4728dd889e9e Mon Sep 17 00:00:00 2001 From: Vladislav Dzhidzhoev Date: Wed, 8 Nov 2023 00:29:24 +0100 Subject: Revert "[DebugMetadata][DwarfDebug] Support function-local types in lexical block scopes (4/7)" This caused assert: llvm/llvm/lib/CodeGen/AsmPrinter/DwarfFile.cpp:110: void llvm::DwarfFile::addScopeVariable(LexicalScope *, DbgVariable *): Assertion `Ret.second' failed. See comments https://reviews.llvm.org/D144006#4656350. This reverts commit 3b449bd46a11a55a40cbc0016a99b202fa05248e. --- llvm/lib/IR/DIBuilder.cpp | 37 ++++++++++--------------------------- 1 file changed, 10 insertions(+), 27 deletions(-) (limited to 'llvm/lib/IR/DIBuilder.cpp') diff --git a/llvm/lib/IR/DIBuilder.cpp b/llvm/lib/IR/DIBuilder.cpp index d3e618b..1ce8c17 100644 --- a/llvm/lib/IR/DIBuilder.cpp +++ b/llvm/lib/IR/DIBuilder.cpp @@ -31,7 +31,7 @@ DIBuilder::DIBuilder(Module &m, bool AllowUnresolvedNodes, DICompileUnit *CU) AllowUnresolvedNodes(AllowUnresolvedNodes) { if (CUNode) { if (const auto &ETs = CUNode->getEnumTypes()) - EnumTypes.assign(ETs.begin(), ETs.end()); + AllEnumTypes.assign(ETs.begin(), ETs.end()); if (const auto &RTs = CUNode->getRetainedTypes()) AllRetainTypes.assign(RTs.begin(), RTs.end()); if (const auto &GVs = CUNode->getGlobalVariables()) @@ -68,10 +68,10 @@ void DIBuilder::finalize() { return; } - if (!EnumTypes.empty()) + if (!AllEnumTypes.empty()) CUNode->replaceEnumTypes(MDTuple::get( - VMContext, SmallVector(EnumTypes.begin(), - EnumTypes.end()))); + VMContext, SmallVector(AllEnumTypes.begin(), + AllEnumTypes.end()))); SmallVector RetainValues; // Declarations and definitions of the same type may be retained. Some @@ -336,13 +336,10 @@ DIDerivedType *DIBuilder::createTypedef(DIType *Ty, StringRef Name, DIScope *Context, uint32_t AlignInBits, DINode::DIFlags Flags, DINodeArray Annotations) { - auto *T = - DIDerivedType::get(VMContext, dwarf::DW_TAG_typedef, Name, File, LineNo, - getNonCompileUnitScope(Context), Ty, 0, AlignInBits, 0, - std::nullopt, Flags, nullptr, Annotations); - if (isa_and_nonnull(Context)) - getSubprogramNodesTrackingVector(Context).emplace_back(T); - return T; + return DIDerivedType::get(VMContext, dwarf::DW_TAG_typedef, Name, File, + LineNo, getNonCompileUnitScope(Context), Ty, 0, + AlignInBits, 0, std::nullopt, Flags, nullptr, + Annotations); } DIDerivedType *DIBuilder::createFriend(DIType *Ty, DIType *FriendTy) { @@ -490,8 +487,6 @@ DICompositeType *DIBuilder::createClassType( OffsetInBits, Flags, Elements, 0, VTableHolder, cast_or_null(TemplateParams), UniqueIdentifier); trackIfUnresolved(R); - if (isa_and_nonnull(Context)) - getSubprogramNodesTrackingVector(Context).emplace_back(R); return R; } @@ -505,8 +500,6 @@ DICompositeType *DIBuilder::createStructType( getNonCompileUnitScope(Context), DerivedFrom, SizeInBits, AlignInBits, 0, Flags, Elements, RunTimeLang, VTableHolder, nullptr, UniqueIdentifier); trackIfUnresolved(R); - if (isa_and_nonnull(Context)) - getSubprogramNodesTrackingVector(Context).emplace_back(R); return R; } @@ -519,8 +512,6 @@ DICompositeType *DIBuilder::createUnionType( getNonCompileUnitScope(Scope), nullptr, SizeInBits, AlignInBits, 0, Flags, Elements, RunTimeLang, nullptr, nullptr, UniqueIdentifier); trackIfUnresolved(R); - if (isa_and_nonnull(Scope)) - getSubprogramNodesTrackingVector(Scope).emplace_back(R); return R; } @@ -553,10 +544,7 @@ DICompositeType *DIBuilder::createEnumerationType( getNonCompileUnitScope(Scope), UnderlyingType, SizeInBits, AlignInBits, 0, IsScoped ? DINode::FlagEnumClass : DINode::FlagZero, Elements, 0, nullptr, nullptr, UniqueIdentifier); - if (isa_and_nonnull(Scope)) - getSubprogramNodesTrackingVector(Scope).emplace_back(CTy); - else - EnumTypes.emplace_back(CTy); + AllEnumTypes.emplace_back(CTy); trackIfUnresolved(CTy); return CTy; } @@ -637,8 +625,7 @@ void DIBuilder::retainType(DIScope *T) { assert((isa(T) || (isa(T) && cast(T)->isDefinition() == false)) && "Expected type or subprogram declaration"); - if (!isa_and_nonnull(T->getScope())) - AllRetainTypes.emplace_back(T); + AllRetainTypes.emplace_back(T); } DIBasicType *DIBuilder::createUnspecifiedParameter() { return nullptr; } @@ -655,8 +642,6 @@ DIBuilder::createForwardDecl(unsigned Tag, StringRef Name, DIScope *Scope, SizeInBits, AlignInBits, 0, DINode::FlagFwdDecl, nullptr, RuntimeLang, nullptr, nullptr, UniqueIdentifier); trackIfUnresolved(RetTy); - if (isa_and_nonnull(Scope)) - getSubprogramNodesTrackingVector(Scope).emplace_back(RetTy); return RetTy; } @@ -673,8 +658,6 @@ DICompositeType *DIBuilder::createReplaceableCompositeType( nullptr, Annotations) .release(); trackIfUnresolved(RetTy); - if (isa_and_nonnull(Scope)) - getSubprogramNodesTrackingVector(Scope).emplace_back(RetTy); return RetTy; } -- cgit v1.1