target/arm: Convert to tcg_ops restore_state_to_opc
Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
This commit is contained in:
parent
c0cd068f32
commit
56c6c98df8
@ -90,6 +90,31 @@ void arm_cpu_synchronize_from_tb(CPUState *cs,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void arm_restore_state_to_opc(CPUState *cs,
|
||||||
|
const TranslationBlock *tb,
|
||||||
|
const uint64_t *data)
|
||||||
|
{
|
||||||
|
CPUARMState *env = cs->env_ptr;
|
||||||
|
|
||||||
|
if (is_a64(env)) {
|
||||||
|
if (TARGET_TB_PCREL) {
|
||||||
|
env->pc = (env->pc & TARGET_PAGE_MASK) | data[0];
|
||||||
|
} else {
|
||||||
|
env->pc = data[0];
|
||||||
|
}
|
||||||
|
env->condexec_bits = 0;
|
||||||
|
env->exception.syndrome = data[2] << ARM_INSN_START_WORD2_SHIFT;
|
||||||
|
} else {
|
||||||
|
if (TARGET_TB_PCREL) {
|
||||||
|
env->regs[15] = (env->regs[15] & TARGET_PAGE_MASK) | data[0];
|
||||||
|
} else {
|
||||||
|
env->regs[15] = data[0];
|
||||||
|
}
|
||||||
|
env->condexec_bits = data[1];
|
||||||
|
env->exception.syndrome = data[2] << ARM_INSN_START_WORD2_SHIFT;
|
||||||
|
}
|
||||||
|
}
|
||||||
#endif /* CONFIG_TCG */
|
#endif /* CONFIG_TCG */
|
||||||
|
|
||||||
static bool arm_cpu_has_work(CPUState *cs)
|
static bool arm_cpu_has_work(CPUState *cs)
|
||||||
@ -2152,6 +2177,7 @@ static const struct TCGCPUOps arm_tcg_ops = {
|
|||||||
.initialize = arm_translate_init,
|
.initialize = arm_translate_init,
|
||||||
.synchronize_from_tb = arm_cpu_synchronize_from_tb,
|
.synchronize_from_tb = arm_cpu_synchronize_from_tb,
|
||||||
.debug_excp_handler = arm_debug_excp_handler,
|
.debug_excp_handler = arm_debug_excp_handler,
|
||||||
|
.restore_state_to_opc = arm_restore_state_to_opc,
|
||||||
|
|
||||||
#ifdef CONFIG_USER_ONLY
|
#ifdef CONFIG_USER_ONLY
|
||||||
.record_sigsegv = arm_cpu_record_sigsegv,
|
.record_sigsegv = arm_cpu_record_sigsegv,
|
||||||
|
@ -9939,25 +9939,3 @@ void gen_intermediate_code(CPUState *cpu, TranslationBlock *tb, int max_insns,
|
|||||||
|
|
||||||
translator_loop(cpu, tb, max_insns, pc, host_pc, ops, &dc.base);
|
translator_loop(cpu, tb, max_insns, pc, host_pc, ops, &dc.base);
|
||||||
}
|
}
|
||||||
|
|
||||||
void restore_state_to_opc(CPUARMState *env, TranslationBlock *tb,
|
|
||||||
target_ulong *data)
|
|
||||||
{
|
|
||||||
if (is_a64(env)) {
|
|
||||||
if (TARGET_TB_PCREL) {
|
|
||||||
env->pc = (env->pc & TARGET_PAGE_MASK) | data[0];
|
|
||||||
} else {
|
|
||||||
env->pc = data[0];
|
|
||||||
}
|
|
||||||
env->condexec_bits = 0;
|
|
||||||
env->exception.syndrome = data[2] << ARM_INSN_START_WORD2_SHIFT;
|
|
||||||
} else {
|
|
||||||
if (TARGET_TB_PCREL) {
|
|
||||||
env->regs[15] = (env->regs[15] & TARGET_PAGE_MASK) | data[0];
|
|
||||||
} else {
|
|
||||||
env->regs[15] = data[0];
|
|
||||||
}
|
|
||||||
env->condexec_bits = data[1];
|
|
||||||
env->exception.syndrome = data[2] << ARM_INSN_START_WORD2_SHIFT;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
Loading…
Reference in New Issue
Block a user