From 0cfcc1e8072af7f3d92bbcdba48da551cccd90be Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Fri, 27 Jan 2006 02:10:50 +0000 Subject: [PATCH] Use printInlineAsm to, well, print inline asm's. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@25677 91177308-0d34-0410-b5e6-96231b3b80d8 --- utils/TableGen/AsmWriterEmitter.cpp | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/utils/TableGen/AsmWriterEmitter.cpp b/utils/TableGen/AsmWriterEmitter.cpp index cc59aa105ad..e6ad2bcf810 100644 --- a/utils/TableGen/AsmWriterEmitter.cpp +++ b/utils/TableGen/AsmWriterEmitter.cpp @@ -345,6 +345,9 @@ void AsmWriterEmitter::run(std::ostream &O) { break; } + std::vector NumberedInstructions; + Target.getInstructionsByEnumValue(NumberedInstructions); + if (AllStartWithString) { // Compute the CodeGenInstruction -> AsmWriterInst mapping. Note that not // all machine instructions are necessarily being printed, so there may be @@ -354,9 +357,6 @@ void AsmWriterEmitter::run(std::ostream &O) { CGIAWIMap.insert(std::make_pair(Instructions[i].CGI, &Instructions[i])); // Emit a table of constant strings. - std::vector NumberedInstructions; - Target.getInstructionsByEnumValue(NumberedInstructions); - O << " static const char * const OpStrs[] = {\n"; for (unsigned i = 0, e = NumberedInstructions.size(); i != e; ++i) { AsmWriterInst *AWI = CGIAWIMap[NumberedInstructions[i]]; @@ -380,8 +380,11 @@ void AsmWriterEmitter::run(std::ostream &O) { // elements in the vector. std::reverse(Instructions.begin(), Instructions.end()); + // Find the opcode # of inline asm O << " switch (MI->getOpcode()) {\n" - " default: return false;\n"; + " default: return false;\n" + " case " << NumberedInstructions.back()->Namespace + << "::INLINEASM: printInlineAsm(MI); break;\n"; while (!Instructions.empty()) EmitInstructions(Instructions, O);