diff options
author | Evan Cheng <evan.cheng@apple.com> | 2007-10-15 18:33:50 +0000 |
---|---|---|
committer | Evan Cheng <evan.cheng@apple.com> | 2007-10-15 18:33:50 +0000 |
commit | f5c7359afa8c9ab8d1bfbb6dc41c2d6db8c0420d (patch) | |
tree | 2be7fbc975be5b0799909f1acb509d70313fc754 /lib/CodeGen/SimpleRegisterCoalescing.cpp | |
parent | 85dd3be7354f848231362bd70f6517c0e667f95d (diff) |
Fix PR1729: watch out for val# with no def.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@42996 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/SimpleRegisterCoalescing.cpp')
-rw-r--r-- | lib/CodeGen/SimpleRegisterCoalescing.cpp | 21 |
1 files changed, 13 insertions, 8 deletions
diff --git a/lib/CodeGen/SimpleRegisterCoalescing.cpp b/lib/CodeGen/SimpleRegisterCoalescing.cpp index 5323cb29a8..4a4df913a1 100644 --- a/lib/CodeGen/SimpleRegisterCoalescing.cpp +++ b/lib/CodeGen/SimpleRegisterCoalescing.cpp @@ -422,14 +422,19 @@ bool SimpleRegisterCoalescing::JoinCopy(MachineInstr *CopyMI, // then create and update the actual physical register allocated to RHS. if (RealDstReg) { LiveInterval &RealDstInt = li_->getOrCreateInterval(RealDstReg); - for (unsigned i = 0, e = ResSrcInt->getNumValNums(); i != e; ++i) { - const VNInfo *SrcValNo = ResSrcInt->getValNumInfo(i); - const VNInfo *DstValNo = - ResDstInt->FindLiveRangeContaining(SrcValNo->def)->valno; - VNInfo *ValNo = RealDstInt.getNextValue(DstValNo->def, DstValNo->reg, - li_->getVNInfoAllocator()); - RealDstInt.addKills(ValNo, DstValNo->kills); - RealDstInt.MergeValueInAsValue(*ResDstInt, DstValNo, ValNo); + SmallSet<const VNInfo*, 4> CopiedValNos; + for (LiveInterval::Ranges::const_iterator I = ResSrcInt->ranges.begin(), + E = ResSrcInt->ranges.end(); I != E; ++I) { + LiveInterval::const_iterator DstLR = + ResDstInt->FindLiveRangeContaining(I->start); + assert(DstLR != ResDstInt->end() && "Invalid joined interval!"); + const VNInfo *DstValNo = DstLR->valno; + if (CopiedValNos.insert(DstValNo)) { + VNInfo *ValNo = RealDstInt.getNextValue(DstValNo->def, DstValNo->reg, + li_->getVNInfoAllocator()); + RealDstInt.addKills(ValNo, DstValNo->kills); + RealDstInt.MergeValueInAsValue(*ResDstInt, DstValNo, ValNo); + } } repDstReg = RealDstReg; } |