mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-01-20 18:31:11 +00:00
Use the qemu helpers to get/set the x86 eflags (#878)
This commit is contained in:
parent
363cbacee4
commit
d7735487f7
|
@ -77,6 +77,7 @@ void x86_reg_reset(struct uc_struct *uc)
|
||||||
env->eip = 0;
|
env->eip = 0;
|
||||||
env->eflags = 0;
|
env->eflags = 0;
|
||||||
env->eflags0 = 0;
|
env->eflags0 = 0;
|
||||||
|
env->cc_op = CC_OP_EFLAGS;
|
||||||
|
|
||||||
env->fpstt = 0; /* top of stack index */
|
env->fpstt = 0; /* top of stack index */
|
||||||
env->fpus = 0;
|
env->fpus = 0;
|
||||||
|
@ -348,7 +349,7 @@ int x86_reg_read(struct uc_struct *uc, unsigned int *regs, void **vals, int coun
|
||||||
*(int32_t *)value = X86_CPU(uc, mycpu)->env.dr[regid - UC_X86_REG_DR0];
|
*(int32_t *)value = X86_CPU(uc, mycpu)->env.dr[regid - UC_X86_REG_DR0];
|
||||||
break;
|
break;
|
||||||
case UC_X86_REG_EFLAGS:
|
case UC_X86_REG_EFLAGS:
|
||||||
*(int32_t *)value = X86_CPU(uc, mycpu)->env.eflags;
|
*(int32_t *)value = cpu_compute_eflags(&X86_CPU(uc, mycpu)->env);
|
||||||
break;
|
break;
|
||||||
case UC_X86_REG_EAX:
|
case UC_X86_REG_EAX:
|
||||||
*(int32_t *)value = X86_CPU(uc, mycpu)->env.regs[R_EAX];
|
*(int32_t *)value = X86_CPU(uc, mycpu)->env.regs[R_EAX];
|
||||||
|
@ -495,7 +496,7 @@ int x86_reg_read(struct uc_struct *uc, unsigned int *regs, void **vals, int coun
|
||||||
*(int64_t *)value = X86_CPU(uc, mycpu)->env.dr[regid - UC_X86_REG_DR0];
|
*(int64_t *)value = X86_CPU(uc, mycpu)->env.dr[regid - UC_X86_REG_DR0];
|
||||||
break;
|
break;
|
||||||
case UC_X86_REG_EFLAGS:
|
case UC_X86_REG_EFLAGS:
|
||||||
*(int64_t *)value = X86_CPU(uc, mycpu)->env.eflags;
|
*(int64_t *)value = cpu_compute_eflags(&X86_CPU(uc, mycpu)->env);
|
||||||
break;
|
break;
|
||||||
case UC_X86_REG_RAX:
|
case UC_X86_REG_RAX:
|
||||||
*(uint64_t *)value = X86_CPU(uc, mycpu)->env.regs[R_EAX];
|
*(uint64_t *)value = X86_CPU(uc, mycpu)->env.regs[R_EAX];
|
||||||
|
@ -888,7 +889,7 @@ int x86_reg_write(struct uc_struct *uc, unsigned int *regs, void *const *vals, i
|
||||||
X86_CPU(uc, mycpu)->env.dr[regid - UC_X86_REG_DR0] = *(uint32_t *)value;
|
X86_CPU(uc, mycpu)->env.dr[regid - UC_X86_REG_DR0] = *(uint32_t *)value;
|
||||||
break;
|
break;
|
||||||
case UC_X86_REG_EFLAGS:
|
case UC_X86_REG_EFLAGS:
|
||||||
X86_CPU(uc, mycpu)->env.eflags = *(uint32_t *)value;
|
cpu_load_eflags(&X86_CPU(uc, mycpu)->env, *(uint32_t *)value, -1);
|
||||||
X86_CPU(uc, mycpu)->env.eflags0 = *(uint32_t *)value;
|
X86_CPU(uc, mycpu)->env.eflags0 = *(uint32_t *)value;
|
||||||
break;
|
break;
|
||||||
case UC_X86_REG_EAX:
|
case UC_X86_REG_EAX:
|
||||||
|
@ -1042,7 +1043,7 @@ int x86_reg_write(struct uc_struct *uc, unsigned int *regs, void *const *vals, i
|
||||||
X86_CPU(uc, mycpu)->env.dr[regid - UC_X86_REG_DR0] = *(uint64_t *)value;
|
X86_CPU(uc, mycpu)->env.dr[regid - UC_X86_REG_DR0] = *(uint64_t *)value;
|
||||||
break;
|
break;
|
||||||
case UC_X86_REG_EFLAGS:
|
case UC_X86_REG_EFLAGS:
|
||||||
X86_CPU(uc, mycpu)->env.eflags = *(uint64_t *)value;
|
cpu_load_eflags(&X86_CPU(uc, mycpu)->env, *(uint64_t *)value, -1);
|
||||||
X86_CPU(uc, mycpu)->env.eflags0 = *(uint64_t *)value;
|
X86_CPU(uc, mycpu)->env.eflags0 = *(uint64_t *)value;
|
||||||
break;
|
break;
|
||||||
case UC_X86_REG_RAX:
|
case UC_X86_REG_RAX:
|
||||||
|
|
Loading…
Reference in a new issue