blob: a1b826d03db0096f8ce39d989911750238f27893 [file] [log] [blame]
Chris Lattner8fea32f2009-09-12 20:34:57 +00001//===-- X86MCInstLower.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 X86_MCINSTLOWER_H
11#define X86_MCINSTLOWER_H
12
Chris Lattner09abd1c2009-09-13 18:33:59 +000013#include "llvm/Support/Compiler.h"
14
Chris Lattner8fea32f2009-09-12 20:34:57 +000015namespace llvm {
Chris Lattnerc0115b52010-07-20 22:30:53 +000016 class MCAsmInfo;
Chris Lattner8fea32f2009-09-12 20:34:57 +000017 class MCContext;
18 class MCInst;
19 class MCOperand;
20 class MCSymbol;
21 class MachineInstr;
Chris Lattner0c13cf32010-07-20 22:26:07 +000022 class MachineFunction;
Chris Lattnerdc62ea02009-09-16 06:25:03 +000023 class MachineModuleInfoMachO;
Chris Lattner8fea32f2009-09-12 20:34:57 +000024 class MachineOperand;
25 class Mangler;
Chris Lattnerc0115b52010-07-20 22:30:53 +000026 class TargetMachine;
Chris Lattner38596382009-09-20 07:35:34 +000027 class X86AsmPrinter;
Chris Lattner8fea32f2009-09-12 20:34:57 +000028
Chris Lattnere9434db2009-09-12 21:01:20 +000029/// X86MCInstLower - This class is used to lower an MachineInstr into an MCInst.
Duncan Sands16d8f8b2010-05-11 20:16:09 +000030class LLVM_LIBRARY_VISIBILITY X86MCInstLower {
Chris Lattner8fea32f2009-09-12 20:34:57 +000031 MCContext &Ctx;
Chris Lattner3310a962009-10-19 21:59:25 +000032 Mangler *Mang;
Chris Lattner0c13cf32010-07-20 22:26:07 +000033 const MachineFunction &MF;
Chris Lattnerc0115b52010-07-20 22:30:53 +000034 const TargetMachine &TM;
35 const MCAsmInfo &MAI;
Chris Lattnercb63ecb2010-07-20 22:35:40 +000036
37 X86AsmPrinter &AsmPrinter;
Chris Lattner8fea32f2009-09-12 20:34:57 +000038public:
Chris Lattnercb63ecb2010-07-20 22:35:40 +000039 X86MCInstLower(MCContext &ctx, Mangler *mang, const MachineFunction &MF,
40 X86AsmPrinter &asmprinter);
Chris Lattner8fea32f2009-09-12 20:34:57 +000041
42 void Lower(const MachineInstr *MI, MCInst &OutMI) const;
43
44 MCSymbol *GetPICBaseSymbol() const;
Chris Lattner8fea32f2009-09-12 20:34:57 +000045
Chris Lattner34841102010-02-08 23:03:41 +000046 MCSymbol *GetSymbolFromOperand(const MachineOperand &MO) const;
Chris Lattner8fea32f2009-09-12 20:34:57 +000047 MCOperand LowerSymbolOperand(const MachineOperand &MO, MCSymbol *Sym) const;
Chris Lattnerdc62ea02009-09-16 06:25:03 +000048
49private:
50 MachineModuleInfoMachO &getMachOMMI() const;
Chris Lattner8fea32f2009-09-12 20:34:57 +000051};
52
53}
54
55#endif