> On 2016-Feb-06, at 10:39, Adrian Prantl via cfe-commits > <cfe-commits@lists.llvm.org> wrote: > > Author: adrian > Date: Sat Feb 6 12:39:34 2016 > New Revision: 260002 > > URL: http://llvm.org/viewvc/llvm-project?rev=260002&view=rev > Log: > Add a missing call to MDNode::deleteTemporary(). > Follow-up to r259975. Kudos to the ASAN bots! > > <rdar://problem/24493203> > > Modified: > cfe/trunk/lib/CodeGen/CGDebugInfo.cpp > > Modified: cfe/trunk/lib/CodeGen/CGDebugInfo.cpp > URL: > http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/CGDebugInfo.cpp?rev=260002&r1=260001&r2=260002&view=diff > ============================================================================== > --- cfe/trunk/lib/CodeGen/CGDebugInfo.cpp (original) > +++ cfe/trunk/lib/CodeGen/CGDebugInfo.cpp Sat Feb 6 12:39:34 2016 > @@ -2056,19 +2056,20 @@ llvm::DIType *CGDebugInfo::CreateEnumTyp > // It is possible for enums to be created as part of their own > // declcontext. We need to cache a placeholder to avoid the type being > // created twice before hitting the cache. > - llvm::DIScope *EDContext = DBuilder.createReplaceableCompositeType( > + llvm::DIScope *TmpContext = DBuilder.createReplaceableCompositeType(
If you change this to: ``` llvm::TempDIScope TmpContext(DBuilder.create...()) ``` then the lifetime of `TmpContext` will get managed for you (it's a `std::unique_ptr<DIScope*, deleteTemporary()>`). Really, `DIBuilder` should return this instead of a `DIScope*`, so that it's clear what the lifetime is. > llvm::dwarf::DW_TAG_enumeration_type, "", TheCU, DefUnit, 0); > > unsigned Line = getLineNumber(ED->getLocation()); > StringRef EDName = ED->getName(); > llvm::DIType *RetTy = DBuilder.createReplaceableCompositeType( > - llvm::dwarf::DW_TAG_enumeration_type, EDName, EDContext, DefUnit, > Line, > + llvm::dwarf::DW_TAG_enumeration_type, EDName, TmpContext, DefUnit, > Line, > 0, Size, Align, llvm::DINode::FlagFwdDecl, FullName); > > // Cache the enum type so it is available when building the declcontext > // and replace the declcontect with the real thing. > TypeCache[Ty].reset(RetTy); > - EDContext->replaceAllUsesWith(getDeclContextDescriptor(ED)); > + TmpContext->replaceAllUsesWith(getDeclContextDescriptor(ED)); > + llvm::MDNode::deleteTemporary(TmpContext); > > ReplaceMap.emplace_back( > std::piecewise_construct, std::make_tuple(Ty), > > > _______________________________________________ > cfe-commits mailing list > cfe-commits@lists.llvm.org > http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits