mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-01 00:33:09 +00:00
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:
parent
97fe645bc2
commit
ca96a86165
@ -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;
|
||||||
|
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user