monitor: Convert do_info_cpus() to QObject
Each CPU information is stored in a QDict and the returned QObject is a QList of all CPUs. The QDict contains the following information: - "CPU": cpu index - "current": "yes" or "no" - "pc": current PC - "halted": "yes" or "no" The user output in the Monitor should not change and the future monitor protocol is expected to emit something like: [ { "CPU": 0, "current": "yes", "pc": 0x..., "halted": "no" }, { "CPU": 1, "current": "no", "pc": 0x..., "halted": "yes" } ] which corresponds to the following user output: * CPU #0: pc=0x00000000fffffff0 CPU #1: pc=0x00000000fffffff0 (halted) Patchworks-ID: 35352 Signed-off-by: Luiz Capitulino <lcapitulino@redhat.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
This commit is contained in:
parent
cc1d9c7015
commit
8f3cec0be8
95
monitor.c
95
monitor.c
@ -46,6 +46,7 @@
|
|||||||
#include "kvm.h"
|
#include "kvm.h"
|
||||||
#include "acl.h"
|
#include "acl.h"
|
||||||
#include "qint.h"
|
#include "qint.h"
|
||||||
|
#include "qlist.h"
|
||||||
#include "qdict.h"
|
#include "qdict.h"
|
||||||
#include "qstring.h"
|
#include "qstring.h"
|
||||||
|
|
||||||
@ -409,33 +410,98 @@ static void do_info_registers(Monitor *mon)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
static void do_info_cpus(Monitor *mon)
|
static void print_cpu_iter(QObject *obj, void *opaque)
|
||||||
|
{
|
||||||
|
QDict *cpu;
|
||||||
|
int active = ' ';
|
||||||
|
Monitor *mon = opaque;
|
||||||
|
|
||||||
|
assert(qobject_type(obj) == QTYPE_QDICT);
|
||||||
|
cpu = qobject_to_qdict(obj);
|
||||||
|
|
||||||
|
if (strcmp(qdict_get_str(cpu, "current"), "yes") == 0)
|
||||||
|
active = '*';
|
||||||
|
|
||||||
|
monitor_printf(mon, "%c CPU #%d: ", active, (int)qdict_get_int(cpu, "CPU"));
|
||||||
|
|
||||||
|
#if defined(TARGET_I386)
|
||||||
|
monitor_printf(mon, "pc=0x" TARGET_FMT_lx,
|
||||||
|
(target_ulong) qdict_get_int(cpu, "pc"));
|
||||||
|
#elif defined(TARGET_PPC)
|
||||||
|
monitor_printf(mon, "nip=0x" TARGET_FMT_lx,
|
||||||
|
(target_long) qdict_get_int(cpu, "nip"));
|
||||||
|
#elif defined(TARGET_SPARC)
|
||||||
|
monitor_printf(mon, "pc=0x " TARGET_FMT_lx,
|
||||||
|
(target_long) qdict_get_int(cpu, "pc"));
|
||||||
|
monitor_printf(mon, "npc=0x" TARGET_FMT_lx,
|
||||||
|
(target_long) qdict_get_int(cpu, "npc"));
|
||||||
|
#elif defined(TARGET_MIPS)
|
||||||
|
monitor_printf(mon, "PC=0x" TARGET_FMT_lx,
|
||||||
|
(target_long) qdict_get_int(cpu, "PC"));
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (strcmp(qdict_get_str(cpu, "halted"), "yes") == 0)
|
||||||
|
monitor_printf(mon, " (halted)");
|
||||||
|
|
||||||
|
monitor_printf(mon, "\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
static void monitor_print_cpus(Monitor *mon, const QObject *data)
|
||||||
|
{
|
||||||
|
QList *cpu_list;
|
||||||
|
|
||||||
|
assert(qobject_type(data) == QTYPE_QLIST);
|
||||||
|
cpu_list = qobject_to_qlist(data);
|
||||||
|
qlist_iter(cpu_list, print_cpu_iter, mon);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* do_info_cpus(): Show CPU information
|
||||||
|
*
|
||||||
|
* Return a QList with a QDict for each CPU.
|
||||||
|
*
|
||||||
|
* For example:
|
||||||
|
*
|
||||||
|
* [ { "CPU": 0, "current": "yes", "pc": 0x..., "halted": "no" },
|
||||||
|
* { "CPU": 1, "current": "no", "pc": 0x..., "halted": "yes" } ]
|
||||||
|
*/
|
||||||
|
static void do_info_cpus(Monitor *mon, QObject **ret_data)
|
||||||
{
|
{
|
||||||
CPUState *env;
|
CPUState *env;
|
||||||
|
QList *cpu_list;
|
||||||
|
|
||||||
|
cpu_list = qlist_new();
|
||||||
|
|
||||||
/* just to set the default cpu if not already done */
|
/* just to set the default cpu if not already done */
|
||||||
mon_get_cpu();
|
mon_get_cpu();
|
||||||
|
|
||||||
for(env = first_cpu; env != NULL; env = env->next_cpu) {
|
for(env = first_cpu; env != NULL; env = env->next_cpu) {
|
||||||
|
const char *answer;
|
||||||
|
QDict *cpu = qdict_new();
|
||||||
|
|
||||||
cpu_synchronize_state(env);
|
cpu_synchronize_state(env);
|
||||||
monitor_printf(mon, "%c CPU #%d:",
|
|
||||||
(env == mon->mon_cpu) ? '*' : ' ',
|
qdict_put(cpu, "CPU", qint_from_int(env->cpu_index));
|
||||||
env->cpu_index);
|
answer = (env == mon->mon_cpu) ? "yes" : "no";
|
||||||
|
qdict_put(cpu, "current", qstring_from_str(answer));
|
||||||
|
|
||||||
#if defined(TARGET_I386)
|
#if defined(TARGET_I386)
|
||||||
monitor_printf(mon, " pc=0x" TARGET_FMT_lx,
|
qdict_put(cpu, "pc", qint_from_int(env->eip + env->segs[R_CS].base));
|
||||||
env->eip + env->segs[R_CS].base);
|
|
||||||
#elif defined(TARGET_PPC)
|
#elif defined(TARGET_PPC)
|
||||||
monitor_printf(mon, " nip=0x" TARGET_FMT_lx, env->nip);
|
qdict_put(cpu, "nip", qint_from_int(env->nip));
|
||||||
#elif defined(TARGET_SPARC)
|
#elif defined(TARGET_SPARC)
|
||||||
monitor_printf(mon, " pc=0x" TARGET_FMT_lx " npc=0x" TARGET_FMT_lx,
|
qdict_put(cpu, "pc", qint_from_int(env->pc));
|
||||||
env->pc, env->npc);
|
qdict_put(cpu, "npc", qint_from_int(env->npc));
|
||||||
#elif defined(TARGET_MIPS)
|
#elif defined(TARGET_MIPS)
|
||||||
monitor_printf(mon, " PC=0x" TARGET_FMT_lx, env->active_tc.PC);
|
qdict_put(cpu, "PC", qint_from_int(env->active_tc.PC));
|
||||||
#endif
|
#endif
|
||||||
if (env->halted)
|
answer = env->halted ? "yes" : "no";
|
||||||
monitor_printf(mon, " (halted)");
|
qdict_put(cpu, "halted", qstring_from_str(answer));
|
||||||
monitor_printf(mon, "\n");
|
|
||||||
|
qlist_append(cpu_list, cpu);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
*ret_data = QOBJECT(cpu_list);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void do_cpu_set(Monitor *mon, const QDict *qdict)
|
static void do_cpu_set(Monitor *mon, const QDict *qdict)
|
||||||
@ -1933,7 +1999,8 @@ static const mon_cmd_t info_cmds[] = {
|
|||||||
.args_type = "",
|
.args_type = "",
|
||||||
.params = "",
|
.params = "",
|
||||||
.help = "show infos for each CPU",
|
.help = "show infos for each CPU",
|
||||||
.mhandler.info = do_info_cpus,
|
.user_print = monitor_print_cpus,
|
||||||
|
.mhandler.info_new = do_info_cpus,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
.name = "history",
|
.name = "history",
|
||||||
|
Loading…
Reference in New Issue
Block a user