summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen/LiveRangeEdit.cpp
diff options
context:
space:
mode:
authorJakob Stoklund Olesen <stoklund@2pi.dk>2011-02-18 22:35:20 +0000
committerJakob Stoklund Olesen <stoklund@2pi.dk>2011-02-18 22:35:20 +0000
commit4376d67b6fc6d4a473c3b7e21ce7cc60ee30017f (patch)
tree1268131331ea80dbc9aef9138c95c2543911c83b /llvm/lib/CodeGen/LiveRangeEdit.cpp
parentfa222dfbed6631341f4b0b725ee4bc78d5fed33d (diff)
downloadbcm5719-llvm-4376d67b6fc6d4a473c3b7e21ce7cc60ee30017f.tar.gz
bcm5719-llvm-4376d67b6fc6d4a473c3b7e21ce7cc60ee30017f.zip
Use VirtRegMap's Virt2SplitMap to keep track of the original live range before splitting.
All new virtual registers created for spilling or splitting point back to their original. llvm-svn: 125980
Diffstat (limited to 'llvm/lib/CodeGen/LiveRangeEdit.cpp')
-rw-r--r--llvm/lib/CodeGen/LiveRangeEdit.cpp8
1 files changed, 7 insertions, 1 deletions
diff --git a/llvm/lib/CodeGen/LiveRangeEdit.cpp b/llvm/lib/CodeGen/LiveRangeEdit.cpp
index 3c7d9f66e74..e23f3828343 100644
--- a/llvm/lib/CodeGen/LiveRangeEdit.cpp
+++ b/llvm/lib/CodeGen/LiveRangeEdit.cpp
@@ -19,12 +19,18 @@
using namespace llvm;
+unsigned LiveRangeEdit::getOriginal(const VirtRegMap &vrm) const {
+ unsigned Orig = vrm.getPreSplitReg(getReg());
+ return Orig ? Orig : getReg();
+}
+
LiveInterval &LiveRangeEdit::create(MachineRegisterInfo &mri,
LiveIntervals &lis,
VirtRegMap &vrm) {
- const TargetRegisterClass *RC = mri.getRegClass(parent_.reg);
+ const TargetRegisterClass *RC = mri.getRegClass(getReg());
unsigned VReg = mri.createVirtualRegister(RC);
vrm.grow();
+ vrm.setIsSplitFromReg(VReg, getOriginal(vrm));
LiveInterval &li = lis.getOrCreateInterval(VReg);
newRegs_.push_back(&li);
return li;
OpenPOWER on IntegriCloud