mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-04 08:13:54 -06:00
qapi: Convert memsave
Please, note that the QMP command has a new 'cpu-index' parameter. Signed-off-by: Anthony Liguori <aliguori@us.ibm.com> Signed-off-by: Luiz Capitulino <lcapitulino@redhat.com>
This commit is contained in:
parent
5889887366
commit
0cfd6a9ab4
7 changed files with 97 additions and 47 deletions
38
monitor.c
38
monitor.c
|
@ -1370,44 +1370,6 @@ static void do_print(Monitor *mon, const QDict *qdict)
|
|||
monitor_printf(mon, "\n");
|
||||
}
|
||||
|
||||
static int do_memory_save(Monitor *mon, const QDict *qdict, QObject **ret_data)
|
||||
{
|
||||
FILE *f;
|
||||
uint32_t size = qdict_get_int(qdict, "size");
|
||||
const char *filename = qdict_get_str(qdict, "filename");
|
||||
target_long addr = qdict_get_int(qdict, "val");
|
||||
uint32_t l;
|
||||
CPUState *env;
|
||||
uint8_t buf[1024];
|
||||
int ret = -1;
|
||||
|
||||
env = mon_get_cpu();
|
||||
|
||||
f = fopen(filename, "wb");
|
||||
if (!f) {
|
||||
qerror_report(QERR_OPEN_FILE_FAILED, filename);
|
||||
return -1;
|
||||
}
|
||||
while (size != 0) {
|
||||
l = sizeof(buf);
|
||||
if (l > size)
|
||||
l = size;
|
||||
cpu_memory_rw_debug(env, addr, buf, l, 0);
|
||||
if (fwrite(buf, 1, l, f) != l) {
|
||||
monitor_printf(mon, "fwrite() error in do_memory_save\n");
|
||||
goto exit;
|
||||
}
|
||||
addr += l;
|
||||
size -= l;
|
||||
}
|
||||
|
||||
ret = 0;
|
||||
|
||||
exit:
|
||||
fclose(f);
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int do_physical_memory_save(Monitor *mon, const QDict *qdict,
|
||||
QObject **ret_data)
|
||||
{
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue