mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-13 20:32:21 +00:00
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
This commit is contained in:
parent
0264d1a477
commit
0cfcc1e807
@ -345,6 +345,9 @@ void AsmWriterEmitter::run(std::ostream &O) {
|
||||
break;
|
||||
}
|
||||
|
||||
std::vector<const CodeGenInstruction*> 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<const CodeGenInstruction*> 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);
|
||||
|
Loading…
Reference in New Issue
Block a user