[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v7 50/64] target/nios2: Use gen_goto_tb for DISAS_TOO_MANY
From: |
Richard Henderson |
Subject: |
[PATCH v7 50/64] target/nios2: Use gen_goto_tb for DISAS_TOO_MANY |
Date: |
Thu, 21 Apr 2022 08:17:21 -0700 |
Depending on the reason for ending the TB, we can chain
to the next TB because the PC is constant.
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
---
target/nios2/translate.c | 5 ++++-
1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/target/nios2/translate.c b/target/nios2/translate.c
index 1686d2b82f..c9b5de2981 100644
--- a/target/nios2/translate.c
+++ b/target/nios2/translate.c
@@ -904,8 +904,11 @@ static void nios2_tr_tb_stop(DisasContextBase *dcbase,
CPUState *cs)
/* Indicate where the next block should start */
switch (dc->base.is_jmp) {
case DISAS_TOO_MANY:
+ gen_goto_tb(dc, 0, dc->base.pc_next);
+ break;
+
case DISAS_UPDATE:
- /* Save the current PC back into the CPU register */
+ /* Save the current PC, and return to the main loop. */
tcg_gen_movi_tl(cpu_pc, dc->base.pc_next);
tcg_gen_exit_tb(NULL, 0);
break;
--
2.34.1
- Re: [PATCH v7 44/64] target/nios2: Split out helpers for gen_* translate macros, (continued)
- [PATCH v7 43/64] target/nios2: Split out named structs for [IRJ]_TYPE, Richard Henderson, 2022/04/21
- [PATCH v7 48/64] target/nios2: Create gen_jumpr, Richard Henderson, 2022/04/21
- [PATCH v7 40/64] target/nios2: Remove CPU_INTERRUPT_NMI, Richard Henderson, 2022/04/21
- [PATCH v7 51/64] target/nios2: Use tcg_gen_lookup_and_goto_ptr, Richard Henderson, 2022/04/21
- [PATCH v7 45/64] target/nios2: Introduce dest_gpr, Richard Henderson, 2022/04/21
- [PATCH v7 47/64] target/nios2: Enable unaligned traps for system mode, Richard Henderson, 2022/04/21
- [PATCH v7 46/64] target/nios2: Drop CR_STATUS_EH from tb->flags, Richard Henderson, 2022/04/21
- [PATCH v7 49/64] target/nios2: Hoist set of is_jmp into gen_goto_tb, Richard Henderson, 2022/04/21
- [PATCH v7 50/64] target/nios2: Use gen_goto_tb for DISAS_TOO_MANY,
Richard Henderson <=
- [PATCH v7 52/64] target/nios2: Implement Misaligned destination exception, Richard Henderson, 2022/04/21
- [PATCH v7 58/64] linux-user/nios2: Handle various SIGILL exceptions, Richard Henderson, 2022/04/21
- [PATCH v7 61/64] hw/nios2: Move memory regions into Nios2Machine, Richard Henderson, 2022/04/21
- [PATCH v7 56/64] target/nios2: Implement EIC interrupt processing, Richard Henderson, 2022/04/21
- [PATCH v7 55/64] target/nios2: Update helper_eret for shadow registers, Richard Henderson, 2022/04/21
- [PATCH v7 59/64] hw/intc: Vectored Interrupt Controller (VIC), Richard Henderson, 2022/04/21
- [PATCH v7 64/64] tests/tcg/nios2: Add test-shadow-1, Richard Henderson, 2022/04/21
- [PATCH v7 53/64] target/nios2: Introduce shadow register sets, Richard Henderson, 2022/04/21