mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 00:32:55 +00:00
Expose the derived register classes to the public header, allowing them
to be accessed. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@22930 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
ecbce617ca
commit
60200e5d32
@ -69,7 +69,17 @@ void RegisterInfoEmitter::runHeader(std::ostream &OS) {
|
||||
<< " { // Register classes\n";
|
||||
for (unsigned i = 0, e = RegisterClasses.size(); i != e; ++i) {
|
||||
const std::string &Name = RegisterClasses[i].getName();
|
||||
OS << " extern TargetRegisterClass * const "<< Name <<"RegisterClass;\n";
|
||||
|
||||
// Output the register class definition.
|
||||
OS << " struct " << Name << "Class : public TargetRegisterClass {\n"
|
||||
<< " " << Name << "Class();\n"
|
||||
<< RegisterClasses[i].MethodProtos << " };\n";
|
||||
|
||||
// Output the extern for the instance.
|
||||
OS << " extern " << Name << "Class\t" << Name << "RegClass;\n";
|
||||
// Output the extern for the pointer to the instance (should remove).
|
||||
OS << " static TargetRegisterClass * const "<< Name <<"RegisterClass = &"
|
||||
<< Name << "RegClass;\n";
|
||||
}
|
||||
OS << "} // end of namespace " << TargetName << "\n\n";
|
||||
}
|
||||
@ -121,13 +131,6 @@ void RegisterInfoEmitter::run(std::ostream &OS) {
|
||||
RegClassesBelongedTo.insert(std::make_pair(Reg, &RC));
|
||||
}
|
||||
OS << "\n };\n\n";
|
||||
|
||||
OS << " struct " << Name << "Class : public TargetRegisterClass {\n"
|
||||
<< " " << Name << "Class() : TargetRegisterClass("
|
||||
<< RC.SpillSize/8 << ", " << RC.SpillAlignment/8 << ", " << Name << ", "
|
||||
<< Name << " + " << RC.Elements.size() << ") {}\n"
|
||||
<< RC.MethodProtos << " };\n";
|
||||
OS << RC.MethodBodies << "\n";
|
||||
}
|
||||
OS << "} // end anonymous namespace\n\n";
|
||||
|
||||
@ -137,7 +140,17 @@ void RegisterInfoEmitter::run(std::ostream &OS) {
|
||||
<< " { // Register class instances\n";
|
||||
for (unsigned i = 0, e = RegisterClasses.size(); i != e; ++i)
|
||||
OS << " " << RegisterClasses[i].getName() << "Class\t"
|
||||
<< RegisterClasses[i].getName() << "RegClassInstance;\n";
|
||||
<< RegisterClasses[i].getName() << "RegClass;\n";
|
||||
|
||||
for (unsigned i = 0, e = RegisterClasses.size(); i != e; ++i) {
|
||||
const CodeGenRegisterClass &RC = RegisterClasses[i];
|
||||
OS << RC.MethodBodies << "\n";
|
||||
OS << RC.getName() << "Class::" << RC.getName()
|
||||
<< "Class() : TargetRegisterClass(" << RC.SpillSize/8 << ", "
|
||||
<< RC.SpillAlignment/8 << ", " << RC.getName() << ", "
|
||||
<< RC.getName() << " + " << RC.Elements.size() << ") {}\n";
|
||||
}
|
||||
|
||||
OS << "}\n";
|
||||
}
|
||||
|
||||
@ -145,7 +158,7 @@ void RegisterInfoEmitter::run(std::ostream &OS) {
|
||||
OS << " const TargetRegisterClass* const RegisterClasses[] = {\n";
|
||||
for (unsigned i = 0, e = RegisterClasses.size(); i != e; ++i)
|
||||
OS << " &" << getQualifiedName(RegisterClasses[i].TheDef)
|
||||
<< "RegClassInstance,\n";
|
||||
<< "RegClass,\n";
|
||||
OS << " };\n";
|
||||
|
||||
// Emit register class aliases...
|
||||
@ -238,18 +251,6 @@ void RegisterInfoEmitter::run(std::ostream &OS) {
|
||||
OS << " };\n"; // End of register descriptors...
|
||||
OS << "}\n\n"; // End of anonymous namespace...
|
||||
|
||||
if (!RegisterClasses.empty()) {
|
||||
OS << "namespace " << RegisterClasses[0].Namespace
|
||||
<< " { // Register classes\n";
|
||||
for (unsigned i = 0, e = RegisterClasses.size(); i != e; ++i) {
|
||||
OS << " TargetRegisterClass * const " << RegisterClasses[i].getName()
|
||||
<< "RegisterClass = &" << getQualifiedName(RegisterClasses[i].TheDef)
|
||||
<< "RegClassInstance;\n";
|
||||
}
|
||||
OS << "} // end of namespace " << RegisterClasses[0].Namespace << "\n\n";
|
||||
}
|
||||
|
||||
|
||||
std::string ClassName = Target.getName() + "GenRegisterInfo";
|
||||
|
||||
// Emit the constructor of the class...
|
||||
|
Loading…
x
Reference in New Issue
Block a user