mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-01-08 23:05:30 +00:00
Add support for ARM application flags - APSR register (#776)
This commit is contained in:
parent
2749b8412e
commit
0150ca24b1
|
@ -41,7 +41,8 @@ def test_arm():
|
||||||
mu.reg_write(UC_ARM_REG_R0, 0x1234)
|
mu.reg_write(UC_ARM_REG_R0, 0x1234)
|
||||||
mu.reg_write(UC_ARM_REG_R2, 0x6789)
|
mu.reg_write(UC_ARM_REG_R2, 0x6789)
|
||||||
mu.reg_write(UC_ARM_REG_R3, 0x3333)
|
mu.reg_write(UC_ARM_REG_R3, 0x3333)
|
||||||
|
mu.reg_write(UC_ARM_REG_APSR, 0xFFFFFFFF) #All application flags turned on
|
||||||
|
|
||||||
# tracing all basic blocks with customized callback
|
# tracing all basic blocks with customized callback
|
||||||
mu.hook_add(UC_HOOK_BLOCK, hook_block)
|
mu.hook_add(UC_HOOK_BLOCK, hook_block)
|
||||||
|
|
||||||
|
|
|
@ -62,6 +62,9 @@ int arm_reg_read(struct uc_struct *uc, unsigned int *regs, void **vals, int coun
|
||||||
*(float64 *)value = ARM_CPU(uc, mycpu)->env.vfp.regs[regid - UC_ARM_REG_D0];
|
*(float64 *)value = ARM_CPU(uc, mycpu)->env.vfp.regs[regid - UC_ARM_REG_D0];
|
||||||
else {
|
else {
|
||||||
switch(regid) {
|
switch(regid) {
|
||||||
|
case UC_ARM_REG_APSR:
|
||||||
|
*(int32_t *)value = cpsr_read(&ARM_CPU(uc, mycpu)->env) & CPSR_NZCV;
|
||||||
|
break;
|
||||||
case UC_ARM_REG_CPSR:
|
case UC_ARM_REG_CPSR:
|
||||||
*(int32_t *)value = cpsr_read(&ARM_CPU(uc, mycpu)->env);
|
*(int32_t *)value = cpsr_read(&ARM_CPU(uc, mycpu)->env);
|
||||||
break;
|
break;
|
||||||
|
@ -107,6 +110,9 @@ int arm_reg_write(struct uc_struct *uc, unsigned int *regs, void* const* vals, i
|
||||||
ARM_CPU(uc, mycpu)->env.vfp.regs[regid - UC_ARM_REG_D0] = *(float64 *)value;
|
ARM_CPU(uc, mycpu)->env.vfp.regs[regid - UC_ARM_REG_D0] = *(float64 *)value;
|
||||||
else {
|
else {
|
||||||
switch(regid) {
|
switch(regid) {
|
||||||
|
case UC_ARM_REG_APSR:
|
||||||
|
cpsr_write(&ARM_CPU(uc, mycpu)->env, *(uint32_t *)value, CPSR_NZCV);
|
||||||
|
break;
|
||||||
case UC_ARM_REG_CPSR:
|
case UC_ARM_REG_CPSR:
|
||||||
cpsr_write(&ARM_CPU(uc, mycpu)->env, *(uint32_t *)value, ~0);
|
cpsr_write(&ARM_CPU(uc, mycpu)->env, *(uint32_t *)value, ~0);
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in a new issue