mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-24 19:52:54 +01:00
Simplify some more getAliasSet callers.
MCRegAliasIterator can include Reg itself in the list. llvm-svn: 157848
This commit is contained in:
parent
39e36628b4
commit
41c8b09fef
@ -711,13 +711,10 @@ void RAFast::handleThroughOperands(MachineInstr *MI,
|
||||
if (!MO.isReg() || !MO.isDef()) continue;
|
||||
unsigned Reg = MO.getReg();
|
||||
if (!Reg || !TargetRegisterInfo::isPhysicalRegister(Reg)) continue;
|
||||
UsedInInstr.set(Reg);
|
||||
if (ThroughRegs.count(PhysRegState[Reg]))
|
||||
definePhysReg(MI, Reg, regFree);
|
||||
for (const uint16_t *AS = TRI->getAliasSet(Reg); *AS; ++AS) {
|
||||
UsedInInstr.set(*AS);
|
||||
if (ThroughRegs.count(PhysRegState[*AS]))
|
||||
definePhysReg(MI, *AS, regFree);
|
||||
for (MCRegAliasIterator AI(Reg, TRI, true); AI.isValid(); ++AI) {
|
||||
UsedInInstr.set(*AI);
|
||||
if (ThroughRegs.count(PhysRegState[*AI]))
|
||||
definePhysReg(MI, *AI, regFree);
|
||||
}
|
||||
}
|
||||
|
||||
@ -1036,9 +1033,8 @@ void RAFast::AllocateBasicBlock() {
|
||||
if (!Reg || !TargetRegisterInfo::isPhysicalRegister(Reg)) continue;
|
||||
// Look for physreg defs and tied uses.
|
||||
if (!MO.isDef() && !MI->isRegTiedToDefOperand(i)) continue;
|
||||
UsedInInstr.set(Reg);
|
||||
for (const uint16_t *AS = TRI->getAliasSet(Reg); *AS; ++AS)
|
||||
UsedInInstr.set(*AS);
|
||||
for (MCRegAliasIterator AI(Reg, TRI, true); AI.isValid(); ++AI)
|
||||
UsedInInstr.set(*AI);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -43,10 +43,8 @@ void RegScavenger::setUsed(unsigned Reg) {
|
||||
}
|
||||
|
||||
bool RegScavenger::isAliasUsed(unsigned Reg) const {
|
||||
if (isUsed(Reg))
|
||||
return true;
|
||||
for (const uint16_t *R = TRI->getAliasSet(Reg); *R; ++R)
|
||||
if (isUsed(*R))
|
||||
for (MCRegAliasIterator AI(Reg, TRI, true); AI.isValid(); ++AI)
|
||||
if (isUsed(*AI))
|
||||
return true;
|
||||
return false;
|
||||
}
|
||||
@ -296,9 +294,8 @@ unsigned RegScavenger::findSurvivorReg(MachineBasicBlock::iterator StartMI,
|
||||
isVirtKillInsn = true;
|
||||
continue;
|
||||
}
|
||||
Candidates.reset(MO.getReg());
|
||||
for (const uint16_t *R = TRI->getAliasSet(MO.getReg()); *R; R++)
|
||||
Candidates.reset(*R);
|
||||
for (MCRegAliasIterator AI(MO.getReg(), TRI, true); AI.isValid(); ++AI)
|
||||
Candidates.reset(*AI);
|
||||
}
|
||||
// If we're not in a virtual reg's live range, this is a valid
|
||||
// restore point.
|
||||
|
@ -441,19 +441,14 @@ static bool CheckForLiveRegDef(SUnit *SU, unsigned Reg,
|
||||
SmallVector<unsigned, 4> &LRegs,
|
||||
const TargetRegisterInfo *TRI) {
|
||||
bool Added = false;
|
||||
if (LiveRegDefs[Reg] && LiveRegDefs[Reg] != SU) {
|
||||
if (RegAdded.insert(Reg)) {
|
||||
LRegs.push_back(Reg);
|
||||
Added = true;
|
||||
}
|
||||
}
|
||||
for (const uint16_t *Alias = TRI->getAliasSet(Reg); *Alias; ++Alias)
|
||||
if (LiveRegDefs[*Alias] && LiveRegDefs[*Alias] != SU) {
|
||||
if (RegAdded.insert(*Alias)) {
|
||||
LRegs.push_back(*Alias);
|
||||
for (MCRegAliasIterator AI(Reg, TRI, true); AI.isValid(); ++AI) {
|
||||
if (LiveRegDefs[*AI] && LiveRegDefs[*AI] != SU) {
|
||||
if (RegAdded.insert(*AI)) {
|
||||
LRegs.push_back(*AI);
|
||||
Added = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
return Added;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user