mirror of
https://github.com/qemu/qemu.git
synced 2024-11-24 11:23:43 +08:00
arm: Factor out "generate right kind of step exception"
We currently have two places that do: if (dc->ss_active) { gen_step_complete_exception(dc); } else { gen_exception_internal(EXCP_DEBUG); } Factor this out into its own function, as we're about to add a third place that needs the same logic. Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org> Reviewed-by: Richard Henderson <rth@twiddle.net> Message-id: 1491844419-12485-4-git-send-email-peter.maydell@linaro.org
This commit is contained in:
parent
bedb8a6b09
commit
5425415ebb
@ -296,6 +296,19 @@ static void gen_step_complete_exception(DisasContext *s)
|
|||||||
s->is_jmp = DISAS_EXC;
|
s->is_jmp = DISAS_EXC;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void gen_singlestep_exception(DisasContext *s)
|
||||||
|
{
|
||||||
|
/* Generate the right kind of exception for singlestep, which is
|
||||||
|
* either the architectural singlestep or EXCP_DEBUG for QEMU's
|
||||||
|
* gdb singlestepping.
|
||||||
|
*/
|
||||||
|
if (s->ss_active) {
|
||||||
|
gen_step_complete_exception(s);
|
||||||
|
} else {
|
||||||
|
gen_exception_internal(EXCP_DEBUG);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void gen_smul_dual(TCGv_i32 a, TCGv_i32 b)
|
static void gen_smul_dual(TCGv_i32 a, TCGv_i32 b)
|
||||||
{
|
{
|
||||||
TCGv_i32 tmp1 = tcg_temp_new_i32();
|
TCGv_i32 tmp1 = tcg_temp_new_i32();
|
||||||
@ -11998,24 +12011,15 @@ void gen_intermediate_code(CPUARMState *env, TranslationBlock *tb)
|
|||||||
gen_set_pc_im(dc, dc->pc);
|
gen_set_pc_im(dc, dc->pc);
|
||||||
/* fall through */
|
/* fall through */
|
||||||
default:
|
default:
|
||||||
if (dc->ss_active) {
|
/* FIXME: Single stepping a WFI insn will not halt the CPU. */
|
||||||
gen_step_complete_exception(dc);
|
gen_singlestep_exception(dc);
|
||||||
} else {
|
|
||||||
/* FIXME: Single stepping a WFI insn will not halt
|
|
||||||
the CPU. */
|
|
||||||
gen_exception_internal(EXCP_DEBUG);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if (dc->condjmp) {
|
if (dc->condjmp) {
|
||||||
/* "Condition failed" instruction codepath. */
|
/* "Condition failed" instruction codepath. */
|
||||||
gen_set_label(dc->condlabel);
|
gen_set_label(dc->condlabel);
|
||||||
gen_set_condexec(dc);
|
gen_set_condexec(dc);
|
||||||
gen_set_pc_im(dc, dc->pc);
|
gen_set_pc_im(dc, dc->pc);
|
||||||
if (dc->ss_active) {
|
gen_singlestep_exception(dc);
|
||||||
gen_step_complete_exception(dc);
|
|
||||||
} else {
|
|
||||||
gen_exception_internal(EXCP_DEBUG);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
/* While branches must always occur at the end of an IT block,
|
/* While branches must always occur at the end of an IT block,
|
||||||
|
Loading…
Reference in New Issue
Block a user