forked from OSchip/llvm-project
parent
3621b8a217
commit
059e800fda
|
@ -101,8 +101,8 @@ void RegAllocBase::allocatePhysRegs() {
|
|||
// register if possible and populate a list of new live intervals that
|
||||
// result from splitting.
|
||||
DEBUG(dbgs() << "\nselectOrSplit "
|
||||
<< MRI->getRegClass(VirtReg->reg)->getName()
|
||||
<< ':' << *VirtReg << '\n');
|
||||
<< MRI->getRegClass(VirtReg->reg)->getName()
|
||||
<< ':' << *VirtReg << " w=" << VirtReg->weight << '\n');
|
||||
typedef SmallVector<unsigned, 4> VirtRegVec;
|
||||
VirtRegVec SplitVRegs;
|
||||
unsigned AvailablePhysReg = selectOrSplit(*VirtReg, SplitVRegs);
|
||||
|
|
|
@ -548,7 +548,11 @@ bool RAGreedy::shouldEvict(LiveInterval &A, bool IsHint,
|
|||
if (CanSplit && IsHint && !BreaksHint)
|
||||
return true;
|
||||
|
||||
return A.weight > B.weight;
|
||||
if (A.weight > B.weight) {
|
||||
DEBUG(dbgs() << "should evict: " << B << " w= " << B.weight << '\n');
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
/// canEvictInterference - Return true if all interferences between VirtReg and
|
||||
|
|
Loading…
Reference in New Issue