Home | History | Annotate | Download | only in MBlaze
      1 //===-- MBlazeMCInstLower.h - Lower MachineInstr to MCInst ------*- C++ -*-===//
      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 MCContext;
     18   class MCInst;
     19   class MCOperand;
     20   class MCSymbol;
     21   class MachineInstr;
     22   class MachineModuleInfoMachO;
     23   class MachineOperand;
     24   class Mangler;
     25 
     26   /// MBlazeMCInstLower - This class is used to lower an MachineInstr
     27   /// into an MCInst.
     28 class LLVM_LIBRARY_VISIBILITY MBlazeMCInstLower {
     29   MCContext &Ctx;
     30   Mangler &Mang;
     31 
     32   AsmPrinter &Printer;
     33 public:
     34   MBlazeMCInstLower(MCContext &ctx, Mangler &mang, AsmPrinter &printer)
     35     : Ctx(ctx), Mang(mang), Printer(printer) {}
     36   void Lower(const MachineInstr *MI, MCInst &OutMI) const;
     37 
     38   MCOperand LowerSymbolOperand(const MachineOperand &MO, MCSymbol *Sym) const;
     39 
     40   MCSymbol *GetGlobalAddressSymbol(const MachineOperand &MO) const;
     41   MCSymbol *GetExternalSymbolSymbol(const MachineOperand &MO) const;
     42   MCSymbol *GetJumpTableSymbol(const MachineOperand &MO) const;
     43   MCSymbol *GetConstantPoolIndexSymbol(const MachineOperand &MO) const;
     44   MCSymbol *GetBlockAddressSymbol(const MachineOperand &MO) const;
     45 };
     46 
     47 }
     48 
     49 #endif
     50