mirror of https://github.com/xemu-project/xemu.git
hw/xen: Fix double-free in xen_console store_con_info()
Coverity spotted a double-free (CID 1508254); we g_string_free(path) and
then for some reason immediately call free(path) too.
We should just use g_autoptr() for it anyway, which simplifies the code
a bit.
Fixes: 7a8a749da7
("hw/xen: Move xenstore_store_pv_console_info to xen_console.c")
Signed-off-by: David Woodhouse <dwmw@amazon.co.uk>
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
parent
9d177b7f87
commit
69d4e746b3
|
@ -178,8 +178,7 @@ static int store_con_info(struct XenConsole *con)
|
||||||
Chardev *cs = qemu_chr_fe_get_driver(&con->chr);
|
Chardev *cs = qemu_chr_fe_get_driver(&con->chr);
|
||||||
char *pts = NULL;
|
char *pts = NULL;
|
||||||
char *dom_path;
|
char *dom_path;
|
||||||
GString *path;
|
g_autoptr(GString) path = NULL;
|
||||||
int ret = -1;
|
|
||||||
|
|
||||||
/* Only continue if we're talking to a pty. */
|
/* Only continue if we're talking to a pty. */
|
||||||
if (!CHARDEV_IS_PTY(cs)) {
|
if (!CHARDEV_IS_PTY(cs)) {
|
||||||
|
@ -204,15 +203,9 @@ static int store_con_info(struct XenConsole *con)
|
||||||
|
|
||||||
if (xenstore_write_str(con->console, path->str, pts)) {
|
if (xenstore_write_str(con->console, path->str, pts)) {
|
||||||
fprintf(stderr, "xenstore_write_str for '%s' fail", path->str);
|
fprintf(stderr, "xenstore_write_str for '%s' fail", path->str);
|
||||||
goto out;
|
return -1;
|
||||||
}
|
}
|
||||||
ret = 0;
|
return 0;
|
||||||
|
|
||||||
out:
|
|
||||||
g_string_free(path, true);
|
|
||||||
free(path);
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int con_init(struct XenLegacyDevice *xendev)
|
static int con_init(struct XenLegacyDevice *xendev)
|
||||||
|
|
Loading…
Reference in New Issue