mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-02-25 13:26:58 +00:00
target/arm: use gen_goto_tb for ISB handling
While an ISB will ensure any raised IRQs happen on the next instruction it doesn't cause any to get raised by itself. We can therefore use a simple tb exit for ISB instructions and rely on the exit_request check at the top of each TB to deal with exiting if needed. Backports commit 0b609cc128ba5ef16cc841bcade898d1898f1dc3 from qemu
This commit is contained in:
parent
0f8d216d67
commit
65356210a8
|
@ -1435,7 +1435,7 @@ static void handle_sync(DisasContext *s, uint32_t insn,
|
|||
* a self-modified code correctly and also to take
|
||||
* any pending interrupts immediately.
|
||||
*/
|
||||
s->is_jmp = DISAS_UPDATE;
|
||||
gen_goto_tb(s, 0, s->pc);
|
||||
return;
|
||||
default:
|
||||
unallocated_encoding(s);
|
||||
|
|
|
@ -8336,7 +8336,7 @@ static void disas_arm_insn(DisasContext *s, unsigned int insn) // qq
|
|||
* self-modifying code correctly and also to take
|
||||
* any pending interrupts immediately.
|
||||
*/
|
||||
gen_lookup_tb(s);
|
||||
gen_goto_tb(s, 0, s->pc & ~1);
|
||||
return;
|
||||
default:
|
||||
goto illegal_op;
|
||||
|
@ -10731,7 +10731,7 @@ static int disas_thumb2_insn(CPUARMState *env, DisasContext *s, uint16_t insn_hw
|
|||
* and also to take any pending interrupts
|
||||
* immediately.
|
||||
*/
|
||||
gen_lookup_tb(s);
|
||||
gen_goto_tb(s, 0, s->pc & ~1);
|
||||
break;
|
||||
default:
|
||||
goto illegal_op;
|
||||
|
|
Loading…
Reference in a new issue