xen: use qdev_unplug() instead of g_free() in xen_pv_find_xendev()
The error exits of xen_pv_find_xendev() free the new xen-device via
g_free() which is wrong.
As the xen-device has been initialized as qdev it must be removed
via qdev_unplug().
This bug has been introduced with commit 3a6c9172ac
("xen: create qdev for each backend device").
Reported-by: Roger Pau Monné <roger.pau@citrix.com>
Tested-by: Roger Pau Monné <roger.pau@citrix.com>
Signed-off-by: Juergen Gross <jgross@suse.com>
Reviewed-by: Stefano Stabellini <sstabellini@kernel.org>
This commit is contained in:
parent
6d06220ad9
commit
e9dcbc86d6
@ -124,10 +124,11 @@ static struct XenDevice *xen_be_get_xendev(const char *type, int dom, int dev,
|
|||||||
/* init new xendev */
|
/* init new xendev */
|
||||||
xendev = g_malloc0(ops->size);
|
xendev = g_malloc0(ops->size);
|
||||||
object_initialize(&xendev->qdev, ops->size, TYPE_XENBACKEND);
|
object_initialize(&xendev->qdev, ops->size, TYPE_XENBACKEND);
|
||||||
qdev_set_parent_bus(&xendev->qdev, xen_sysbus);
|
OBJECT(xendev)->free = g_free;
|
||||||
qdev_set_id(&xendev->qdev, g_strdup_printf("xen-%s-%d", type, dev));
|
qdev_set_parent_bus(DEVICE(xendev), xen_sysbus);
|
||||||
qdev_init_nofail(&xendev->qdev);
|
qdev_set_id(DEVICE(xendev), g_strdup_printf("xen-%s-%d", type, dev));
|
||||||
object_unref(OBJECT(&xendev->qdev));
|
qdev_init_nofail(DEVICE(xendev));
|
||||||
|
object_unref(OBJECT(xendev));
|
||||||
|
|
||||||
xendev->type = type;
|
xendev->type = type;
|
||||||
xendev->dom = dom;
|
xendev->dom = dom;
|
||||||
@ -145,7 +146,7 @@ static struct XenDevice *xen_be_get_xendev(const char *type, int dom, int dev,
|
|||||||
xendev->evtchndev = xenevtchn_open(NULL, 0);
|
xendev->evtchndev = xenevtchn_open(NULL, 0);
|
||||||
if (xendev->evtchndev == NULL) {
|
if (xendev->evtchndev == NULL) {
|
||||||
xen_pv_printf(NULL, 0, "can't open evtchn device\n");
|
xen_pv_printf(NULL, 0, "can't open evtchn device\n");
|
||||||
g_free(xendev);
|
qdev_unplug(DEVICE(xendev), NULL);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
fcntl(xenevtchn_fd(xendev->evtchndev), F_SETFD, FD_CLOEXEC);
|
fcntl(xenevtchn_fd(xendev->evtchndev), F_SETFD, FD_CLOEXEC);
|
||||||
@ -155,7 +156,7 @@ static struct XenDevice *xen_be_get_xendev(const char *type, int dom, int dev,
|
|||||||
if (xendev->gnttabdev == NULL) {
|
if (xendev->gnttabdev == NULL) {
|
||||||
xen_pv_printf(NULL, 0, "can't open gnttab device\n");
|
xen_pv_printf(NULL, 0, "can't open gnttab device\n");
|
||||||
xenevtchn_close(xendev->evtchndev);
|
xenevtchn_close(xendev->evtchndev);
|
||||||
g_free(xendev);
|
qdev_unplug(DEVICE(xendev), NULL);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
Loading…
Reference in New Issue
Block a user