mirror of
https://github.com/bitdefender/bddisasm.git
synced 2024-11-27 01:48:10 +00:00
bdshemu: Fix edge case with unsupported instrs
Fixes https://github.com/bitdefender/bddisasm/issues/106
This commit is contained in:
parent
b67fd766a1
commit
7136b64c6c
@ -1793,13 +1793,6 @@ ShemuX86Emulate(
|
|||||||
nd_memzero(&dst, sizeof(dst));
|
nd_memzero(&dst, sizeof(dst));
|
||||||
nd_memzero(&src, sizeof(src));
|
nd_memzero(&src, sizeof(src));
|
||||||
|
|
||||||
// The stop flag has been set, this means we've reached a valid instruction, but that instruction cannot be
|
|
||||||
// emulated (for example, SYSCALL, INT, system instructions, etc).
|
|
||||||
if (stop)
|
|
||||||
{
|
|
||||||
return SHEMU_ABORT_CANT_EMULATE;
|
|
||||||
}
|
|
||||||
|
|
||||||
// If we already have a detection and we wish to stop on detections, do so now.
|
// If we already have a detection and we wish to stop on detections, do so now.
|
||||||
if ((0 != Context->Flags) && (0 != (Context->Options & SHEMU_OPT_STOP_ON_EXPLOIT)))
|
if ((0 != Context->Flags) && (0 != (Context->Options & SHEMU_OPT_STOP_ON_EXPLOIT)))
|
||||||
{
|
{
|
||||||
@ -1942,7 +1935,7 @@ ShemuX86Emulate(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
continue;
|
goto post_emulate;
|
||||||
}
|
}
|
||||||
|
|
||||||
// This flag can only be set for APX instructions.
|
// This flag can only be set for APX instructions.
|
||||||
@ -3557,6 +3550,14 @@ check_far_branch:
|
|||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
post_emulate:
|
||||||
|
// The stop flag has been set, this means we've reached a valid instruction, but that instruction cannot be
|
||||||
|
// emulated (for example, SYSCALL, INT, system instructions, etc).
|
||||||
|
if (stop)
|
||||||
|
{
|
||||||
|
return SHEMU_ABORT_CANT_EMULATE;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Minimum percent of the instructions were NOPs => consider we have a NOP sled. Note that we get here only if
|
// Minimum percent of the instructions were NOPs => consider we have a NOP sled. Note that we get here only if
|
||||||
|
Loading…
Reference in New Issue
Block a user