mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-09-27 16:17:17 +00:00
Reapply r99881 with some fixes: only call destructor in releaseMemory!
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@99883 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -330,12 +330,7 @@ namespace llvm {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void clear() {
|
void clear() {
|
||||||
while (!valnos.empty()) {
|
valnos.clear();
|
||||||
VNInfo *VNI = valnos.back();
|
|
||||||
valnos.pop_back();
|
|
||||||
VNI->~VNInfo();
|
|
||||||
}
|
|
||||||
|
|
||||||
ranges.clear();
|
ranges.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -134,6 +134,7 @@ class BumpPtrAllocator {
|
|||||||
static MallocSlabAllocator DefaultSlabAllocator;
|
static MallocSlabAllocator DefaultSlabAllocator;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
typedef void (*DTorFunction)(void*);
|
||||||
BumpPtrAllocator(size_t size = 4096, size_t threshold = 4096,
|
BumpPtrAllocator(size_t size = 4096, size_t threshold = 4096,
|
||||||
SlabAllocator &allocator = DefaultSlabAllocator);
|
SlabAllocator &allocator = DefaultSlabAllocator);
|
||||||
~BumpPtrAllocator();
|
~BumpPtrAllocator();
|
||||||
@@ -142,6 +143,11 @@ public:
|
|||||||
/// to the beginning of it, freeing all memory allocated so far.
|
/// to the beginning of it, freeing all memory allocated so far.
|
||||||
void Reset();
|
void Reset();
|
||||||
|
|
||||||
|
/// Reset - like Reset(), but call DTorFunction for each allocated
|
||||||
|
/// object. This assumes that all objects allocated with this allocator
|
||||||
|
/// had the same size and alignment specified here.
|
||||||
|
void Reset(size_t Size, size_t Alignment, DTorFunction DTor);
|
||||||
|
|
||||||
/// Allocate - Allocate space at the specified alignment.
|
/// Allocate - Allocate space at the specified alignment.
|
||||||
///
|
///
|
||||||
void *Allocate(size_t Size, size_t Alignment);
|
void *Allocate(size_t Size, size_t Alignment);
|
||||||
|
@@ -305,7 +305,6 @@ void LiveInterval::removeRange(SlotIndex Start, SlotIndex End,
|
|||||||
do {
|
do {
|
||||||
VNInfo *VNI = valnos.back();
|
VNInfo *VNI = valnos.back();
|
||||||
valnos.pop_back();
|
valnos.pop_back();
|
||||||
VNI->~VNInfo();
|
|
||||||
} while (!valnos.empty() && valnos.back()->isUnused());
|
} while (!valnos.empty() && valnos.back()->isUnused());
|
||||||
} else {
|
} else {
|
||||||
ValNo->setIsUnused(true);
|
ValNo->setIsUnused(true);
|
||||||
@@ -353,7 +352,6 @@ void LiveInterval::removeValNo(VNInfo *ValNo) {
|
|||||||
do {
|
do {
|
||||||
VNInfo *VNI = valnos.back();
|
VNInfo *VNI = valnos.back();
|
||||||
valnos.pop_back();
|
valnos.pop_back();
|
||||||
VNI->~VNInfo();
|
|
||||||
} while (!valnos.empty() && valnos.back()->isUnused());
|
} while (!valnos.empty() && valnos.back()->isUnused());
|
||||||
} else {
|
} else {
|
||||||
ValNo->setIsUnused(true);
|
ValNo->setIsUnused(true);
|
||||||
@@ -581,7 +579,6 @@ void LiveInterval::MergeValueInAsValue(
|
|||||||
do {
|
do {
|
||||||
VNInfo *VNI = valnos.back();
|
VNInfo *VNI = valnos.back();
|
||||||
valnos.pop_back();
|
valnos.pop_back();
|
||||||
VNI->~VNInfo();
|
|
||||||
} while (!valnos.empty() && valnos.back()->isUnused());
|
} while (!valnos.empty() && valnos.back()->isUnused());
|
||||||
} else {
|
} else {
|
||||||
V1->setIsUnused(true);
|
V1->setIsUnused(true);
|
||||||
@@ -658,7 +655,6 @@ void LiveInterval::MergeInClobberRanges(LiveIntervals &li_,
|
|||||||
if (UnusedValNo) {
|
if (UnusedValNo) {
|
||||||
// Delete the last unused val#.
|
// Delete the last unused val#.
|
||||||
valnos.pop_back();
|
valnos.pop_back();
|
||||||
UnusedValNo->~VNInfo();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -751,7 +747,6 @@ VNInfo* LiveInterval::MergeValueNumberInto(VNInfo *V1, VNInfo *V2) {
|
|||||||
do {
|
do {
|
||||||
VNInfo *VNI = valnos.back();
|
VNInfo *VNI = valnos.back();
|
||||||
valnos.pop_back();
|
valnos.pop_back();
|
||||||
VNI->~VNInfo();
|
|
||||||
} while (valnos.back()->isUnused());
|
} while (valnos.back()->isUnused());
|
||||||
} else {
|
} else {
|
||||||
V1->setIsUnused(true);
|
V1->setIsUnused(true);
|
||||||
|
@@ -82,6 +82,11 @@ void LiveIntervals::getAnalysisUsage(AnalysisUsage &AU) const {
|
|||||||
MachineFunctionPass::getAnalysisUsage(AU);
|
MachineFunctionPass::getAnalysisUsage(AU);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void VNInfoDTor(void* Ptr)
|
||||||
|
{
|
||||||
|
reinterpret_cast<VNInfo*>(Ptr)->~VNInfo();
|
||||||
|
}
|
||||||
|
|
||||||
void LiveIntervals::releaseMemory() {
|
void LiveIntervals::releaseMemory() {
|
||||||
// Free the live intervals themselves.
|
// Free the live intervals themselves.
|
||||||
for (DenseMap<unsigned, LiveInterval*>::iterator I = r2iMap_.begin(),
|
for (DenseMap<unsigned, LiveInterval*>::iterator I = r2iMap_.begin(),
|
||||||
@@ -91,7 +96,7 @@ void LiveIntervals::releaseMemory() {
|
|||||||
r2iMap_.clear();
|
r2iMap_.clear();
|
||||||
|
|
||||||
// Release VNInfo memroy regions after all VNInfo objects are dtor'd.
|
// Release VNInfo memroy regions after all VNInfo objects are dtor'd.
|
||||||
VNInfoAllocator.Reset();
|
VNInfoAllocator.Reset((unsigned)sizeof(VNInfo), alignof<VNInfo>(), VNInfoDTor);
|
||||||
while (!CloneMIs.empty()) {
|
while (!CloneMIs.empty()) {
|
||||||
MachineInstr *MI = CloneMIs.back();
|
MachineInstr *MI = CloneMIs.back();
|
||||||
CloneMIs.pop_back();
|
CloneMIs.pop_back();
|
||||||
|
@@ -78,6 +78,21 @@ void BumpPtrAllocator::Reset() {
|
|||||||
End = ((char*)CurSlab) + CurSlab->Size;
|
End = ((char*)CurSlab) + CurSlab->Size;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void BumpPtrAllocator::Reset(size_t Size, size_t Alignment, DTorFunction DTor) {
|
||||||
|
if (Alignment == 0) Alignment = 1;
|
||||||
|
MemSlab *Slab = CurSlab;
|
||||||
|
while (Slab) {
|
||||||
|
char *End = Slab == CurSlab ? CurPtr : (char*)Slab + Slab->Size;
|
||||||
|
for (char *Ptr = (char*)Slab+1; Ptr < End; Ptr += Size) {
|
||||||
|
Ptr = AlignPtr(Ptr, Alignment);
|
||||||
|
if (Ptr + Size <= End)
|
||||||
|
DTor(Ptr);
|
||||||
|
}
|
||||||
|
Slab = Slab->NextPtr;
|
||||||
|
}
|
||||||
|
Reset();
|
||||||
|
}
|
||||||
|
|
||||||
/// Allocate - Allocate space at the specified alignment.
|
/// Allocate - Allocate space at the specified alignment.
|
||||||
///
|
///
|
||||||
void *BumpPtrAllocator::Allocate(size_t Size, size_t Alignment) {
|
void *BumpPtrAllocator::Allocate(size_t Size, size_t Alignment) {
|
||||||
|
Reference in New Issue
Block a user