mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-10 11:04:58 -06:00
qom/cpu: Simplify how CPUClass:cpu_dump_state() prints
CPUClass method dump_statistics() takes an fprintf()-like callback and a FILE * to pass to it. Most callers pass fprintf() and stderr. log_cpu_state() passes fprintf() and qemu_log_file. hmp_info_registers() passes monitor_fprintf() and the current monitor cast to FILE *. monitor_fprintf() casts it right back, and is otherwise identical to monitor_printf(). The callback gets passed around a lot, which is tiresome. The type-punning around monitor_fprintf() is ugly. Drop the callback, and call qemu_fprintf() instead. Also gets rid of the type-punning, since qemu_fprintf() takes NULL instead of the current monitor cast to FILE *. Signed-off-by: Markus Armbruster <armbru@redhat.com> Reviewed-by: Dr. David Alan Gilbert <dgilbert@redhat.com> Message-Id: <20190417191805.28198-15-armbru@redhat.com>
This commit is contained in:
parent
19aaa4c3fd
commit
90c84c5600
63 changed files with 682 additions and 711 deletions
|
@ -224,8 +224,7 @@ static inline TriCoreCPU *tricore_env_get_cpu(CPUTriCoreState *env)
|
|||
#define ENV_OFFSET offsetof(TriCoreCPU, env)
|
||||
|
||||
hwaddr tricore_cpu_get_phys_page_debug(CPUState *cpu, vaddr addr);
|
||||
void tricore_cpu_dump_state(CPUState *cpu, FILE *f,
|
||||
fprintf_function cpu_fprintf, int flags);
|
||||
void tricore_cpu_dump_state(CPUState *cpu, FILE *f, int flags);
|
||||
|
||||
|
||||
#define MASK_PCXI_PCPN 0xff000000
|
||||
|
|
|
@ -24,6 +24,7 @@
|
|||
#include "exec/exec-all.h"
|
||||
#include "tcg-op.h"
|
||||
#include "exec/cpu_ldst.h"
|
||||
#include "qemu/qemu-print.h"
|
||||
|
||||
#include "exec/helper-proto.h"
|
||||
#include "exec/helper-gen.h"
|
||||
|
@ -88,8 +89,7 @@ enum {
|
|||
MODE_UU = 3,
|
||||
};
|
||||
|
||||
void tricore_cpu_dump_state(CPUState *cs, FILE *f,
|
||||
fprintf_function cpu_fprintf, int flags)
|
||||
void tricore_cpu_dump_state(CPUState *cs, FILE *f, int flags)
|
||||
{
|
||||
TriCoreCPU *cpu = TRICORE_CPU(cs);
|
||||
CPUTriCoreState *env = &cpu->env;
|
||||
|
@ -98,26 +98,26 @@ void tricore_cpu_dump_state(CPUState *cs, FILE *f,
|
|||
|
||||
psw = psw_read(env);
|
||||
|
||||
cpu_fprintf(f, "PC: " TARGET_FMT_lx, env->PC);
|
||||
cpu_fprintf(f, " PSW: " TARGET_FMT_lx, psw);
|
||||
cpu_fprintf(f, " ICR: " TARGET_FMT_lx, env->ICR);
|
||||
cpu_fprintf(f, "\nPCXI: " TARGET_FMT_lx, env->PCXI);
|
||||
cpu_fprintf(f, " FCX: " TARGET_FMT_lx, env->FCX);
|
||||
cpu_fprintf(f, " LCX: " TARGET_FMT_lx, env->LCX);
|
||||
qemu_fprintf(f, "PC: " TARGET_FMT_lx, env->PC);
|
||||
qemu_fprintf(f, " PSW: " TARGET_FMT_lx, psw);
|
||||
qemu_fprintf(f, " ICR: " TARGET_FMT_lx, env->ICR);
|
||||
qemu_fprintf(f, "\nPCXI: " TARGET_FMT_lx, env->PCXI);
|
||||
qemu_fprintf(f, " FCX: " TARGET_FMT_lx, env->FCX);
|
||||
qemu_fprintf(f, " LCX: " TARGET_FMT_lx, env->LCX);
|
||||
|
||||
for (i = 0; i < 16; ++i) {
|
||||
if ((i & 3) == 0) {
|
||||
cpu_fprintf(f, "\nGPR A%02d:", i);
|
||||
qemu_fprintf(f, "\nGPR A%02d:", i);
|
||||
}
|
||||
cpu_fprintf(f, " " TARGET_FMT_lx, env->gpr_a[i]);
|
||||
qemu_fprintf(f, " " TARGET_FMT_lx, env->gpr_a[i]);
|
||||
}
|
||||
for (i = 0; i < 16; ++i) {
|
||||
if ((i & 3) == 0) {
|
||||
cpu_fprintf(f, "\nGPR D%02d:", i);
|
||||
qemu_fprintf(f, "\nGPR D%02d:", i);
|
||||
}
|
||||
cpu_fprintf(f, " " TARGET_FMT_lx, env->gpr_d[i]);
|
||||
qemu_fprintf(f, " " TARGET_FMT_lx, env->gpr_d[i]);
|
||||
}
|
||||
cpu_fprintf(f, "\n");
|
||||
qemu_fprintf(f, "\n");
|
||||
}
|
||||
|
||||
/*
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue