blob: 794aa56bf04cb234476acaa7ef530cb8ad3f077e [file] [log] [blame]
Jia Liu31d157a2012-02-18 12:03:15 +00001//===-- MSP430MCInstLower.h - Lower MachineInstr to MCInst ------*- C++ -*-===//
Nick Lewycky0e7fdf52010-10-02 01:08:17 +00002//
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
15namespace llvm {
16 class AsmPrinter;
Nick Lewycky0e7fdf52010-10-02 01:08:17 +000017 class MCContext;
18 class MCInst;
19 class MCOperand;
20 class MCSymbol;
21 class MachineInstr;
22 class MachineModuleInfoMachO;
23 class MachineOperand;
Nick Lewycky0e7fdf52010-10-02 01:08:17 +000024
25 /// MSP430MCInstLower - This class is used to lower an MachineInstr
26 /// into an MCInst.
27class LLVM_LIBRARY_VISIBILITY MSP430MCInstLower {
28 MCContext &Ctx;
Nick Lewycky0e7fdf52010-10-02 01:08:17 +000029
30 AsmPrinter &Printer;
31public:
Benjamin Kramera7542d52012-06-06 18:25:08 +000032 MSP430MCInstLower(MCContext &ctx, AsmPrinter &printer)
33 : Ctx(ctx), Printer(printer) {}
Nick Lewycky0e7fdf52010-10-02 01:08:17 +000034 void Lower(const MachineInstr *MI, MCInst &OutMI) const;
35
36 MCOperand LowerSymbolOperand(const MachineOperand &MO, MCSymbol *Sym) const;
37
38 MCSymbol *GetGlobalAddressSymbol(const MachineOperand &MO) const;
39 MCSymbol *GetExternalSymbolSymbol(const MachineOperand &MO) const;
40 MCSymbol *GetJumpTableSymbol(const MachineOperand &MO) const;
41 MCSymbol *GetConstantPoolIndexSymbol(const MachineOperand &MO) const;
42 MCSymbol *GetBlockAddressSymbol(const MachineOperand &MO) const;
43};
44
45}
46
47#endif