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 | |
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')
-rw-r--r-- | llvm/lib/CodeGen/LiveRangeEdit.cpp | 8 | ||||
-rw-r--r-- | llvm/lib/CodeGen/LiveRangeEdit.h | 4 | ||||
-rw-r--r-- | llvm/lib/CodeGen/VirtRegMap.h | 2 |
3 files changed, 12 insertions, 2 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; diff --git a/llvm/lib/CodeGen/LiveRangeEdit.h b/llvm/lib/CodeGen/LiveRangeEdit.h index 73f69ed6398..832a12db4f4 100644 --- a/llvm/lib/CodeGen/LiveRangeEdit.h +++ b/llvm/lib/CodeGen/LiveRangeEdit.h @@ -73,6 +73,10 @@ public: LiveInterval &getParent() const { return parent_; } unsigned getReg() const { return parent_.reg; } + /// getOriginal - Return the original virtual register that parent descends + /// from through splitting. The original was not created by splitting. + unsigned getOriginal(const VirtRegMap&) const; + /// Iterator for accessing the new registers added by this edit. typedef SmallVectorImpl<LiveInterval*>::const_iterator iterator; iterator begin() const { return newRegs_.begin()+firstNew_; } diff --git a/llvm/lib/CodeGen/VirtRegMap.h b/llvm/lib/CodeGen/VirtRegMap.h index a43ac5fc82d..23101ce74f9 100644 --- a/llvm/lib/CodeGen/VirtRegMap.h +++ b/llvm/lib/CodeGen/VirtRegMap.h @@ -214,7 +214,7 @@ namespace llvm { } /// @brief returns the live interval virtReg is split from. - unsigned getPreSplitReg(unsigned virtReg) { + unsigned getPreSplitReg(unsigned virtReg) const { return Virt2SplitMap[virtReg]; } |