Merge pull request #256 from farmdve/fix_bugs1
Patch eflags_noset to compile on 32-bit and on 64-bit.
This commit is contained in:
commit
29b3c57e3c
@ -14,28 +14,46 @@
|
|||||||
#define TARGET_PAGE_PREPARE(addr) (((addr) + PAGE_4K - 1) & TARGET_PAGE_MASK)
|
#define TARGET_PAGE_PREPARE(addr) (((addr) + PAGE_4K - 1) & TARGET_PAGE_MASK)
|
||||||
#define TARGET_PAGE_ALIGN(addr) (addr - (TARGET_PAGE_PREPARE(addr) - addr) & TARGET_PAGE_MASK)
|
#define TARGET_PAGE_ALIGN(addr) (addr - (TARGET_PAGE_PREPARE(addr) - addr) & TARGET_PAGE_MASK)
|
||||||
|
|
||||||
unsigned int realEflags()
|
#if defined(__i386__)
|
||||||
{
|
typedef uint32_t puint;
|
||||||
unsigned int val = 0;
|
#define PRIX3264 PRIX32
|
||||||
unsigned int i = 0xFFFFFEFF; //attempt to set ALL bits except trap flag.
|
#else
|
||||||
|
typedef uint64_t puint;
|
||||||
|
#define PRIX3264 PRIX64
|
||||||
|
#endif
|
||||||
|
|
||||||
|
uint32_t realEflags()
|
||||||
|
{
|
||||||
|
puint val = 0;
|
||||||
|
puint i = 0xFFFFFEFF; //attempt to set ALL bits except trap flag.
|
||||||
|
|
||||||
|
#if defined(__i386__)
|
||||||
__asm__("pushf\n\t"
|
__asm__("pushf\n\t"
|
||||||
"push %0\n\t"
|
"push %0\n\t"
|
||||||
"popf\n\t"
|
"popf\n\t"
|
||||||
"pushf\n\t"
|
"pushf\n\t"
|
||||||
"pop %0\n\t"
|
"pop %0\n\t"
|
||||||
"popf"
|
"popf"
|
||||||
|
#else
|
||||||
|
__asm__("pushfq\n\t"
|
||||||
|
"pushq %0\n\t"
|
||||||
|
"popfq\n\t"
|
||||||
|
"pushfq\n\t"
|
||||||
|
"popq %0\n\t"
|
||||||
|
"popfq"
|
||||||
|
#endif
|
||||||
: "=r"(val)
|
: "=r"(val)
|
||||||
: "r"(i)
|
: "r"(i)
|
||||||
: "%0");
|
: "%0");
|
||||||
|
|
||||||
printf("Real system eflags: 0x%08X\n", val);
|
printf("Real system eflags: 0x%08"PRIX3264"\n", val);
|
||||||
|
|
||||||
return val;
|
return (uint32_t)val & 0xFFFFFFFF;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void VM_exec()
|
static void VM_exec()
|
||||||
{
|
{
|
||||||
|
|
||||||
uc_engine *uc;
|
uc_engine *uc;
|
||||||
uc_err err;
|
uc_err err;
|
||||||
unsigned int r_eax, eflags, r_esp, realflags = 0;
|
unsigned int r_eax, eflags, r_esp, realflags = 0;
|
||||||
@ -63,7 +81,7 @@ static void VM_exec()
|
|||||||
err = uc_mem_write(uc, ADDRESS, X86_CODE32, sizeof(X86_CODE32) - 1);
|
err = uc_mem_write(uc, ADDRESS, X86_CODE32, sizeof(X86_CODE32) - 1);
|
||||||
if(err != UC_ERR_OK)
|
if(err != UC_ERR_OK)
|
||||||
{
|
{
|
||||||
printf("Failed to write emulation code to memory, quit!: %s(len %lu)\n", uc_strerror(err), sizeof(X86_CODE32) - 1);
|
printf("Failed to write emulation code to memory, quit!: %s(len %lu)\n", uc_strerror(err), (unsigned long)sizeof(X86_CODE32) - 1);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -94,11 +112,8 @@ static void VM_exec()
|
|||||||
realflags = realEflags();
|
realflags = realEflags();
|
||||||
|
|
||||||
assert(r_eax == realflags);
|
assert(r_eax == realflags);
|
||||||
|
|
||||||
puts("Unicorn EFLAGS match expected system eflags");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
VM_exec();
|
VM_exec();
|
||||||
|
Loading…
Reference in New Issue
Block a user