LLVM  4.0.0
X86AsmInstrumentation.h
Go to the documentation of this file.
1 //===- X86AsmInstrumentation.h - Instrument X86 inline assembly *- 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 LLVM_LIB_TARGET_X86_ASMPARSER_X86ASMINSTRUMENTATION_H
11 #define LLVM_LIB_TARGET_X86_ASMPARSER_X86ASMINSTRUMENTATION_H
12 
13 #include "llvm/ADT/SmallVector.h"
14 
15 #include <memory>
16 
17 namespace llvm {
18 
19 class MCContext;
20 class MCInst;
21 class MCInstrInfo;
22 class MCParsedAsmOperand;
23 class MCStreamer;
24 class MCSubtargetInfo;
25 class MCTargetOptions;
26 
27 class X86AsmInstrumentation;
28 
29 X86AsmInstrumentation *
30 CreateX86AsmInstrumentation(const MCTargetOptions &MCOptions,
31  const MCContext &Ctx,
32  const MCSubtargetInfo *&STI);
33 
35 public:
36  virtual ~X86AsmInstrumentation();
37 
38  // Sets frame register corresponding to a current frame.
39  void SetInitialFrameRegister(unsigned RegNo) {
40  InitialFrameReg = RegNo;
41  }
42 
43  // Tries to instrument and emit instruction.
44  virtual void InstrumentAndEmitInstruction(
45  const MCInst &Inst,
46  SmallVectorImpl<std::unique_ptr<MCParsedAsmOperand> > &Operands,
47  MCContext &Ctx, const MCInstrInfo &MII, MCStreamer &Out);
48 
49 protected:
50  friend X86AsmInstrumentation *
52  const MCContext &Ctx,
53  const MCSubtargetInfo *&STI);
54 
56 
57  unsigned GetFrameRegGeneric(const MCContext &Ctx, MCStreamer &Out);
58 
59  void EmitInstruction(MCStreamer &Out, const MCInst &Inst);
60 
62 
63  unsigned InitialFrameReg;
64 };
65 
66 } // End llvm namespace
67 
68 #endif
unsigned GetFrameRegGeneric(const MCContext &Ctx, MCStreamer &Out)
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
Definition: APFloat.h:32
Context object for machine code objects.
Definition: MCContext.h:51
Instances of this class represent a single low-level machine instruction.
Definition: MCInst.h:150
virtual void InstrumentAndEmitInstruction(const MCInst &Inst, SmallVectorImpl< std::unique_ptr< MCParsedAsmOperand > > &Operands, MCContext &Ctx, const MCInstrInfo &MII, MCStreamer &Out)
void EmitInstruction(MCStreamer &Out, const MCInst &Inst)
Streaming machine code generation interface.
Definition: MCStreamer.h:161
X86AsmInstrumentation(const MCSubtargetInfo *&STI)
Interface to description of machine instruction set.
Definition: MCInstrInfo.h:24
X86AsmInstrumentation * CreateX86AsmInstrumentation(const MCTargetOptions &MCOptions, const MCContext &Ctx, const MCSubtargetInfo *&STI)
friend X86AsmInstrumentation * CreateX86AsmInstrumentation(const MCTargetOptions &MCOptions, const MCContext &Ctx, const MCSubtargetInfo *&STI)
MCSubtargetInfo - Generic base class for all target subtargets.
const MCSubtargetInfo *& STI
void SetInitialFrameRegister(unsigned RegNo)