mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-15 04:30:12 +00:00
When reserving a preallocated register spill the aliases of this
register too. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@10450 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
4c214d2bf0
commit
94743e4915
@ -628,6 +628,22 @@ void RA::reservePhysReg(unsigned physReg)
|
||||
assignVirt2StackSlot(virtReg);
|
||||
}
|
||||
p2vMap_[physReg] = physReg; // this denotes a reserved physical register
|
||||
|
||||
// if it also aliases any other registers with values spill them too
|
||||
for (const unsigned* as = mri_->getAliasSet(physReg); *as; ++as) {
|
||||
unsigned virtReg = p2vMap_[*as];
|
||||
if (virtReg != 0 && virtReg != *as) {
|
||||
// remove interval from active
|
||||
for (IntervalPtrs::iterator i = active_.begin(), e = active_.end();
|
||||
i != e; ++i) {
|
||||
if ((*i)->reg == virtReg) {
|
||||
active_.erase(i);
|
||||
break;
|
||||
}
|
||||
}
|
||||
assignVirt2StackSlot(virtReg);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void RA::clearReservedPhysReg(unsigned physReg)
|
||||
|
Loading…
Reference in New Issue
Block a user