diff options
author | Chris Lattner <sabre@nondot.org> | 2006-11-07 07:18:40 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2006-11-07 07:18:40 +0000 |
commit | 01d039cc448287a145fd9a195173f6d16ed06606 (patch) | |
tree | afacbc1c08739d265353df9fdc2ac578c194277c /llvm/lib/CodeGen | |
parent | 78c84a032807b51612ea5730c68ecfc6c810190e (diff) | |
download | bcm5719-llvm-01d039cc448287a145fd9a195173f6d16ed06606.tar.gz bcm5719-llvm-01d039cc448287a145fd9a195173f6d16ed06606.zip |
Add a new llcbeta option. This speeds up viterbi from 12.34 to 8.76s on
X86. If happy, I'll enable this by default.
llvm-svn: 31493
Diffstat (limited to 'llvm/lib/CodeGen')
-rw-r--r-- | llvm/lib/CodeGen/LiveIntervalAnalysis.cpp | 23 |
1 files changed, 19 insertions, 4 deletions
diff --git a/llvm/lib/CodeGen/LiveIntervalAnalysis.cpp b/llvm/lib/CodeGen/LiveIntervalAnalysis.cpp index 118a2e0a6e2..ec2470a04a3 100644 --- a/llvm/lib/CodeGen/LiveIntervalAnalysis.cpp +++ b/llvm/lib/CodeGen/LiveIntervalAnalysis.cpp @@ -59,6 +59,9 @@ namespace { EnableJoining("join-liveintervals", cl::desc("Coallesce copies (default=true)"), cl::init(true)); + static cl::opt<bool> + EnableReweight("enable-majik-f00"); + } void LiveIntervals::getAnalysisUsage(AnalysisUsage &AU) const { @@ -208,14 +211,26 @@ bool LiveIntervals::runOnMachineFunction(MachineFunction &fn) { } } + for (iterator I = begin(), E = end(); I != E; ++I) { - LiveInterval &li = I->second; - if (MRegisterInfo::isVirtualRegister(li.reg)) { + LiveInterval &LI = I->second; + if (MRegisterInfo::isVirtualRegister(LI.reg)) { // If the live interval length is essentially zero, i.e. in every live // range the use follows def immediately, it doesn't make sense to spill // it and hope it will be easier to allocate for this li. - if (isZeroLengthInterval(&li)) - li.weight = float(HUGE_VAL); + if (isZeroLengthInterval(&LI)) + LI.weight = float(HUGE_VAL); + + if (EnableReweight) { + // Divide the weight of the interval by its size. This encourages + // spilling of intervals that are large and have few uses, and + // discourages spilling of small intervals with many uses. + unsigned Size = 0; + for (LiveInterval::iterator II = LI.begin(), E = LI.end(); II != E;++II) + Size += II->end - II->start; + + LI.weight /= Size; + } } } |