mirror of https://github.com/x64dbg/zydis
Removed obsolete public decoder struct
This commit is contained in:
parent
e825b6ed78
commit
c9606c389d
|
@ -41,60 +41,19 @@ extern "C" {
|
||||||
/* ============================================================================================== */
|
/* ============================================================================================== */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Defines the @c ZydisDecoderFlags datatype.
|
* @brief Defines the @c ZydisDecodeGranularity datatype.
|
||||||
*/
|
*/
|
||||||
typedef uint32_t ZydisDecoderFlags;
|
typedef uint32_t ZydisDecodeGranularity;
|
||||||
|
|
||||||
// TODO: Add flags to enable/disable certain decoding-steps like operands, affected flags, ..
|
|
||||||
|
|
||||||
/* ---------------------------------------------------------------------------------------------- */
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Defines the @c ZydisInstructionDecoder struct.
|
* @brief Decoders modes defining how granular the instruction should be decoded.
|
||||||
*/
|
*/
|
||||||
typedef struct ZydisInstructionDecoder_
|
enum ZydisDecodeGranularities
|
||||||
{
|
{
|
||||||
/**
|
ZYDIS_DECODE_GRANULARITY_DEFAULT,
|
||||||
* @brief The current disassembler-mode.
|
ZYDIS_DECODE_GRANULARITY_MINIMAL,
|
||||||
*/
|
ZYDIS_DECODE_GRANULARITY_FULL
|
||||||
ZydisDisassemblerMode disassemblerMode;
|
};
|
||||||
// TODO: Remove from this struct and pass as argument
|
|
||||||
/**
|
|
||||||
* @brief The current input buffer.
|
|
||||||
*/
|
|
||||||
struct
|
|
||||||
{
|
|
||||||
const uint8_t* buffer;
|
|
||||||
size_t bufferLen;
|
|
||||||
} input;
|
|
||||||
/**
|
|
||||||
* @brief Internal field. @c TRUE, if the @c imm8 value is already initialized.
|
|
||||||
*/
|
|
||||||
ZydisBool imm8initialized;
|
|
||||||
/**
|
|
||||||
* @brief Internal field. We have to store a copy of the imm8 value for instructions that
|
|
||||||
* encode different operands in the lo and hi part of the immediate.
|
|
||||||
*/
|
|
||||||
uint8_t imm8;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Internal field. The 0x66 prefix can be consumed, if it is used as mandatory-prefix.
|
|
||||||
* This field contains the prefix-byte, if the prefix is present and not already
|
|
||||||
* consumed.
|
|
||||||
*/
|
|
||||||
uint8_t hasUnusedPrefix66;
|
|
||||||
/**
|
|
||||||
* @brief Internal field. The mutally exclusive 0xF2 and 0xF3 prefixs can be consumed, if
|
|
||||||
* they are used as mandatory-prefix. This field contains the prefix-byte of the
|
|
||||||
* latest 0xF2 or 0xF3 prefix, if one of the prefixes is present and not already
|
|
||||||
* consumed.
|
|
||||||
*/
|
|
||||||
uint8_t hasUnusedPrefixF2F3;
|
|
||||||
/**
|
|
||||||
* @brief Internal field. Contains the latest (significant) segment prefix.
|
|
||||||
*/
|
|
||||||
uint8_t lastSegmentPrefix;
|
|
||||||
} ZydisInstructionDecoder;
|
|
||||||
|
|
||||||
/* ---------------------------------------------------------------------------------------------- */
|
/* ---------------------------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
@ -102,21 +61,10 @@ typedef struct ZydisInstructionDecoder_
|
||||||
/* Exported functions */
|
/* Exported functions */
|
||||||
/* ============================================================================================== */
|
/* ============================================================================================== */
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Initializes the given @c ZydisInstructionDecoder instance.
|
|
||||||
*
|
|
||||||
* @param decoder A pointer to the @c ZydisInstructionDecoder instance.
|
|
||||||
* @param disassemblerMode The desired disassembler-mode.
|
|
||||||
*
|
|
||||||
* @return A zydis status code.
|
|
||||||
*/
|
|
||||||
ZYDIS_EXPORT ZydisStatus ZydisDecoderInitInstructionDecoder(ZydisInstructionDecoder* decoder,
|
|
||||||
ZydisDisassemblerMode disassemblerMode);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Decodes the instruction in the given input @c buffer.
|
* @brief Decodes the instruction in the given input @c buffer.
|
||||||
*
|
*
|
||||||
* @param decoder A pointer to the @c ZydisInstructionDecoder instance.
|
* @param operatingMode The desired operating mode.
|
||||||
* @param buffer A pointer to the input buffer.
|
* @param buffer A pointer to the input buffer.
|
||||||
* @param bufferLen The length of the input buffer.
|
* @param bufferLen The length of the input buffer.
|
||||||
* @param instructionPointer The instruction-pointer.
|
* @param instructionPointer The instruction-pointer.
|
||||||
|
@ -125,25 +73,25 @@ ZYDIS_EXPORT ZydisStatus ZydisDecoderInitInstructionDecoder(ZydisInstructionDeco
|
||||||
*
|
*
|
||||||
* @return A zydis status code.
|
* @return A zydis status code.
|
||||||
*/
|
*/
|
||||||
ZYDIS_EXPORT ZydisStatus ZydisDecoderDecodeInstruction(ZydisInstructionDecoder* decoder,
|
ZYDIS_EXPORT ZydisStatus ZydisDecode(ZydisOperatingMode operatingMode,
|
||||||
const void* buffer, size_t bufferLen, uint64_t instructionPointer, ZydisInstructionInfo* info);
|
const void* buffer, size_t bufferLen, uint64_t instructionPointer, ZydisInstructionInfo* info);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Decodes the instruction in the given input @c buffer.
|
* @brief Decodes the instruction in the given input @c buffer.
|
||||||
*
|
*
|
||||||
* @param decoder A pointer to the @c ZydisInstructionDecoder instance.
|
* @param operatingMode The desired operating mode.
|
||||||
* @param buffer A pointer to the input buffer.
|
* @param buffer A pointer to the input buffer.
|
||||||
* @param bufferLen The length of the input buffer.
|
* @param bufferLen The length of the input buffer.
|
||||||
* @param instructionPointer The instruction-pointer.
|
* @param instructionPointer The instruction-pointer.
|
||||||
* @param flags Additional decoding flags.
|
* @param granularity The granularity to decode with.
|
||||||
* @param info A pointer to the @c ZydisInstructionInfo struct, that receives the
|
* @param info A pointer to the @c ZydisInstructionInfo struct, that receives the
|
||||||
* details about the decoded instruction.
|
* details about the decoded instruction.
|
||||||
*
|
*
|
||||||
* @return A zydis status code.
|
* @return A zydis status code.
|
||||||
*/
|
*/
|
||||||
ZYDIS_EXPORT ZydisStatus ZydisDecoderDecodeInstructionEx(ZydisInstructionDecoder* decoder,
|
ZYDIS_EXPORT ZydisStatus ZydisDecodeEx(ZydisOperatingMode operatingMode,
|
||||||
const void* buffer, size_t bufferLen, uint64_t instructionPointer, ZydisDecoderFlags flags,
|
const void* buffer, size_t bufferLen, uint64_t instructionPointer,
|
||||||
ZydisInstructionInfo* info);
|
ZydisDecodeGranularity granularity, ZydisInstructionInfo* info);
|
||||||
|
|
||||||
/* ============================================================================================== */
|
/* ============================================================================================== */
|
||||||
|
|
||||||
|
|
|
@ -397,7 +397,7 @@ typedef struct ZydisOperandInfo_
|
||||||
/**
|
/**
|
||||||
* @brief Defines the @c ZydisDisassemblerMode datatype.
|
* @brief Defines the @c ZydisDisassemblerMode datatype.
|
||||||
*/
|
*/
|
||||||
typedef uint8_t ZydisDisassemblerMode;
|
typedef uint8_t ZydisOperatingMode;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Values that represent disassembler-modes.
|
* @brief Values that represent disassembler-modes.
|
||||||
|
@ -784,7 +784,7 @@ typedef struct ZydisInstructionInfo_
|
||||||
/**
|
/**
|
||||||
* @brief The disassembler-mode used to decode this instruction.
|
* @brief The disassembler-mode used to decode this instruction.
|
||||||
*/
|
*/
|
||||||
ZydisDisassemblerMode mode;
|
ZydisOperatingMode mode;
|
||||||
/**
|
/**
|
||||||
* @brief The instruction-mnemonic.
|
* @brief The instruction-mnemonic.
|
||||||
*/
|
*/
|
||||||
|
|
179
src/Decoder.c
179
src/Decoder.c
|
@ -30,9 +30,64 @@
|
||||||
#include <Zydis/Internal/InstructionTable.h>
|
#include <Zydis/Internal/InstructionTable.h>
|
||||||
|
|
||||||
/* ============================================================================================== */
|
/* ============================================================================================== */
|
||||||
/* Internal functions */
|
/* Internal functions and types */
|
||||||
/* ============================================================================================== */
|
/* ============================================================================================== */
|
||||||
|
|
||||||
|
/* ---------------------------------------------------------------------------------------------- */
|
||||||
|
/* Internals structs */
|
||||||
|
/* ---------------------------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Defines the @c ZydisInstructionDecoder struct.
|
||||||
|
*/
|
||||||
|
typedef struct ZydisDecoderContext_
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @brief The current disassembler-mode.
|
||||||
|
*/
|
||||||
|
ZydisOperatingMode operatingMode;
|
||||||
|
// TODO: Remove from this struct and pass as argument
|
||||||
|
/**
|
||||||
|
* @brief The current input buffer.
|
||||||
|
*/
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
const uint8_t* buffer;
|
||||||
|
size_t bufferLen;
|
||||||
|
} input;
|
||||||
|
/**
|
||||||
|
* @brief Internal field. @c TRUE, if the @c imm8 value is already initialized.
|
||||||
|
*/
|
||||||
|
ZydisBool imm8initialized;
|
||||||
|
/**
|
||||||
|
* @brief Internal field. We have to store a copy of the imm8 value for instructions that
|
||||||
|
* encode different operands in the lo and hi part of the immediate.
|
||||||
|
*/
|
||||||
|
uint8_t imm8;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Internal field. The 0x66 prefix can be consumed, if it is used as mandatory-prefix.
|
||||||
|
* This field contains the prefix-byte, if the prefix is present and not already
|
||||||
|
* consumed.
|
||||||
|
*/
|
||||||
|
uint8_t hasUnusedPrefix66;
|
||||||
|
/**
|
||||||
|
* @brief Internal field. The mutally exclusive 0xF2 and 0xF3 prefixs can be consumed, if
|
||||||
|
* they are used as mandatory-prefix. This field contains the prefix-byte of the
|
||||||
|
* latest 0xF2 or 0xF3 prefix, if one of the prefixes is present and not already
|
||||||
|
* consumed.
|
||||||
|
*/
|
||||||
|
uint8_t hasUnusedPrefixF2F3;
|
||||||
|
/**
|
||||||
|
* @brief Internal field. Contains the latest (significant) segment prefix.
|
||||||
|
*/
|
||||||
|
uint8_t lastSegmentPrefix;
|
||||||
|
/**
|
||||||
|
* @brief How granular the instructions should be decoded.
|
||||||
|
*/
|
||||||
|
ZydisDecodeGranularity granularity;
|
||||||
|
} ZydisDecoderContext;
|
||||||
|
|
||||||
/* ---------------------------------------------------------------------------------------------- */
|
/* ---------------------------------------------------------------------------------------------- */
|
||||||
/* Input helper functions */
|
/* Input helper functions */
|
||||||
/* ---------------------------------------------------------------------------------------------- */
|
/* ---------------------------------------------------------------------------------------------- */
|
||||||
|
@ -52,7 +107,7 @@
|
||||||
* This function may fail, if the @c ZYDIS_MAX_INSTRUCTION_LENGTH limit got exceeded, or no more
|
* This function may fail, if the @c ZYDIS_MAX_INSTRUCTION_LENGTH limit got exceeded, or no more
|
||||||
* data is available.
|
* data is available.
|
||||||
*/
|
*/
|
||||||
static ZydisStatus ZydisInputPeek(ZydisInstructionDecoder* decoder, ZydisInstructionInfo* info,
|
static ZydisStatus ZydisInputPeek(ZydisDecoderContext* decoder, ZydisInstructionInfo* info,
|
||||||
uint8_t* value)
|
uint8_t* value)
|
||||||
{
|
{
|
||||||
ZYDIS_ASSERT(decoder);
|
ZYDIS_ASSERT(decoder);
|
||||||
|
@ -87,7 +142,7 @@ static ZydisStatus ZydisInputPeek(ZydisInstructionDecoder* decoder, ZydisInstruc
|
||||||
* This function increases the @c length field of the @c ZydisInstructionInfo struct by one and
|
* This function increases the @c length field of the @c ZydisInstructionInfo struct by one and
|
||||||
* adds the current byte to the @c data array.
|
* adds the current byte to the @c data array.
|
||||||
*/
|
*/
|
||||||
static void ZydisInputSkip(ZydisInstructionDecoder* decoder, ZydisInstructionInfo* info)
|
static void ZydisInputSkip(ZydisDecoderContext* decoder, ZydisInstructionInfo* info)
|
||||||
{
|
{
|
||||||
ZYDIS_ASSERT(decoder);
|
ZYDIS_ASSERT(decoder);
|
||||||
ZYDIS_ASSERT(info);
|
ZYDIS_ASSERT(info);
|
||||||
|
@ -109,7 +164,7 @@ static void ZydisInputSkip(ZydisInstructionDecoder* decoder, ZydisInstructionInf
|
||||||
*
|
*
|
||||||
* This function acts like a subsequent call of @c ZydisInputPeek and @c ZydisInputSkip.
|
* This function acts like a subsequent call of @c ZydisInputPeek and @c ZydisInputSkip.
|
||||||
*/
|
*/
|
||||||
static ZydisStatus ZydisInputNext(ZydisInstructionDecoder* decoder, ZydisInstructionInfo* info,
|
static ZydisStatus ZydisInputNext(ZydisDecoderContext* decoder, ZydisInstructionInfo* info,
|
||||||
uint8_t* value)
|
uint8_t* value)
|
||||||
{
|
{
|
||||||
ZYDIS_ASSERT(decoder);
|
ZYDIS_ASSERT(decoder);
|
||||||
|
@ -375,7 +430,7 @@ static void ZydisDecodeSIB(uint8_t sibByte, ZydisInstructionInfo* info)
|
||||||
* This function sets the corresponding flag for each prefix and automatically decodes the last
|
* This function sets the corresponding flag for each prefix and automatically decodes the last
|
||||||
* REX-prefix (if exists).
|
* REX-prefix (if exists).
|
||||||
*/
|
*/
|
||||||
static ZydisStatus ZydisCollectOptionalPrefixes(ZydisInstructionDecoder* decoder,
|
static ZydisStatus ZydisCollectOptionalPrefixes(ZydisDecoderContext* decoder,
|
||||||
ZydisInstructionInfo* info)
|
ZydisInstructionInfo* info)
|
||||||
{
|
{
|
||||||
ZYDIS_ASSERT(decoder);
|
ZYDIS_ASSERT(decoder);
|
||||||
|
@ -431,7 +486,7 @@ static ZydisStatus ZydisCollectOptionalPrefixes(ZydisInstructionDecoder* decoder
|
||||||
++info->details.prefixes.has67;
|
++info->details.prefixes.has67;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
if ((decoder->disassemblerMode == ZYDIS_DISASSEMBLER_MODE_64BIT) &&
|
if ((decoder->operatingMode == ZYDIS_DISASSEMBLER_MODE_64BIT) &&
|
||||||
(prefixByte & 0xF0) == 0x40)
|
(prefixByte & 0xF0) == 0x40)
|
||||||
{
|
{
|
||||||
info->details.rex.data[0] = prefixByte;
|
info->details.rex.data[0] = prefixByte;
|
||||||
|
@ -468,7 +523,7 @@ static ZydisStatus ZydisCollectOptionalPrefixes(ZydisInstructionDecoder* decoder
|
||||||
*
|
*
|
||||||
* @return A zydis status code.
|
* @return A zydis status code.
|
||||||
*/
|
*/
|
||||||
static ZydisStatus ZydisDecodeOperandImmediate(ZydisInstructionDecoder* decoder,
|
static ZydisStatus ZydisDecodeOperandImmediate(ZydisDecoderContext* decoder,
|
||||||
ZydisInstructionInfo* info, ZydisOperandInfo* operand, uint8_t physicalSize,
|
ZydisInstructionInfo* info, ZydisOperandInfo* operand, uint8_t physicalSize,
|
||||||
ZydisBool isSigned)
|
ZydisBool isSigned)
|
||||||
{
|
{
|
||||||
|
@ -617,7 +672,7 @@ static ZydisStatus ZydisDecodeOperandRegister(ZydisInstructionInfo* info,
|
||||||
*
|
*
|
||||||
* @return A zydis status code.
|
* @return A zydis status code.
|
||||||
*/
|
*/
|
||||||
static ZydisStatus ZydisDecodeOperandModrmRm(ZydisInstructionDecoder* decoder,
|
static ZydisStatus ZydisDecodeOperandModrmRm(ZydisDecoderContext* decoder,
|
||||||
ZydisInstructionInfo* info, ZydisOperandInfo* operand, ZydisRegisterClass registerClass)
|
ZydisInstructionInfo* info, ZydisOperandInfo* operand, ZydisRegisterClass registerClass)
|
||||||
{
|
{
|
||||||
ZYDIS_ASSERT(decoder);
|
ZYDIS_ASSERT(decoder);
|
||||||
|
@ -639,7 +694,7 @@ static ZydisStatus ZydisDecodeOperandModrmRm(ZydisInstructionDecoder* decoder,
|
||||||
{
|
{
|
||||||
info->attributes |= ZYDIS_ATTRIB_HAS_ADDRESSSIZE;
|
info->attributes |= ZYDIS_ATTRIB_HAS_ADDRESSSIZE;
|
||||||
}
|
}
|
||||||
switch (decoder->disassemblerMode)
|
switch (decoder->operatingMode)
|
||||||
{
|
{
|
||||||
case ZYDIS_DISASSEMBLER_MODE_16BIT: // TODO: Set ZYDIS_ATTRIB_ACCEPTS_ADDRESSSIZE and ZYDIS_ATTRIB_HAS_ADDRESSSIZE after getting the instruction definition
|
case ZYDIS_DISASSEMBLER_MODE_16BIT: // TODO: Set ZYDIS_ATTRIB_ACCEPTS_ADDRESSSIZE and ZYDIS_ATTRIB_HAS_ADDRESSSIZE after getting the instruction definition
|
||||||
operand->mem.addressSize = (info->attributes & ZYDIS_ATTRIB_HAS_ADDRESSSIZE) ? 32 : 16;
|
operand->mem.addressSize = (info->attributes & ZYDIS_ATTRIB_HAS_ADDRESSSIZE) ? 32 : 16;
|
||||||
|
@ -691,7 +746,7 @@ static ZydisStatus ZydisDecodeOperandModrmRm(ZydisInstructionDecoder* decoder,
|
||||||
case 0:
|
case 0:
|
||||||
if (modrm_rm == 5)
|
if (modrm_rm == 5)
|
||||||
{
|
{
|
||||||
if (decoder->disassemblerMode == ZYDIS_DISASSEMBLER_MODE_64BIT)
|
if (decoder->operatingMode == ZYDIS_DISASSEMBLER_MODE_64BIT)
|
||||||
{
|
{
|
||||||
info->attributes |= ZYDIS_ATTRIB_IS_RELATIVE;
|
info->attributes |= ZYDIS_ATTRIB_IS_RELATIVE;
|
||||||
operand->mem.base = ZYDIS_REGISTER_EIP;
|
operand->mem.base = ZYDIS_REGISTER_EIP;
|
||||||
|
@ -831,7 +886,7 @@ static ZydisStatus ZydisDecodeOperandModrmRm(ZydisInstructionDecoder* decoder,
|
||||||
*
|
*
|
||||||
* @return A zydis status code.
|
* @return A zydis status code.
|
||||||
*/
|
*/
|
||||||
static ZydisStatus ZydisDecodeOperand(ZydisInstructionDecoder* decoder, ZydisInstructionInfo* info,
|
static ZydisStatus ZydisDecodeOperand(ZydisDecoderContext* decoder, ZydisInstructionInfo* info,
|
||||||
ZydisOperandInfo* operand, ZydisSemanticOperandType type, ZydisOperandEncoding encoding)
|
ZydisOperandInfo* operand, ZydisSemanticOperandType type, ZydisOperandEncoding encoding)
|
||||||
{
|
{
|
||||||
ZYDIS_ASSERT(decoder);
|
ZYDIS_ASSERT(decoder);
|
||||||
|
@ -954,11 +1009,11 @@ static ZydisStatus ZydisDecodeOperand(ZydisInstructionDecoder* decoder, ZydisIns
|
||||||
registerClass = ZYDIS_REGCLASS_TEST;
|
registerClass = ZYDIS_REGCLASS_TEST;
|
||||||
break;
|
break;
|
||||||
case ZYDIS_SEM_OPERAND_TYPE_CR:
|
case ZYDIS_SEM_OPERAND_TYPE_CR:
|
||||||
operand->size = (decoder->disassemblerMode == ZYDIS_DISASSEMBLER_MODE_64BIT) ? 64 : 32;
|
operand->size = (decoder->operatingMode == ZYDIS_DISASSEMBLER_MODE_64BIT) ? 64 : 32;
|
||||||
registerClass = ZYDIS_REGCLASS_CONTROL;
|
registerClass = ZYDIS_REGCLASS_CONTROL;
|
||||||
break;
|
break;
|
||||||
case ZYDIS_SEM_OPERAND_TYPE_DR:
|
case ZYDIS_SEM_OPERAND_TYPE_DR:
|
||||||
operand->size = (decoder->disassemblerMode == ZYDIS_DISASSEMBLER_MODE_64BIT) ? 64 : 32;
|
operand->size = (decoder->operatingMode == ZYDIS_DISASSEMBLER_MODE_64BIT) ? 64 : 32;
|
||||||
registerClass = ZYDIS_REGCLASS_DEBUG;
|
registerClass = ZYDIS_REGCLASS_DEBUG;
|
||||||
break;
|
break;
|
||||||
case ZYDIS_SEM_OPERAND_TYPE_FPR:
|
case ZYDIS_SEM_OPERAND_TYPE_FPR:
|
||||||
|
@ -1429,7 +1484,7 @@ static ZydisStatus ZydisDecodeOperand(ZydisInstructionDecoder* decoder, ZydisIns
|
||||||
{
|
{
|
||||||
info->attributes |= ZYDIS_ATTRIB_HAS_ADDRESSSIZE;
|
info->attributes |= ZYDIS_ATTRIB_HAS_ADDRESSSIZE;
|
||||||
}
|
}
|
||||||
switch (decoder->disassemblerMode)
|
switch (decoder->operatingMode)
|
||||||
{
|
{
|
||||||
case ZYDIS_DISASSEMBLER_MODE_16BIT:
|
case ZYDIS_DISASSEMBLER_MODE_16BIT:
|
||||||
operand->mem.addressSize = (info->attributes & ZYDIS_ATTRIB_HAS_ADDRESSSIZE) ? 32 : 16;
|
operand->mem.addressSize = (info->attributes & ZYDIS_ATTRIB_HAS_ADDRESSSIZE) ? 32 : 16;
|
||||||
|
@ -1494,7 +1549,7 @@ static ZydisStatus ZydisDecodeOperand(ZydisInstructionDecoder* decoder, ZydisIns
|
||||||
*
|
*
|
||||||
* @return A zydis status code.
|
* @return A zydis status code.
|
||||||
*/
|
*/
|
||||||
static ZydisStatus ZydisDecodeOperands(ZydisInstructionDecoder* decoder,
|
static ZydisStatus ZydisDecodeOperands(ZydisDecoderContext* decoder,
|
||||||
ZydisInstructionInfo* info, const ZydisOperandDefinition* operands, uint8_t operandCount)
|
ZydisInstructionInfo* info, const ZydisOperandDefinition* operands, uint8_t operandCount)
|
||||||
{
|
{
|
||||||
ZYDIS_ASSERT(decoder);
|
ZYDIS_ASSERT(decoder);
|
||||||
|
@ -1582,7 +1637,7 @@ static ZydisStatus ZydisDecodeOperands(ZydisInstructionDecoder* decoder,
|
||||||
* @param decoder A pointer to the @c ZydisInstructionDecoder decoder instance.
|
* @param decoder A pointer to the @c ZydisInstructionDecoder decoder instance.
|
||||||
* @param info A pointer to the @c ZydisInstructionInfo struct.
|
* @param info A pointer to the @c ZydisInstructionInfo struct.
|
||||||
*/
|
*/
|
||||||
static void ZydisApplyInstructionDefinition(ZydisInstructionDecoder* decoder,
|
static void ZydisApplyInstructionDefinition(ZydisDecoderContext* decoder,
|
||||||
ZydisInstructionInfo* info)
|
ZydisInstructionInfo* info)
|
||||||
{
|
{
|
||||||
ZYDIS_ASSERT(info);
|
ZYDIS_ASSERT(info);
|
||||||
|
@ -1691,7 +1746,7 @@ static void ZydisApplyInstructionDefinition(ZydisInstructionDecoder* decoder,
|
||||||
|
|
||||||
/* ---------------------------------------------------------------------------------------------- */
|
/* ---------------------------------------------------------------------------------------------- */
|
||||||
|
|
||||||
static ZydisStatus ZydisNodeHandlerOpcode(ZydisInstructionDecoder* decoder,
|
static ZydisStatus ZydisNodeHandlerOpcode(ZydisDecoderContext* decoder,
|
||||||
ZydisInstructionInfo* info, uint16_t* index)
|
ZydisInstructionInfo* info, uint16_t* index)
|
||||||
{
|
{
|
||||||
ZYDIS_ASSERT(decoder);
|
ZYDIS_ASSERT(decoder);
|
||||||
|
@ -1866,13 +1921,13 @@ static ZydisStatus ZydisNodeHandlerXop(ZydisInstructionInfo* info, uint16_t* ind
|
||||||
return ZYDIS_STATUS_SUCCESS;
|
return ZYDIS_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
static ZydisStatus ZydisNodeHandlerMode(ZydisInstructionDecoder* decoder,
|
static ZydisStatus ZydisNodeHandlerMode(ZydisDecoderContext* decoder,
|
||||||
uint16_t* index)
|
uint16_t* index)
|
||||||
{
|
{
|
||||||
ZYDIS_ASSERT(decoder);
|
ZYDIS_ASSERT(decoder);
|
||||||
ZYDIS_ASSERT(index);
|
ZYDIS_ASSERT(index);
|
||||||
|
|
||||||
*index = (decoder->disassemblerMode == ZYDIS_DISASSEMBLER_MODE_64BIT) ? 0 : 1;
|
*index = (decoder->operatingMode == ZYDIS_DISASSEMBLER_MODE_64BIT) ? 0 : 1;
|
||||||
return ZYDIS_STATUS_SUCCESS;
|
return ZYDIS_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1900,7 +1955,7 @@ static ZydisStatus ZydisNodeHandlerVex(ZydisInstructionInfo* info, uint16_t* ind
|
||||||
return ZYDIS_STATUS_SUCCESS;
|
return ZYDIS_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
static ZydisStatus ZydisNodeHandlerMandatoryPrefix(ZydisInstructionDecoder* decoder,
|
static ZydisStatus ZydisNodeHandlerMandatoryPrefix(ZydisDecoderContext* decoder,
|
||||||
uint16_t* index)
|
uint16_t* index)
|
||||||
{
|
{
|
||||||
ZYDIS_ASSERT(index);
|
ZYDIS_ASSERT(index);
|
||||||
|
@ -1931,7 +1986,7 @@ static ZydisStatus ZydisNodeHandlerMandatoryPrefix(ZydisInstructionDecoder* deco
|
||||||
return ZYDIS_STATUS_SUCCESS;
|
return ZYDIS_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
static ZydisStatus ZydisNodeHandlerModrmMod(ZydisInstructionDecoder* decoder,
|
static ZydisStatus ZydisNodeHandlerModrmMod(ZydisDecoderContext* decoder,
|
||||||
ZydisInstructionInfo* info, uint16_t* index)
|
ZydisInstructionInfo* info, uint16_t* index)
|
||||||
{
|
{
|
||||||
ZYDIS_ASSERT(decoder);
|
ZYDIS_ASSERT(decoder);
|
||||||
|
@ -1948,7 +2003,7 @@ static ZydisStatus ZydisNodeHandlerModrmMod(ZydisInstructionDecoder* decoder,
|
||||||
return ZYDIS_STATUS_SUCCESS;
|
return ZYDIS_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
static ZydisStatus ZydisNodeHandlerModrmReg(ZydisInstructionDecoder* decoder,
|
static ZydisStatus ZydisNodeHandlerModrmReg(ZydisDecoderContext* decoder,
|
||||||
ZydisInstructionInfo* info, uint16_t* index)
|
ZydisInstructionInfo* info, uint16_t* index)
|
||||||
{
|
{
|
||||||
ZYDIS_ASSERT(decoder);
|
ZYDIS_ASSERT(decoder);
|
||||||
|
@ -1965,7 +2020,7 @@ static ZydisStatus ZydisNodeHandlerModrmReg(ZydisInstructionDecoder* decoder,
|
||||||
return ZYDIS_STATUS_SUCCESS;
|
return ZYDIS_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
static ZydisStatus ZydisNodeHandlerModrmRm(ZydisInstructionDecoder* decoder,
|
static ZydisStatus ZydisNodeHandlerModrmRm(ZydisDecoderContext* decoder,
|
||||||
ZydisInstructionInfo* info, uint16_t* index)
|
ZydisInstructionInfo* info, uint16_t* index)
|
||||||
{
|
{
|
||||||
ZYDIS_ASSERT(decoder);
|
ZYDIS_ASSERT(decoder);
|
||||||
|
@ -1982,7 +2037,7 @@ static ZydisStatus ZydisNodeHandlerModrmRm(ZydisInstructionDecoder* decoder,
|
||||||
return ZYDIS_STATUS_SUCCESS;
|
return ZYDIS_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
static ZydisStatus ZydisNodeHandlerOperandSize(ZydisInstructionDecoder* decoder,
|
static ZydisStatus ZydisNodeHandlerOperandSize(ZydisDecoderContext* decoder,
|
||||||
ZydisInstructionInfo* info, uint16_t* index)
|
ZydisInstructionInfo* info, uint16_t* index)
|
||||||
{
|
{
|
||||||
ZYDIS_ASSERT(decoder);
|
ZYDIS_ASSERT(decoder);
|
||||||
|
@ -1996,7 +2051,7 @@ static ZydisStatus ZydisNodeHandlerOperandSize(ZydisInstructionDecoder* decoder,
|
||||||
decoder->hasUnusedPrefix66 = 0;
|
decoder->hasUnusedPrefix66 = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (decoder->disassemblerMode)
|
switch (decoder->operatingMode)
|
||||||
{
|
{
|
||||||
case ZYDIS_DISASSEMBLER_MODE_16BIT:
|
case ZYDIS_DISASSEMBLER_MODE_16BIT:
|
||||||
*index = (info->attributes & ZYDIS_ATTRIB_HAS_OPERANDSIZE) ? 1 : 0;
|
*index = (info->attributes & ZYDIS_ATTRIB_HAS_OPERANDSIZE) ? 1 : 0;
|
||||||
|
@ -2011,7 +2066,7 @@ static ZydisStatus ZydisNodeHandlerOperandSize(ZydisInstructionDecoder* decoder,
|
||||||
return ZYDIS_STATUS_SUCCESS;
|
return ZYDIS_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
static ZydisStatus ZydisNodeHandlerAddressSize(ZydisInstructionDecoder* decoder,
|
static ZydisStatus ZydisNodeHandlerAddressSize(ZydisDecoderContext* decoder,
|
||||||
ZydisInstructionInfo* info, uint16_t* index)
|
ZydisInstructionInfo* info, uint16_t* index)
|
||||||
{
|
{
|
||||||
ZYDIS_ASSERT(decoder);
|
ZYDIS_ASSERT(decoder);
|
||||||
|
@ -2024,7 +2079,7 @@ static ZydisStatus ZydisNodeHandlerAddressSize(ZydisInstructionDecoder* decoder,
|
||||||
info->attributes |= ZYDIS_ATTRIB_HAS_ADDRESSSIZE;
|
info->attributes |= ZYDIS_ATTRIB_HAS_ADDRESSSIZE;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (decoder->disassemblerMode)
|
switch (decoder->operatingMode)
|
||||||
{
|
{
|
||||||
case ZYDIS_DISASSEMBLER_MODE_16BIT:
|
case ZYDIS_DISASSEMBLER_MODE_16BIT:
|
||||||
*index = (info->attributes & ZYDIS_ATTRIB_HAS_ADDRESSSIZE) ? 1 : 0;
|
*index = (info->attributes & ZYDIS_ATTRIB_HAS_ADDRESSSIZE) ? 1 : 0;
|
||||||
|
@ -2121,7 +2176,7 @@ static ZydisStatus ZydisNodeHandlerEvexB(ZydisInstructionInfo* info, uint16_t* i
|
||||||
*
|
*
|
||||||
* @return A zydis decoder status code.
|
* @return A zydis decoder status code.
|
||||||
*/
|
*/
|
||||||
static ZydisStatus ZydisDecodeOpcode(ZydisInstructionDecoder* decoder,
|
static ZydisStatus ZydisDecodeOpcode(ZydisDecoderContext* decoder,
|
||||||
ZydisInstructionInfo* info)
|
ZydisInstructionInfo* info)
|
||||||
{
|
{
|
||||||
ZYDIS_ASSERT(decoder);
|
ZYDIS_ASSERT(decoder);
|
||||||
|
@ -2269,63 +2324,54 @@ static ZydisStatus ZydisDecodeOpcode(ZydisInstructionDecoder* decoder,
|
||||||
/* Exported functions */
|
/* Exported functions */
|
||||||
/* ============================================================================================== */
|
/* ============================================================================================== */
|
||||||
|
|
||||||
ZydisStatus ZydisDecoderInitInstructionDecoder(ZydisInstructionDecoder* decoder,
|
ZydisStatus ZydisDecode(ZydisOperatingMode operatingMode,
|
||||||
ZydisDisassemblerMode disassemblerMode)
|
const void* buffer, size_t bufferLen, uint64_t instructionPointer,
|
||||||
{
|
|
||||||
if (!decoder || (
|
|
||||||
(disassemblerMode != ZYDIS_DISASSEMBLER_MODE_16BIT) &&
|
|
||||||
(disassemblerMode != ZYDIS_DISASSEMBLER_MODE_32BIT) &&
|
|
||||||
(disassemblerMode != ZYDIS_DISASSEMBLER_MODE_64BIT)))
|
|
||||||
{
|
|
||||||
return ZYDIS_STATUS_INVALID_PARAMETER;
|
|
||||||
}
|
|
||||||
decoder->disassemblerMode = disassemblerMode;
|
|
||||||
decoder->input.buffer = NULL;
|
|
||||||
decoder->input.bufferLen = 0;
|
|
||||||
return ZYDIS_STATUS_SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
ZydisStatus ZydisDecoderDecodeInstruction(ZydisInstructionDecoder* decoder,
|
|
||||||
const void* buffer, size_t bufferLen, uint64_t instructionPointer, ZydisInstructionInfo* info)
|
|
||||||
{
|
|
||||||
return ZydisDecoderDecodeInstructionEx(decoder, buffer, bufferLen, instructionPointer, 0, info);
|
|
||||||
}
|
|
||||||
|
|
||||||
ZydisStatus ZydisDecoderDecodeInstructionEx(ZydisInstructionDecoder* decoder,
|
|
||||||
const void* buffer, size_t bufferLen, uint64_t instructionPointer, ZydisDecoderFlags flags,
|
|
||||||
ZydisInstructionInfo* info)
|
ZydisInstructionInfo* info)
|
||||||
{
|
{
|
||||||
(void)flags;
|
return ZydisDecodeEx(
|
||||||
|
operatingMode, buffer, bufferLen, instructionPointer,
|
||||||
|
ZYDIS_DECODE_GRANULARITY_DEFAULT, info);
|
||||||
|
}
|
||||||
|
|
||||||
if (!decoder)
|
ZydisStatus ZydisDecodeEx(ZydisOperatingMode operatingMode,
|
||||||
|
const void* buffer, size_t bufferLen, uint64_t instructionPointer,
|
||||||
|
ZydisDecodeGranularity granularity, ZydisInstructionInfo* info)
|
||||||
|
{
|
||||||
|
if ((operatingMode != ZYDIS_DISASSEMBLER_MODE_16BIT) &&
|
||||||
|
(operatingMode != ZYDIS_DISASSEMBLER_MODE_32BIT) &&
|
||||||
|
(operatingMode != ZYDIS_DISASSEMBLER_MODE_64BIT))
|
||||||
{
|
{
|
||||||
return ZYDIS_STATUS_INVALID_PARAMETER;
|
return ZYDIS_STATUS_INVALID_PARAMETER;
|
||||||
}
|
}
|
||||||
if (!buffer || (bufferLen == 0))
|
|
||||||
|
if (!buffer || !bufferLen)
|
||||||
{
|
{
|
||||||
return ZYDIS_STATUS_NO_MORE_DATA;
|
return ZYDIS_STATUS_NO_MORE_DATA;
|
||||||
}
|
}
|
||||||
|
|
||||||
decoder->input.buffer = (uint8_t*)buffer;
|
ZydisDecoderContext ctx;
|
||||||
decoder->input.bufferLen = bufferLen;
|
ctx.operatingMode = operatingMode;
|
||||||
decoder->hasUnusedPrefix66 = 0;
|
ctx.granularity = granularity;
|
||||||
decoder->hasUnusedPrefixF2F3 = 0;
|
ctx.input.buffer = (uint8_t*)buffer;
|
||||||
decoder->lastSegmentPrefix = 0;
|
ctx.input.bufferLen = bufferLen;
|
||||||
decoder->imm8initialized = ZYDIS_FALSE;
|
ctx.hasUnusedPrefix66 = 0;
|
||||||
|
ctx.hasUnusedPrefixF2F3 = 0;
|
||||||
|
ctx.lastSegmentPrefix = 0;
|
||||||
|
ctx.imm8initialized = ZYDIS_FALSE;
|
||||||
|
|
||||||
void* userData = info->userData;
|
void* userData = info->userData;
|
||||||
memset(info, 0, sizeof(*info));
|
memset(info, 0, sizeof(*info));
|
||||||
info->mode = decoder->disassemblerMode;
|
info->mode = ctx.operatingMode;
|
||||||
info->instrAddress = instructionPointer;
|
info->instrAddress = instructionPointer;
|
||||||
info->userData = userData;
|
info->userData = userData;
|
||||||
|
|
||||||
ZYDIS_CHECK(ZydisCollectOptionalPrefixes(decoder, info));
|
ZYDIS_CHECK(ZydisCollectOptionalPrefixes(&ctx, info));
|
||||||
ZYDIS_CHECK(ZydisDecodeOpcode(decoder, info));
|
ZYDIS_CHECK(ZydisDecodeOpcode(&ctx, info));
|
||||||
|
|
||||||
// TODO: The index, dest and mask regs for AVX2 gathers must be different.
|
// TODO: The index, dest and mask regs for AVX2 gathers must be different.
|
||||||
// TODO: More EVEX UD conditions (page 81)
|
// TODO: More EVEX UD conditions (page 81)
|
||||||
// Set AVX-512 info
|
// Set AVX-512 info
|
||||||
if (info->encoding == ZYDIS_INSTRUCTION_ENCODING_EVEX)
|
if (info->encoding == ZYDIS_INSTRUCTION_ENCODING_EVEX)
|
||||||
{
|
{
|
||||||
const ZydisInstructionDefinition* definition =
|
const ZydisInstructionDefinition* definition =
|
||||||
(ZydisInstructionDefinition*)info->details.internal.definition;
|
(ZydisInstructionDefinition*)info->details.internal.definition;
|
||||||
|
@ -2373,6 +2419,7 @@ ZydisStatus ZydisDecoderDecodeInstructionEx(ZydisInstructionDecoder* decoder,
|
||||||
default:
|
default:
|
||||||
ZYDIS_UNREACHABLE;
|
ZYDIS_UNREACHABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (info->details.evex.z)
|
if (info->details.evex.z)
|
||||||
{
|
{
|
||||||
if (!definition->evexZeroMaskAccepted)
|
if (!definition->evexZeroMaskAccepted)
|
||||||
|
|
|
@ -60,13 +60,6 @@ int main(int argc, char** argv)
|
||||||
return EXIT_FAILURE;
|
return EXIT_FAILURE;
|
||||||
}
|
}
|
||||||
|
|
||||||
ZydisInstructionDecoder decoder;
|
|
||||||
if (!ZYDIS_SUCCESS(ZydisDecoderInitInstructionDecoder(&decoder, ZYDIS_DISASSEMBLER_MODE_64BIT)))
|
|
||||||
{
|
|
||||||
fputs("Failed to initialize instruction-decoder\n", stderr);
|
|
||||||
return EXIT_FAILURE;
|
|
||||||
}
|
|
||||||
|
|
||||||
uint8_t readBuf[ZYDIS_MAX_INSTRUCTION_LENGTH * 1024];
|
uint8_t readBuf[ZYDIS_MAX_INSTRUCTION_LENGTH * 1024];
|
||||||
size_t numBytesRead;
|
size_t numBytesRead;
|
||||||
do
|
do
|
||||||
|
@ -76,8 +69,12 @@ int main(int argc, char** argv)
|
||||||
ZydisInstructionInfo info;
|
ZydisInstructionInfo info;
|
||||||
ZydisStatus status;
|
ZydisStatus status;
|
||||||
size_t readOffs = 0;
|
size_t readOffs = 0;
|
||||||
while ((status = ZydisDecoderDecodeInstruction(
|
while ((status = ZydisDecode(
|
||||||
&decoder, readBuf + readOffs, numBytesRead - readOffs, readOffs, &info
|
ZYDIS_DISASSEMBLER_MODE_64BIT,
|
||||||
|
readBuf + readOffs,
|
||||||
|
numBytesRead - readOffs,
|
||||||
|
readOffs,
|
||||||
|
&info
|
||||||
)) != ZYDIS_STATUS_NO_MORE_DATA)
|
)) != ZYDIS_STATUS_NO_MORE_DATA)
|
||||||
{
|
{
|
||||||
if (!ZYDIS_SUCCESS(status))
|
if (!ZYDIS_SUCCESS(status))
|
||||||
|
|
|
@ -70,13 +70,6 @@ int main()
|
||||||
return EXIT_FAILURE;
|
return EXIT_FAILURE;
|
||||||
}
|
}
|
||||||
|
|
||||||
ZydisInstructionDecoder decoder;
|
|
||||||
if (!ZYDIS_SUCCESS(ZydisDecoderInitInstructionDecoder(&decoder, controlBlock.disasMode)))
|
|
||||||
{
|
|
||||||
fputs("Failed to initialize instruction-decoder\n", stderr);
|
|
||||||
return EXIT_FAILURE;
|
|
||||||
}
|
|
||||||
|
|
||||||
uint8_t readBuf[ZYDIS_MAX_INSTRUCTION_LENGTH * 1024];
|
uint8_t readBuf[ZYDIS_MAX_INSTRUCTION_LENGTH * 1024];
|
||||||
size_t numBytesRead;
|
size_t numBytesRead;
|
||||||
do
|
do
|
||||||
|
@ -86,8 +79,12 @@ int main()
|
||||||
ZydisInstructionInfo info;
|
ZydisInstructionInfo info;
|
||||||
ZydisStatus status;
|
ZydisStatus status;
|
||||||
size_t readOffs = 0;
|
size_t readOffs = 0;
|
||||||
while ((status = ZydisDecoderDecodeInstruction(
|
while ((status = ZydisDecode(
|
||||||
&decoder, readBuf + readOffs, numBytesRead - readOffs, readOffs, &info
|
controlBlock.disasMode,
|
||||||
|
readBuf + readOffs,
|
||||||
|
numBytesRead - readOffs,
|
||||||
|
readOffs,
|
||||||
|
&info
|
||||||
)) != ZYDIS_STATUS_NO_MORE_DATA)
|
)) != ZYDIS_STATUS_NO_MORE_DATA)
|
||||||
{
|
{
|
||||||
if (!ZYDIS_SUCCESS(status))
|
if (!ZYDIS_SUCCESS(status))
|
||||||
|
|
Loading…
Reference in New Issue