Ignore X = X assignments that was causing Alkis's rewrite of X86.td to crash

tblgen.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@11948 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Chris Lattner 2004-02-28 17:31:28 +00:00
parent 7b6ee7d8f1
commit 81d50adfaf

View File

@ -68,7 +68,7 @@ static void addSuperClass(Record *SC) {
static void setValue(const std::string &ValName, static void setValue(const std::string &ValName,
std::vector<unsigned> *BitList, Init *V) { std::vector<unsigned> *BitList, Init *V) {
if (!V) return ; if (!V) return;
RecordVal *RV = CurRec->getValue(ValName); RecordVal *RV = CurRec->getValue(ValName);
if (RV == 0) { if (RV == 0) {
@ -76,6 +76,13 @@ static void setValue(const std::string &ValName,
exit(1); exit(1);
} }
// Do not allow assignments like 'X = X'. This will just cause infinite loops
// in the resolution machinery.
if (!BitList)
if (VarInit *VI = dynamic_cast<VarInit*>(V))
if (VI->getName() == ValName)
return;
// If we are assigning to a subset of the bits in the value... then we must be // If we are assigning to a subset of the bits in the value... then we must be
// assigning to a field of BitsRecTy, which must have a BitsInit // assigning to a field of BitsRecTy, which must have a BitsInit
// initializer... // initializer...
@ -154,10 +161,9 @@ static void addSubClass(Record *SC, const std::vector<Init*> &TemplateArgs) {
} }
} }
// Since everything went well, we can now set the "superclass" list for the // Since everything went well, we can now set the "superclass" list for the
// current record. // current record.
const std::vector<Record*> &SCs = SC->getSuperClasses(); const std::vector<Record*> &SCs = SC->getSuperClasses();
for (unsigned i = 0, e = SCs.size(); i != e; ++i) for (unsigned i = 0, e = SCs.size(); i != e; ++i)
addSuperClass(SCs[i]); addSuperClass(SCs[i]);
addSuperClass(SC); addSuperClass(SC);