1 //===-- MBlazeMCInstLower.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 MBLAZE_MCINSTLOWER_H 11 #define MBLAZE_MCINSTLOWER_H 12 13 #include "llvm/Support/Compiler.h" 14 15 namespace llvm { 16 class AsmPrinter; 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 /// MBlazeMCInstLower - This class is used to lower an MachineInstr 28 /// into an MCInst. 29 class LLVM_LIBRARY_VISIBILITY MBlazeMCInstLower { 30 MCContext &Ctx; 31 Mangler &Mang; 32 33 AsmPrinter &Printer; 34 public: MBlazeMCInstLower(MCContext & ctx,Mangler & mang,AsmPrinter & printer)35 MBlazeMCInstLower(MCContext &ctx, Mangler &mang, AsmPrinter &printer) 36 : Ctx(ctx), Mang(mang), Printer(printer) {} 37 void Lower(const MachineInstr *MI, MCInst &OutMI) const; 38 39 MCOperand LowerSymbolOperand(const MachineOperand &MO, MCSymbol *Sym) const; 40 41 MCSymbol *GetGlobalAddressSymbol(const MachineOperand &MO) const; 42 MCSymbol *GetExternalSymbolSymbol(const MachineOperand &MO) const; 43 MCSymbol *GetJumpTableSymbol(const MachineOperand &MO) const; 44 MCSymbol *GetConstantPoolIndexSymbol(const MachineOperand &MO) const; 45 MCSymbol *GetBlockAddressSymbol(const MachineOperand &MO) const; 46 }; 47 48 } 49 50 #endif 51