diff options
author | Matthias Braun <matze@braunis.de> | 2015-07-10 22:23:57 +0000 |
---|---|---|
committer | Matthias Braun <matze@braunis.de> | 2015-07-10 22:23:57 +0000 |
commit | e5a112f5e15419a73e496371eaf486f08aa0256c (patch) | |
tree | ab31be932a45ee610641ab3c942658ad5a55e962 /llvm/lib/Target/ARM/ARMLoadStoreOptimizer.cpp | |
parent | 7ea7708d925fb04b422ede635156589c4b42f480 (diff) | |
download | bcm5719-llvm-e5a112f5e15419a73e496371eaf486f08aa0256c.tar.gz bcm5719-llvm-e5a112f5e15419a73e496371eaf486f08aa0256c.zip |
ARM: Use SpecificBumpPtrAllocator to fix leak introduced in r241920
llvm-svn: 241951
Diffstat (limited to 'llvm/lib/Target/ARM/ARMLoadStoreOptimizer.cpp')
-rw-r--r-- | llvm/lib/Target/ARM/ARMLoadStoreOptimizer.cpp | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/llvm/lib/Target/ARM/ARMLoadStoreOptimizer.cpp b/llvm/lib/Target/ARM/ARMLoadStoreOptimizer.cpp index c64c190ed15..f77af983791 100644 --- a/llvm/lib/Target/ARM/ARMLoadStoreOptimizer.cpp +++ b/llvm/lib/Target/ARM/ARMLoadStoreOptimizer.cpp @@ -116,7 +116,7 @@ namespace { /// Whether the instructions can be merged into a ldrd/strd instruction. bool CanMergeToLSDouble; }; - BumpPtrAllocator Allocator; + SpecificBumpPtrAllocator<MergeCandidate> Allocator; SmallVector<const MergeCandidate*,4> Candidates; SmallVector<MachineInstr*,4> MergeBaseCandidates; @@ -996,7 +996,7 @@ void ARMLoadStoreOpt::FormCandidates(const MemOpQueue &MemOps) { } // Form a candidate from the Ops collected so far. - MergeCandidate *Candidate = new(Allocator) MergeCandidate; + MergeCandidate *Candidate = new(Allocator.Allocate()) MergeCandidate; for (unsigned C = SIndex, CE = SIndex + Count; C < CE; ++C) Candidate->Instrs.push_back(MemOps[C].MI); Candidate->LatestMIIdx = Latest - SIndex; @@ -1849,7 +1849,7 @@ bool ARMLoadStoreOpt::runOnMachineFunction(MachineFunction &Fn) { Modified |= MergeReturnIntoLDM(MBB); } - Allocator.Reset(); + Allocator.DestroyAll(); return Modified; } |