Commit 03cd4655 authored by Markus Armbruster's avatar Markus Armbruster
Browse files

savevm: Fix -loadvm to report errors to stderr, not the monitor

A monitor may not even exist.

Change load_vmstate() to use qemu_error() instead of monitor_printf().
Parameter mon is now unused, remove it.
parent 4491e0f3
Loading
Loading
Loading
Loading
+1 −1
Original line number Diff line number Diff line
@@ -2533,7 +2533,7 @@ static void do_loadvm(Monitor *mon, const QDict *qdict)

    vm_stop(0);

    if (load_vmstate(mon, name) >= 0 && saved_vm_running)
    if (load_vmstate(name) >= 0 && saved_vm_running)
        vm_start();
}

+11 −13
Original line number Diff line number Diff line
@@ -1737,7 +1737,7 @@ void do_savevm(Monitor *mon, const QDict *qdict)
        vm_start();
}

int load_vmstate(Monitor *mon, const char *name)
int load_vmstate(const char *name)
{
    DriveInfo *dinfo;
    BlockDriverState *bs, *bs1;
@@ -1747,7 +1747,7 @@ int load_vmstate(Monitor *mon, const char *name)

    bs = get_bs_snapshots();
    if (!bs) {
        monitor_printf(mon, "No block device supports snapshots\n");
        qemu_error("No block device supports snapshots\n");
        return -EINVAL;
    }

@@ -1760,21 +1760,19 @@ int load_vmstate(Monitor *mon, const char *name)
            ret = bdrv_snapshot_goto(bs1, name);
            if (ret < 0) {
                if (bs != bs1)
                    monitor_printf(mon, "Warning: ");
                    qemu_error("Warning: ");
                switch(ret) {
                case -ENOTSUP:
                    monitor_printf(mon,
                                   "Snapshots not supported on device '%s'\n",
                    qemu_error("Snapshots not supported on device '%s'\n",
                               bdrv_get_device_name(bs1));
                    break;
                case -ENOENT:
                    monitor_printf(mon, "Could not find snapshot '%s' on "
                                   "device '%s'\n",
                    qemu_error("Could not find snapshot '%s' on device '%s'\n",
                               name, bdrv_get_device_name(bs1));
                    break;
                default:
                    monitor_printf(mon, "Error %d while activating snapshot on"
                                   " '%s'\n", ret, bdrv_get_device_name(bs1));
                    qemu_error("Error %d while activating snapshot on '%s'\n",
                               ret, bdrv_get_device_name(bs1));
                    break;
                }
                /* fatal on snapshot block device */
@@ -1792,13 +1790,13 @@ int load_vmstate(Monitor *mon, const char *name)
    /* restore the VM state */
    f = qemu_fopen_bdrv(bs, 0);
    if (!f) {
        monitor_printf(mon, "Could not open VM state file\n");
        qemu_error("Could not open VM state file\n");
        return -EINVAL;
    }
    ret = qemu_loadvm_state(f);
    qemu_fclose(f);
    if (ret < 0) {
        monitor_printf(mon, "Error %d while loading VM state\n", ret);
        qemu_error("Error %d while loading VM state\n", ret);
        return ret;
    }
    return 0;
+1 −1
Original line number Diff line number Diff line
@@ -54,7 +54,7 @@ extern qemu_irq qemu_system_powerdown;
void qemu_system_reset(void);

void do_savevm(Monitor *mon, const QDict *qdict);
int load_vmstate(Monitor *mon, const char *name);
int load_vmstate(const char *name);
void do_delvm(Monitor *mon, const QDict *qdict);
void do_info_snapshots(Monitor *mon);

+1 −1
Original line number Diff line number Diff line
@@ -6072,7 +6072,7 @@ int main(int argc, char **argv, char **envp)

    qemu_system_reset();
    if (loadvm) {
        if (load_vmstate(cur_mon, loadvm) < 0) {
        if (load_vmstate(loadvm) < 0) {
            autostart = 0;
        }
    }