r260002 - Add a missing call to MDNode::deleteTemporary().

Adrian Prantl via cfe-commits cfe-commits at lists.llvm.org
Mon Feb 8 09:09:23 PST 2016


> On Feb 6, 2016, at 12:38 PM, Duncan P. N. Exon Smith <dexonsmith at apple.com> wrote:
> 
>> 
>> On 2016-Feb-06, at 10:39, Adrian Prantl via cfe-commits <cfe-commits at 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.

That’s much better, thanks!

r260113

-- adrian


> 
>>      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 at lists.llvm.org
>> http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits



More information about the cfe-commits mailing list