Move the composite map into CodeGenSubRegIndex.

Each SubRegIndex keeps track of how it composes.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@149423 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Jakob Stoklund Olesen 2012-01-31 21:44:11 +00:00
parent 5fcc156344
commit 90498b195b
3 changed files with 51 additions and 30 deletions

View File

@ -49,6 +49,16 @@ std::string CodeGenSubRegIndex::getQualifiedName() const {
return N; return N;
} }
void CodeGenSubRegIndex::cleanComposites() {
// Clean out redundant mappings of the form this+X -> X.
for (CompMap::iterator i = Composed.begin(), e = Composed.end(); i != e;) {
CompMap::iterator j = i;
++i;
if (j->first == j->second)
Composed.erase(j);
}
}
//===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===//
// CodeGenRegister // CodeGenRegister
//===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===//
@ -168,7 +178,7 @@ CodeGenRegister::getSubRegs(CodeGenRegBank &RegBank) {
Orphan &O = Orphans[i]; Orphan &O = Orphans[i];
if (!O.SubReg) if (!O.SubReg)
continue; continue;
SubRegs[RegBank.getCompositeSubRegIndex(O.First, O.Second, true)] = SubRegs[RegBank.getCompositeSubRegIndex(O.First, O.Second)] =
O.SubReg; O.SubReg;
} }
return SubRegs; return SubRegs;
@ -679,16 +689,16 @@ CodeGenRegisterClass *CodeGenRegBank::getRegClass(Record *Def) {
CodeGenSubRegIndex* CodeGenSubRegIndex*
CodeGenRegBank::getCompositeSubRegIndex(CodeGenSubRegIndex *A, CodeGenRegBank::getCompositeSubRegIndex(CodeGenSubRegIndex *A,
CodeGenSubRegIndex *B, CodeGenSubRegIndex *B) {
bool create) {
// Look for an existing entry. // Look for an existing entry.
CodeGenSubRegIndex *&Comp = Composite[std::make_pair(A, B)]; CodeGenSubRegIndex *Comp = A->compose(B);
if (Comp || !create) if (Comp)
return Comp; return Comp;
// None exists, synthesize one. // None exists, synthesize one.
std::string Name = A->getName() + "_then_" + B->getName(); std::string Name = A->getName() + "_then_" + B->getName();
Comp = getSubRegIdx(new Record(Name, SMLoc(), Records)); Comp = getSubRegIdx(new Record(Name, SMLoc(), Records));
A->addComposite(B, Comp);
return Comp; return Comp;
} }
@ -707,8 +717,7 @@ void CodeGenRegBank::computeComposites() {
// Try composing Idx1 with another SubRegIndex. // Try composing Idx1 with another SubRegIndex.
for (CodeGenRegister::SubRegMap::const_iterator i2 = SRM2.begin(), for (CodeGenRegister::SubRegMap::const_iterator i2 = SRM2.begin(),
e2 = SRM2.end(); i2 != e2; ++i2) { e2 = SRM2.end(); i2 != e2; ++i2) {
std::pair<CodeGenSubRegIndex*, CodeGenSubRegIndex*> CodeGenSubRegIndex *Idx2 = i2->first;
IdxPair(Idx1, i2->first);
CodeGenRegister *Reg3 = i2->second; CodeGenRegister *Reg3 = i2->second;
// Ignore identity compositions. // Ignore identity compositions.
if (Reg2 == Reg3) if (Reg2 == Reg3)
@ -717,31 +726,23 @@ void CodeGenRegBank::computeComposites() {
for (CodeGenRegister::SubRegMap::const_iterator i1d = SRM1.begin(), for (CodeGenRegister::SubRegMap::const_iterator i1d = SRM1.begin(),
e1d = SRM1.end(); i1d != e1d; ++i1d) { e1d = SRM1.end(); i1d != e1d; ++i1d) {
if (i1d->second == Reg3) { if (i1d->second == Reg3) {
std::pair<CompositeMap::iterator, bool> Ins =
Composite.insert(std::make_pair(IdxPair, i1d->first));
// Conflicting composition? Emit a warning but allow it. // Conflicting composition? Emit a warning but allow it.
if (!Ins.second && Ins.first->second != i1d->first) { if (CodeGenSubRegIndex *Prev = Idx1->addComposite(Idx2, i1d->first))
errs() << "Warning: SubRegIndex " << Idx1->getQualifiedName() errs() << "Warning: SubRegIndex " << Idx1->getQualifiedName()
<< " and " << IdxPair.second->getQualifiedName() << " and " << Idx2->getQualifiedName()
<< " compose ambiguously as " << " compose ambiguously as "
<< Ins.first->second->getQualifiedName() << " or " << Prev->getQualifiedName() << " or "
<< i1d->first->getQualifiedName() << "\n"; << i1d->first->getQualifiedName() << "\n";
} }
} }
} }
} }
} }
}
// We don't care about the difference between (Idx1, Idx2) -> Idx2 and invalid // We don't care about the difference between (Idx1, Idx2) -> Idx2 and invalid
// compositions, so remove any mappings of that form. // compositions, so remove any mappings of that form.
for (CompositeMap::iterator i = Composite.begin(), e = Composite.end(); for (unsigned i = 0, e = SubRegIndices.size(); i != e; ++i)
i != e;) { SubRegIndices[i]->cleanComposites();
CompositeMap::iterator j = i;
++i;
if (j->first.second == j->second)
Composite.erase(j);
}
} }
// Compute sets of overlapping registers. // Compute sets of overlapping registers.

