|
|
@ -4,10 +4,23 @@ XED_ICLASS_ENUM ObfGetRandomJccClass()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
switch (rand() % 15)
|
|
|
|
switch (rand() % 15)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
case 0: return XED_ICLASS_JL;
|
|
|
|
default:
|
|
|
|
case 1: return XED_ICLASS_JLE;
|
|
|
|
return XED_ICLASS_JLE;
|
|
|
|
case 2: return XED_ICLASS_JNB;
|
|
|
|
|
|
|
|
case 3: return XED_ICLASS_JNBE;
|
|
|
|
|
|
|
|
case 4: return XED_ICLASS_JNL;
|
|
|
|
|
|
|
|
case 5: return XED_ICLASS_JNLE;
|
|
|
|
|
|
|
|
case 6: return XED_ICLASS_JNO;
|
|
|
|
|
|
|
|
case 7: return XED_ICLASS_JNP;
|
|
|
|
|
|
|
|
case 8: return XED_ICLASS_JNS;
|
|
|
|
|
|
|
|
case 9: return XED_ICLASS_JNZ;
|
|
|
|
|
|
|
|
case 10: return XED_ICLASS_JO;
|
|
|
|
|
|
|
|
case 11: return XED_ICLASS_JP;
|
|
|
|
|
|
|
|
case 12: return XED_ICLASS_JRCXZ;
|
|
|
|
|
|
|
|
case 13: return XED_ICLASS_JS;
|
|
|
|
|
|
|
|
case 14: return XED_ICLASS_JZ;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return XED_ICLASS_JLE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
PNATIVE_CODE_LINK ObfGenRandomJcc(ULONG LabelId, ULONG DisplacementWidth)
|
|
|
|
PNATIVE_CODE_LINK ObfGenRandomJcc(ULONG LabelId, ULONG DisplacementWidth)
|
|
|
@ -17,11 +30,10 @@ PNATIVE_CODE_LINK ObfGenRandomJcc(ULONG LabelId, ULONG DisplacementWidth)
|
|
|
|
MachineState.stack_addr_width = XED_ADDRESS_WIDTH_64b;
|
|
|
|
MachineState.stack_addr_width = XED_ADDRESS_WIDTH_64b;
|
|
|
|
XED_ENCODER_INSTRUCTION EncoderInstruction;
|
|
|
|
XED_ENCODER_INSTRUCTION EncoderInstruction;
|
|
|
|
XED_ENCODER_REQUEST EncoderRequest;
|
|
|
|
XED_ENCODER_REQUEST EncoderRequest;
|
|
|
|
ULONG DispWidth = ((rand() % 2) ? 16 : 32);
|
|
|
|
|
|
|
|
UCHAR EncodeBuffer[15];
|
|
|
|
UCHAR EncodeBuffer[15];
|
|
|
|
UINT ReturnedSize;
|
|
|
|
UINT ReturnedSize;
|
|
|
|
|
|
|
|
|
|
|
|
XedInst1(&EncoderInstruction, MachineState, ObfGetRandomJccClass(), DispWidth, XedRelBr(0, DispWidth));
|
|
|
|
XedInst1(&EncoderInstruction, MachineState, ObfGetRandomJccClass(), DisplacementWidth, XedRelBr(0, DisplacementWidth));
|
|
|
|
|
|
|
|
|
|
|
|
XedEncoderRequestZeroSetMode(&EncoderRequest, &MachineState);
|
|
|
|
XedEncoderRequestZeroSetMode(&EncoderRequest, &MachineState);
|
|
|
|
if (!XedConvertToEncoderRequest(&EncoderRequest, &EncoderInstruction))
|
|
|
|
if (!XedConvertToEncoderRequest(&EncoderRequest, &EncoderInstruction))
|
|
|
@ -37,16 +49,43 @@ PNATIVE_CODE_LINK ObfGenRandomJcc(ULONG LabelId, ULONG DisplacementWidth)
|
|
|
|
return NULL;
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
Link->Label = LabelId;
|
|
|
|
Link->Label = LabelId;
|
|
|
|
|
|
|
|
Link->Flags = (CODE_FLAG_IS_INST | CODE_FLAG_IS_REL_JMP);
|
|
|
|
|
|
|
|
|
|
|
|
return Link;
|
|
|
|
return Link;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
PNATIVE_CODE_LINK ObfGenJmpForOpaqueBranch(ULONG LabelId, ULONG DisplacementWidth)
|
|
|
|
PNATIVE_CODE_LINK ObfGenJmpToLabel(ULONG LabelId, ULONG DisplacementWidth)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
XED_STATE MachineState;
|
|
|
|
|
|
|
|
MachineState.mmode = XED_MACHINE_MODE_LONG_64;
|
|
|
|
|
|
|
|
MachineState.stack_addr_width = XED_ADDRESS_WIDTH_64b;
|
|
|
|
|
|
|
|
XED_ENCODER_INSTRUCTION EncoderInstruction;
|
|
|
|
|
|
|
|
XED_ENCODER_REQUEST EncoderRequest;
|
|
|
|
|
|
|
|
UCHAR EncodeBuffer[15];
|
|
|
|
|
|
|
|
UINT ReturnedSize;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
XedInst1(&EncoderInstruction, MachineState, XED_ICLASS_JMP, DisplacementWidth, XedRelBr(0, DisplacementWidth));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
XedEncoderRequestZeroSetMode(&EncoderRequest, &MachineState);
|
|
|
|
|
|
|
|
if (!XedConvertToEncoderRequest(&EncoderRequest, &EncoderInstruction))
|
|
|
|
return NULL;
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (XED_ERROR_NONE != XedEncode(&EncoderRequest, EncodeBuffer, 15, &ReturnedSize))
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
PNATIVE_CODE_LINK Link = new NATIVE_CODE_LINK(CODE_FLAG_IS_INST, EncodeBuffer, ReturnedSize);
|
|
|
|
|
|
|
|
if (XED_ERROR_NONE != XedDecode(&Link->XedInstruction, Link->RawData, Link->RawDataSize))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
delete Link;
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
Link->Label = LabelId;
|
|
|
|
|
|
|
|
Link->Flags = (CODE_FLAG_IS_INST | CODE_FLAG_IS_REL_JMP);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return Link;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
PNATIVE_CODE_BLOCK ObfGenerateOpaqueBranch(PNATIVE_CODE_LINK Start, PNATIVE_CODE_LINK End)
|
|
|
|
PNATIVE_CODE_BLOCK ObfGenOpaqueBranch(PNATIVE_CODE_LINK Start, PNATIVE_CODE_LINK End)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (!Start || !End || !Start->Block || Start->Block != End->Block)
|
|
|
|
if (!Start || !End || !Start->Block || Start->Block != End->Block)
|
|
|
|
return NULL;
|
|
|
|
return NULL;
|
|
|
@ -78,7 +117,7 @@ PNATIVE_CODE_BLOCK ObfGenerateOpaqueBranch(PNATIVE_CODE_LINK Start, PNATIVE_CODE
|
|
|
|
delete NotTaken;
|
|
|
|
delete NotTaken;
|
|
|
|
return NULL;
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
PNATIVE_CODE_LINK Jmp = ObfGenJmpForOpaqueBranch(JmpLabel);
|
|
|
|
PNATIVE_CODE_LINK Jmp = ObfGenJmpToLabel(JmpLabel);
|
|
|
|
if (!Jmp)
|
|
|
|
if (!Jmp)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
delete Jcc;
|
|
|
|
delete Jcc;
|
|
|
|