Use VirtRegMap's Virt2SplitMap to keep track of the original live range before splitting.
authorJakob Stoklund Olesen <stoklund@2pi.dk>
Fri, 18 Feb 2011 22:35:20 +0000 (22:35 +0000)
committerJakob Stoklund Olesen <stoklund@2pi.dk>
Fri, 18 Feb 2011 22:35:20 +0000 (22:35 +0000)
All new virtual registers created for spilling or splitting point back to their original.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@125980 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/LiveRangeEdit.cpp
lib/CodeGen/LiveRangeEdit.h
lib/CodeGen/VirtRegMap.h

index 3c7d9f66e7411339898251cdce490532b8a5cef2..e23f38283430fa97f92d6ef50a9ae18c24a4d53c 100644 (file)
 
 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;
index 73f69ed639836a1eef47772c502cec49ef4fa71b..832a12db4f4214a4552b4ce6479cf4287c842cb9 100644 (file)
@@ -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_; }
index a43ac5fc82df6a3d2abaec7e3112cdc0684fda78..23101ce74f915174e64c934a1671c804751b7a1d 100644 (file)
@@ -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];
     }