mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 16:33:28 +00:00
TableGen: Refactor AsmWriterEmitter to keep AsmWriterInsts.
These used to be referenced by the CGI->AWI map (in AsmWriterEmitter), but stored in a vector local to EmitPrintInstruction. Move the vector to AsmWriterEmitter too. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@193525 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
23125d02d9
commit
254ce94c26
@ -32,10 +32,12 @@ using namespace llvm;
|
|||||||
namespace {
|
namespace {
|
||||||
class AsmWriterEmitter {
|
class AsmWriterEmitter {
|
||||||
RecordKeeper &Records;
|
RecordKeeper &Records;
|
||||||
|
CodeGenTarget Target;
|
||||||
std::map<const CodeGenInstruction*, AsmWriterInst*> CGIAWIMap;
|
std::map<const CodeGenInstruction*, AsmWriterInst*> CGIAWIMap;
|
||||||
std::vector<const CodeGenInstruction*> NumberedInstructions;
|
std::vector<const CodeGenInstruction*> NumberedInstructions;
|
||||||
|
std::vector<AsmWriterInst> Instructions;
|
||||||
public:
|
public:
|
||||||
AsmWriterEmitter(RecordKeeper &R) : Records(R) {}
|
AsmWriterEmitter(RecordKeeper &R);
|
||||||
|
|
||||||
void run(raw_ostream &o);
|
void run(raw_ostream &o);
|
||||||
|
|
||||||
@ -273,9 +275,9 @@ static void UnescapeString(std::string &Str) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// EmitPrintInstruction - Generate the code for the "printInstruction" method
|
/// EmitPrintInstruction - Generate the code for the "printInstruction" method
|
||||||
/// implementation.
|
/// implementation. Destroys all instances of AsmWriterInst information, by
|
||||||
|
/// clearing the Instructions vector.
|
||||||
void AsmWriterEmitter::EmitPrintInstruction(raw_ostream &O) {
|
void AsmWriterEmitter::EmitPrintInstruction(raw_ostream &O) {
|
||||||
CodeGenTarget Target(Records);
|
|
||||||
Record *AsmWriter = Target.getAsmWriter();
|
Record *AsmWriter = Target.getAsmWriter();
|
||||||
std::string ClassName = AsmWriter->getValueAsString("AsmWriterClassName");
|
std::string ClassName = AsmWriter->getValueAsString("AsmWriterClassName");
|
||||||
bool isMC = AsmWriter->getValueAsBit("isMCAsmWriter");
|
bool isMC = AsmWriter->getValueAsBit("isMCAsmWriter");
|
||||||
@ -288,27 +290,6 @@ void AsmWriterEmitter::EmitPrintInstruction(raw_ostream &O) {
|
|||||||
<< "::printInstruction(const " << MachineInstrClassName
|
<< "::printInstruction(const " << MachineInstrClassName
|
||||||
<< " *MI, raw_ostream &O) {\n";
|
<< " *MI, raw_ostream &O) {\n";
|
||||||
|
|
||||||
std::vector<AsmWriterInst> Instructions;
|
|
||||||
|
|
||||||
for (CodeGenTarget::inst_iterator I = Target.inst_begin(),
|
|
||||||
E = Target.inst_end(); I != E; ++I)
|
|
||||||
if (!(*I)->AsmString.empty() &&
|
|
||||||
(*I)->TheDef->getName() != "PHI")
|
|
||||||
Instructions.push_back(
|
|
||||||
AsmWriterInst(**I,
|
|
||||||
AsmWriter->getValueAsInt("Variant"),
|
|
||||||
AsmWriter->getValueAsInt("FirstOperandColumn"),
|
|
||||||
AsmWriter->getValueAsInt("OperandSpacing")));
|
|
||||||
|
|
||||||
// Get the instruction numbering.
|
|
||||||
NumberedInstructions = Target.getInstructionsByEnumValue();
|
|
||||||
|
|
||||||
// Compute the CodeGenInstruction -> AsmWriterInst mapping. Note that not
|
|
||||||
// all machine instructions are necessarily being printed, so there may be
|
|
||||||
// target instructions not in this map.
|
|
||||||
for (unsigned i = 0, e = Instructions.size(); i != e; ++i)
|
|
||||||
CGIAWIMap.insert(std::make_pair(Instructions[i].CGI, &Instructions[i]));
|
|
||||||
|
|
||||||
// Build an aggregate string, and build a table of offsets into it.
|
// Build an aggregate string, and build a table of offsets into it.
|
||||||
SequenceToOffsetTable<std::string> StringTable;
|
SequenceToOffsetTable<std::string> StringTable;
|
||||||
|
|
||||||
@ -592,7 +573,6 @@ emitRegisterNameString(raw_ostream &O, StringRef AltName,
|
|||||||
}
|
}
|
||||||
|
|
||||||
void AsmWriterEmitter::EmitGetRegisterName(raw_ostream &O) {
|
void AsmWriterEmitter::EmitGetRegisterName(raw_ostream &O) {
|
||||||
CodeGenTarget Target(Records);
|
|
||||||
Record *AsmWriter = Target.getAsmWriter();
|
Record *AsmWriter = Target.getAsmWriter();
|
||||||
std::string ClassName = AsmWriter->getValueAsString("AsmWriterClassName");
|
std::string ClassName = AsmWriter->getValueAsString("AsmWriterClassName");
|
||||||
const std::vector<CodeGenRegister*> &Registers =
|
const std::vector<CodeGenRegister*> &Registers =
|
||||||
@ -782,7 +762,6 @@ static unsigned CountResultNumOperands(StringRef AsmString) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void AsmWriterEmitter::EmitPrintAliasInstruction(raw_ostream &O) {
|
void AsmWriterEmitter::EmitPrintAliasInstruction(raw_ostream &O) {
|
||||||
CodeGenTarget Target(Records);
|
|
||||||
Record *AsmWriter = Target.getAsmWriter();
|
Record *AsmWriter = Target.getAsmWriter();
|
||||||
|
|
||||||
if (!AsmWriter->getValueAsBit("isMCAsmWriter"))
|
if (!AsmWriter->getValueAsBit("isMCAsmWriter"))
|
||||||
@ -1000,6 +979,27 @@ void AsmWriterEmitter::EmitPrintAliasInstruction(raw_ostream &O) {
|
|||||||
O << "#endif // PRINT_ALIAS_INSTR\n";
|
O << "#endif // PRINT_ALIAS_INSTR\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
AsmWriterEmitter::AsmWriterEmitter(RecordKeeper &R) : Records(R), Target(R) {
|
||||||
|
Record *AsmWriter = Target.getAsmWriter();
|
||||||
|
for (CodeGenTarget::inst_iterator I = Target.inst_begin(),
|
||||||
|
E = Target.inst_end();
|
||||||
|
I != E; ++I)
|
||||||
|
if (!(*I)->AsmString.empty() && (*I)->TheDef->getName() != "PHI")
|
||||||
|
Instructions.push_back(
|
||||||
|
AsmWriterInst(**I, AsmWriter->getValueAsInt("Variant"),
|
||||||
|
AsmWriter->getValueAsInt("FirstOperandColumn"),
|
||||||
|
AsmWriter->getValueAsInt("OperandSpacing")));
|
||||||
|
|
||||||
|
// Get the instruction numbering.
|
||||||
|
NumberedInstructions = Target.getInstructionsByEnumValue();
|
||||||
|
|
||||||
|
// Compute the CodeGenInstruction -> AsmWriterInst mapping. Note that not
|
||||||
|
// all machine instructions are necessarily being printed, so there may be
|
||||||
|
// target instructions not in this map.
|
||||||
|
for (unsigned i = 0, e = Instructions.size(); i != e; ++i)
|
||||||
|
CGIAWIMap.insert(std::make_pair(Instructions[i].CGI, &Instructions[i]));
|
||||||
|
}
|
||||||
|
|
||||||
void AsmWriterEmitter::run(raw_ostream &O) {
|
void AsmWriterEmitter::run(raw_ostream &O) {
|
||||||
EmitPrintInstruction(O);
|
EmitPrintInstruction(O);
|
||||||
EmitGetRegisterName(O);
|
EmitGetRegisterName(O);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user