@@ -2434,6 +2434,7 @@ CharDriverState *qemu_chr_open_opts(QemuOpts *opts,
void (*init)(struct CharDriverState *s))
{
CharDriverState *chr;
+ const char *backend;
int i;
if (qemu_opts_id(opts) == NULL) {
@@ -2441,8 +2442,14 @@ CharDriverState *qemu_chr_open_opts(QemuOpts *opts,
return NULL;
}
+ backend = qemu_opt_get(opts, "backend");
+ if (!backend) {
+ fprintf(stderr, "chardev: backend option not specified\n");
+ return NULL;
+ }
+
for (i = 0; i < ARRAY_SIZE(backend_table); i++) {
- if (strcmp(backend_table[i].name, qemu_opt_get(opts, "backend")) == 0)
+ if (strcmp(backend_table[i].name, backend) == 0)
break;
}
if (i == ARRAY_SIZE(backend_table)) {
qemu_opt_get may return NULL, so handle that rather than crashing. Signed-off-by: Mike McCormack <mj.mccormack@samsung.com> --- qemu-char.c | 9 ++++++++- 1 files changed, 8 insertions(+), 1 deletions(-)