aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarcel Apfelbaum <marcel@redhat.com>2016-02-12 17:02:24 -0200
committerMarkus Armbruster <armbru@redhat.com>2016-02-19 13:46:44 +0100
commit34f405ae6d5c4170b192a12b2e654a2aea0c3b50 (patch)
treea669b88e0062b1136ac00da5d21c75007454d8b3
parentdd5e38b19d7cb07d317e1285941d8245c01da540 (diff)
downloadqemu-34f405ae6d5c4170b192a12b2e654a2aea0c3b50.zip
qemu-34f405ae6d5c4170b192a12b2e654a2aea0c3b50.tar.gz
qemu-34f405ae6d5c4170b192a12b2e654a2aea0c3b50.tar.bz2
vl.c: Fix regression in machine error message
Commit e1ce0c3cb (vl.c: fix regression when reading machine type from config file) fixed the error message when the machine type was supplied inside the config file. However now the option name is not displayed correctly if the error happens when the machine is specified at command line. Running ./x86_64-softmmu/qemu-system-x86_64 -M q35-1.5 -redir tcp:8022::22 will result in the error message: qemu-system-x86_64: -redir tcp:8022::22: unsupported machine type Use -machine help to list supported machines Fixed it by restoring the error location and also extracted the code dealing with machine options into a separate function. Reported-by: Michael S. Tsirkin <mst@redhat.com> Reviewed-by: Laszlo Ersek <lersek@redhat.com> Signed-off-by: Marcel Apfelbaum <marcel@redhat.com> Reviewed-by: Eduardo Habkost <ehabkost@redhat.com> Signed-off-by: Eduardo Habkost <ehabkost@redhat.com> Message-Id: <1455303747-19776-2-git-send-email-ehabkost@redhat.com> Signed-off-by: Markus Armbruster <armbru@redhat.com>
-rw-r--r--vl.c37
1 files changed, 26 insertions, 11 deletions
diff --git a/vl.c b/vl.c
index 18e6086..226bdeb 100644
--- a/vl.c
+++ b/vl.c
@@ -2762,6 +2762,31 @@ static const QEMUOption *lookup_opt(int argc, char **argv,
return popt;
}
+static void set_machine_options(MachineClass **machine_class)
+{
+ const char *optarg;
+ QemuOpts *opts;
+ Location loc;
+
+ loc_push_none(&loc);
+
+ opts = qemu_get_machine_opts();
+ qemu_opts_loc_restore(opts);
+
+ optarg = qemu_opt_get(opts, "type");
+ if (optarg) {
+ *machine_class = machine_parse(optarg);
+ }
+
+ if (*machine_class == NULL) {
+ error_report("No machine specified, and there is no default");
+ error_printf("Use -machine help to list supported machines\n");
+ exit(1);
+ }
+
+ loc_pop(&loc);
+}
+
static int machine_set_property(void *opaque,
const char *name, const char *value,
Error **errp)
@@ -3986,17 +4011,7 @@ int main(int argc, char **argv, char **envp)
replay_configure(icount_opts);
- opts = qemu_get_machine_opts();
- optarg = qemu_opt_get(opts, "type");
- if (optarg) {
- machine_class = machine_parse(optarg);
- }
-
- if (machine_class == NULL) {
- error_report("No machine specified, and there is no default");
- error_printf("Use -machine help to list supported machines\n");
- exit(1);
- }
+ set_machine_options(&machine_class);
set_memory_options(&ram_slots, &maxram_size, machine_class);