target-arm: Dump 32-bit CPU state if 64 bit CPU is in AArch32
For system mode, we may have a 64 bit CPU which is currently executing in AArch32 state; if we're dumping CPU state to the logs we should therefore show the correct state for the current execution state, rather than hardwiring it based on the type of the CPU. For consistency with how we handle translation, we leave the 32 bit dump function as the default, and have it hand off control to the 64 bit dump code if we're in AArch64 mode. Reported-by: Rob Herring <rob.herring@linaro.org> Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
parent
7633378d5f
commit
177311157c
@ -200,8 +200,6 @@ void arm_gt_ptimer_cb(void *opaque);
|
|||||||
void arm_gt_vtimer_cb(void *opaque);
|
void arm_gt_vtimer_cb(void *opaque);
|
||||||
|
|
||||||
#ifdef TARGET_AARCH64
|
#ifdef TARGET_AARCH64
|
||||||
void aarch64_cpu_dump_state(CPUState *cs, FILE *f,
|
|
||||||
fprintf_function cpu_fprintf, int flags);
|
|
||||||
int aarch64_cpu_gdb_read_register(CPUState *cpu, uint8_t *buf, int reg);
|
int aarch64_cpu_gdb_read_register(CPUState *cpu, uint8_t *buf, int reg);
|
||||||
int aarch64_cpu_gdb_write_register(CPUState *cpu, uint8_t *buf, int reg);
|
int aarch64_cpu_gdb_write_register(CPUState *cpu, uint8_t *buf, int reg);
|
||||||
|
|
||||||
|
@ -188,7 +188,6 @@ static void aarch64_cpu_class_init(ObjectClass *oc, void *data)
|
|||||||
CPUClass *cc = CPU_CLASS(oc);
|
CPUClass *cc = CPU_CLASS(oc);
|
||||||
|
|
||||||
cc->do_interrupt = aarch64_cpu_do_interrupt;
|
cc->do_interrupt = aarch64_cpu_do_interrupt;
|
||||||
cc->dump_state = aarch64_cpu_dump_state;
|
|
||||||
cc->set_pc = aarch64_cpu_set_pc;
|
cc->set_pc = aarch64_cpu_set_pc;
|
||||||
cc->gdb_read_register = aarch64_cpu_gdb_read_register;
|
cc->gdb_read_register = aarch64_cpu_gdb_read_register;
|
||||||
cc->gdb_write_register = aarch64_cpu_gdb_write_register;
|
cc->gdb_write_register = aarch64_cpu_gdb_write_register;
|
||||||
|
@ -11047,6 +11047,11 @@ void arm_cpu_dump_state(CPUState *cs, FILE *f, fprintf_function cpu_fprintf,
|
|||||||
int i;
|
int i;
|
||||||
uint32_t psr;
|
uint32_t psr;
|
||||||
|
|
||||||
|
if (is_a64(env)) {
|
||||||
|
aarch64_cpu_dump_state(cs, f, cpu_fprintf, flags);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
for(i=0;i<16;i++) {
|
for(i=0;i<16;i++) {
|
||||||
cpu_fprintf(f, "R%02d=%08x", i, env->regs[i]);
|
cpu_fprintf(f, "R%02d=%08x", i, env->regs[i]);
|
||||||
if ((i % 4) == 3)
|
if ((i % 4) == 3)
|
||||||
|
@ -72,6 +72,8 @@ void gen_intermediate_code_internal_a64(ARMCPU *cpu,
|
|||||||
TranslationBlock *tb,
|
TranslationBlock *tb,
|
||||||
bool search_pc);
|
bool search_pc);
|
||||||
void gen_a64_set_pc_im(uint64_t val);
|
void gen_a64_set_pc_im(uint64_t val);
|
||||||
|
void aarch64_cpu_dump_state(CPUState *cs, FILE *f,
|
||||||
|
fprintf_function cpu_fprintf, int flags);
|
||||||
#else
|
#else
|
||||||
static inline void a64_translate_init(void)
|
static inline void a64_translate_init(void)
|
||||||
{
|
{
|
||||||
@ -86,6 +88,12 @@ static inline void gen_intermediate_code_internal_a64(ARMCPU *cpu,
|
|||||||
static inline void gen_a64_set_pc_im(uint64_t val)
|
static inline void gen_a64_set_pc_im(uint64_t val)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline void aarch64_cpu_dump_state(CPUState *cs, FILE *f,
|
||||||
|
fprintf_function cpu_fprintf,
|
||||||
|
int flags)
|
||||||
|
{
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void arm_gen_test_cc(int cc, int label);
|
void arm_gen_test_cc(int cc, int label);
|
||||||
|
Loading…
Reference in New Issue
Block a user