mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-01-05 14:35:35 +00:00
Add support for the ARM IPSR register. (#1067)
1. Create an enum name for the IPSR register. 2. Implement read and write of the IPSR via the xpsr helper functions. Fixes #1065 Backports commit 6c319941a5462ee3a4af4593c371f5674394d6ce from unicorn.
This commit is contained in:
parent
c1267811e2
commit
5ad3a0ea82
|
@ -133,6 +133,7 @@ typedef enum uc_arm_reg {
|
||||||
UC_ARM_REG_C13_C0_2,
|
UC_ARM_REG_C13_C0_2,
|
||||||
UC_ARM_REG_C13_C0_3,
|
UC_ARM_REG_C13_C0_3,
|
||||||
|
|
||||||
|
UC_ARM_REG_IPSR,
|
||||||
UC_ARM_REG_ENDING, // <-- mark the end of the list or registers
|
UC_ARM_REG_ENDING, // <-- mark the end of the list or registers
|
||||||
|
|
||||||
//> alias registers
|
//> alias registers
|
||||||
|
|
|
@ -93,6 +93,9 @@ int arm_reg_read(struct uc_struct *uc, unsigned int *regs, void **vals, int coun
|
||||||
case UC_ARM_REG_FPEXC:
|
case UC_ARM_REG_FPEXC:
|
||||||
*(int32_t *)value = state->vfp.xregs[ARM_VFP_FPEXC];
|
*(int32_t *)value = state->vfp.xregs[ARM_VFP_FPEXC];
|
||||||
break;
|
break;
|
||||||
|
case UC_ARM_REG_IPSR:
|
||||||
|
*(uint32_t *)value = xpsr_read(state) & 0x1ff;
|
||||||
|
break;
|
||||||
case UC_ARM_REG_FPSCR:
|
case UC_ARM_REG_FPSCR:
|
||||||
*(int32_t *)value = vfp_get_fpscr(state);
|
*(int32_t *)value = vfp_get_fpscr(state);
|
||||||
break;
|
break;
|
||||||
|
@ -157,6 +160,9 @@ int arm_reg_write(struct uc_struct *uc, unsigned int *regs, void* const* vals, i
|
||||||
case UC_ARM_REG_FPSCR:
|
case UC_ARM_REG_FPSCR:
|
||||||
vfp_set_fpscr(state, *(uint32_t *)value);
|
vfp_set_fpscr(state, *(uint32_t *)value);
|
||||||
break;
|
break;
|
||||||
|
case UC_ARM_REG_IPSR:
|
||||||
|
xpsr_write(state, *(uint32_t *)value, 0x1ff);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue