Removed EVEX tuple-type and element-size from the public info-struct

This commit is contained in:
flobernd 2017-06-22 19:54:35 +02:00
parent b9c43d83a7
commit 4d3a71369b
3 changed files with 132 additions and 116 deletions

View File

@ -708,83 +708,6 @@ enum ZydisVectorLengths
ZYDIS_VECTOR_LENGTH_512 = 512 ZYDIS_VECTOR_LENGTH_512 = 512
}; };
/* ---------------------------------------------------------------------------------------------- */
/* EVEX tuple-type */
/* ---------------------------------------------------------------------------------------------- */
/**
* @brief Defines the @c ZydisTupleType datatype.
*/
typedef uint8_t ZydisTupleType;
/**
* @brief Values that represent EVEX tuple-types.
*/
enum ZydisTupleTypes
{
ZYDIS_TUPLETYPE_INVALID,
/**
* @brief Full Vector
*/
ZYDIS_TUPLETYPE_FV,
/**
* @brief Half Vector
*/
ZYDIS_TUPLETYPE_HV,
/**
* @brief Full Vector Mem
*/
ZYDIS_TUPLETYPE_FVM,
/**
* @brief Tuple1 Scalar
*/
ZYDIS_TUPLETYPE_T1S,
/**
* @brief Tuple1 Fixed
*/
ZYDIS_TUPLETYPE_T1F,
/**
* @brief Tuple1 4x32
*/
ZYDIS_TUPLETYPE_T1_4X,
/**
* @brief Gather / Scatter
*/
ZYDIS_TUPLETYPE_GSCAT,
/**
* @brief Tuple2
*/
ZYDIS_TUPLETYPE_T2,
/**
* @brief Tuple4
*/
ZYDIS_TUPLETYPE_T4,
/**
* @brief Tuple8
*/
ZYDIS_TUPLETYPE_T8,
/**
* @brief Half Mem
*/
ZYDIS_TUPLETYPE_HVM,
/**
* @brief QuarterMem
*/
ZYDIS_TUPLETYPE_QVM,
/**
* @brief OctMem
*/
ZYDIS_TUPLETYPE_OVM,
/**
* @brief Mem128
*/
ZYDIS_TUPLETYPE_M128,
/**
* @brief MOVDDUP
*/
ZYDIS_TUPLETYPE_DUP
};
/* ---------------------------------------------------------------------------------------------- */ /* ---------------------------------------------------------------------------------------------- */
/* AVX mask mode */ /* AVX mask mode */
/* ---------------------------------------------------------------------------------------------- */ /* ---------------------------------------------------------------------------------------------- */
@ -1007,14 +930,6 @@ typedef struct ZydisInstructionInfo_
* @brief The AVX vector-length. * @brief The AVX vector-length.
*/ */
ZydisVectorLength vectorLength; ZydisVectorLength vectorLength;
/**
* @brief The AVX tuple-type (EVEX only).
*/
ZydisTupleType tupleType;
/**
* @brief The AVX element-size.
*/
uint8_t elementSize;
/** /**
* @brief The scale-factor for compressed 8-bit displacement values. * @brief The scale-factor for compressed 8-bit displacement values.
*/ */
@ -1031,13 +946,26 @@ typedef struct ZydisInstructionInfo_
* @brief The AVX rounding-mode. * @brief The AVX rounding-mode.
*/ */
ZydisRoundingMode roundingMode; ZydisRoundingMode roundingMode;
/**
* @brief The AVX register-swizzle mode (MVEX only).
*/
ZydisSwizzleMode swizzleMode;
/**
* @brief The AVX data-conversion mode (MVEX only).
*/
ZydisConversionMode conversionMode;
// TODO: Remove SAE from the rounding-mode enum and always add it as extra value // TODO: Remove SAE from the rounding-mode enum and always add it as extra value
/**
* @brief Signals, if the sae functionality is enabled for the instruction.
*/
ZydisBool hasSAE; ZydisBool hasSAE;
/**
* @brief Signals, if the instruction has a memory eviction-hint (MVEX only).
*/
ZydisBool hasEvictionHint; ZydisBool hasEvictionHint;
ZydisSwizzleMode swizzleMode;
ZydisConversionMode conversionMode;
} avx; } avx;
/** /**
* @brief Extended info about different instruction-parts like ModRM, SIB or * @brief Extended info about different instruction-parts like ModRM, SIB or

View File

@ -355,6 +355,81 @@ enum ZydisEVEXFunctionalities
/* ---------------------------------------------------------------------------------------------- */ /* ---------------------------------------------------------------------------------------------- */
/**
* @brief Defines the @c ZydisEVEXTupleType datatype.
*/
typedef uint8_t ZydisEVEXTupleType;
/**
* @brief Values that represent EVEX tuple-types.
*/
enum ZydisEVEXTupleTypes
{
ZYDIS_TUPLETYPE_INVALID,
/**
* @brief Full Vector
*/
ZYDIS_TUPLETYPE_FV,
/**
* @brief Half Vector
*/
ZYDIS_TUPLETYPE_HV,
/**
* @brief Full Vector Mem
*/
ZYDIS_TUPLETYPE_FVM,
/**
* @brief Tuple1 Scalar
*/
ZYDIS_TUPLETYPE_T1S,
/**
* @brief Tuple1 Fixed
*/
ZYDIS_TUPLETYPE_T1F,
/**
* @brief Tuple1 4x32
*/
ZYDIS_TUPLETYPE_T1_4X,
/**
* @brief Gather / Scatter
*/
ZYDIS_TUPLETYPE_GSCAT,
/**
* @brief Tuple2
*/
ZYDIS_TUPLETYPE_T2,
/**
* @brief Tuple4
*/
ZYDIS_TUPLETYPE_T4,
/**
* @brief Tuple8
*/
ZYDIS_TUPLETYPE_T8,
/**
* @brief Half Mem
*/
ZYDIS_TUPLETYPE_HVM,
/**
* @brief QuarterMem
*/
ZYDIS_TUPLETYPE_QVM,
/**
* @brief OctMem
*/
ZYDIS_TUPLETYPE_OVM,
/**
* @brief Mem128
*/
ZYDIS_TUPLETYPE_M128,
/**
* @brief MOVDDUP
*/
ZYDIS_TUPLETYPE_DUP
};
/* ---------------------------------------------------------------------------------------------- */
/** /**
* @brief Defines the @c ZydisMVEXFunctionality datatype. * @brief Defines the @c ZydisMVEXFunctionality datatype.
*/ */
@ -510,7 +585,7 @@ typedef struct ZydisInstructionDefinitionEVEX_
{ {
ZYDIS_INSTRUCTION_DEFINITION_BASE; ZYDIS_INSTRUCTION_DEFINITION_BASE;
ZydisInternalVectorLength vectorLength: 2; ZydisInternalVectorLength vectorLength: 2;
ZydisTupleType tupleType : 4; ZydisEVEXTupleType tupleType : 4;
ZydisInternalElementSize elementSize : 4; ZydisInternalElementSize elementSize : 4;
ZydisEVEXFunctionality functionality : 2; ZydisEVEXFunctionality functionality : 2;
ZydisMaskPolicy maskPolicy : 2; ZydisMaskPolicy maskPolicy : 2;

View File

@ -97,14 +97,28 @@ typedef struct ZydisDecoderContext_
uint8_t v_vvvv; uint8_t v_vvvv;
uint8_t mask; uint8_t mask;
} cache; } cache;
/**
* @brief Internal EVEX-specific information.
*/
struct struct
{ {
int dummy; /**
* @brief The EVEX tuple-type.
*/
ZydisEVEXTupleType tupleType;
/**
* @brief The EVEX element-size.
*/
uint8_t elementSize;
} evex; } evex;
/**
* @brief Internal MVEX-specific information.
*/
struct struct
{ {
/**
* @brief The MVEX functionality.
*/
ZydisMVEXFunctionality functionality; ZydisMVEXFunctionality functionality;
} mvex; } mvex;
} ZydisDecoderContext; } ZydisDecoderContext;
@ -992,13 +1006,13 @@ static void ZydisSetOperandSizeAndElementInfo(ZydisDecoderContext* context,
// Operand size depends on the tuple-type, the element-size and the number of // Operand size depends on the tuple-type, the element-size and the number of
// elements // elements
ZYDIS_ASSERT(info->avx.vectorLength); ZYDIS_ASSERT(info->avx.vectorLength);
ZYDIS_ASSERT(info->avx.elementSize); ZYDIS_ASSERT(context->evex.elementSize);
switch (info->avx.tupleType) switch (context->evex.tupleType)
{ {
case ZYDIS_TUPLETYPE_FV: case ZYDIS_TUPLETYPE_FV:
if (info->avx.broadcastMode) if (info->avx.broadcastMode)
{ {
operand->size = info->avx.elementSize; operand->size = context->evex.elementSize;
} else } else
{ {
operand->size = info->avx.vectorLength; operand->size = info->avx.vectorLength;
@ -1007,7 +1021,7 @@ static void ZydisSetOperandSizeAndElementInfo(ZydisDecoderContext* context,
case ZYDIS_TUPLETYPE_HV: case ZYDIS_TUPLETYPE_HV:
if (info->avx.broadcastMode) if (info->avx.broadcastMode)
{ {
operand->size = info->avx.elementSize; operand->size = context->evex.elementSize;
} else } else
{ {
operand->size = info->avx.vectorLength / 2; operand->size = info->avx.vectorLength / 2;
@ -2263,8 +2277,8 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
ZYDIS_UNREACHABLE; ZYDIS_UNREACHABLE;
} }
info->avx.tupleType = def->tupleType; context->evex.tupleType = def->tupleType;
if (info->avx.tupleType) if (def->tupleType)
{ {
ZYDIS_ASSERT(info->details.modrm.mod != 3); ZYDIS_ASSERT(info->details.modrm.mod != 3);
ZYDIS_ASSERT(def->elementSize); ZYDIS_ASSERT(def->elementSize);
@ -2273,23 +2287,23 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
switch (def->elementSize) switch (def->elementSize)
{ {
case ZYDIS_IELEMENT_SIZE_8: case ZYDIS_IELEMENT_SIZE_8:
info->avx.elementSize = 8; context->evex.elementSize = 8;
break; break;
case ZYDIS_IELEMENT_SIZE_16: case ZYDIS_IELEMENT_SIZE_16:
info->avx.elementSize = 16; context->evex.elementSize = 16;
break; break;
case ZYDIS_IELEMENT_SIZE_32: case ZYDIS_IELEMENT_SIZE_32:
info->avx.elementSize = 32; context->evex.elementSize = 32;
break; break;
case ZYDIS_IELEMENT_SIZE_64: case ZYDIS_IELEMENT_SIZE_64:
info->avx.elementSize = 64; context->evex.elementSize = 64;
break; break;
default: default:
ZYDIS_UNREACHABLE; ZYDIS_UNREACHABLE;
} }
// Compressed disp8 scale and broadcast-factor // Compressed disp8 scale and broadcast-factor
switch (info->avx.tupleType) switch (def->tupleType)
{ {
case ZYDIS_TUPLETYPE_FV: case ZYDIS_TUPLETYPE_FV:
switch (info->details.evex.b) switch (info->details.evex.b)
@ -2315,7 +2329,7 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
switch (context->cache.W) switch (context->cache.W)
{ {
case 0: case 0:
ZYDIS_ASSERT(info->avx.elementSize == 32); ZYDIS_ASSERT(context->evex.elementSize == 32);
info->avx.compressedDisp8Scale = 4; info->avx.compressedDisp8Scale = 4;
switch (info->avx.vectorLength) switch (info->avx.vectorLength)
{ {
@ -2333,7 +2347,7 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
} }
break; break;
case 1: case 1:
ZYDIS_ASSERT(info->avx.elementSize == 64); ZYDIS_ASSERT(context->evex.elementSize == 64);
info->avx.compressedDisp8Scale = 8; info->avx.compressedDisp8Scale = 8;
switch (info->avx.vectorLength) switch (info->avx.vectorLength)
{ {
@ -2359,7 +2373,7 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
} }
break; break;
case ZYDIS_TUPLETYPE_HV: case ZYDIS_TUPLETYPE_HV:
ZYDIS_ASSERT(info->avx.elementSize == 32); ZYDIS_ASSERT(context->evex.elementSize == 32);
switch (info->details.evex.b) switch (info->details.evex.b)
{ {
case 0: case 0:
@ -2419,19 +2433,19 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
switch (context->cache.W) switch (context->cache.W)
{ {
case 0: case 0:
ZYDIS_ASSERT(info->avx.elementSize == 32); ZYDIS_ASSERT(context->evex.elementSize == 32);
break; break;
case 1: case 1:
ZYDIS_ASSERT(info->avx.elementSize == 64); ZYDIS_ASSERT(context->evex.elementSize == 64);
break; break;
default: default:
ZYDIS_UNREACHABLE; ZYDIS_UNREACHABLE;
} }
case ZYDIS_TUPLETYPE_T1S: case ZYDIS_TUPLETYPE_T1S:
info->avx.compressedDisp8Scale = info->avx.elementSize / 8; info->avx.compressedDisp8Scale = context->evex.elementSize / 8;
break; break;
case ZYDIS_TUPLETYPE_T1F: case ZYDIS_TUPLETYPE_T1F:
switch (info->avx.elementSize) switch (context->evex.elementSize)
{ {
case 32: case 32:
info->avx.compressedDisp8Scale = 4; info->avx.compressedDisp8Scale = 4;
@ -2444,7 +2458,7 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
} }
break; break;
case ZYDIS_TUPLETYPE_T1_4X: case ZYDIS_TUPLETYPE_T1_4X:
ZYDIS_ASSERT(info->avx.elementSize == 32); ZYDIS_ASSERT(context->evex.elementSize == 32);
ZYDIS_ASSERT(context->cache.W == 0); ZYDIS_ASSERT(context->cache.W == 0);
info->avx.compressedDisp8Scale = 16; info->avx.compressedDisp8Scale = 16;
break; break;
@ -2452,11 +2466,11 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
switch (context->cache.W) switch (context->cache.W)
{ {
case 0: case 0:
ZYDIS_ASSERT(info->avx.elementSize == 32); ZYDIS_ASSERT(context->evex.elementSize == 32);
info->avx.compressedDisp8Scale = 8; info->avx.compressedDisp8Scale = 8;
break; break;
case 1: case 1:
ZYDIS_ASSERT(info->avx.elementSize == 64); ZYDIS_ASSERT(context->evex.elementSize == 64);
ZYDIS_ASSERT((info->avx.vectorLength == 256) || ZYDIS_ASSERT((info->avx.vectorLength == 256) ||
(info->avx.vectorLength == 512)); (info->avx.vectorLength == 512));
info->avx.compressedDisp8Scale = 16; info->avx.compressedDisp8Scale = 16;
@ -2469,13 +2483,13 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
switch (context->cache.W) switch (context->cache.W)
{ {
case 0: case 0:
ZYDIS_ASSERT(info->avx.elementSize == 32); ZYDIS_ASSERT(context->evex.elementSize == 32);
ZYDIS_ASSERT((info->avx.vectorLength == 256) || ZYDIS_ASSERT((info->avx.vectorLength == 256) ||
(info->avx.vectorLength == 512)); (info->avx.vectorLength == 512));
info->avx.compressedDisp8Scale = 16; info->avx.compressedDisp8Scale = 16;
break; break;
case 1: case 1:
ZYDIS_ASSERT(info->avx.elementSize == 64); ZYDIS_ASSERT(context->evex.elementSize == 64);
ZYDIS_ASSERT(info->avx.vectorLength == 512); ZYDIS_ASSERT(info->avx.vectorLength == 512);
info->avx.compressedDisp8Scale = 32; info->avx.compressedDisp8Scale = 32;
break; break;
@ -2486,7 +2500,7 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
case ZYDIS_TUPLETYPE_T8: case ZYDIS_TUPLETYPE_T8:
ZYDIS_ASSERT(!context->cache.W); ZYDIS_ASSERT(!context->cache.W);
ZYDIS_ASSERT(info->avx.vectorLength == 512); ZYDIS_ASSERT(info->avx.vectorLength == 512);
ZYDIS_ASSERT(info->avx.elementSize == 32); ZYDIS_ASSERT(context->evex.elementSize == 32);
info->avx.compressedDisp8Scale = 32; info->avx.compressedDisp8Scale = 32;
break; break;
case ZYDIS_TUPLETYPE_HVM: case ZYDIS_TUPLETYPE_HVM:
@ -2598,7 +2612,6 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
(const ZydisInstructionDefinitionMVEX*)definition; (const ZydisInstructionDefinitionMVEX*)definition;
// Compressed disp8 scale // Compressed disp8 scale
info->avx.compressedDisp8Scale = 1;
switch (def->functionality) switch (def->functionality)
{ {
case ZYDIS_MVEX_FUNC_INVALID: case ZYDIS_MVEX_FUNC_INVALID: