aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib
diff options
context:
space:
mode:
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/MC/MCCodeView.cpp4
-rw-r--r--llvm/lib/MC/MCContext.cpp7
-rw-r--r--llvm/lib/MC/MCFragment.cpp38
3 files changed, 23 insertions, 26 deletions
diff --git a/llvm/lib/MC/MCCodeView.cpp b/llvm/lib/MC/MCCodeView.cpp
index 713ae07..89b28b4 100644
--- a/llvm/lib/MC/MCCodeView.cpp
+++ b/llvm/lib/MC/MCCodeView.cpp
@@ -29,8 +29,8 @@ using namespace llvm::codeview;
CodeViewContext::~CodeViewContext() {
// If someone inserted strings into the string table but never actually
// emitted them somewhere, clean up the fragment.
- if (!InsertedStrTabFragment)
- delete StrTabFragment;
+ if (!InsertedStrTabFragment && StrTabFragment)
+ StrTabFragment->destroy();
}
/// This is a valid number for use with .cv_loc if we've already seen a .cv_file
diff --git a/llvm/lib/MC/MCContext.cpp b/llvm/lib/MC/MCContext.cpp
index bb87682..e7fc883 100644
--- a/llvm/lib/MC/MCContext.cpp
+++ b/llvm/lib/MC/MCContext.cpp
@@ -151,10 +151,15 @@ void MCContext::reset() {
SPIRVAllocator.DestroyAll();
WasmSignatureAllocator.DestroyAll();
+ // ~CodeViewContext may destroy a MCFragment outside of sections and need to
+ // be reset before FragmentAllocator.
+ CVContext.reset();
+
MCSubtargetAllocator.DestroyAll();
InlineAsmUsedLabelNames.clear();
Symbols.clear();
Allocator.Reset();
+ FragmentAllocator.Reset();
Instances.clear();
CompilationDir.clear();
MainFileName.clear();
@@ -165,8 +170,6 @@ void MCContext::reset() {
DwarfCompileUnitID = 0;
CurrentDwarfLoc = MCDwarfLoc(0, 0, 0, DWARF2_FLAG_IS_STMT, 0, 0);
- CVContext.reset();
-
MachOUniquingMap.clear();
ELFUniquingMap.clear();
GOFFUniquingMap.clear();
diff --git a/llvm/lib/MC/MCFragment.cpp b/llvm/lib/MC/MCFragment.cpp
index d90fd34..b1ed594 100644
--- a/llvm/lib/MC/MCFragment.cpp
+++ b/llvm/lib/MC/MCFragment.cpp
@@ -202,60 +202,54 @@ MCFragment::MCFragment(FragmentType Kind, bool HasInstructions)
: Kind(Kind), HasInstructions(HasInstructions), LinkerRelaxable(false) {}
void MCFragment::destroy() {
- // First check if we are the sentinel.
- if (Kind == FragmentType(~0)) {
- delete this;
- return;
- }
-
switch (Kind) {
case FT_Align:
- delete cast<MCAlignFragment>(this);
+ cast<MCAlignFragment>(this)->~MCAlignFragment();
return;
case FT_Data:
- delete cast<MCDataFragment>(this);
+ cast<MCDataFragment>(this)->~MCDataFragment();
return;
case FT_CompactEncodedInst:
- delete cast<MCCompactEncodedInstFragment>(this);
+ cast<MCCompactEncodedInstFragment>(this)->~MCCompactEncodedInstFragment();
return;
case FT_Fill:
- delete cast<MCFillFragment>(this);
+ cast<MCFillFragment>(this)->~MCFillFragment();
return;
case FT_Nops:
- delete cast<MCNopsFragment>(this);
+ cast<MCNopsFragment>(this)->~MCNopsFragment();
return;
case FT_Relaxable:
- delete cast<MCRelaxableFragment>(this);
+ cast<MCRelaxableFragment>(this)->~MCRelaxableFragment();
return;
case FT_Org:
- delete cast<MCOrgFragment>(this);
+ cast<MCOrgFragment>(this)->~MCOrgFragment();
return;
case FT_Dwarf:
- delete cast<MCDwarfLineAddrFragment>(this);
+ cast<MCDwarfLineAddrFragment>(this)->~MCDwarfLineAddrFragment();
return;
case FT_DwarfFrame:
- delete cast<MCDwarfCallFrameFragment>(this);
+ cast<MCDwarfCallFrameFragment>(this)->~MCDwarfCallFrameFragment();
return;
case FT_LEB:
- delete cast<MCLEBFragment>(this);
+ cast<MCLEBFragment>(this)->~MCLEBFragment();
return;
case FT_BoundaryAlign:
- delete cast<MCBoundaryAlignFragment>(this);
+ cast<MCBoundaryAlignFragment>(this)->~MCBoundaryAlignFragment();
return;
case FT_SymbolId:
- delete cast<MCSymbolIdFragment>(this);
+ cast<MCSymbolIdFragment>(this)->~MCSymbolIdFragment();
return;
case FT_CVInlineLines:
- delete cast<MCCVInlineLineTableFragment>(this);
+ cast<MCCVInlineLineTableFragment>(this)->~MCCVInlineLineTableFragment();
return;
case FT_CVDefRange:
- delete cast<MCCVDefRangeFragment>(this);
+ cast<MCCVDefRangeFragment>(this)->~MCCVDefRangeFragment();
return;
case FT_PseudoProbe:
- delete cast<MCPseudoProbeAddrFragment>(this);
+ cast<MCPseudoProbeAddrFragment>(this)->~MCPseudoProbeAddrFragment();
return;
case FT_Dummy:
- delete cast<MCDummyFragment>(this);
+ cast<MCDummyFragment>(this)->~MCDummyFragment();
return;
}
}