summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen/LiveIntervals.cpp
diff options
context:
space:
mode:
authorAlkis Evlogimenos <alkis@evlogimenos.com>2004-02-17 04:04:20 +0000
committerAlkis Evlogimenos <alkis@evlogimenos.com>2004-02-17 04:04:20 +0000
commit4f7c2d9e5e21c6e4ac87a877f642727b72afb01a (patch)
tree5cf809e6d5aa542eda68f1dc5bd61d2f321ae376 /llvm/lib/CodeGen/LiveIntervals.cpp
parentddedac59fed504ffb62a31c057623056976a0b8c (diff)
downloadbcm5719-llvm-4f7c2d9e5e21c6e4ac87a877f642727b72afb01a.tar.gz
bcm5719-llvm-4f7c2d9e5e21c6e4ac87a877f642727b72afb01a.zip
Fix spilled interval update. It was too conservative.
llvm-svn: 11516
Diffstat (limited to 'llvm/lib/CodeGen/LiveIntervals.cpp')
-rw-r--r--llvm/lib/CodeGen/LiveIntervals.cpp5
1 files changed, 4 insertions, 1 deletions
diff --git a/llvm/lib/CodeGen/LiveIntervals.cpp b/llvm/lib/CodeGen/LiveIntervals.cpp
index f602658d176..64925b40bd3 100644
--- a/llvm/lib/CodeGen/LiveIntervals.cpp
+++ b/llvm/lib/CodeGen/LiveIntervals.cpp
@@ -191,7 +191,10 @@ void LiveIntervals::updateSpilledInterval(Interval& li)
if (mop.isRegister()) {
unsigned reg = mop.getReg();
if (rep(reg) == li.reg) {
- li.addRange(index, index + 2);
+ if (mop.isUse())
+ li.addRange(index, index+2);
+ else
+ li.addRange(index+1, index+2);
}
}
}
OpenPOWER on IntegriCloud