提交 8f3cec0b 编写于 作者: L Luiz Capitulino 提交者: Anthony Liguori

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: NLuiz Capitulino <lcapitulino@redhat.com>
Signed-off-by: NAnthony Liguori <aliguori@us.ibm.com>
上级 cc1d9c70
...@@ -46,6 +46,7 @@ ...@@ -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) ...@@ -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[] = { ...@@ -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",
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册