mirror of https://github.com/x64dbg/zydis
parent
0376376b83
commit
3b47ed4a9a
|
@ -524,7 +524,7 @@ static ZydisStatus ZydisDecodeOperandImmediate(ZydisInstructionDecoder* decoder,
|
||||||
case 32:
|
case 32:
|
||||||
{
|
{
|
||||||
uint32_t data[4] = { 0, 0, 0, 0 };
|
uint32_t data[4] = { 0, 0, 0, 0 };
|
||||||
for (int i = sizeof(data) / sizeof(data[0]); i > 0; --i)
|
for (int i = ZYDIS_ARRAY_SIZE(data); i > 0; --i)
|
||||||
{
|
{
|
||||||
ZYDIS_CHECK(ZydisInputNext(decoder, info, (uint8_t*)&data[i - 1]));
|
ZYDIS_CHECK(ZydisInputNext(decoder, info, (uint8_t*)&data[i - 1]));
|
||||||
}
|
}
|
||||||
|
@ -1255,6 +1255,7 @@ static ZydisStatus ZydisDecodeOperand(ZydisInstructionDecoder* decoder, ZydisIns
|
||||||
case ZYDIS_SEM_OPERAND_TYPE_REL8:
|
case ZYDIS_SEM_OPERAND_TYPE_REL8:
|
||||||
info->attributes |= ZYDIS_ATTRIB_IS_RELATIVE;
|
info->attributes |= ZYDIS_ATTRIB_IS_RELATIVE;
|
||||||
operand->imm.isRelative = ZYDIS_TRUE;
|
operand->imm.isRelative = ZYDIS_TRUE;
|
||||||
|
// Intentional fallthrough.
|
||||||
case ZYDIS_SEM_OPERAND_TYPE_IMM8:
|
case ZYDIS_SEM_OPERAND_TYPE_IMM8:
|
||||||
operand->size = 8;
|
operand->size = 8;
|
||||||
operand->imm.isSigned = ZYDIS_TRUE;
|
operand->imm.isSigned = ZYDIS_TRUE;
|
||||||
|
@ -1266,6 +1267,7 @@ static ZydisStatus ZydisDecodeOperand(ZydisInstructionDecoder* decoder, ZydisIns
|
||||||
case ZYDIS_SEM_OPERAND_TYPE_REL16:
|
case ZYDIS_SEM_OPERAND_TYPE_REL16:
|
||||||
info->attributes |= ZYDIS_ATTRIB_IS_RELATIVE;
|
info->attributes |= ZYDIS_ATTRIB_IS_RELATIVE;
|
||||||
operand->imm.isRelative = ZYDIS_TRUE;
|
operand->imm.isRelative = ZYDIS_TRUE;
|
||||||
|
// Intentional fallthrough.
|
||||||
case ZYDIS_SEM_OPERAND_TYPE_IMM16:
|
case ZYDIS_SEM_OPERAND_TYPE_IMM16:
|
||||||
operand->size = 16;
|
operand->size = 16;
|
||||||
operand->imm.isSigned = ZYDIS_TRUE;
|
operand->imm.isSigned = ZYDIS_TRUE;
|
||||||
|
@ -1280,6 +1282,7 @@ static ZydisStatus ZydisDecodeOperand(ZydisInstructionDecoder* decoder, ZydisIns
|
||||||
case ZYDIS_SEM_OPERAND_TYPE_REL64:
|
case ZYDIS_SEM_OPERAND_TYPE_REL64:
|
||||||
info->attributes |= ZYDIS_ATTRIB_IS_RELATIVE;
|
info->attributes |= ZYDIS_ATTRIB_IS_RELATIVE;
|
||||||
operand->imm.isRelative = ZYDIS_TRUE;
|
operand->imm.isRelative = ZYDIS_TRUE;
|
||||||
|
// Intentional fallthrough.
|
||||||
case ZYDIS_SEM_OPERAND_TYPE_IMM64:
|
case ZYDIS_SEM_OPERAND_TYPE_IMM64:
|
||||||
operand->size = 64;
|
operand->size = 64;
|
||||||
operand->imm.isSigned = ZYDIS_TRUE;
|
operand->imm.isSigned = ZYDIS_TRUE;
|
||||||
|
@ -2383,6 +2386,16 @@ ZydisStatus ZydisDecoderDecodeInstructionEx(ZydisInstructionDecoder* decoder,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// For relative operands, apply instruction length offset.
|
||||||
|
for (size_t i = 0; i < info->operandCount; ++i)
|
||||||
|
{
|
||||||
|
if (info->operands[i].type == ZYDIS_OPERAND_TYPE_IMMEDIATE &&
|
||||||
|
info->operands[i].imm.isRelative)
|
||||||
|
{
|
||||||
|
info->operands[i].imm.value.sqword += info->length;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Replace XCHG rAX, rAX with NOP alias
|
// Replace XCHG rAX, rAX with NOP alias
|
||||||
if (info->mnemonic == ZYDIS_MNEMONIC_XCHG)
|
if (info->mnemonic == ZYDIS_MNEMONIC_XCHG)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue