Removed EVEX/MVEX compressed 8-bit displacement scale-factor from the public interface (for now)

This commit is contained in:
flobernd 2017-07-04 16:26:03 +02:00
parent 447e89820a
commit af0c6c8cac
2 changed files with 45 additions and 45 deletions

View File

@ -947,10 +947,6 @@ typedef struct ZydisDecodedInstruction_
* @brief The AVX vector-length. * @brief The AVX vector-length.
*/ */
ZydisVectorLength vectorLength; ZydisVectorLength vectorLength;
/**
* @brief The scale-factor for compressed 8-bit displacement values.
*/
uint8_t compressedDisp8Scale;
/** /**
* @brief The AVX mask-mode. * @brief The AVX mask-mode.
*/ */

View File

@ -121,6 +121,10 @@ typedef struct ZydisDecoderContext_
*/ */
ZydisMVEXFunctionality functionality; ZydisMVEXFunctionality functionality;
} mvex; } mvex;
/**
* @brief The scale factor for EVEX/MVEX compressed 8-bit displacement values.
*/
uint8_t cd8scale;
} ZydisDecoderContext; } ZydisDecoderContext;
/* ---------------------------------------------------------------------------------------------- */ /* ---------------------------------------------------------------------------------------------- */
@ -1898,7 +1902,7 @@ static ZydisStatus ZydisDecodeOperands(ZydisDecoderContext* context,
(instruction->encoding == ZYDIS_INSTRUCTION_ENCODING_MVEX)) && (instruction->encoding == ZYDIS_INSTRUCTION_ENCODING_MVEX)) &&
(instruction->raw.disp.size == 8)) (instruction->raw.disp.size == 8))
{ {
instruction->operands[i].mem.disp.value *= instruction->avx.compressedDisp8Scale; instruction->operands[i].mem.disp.value *= context->cd8scale;
} }
goto FinalizeOperand; goto FinalizeOperand;
@ -2363,13 +2367,13 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
switch (instruction->avx.vectorLength) switch (instruction->avx.vectorLength)
{ {
case 128: case 128:
instruction->avx.compressedDisp8Scale = 16; context->cd8scale = 16;
break; break;
case 256: case 256:
instruction->avx.compressedDisp8Scale = 32; context->cd8scale = 32;
break; break;
case 512: case 512:
instruction->avx.compressedDisp8Scale = 64; context->cd8scale = 64;
break; break;
default: default:
ZYDIS_UNREACHABLE; ZYDIS_UNREACHABLE;
@ -2381,7 +2385,7 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
{ {
case 0: case 0:
ZYDIS_ASSERT(context->evex.elementSize == 32); ZYDIS_ASSERT(context->evex.elementSize == 32);
instruction->avx.compressedDisp8Scale = 4; context->cd8scale = 4;
switch (instruction->avx.vectorLength) switch (instruction->avx.vectorLength)
{ {
case 128: case 128:
@ -2399,7 +2403,7 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
break; break;
case 1: case 1:
ZYDIS_ASSERT(context->evex.elementSize == 64); ZYDIS_ASSERT(context->evex.elementSize == 64);
instruction->avx.compressedDisp8Scale = 8; context->cd8scale = 8;
switch (instruction->avx.vectorLength) switch (instruction->avx.vectorLength)
{ {
case 128: case 128:
@ -2431,20 +2435,20 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
switch (instruction->avx.vectorLength) switch (instruction->avx.vectorLength)
{ {
case 128: case 128:
instruction->avx.compressedDisp8Scale = 8; context->cd8scale = 8;
break; break;
case 256: case 256:
instruction->avx.compressedDisp8Scale = 16; context->cd8scale = 16;
break; break;
case 512: case 512:
instruction->avx.compressedDisp8Scale = 32; context->cd8scale = 32;
break; break;
default: default:
ZYDIS_UNREACHABLE; ZYDIS_UNREACHABLE;
} }
break; break;
case 1: case 1:
instruction->avx.compressedDisp8Scale = 4; context->cd8scale = 4;
switch (instruction->avx.vectorLength) switch (instruction->avx.vectorLength)
{ {
case 128: case 128:
@ -2468,13 +2472,13 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
switch (instruction->avx.vectorLength) switch (instruction->avx.vectorLength)
{ {
case 128: case 128:
instruction->avx.compressedDisp8Scale = 16; context->cd8scale = 16;
break; break;
case 256: case 256:
instruction->avx.compressedDisp8Scale = 32; context->cd8scale = 32;
break; break;
case 512: case 512:
instruction->avx.compressedDisp8Scale = 64; context->cd8scale = 64;
break; break;
default: default:
ZYDIS_UNREACHABLE; ZYDIS_UNREACHABLE;
@ -2493,16 +2497,16 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
ZYDIS_UNREACHABLE; ZYDIS_UNREACHABLE;
} }
case ZYDIS_TUPLETYPE_T1S: case ZYDIS_TUPLETYPE_T1S:
instruction->avx.compressedDisp8Scale = context->evex.elementSize / 8; context->cd8scale = context->evex.elementSize / 8;
break; break;
case ZYDIS_TUPLETYPE_T1F: case ZYDIS_TUPLETYPE_T1F:
switch (context->evex.elementSize) switch (context->evex.elementSize)
{ {
case 32: case 32:
instruction->avx.compressedDisp8Scale = 4; context->cd8scale = 4;
break; break;
case 64: case 64:
instruction->avx.compressedDisp8Scale = 8; context->cd8scale = 8;
break; break;
default: default:
ZYDIS_UNREACHABLE; ZYDIS_UNREACHABLE;
@ -2511,20 +2515,20 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
case ZYDIS_TUPLETYPE_T1_4X: case ZYDIS_TUPLETYPE_T1_4X:
ZYDIS_ASSERT(context->evex.elementSize == 32); ZYDIS_ASSERT(context->evex.elementSize == 32);
ZYDIS_ASSERT(context->cache.W == 0); ZYDIS_ASSERT(context->cache.W == 0);
instruction->avx.compressedDisp8Scale = 16; context->cd8scale = 16;
break; break;
case ZYDIS_TUPLETYPE_T2: case ZYDIS_TUPLETYPE_T2:
switch (context->cache.W) switch (context->cache.W)
{ {
case 0: case 0:
ZYDIS_ASSERT(context->evex.elementSize == 32); ZYDIS_ASSERT(context->evex.elementSize == 32);
instruction->avx.compressedDisp8Scale = 8; context->cd8scale = 8;
break; break;
case 1: case 1:
ZYDIS_ASSERT(context->evex.elementSize == 64); ZYDIS_ASSERT(context->evex.elementSize == 64);
ZYDIS_ASSERT((instruction->avx.vectorLength == 256) || ZYDIS_ASSERT((instruction->avx.vectorLength == 256) ||
(instruction->avx.vectorLength == 512)); (instruction->avx.vectorLength == 512));
instruction->avx.compressedDisp8Scale = 16; context->cd8scale = 16;
break; break;
default: default:
ZYDIS_UNREACHABLE; ZYDIS_UNREACHABLE;
@ -2537,12 +2541,12 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
ZYDIS_ASSERT(context->evex.elementSize == 32); ZYDIS_ASSERT(context->evex.elementSize == 32);
ZYDIS_ASSERT((instruction->avx.vectorLength == 256) || ZYDIS_ASSERT((instruction->avx.vectorLength == 256) ||
(instruction->avx.vectorLength == 512)); (instruction->avx.vectorLength == 512));
instruction->avx.compressedDisp8Scale = 16; context->cd8scale = 16;
break; break;
case 1: case 1:
ZYDIS_ASSERT(context->evex.elementSize == 64); ZYDIS_ASSERT(context->evex.elementSize == 64);
ZYDIS_ASSERT(instruction->avx.vectorLength == 512); ZYDIS_ASSERT(instruction->avx.vectorLength == 512);
instruction->avx.compressedDisp8Scale = 32; context->cd8scale = 32;
break; break;
default: default:
ZYDIS_UNREACHABLE; ZYDIS_UNREACHABLE;
@ -2552,19 +2556,19 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
ZYDIS_ASSERT(!context->cache.W); ZYDIS_ASSERT(!context->cache.W);
ZYDIS_ASSERT(instruction->avx.vectorLength == 512); ZYDIS_ASSERT(instruction->avx.vectorLength == 512);
ZYDIS_ASSERT(context->evex.elementSize == 32); ZYDIS_ASSERT(context->evex.elementSize == 32);
instruction->avx.compressedDisp8Scale = 32; context->cd8scale = 32;
break; break;
case ZYDIS_TUPLETYPE_HVM: case ZYDIS_TUPLETYPE_HVM:
switch (instruction->avx.vectorLength) switch (instruction->avx.vectorLength)
{ {
case 128: case 128:
instruction->avx.compressedDisp8Scale = 8; context->cd8scale = 8;
break; break;
case 256: case 256:
instruction->avx.compressedDisp8Scale = 16; context->cd8scale = 16;
break; break;
case 512: case 512:
instruction->avx.compressedDisp8Scale = 32; context->cd8scale = 32;
break; break;
default: default:
ZYDIS_UNREACHABLE; ZYDIS_UNREACHABLE;
@ -2574,13 +2578,13 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
switch (instruction->avx.vectorLength) switch (instruction->avx.vectorLength)
{ {
case 128: case 128:
instruction->avx.compressedDisp8Scale = 4; context->cd8scale = 4;
break; break;
case 256: case 256:
instruction->avx.compressedDisp8Scale = 8; context->cd8scale = 8;
break; break;
case 512: case 512:
instruction->avx.compressedDisp8Scale = 16; context->cd8scale = 16;
break; break;
default: default:
ZYDIS_UNREACHABLE; ZYDIS_UNREACHABLE;
@ -2590,32 +2594,32 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
switch (instruction->avx.vectorLength) switch (instruction->avx.vectorLength)
{ {
case 128: case 128:
instruction->avx.compressedDisp8Scale = 2; context->cd8scale = 2;
break; break;
case 256: case 256:
instruction->avx.compressedDisp8Scale = 4; context->cd8scale = 4;
break; break;
case 512: case 512:
instruction->avx.compressedDisp8Scale = 8; context->cd8scale = 8;
break; break;
default: default:
ZYDIS_UNREACHABLE; ZYDIS_UNREACHABLE;
} }
break; break;
case ZYDIS_TUPLETYPE_M128: case ZYDIS_TUPLETYPE_M128:
instruction->avx.compressedDisp8Scale = 16; context->cd8scale = 16;
break; break;
case ZYDIS_TUPLETYPE_DUP: case ZYDIS_TUPLETYPE_DUP:
switch (instruction->avx.vectorLength) switch (instruction->avx.vectorLength)
{ {
case 128: case 128:
instruction->avx.compressedDisp8Scale = 8; context->cd8scale = 8;
break; break;
case 256: case 256:
instruction->avx.compressedDisp8Scale = 32; context->cd8scale = 32;
break; break;
case 512: case 512:
instruction->avx.compressedDisp8Scale = 64; context->cd8scale = 64;
break; break;
default: default:
ZYDIS_UNREACHABLE; ZYDIS_UNREACHABLE;
@ -2754,7 +2758,7 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
case ZYDIS_MVEX_FUNC_I_32: case ZYDIS_MVEX_FUNC_I_32:
case ZYDIS_MVEX_FUNC_F_64: case ZYDIS_MVEX_FUNC_F_64:
case ZYDIS_MVEX_FUNC_I_64: case ZYDIS_MVEX_FUNC_I_64:
instruction->avx.compressedDisp8Scale = 64; context->cd8scale = 64;
break; break;
case ZYDIS_MVEX_FUNC_SF_32: case ZYDIS_MVEX_FUNC_SF_32:
case ZYDIS_MVEX_FUNC_SF_32_BCST: case ZYDIS_MVEX_FUNC_SF_32_BCST:
@ -2768,7 +2772,7 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
{ 16, 0, 0, 8, 4, 4, 8, 8 } { 16, 0, 0, 8, 4, 4, 8, 8 }
}; };
ZYDIS_ASSERT(instruction->raw.mvex.SSS < ZYDIS_ARRAY_SIZE(lookup[index])); ZYDIS_ASSERT(instruction->raw.mvex.SSS < ZYDIS_ARRAY_SIZE(lookup[index]));
instruction->avx.compressedDisp8Scale = lookup[index][instruction->raw.mvex.SSS]; context->cd8scale = lookup[index][instruction->raw.mvex.SSS];
break; break;
} }
case ZYDIS_MVEX_FUNC_SI_32: case ZYDIS_MVEX_FUNC_SI_32:
@ -2783,7 +2787,7 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
{ 16, 0, 0, 0, 4, 4, 8, 8 } { 16, 0, 0, 0, 4, 4, 8, 8 }
}; };
ZYDIS_ASSERT(instruction->raw.mvex.SSS < ZYDIS_ARRAY_SIZE(lookup[index])); ZYDIS_ASSERT(instruction->raw.mvex.SSS < ZYDIS_ARRAY_SIZE(lookup[index]));
instruction->avx.compressedDisp8Scale = lookup[index][instruction->raw.mvex.SSS]; context->cd8scale = lookup[index][instruction->raw.mvex.SSS];
break; break;
} }
case ZYDIS_MVEX_FUNC_SF_64: case ZYDIS_MVEX_FUNC_SF_64:
@ -2798,7 +2802,7 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
{ 32, 0, 0 } { 32, 0, 0 }
}; };
ZYDIS_ASSERT(instruction->raw.mvex.SSS < ZYDIS_ARRAY_SIZE(lookup[index])); ZYDIS_ASSERT(instruction->raw.mvex.SSS < ZYDIS_ARRAY_SIZE(lookup[index]));
instruction->avx.compressedDisp8Scale = lookup[index][instruction->raw.mvex.SSS]; context->cd8scale = lookup[index][instruction->raw.mvex.SSS];
break; break;
} }
case ZYDIS_MVEX_FUNC_DF_32: case ZYDIS_MVEX_FUNC_DF_32:
@ -2810,7 +2814,7 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
{ 4, 0, 0, 2, 1, 1, 2, 2 } { 4, 0, 0, 2, 1, 1, 2, 2 }
}; };
ZYDIS_ASSERT(instruction->raw.mvex.SSS < ZYDIS_ARRAY_SIZE(lookup[index])); ZYDIS_ASSERT(instruction->raw.mvex.SSS < ZYDIS_ARRAY_SIZE(lookup[index]));
instruction->avx.compressedDisp8Scale = lookup[index][instruction->raw.mvex.SSS]; context->cd8scale = lookup[index][instruction->raw.mvex.SSS];
break; break;
} }
case ZYDIS_MVEX_FUNC_DF_64: case ZYDIS_MVEX_FUNC_DF_64:
@ -2822,7 +2826,7 @@ static void ZydisSetAVXInformation(ZydisDecoderContext* context,
{ 8 } { 8 }
}; };
ZYDIS_ASSERT(instruction->raw.mvex.SSS < ZYDIS_ARRAY_SIZE(lookup[index])); ZYDIS_ASSERT(instruction->raw.mvex.SSS < ZYDIS_ARRAY_SIZE(lookup[index]));
instruction->avx.compressedDisp8Scale = lookup[index][instruction->raw.mvex.SSS]; context->cd8scale = lookup[index][instruction->raw.mvex.SSS];
break; break;
} }
default: default: