diff options
| author | Jakob Stoklund Olesen <stoklund@2pi.dk> | 2011-02-18 22:35:20 +0000 |
|---|---|---|
| committer | Jakob Stoklund Olesen <stoklund@2pi.dk> | 2011-02-18 22:35:20 +0000 |
| commit | 4376d67b6fc6d4a473c3b7e21ce7cc60ee30017f (patch) | |
| tree | 1268131331ea80dbc9aef9138c95c2543911c83b /llvm/lib/CodeGen/LiveRangeEdit.cpp | |
| parent | fa222dfbed6631341f4b0b725ee4bc78d5fed33d (diff) | |
| download | bcm5719-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.cpp | 8 |
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; |

