diff options
| author | Evan Cheng <evan.cheng@apple.com> | 2008-03-26 19:03:01 +0000 | 
|---|---|---|
| committer | Evan Cheng <evan.cheng@apple.com> | 2008-03-26 19:03:01 +0000 | 
| commit | 9714850cee82f19572701dd7cfd8b202aba27b4c (patch) | |
| tree | ec25ced033c89f098d241a6db0cf6154314b5efe /lib/CodeGen | |
| parent | 0664ef9d7e3b538fc448fe42e8557aa52d8d6d51 (diff) | |
| download | external_llvm-9714850cee82f19572701dd7cfd8b202aba27b4c.zip external_llvm-9714850cee82f19572701dd7cfd8b202aba27b4c.tar.gz external_llvm-9714850cee82f19572701dd7cfd8b202aba27b4c.tar.bz2 | |
Avoid commuting a def MI in order to coalesce a copy instruction away if any use of the same val# is a copy instruction that has already been coalesced.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@48833 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen')
| -rw-r--r-- | lib/CodeGen/SimpleRegisterCoalescing.cpp | 14 | ||||
| -rw-r--r-- | lib/CodeGen/VirtRegMap.cpp | 1 | 
2 files changed, 13 insertions, 2 deletions
| diff --git a/lib/CodeGen/SimpleRegisterCoalescing.cpp b/lib/CodeGen/SimpleRegisterCoalescing.cpp index 870fcc4..8ae36db 100644 --- a/lib/CodeGen/SimpleRegisterCoalescing.cpp +++ b/lib/CodeGen/SimpleRegisterCoalescing.cpp @@ -283,6 +283,17 @@ bool SimpleRegisterCoalescing::RemoveCopyByCommutingDef(LiveInterval &IntA,    if (HasOtherReachingDefs(IntA, IntB, AValNo, BValNo))      return false; +  // If some of the uses of IntA.reg is already coalesced away, return false. +  // It's not possible to determine whether it's safe to perform the coalescing. +  for (MachineRegisterInfo::use_iterator UI = mri_->use_begin(IntA.reg), +         UE = mri_->use_end(); UI != UE; ++UI) { +    MachineInstr *UseMI = &*UI; +    unsigned UseIdx = li_->getInstructionIndex(UseMI); +    LiveInterval::iterator ULR = IntA.FindLiveRangeContaining(UseIdx); +    if (ULR->valno == AValNo && JoinedCopies.count(UseMI)) +      return false; +  } +    // At this point we have decided that it is legal to do this    // transformation.  Start by commuting the instruction.    MachineBasicBlock *MBB = DefMI->getParent(); @@ -323,8 +334,7 @@ bool SimpleRegisterCoalescing::RemoveCopyByCommutingDef(LiveInterval &IntA,      MachineInstr *UseMI = &*UI;      ++UI;      if (JoinedCopies.count(UseMI)) -      // It'll no longer be "joined" after the change. -      JoinedCopies.erase(UseMI); +      continue;      unsigned UseIdx = li_->getInstructionIndex(UseMI);      LiveInterval::iterator ULR = IntA.FindLiveRangeContaining(UseIdx);      if (ULR->valno != AValNo) diff --git a/lib/CodeGen/VirtRegMap.cpp b/lib/CodeGen/VirtRegMap.cpp index f89ef9a..264ab14 100644 --- a/lib/CodeGen/VirtRegMap.cpp +++ b/lib/CodeGen/VirtRegMap.cpp @@ -1593,6 +1593,7 @@ void LocalSpiller::RewriteMBB(MachineBasicBlock &MBB, VirtRegMap &VRM) {          }        } +      assert(PhysReg && "VR not assigned a physical register?");        RegInfo->setPhysRegUsed(PhysReg);        unsigned RReg = SubIdx ? TRI->getSubReg(PhysReg, SubIdx) : PhysReg;        ReusedOperands.markClobbered(RReg); | 
