From: Peter Maydell Date: Wed, 22 Feb 2012 22:40:00 +0000 (+0000) Subject: vl.c: Avoid segfault when started with no arguments X-Git-Tag: TizenStudio_2.0_p2.3.2~208^2~4439 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=967c0da73a7b0da186baba6632301d83644a570c;p=sdk%2Femulator%2Fqemu.git vl.c: Avoid segfault when started with no arguments Fix a bug (introduced in commit a0abe47) where a command line which specified no machine arguments (either explicitly or implicitly via -kernel &co) would result in a segfault because of a NULL pointer returned from qemu_opts_find(qemu_find_opts("machine"), 0). Signed-off-by: Peter Maydell Signed-off-by: Anthony Liguori --- diff --git a/vl.c b/vl.c index e1a1e89..1d4c350 100644 --- a/vl.c +++ b/vl.c @@ -2261,7 +2261,7 @@ int main(int argc, char **argv, char **envp) DisplayState *ds; DisplayChangeListener *dcl; int cyls, heads, secs, translation; - QemuOpts *hda_opts = NULL, *opts; + QemuOpts *hda_opts = NULL, *opts, *machine_opts; QemuOptsList *olist; int optind; const char *optarg; @@ -3320,12 +3320,15 @@ int main(int argc, char **argv, char **envp) exit(1); } - kernel_filename = qemu_opt_get(qemu_opts_find(qemu_find_opts("machine"), - 0), "kernel"); - initrd_filename = qemu_opt_get(qemu_opts_find(qemu_find_opts("machine"), - 0), "initrd"); - kernel_cmdline = qemu_opt_get(qemu_opts_find(qemu_find_opts("machine"), - 0), "append"); + machine_opts = qemu_opts_find(qemu_find_opts("machine"), 0); + if (machine_opts) { + kernel_filename = qemu_opt_get(machine_opts, "kernel"); + initrd_filename = qemu_opt_get(machine_opts, "initrd"); + kernel_cmdline = qemu_opt_get(machine_opts, "append"); + } else { + kernel_filename = initrd_filename = kernel_cmdline = NULL; + } + if (!kernel_cmdline) { kernel_cmdline = ""; }