mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-05 00:33:55 -06:00
xen_disk: Plug memory leak on error path
The Error object was leaked after failed bdrv_new(). While there, streamline control flow a bit. Signed-off-by: Markus Armbruster <armbru@redhat.com> Signed-off-by: Kevin Wolf <kwolf@redhat.com>
This commit is contained in:
parent
dbb651c46c
commit
cedccf1381
1 changed files with 14 additions and 17 deletions
|
@ -852,26 +852,23 @@ static int blk_connect(struct XenDevice *xendev)
|
||||||
blkdev->dinfo = drive_get(IF_XEN, 0, index);
|
blkdev->dinfo = drive_get(IF_XEN, 0, index);
|
||||||
if (!blkdev->dinfo) {
|
if (!blkdev->dinfo) {
|
||||||
Error *local_err = NULL;
|
Error *local_err = NULL;
|
||||||
|
BlockDriver *drv;
|
||||||
|
|
||||||
/* setup via xenbus -> create new block driver instance */
|
/* setup via xenbus -> create new block driver instance */
|
||||||
xen_be_printf(&blkdev->xendev, 2, "create new bdrv (xenbus setup)\n");
|
xen_be_printf(&blkdev->xendev, 2, "create new bdrv (xenbus setup)\n");
|
||||||
blkdev->bs = bdrv_new(blkdev->dev, &local_err);
|
blkdev->bs = bdrv_new(blkdev->dev, NULL);
|
||||||
if (local_err) {
|
if (!blkdev->bs) {
|
||||||
blkdev->bs = NULL;
|
return -1;
|
||||||
}
|
}
|
||||||
if (blkdev->bs) {
|
|
||||||
BlockDriver *drv = bdrv_find_whitelisted_format(blkdev->fileproto,
|
drv = bdrv_find_whitelisted_format(blkdev->fileproto, readonly);
|
||||||
readonly);
|
|
||||||
if (bdrv_open(&blkdev->bs, blkdev->filename, NULL, NULL, qflags,
|
if (bdrv_open(&blkdev->bs, blkdev->filename, NULL, NULL, qflags,
|
||||||
drv, &local_err) != 0)
|
drv, &local_err) != 0) {
|
||||||
{
|
|
||||||
xen_be_printf(&blkdev->xendev, 0, "error: %s\n",
|
xen_be_printf(&blkdev->xendev, 0, "error: %s\n",
|
||||||
error_get_pretty(local_err));
|
error_get_pretty(local_err));
|
||||||
error_free(local_err);
|
error_free(local_err);
|
||||||
bdrv_unref(blkdev->bs);
|
bdrv_unref(blkdev->bs);
|
||||||
blkdev->bs = NULL;
|
blkdev->bs = NULL;
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!blkdev->bs) {
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue