mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-21 03:32:21 +00:00
* Changes to allow lists of any type
* Reorganize Target class a bit * Fix string out of range access bug git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@7520 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
7cf0ce4b8d
commit
13c5b4cdc8
@ -41,20 +41,24 @@ void RegisterInfoEmitter::runEnums(std::ostream &OS) {
|
|||||||
OS << "}\n";
|
OS << "}\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
static Record *getRegisterInfo(RecordKeeper &RC) {
|
static Record *getTarget(RecordKeeper &RC) {
|
||||||
std::vector<Record*> RegisterInfos =
|
std::vector<Record*> Targets = RC.getAllDerivedDefinitions("Target");
|
||||||
Records.getAllDerivedDefinitions("RegisterInfo");
|
|
||||||
|
|
||||||
if (RegisterInfos.size() != 1)
|
if (Targets.size() != 1)
|
||||||
throw std::string("ERROR: Multiple subclasses of RegisterInfo defined!");
|
throw std::string("ERROR: Multiple subclasses of Target defined!");
|
||||||
return RegisterInfos[0];
|
return Targets[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
static std::string getQualifiedName(Record *R) {
|
||||||
|
std::string Namespace = R->getValueAsString("Namespace");
|
||||||
|
if (Namespace.empty()) return R->getName();
|
||||||
|
return Namespace + "::" + R->getName();
|
||||||
}
|
}
|
||||||
|
|
||||||
void RegisterInfoEmitter::runHeader(std::ostream &OS) {
|
void RegisterInfoEmitter::runHeader(std::ostream &OS) {
|
||||||
EmitSourceHeader("Register Information Header Fragment", OS);
|
EmitSourceHeader("Register Information Header Fragment", OS);
|
||||||
|
|
||||||
std::string ClassName =
|
std::string ClassName = getTarget(Records)->getName() + "GenRegisterInfo";
|
||||||
getRegisterInfo(Records)->getValueAsString("ClassName");
|
|
||||||
|
|
||||||
OS << "#include \"llvm/Target/MRegisterInfo.h\"\n\n";
|
OS << "#include \"llvm/Target/MRegisterInfo.h\"\n\n";
|
||||||
|
|
||||||
@ -65,12 +69,6 @@ void RegisterInfoEmitter::runHeader(std::ostream &OS) {
|
|||||||
<< "};\n\n";
|
<< "};\n\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
static std::string getQualifiedName(Record *R) {
|
|
||||||
std::string Namespace = R->getValueAsString("Namespace");
|
|
||||||
if (Namespace.empty()) return R->getName();
|
|
||||||
return Namespace + "::" + R->getName();
|
|
||||||
}
|
|
||||||
|
|
||||||
// RegisterInfoEmitter::run - Main register file description emitter.
|
// RegisterInfoEmitter::run - Main register file description emitter.
|
||||||
//
|
//
|
||||||
void RegisterInfoEmitter::run(std::ostream &OS) {
|
void RegisterInfoEmitter::run(std::ostream &OS) {
|
||||||
@ -95,7 +93,7 @@ void RegisterInfoEmitter::run(std::ostream &OS) {
|
|||||||
for (unsigned rc = 0, e = RegisterClasses.size(); rc != e; ++rc) {
|
for (unsigned rc = 0, e = RegisterClasses.size(); rc != e; ++rc) {
|
||||||
Record *RC = RegisterClasses[rc];
|
Record *RC = RegisterClasses[rc];
|
||||||
std::string Name = RC->getName();
|
std::string Name = RC->getName();
|
||||||
if (Name[9] == '.') {
|
if (Name.size() > 9 && Name[9] == '.') {
|
||||||
static unsigned AnonCounter = 0;
|
static unsigned AnonCounter = 0;
|
||||||
Name = "AnonRegClass_"+utostr(AnonCounter++);
|
Name = "AnonRegClass_"+utostr(AnonCounter++);
|
||||||
}
|
}
|
||||||
@ -107,7 +105,9 @@ void RegisterInfoEmitter::run(std::ostream &OS) {
|
|||||||
<< "[] = {\n ";
|
<< "[] = {\n ";
|
||||||
ListInit *RegList = RC->getValueAsListInit("MemberList");
|
ListInit *RegList = RC->getValueAsListInit("MemberList");
|
||||||
for (unsigned i = 0, e = RegList->getSize(); i != e; ++i) {
|
for (unsigned i = 0, e = RegList->getSize(); i != e; ++i) {
|
||||||
Record *Reg = RegList->getElement(i);
|
DefInit *RegDef = dynamic_cast<DefInit*>(RegList->getElement(i));
|
||||||
|
if (!RegDef) throw "Register class member is not a record!";
|
||||||
|
Record *Reg = RegDef->getDef();
|
||||||
if (!Reg->isSubClassOf(RegisterClass))
|
if (!Reg->isSubClassOf(RegisterClass))
|
||||||
throw "Register Class member '" + Reg->getName() +
|
throw "Register Class member '" + Reg->getName() +
|
||||||
" does not derive from the Register class!";
|
" does not derive from the Register class!";
|
||||||
@ -152,17 +152,19 @@ void RegisterInfoEmitter::run(std::ostream &OS) {
|
|||||||
// Add information that R aliases all of the elements in the list... and
|
// Add information that R aliases all of the elements in the list... and
|
||||||
// that everything in the list aliases R.
|
// that everything in the list aliases R.
|
||||||
for (unsigned j = 0, e = LI->getSize(); j != e; ++j) {
|
for (unsigned j = 0, e = LI->getSize(); j != e; ++j) {
|
||||||
if (RegisterAliases[R].count(LI->getElement(j)))
|
DefInit *Reg = dynamic_cast<DefInit*>(LI->getElement(j));
|
||||||
|
if (!Reg) throw "ERROR: Alias list element is not a def!";
|
||||||
|
if (RegisterAliases[R].count(Reg->getDef()))
|
||||||
std::cerr << "Warning: register alias between " << getQualifiedName(R)
|
std::cerr << "Warning: register alias between " << getQualifiedName(R)
|
||||||
<< " and " << getQualifiedName(LI->getElement(j))
|
<< " and " << getQualifiedName(Reg->getDef())
|
||||||
<< " specified multiple times!\n";
|
<< " specified multiple times!\n";
|
||||||
RegisterAliases[R].insert(LI->getElement(j));
|
RegisterAliases[R].insert(Reg->getDef());
|
||||||
|
|
||||||
if (RegisterAliases[LI->getElement(j)].count(R))
|
if (RegisterAliases[Reg->getDef()].count(R))
|
||||||
std::cerr << "Warning: register alias between " << getQualifiedName(R)
|
std::cerr << "Warning: register alias between " << getQualifiedName(R)
|
||||||
<< " and " << getQualifiedName(LI->getElement(j))
|
<< " and " << getQualifiedName(Reg->getDef())
|
||||||
<< " specified multiple times!\n";
|
<< " specified multiple times!\n";
|
||||||
RegisterAliases[LI->getElement(j)].insert(R);
|
RegisterAliases[Reg->getDef()].insert(R);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -196,8 +198,8 @@ void RegisterInfoEmitter::run(std::ostream &OS) {
|
|||||||
OS << " };\n"; // End of register descriptors...
|
OS << " };\n"; // End of register descriptors...
|
||||||
OS << "}\n\n"; // End of anonymous namespace...
|
OS << "}\n\n"; // End of anonymous namespace...
|
||||||
|
|
||||||
Record *RegisterInfo = getRegisterInfo(Records);
|
Record *Target = getTarget(Records);
|
||||||
std::string ClassName = RegisterInfo->getValueAsString("ClassName");
|
std::string ClassName = Target->getName() + "GenRegisterInfo";
|
||||||
|
|
||||||
// Emit the constructor of the class...
|
// Emit the constructor of the class...
|
||||||
OS << ClassName << "::" << ClassName
|
OS << ClassName << "::" << ClassName
|
||||||
@ -210,8 +212,11 @@ void RegisterInfoEmitter::run(std::ostream &OS) {
|
|||||||
OS << "const unsigned* " << ClassName << "::getCalleeSaveRegs() const {\n"
|
OS << "const unsigned* " << ClassName << "::getCalleeSaveRegs() const {\n"
|
||||||
<< " static const unsigned CalleeSaveRegs[] = {\n ";
|
<< " static const unsigned CalleeSaveRegs[] = {\n ";
|
||||||
|
|
||||||
ListInit *LI = RegisterInfo->getValueAsListInit("CalleeSavedRegisters");
|
ListInit *LI = Target->getValueAsListInit("CalleeSavedRegisters");
|
||||||
for (unsigned i = 0, e = LI->getSize(); i != e; ++i)
|
for (unsigned i = 0, e = LI->getSize(); i != e; ++i)
|
||||||
OS << getQualifiedName(LI->getElement(i)) << ", ";
|
if (DefInit *DI = dynamic_cast<DefInit*>(LI->getElement(i)))
|
||||||
|
OS << getQualifiedName(DI->getDef()) << ", ";
|
||||||
|
else
|
||||||
|
throw "Expected register definition in CalleeSavedRegisters list!";
|
||||||
OS << " 0\n };\n return CalleeSaveRegs;\n}\n\n";
|
OS << " 0\n };\n return CalleeSaveRegs;\n}\n\n";
|
||||||
}
|
}
|
||||||
|
@ -41,20 +41,24 @@ void RegisterInfoEmitter::runEnums(std::ostream &OS) {
|
|||||||
OS << "}\n";
|
OS << "}\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
static Record *getRegisterInfo(RecordKeeper &RC) {
|
static Record *getTarget(RecordKeeper &RC) {
|
||||||
std::vector<Record*> RegisterInfos =
|
std::vector<Record*> Targets = RC.getAllDerivedDefinitions("Target");
|
||||||
Records.getAllDerivedDefinitions("RegisterInfo");
|
|
||||||
|
|
||||||
if (RegisterInfos.size() != 1)
|
if (Targets.size() != 1)
|
||||||
throw std::string("ERROR: Multiple subclasses of RegisterInfo defined!");
|
throw std::string("ERROR: Multiple subclasses of Target defined!");
|
||||||
return RegisterInfos[0];
|
return Targets[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
static std::string getQualifiedName(Record *R) {
|
||||||
|
std::string Namespace = R->getValueAsString("Namespace");
|
||||||
|
if (Namespace.empty()) return R->getName();
|
||||||
|
return Namespace + "::" + R->getName();
|
||||||
}
|
}
|
||||||
|
|
||||||
void RegisterInfoEmitter::runHeader(std::ostream &OS) {
|
void RegisterInfoEmitter::runHeader(std::ostream &OS) {
|
||||||
EmitSourceHeader("Register Information Header Fragment", OS);
|
EmitSourceHeader("Register Information Header Fragment", OS);
|
||||||
|
|
||||||
std::string ClassName =
|
std::string ClassName = getTarget(Records)->getName() + "GenRegisterInfo";
|
||||||
getRegisterInfo(Records)->getValueAsString("ClassName");
|
|
||||||
|
|
||||||
OS << "#include \"llvm/Target/MRegisterInfo.h\"\n\n";
|
OS << "#include \"llvm/Target/MRegisterInfo.h\"\n\n";
|
||||||
|
|
||||||
@ -65,12 +69,6 @@ void RegisterInfoEmitter::runHeader(std::ostream &OS) {
|
|||||||
<< "};\n\n";
|
<< "};\n\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
static std::string getQualifiedName(Record *R) {
|
|
||||||
std::string Namespace = R->getValueAsString("Namespace");
|
|
||||||
if (Namespace.empty()) return R->getName();
|
|
||||||
return Namespace + "::" + R->getName();
|
|
||||||
}
|
|
||||||
|
|
||||||
// RegisterInfoEmitter::run - Main register file description emitter.
|
// RegisterInfoEmitter::run - Main register file description emitter.
|
||||||
//
|
//
|
||||||
void RegisterInfoEmitter::run(std::ostream &OS) {
|
void RegisterInfoEmitter::run(std::ostream &OS) {
|
||||||
@ -95,7 +93,7 @@ void RegisterInfoEmitter::run(std::ostream &OS) {
|
|||||||
for (unsigned rc = 0, e = RegisterClasses.size(); rc != e; ++rc) {
|
for (unsigned rc = 0, e = RegisterClasses.size(); rc != e; ++rc) {
|
||||||
Record *RC = RegisterClasses[rc];
|
Record *RC = RegisterClasses[rc];
|
||||||
std::string Name = RC->getName();
|
std::string Name = RC->getName();
|
||||||
if (Name[9] == '.') {
|
if (Name.size() > 9 && Name[9] == '.') {
|
||||||
static unsigned AnonCounter = 0;
|
static unsigned AnonCounter = 0;
|
||||||
Name = "AnonRegClass_"+utostr(AnonCounter++);
|
Name = "AnonRegClass_"+utostr(AnonCounter++);
|
||||||
}
|
}
|
||||||
@ -107,7 +105,9 @@ void RegisterInfoEmitter::run(std::ostream &OS) {
|
|||||||
<< "[] = {\n ";
|
<< "[] = {\n ";
|
||||||
ListInit *RegList = RC->getValueAsListInit("MemberList");
|
ListInit *RegList = RC->getValueAsListInit("MemberList");
|
||||||
for (unsigned i = 0, e = RegList->getSize(); i != e; ++i) {
|
for (unsigned i = 0, e = RegList->getSize(); i != e; ++i) {
|
||||||
Record *Reg = RegList->getElement(i);
|
DefInit *RegDef = dynamic_cast<DefInit*>(RegList->getElement(i));
|
||||||
|
if (!RegDef) throw "Register class member is not a record!";
|
||||||
|
Record *Reg = RegDef->getDef();
|
||||||
if (!Reg->isSubClassOf(RegisterClass))
|
if (!Reg->isSubClassOf(RegisterClass))
|
||||||
throw "Register Class member '" + Reg->getName() +
|
throw "Register Class member '" + Reg->getName() +
|
||||||
" does not derive from the Register class!";
|
" does not derive from the Register class!";
|
||||||
@ -152,17 +152,19 @@ void RegisterInfoEmitter::run(std::ostream &OS) {
|
|||||||
// Add information that R aliases all of the elements in the list... and
|
// Add information that R aliases all of the elements in the list... and
|
||||||
// that everything in the list aliases R.
|
// that everything in the list aliases R.
|
||||||
for (unsigned j = 0, e = LI->getSize(); j != e; ++j) {
|
for (unsigned j = 0, e = LI->getSize(); j != e; ++j) {
|
||||||
if (RegisterAliases[R].count(LI->getElement(j)))
|
DefInit *Reg = dynamic_cast<DefInit*>(LI->getElement(j));
|
||||||
|
if (!Reg) throw "ERROR: Alias list element is not a def!";
|
||||||
|
if (RegisterAliases[R].count(Reg->getDef()))
|
||||||
std::cerr << "Warning: register alias between " << getQualifiedName(R)
|
std::cerr << "Warning: register alias between " << getQualifiedName(R)
|
||||||
<< " and " << getQualifiedName(LI->getElement(j))
|
<< " and " << getQualifiedName(Reg->getDef())
|
||||||
<< " specified multiple times!\n";
|
<< " specified multiple times!\n";
|
||||||
RegisterAliases[R].insert(LI->getElement(j));
|
RegisterAliases[R].insert(Reg->getDef());
|
||||||
|
|
||||||
if (RegisterAliases[LI->getElement(j)].count(R))
|
if (RegisterAliases[Reg->getDef()].count(R))
|
||||||
std::cerr << "Warning: register alias between " << getQualifiedName(R)
|
std::cerr << "Warning: register alias between " << getQualifiedName(R)
|
||||||
<< " and " << getQualifiedName(LI->getElement(j))
|
<< " and " << getQualifiedName(Reg->getDef())
|
||||||
<< " specified multiple times!\n";
|
<< " specified multiple times!\n";
|
||||||
RegisterAliases[LI->getElement(j)].insert(R);
|
RegisterAliases[Reg->getDef()].insert(R);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -196,8 +198,8 @@ void RegisterInfoEmitter::run(std::ostream &OS) {
|
|||||||
OS << " };\n"; // End of register descriptors...
|
OS << " };\n"; // End of register descriptors...
|
||||||
OS << "}\n\n"; // End of anonymous namespace...
|
OS << "}\n\n"; // End of anonymous namespace...
|
||||||
|
|
||||||
Record *RegisterInfo = getRegisterInfo(Records);
|
Record *Target = getTarget(Records);
|
||||||
std::string ClassName = RegisterInfo->getValueAsString("ClassName");
|
std::string ClassName = Target->getName() + "GenRegisterInfo";
|
||||||
|
|
||||||
// Emit the constructor of the class...
|
// Emit the constructor of the class...
|
||||||
OS << ClassName << "::" << ClassName
|
OS << ClassName << "::" << ClassName
|
||||||
@ -210,8 +212,11 @@ void RegisterInfoEmitter::run(std::ostream &OS) {
|
|||||||
OS << "const unsigned* " << ClassName << "::getCalleeSaveRegs() const {\n"
|
OS << "const unsigned* " << ClassName << "::getCalleeSaveRegs() const {\n"
|
||||||
<< " static const unsigned CalleeSaveRegs[] = {\n ";
|
<< " static const unsigned CalleeSaveRegs[] = {\n ";
|
||||||
|
|
||||||
ListInit *LI = RegisterInfo->getValueAsListInit("CalleeSavedRegisters");
|
ListInit *LI = Target->getValueAsListInit("CalleeSavedRegisters");
|
||||||
for (unsigned i = 0, e = LI->getSize(); i != e; ++i)
|
for (unsigned i = 0, e = LI->getSize(); i != e; ++i)
|
||||||
OS << getQualifiedName(LI->getElement(i)) << ", ";
|
if (DefInit *DI = dynamic_cast<DefInit*>(LI->getElement(i)))
|
||||||
|
OS << getQualifiedName(DI->getDef()) << ", ";
|
||||||
|
else
|
||||||
|
throw "Expected register definition in CalleeSavedRegisters list!";
|
||||||
OS << " 0\n };\n return CalleeSaveRegs;\n}\n\n";
|
OS << " 0\n };\n return CalleeSaveRegs;\n}\n\n";
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user