blob: 9f7d7761a497ffbeedd473aa9152a5262ca3e8ab [file] [log] [blame]
Chris Lattner2e1f51b2004-08-01 05:59:33 +00001//===- AsmWriterEmitter.h - Generate an assembly writer ---------*- C++ -*-===//
Misha Brukman3da94ae2005-04-22 00:00:37 +00002//
Chris Lattner2e1f51b2004-08-01 05:59:33 +00003// The LLVM Compiler Infrastructure
4//
Chris Lattner30609102007-12-29 20:37:13 +00005// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
Misha Brukman3da94ae2005-04-22 00:00:37 +00007//
Chris Lattner2e1f51b2004-08-01 05:59:33 +00008//===----------------------------------------------------------------------===//
9//
10// This tablegen backend is responsible for emitting an assembly printer for the
11// code generator.
12//
13//===----------------------------------------------------------------------===//
14
15#ifndef ASMWRITER_EMITTER_H
16#define ASMWRITER_EMITTER_H
17
18#include "TableGenBackend.h"
Chris Lattnerbdff5f92006-07-18 17:18:03 +000019#include <map>
20#include <vector>
21#include <cassert>
Chris Lattner2e1f51b2004-08-01 05:59:33 +000022
23namespace llvm {
Chris Lattnerbdff5f92006-07-18 17:18:03 +000024 class AsmWriterInst;
25 class CodeGenInstruction;
26
Chris Lattner2e1f51b2004-08-01 05:59:33 +000027 class AsmWriterEmitter : public TableGenBackend {
28 RecordKeeper &Records;
Chris Lattnerbdff5f92006-07-18 17:18:03 +000029 std::map<const CodeGenInstruction*, AsmWriterInst*> CGIAWIMap;
30 std::vector<const CodeGenInstruction*> NumberedInstructions;
Chris Lattner2e1f51b2004-08-01 05:59:33 +000031 public:
32 AsmWriterEmitter(RecordKeeper &R) : Records(R) {}
Misha Brukman3da94ae2005-04-22 00:00:37 +000033
Chris Lattner2e1f51b2004-08-01 05:59:33 +000034 // run - Output the asmwriter, returning true on failure.
Daniel Dunbar1a551802009-07-03 00:10:29 +000035 void run(raw_ostream &o);
Chris Lattnerbdff5f92006-07-18 17:18:03 +000036
37private:
Chris Lattner05af2612009-09-13 20:08:00 +000038 void EmitPrintInstruction(raw_ostream &o);
39 void EmitGetRegisterName(raw_ostream &o);
Chris Lattner0d7b0aa2010-02-11 22:57:32 +000040 void EmitGetInstructionName(raw_ostream &o);
Chris Lattner05af2612009-09-13 20:08:00 +000041
Chris Lattnerbdff5f92006-07-18 17:18:03 +000042 AsmWriterInst *getAsmWriterInstByID(unsigned ID) const {
43 assert(ID < NumberedInstructions.size());
44 std::map<const CodeGenInstruction*, AsmWriterInst*>::const_iterator I =
45 CGIAWIMap.find(NumberedInstructions[ID]);
46 assert(I != CGIAWIMap.end() && "Didn't find inst!");
47 return I->second;
48 }
49 void FindUniqueOperandCommands(std::vector<std::string> &UOC,
Chris Lattner96c1ade2006-07-18 18:28:27 +000050 std::vector<unsigned> &InstIdxs,
51 std::vector<unsigned> &InstOpsUsed) const;
Chris Lattner2e1f51b2004-08-01 05:59:33 +000052 };
53}
54#endif