|  | //===-- 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 |