2021-05-25 21:23:39 +01:00
|
|
|
/***************************************************************************************************
|
|
|
|
|
|
|
|
Zyan Disassembler Library (Zydis)
|
|
|
|
|
|
|
|
Original Author : Florian Bernd
|
|
|
|
|
|
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
* of this software and associated documentation files (the "Software"), to deal
|
|
|
|
* in the Software without restriction, including without limitation the rights
|
|
|
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
* copies of the Software, and to permit persons to whom the Software is
|
|
|
|
* furnished to do so, subject to the following conditions:
|
|
|
|
*
|
|
|
|
* The above copyright notice and this permission notice shall be included in all
|
|
|
|
* copies or substantial portions of the Software.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
|
|
* SOFTWARE.
|
|
|
|
|
|
|
|
***************************************************************************************************/
|
|
|
|
|
|
|
|
#ifndef ZYDIS_INTERNAL_SHAREDDATA_H
|
|
|
|
#define ZYDIS_INTERNAL_SHAREDDATA_H
|
|
|
|
|
|
|
|
#include <Zycore/Defines.h>
|
|
|
|
#include <Zydis/Mnemonic.h>
|
|
|
|
#include <Zydis/Register.h>
|
|
|
|
#include <Zydis/SharedTypes.h>
|
|
|
|
#include <Zydis/DecoderTypes.h>
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* ============================================================================================== */
|
|
|
|
/* Enums and types */
|
|
|
|
/* ============================================================================================== */
|
|
|
|
|
|
|
|
// MSVC does not like types other than (un-)signed int for bit-fields
|
|
|
|
#ifdef ZYAN_MSVC
|
|
|
|
# pragma warning(push)
|
|
|
|
# pragma warning(disable:4214)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#pragma pack(push, 1)
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
/* Operand definition */
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the `ZydisSemanticOperandType` enum.
|
|
|
|
*/
|
|
|
|
typedef enum ZydisSemanticOperandType_
|
|
|
|
{
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_UNUSED,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_IMPLICIT_REG,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_IMPLICIT_MEM,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_IMPLICIT_IMM1,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_GPR8,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_GPR16,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_GPR32,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_GPR64,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_GPR16_32_64,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_GPR32_32_64,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_GPR16_32_32,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_GPR_ASZ,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_FPR,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_MMX,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_XMM,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_YMM,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_ZMM,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_TMM,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_BND,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_SREG,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_CR,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_DR,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_MASK,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_MEM,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_MEM_VSIBX,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_MEM_VSIBY,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_MEM_VSIBZ,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_IMM,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_REL,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_PTR,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_AGEN,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_MOFFS,
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_MIB,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Maximum value of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_MAX_VALUE = ZYDIS_SEMANTIC_OPTYPE_MIB,
|
|
|
|
/**
|
|
|
|
* The minimum number of bits required to represent all values of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_SEMANTIC_OPTYPE_REQUIRED_BITS = ZYAN_BITS_TO_REPRESENT(ZYDIS_SEMANTIC_OPTYPE_MAX_VALUE)
|
|
|
|
} ZydisSemanticOperandType;
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the `ZydisInternalElementType` enum.
|
|
|
|
*/
|
|
|
|
typedef enum ZydisInternalElementType_
|
|
|
|
{
|
|
|
|
ZYDIS_IELEMENT_TYPE_INVALID,
|
|
|
|
ZYDIS_IELEMENT_TYPE_VARIABLE,
|
|
|
|
ZYDIS_IELEMENT_TYPE_STRUCT,
|
|
|
|
ZYDIS_IELEMENT_TYPE_INT,
|
|
|
|
ZYDIS_IELEMENT_TYPE_UINT,
|
|
|
|
ZYDIS_IELEMENT_TYPE_INT1,
|
|
|
|
ZYDIS_IELEMENT_TYPE_INT8,
|
|
|
|
ZYDIS_IELEMENT_TYPE_INT16,
|
|
|
|
ZYDIS_IELEMENT_TYPE_INT32,
|
|
|
|
ZYDIS_IELEMENT_TYPE_INT64,
|
|
|
|
ZYDIS_IELEMENT_TYPE_UINT8,
|
|
|
|
ZYDIS_IELEMENT_TYPE_UINT16,
|
|
|
|
ZYDIS_IELEMENT_TYPE_UINT32,
|
|
|
|
ZYDIS_IELEMENT_TYPE_UINT64,
|
|
|
|
ZYDIS_IELEMENT_TYPE_UINT128,
|
|
|
|
ZYDIS_IELEMENT_TYPE_UINT256,
|
|
|
|
ZYDIS_IELEMENT_TYPE_FLOAT16,
|
2022-11-20 21:52:09 +01:00
|
|
|
ZYDIS_IELEMENT_TYPE_FLOAT16X2,
|
2021-05-25 21:23:39 +01:00
|
|
|
ZYDIS_IELEMENT_TYPE_FLOAT32,
|
|
|
|
ZYDIS_IELEMENT_TYPE_FLOAT64,
|
|
|
|
ZYDIS_IELEMENT_TYPE_FLOAT80,
|
|
|
|
ZYDIS_IELEMENT_TYPE_BCD80,
|
|
|
|
ZYDIS_IELEMENT_TYPE_CC3,
|
|
|
|
ZYDIS_IELEMENT_TYPE_CC5,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Maximum value of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_IELEMENT_TYPE_MAX_VALUE = ZYDIS_IELEMENT_TYPE_CC5,
|
|
|
|
/**
|
|
|
|
* The minimum number of bits required to represent all values of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_IELEMENT_TYPE_REQUIRED_BITS = ZYAN_BITS_TO_REPRESENT(ZYDIS_IELEMENT_TYPE_MAX_VALUE)
|
|
|
|
} ZydisInternalElementType;
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the `ZydisImplicitRegisterType` enum.
|
|
|
|
*/
|
|
|
|
typedef enum ZydisImplicitRegisterType_
|
|
|
|
{
|
2022-11-20 21:52:09 +01:00
|
|
|
// TODO: Rename OSZ|ASZ|SSZ_
|
2021-05-25 21:23:39 +01:00
|
|
|
ZYDIS_IMPLREG_TYPE_STATIC,
|
|
|
|
ZYDIS_IMPLREG_TYPE_GPR_OSZ,
|
|
|
|
ZYDIS_IMPLREG_TYPE_GPR_ASZ,
|
|
|
|
ZYDIS_IMPLREG_TYPE_IP_ASZ,
|
|
|
|
ZYDIS_IMPLREG_TYPE_IP_SSZ,
|
2022-11-20 21:52:09 +01:00
|
|
|
ZYDIS_IMPLREG_TYPE_GPR_SSZ,
|
2021-05-25 21:23:39 +01:00
|
|
|
ZYDIS_IMPLREG_TYPE_FLAGS_SSZ,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Maximum value of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_IMPLREG_TYPE_MAX_VALUE = ZYDIS_IMPLREG_TYPE_FLAGS_SSZ,
|
|
|
|
/**
|
|
|
|
* The minimum number of bits required to represent all values of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_IMPLREG_TYPE_REQUIRED_BITS = ZYAN_BITS_TO_REPRESENT(ZYDIS_IMPLREG_TYPE_MAX_VALUE)
|
|
|
|
} ZydisImplicitRegisterType;
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the `ZydisImplicitMemBase` enum.
|
|
|
|
*/
|
|
|
|
typedef enum ZydisImplicitMemBase_
|
|
|
|
{
|
2022-11-20 21:52:09 +01:00
|
|
|
// TODO: Rename OSZ|ASZ|SSZ_
|
2021-05-25 21:23:39 +01:00
|
|
|
ZYDIS_IMPLMEM_BASE_AGPR_REG,
|
|
|
|
ZYDIS_IMPLMEM_BASE_AGPR_RM,
|
|
|
|
ZYDIS_IMPLMEM_BASE_AAX,
|
|
|
|
ZYDIS_IMPLMEM_BASE_ADX,
|
|
|
|
ZYDIS_IMPLMEM_BASE_ABX,
|
|
|
|
ZYDIS_IMPLMEM_BASE_ASI,
|
|
|
|
ZYDIS_IMPLMEM_BASE_ADI,
|
2022-11-20 21:52:09 +01:00
|
|
|
ZYDIS_IMPLMEM_BASE_SSP,
|
|
|
|
ZYDIS_IMPLMEM_BASE_SBP,
|
2021-05-25 21:23:39 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Maximum value of this enum.
|
|
|
|
*/
|
2022-11-20 21:52:09 +01:00
|
|
|
ZYDIS_IMPLMEM_BASE_MAX_VALUE = ZYDIS_IMPLMEM_BASE_SBP,
|
2021-05-25 21:23:39 +01:00
|
|
|
/**
|
|
|
|
* The minimum number of bits required to represent all values of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_IMPLMEM_BASE_REQUIRED_BITS = ZYAN_BITS_TO_REPRESENT(ZYDIS_IMPLMEM_BASE_MAX_VALUE)
|
|
|
|
} ZydisImplicitMemBase;
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
// MSVC does not correctly execute the `pragma pack(1)` compiler-directive, if we use the correct
|
|
|
|
// enum types
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_SEMANTIC_OPTYPE_REQUIRED_BITS <= 8);
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_OPERAND_VISIBILITY_REQUIRED_BITS <= 8);
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_OPERAND_ACTION_REQUIRED_BITS <= 8);
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_IELEMENT_TYPE_REQUIRED_BITS <= 8);
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_OPERAND_ENCODING_REQUIRED_BITS <= 8);
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_IMPLREG_TYPE_REQUIRED_BITS <= 8);
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_REGISTER_REQUIRED_BITS <= 16);
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_IMPLMEM_BASE_REQUIRED_BITS <= 8);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the `ZydisOperandDefinition` struct.
|
|
|
|
*/
|
|
|
|
typedef struct ZydisOperandDefinition_
|
|
|
|
{
|
|
|
|
ZyanU8 type ZYAN_BITFIELD(ZYDIS_SEMANTIC_OPTYPE_REQUIRED_BITS);
|
|
|
|
ZyanU8 visibility ZYAN_BITFIELD(ZYDIS_OPERAND_VISIBILITY_REQUIRED_BITS);
|
|
|
|
ZyanU8 actions ZYAN_BITFIELD(ZYDIS_OPERAND_ACTION_REQUIRED_BITS);
|
|
|
|
ZyanU16 size[3];
|
|
|
|
ZyanU8 element_type ZYAN_BITFIELD(ZYDIS_IELEMENT_TYPE_REQUIRED_BITS);
|
|
|
|
union
|
|
|
|
{
|
|
|
|
ZyanU8 encoding ZYAN_BITFIELD(ZYDIS_OPERAND_ENCODING_REQUIRED_BITS);
|
|
|
|
struct
|
|
|
|
{
|
|
|
|
ZyanU8 type ZYAN_BITFIELD(ZYDIS_IMPLREG_TYPE_REQUIRED_BITS);
|
|
|
|
union
|
|
|
|
{
|
|
|
|
ZyanU16 reg ZYAN_BITFIELD(ZYDIS_REGISTER_REQUIRED_BITS);
|
|
|
|
ZyanU8 id ZYAN_BITFIELD(6);
|
|
|
|
} reg;
|
|
|
|
} reg;
|
|
|
|
struct
|
|
|
|
{
|
|
|
|
ZyanU8 seg ZYAN_BITFIELD(3);
|
|
|
|
ZyanU8 base ZYAN_BITFIELD(ZYDIS_IMPLMEM_BASE_REQUIRED_BITS);
|
|
|
|
} mem;
|
|
|
|
} op;
|
|
|
|
ZyanBool is_multisource4 ZYAN_BITFIELD(1);
|
2022-11-20 21:52:09 +01:00
|
|
|
ZyanBool ignore_seg_override ZYAN_BITFIELD(1);
|
2021-05-25 21:23:39 +01:00
|
|
|
} ZydisOperandDefinition;
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
/* Instruction definition */
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the `ZydisReadWriteAction` enum.
|
|
|
|
*/
|
|
|
|
typedef enum ZydisReadWriteAction_
|
|
|
|
{
|
|
|
|
ZYDIS_RW_ACTION_NONE,
|
|
|
|
ZYDIS_RW_ACTION_READ,
|
|
|
|
ZYDIS_RW_ACTION_WRITE,
|
|
|
|
ZYDIS_RW_ACTION_READWRITE,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Maximum value of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_RW_ACTION_MAX_VALUE = ZYDIS_RW_ACTION_READWRITE,
|
|
|
|
/**
|
|
|
|
* The minimum number of bits required to represent all values of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_RW_ACTION_REQUIRED_BITS = ZYAN_BITS_TO_REPRESENT(ZYDIS_RW_ACTION_MAX_VALUE)
|
|
|
|
} ZydisReadWriteAction;
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the `ZydisInternalVectorLength` enum.
|
|
|
|
*/
|
|
|
|
typedef enum ZydisInternalVectorLength_
|
|
|
|
{
|
|
|
|
ZYDIS_IVECTOR_LENGTH_DEFAULT,
|
|
|
|
ZYDIS_IVECTOR_LENGTH_FIXED_128,
|
|
|
|
ZYDIS_IVECTOR_LENGTH_FIXED_256,
|
|
|
|
ZYDIS_IVECTOR_LENGTH_FIXED_512,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Maximum value of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_IVECTOR_LENGTH_MAX_VALUE = ZYDIS_IVECTOR_LENGTH_FIXED_512,
|
|
|
|
/**
|
|
|
|
* The minimum number of bits required to represent all values of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_IVECTOR_LENGTH_REQUIRED_BITS = ZYAN_BITS_TO_REPRESENT(ZYDIS_IVECTOR_LENGTH_MAX_VALUE)
|
|
|
|
} ZydisInternalVectorLength;
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the `ZydisInternalElementSize` enum.
|
|
|
|
*/
|
|
|
|
typedef enum ZydisInternalElementSize_
|
|
|
|
{
|
|
|
|
ZYDIS_IELEMENT_SIZE_INVALID,
|
|
|
|
ZYDIS_IELEMENT_SIZE_8,
|
|
|
|
ZYDIS_IELEMENT_SIZE_16,
|
|
|
|
ZYDIS_IELEMENT_SIZE_32,
|
|
|
|
ZYDIS_IELEMENT_SIZE_64,
|
|
|
|
ZYDIS_IELEMENT_SIZE_128,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Maximum value of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_IELEMENT_SIZE_MAX_VALUE = ZYDIS_IELEMENT_SIZE_128,
|
|
|
|
/**
|
|
|
|
* The minimum number of bits required to represent all values of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_IELEMENT_SIZE_REQUIRED_BITS = ZYAN_BITS_TO_REPRESENT(ZYDIS_IELEMENT_SIZE_MAX_VALUE)
|
|
|
|
} ZydisInternalElementSize;
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the `ZydisEVEXFunctionality` enum.
|
|
|
|
*/
|
|
|
|
typedef enum ZydisEVEXFunctionality_
|
|
|
|
{
|
|
|
|
ZYDIS_EVEX_FUNC_INVALID,
|
|
|
|
/**
|
|
|
|
* `EVEX.b` enables broadcast functionality.
|
|
|
|
*/
|
|
|
|
ZYDIS_EVEX_FUNC_BC,
|
|
|
|
/**
|
|
|
|
* `EVEX.b` enables embedded-rounding functionality.
|
|
|
|
*/
|
|
|
|
ZYDIS_EVEX_FUNC_RC,
|
|
|
|
/**
|
|
|
|
* `EVEX.b` enables sae functionality.
|
|
|
|
*/
|
|
|
|
ZYDIS_EVEX_FUNC_SAE,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Maximum value of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_EVEX_FUNC_MAX_VALUE = ZYDIS_EVEX_FUNC_SAE,
|
|
|
|
/**
|
|
|
|
* The minimum number of bits required to represent all values of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_EVEX_FUNC_REQUIRED_BITS = ZYAN_BITS_TO_REPRESENT(ZYDIS_EVEX_FUNC_MAX_VALUE)
|
|
|
|
} ZydisEVEXFunctionality;
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the `ZydisEVEXTupleType` enum.
|
|
|
|
*/
|
|
|
|
typedef enum ZydisEVEXTupleType_
|
|
|
|
{
|
|
|
|
ZYDIS_TUPLETYPE_INVALID,
|
|
|
|
/**
|
|
|
|
* Full Vector
|
|
|
|
*/
|
|
|
|
ZYDIS_TUPLETYPE_FV,
|
|
|
|
/**
|
|
|
|
* Half Vector
|
|
|
|
*/
|
|
|
|
ZYDIS_TUPLETYPE_HV,
|
|
|
|
/**
|
|
|
|
* Full Vector Mem
|
|
|
|
*/
|
|
|
|
ZYDIS_TUPLETYPE_FVM,
|
|
|
|
/**
|
|
|
|
* Tuple1 Scalar
|
|
|
|
*/
|
|
|
|
ZYDIS_TUPLETYPE_T1S,
|
|
|
|
/**
|
|
|
|
* Tuple1 Fixed
|
|
|
|
*/
|
|
|
|
ZYDIS_TUPLETYPE_T1F,
|
|
|
|
/**
|
|
|
|
* Tuple1 4x32
|
|
|
|
*/
|
|
|
|
ZYDIS_TUPLETYPE_T1_4X,
|
|
|
|
/**
|
|
|
|
* Gather / Scatter
|
|
|
|
*/
|
|
|
|
ZYDIS_TUPLETYPE_GSCAT,
|
|
|
|
/**
|
|
|
|
* Tuple2
|
|
|
|
*/
|
|
|
|
ZYDIS_TUPLETYPE_T2,
|
|
|
|
/**
|
|
|
|
* Tuple4
|
|
|
|
*/
|
|
|
|
ZYDIS_TUPLETYPE_T4,
|
|
|
|
/**
|
|
|
|
* Tuple8
|
|
|
|
*/
|
|
|
|
ZYDIS_TUPLETYPE_T8,
|
|
|
|
/**
|
|
|
|
* Half Mem
|
|
|
|
*/
|
|
|
|
ZYDIS_TUPLETYPE_HVM,
|
|
|
|
/**
|
|
|
|
* QuarterMem
|
|
|
|
*/
|
|
|
|
ZYDIS_TUPLETYPE_QVM,
|
|
|
|
/**
|
|
|
|
* OctMem
|
|
|
|
*/
|
|
|
|
ZYDIS_TUPLETYPE_OVM,
|
|
|
|
/**
|
|
|
|
* Mem128
|
|
|
|
*/
|
|
|
|
ZYDIS_TUPLETYPE_M128,
|
|
|
|
/**
|
|
|
|
* MOVDDUP
|
|
|
|
*/
|
|
|
|
ZYDIS_TUPLETYPE_DUP,
|
2022-11-20 21:52:09 +01:00
|
|
|
/**
|
|
|
|
* Quarter of the vector-length.
|
|
|
|
*/
|
|
|
|
ZYDIS_TUPLETYPE_QUARTER,
|
2021-05-25 21:23:39 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Maximum value of this enum.
|
|
|
|
*/
|
2022-11-20 21:52:09 +01:00
|
|
|
ZYDIS_TUPLETYPE_MAX_VALUE = ZYDIS_TUPLETYPE_QUARTER,
|
2021-05-25 21:23:39 +01:00
|
|
|
/**
|
|
|
|
* The minimum number of bits required to represent all values of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_TUPLETYPE_REQUIRED_BITS = ZYAN_BITS_TO_REPRESENT(ZYDIS_TUPLETYPE_MAX_VALUE)
|
|
|
|
} ZydisEVEXTupleType;
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the `ZydisMVEXFunctionality` enum.
|
|
|
|
*/
|
|
|
|
typedef enum ZydisMVEXFunctionality_
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* The `MVEX.SSS` value is ignored.
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_IGNORED,
|
|
|
|
/**
|
|
|
|
* `MVEX.SSS` must be `000b`.
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_INVALID,
|
|
|
|
/**
|
|
|
|
* `MVEX.SSS` controls embedded-rounding functionality.
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_RC,
|
|
|
|
/**
|
|
|
|
* `MVEX.SSS` controls sae functionality.
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_SAE,
|
|
|
|
/**
|
|
|
|
* No special operation (32bit float elements).
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_F_32,
|
|
|
|
/**
|
|
|
|
* No special operation (32bit uint elements).
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_I_32,
|
|
|
|
/**
|
|
|
|
* No special operation (64bit float elements).
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_F_64,
|
|
|
|
/**
|
|
|
|
* No special operation (64bit uint elements).
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_I_64,
|
|
|
|
/**
|
|
|
|
* Sf32(reg) or Si32(reg).
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_SWIZZLE_32,
|
|
|
|
/**
|
|
|
|
* Sf64(reg) or Si64(reg).
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_SWIZZLE_64,
|
|
|
|
/**
|
|
|
|
* Sf32(mem).
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_SF_32,
|
|
|
|
/**
|
|
|
|
* Sf32(mem) broadcast only.
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_SF_32_BCST,
|
|
|
|
/**
|
|
|
|
* Sf32(mem) broadcast 4to16 only.
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_SF_32_BCST_4TO16,
|
|
|
|
/**
|
|
|
|
* Sf64(mem).
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_SF_64,
|
|
|
|
/**
|
|
|
|
* Si32(mem).
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_SI_32,
|
|
|
|
/**
|
|
|
|
* Si32(mem) broadcast only.
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_SI_32_BCST,
|
|
|
|
/**
|
|
|
|
* Si32(mem) broadcast 4to16 only.
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_SI_32_BCST_4TO16,
|
|
|
|
/**
|
|
|
|
* Si64(mem).
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_SI_64,
|
|
|
|
/**
|
|
|
|
* Uf32.
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_UF_32,
|
|
|
|
/**
|
|
|
|
* Uf64.
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_UF_64,
|
|
|
|
/**
|
|
|
|
* Ui32.
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_UI_32,
|
|
|
|
/**
|
|
|
|
* Ui64.
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_UI_64,
|
|
|
|
/**
|
|
|
|
* Df32.
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_DF_32,
|
|
|
|
/**
|
|
|
|
* Df64.
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_DF_64,
|
|
|
|
/**
|
|
|
|
* Di32.
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_DI_32,
|
|
|
|
/**
|
|
|
|
* Di64.
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_DI_64,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Maximum value of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_MAX_VALUE = ZYDIS_MVEX_FUNC_DI_64,
|
|
|
|
/**
|
|
|
|
* The minimum number of bits required to represent all values of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_FUNC_REQUIRED_BITS = ZYAN_BITS_TO_REPRESENT(ZYDIS_MVEX_FUNC_MAX_VALUE)
|
|
|
|
} ZydisMVEXFunctionality;
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the `ZydisVEXStaticBroadcast` enum.
|
|
|
|
*/
|
|
|
|
typedef enum ZydisVEXStaticBroadcast
|
|
|
|
{
|
|
|
|
ZYDIS_VEX_STATIC_BROADCAST_NONE,
|
|
|
|
ZYDIS_VEX_STATIC_BROADCAST_1_TO_2,
|
|
|
|
ZYDIS_VEX_STATIC_BROADCAST_1_TO_4,
|
|
|
|
ZYDIS_VEX_STATIC_BROADCAST_1_TO_8,
|
|
|
|
ZYDIS_VEX_STATIC_BROADCAST_1_TO_16,
|
|
|
|
ZYDIS_VEX_STATIC_BROADCAST_1_TO_32,
|
|
|
|
ZYDIS_VEX_STATIC_BROADCAST_2_TO_4,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Maximum value of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_VEX_STATIC_BROADCAST_MAX_VALUE = ZYDIS_VEX_STATIC_BROADCAST_2_TO_4,
|
|
|
|
/**
|
|
|
|
* The minimum number of bits required to represent all values of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_VEX_STATIC_BROADCAST_REQUIRED_BITS =
|
|
|
|
ZYAN_BITS_TO_REPRESENT(ZYDIS_VEX_STATIC_BROADCAST_MAX_VALUE)
|
|
|
|
} ZydisVEXStaticBroadcast;
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the `ZydisEVEXStaticBroadcast` enum.
|
|
|
|
*/
|
|
|
|
typedef enum ZydisEVEXStaticBroadcast_
|
|
|
|
{
|
|
|
|
ZYDIS_EVEX_STATIC_BROADCAST_NONE,
|
|
|
|
ZYDIS_EVEX_STATIC_BROADCAST_1_TO_2,
|
|
|
|
ZYDIS_EVEX_STATIC_BROADCAST_1_TO_4,
|
|
|
|
ZYDIS_EVEX_STATIC_BROADCAST_1_TO_8,
|
|
|
|
ZYDIS_EVEX_STATIC_BROADCAST_1_TO_16,
|
|
|
|
ZYDIS_EVEX_STATIC_BROADCAST_1_TO_32,
|
|
|
|
ZYDIS_EVEX_STATIC_BROADCAST_1_TO_64,
|
|
|
|
ZYDIS_EVEX_STATIC_BROADCAST_2_TO_4,
|
|
|
|
ZYDIS_EVEX_STATIC_BROADCAST_2_TO_8,
|
|
|
|
ZYDIS_EVEX_STATIC_BROADCAST_2_TO_16,
|
|
|
|
ZYDIS_EVEX_STATIC_BROADCAST_4_TO_8,
|
|
|
|
ZYDIS_EVEX_STATIC_BROADCAST_4_TO_16,
|
|
|
|
ZYDIS_EVEX_STATIC_BROADCAST_8_TO_16,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Maximum value of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_EVEX_STATIC_BROADCAST_MAX_VALUE = ZYDIS_EVEX_STATIC_BROADCAST_8_TO_16,
|
|
|
|
/**
|
|
|
|
* The minimum number of bits required to represent all values of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_EVEX_STATIC_BROADCAST_REQUIRED_BITS =
|
|
|
|
ZYAN_BITS_TO_REPRESENT(ZYDIS_EVEX_STATIC_BROADCAST_MAX_VALUE)
|
|
|
|
} ZydisEVEXStaticBroadcast;
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the `ZydisMVEXStaticBroadcast` enum.
|
|
|
|
*/
|
|
|
|
typedef enum ZydisMVEXStaticBroadcast_
|
|
|
|
{
|
|
|
|
ZYDIS_MVEX_STATIC_BROADCAST_NONE,
|
|
|
|
ZYDIS_MVEX_STATIC_BROADCAST_1_TO_8,
|
|
|
|
ZYDIS_MVEX_STATIC_BROADCAST_1_TO_16,
|
|
|
|
ZYDIS_MVEX_STATIC_BROADCAST_4_TO_8,
|
|
|
|
ZYDIS_MVEX_STATIC_BROADCAST_4_TO_16,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Maximum value of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_STATIC_BROADCAST_MAX_VALUE = ZYDIS_MVEX_STATIC_BROADCAST_4_TO_16,
|
|
|
|
/**
|
|
|
|
* The minimum number of bits required to represent all values of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_MVEX_STATIC_BROADCAST_REQUIRED_BITS =
|
|
|
|
ZYAN_BITS_TO_REPRESENT(ZYDIS_MVEX_STATIC_BROADCAST_MAX_VALUE)
|
|
|
|
} ZydisMVEXStaticBroadcast;
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the `ZydisMaskPolicy` enum.
|
|
|
|
*/
|
|
|
|
typedef enum ZydisMaskPolicy_
|
|
|
|
{
|
|
|
|
ZYDIS_MASK_POLICY_INVALID,
|
|
|
|
/**
|
|
|
|
* The instruction accepts mask-registers other than the default-mask (K0), but
|
|
|
|
* does not require them.
|
|
|
|
*/
|
|
|
|
ZYDIS_MASK_POLICY_ALLOWED,
|
|
|
|
/**
|
|
|
|
* The instruction requires a mask-register other than the default-mask (K0).
|
|
|
|
*/
|
|
|
|
ZYDIS_MASK_POLICY_REQUIRED,
|
|
|
|
/**
|
|
|
|
* The instruction does not allow a mask-register other than the default-mask (K0).
|
|
|
|
*/
|
|
|
|
ZYDIS_MASK_POLICY_FORBIDDEN,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Maximum value of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_MASK_POLICY_MAX_VALUE = ZYDIS_MASK_POLICY_FORBIDDEN,
|
|
|
|
/**
|
|
|
|
* The minimum number of bits required to represent all values of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_MASK_POLICY_REQUIRED_BITS = ZYAN_BITS_TO_REPRESENT(ZYDIS_MASK_POLICY_MAX_VALUE)
|
|
|
|
} ZydisMaskPolicy;
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the `ZydisMaskOverride` enum.
|
|
|
|
*/
|
|
|
|
typedef enum ZydisMaskOverride_
|
|
|
|
{
|
|
|
|
ZYDIS_MASK_OVERRIDE_DEFAULT,
|
|
|
|
ZYDIS_MASK_OVERRIDE_ZEROING,
|
|
|
|
ZYDIS_MASK_OVERRIDE_CONTROL,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Maximum value of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_MASK_OVERRIDE_MAX_VALUE = ZYDIS_MASK_OVERRIDE_CONTROL,
|
|
|
|
/**
|
|
|
|
* The minimum number of bits required to represent all values of this enum.
|
|
|
|
*/
|
|
|
|
ZYDIS_MASK_OVERRIDE_REQUIRED_BITS = ZYAN_BITS_TO_REPRESENT(ZYDIS_MASK_OVERRIDE_MAX_VALUE)
|
|
|
|
} ZydisMaskOverride;
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
2022-11-20 21:52:09 +01:00
|
|
|
#define ZYDIS_OPDEF_REQUIRED_BITS \
|
|
|
|
ZYAN_MAX(ZYDIS_REGKIND_REQUIRED_BITS, ZYDIS_MEMOP_TYPE_REQUIRED_BITS + 1) + 1
|
|
|
|
|
|
|
|
#define ZYDIS_OPDEF_GET_REG(operand_definition) \
|
|
|
|
((operand_definition) & ((1 << ZYDIS_REGKIND_REQUIRED_BITS ) - 1))
|
|
|
|
|
|
|
|
#define ZYDIS_OPDEF_GET_MEM(operand_definition) \
|
|
|
|
((operand_definition) & ((1 << ZYDIS_MEMOP_TYPE_REQUIRED_BITS) - 1))
|
|
|
|
|
|
|
|
#define ZYDIS_OPDEF_GET_REG_HIGH_BIT(operand_definition) \
|
|
|
|
(((operand_definition) >> ZYDIS_REGKIND_REQUIRED_BITS ) & 0x01)
|
|
|
|
|
|
|
|
#define ZYDIS_OPDEF_GET_MEM_HIGH_BIT(operand_definition) \
|
|
|
|
(((operand_definition) >> ZYDIS_MEMOP_TYPE_REQUIRED_BITS) & 0x01)
|
|
|
|
|
2021-05-25 21:23:39 +01:00
|
|
|
// MSVC does not correctly execute the `pragma pack(1)` compiler-directive, if we use the correct
|
|
|
|
// enum types
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_MNEMONIC_REQUIRED_BITS <= 16);
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_CATEGORY_REQUIRED_BITS <= 8);
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_ISA_SET_REQUIRED_BITS <= 8);
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_ISA_EXT_REQUIRED_BITS <= 8);
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_BRANCH_TYPE_REQUIRED_BITS <= 8);
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_EXCEPTION_CLASS_REQUIRED_BITS <= 8);
|
2022-11-20 21:52:09 +01:00
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_OPDEF_REQUIRED_BITS <= 8);
|
2021-05-25 21:23:39 +01:00
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_RW_ACTION_REQUIRED_BITS <= 8);
|
|
|
|
|
|
|
|
#ifndef ZYDIS_MINIMAL_MODE
|
|
|
|
# define ZYDIS_INSTRUCTION_DEFINITION_BASE \
|
|
|
|
ZyanU16 mnemonic ZYAN_BITFIELD(ZYDIS_MNEMONIC_REQUIRED_BITS); \
|
|
|
|
ZyanU8 operand_count ZYAN_BITFIELD( 4); \
|
2022-11-20 21:52:09 +01:00
|
|
|
ZyanU8 operand_count_visible ZYAN_BITFIELD( 3); \
|
2021-05-25 21:23:39 +01:00
|
|
|
ZyanU16 operand_reference ZYAN_BITFIELD(15); \
|
|
|
|
ZyanU8 operand_size_map ZYAN_BITFIELD( 3); \
|
|
|
|
ZyanU8 address_size_map ZYAN_BITFIELD( 2); \
|
|
|
|
ZyanU8 flags_reference ZYAN_BITFIELD( 7); \
|
|
|
|
ZyanBool requires_protected_mode ZYAN_BITFIELD( 1); \
|
2022-11-20 21:52:09 +01:00
|
|
|
ZyanBool no_compat_mode ZYAN_BITFIELD( 1); \
|
2021-05-25 21:23:39 +01:00
|
|
|
ZyanU8 category ZYAN_BITFIELD(ZYDIS_CATEGORY_REQUIRED_BITS); \
|
|
|
|
ZyanU8 isa_set ZYAN_BITFIELD(ZYDIS_ISA_SET_REQUIRED_BITS); \
|
|
|
|
ZyanU8 isa_ext ZYAN_BITFIELD(ZYDIS_ISA_EXT_REQUIRED_BITS); \
|
|
|
|
ZyanU8 branch_type ZYAN_BITFIELD(ZYDIS_BRANCH_TYPE_REQUIRED_BITS); \
|
|
|
|
ZyanU8 exception_class ZYAN_BITFIELD(ZYDIS_EXCEPTION_CLASS_REQUIRED_BITS); \
|
2022-11-20 21:52:09 +01:00
|
|
|
ZyanU8 op_reg ZYAN_BITFIELD(ZYDIS_OPDEF_REQUIRED_BITS); \
|
|
|
|
ZyanU8 op_rm ZYAN_BITFIELD(ZYDIS_OPDEF_REQUIRED_BITS); \
|
2021-05-25 21:23:39 +01:00
|
|
|
ZyanU8 cpu_state ZYAN_BITFIELD(ZYDIS_RW_ACTION_REQUIRED_BITS); \
|
|
|
|
ZyanU8 fpu_state ZYAN_BITFIELD(ZYDIS_RW_ACTION_REQUIRED_BITS); \
|
2022-11-20 21:52:09 +01:00
|
|
|
ZyanU8 xmm_state ZYAN_BITFIELD(ZYDIS_RW_ACTION_REQUIRED_BITS); \
|
|
|
|
ZyanBool accepts_segment ZYAN_BITFIELD( 1)
|
2021-05-25 21:23:39 +01:00
|
|
|
#else
|
|
|
|
# define ZYDIS_INSTRUCTION_DEFINITION_BASE \
|
|
|
|
ZyanU16 mnemonic ZYAN_BITFIELD(ZYDIS_MNEMONIC_REQUIRED_BITS); \
|
|
|
|
ZyanU8 operand_size_map ZYAN_BITFIELD( 3); \
|
|
|
|
ZyanU8 address_size_map ZYAN_BITFIELD( 2); \
|
|
|
|
ZyanBool requires_protected_mode ZYAN_BITFIELD( 1); \
|
2022-11-20 21:52:09 +01:00
|
|
|
ZyanBool no_compat_mode ZYAN_BITFIELD( 1); \
|
|
|
|
ZyanU8 op_reg ZYAN_BITFIELD(ZYDIS_OPDEF_REQUIRED_BITS); \
|
|
|
|
ZyanU8 op_rm ZYAN_BITFIELD(ZYDIS_OPDEF_REQUIRED_BITS)
|
2021-05-25 21:23:39 +01:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#define ZYDIS_INSTRUCTION_DEFINITION_BASE_VECTOR \
|
|
|
|
ZYDIS_INSTRUCTION_DEFINITION_BASE; \
|
2022-11-20 21:52:09 +01:00
|
|
|
ZyanU8 op_ndsndd ZYAN_BITFIELD(ZYDIS_OPDEF_REQUIRED_BITS)
|
2021-05-25 21:23:39 +01:00
|
|
|
|
|
|
|
#define ZYDIS_INSTRUCTION_DEFINITION_BASE_VECTOR_INTEL \
|
|
|
|
ZYDIS_INSTRUCTION_DEFINITION_BASE_VECTOR; \
|
2022-11-20 21:52:09 +01:00
|
|
|
ZyanBool is_gather ZYAN_BITFIELD( 1); \
|
|
|
|
ZyanBool no_source_dest_match ZYAN_BITFIELD( 1); \
|
|
|
|
ZyanBool no_source_source_match ZYAN_BITFIELD( 1) // TODO: Could be moved to VEX
|
2021-05-25 21:23:39 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the `ZydisInstructionDefinition` struct.
|
|
|
|
*/
|
|
|
|
typedef struct ZydisInstructionDefinition_
|
|
|
|
{
|
|
|
|
ZYDIS_INSTRUCTION_DEFINITION_BASE;
|
|
|
|
} ZydisInstructionDefinition;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the `ZydisInstructionDefinitionLEGACY` struct.
|
|
|
|
*/
|
|
|
|
typedef struct ZydisInstructionDefinitionLEGACY_
|
|
|
|
{
|
|
|
|
ZYDIS_INSTRUCTION_DEFINITION_BASE;
|
|
|
|
#ifndef ZYDIS_MINIMAL_MODE
|
|
|
|
ZyanBool is_privileged ZYAN_BITFIELD( 1);
|
|
|
|
#endif
|
|
|
|
ZyanBool accepts_LOCK ZYAN_BITFIELD( 1);
|
|
|
|
#ifndef ZYDIS_MINIMAL_MODE
|
|
|
|
ZyanBool accepts_REP ZYAN_BITFIELD( 1);
|
|
|
|
ZyanBool accepts_REPEREPZ ZYAN_BITFIELD( 1);
|
|
|
|
ZyanBool accepts_REPNEREPNZ ZYAN_BITFIELD( 1);
|
|
|
|
ZyanBool accepts_BOUND ZYAN_BITFIELD( 1);
|
|
|
|
ZyanBool accepts_XACQUIRE ZYAN_BITFIELD( 1);
|
|
|
|
ZyanBool accepts_XRELEASE ZYAN_BITFIELD( 1);
|
2022-11-20 21:52:09 +01:00
|
|
|
ZyanBool accepts_NOTRACK ZYAN_BITFIELD( 1);
|
2021-05-25 21:23:39 +01:00
|
|
|
ZyanBool accepts_hle_without_lock ZYAN_BITFIELD( 1);
|
|
|
|
ZyanBool accepts_branch_hints ZYAN_BITFIELD( 1);
|
|
|
|
#endif
|
|
|
|
} ZydisInstructionDefinitionLEGACY;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the `ZydisInstructionDefinition3DNOW` struct.
|
|
|
|
*/
|
|
|
|
typedef struct ZydisInstructionDefinition3DNOW_
|
|
|
|
{
|
|
|
|
ZYDIS_INSTRUCTION_DEFINITION_BASE;
|
|
|
|
} ZydisInstructionDefinition3DNOW;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the `ZydisInstructionDefinitionXOP` struct.
|
|
|
|
*/
|
|
|
|
typedef struct ZydisInstructionDefinitionXOP_
|
|
|
|
{
|
|
|
|
ZYDIS_INSTRUCTION_DEFINITION_BASE_VECTOR;
|
|
|
|
} ZydisInstructionDefinitionXOP;
|
|
|
|
|
|
|
|
// MSVC does not correctly execute the `pragma pack(1)` compiler-directive, if we use the correct
|
|
|
|
// enum types
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_VEX_STATIC_BROADCAST_REQUIRED_BITS <= 8);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the `ZydisInstructionDefinitionVEX` struct.
|
|
|
|
*/
|
|
|
|
typedef struct ZydisInstructionDefinitionVEX_
|
|
|
|
{
|
|
|
|
ZYDIS_INSTRUCTION_DEFINITION_BASE_VECTOR_INTEL;
|
|
|
|
#ifndef ZYDIS_MINIMAL_MODE
|
|
|
|
ZyanU8 broadcast ZYAN_BITFIELD(ZYDIS_VEX_STATIC_BROADCAST_REQUIRED_BITS);
|
|
|
|
#endif
|
|
|
|
} ZydisInstructionDefinitionVEX;
|
|
|
|
|
|
|
|
#ifndef ZYDIS_DISABLE_AVX512
|
|
|
|
|
|
|
|
// MSVC does not correctly execute the `pragma pack(1)` compiler-directive, if we use the correct
|
|
|
|
// enum types
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_IVECTOR_LENGTH_REQUIRED_BITS <= 8);
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_TUPLETYPE_REQUIRED_BITS <= 8);
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_IELEMENT_SIZE_REQUIRED_BITS <= 8);
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_EVEX_FUNC_REQUIRED_BITS <= 8);
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_MASK_POLICY_REQUIRED_BITS <= 8);
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_MASK_OVERRIDE_REQUIRED_BITS <= 8);
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_EVEX_STATIC_BROADCAST_REQUIRED_BITS <= 8);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the `ZydisInstructionDefinitionEVEX` struct.
|
|
|
|
*/
|
|
|
|
typedef struct ZydisInstructionDefinitionEVEX_
|
|
|
|
{
|
|
|
|
ZYDIS_INSTRUCTION_DEFINITION_BASE_VECTOR_INTEL;
|
|
|
|
#ifndef ZYDIS_MINIMAL_MODE
|
|
|
|
ZyanU8 vector_length ZYAN_BITFIELD(ZYDIS_IVECTOR_LENGTH_REQUIRED_BITS);
|
|
|
|
ZyanU8 tuple_type ZYAN_BITFIELD(ZYDIS_TUPLETYPE_REQUIRED_BITS);
|
|
|
|
ZyanU8 element_size ZYAN_BITFIELD(ZYDIS_IELEMENT_SIZE_REQUIRED_BITS);
|
|
|
|
ZyanU8 functionality ZYAN_BITFIELD(ZYDIS_EVEX_FUNC_REQUIRED_BITS);
|
|
|
|
#endif
|
|
|
|
ZyanU8 mask_policy ZYAN_BITFIELD(ZYDIS_MASK_POLICY_REQUIRED_BITS);
|
|
|
|
ZyanBool accepts_zero_mask ZYAN_BITFIELD( 1);
|
|
|
|
#ifndef ZYDIS_MINIMAL_MODE
|
|
|
|
ZyanU8 mask_override ZYAN_BITFIELD(ZYDIS_MASK_OVERRIDE_REQUIRED_BITS);
|
|
|
|
ZyanU8 broadcast ZYAN_BITFIELD(ZYDIS_EVEX_STATIC_BROADCAST_REQUIRED_BITS);
|
|
|
|
#endif
|
|
|
|
} ZydisInstructionDefinitionEVEX;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef ZYDIS_DISABLE_KNC
|
|
|
|
|
|
|
|
// MSVC does not correctly execute the `pragma pack(1)` compiler-directive, if we use the correct
|
|
|
|
// enum types
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_MVEX_FUNC_REQUIRED_BITS <= 8);
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_MASK_POLICY_REQUIRED_BITS <= 8);
|
|
|
|
ZYAN_STATIC_ASSERT(ZYDIS_MVEX_STATIC_BROADCAST_REQUIRED_BITS <= 8);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the `ZydisInstructionDefinitionMVEX` struct.
|
|
|
|
*/
|
|
|
|
typedef struct ZydisInstructionDefinitionMVEX_
|
|
|
|
{
|
|
|
|
ZYDIS_INSTRUCTION_DEFINITION_BASE_VECTOR_INTEL;
|
|
|
|
ZyanU8 functionality ZYAN_BITFIELD(ZYDIS_MVEX_FUNC_REQUIRED_BITS);
|
|
|
|
ZyanU8 mask_policy ZYAN_BITFIELD(ZYDIS_MASK_POLICY_REQUIRED_BITS);
|
|
|
|
#ifndef ZYDIS_MINIMAL_MODE
|
|
|
|
ZyanBool has_element_granularity ZYAN_BITFIELD( 1);
|
|
|
|
ZyanU8 broadcast ZYAN_BITFIELD(ZYDIS_MVEX_STATIC_BROADCAST_REQUIRED_BITS);
|
|
|
|
#endif
|
|
|
|
} ZydisInstructionDefinitionMVEX;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
#pragma pack(pop)
|
|
|
|
|
|
|
|
#ifdef ZYAN_MSVC
|
|
|
|
# pragma warning(pop)
|
|
|
|
#endif
|
|
|
|
|
2022-11-20 21:52:09 +01:00
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
/* Accessed CPU/FPU flags */
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Contains information about the CPU/FPU flags accessed by an instruction.
|
|
|
|
*
|
|
|
|
* We don't want this struct to be packed! A pointer to the individual members will be used by the
|
|
|
|
* `ZydisDecodedInstruction` struct.
|
|
|
|
*/
|
|
|
|
typedef struct ZydisDefinitionAccessedFlags_
|
|
|
|
{
|
|
|
|
ZydisAccessedFlags cpu_flags;
|
|
|
|
ZydisAccessedFlags fpu_flags;
|
|
|
|
} ZydisDefinitionAccessedFlags;
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
2021-05-25 21:23:39 +01:00
|
|
|
/* ============================================================================================== */
|
|
|
|
/* Functions */
|
|
|
|
/* ============================================================================================== */
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
/* Instruction definition */
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the instruction-definition with the given `encoding` and `id`.
|
|
|
|
*
|
|
|
|
* @param encoding The instruction-encoding.
|
|
|
|
* @param id The definition-id.
|
|
|
|
* @param definition A pointer to the variable that receives a pointer to the instruction-
|
|
|
|
* definition.
|
|
|
|
*/
|
|
|
|
ZYDIS_NO_EXPORT void ZydisGetInstructionDefinition(ZydisInstructionEncoding encoding,
|
|
|
|
ZyanU16 id, const ZydisInstructionDefinition** definition);
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
/* Operand definition */
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
#ifndef ZYDIS_MINIMAL_MODE
|
|
|
|
/**
|
|
|
|
* Returns the the operand-definitions for the given instruction-`definition`.
|
|
|
|
*
|
|
|
|
* @param definition A pointer to the instruction-definition.
|
|
|
|
*
|
2022-11-20 21:52:09 +01:00
|
|
|
* @return A pointer to the first operand definition of the instruction, or `ZYAN_NULL`.
|
2021-05-25 21:23:39 +01:00
|
|
|
*/
|
2022-11-20 21:52:09 +01:00
|
|
|
ZYDIS_NO_EXPORT const ZydisOperandDefinition* ZydisGetOperandDefinitions(
|
|
|
|
const ZydisInstructionDefinition* definition);
|
2021-05-25 21:23:39 +01:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
/* Element info */
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
#ifndef ZYDIS_MINIMAL_MODE
|
|
|
|
/**
|
|
|
|
* Returns the actual type and size of an internal element-type.
|
|
|
|
*
|
|
|
|
* @param element The internal element type.
|
|
|
|
* @param type The actual element type.
|
|
|
|
* @param size The element size.
|
|
|
|
*/
|
|
|
|
ZYDIS_NO_EXPORT void ZydisGetElementInfo(ZydisInternalElementType element, ZydisElementType* type,
|
|
|
|
ZydisElementSize* size);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
/* Accessed CPU flags */
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
#ifndef ZYDIS_MINIMAL_MODE
|
|
|
|
/**
|
|
|
|
* Returns the the operand-definitions for the given instruction-`definition`.
|
|
|
|
*
|
|
|
|
* @param definition A pointer to the instruction-definition.
|
2022-11-20 21:52:09 +01:00
|
|
|
* @param flags A pointer to the variable that receives the `ZydisDefinitionAccessedFlags`
|
|
|
|
* struct.
|
2021-05-25 21:23:39 +01:00
|
|
|
*
|
|
|
|
* @return `ZYAN_TRUE`, if the instruction accesses any flags, or `ZYAN_FALSE`, if not.
|
|
|
|
*/
|
|
|
|
ZYDIS_NO_EXPORT ZyanBool ZydisGetAccessedFlags(const ZydisInstructionDefinition* definition,
|
2022-11-20 21:52:09 +01:00
|
|
|
const ZydisDefinitionAccessedFlags** flags);
|
2021-05-25 21:23:39 +01:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/* ---------------------------------------------------------------------------------------------- */
|
|
|
|
|
|
|
|
/* ============================================================================================== */
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* ZYDIS_INTERNAL_SHAREDDATA_H */
|