| Anton Korobeynikov | 6e78029 | 2009-10-21 00:11:08 +0000 | [diff] [blame] | 1 | //===-- MSP430MCInstLower.h - Lower MachineInstr to MCInst ----------------===// | 
|  | 2 | // | 
|  | 3 | //                     The LLVM Compiler Infrastructure | 
|  | 4 | // | 
|  | 5 | // This file is distributed under the University of Illinois Open Source | 
|  | 6 | // License. See LICENSE.TXT for details. | 
|  | 7 | // | 
|  | 8 | //===----------------------------------------------------------------------===// | 
|  | 9 |  | 
|  | 10 | #ifndef MSP430_MCINSTLOWER_H | 
|  | 11 | #define MSP430_MCINSTLOWER_H | 
|  | 12 |  | 
|  | 13 | #include "llvm/Support/Compiler.h" | 
|  | 14 |  | 
|  | 15 | namespace llvm { | 
| Anton Korobeynikov | 94ba9c2 | 2009-10-21 00:13:05 +0000 | [diff] [blame^] | 16 | class AsmPrinter; | 
| Anton Korobeynikov | 6e78029 | 2009-10-21 00:11:08 +0000 | [diff] [blame] | 17 | class MCAsmInfo; | 
|  | 18 | class MCContext; | 
|  | 19 | class MCInst; | 
|  | 20 | class MCOperand; | 
|  | 21 | class MCSymbol; | 
|  | 22 | class MachineInstr; | 
|  | 23 | class MachineModuleInfoMachO; | 
|  | 24 | class MachineOperand; | 
|  | 25 | class Mangler; | 
|  | 26 |  | 
|  | 27 | /// MSP430MCInstLower - This class is used to lower an MachineInstr | 
|  | 28 | /// into an MCInst. | 
|  | 29 | class VISIBILITY_HIDDEN MSP430MCInstLower { | 
|  | 30 | MCContext &Ctx; | 
| Anton Korobeynikov | 4e32bff | 2009-10-21 00:12:08 +0000 | [diff] [blame] | 31 | Mangler &Mang; | 
| Anton Korobeynikov | 6e78029 | 2009-10-21 00:11:08 +0000 | [diff] [blame] | 32 |  | 
| Anton Korobeynikov | 94ba9c2 | 2009-10-21 00:13:05 +0000 | [diff] [blame^] | 33 | AsmPrinter &Printer; | 
| Anton Korobeynikov | 6e78029 | 2009-10-21 00:11:08 +0000 | [diff] [blame] | 34 | public: | 
| Anton Korobeynikov | 94ba9c2 | 2009-10-21 00:13:05 +0000 | [diff] [blame^] | 35 | MSP430MCInstLower(MCContext &ctx, Mangler &mang, AsmPrinter &printer) | 
|  | 36 | : Ctx(ctx), Mang(mang), Printer(printer) {} | 
| Anton Korobeynikov | 6e78029 | 2009-10-21 00:11:08 +0000 | [diff] [blame] | 37 | void Lower(const MachineInstr *MI, MCInst &OutMI) const; | 
| Anton Korobeynikov | 4e32bff | 2009-10-21 00:12:08 +0000 | [diff] [blame] | 38 |  | 
|  | 39 | MCOperand LowerSymbolOperand(const MachineOperand &MO, MCSymbol *Sym) const; | 
|  | 40 |  | 
|  | 41 | MCSymbol *GetGlobalAddressSymbol(const MachineOperand &MO) const; | 
|  | 42 | MCSymbol *GetJumpTableSymbol(const MachineOperand &MO) const; | 
|  | 43 | MCSymbol *GetConstantPoolIndexSymbol(const MachineOperand &MO) const; | 
| Anton Korobeynikov | 6e78029 | 2009-10-21 00:11:08 +0000 | [diff] [blame] | 44 | }; | 
|  | 45 |  | 
|  | 46 | } | 
|  | 47 |  | 
|  | 48 | #endif |