diff options
author | Jakob Stoklund Olesen <stoklund@2pi.dk> | 2011-02-23 00:56:56 +0000 |
---|---|---|
committer | Jakob Stoklund Olesen <stoklund@2pi.dk> | 2011-02-23 00:56:56 +0000 |
commit | d2a50734234a80893ad71da90d9f32032c47e000 (patch) | |
tree | 7b702877711c97568bca910e50450d4193085956 /lib/CodeGen/RegAllocGreedy.cpp | |
parent | 417df0129146e299e9fd273becab824887c384e9 (diff) |
Keep track of how many times a live range has been dequeued, and prioritize new ranges.
When a large live range is evicted, it will usually be split when it comes
around again. By deferring evicted live ranges, the splitting happens at a time
when the interference pattern is more realistic. This prevents repeated
splitting and evictions.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@126282 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/RegAllocGreedy.cpp')
-rw-r--r-- | lib/CodeGen/RegAllocGreedy.cpp | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/lib/CodeGen/RegAllocGreedy.cpp b/lib/CodeGen/RegAllocGreedy.cpp index 59d4fc6180..0388619540 100644 --- a/lib/CodeGen/RegAllocGreedy.cpp +++ b/lib/CodeGen/RegAllocGreedy.cpp @@ -74,6 +74,7 @@ class RAGreedy : public MachineFunctionPass, public RegAllocBase { std::auto_ptr<Spiller> SpillerInstance; std::auto_ptr<SplitAnalysis> SA; std::priority_queue<std::pair<unsigned, unsigned> > Queue; + IndexedMap<unsigned, VirtReg2IndexFunctor> Generation; // splitting state. @@ -186,6 +187,7 @@ void RAGreedy::getAnalysisUsage(AnalysisUsage &AU) const { void RAGreedy::releaseMemory() { SpillerInstance.reset(0); + Generation.clear(); RegAllocBase::releaseMemory(); } @@ -202,6 +204,11 @@ void RAGreedy::enqueue(LiveInterval *LI) { if (TargetRegisterInfo::isPhysicalRegister(Hint)) Size |= (1u << 30); + // Boost ranges that we see for the first time. + Generation.grow(Reg); + if (++Generation[Reg] == 1) + Size |= (1u << 31); + Queue.push(std::make_pair(Size, Reg)); } |