target/arm: Introduce gen_exception

Create a new wrapper function that passes the default
exception target to gen_exception_el.

Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
Message-id: 20220609202901.1177572-18-richard.henderson@linaro.org
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
Richard Henderson 2022-06-10 14:32:33 +01:00 committed by Peter Maydell
parent bca6f24f01
commit 1a13b9a863

View File

@ -1093,6 +1093,11 @@ static void gen_exception_el(int excp, uint32_t syndrome, uint32_t target_el)
tcg_constant_i32(target_el)); tcg_constant_i32(target_el));
} }
static void gen_exception(DisasContext *s, int excp, uint32_t syndrome)
{
gen_exception_el(excp, syndrome, default_exception_el(s));
}
static void gen_exception_insn_el_v(DisasContext *s, uint64_t pc, int excp, static void gen_exception_insn_el_v(DisasContext *s, uint64_t pc, int excp,
uint32_t syn, TCGv_i32 tcg_el) uint32_t syn, TCGv_i32 tcg_el)
{ {
@ -9758,8 +9763,7 @@ static void arm_tr_tb_stop(DisasContextBase *dcbase, CPUState *cpu)
switch (dc->base.is_jmp) { switch (dc->base.is_jmp) {
case DISAS_SWI: case DISAS_SWI:
gen_ss_advance(dc); gen_ss_advance(dc);
gen_exception_el(EXCP_SWI, syn_aa32_svc(dc->svc_imm, dc->thumb), gen_exception(dc, EXCP_SWI, syn_aa32_svc(dc->svc_imm, dc->thumb));
default_exception_el(dc));
break; break;
case DISAS_HVC: case DISAS_HVC:
gen_ss_advance(dc); gen_ss_advance(dc);
@ -9828,8 +9832,7 @@ static void arm_tr_tb_stop(DisasContextBase *dcbase, CPUState *cpu)
gen_helper_yield(cpu_env); gen_helper_yield(cpu_env);
break; break;
case DISAS_SWI: case DISAS_SWI:
gen_exception_el(EXCP_SWI, syn_aa32_svc(dc->svc_imm, dc->thumb), gen_exception(dc, EXCP_SWI, syn_aa32_svc(dc->svc_imm, dc->thumb));
default_exception_el(dc));
break; break;
case DISAS_HVC: case DISAS_HVC:
gen_exception_el(EXCP_HVC, syn_aa32_hvc(dc->svc_imm), 2); gen_exception_el(EXCP_HVC, syn_aa32_hvc(dc->svc_imm), 2);