From f99a02005970cdcb0aad0de80fa4e5b546c6546b Mon Sep 17 00:00:00 2001 From: Stephen Tozer Date: Fri, 17 Nov 2023 17:52:24 +0000 Subject: Reapply "[DebugInfo] Make DIArgList inherit from Metadata and always unique" This reverts commit 0fd5dc94380d5fe666dc6c603b4bb782cef743e7. The original commit removed DIArgLists from being in an MDNode map, but did not insert a new `delete` in the LLVMContextImpl destructor. This reapply adds that call to delete, preventing a memory leak. --- llvm/lib/Bitcode/Writer/BitcodeWriter.cpp | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) (limited to 'llvm/lib/Bitcode/Writer/BitcodeWriter.cpp') diff --git a/llvm/lib/Bitcode/Writer/BitcodeWriter.cpp b/llvm/lib/Bitcode/Writer/BitcodeWriter.cpp index d16b5c7..9c21cc6 100644 --- a/llvm/lib/Bitcode/Writer/BitcodeWriter.cpp +++ b/llvm/lib/Bitcode/Writer/BitcodeWriter.cpp @@ -336,8 +336,7 @@ private: unsigned Abbrev); void writeDIMacroFile(const DIMacroFile *N, SmallVectorImpl &Record, unsigned Abbrev); - void writeDIArgList(const DIArgList *N, SmallVectorImpl &Record, - unsigned Abbrev); + void writeDIArgList(const DIArgList *N, SmallVectorImpl &Record); void writeDIModule(const DIModule *N, SmallVectorImpl &Record, unsigned Abbrev); void writeDIAssignID(const DIAssignID *N, SmallVectorImpl &Record, @@ -1975,13 +1974,12 @@ void ModuleBitcodeWriter::writeDIMacroFile(const DIMacroFile *N, } void ModuleBitcodeWriter::writeDIArgList(const DIArgList *N, - SmallVectorImpl &Record, - unsigned Abbrev) { + SmallVectorImpl &Record) { Record.reserve(N->getArgs().size()); for (ValueAsMetadata *MD : N->getArgs()) Record.push_back(VE.getMetadataID(MD)); - Stream.EmitRecord(bitc::METADATA_ARG_LIST, Record, Abbrev); + Stream.EmitRecord(bitc::METADATA_ARG_LIST, Record); Record.clear(); } @@ -2264,6 +2262,10 @@ void ModuleBitcodeWriter::writeMetadataRecords( #include "llvm/IR/Metadata.def" } } + if (auto *AL = dyn_cast(MD)) { + writeDIArgList(AL, Record); + continue; + } writeValueAsMetadata(cast(MD), Record); } } -- cgit v1.1