diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2013-04-08 18:41:23 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2013-04-08 18:41:23 +0000 | 
| commit | 4a16efa3e43e35f0cc9efe3a67f620f0017c3d36 (patch) | |
| tree | 06099edc18d30894081a822b756f117cbe0b8207 /lib/MC/MCDisassembler/EDInst.h | |
| parent | 482e7bddf617ae804dc47133cb07eb4aa81e45de (diff) | |
Diffstat (limited to 'lib/MC/MCDisassembler/EDInst.h')
| -rw-r--r-- | lib/MC/MCDisassembler/EDInst.h | 182 | 
1 files changed, 0 insertions, 182 deletions
| diff --git a/lib/MC/MCDisassembler/EDInst.h b/lib/MC/MCDisassembler/EDInst.h deleted file mode 100644 index 6b78dc826c92..000000000000 --- a/lib/MC/MCDisassembler/EDInst.h +++ /dev/null @@ -1,182 +0,0 @@ -//===-- EDInst.h - LLVM Enhanced Disassembler -------------------*- C++ -*-===// -// -//                     The LLVM Compiler Infrastructure -// -// This file is distributed under the University of Illinois Open Source -// License. See LICENSE.TXT for details. -//  -//===----------------------------------------------------------------------===// -// -// This file defines the interface for the Enhanced Disassembly library's -// instruction class.  The instruction is responsible for vending the string -// representation, individual tokens and operands for a single instruction. -// -//===----------------------------------------------------------------------===// - -#ifndef LLVM_EDINST_H -#define LLVM_EDINST_H - -#include "llvm/Support/DataTypes.h" -#include "llvm/ADT/SmallVector.h" -#include <string> -#include <vector> - -namespace llvm { -  class MCInst; -  struct EDInstInfo; -  struct EDToken; -  struct EDDisassembler; -  struct EDOperand; - -#ifdef __BLOCKS__ -  typedef int (^EDTokenVisitor_t)(EDToken *token); -#endif - -/// CachedResult - Encapsulates the result of a function along with the validity -///   of that result, so that slow functions don't need to run twice -struct CachedResult { -  /// True if the result has been obtained by executing the function -  bool Valid; -  /// The result last obtained from the function -  int Result; -   -  /// Constructor - Initializes an invalid result -  CachedResult() : Valid(false) { } -  /// valid - Returns true if the result has been obtained by executing the -  ///   function and false otherwise -  bool valid() { return Valid; } -  /// result - Returns the result of the function or an undefined value if -  ///   valid() is false -  int result() { return Result; } -  /// setResult - Sets the result of the function and declares it valid -  ///   returning the result (so that setResult() can be called from inside a -  ///   return statement) -  /// @arg result - The result of the function -  int setResult(int result) { Result = result; Valid = true; return result; } -}; - -/// EDInst - Encapsulates a single instruction, which can be queried for its -///   string representation, as well as its operands and tokens -struct EDInst { -  /// The parent disassembler -  EDDisassembler &Disassembler; -  /// The containing MCInst -  llvm::MCInst *Inst; -  /// The instruction information provided by TableGen for this instruction -  const llvm::EDInstInfo *ThisInstInfo; -  /// The number of bytes for the machine code representation of the instruction -  uint64_t ByteSize; -   -  /// The result of the stringify() function -  CachedResult StringifyResult; -  /// The string representation of the instruction -  std::string String; -  /// The order in which operands from the InstInfo's operand information appear -  /// in String -  const signed char* OperandOrder; -   -  /// The result of the parseOperands() function -  CachedResult ParseResult; -  typedef llvm::SmallVector<EDOperand*, 5> opvec_t; -  /// The instruction's operands -  opvec_t Operands; -  /// The operand corresponding to the target, if the instruction is a branch -  int BranchTarget; -  /// The operand corresponding to the source, if the instruction is a move -  int MoveSource; -  /// The operand corresponding to the target, if the instruction is a move -  int MoveTarget; -   -  /// The result of the tokenize() function -  CachedResult TokenizeResult; -  typedef std::vector<EDToken*> tokvec_t; -  /// The instruction's tokens -  tokvec_t Tokens; -   -  /// Constructor - initializes an instruction given the output of the LLVM -  ///   C++ disassembler -  /// -  /// @arg inst         - The MCInst, which will now be owned by this object -  /// @arg byteSize     - The size of the consumed instruction, in bytes -  /// @arg disassembler - The parent disassembler -  /// @arg instInfo     - The instruction information produced by the table -  ///                     generator for this instruction -  EDInst(llvm::MCInst *inst, -         uint64_t byteSize, -         EDDisassembler &disassembler, -         const llvm::EDInstInfo *instInfo); -  ~EDInst(); -   -  /// byteSize - returns the number of bytes consumed by the machine code -  ///   representation of the instruction -  uint64_t byteSize(); -  /// instID - returns the LLVM instruction ID of the instruction -  unsigned instID(); -   -  /// stringify - populates the String and AsmString members of the instruction, -  ///   returning 0 on success or -1 otherwise -  int stringify(); -  /// getString - retrieves a pointer to the string representation of the -  ///   instructinon, returning 0 on success or -1 otherwise -  /// -  /// @arg str - A reference to a pointer that, on success, is set to point to -  ///   the string representation of the instruction; this string is still owned -  ///   by the instruction and will be deleted when it is -  int getString(const char *&str); -   -  /// isBranch - Returns true if the instruction is a branch -  bool isBranch(); -  /// isMove - Returns true if the instruction is a move -  bool isMove(); -   -  /// parseOperands - populates the Operands member of the instruction, -  ///   returning 0 on success or -1 otherwise -  int parseOperands(); -  /// branchTargetID - returns the ID (suitable for use with getOperand()) of  -  ///   the target operand if the instruction is a branch, or -1 otherwise -  int branchTargetID(); -  /// moveSourceID - returns the ID of the source operand if the instruction -  ///   is a move, or -1 otherwise -  int moveSourceID(); -  /// moveTargetID - returns the ID of the target operand if the instruction -  ///   is a move, or -1 otherwise -  int moveTargetID(); -   -  /// numOperands - returns the number of operands available to retrieve, or -1 -  ///   on error -  int numOperands(); -  /// getOperand - retrieves an operand from the instruction's operand list by -  ///   index, returning 0 on success or -1 on error -  /// -  /// @arg operand  - A reference whose target is pointed at the operand on -  ///                 success, although the operand is still owned by the EDInst -  /// @arg index    - The index of the operand in the instruction -  int getOperand(EDOperand *&operand, unsigned int index); - -  /// tokenize - populates the Tokens member of the instruction, returning 0 on -  ///   success or -1 otherwise -  int tokenize(); -  /// numTokens - returns the number of tokens in the instruction, or -1 on -  ///   error -  int numTokens(); -  /// getToken - retrieves a token from the instruction's token list by index, -  ///   returning 0 on success or -1 on error -  /// -  /// @arg token  - A reference whose target is pointed at the token on success, -  ///               although the token is still owned by the EDInst -  /// @arg index  - The index of the token in the instrcutino -  int getToken(EDToken *&token, unsigned int index); - -#ifdef __BLOCKS__ -  /// visitTokens - Visits each token in turn and applies a block to it, -  ///   returning 0 if all blocks are visited and/or the block signals -  ///   termination by returning 1; returns -1 on error -  /// -  /// @arg visitor  - The visitor block to apply to all tokens. -  int visitTokens(EDTokenVisitor_t visitor); -#endif -}; - -} // end namespace llvm - -#endif | 
