Let a target specify whether it wants an assembly printer to be the MC version

or not. TableGen needs to generate the printInstruction() function as taking
an MCInstr* or a MachineInstr*, depending. Default to the old non-MC
version so that everything not yet using MC continues to just work without
fidding.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@115126 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Jim Grosbach 2010-09-30 01:29:54 +00:00
parent 97fe645bc2
commit ca96a86165
2 changed files with 9 additions and 1 deletions

View File

@ -565,6 +565,11 @@ class AsmWriter {
// OperandSpacing - Space between operand columns. // OperandSpacing - Space between operand columns.
int OperandSpacing = -1; int OperandSpacing = -1;
// isMCAsmWriter - Is this assembly writer for an MC emitter? This controls
// generation of the printInstruction() method. For MC printers, it takes
// an MCInstr* operand, otherwise it takes a MachineInstr*.
bit isMCAsmWriter = 0;
} }
def DefaultAsmWriter : AsmWriter; def DefaultAsmWriter : AsmWriter;

View File

@ -243,12 +243,15 @@ void AsmWriterEmitter::EmitPrintInstruction(raw_ostream &O) {
CodeGenTarget Target; CodeGenTarget Target;
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");
const char *MachineInstrClassName = isMC ? "MCInst" : "MachineInstr";
O << O <<
"/// printInstruction - This method is automatically generated by tablegen\n" "/// printInstruction - This method is automatically generated by tablegen\n"
"/// from the instruction set description.\n" "/// from the instruction set description.\n"
"void " << Target.getName() << ClassName "void " << Target.getName() << ClassName
<< "::printInstruction(const MachineInstr *MI, raw_ostream &O) {\n"; << "::printInstruction(const " << MachineInstrClassName
<< " *MI, raw_ostream &O) {\n";
std::vector<AsmWriterInst> Instructions; std::vector<AsmWriterInst> Instructions;