mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-19 10:53:55 +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.
|
||||
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;
|
||||
|
||||
|
@ -243,12 +243,15 @@ void AsmWriterEmitter::EmitPrintInstruction(raw_ostream &O) {
|
||||
CodeGenTarget Target;
|
||||
Record *AsmWriter = Target.getAsmWriter();
|
||||
std::string ClassName = AsmWriter->getValueAsString("AsmWriterClassName");
|
||||
bool isMC = AsmWriter->getValueAsBit("isMCAsmWriter");
|
||||
const char *MachineInstrClassName = isMC ? "MCInst" : "MachineInstr";
|
||||
|
||||
O <<
|
||||
"/// printInstruction - This method is automatically generated by tablegen\n"
|
||||
"/// from the instruction set description.\n"
|
||||
"void " << Target.getName() << ClassName
|
||||
<< "::printInstruction(const MachineInstr *MI, raw_ostream &O) {\n";
|
||||
<< "::printInstruction(const " << MachineInstrClassName
|
||||
<< " *MI, raw_ostream &O) {\n";
|
||||
|
||||
std::vector<AsmWriterInst> Instructions;
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user