View File

@ -51,6 +51,34 @@ namespace llvm {
return A->EnumValue < B->EnumValue; return A->EnumValue < B->EnumValue;
} }
}; };
// Map of composite subreg indices.
typedef std::map<CodeGenSubRegIndex*, CodeGenSubRegIndex*, Less> CompMap;
// Returns the subreg index that results from composing this with Idx.
// Returns NULL if this and Idx don't compose.
CodeGenSubRegIndex *compose(CodeGenSubRegIndex *Idx) const {
CompMap::const_iterator I = Composed.find(Idx);
return I == Composed.end() ? 0 : I->second;
}
// Add a composite subreg index: this+A = B.
// Return a conflicting composite, or NULL
CodeGenSubRegIndex *addComposite(CodeGenSubRegIndex *A,
CodeGenSubRegIndex *B) {
std::pair<CompMap::iterator, bool> Ins =
Composed.insert(std::make_pair(A, B));
return (Ins.second || Ins.first->second == B) ? 0 : Ins.first->second;
}
// Clean out redundant composite mappings.
void cleanComposites();
// Return the map of composites.
const CompMap &getComposites() const { return Composed; }
private:
CompMap Composed;
}; };
/// CodeGenRegister - Represents a register definition. /// CodeGenRegister - Represents a register definition.
@ -298,12 +326,6 @@ namespace llvm {
void inferMatchingSuperRegClass(CodeGenRegisterClass *RC, void inferMatchingSuperRegClass(CodeGenRegisterClass *RC,
unsigned FirstSubRegRC = 0); unsigned FirstSubRegRC = 0);
// Composite SubRegIndex instances.
// Map (SubRegIndex, SubRegIndex) -> SubRegIndex.
typedef DenseMap<std::pair<CodeGenSubRegIndex*, CodeGenSubRegIndex*>,
CodeGenSubRegIndex*> CompositeMap;
CompositeMap Composite;
// Populate the Composite map from sub-register relationships. // Populate the Composite map from sub-register relationships.
void computeComposites(); void computeComposites();
@ -323,8 +345,7 @@ namespace llvm {
// Find or create a sub-register index representing the A+B composition. // Find or create a sub-register index representing the A+B composition.
CodeGenSubRegIndex *getCompositeSubRegIndex(CodeGenSubRegIndex *A, CodeGenSubRegIndex *getCompositeSubRegIndex(CodeGenSubRegIndex *A,
CodeGenSubRegIndex *B, CodeGenSubRegIndex *B);
bool create = false);
const std::vector<CodeGenRegister*> &getRegisters() { return Registers; } const std::vector<CodeGenRegister*> &getRegisters() { return Registers; }

View File

@ -766,8 +766,7 @@ RegisterInfoEmitter::runTargetDesc(raw_ostream &OS, CodeGenTarget &Target,
bool Open = false; bool Open = false;
for (unsigned j = 0; j != e; ++j) { for (unsigned j = 0; j != e; ++j) {
if (CodeGenSubRegIndex *Comp = if (CodeGenSubRegIndex *Comp =
RegBank.getCompositeSubRegIndex(SubRegIndices[i], SubRegIndices[i]->compose(SubRegIndices[j])) {
SubRegIndices[j])) {
if (!Open) { if (!Open) {
OS << " case " << SubRegIndices[i]->getQualifiedName() OS << " case " << SubRegIndices[i]->getQualifiedName()
<< ": switch(IdxB) {\n default: return IdxB;\n"; << ": switch(IdxB) {\n default: return IdxB;\n";