mirror of https://github.com/x64dbg/zydis
Minor bugfixes
This commit is contained in:
parent
8289bb9fc4
commit
626d0bc238
|
@ -128,6 +128,14 @@ enum ZydisFormatterProperties
|
||||||
*/
|
*/
|
||||||
ZYDIS_FORMATTER_PROP_IMM_FORMAT,
|
ZYDIS_FORMATTER_PROP_IMM_FORMAT,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Controls the letter-case of hexadecimal values.
|
||||||
|
*
|
||||||
|
* Pass `ZYDIS_TRUE` as value to format in uppercase and `ZYDIS_FALSE` to format in lowercase.
|
||||||
|
*
|
||||||
|
* The default value is `ZYDIS_TRUE`.
|
||||||
|
*/
|
||||||
|
ZYDIS_FORMATTER_PROP_HEX_UPPERCASE,
|
||||||
/**
|
/**
|
||||||
* @brief Sets the prefix for hexadecimal values.
|
* @brief Sets the prefix for hexadecimal values.
|
||||||
*
|
*
|
||||||
|
@ -530,6 +538,7 @@ struct ZydisFormatter_
|
||||||
uint8_t addressFormat;
|
uint8_t addressFormat;
|
||||||
uint8_t displacementFormat;
|
uint8_t displacementFormat;
|
||||||
uint8_t immediateFormat;
|
uint8_t immediateFormat;
|
||||||
|
ZydisBool hexUppercase;
|
||||||
char* hexPrefix;
|
char* hexPrefix;
|
||||||
char* hexSuffix;
|
char* hexSuffix;
|
||||||
uint8_t hexPaddingAddress;
|
uint8_t hexPaddingAddress;
|
||||||
|
|
|
@ -222,11 +222,11 @@ static ZydisStatus ZydisFormatterFormatOperandPtrIntel(const ZydisFormatter* for
|
||||||
}
|
}
|
||||||
|
|
||||||
char* bufEnd = *buffer + bufferLen;
|
char* bufEnd = *buffer + bufferLen;
|
||||||
ZYDIS_CHECK(ZydisPrintHexU(buffer, bufEnd - *buffer, operand->ptr.segment, 4, ZYDIS_TRUE,
|
ZYDIS_CHECK(ZydisPrintHexU(buffer, bufEnd - *buffer, operand->ptr.segment, 4,
|
||||||
formatter->hexPrefix, formatter->hexSuffix));
|
formatter->hexUppercase, formatter->hexPrefix, formatter->hexSuffix));
|
||||||
ZYDIS_CHECK(ZydisPrintStr(buffer, bufEnd - *buffer, ":", ZYDIS_LETTER_CASE_DEFAULT));
|
ZYDIS_CHECK(ZydisPrintStr(buffer, bufEnd - *buffer, ":", ZYDIS_LETTER_CASE_DEFAULT));
|
||||||
return ZydisPrintHexU(buffer, bufEnd - *buffer, operand->ptr.offset, 8, ZYDIS_TRUE,
|
return ZydisPrintHexU(buffer, bufEnd - *buffer, operand->ptr.offset, 8,
|
||||||
formatter->hexPrefix, formatter->hexSuffix);
|
formatter->hexUppercase, formatter->hexPrefix, formatter->hexSuffix);
|
||||||
}
|
}
|
||||||
|
|
||||||
static ZydisStatus ZydisFormatterFormatOperandImmIntel(const ZydisFormatter* formatter,
|
static ZydisStatus ZydisFormatterFormatOperandImmIntel(const ZydisFormatter* formatter,
|
||||||
|
@ -263,11 +263,11 @@ static ZydisStatus ZydisFormatterFormatOperandImmIntel(const ZydisFormatter* for
|
||||||
if (printSignedHEX)
|
if (printSignedHEX)
|
||||||
{
|
{
|
||||||
return ZydisPrintHexS(buffer, bufferLen, (int32_t)operand->imm.value.s,
|
return ZydisPrintHexS(buffer, bufferLen, (int32_t)operand->imm.value.s,
|
||||||
formatter->hexPaddingAddress, ZYDIS_TRUE, formatter->hexPrefix,
|
formatter->hexPaddingAddress, formatter->hexUppercase, formatter->hexPrefix,
|
||||||
formatter->hexSuffix);
|
formatter->hexSuffix);
|
||||||
}
|
}
|
||||||
return ZydisPrintHexU(buffer, bufferLen, operand->imm.value.u,
|
return ZydisPrintHexU(buffer, bufferLen, operand->imm.value.u,
|
||||||
formatter->hexPaddingAddress, ZYDIS_TRUE, formatter->hexPrefix,
|
formatter->hexPaddingAddress, formatter->hexUppercase, formatter->hexPrefix,
|
||||||
formatter->hexSuffix);
|
formatter->hexSuffix);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -292,14 +292,14 @@ static ZydisStatus ZydisFormatterPrintAddressIntel(const ZydisFormatter* formatt
|
||||||
switch (instruction->stackWidth)
|
switch (instruction->stackWidth)
|
||||||
{
|
{
|
||||||
case 16:
|
case 16:
|
||||||
return ZydisPrintHexU(buffer, bufferLen, (uint16_t)address, 4, ZYDIS_TRUE,
|
return ZydisPrintHexU(buffer, bufferLen, (uint16_t)address, 4,
|
||||||
formatter->hexPrefix, formatter->hexSuffix);
|
formatter->hexUppercase, formatter->hexPrefix, formatter->hexSuffix);
|
||||||
case 32:
|
case 32:
|
||||||
return ZydisPrintHexU(buffer, bufferLen, (uint32_t)address, 8, ZYDIS_TRUE,
|
return ZydisPrintHexU(buffer, bufferLen, (uint32_t)address, 8,
|
||||||
formatter->hexPrefix, formatter->hexSuffix);
|
formatter->hexUppercase, formatter->hexPrefix, formatter->hexSuffix);
|
||||||
case 64:
|
case 64:
|
||||||
return ZydisPrintHexU(buffer, bufferLen, address, 16, ZYDIS_TRUE,
|
return ZydisPrintHexU(buffer, bufferLen, address, 16,
|
||||||
formatter->hexPrefix, formatter->hexSuffix);
|
formatter->hexUppercase, formatter->hexPrefix, formatter->hexSuffix);
|
||||||
default:
|
default:
|
||||||
return ZYDIS_STATUS_INVALID_PARAMETER;
|
return ZYDIS_STATUS_INVALID_PARAMETER;
|
||||||
}
|
}
|
||||||
|
@ -327,7 +327,7 @@ static ZydisStatus ZydisFormatterPrintDisplacementIntel(const ZydisFormatter* fo
|
||||||
(operand->mem.index != ZYDIS_REGISTER_NONE)))
|
(operand->mem.index != ZYDIS_REGISTER_NONE)))
|
||||||
{
|
{
|
||||||
return ZydisPrintHexS(buffer, bufferLen, operand->mem.disp.value,
|
return ZydisPrintHexS(buffer, bufferLen, operand->mem.disp.value,
|
||||||
formatter->hexPaddingDisplacement, ZYDIS_TRUE, formatter->hexPrefix,
|
formatter->hexPaddingDisplacement, formatter->hexUppercase, formatter->hexPrefix,
|
||||||
formatter->hexSuffix);
|
formatter->hexSuffix);
|
||||||
}
|
}
|
||||||
char* bufEnd = *buffer + bufferLen;
|
char* bufEnd = *buffer + bufferLen;
|
||||||
|
@ -337,7 +337,7 @@ static ZydisStatus ZydisFormatterPrintDisplacementIntel(const ZydisFormatter* fo
|
||||||
ZYDIS_CHECK(ZydisPrintStr(buffer, bufferLen, "+", ZYDIS_LETTER_CASE_DEFAULT));
|
ZYDIS_CHECK(ZydisPrintStr(buffer, bufferLen, "+", ZYDIS_LETTER_CASE_DEFAULT));
|
||||||
}
|
}
|
||||||
return ZydisPrintHexU(buffer, bufEnd - *buffer, (uint64_t)operand->mem.disp.value,
|
return ZydisPrintHexU(buffer, bufEnd - *buffer, (uint64_t)operand->mem.disp.value,
|
||||||
formatter->hexPaddingDisplacement, ZYDIS_TRUE, formatter->hexPrefix,
|
formatter->hexPaddingDisplacement, formatter->hexUppercase, formatter->hexPrefix,
|
||||||
formatter->hexSuffix);
|
formatter->hexSuffix);
|
||||||
}
|
}
|
||||||
return ZYDIS_STATUS_SUCCESS;
|
return ZYDIS_STATUS_SUCCESS;
|
||||||
|
@ -366,19 +366,19 @@ static ZydisStatus ZydisFormatterPrintImmediateIntel(const ZydisFormatter* forma
|
||||||
{
|
{
|
||||||
case 8:
|
case 8:
|
||||||
return ZydisPrintHexS(buffer, bufferLen, (int8_t)operand->imm.value.s,
|
return ZydisPrintHexS(buffer, bufferLen, (int8_t)operand->imm.value.s,
|
||||||
formatter->hexPaddingImmediate, ZYDIS_TRUE, formatter->hexPrefix,
|
formatter->hexPaddingImmediate, formatter->hexUppercase, formatter->hexPrefix,
|
||||||
formatter->hexSuffix);
|
formatter->hexSuffix);
|
||||||
case 16:
|
case 16:
|
||||||
return ZydisPrintHexS(buffer, bufferLen, (int16_t)operand->imm.value.s,
|
return ZydisPrintHexS(buffer, bufferLen, (int16_t)operand->imm.value.s,
|
||||||
formatter->hexPaddingImmediate, ZYDIS_TRUE, formatter->hexPrefix,
|
formatter->hexPaddingImmediate, formatter->hexUppercase, formatter->hexPrefix,
|
||||||
formatter->hexSuffix);
|
formatter->hexSuffix);
|
||||||
case 32:
|
case 32:
|
||||||
return ZydisPrintHexS(buffer, bufferLen, (int32_t)operand->imm.value.s,
|
return ZydisPrintHexS(buffer, bufferLen, (int32_t)operand->imm.value.s,
|
||||||
formatter->hexPaddingImmediate, ZYDIS_TRUE, formatter->hexPrefix,
|
formatter->hexPaddingImmediate, formatter->hexUppercase, formatter->hexPrefix,
|
||||||
formatter->hexSuffix);
|
formatter->hexSuffix);
|
||||||
case 64:
|
case 64:
|
||||||
return ZydisPrintHexS(buffer, bufferLen, operand->imm.value.s,
|
return ZydisPrintHexS(buffer, bufferLen, operand->imm.value.s,
|
||||||
formatter->hexPaddingImmediate, ZYDIS_TRUE, formatter->hexPrefix,
|
formatter->hexPaddingImmediate, formatter->hexUppercase, formatter->hexPrefix,
|
||||||
formatter->hexSuffix);
|
formatter->hexSuffix);
|
||||||
default:
|
default:
|
||||||
return ZYDIS_STATUS_INVALID_PARAMETER;
|
return ZYDIS_STATUS_INVALID_PARAMETER;
|
||||||
|
@ -388,19 +388,19 @@ static ZydisStatus ZydisFormatterPrintImmediateIntel(const ZydisFormatter* forma
|
||||||
{
|
{
|
||||||
case 8:
|
case 8:
|
||||||
return ZydisPrintHexU(buffer, bufferLen, (uint8_t)operand->imm.value.u,
|
return ZydisPrintHexU(buffer, bufferLen, (uint8_t)operand->imm.value.u,
|
||||||
formatter->hexPaddingImmediate, ZYDIS_TRUE, formatter->hexPrefix,
|
formatter->hexPaddingImmediate, formatter->hexUppercase, formatter->hexPrefix,
|
||||||
formatter->hexSuffix);
|
formatter->hexSuffix);
|
||||||
case 16:
|
case 16:
|
||||||
return ZydisPrintHexU(buffer, bufferLen, (uint16_t)operand->imm.value.u,
|
return ZydisPrintHexU(buffer, bufferLen, (uint16_t)operand->imm.value.u,
|
||||||
formatter->hexPaddingImmediate, ZYDIS_TRUE, formatter->hexPrefix,
|
formatter->hexPaddingImmediate, formatter->hexUppercase, formatter->hexPrefix,
|
||||||
formatter->hexSuffix);
|
formatter->hexSuffix);
|
||||||
case 32:
|
case 32:
|
||||||
return ZydisPrintHexU(buffer, bufferLen, (uint32_t)operand->imm.value.u,
|
return ZydisPrintHexU(buffer, bufferLen, (uint32_t)operand->imm.value.u,
|
||||||
formatter->hexPaddingImmediate, ZYDIS_TRUE, formatter->hexPrefix,
|
formatter->hexPaddingImmediate, formatter->hexUppercase, formatter->hexPrefix,
|
||||||
formatter->hexSuffix);
|
formatter->hexSuffix);
|
||||||
case 64:
|
case 64:
|
||||||
return ZydisPrintHexU(buffer, bufferLen, operand->imm.value.u,
|
return ZydisPrintHexU(buffer, bufferLen, operand->imm.value.u,
|
||||||
formatter->hexPaddingImmediate, ZYDIS_TRUE, formatter->hexPrefix,
|
formatter->hexPaddingImmediate, formatter->hexUppercase, formatter->hexPrefix,
|
||||||
formatter->hexSuffix);
|
formatter->hexSuffix);
|
||||||
default:
|
default:
|
||||||
return ZYDIS_STATUS_INVALID_PARAMETER;
|
return ZYDIS_STATUS_INVALID_PARAMETER;
|
||||||
|
@ -916,6 +916,7 @@ ZydisStatus ZydisFormatterInit(ZydisFormatter* formatter, ZydisFormatterStyle st
|
||||||
formatter->addressFormat = ZYDIS_ADDR_FORMAT_ABSOLUTE;
|
formatter->addressFormat = ZYDIS_ADDR_FORMAT_ABSOLUTE;
|
||||||
formatter->displacementFormat = ZYDIS_DISP_FORMAT_HEX_SIGNED;
|
formatter->displacementFormat = ZYDIS_DISP_FORMAT_HEX_SIGNED;
|
||||||
formatter->immediateFormat = ZYDIS_IMM_FORMAT_HEX_UNSIGNED;
|
formatter->immediateFormat = ZYDIS_IMM_FORMAT_HEX_UNSIGNED;
|
||||||
|
formatter->hexUppercase = ZYDIS_TRUE;
|
||||||
formatter->hexPrefix = "0x";
|
formatter->hexPrefix = "0x";
|
||||||
formatter->hexSuffix = NULL;
|
formatter->hexSuffix = NULL;
|
||||||
formatter->hexPaddingAddress = 2;
|
formatter->hexPaddingAddress = 2;
|
||||||
|
@ -957,43 +958,13 @@ ZydisStatus ZydisFormatterSetProperty(ZydisFormatter* formatter,
|
||||||
switch (property)
|
switch (property)
|
||||||
{
|
{
|
||||||
case ZYDIS_FORMATTER_PROP_UPPERCASE:
|
case ZYDIS_FORMATTER_PROP_UPPERCASE:
|
||||||
switch (value)
|
formatter->letterCase = (value) ? ZYDIS_LETTER_CASE_UPPER : ZYDIS_LETTER_CASE_DEFAULT;
|
||||||
{
|
|
||||||
case ZYDIS_FALSE:
|
|
||||||
formatter->letterCase = ZYDIS_LETTER_CASE_DEFAULT;
|
|
||||||
break;
|
|
||||||
case ZYDIS_TRUE:
|
|
||||||
formatter->letterCase = ZYDIS_LETTER_CASE_UPPER;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
return ZYDIS_STATUS_INVALID_PARAMETER;
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case ZYDIS_FORMATTER_PROP_FORCE_SEGMENTS:
|
case ZYDIS_FORMATTER_PROP_FORCE_SEGMENTS:
|
||||||
switch (value)
|
formatter->forceSegments = (value) ? ZYDIS_TRUE : ZYDIS_FALSE;
|
||||||
{
|
|
||||||
case ZYDIS_FALSE:
|
|
||||||
formatter->forceSegments = ZYDIS_LETTER_CASE_DEFAULT;
|
|
||||||
break;
|
|
||||||
case ZYDIS_TRUE:
|
|
||||||
formatter->forceSegments = ZYDIS_LETTER_CASE_UPPER;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
return ZYDIS_STATUS_INVALID_PARAMETER;
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case ZYDIS_FORMATTER_PROP_FORCE_OPERANDSIZE:
|
case ZYDIS_FORMATTER_PROP_FORCE_OPERANDSIZE:
|
||||||
switch (value)
|
formatter->forceOperandSize = (value) ? ZYDIS_TRUE : ZYDIS_FALSE;
|
||||||
{
|
|
||||||
case ZYDIS_FALSE:
|
|
||||||
formatter->forceOperandSize = ZYDIS_LETTER_CASE_DEFAULT;
|
|
||||||
break;
|
|
||||||
case ZYDIS_TRUE:
|
|
||||||
formatter->forceOperandSize = ZYDIS_LETTER_CASE_UPPER;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
return ZYDIS_STATUS_INVALID_PARAMETER;
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case ZYDIS_FORMATTER_PROP_ADDR_FORMAT:
|
case ZYDIS_FORMATTER_PROP_ADDR_FORMAT:
|
||||||
if (value > ZYDIS_ADDR_FORMAT_MAX_VALUE)
|
if (value > ZYDIS_ADDR_FORMAT_MAX_VALUE)
|
||||||
|
@ -1016,6 +987,9 @@ ZydisStatus ZydisFormatterSetProperty(ZydisFormatter* formatter,
|
||||||
}
|
}
|
||||||
formatter->immediateFormat = (uint8_t)value;
|
formatter->immediateFormat = (uint8_t)value;
|
||||||
break;
|
break;
|
||||||
|
case ZYDIS_FORMATTER_PROP_HEX_UPPERCASE:
|
||||||
|
formatter->hexUppercase = (value) ? ZYDIS_TRUE : ZYDIS_FALSE;
|
||||||
|
break;
|
||||||
case ZYDIS_FORMATTER_PROP_HEX_PREFIX:
|
case ZYDIS_FORMATTER_PROP_HEX_PREFIX:
|
||||||
formatter->hexPrefix = (char*)value;
|
formatter->hexPrefix = (char*)value;
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -84,14 +84,17 @@ ZydisStatus ZydisCalcAbsoluteAddress(const ZydisDecodedInstruction* instruction,
|
||||||
*address = (uint64_t)((int64_t)instruction->instrPointer + operand->imm.value.s);
|
*address = (uint64_t)((int64_t)instruction->instrPointer + operand->imm.value.s);
|
||||||
switch (instruction->machineMode)
|
switch (instruction->machineMode)
|
||||||
{
|
{
|
||||||
case 16:
|
case ZYDIS_MACHINE_MODE_LONG_COMPAT_16:
|
||||||
case 32:
|
case ZYDIS_MACHINE_MODE_LEGACY_16:
|
||||||
|
case ZYDIS_MACHINE_MODE_REAL_16:
|
||||||
|
case ZYDIS_MACHINE_MODE_LONG_COMPAT_32:
|
||||||
|
case ZYDIS_MACHINE_MODE_LEGACY_32:
|
||||||
if (operand->size == 16)
|
if (operand->size == 16)
|
||||||
{
|
{
|
||||||
*address &= 0xFFFF;
|
*address &= 0xFFFF;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 64:
|
case ZYDIS_MACHINE_MODE_LONG_64:
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
return ZYDIS_STATUS_INVALID_PARAMETER;
|
return ZYDIS_STATUS_INVALID_PARAMETER;
|
||||||
|
|
|
@ -583,6 +583,10 @@ int main(int argc, char** argv)
|
||||||
}
|
}
|
||||||
|
|
||||||
ZydisDecoder decoder;
|
ZydisDecoder decoder;
|
||||||
|
if (!strcmp(argv[1], "-real"))
|
||||||
|
{
|
||||||
|
ZydisDecoderInit(&decoder, ZYDIS_MACHINE_MODE_REAL_16, ZYDIS_ADDRESS_WIDTH_16);
|
||||||
|
} else
|
||||||
if (!strcmp(argv[1], "-16"))
|
if (!strcmp(argv[1], "-16"))
|
||||||
{
|
{
|
||||||
ZydisDecoderInit(&decoder, ZYDIS_MACHINE_MODE_LONG_COMPAT_16, ZYDIS_ADDRESS_WIDTH_16);
|
ZydisDecoderInit(&decoder, ZYDIS_MACHINE_MODE_LONG_COMPAT_16, ZYDIS_ADDRESS_WIDTH_16);
|
||||||
|
@ -596,7 +600,7 @@ int main(int argc, char** argv)
|
||||||
ZydisDecoderInit(&decoder, ZYDIS_MACHINE_MODE_LONG_64, ZYDIS_ADDRESS_WIDTH_64);
|
ZydisDecoderInit(&decoder, ZYDIS_MACHINE_MODE_LONG_64, ZYDIS_ADDRESS_WIDTH_64);
|
||||||
} else
|
} else
|
||||||
{
|
{
|
||||||
fputs("Usage: ZydisInfo -[16|32|64] [hexbytes]\n", stderr);
|
fputs("Usage: ZydisInfo -[real|16|32|64] [hexbytes]\n", stderr);
|
||||||
return ZYDIS_STATUS_INVALID_PARAMETER;
|
return ZYDIS_STATUS_INVALID_PARAMETER;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue