Change MRegisterDesc::AliasSet, TargetInstrDescriptor::ImplicitDefs

and TargetInstrDescriptor::ImplicitUses to always point to a null
terminated array and never be null. So there is no need to check for
pointer validity when iterating over those sets. Code that looked
like:

if (const unsigned* AS = TID.ImplicitDefs) {
  for (int i = 0; AS[i]; ++i) {
    // use AS[i]
  }
}

was changed to:

for (const unsigned* AS = TID.ImplicitDefs; *AS; ++AS) {
  // use *AS
}


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@8960 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Alkis Evlogimenos 2003-10-08 05:20:08 +00:00
parent 6b8b22585c
commit 73ff5120eb
6 changed files with 64 additions and 48 deletions

View File

@ -108,12 +108,14 @@ void LiveVariables::HandlePhysRegUse(unsigned Reg, MachineInstr *MI) {
if (PhysRegInfo[Reg]) { if (PhysRegInfo[Reg]) {
PhysRegInfo[Reg] = MI; PhysRegInfo[Reg] = MI;
PhysRegUsed[Reg] = true; PhysRegUsed[Reg] = true;
} else if (const unsigned *AliasSet = RegInfo->getAliasSet(Reg)) { } else {
for (; unsigned NReg = AliasSet[0]; ++AliasSet) for (const unsigned *AliasSet = RegInfo->getAliasSet(Reg);
if (MachineInstr *LastUse = PhysRegInfo[NReg]) { *AliasSet; ++AliasSet) {
PhysRegInfo[NReg] = MI; if (MachineInstr *LastUse = PhysRegInfo[*AliasSet]) {
PhysRegUsed[NReg] = true; PhysRegInfo[*AliasSet] = MI;
PhysRegUsed[*AliasSet] = true;
} }
}
} }
} }
@ -124,15 +126,17 @@ void LiveVariables::HandlePhysRegDef(unsigned Reg, MachineInstr *MI) {
RegistersKilled.insert(std::make_pair(LastUse, Reg)); RegistersKilled.insert(std::make_pair(LastUse, Reg));
else else
RegistersDead.insert(std::make_pair(LastUse, Reg)); RegistersDead.insert(std::make_pair(LastUse, Reg));
} else if (const unsigned *AliasSet = RegInfo->getAliasSet(Reg)) { } else {
for (; unsigned NReg = AliasSet[0]; ++AliasSet) for (const unsigned *AliasSet = RegInfo->getAliasSet(Reg);
if (MachineInstr *LastUse = PhysRegInfo[NReg]) { *AliasSet; ++AliasSet) {
if (PhysRegUsed[NReg]) if (MachineInstr *LastUse = PhysRegInfo[*AliasSet]) {
RegistersKilled.insert(std::make_pair(LastUse, NReg)); if (PhysRegUsed[*AliasSet])
RegistersKilled.insert(std::make_pair(LastUse, *AliasSet));
else else
RegistersDead.insert(std::make_pair(LastUse, NReg)); RegistersDead.insert(std::make_pair(LastUse, *AliasSet));
PhysRegInfo[NReg] = 0; // Kill the aliased register PhysRegInfo[*AliasSet] = 0; // Kill the aliased register
} }
}
} }
PhysRegInfo[Reg] = MI; PhysRegInfo[Reg] = MI;
PhysRegUsed[Reg] = false; PhysRegUsed[Reg] = false;
@ -206,9 +210,9 @@ bool LiveVariables::runOnMachineFunction(MachineFunction &MF) {
NumOperandsToProcess = 1; NumOperandsToProcess = 1;
// Loop over implicit uses, using them. // Loop over implicit uses, using them.
if (const unsigned *ImplicitUses = MID.ImplicitUses) for (const unsigned *ImplicitUses = MID.ImplicitUses;
for (unsigned i = 0; ImplicitUses[i]; ++i) *ImplicitUses; ++ImplicitUses)
HandlePhysRegUse(ImplicitUses[i], MI); HandlePhysRegUse(*ImplicitUses, MI);
// Process all explicit uses... // Process all explicit uses...
for (unsigned i = 0; i != NumOperandsToProcess; ++i) { for (unsigned i = 0; i != NumOperandsToProcess; ++i) {

View File

@ -127,12 +127,15 @@ void PEI::saveCallerSavedRegisters(MachineFunction &Fn) {
unsigned Reg = CSRegs[i]; unsigned Reg = CSRegs[i];
if (ModifiedRegs[Reg]) { if (ModifiedRegs[Reg]) {
RegsToSave.push_back(Reg); // If modified register... RegsToSave.push_back(Reg); // If modified register...
} else if (const unsigned *AliasSet = RegInfo->getAliasSet(Reg)) } else {
for (unsigned j = 0; AliasSet[j]; ++j) // Check alias registers too... for (const unsigned *AliasSet = RegInfo->getAliasSet(Reg);
if (ModifiedRegs[AliasSet[j]]) { *AliasSet; ++AliasSet) { // Check alias registers too...
if (ModifiedRegs[*AliasSet]) {
RegsToSave.push_back(Reg); RegsToSave.push_back(Reg);
break; break;
} }
}
}
} }
if (RegsToSave.empty()) if (RegsToSave.empty())

View File

@ -120,9 +120,10 @@ namespace {
/// ///
bool areRegsEqual(unsigned R1, unsigned R2) const { bool areRegsEqual(unsigned R1, unsigned R2) const {
if (R1 == R2) return true; if (R1 == R2) return true;
if (const unsigned *AliasSet = RegInfo->getAliasSet(R2)) for (const unsigned *AliasSet = RegInfo->getAliasSet(R2);
for (unsigned i = 0; AliasSet[i]; ++i) *AliasSet; ++AliasSet) {
if (AliasSet[i] == R1) return true; if (*AliasSet == R1) return true;
}
return false; return false;
} }
@ -271,14 +272,15 @@ void RA::spillPhysReg(MachineBasicBlock &MBB, MachineBasicBlock::iterator &I,
if (PI != PhysRegsUsed.end()) { // Only spill it if it's used! if (PI != PhysRegsUsed.end()) { // Only spill it if it's used!
if (PI->second || !OnlyVirtRegs) if (PI->second || !OnlyVirtRegs)
spillVirtReg(MBB, I, PI->second, PhysReg); spillVirtReg(MBB, I, PI->second, PhysReg);
} else if (const unsigned *AliasSet = RegInfo->getAliasSet(PhysReg)) { } else {
// If the selected register aliases any other registers, we must make // If the selected register aliases any other registers, we must make
// sure that one of the aliases isn't alive... // sure that one of the aliases isn't alive...
for (unsigned i = 0; AliasSet[i]; ++i) { for (const unsigned *AliasSet = RegInfo->getAliasSet(PhysReg);
PI = PhysRegsUsed.find(AliasSet[i]); *AliasSet; ++AliasSet) {
PI = PhysRegsUsed.find(*AliasSet);
if (PI != PhysRegsUsed.end()) // Spill aliased register... if (PI != PhysRegsUsed.end()) // Spill aliased register...
if (PI->second || !OnlyVirtRegs) if (PI->second || !OnlyVirtRegs)
spillVirtReg(MBB, I, PI->second, AliasSet[i]); spillVirtReg(MBB, I, PI->second, *AliasSet);
} }
} }
} }
@ -308,10 +310,10 @@ bool RA::isPhysRegAvailable(unsigned PhysReg) const {
// If the selected register aliases any other allocated registers, it is // If the selected register aliases any other allocated registers, it is
// not free! // not free!
if (const unsigned *AliasSet = RegInfo->getAliasSet(PhysReg)) for (const unsigned *AliasSet = RegInfo->getAliasSet(PhysReg);
for (unsigned i = 0; AliasSet[i]; ++i) *AliasSet; ++AliasSet)
if (PhysRegsUsed.count(AliasSet[i])) // Aliased register in use? if (PhysRegsUsed.count(*AliasSet)) // Aliased register in use?
return false; // Can't use this reg then. return false; // Can't use this reg then.
return true; return true;
} }
@ -414,12 +416,13 @@ unsigned RA::getReg(MachineBasicBlock &MBB, MachineBasicBlock::iterator &I,
} else { } else {
// If one of the registers aliased to the current register is // If one of the registers aliased to the current register is
// compatible, use it. // compatible, use it.
if (const unsigned *AliasSet = RegInfo->getAliasSet(R)) for (const unsigned *AliasSet = RegInfo->getAliasSet(R);
for (unsigned a = 0; AliasSet[a]; ++a) *AliasSet; ++AliasSet) {
if (RegInfo->getRegClass(AliasSet[a]) == RC) { if (RegInfo->getRegClass(*AliasSet) == RC) {
PhysReg = AliasSet[a]; // Take an aliased register PhysReg = *AliasSet; // Take an aliased register
break; break;
} }
}
} }
} }
} }
@ -485,9 +488,9 @@ void RA::AllocateBasicBlock(MachineBasicBlock &MBB) {
// Loop over the implicit uses, making sure that they are at the head of the // Loop over the implicit uses, making sure that they are at the head of the
// use order list, so they don't get reallocated. // use order list, so they don't get reallocated.
if (const unsigned *ImplicitUses = TID.ImplicitUses) for (const unsigned *ImplicitUses = TID.ImplicitUses;
for (unsigned i = 0; ImplicitUses[i]; ++i) *ImplicitUses; ++ImplicitUses)
MarkPhysRegRecentlyUsed(ImplicitUses[i]); MarkPhysRegRecentlyUsed(*ImplicitUses);
// Get the used operands into registers. This has the potential to spill // Get the used operands into registers. This has the potential to spill
// incoming values if we are out of registers. Note that we completely // incoming values if we are out of registers. Note that we completely

View File

@ -153,13 +153,13 @@ void RegAllocSimple::AllocateBasicBlock(MachineBasicBlock &MBB) {
// are used by the instruction (including implicit uses) // are used by the instruction (including implicit uses)
unsigned Opcode = MI->getOpcode(); unsigned Opcode = MI->getOpcode();
const TargetInstrDescriptor &Desc = TM->getInstrInfo().get(Opcode); const TargetInstrDescriptor &Desc = TM->getInstrInfo().get(Opcode);
if (const unsigned *Regs = Desc.ImplicitUses) const unsigned *Regs = Desc.ImplicitUses;
while (*Regs) while (*Regs)
RegsUsed[*Regs++] = true; RegsUsed[*Regs++] = true;
if (const unsigned *Regs = Desc.ImplicitDefs) Regs = Desc.ImplicitDefs;
while (*Regs) while (*Regs)
RegsUsed[*Regs++] = true; RegsUsed[*Regs++] = true;
// Loop over uses, move from memory into registers // Loop over uses, move from memory into registers
for (int i = MI->getNumOperands() - 1; i >= 0; --i) { for (int i = MI->getNumOperands() - 1; i >= 0; --i) {

View File

@ -65,6 +65,10 @@ void InstrInfoEmitter::run(std::ostream &OS) {
std::vector<Record*> Instructions = std::vector<Record*> Instructions =
Records.getAllDerivedDefinitions("Instruction"); Records.getAllDerivedDefinitions("Instruction");
// Emit empty implicit uses and defs lists
OS << "static const unsigned EmptyImpUses[] = { 0 };\n"
<< "static const unsigned EmptyImpDefs[] = { 0 };\n";
// Emit all of the instruction's implicit uses and defs... // Emit all of the instruction's implicit uses and defs...
for (unsigned i = 0, e = Instructions.size(); i != e; ++i) { for (unsigned i = 0, e = Instructions.size(); i != e; ++i) {
Record *Inst = Instructions[i]; Record *Inst = Instructions[i];
@ -113,13 +117,13 @@ void InstrInfoEmitter::emitRecord(Record *R, unsigned Num, Record *InstrInfo,
// Emit the implicit uses and defs lists... // Emit the implicit uses and defs lists...
LI = R->getValueAsListInit("Uses"); LI = R->getValueAsListInit("Uses");
if (!LI->getSize()) if (!LI->getSize())
OS << "0, "; OS << "EmptyImpUses, ";
else else
OS << R->getName() << "ImpUses, "; OS << R->getName() << "ImpUses, ";
LI = R->getValueAsListInit("Defs"); LI = R->getValueAsListInit("Defs");
if (!LI->getSize()) if (!LI->getSize())
OS << "0 "; OS << "EmptyImpDefs ";
else else
OS << R->getName() << "ImpDefs "; OS << R->getName() << "ImpDefs ";

View File

@ -138,7 +138,7 @@ void RegisterInfoEmitter::run(std::ostream &OS) {
std::vector<Record*> RegisterAliasesRecs = std::vector<Record*> RegisterAliasesRecs =
Records.getAllDerivedDefinitions("RegisterAliases"); Records.getAllDerivedDefinitions("RegisterAliases");
std::map<Record*, std::set<Record*> > RegisterAliases; std::map<Record*, std::set<Record*> > RegisterAliases;
for (unsigned i = 0, e = RegisterAliasesRecs.size(); i != e; ++i) { for (unsigned i = 0, e = RegisterAliasesRecs.size(); i != e; ++i) {
Record *AS = RegisterAliasesRecs[i]; Record *AS = RegisterAliasesRecs[i];
Record *R = AS->getValueAsDef("Reg"); Record *R = AS->getValueAsDef("Reg");
@ -166,6 +166,8 @@ void RegisterInfoEmitter::run(std::ostream &OS) {
if (!RegisterAliases.empty()) if (!RegisterAliases.empty())
OS << "\n\n // Register Alias Sets...\n"; OS << "\n\n // Register Alias Sets...\n";
// Emit the empty alias list
OS << " const unsigned Empty_AliasSet[] = { 0 };\n";
// Loop over all of the registers which have aliases, emitting the alias list // Loop over all of the registers which have aliases, emitting the alias list
// to memory. // to memory.
for (std::map<Record*, std::set<Record*> >::iterator for (std::map<Record*, std::set<Record*> >::iterator
@ -192,7 +194,7 @@ void RegisterInfoEmitter::run(std::ostream &OS) {
if (RegisterAliases.count(Reg)) if (RegisterAliases.count(Reg))
OS << Reg->getName() << "_AliasSet,\t"; OS << Reg->getName() << "_AliasSet,\t";
else else
OS << "0,\t\t"; OS << "Empty_AliasSet,\t";
OS << "0, 0 },\n"; OS << "0, 0 },\n";
} }
OS << " };\n"; // End of register descriptors... OS << " };\n"; // End of register descriptors...