From: Kevin Wolf Date: Tue, 20 Sep 2016 11:38:41 +0000 (+0200) Subject: qdev-monitor: Factor out find_device_state() X-Git-Tag: TizenStudio_2.0_p2.3.2~9^2~14^2~5^2~167^2~20 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=6c1db528b0e1a68c342d49d032af1c707e9de87c;p=sdk%2Femulator%2Fqemu.git qdev-monitor: Factor out find_device_state() Signed-off-by: Kevin Wolf Reviewed-by: Eric Blake --- diff --git a/qdev-monitor.c b/qdev-monitor.c index e19617f..bc0213f 100644 --- a/qdev-monitor.c +++ b/qdev-monitor.c @@ -801,7 +801,7 @@ void qmp_device_add(QDict *qdict, QObject **ret_data, Error **errp) object_unref(OBJECT(dev)); } -void qmp_device_del(const char *id, Error **errp) +static DeviceState *find_device_state(const char *id, Error **errp) { Object *obj; @@ -819,15 +819,23 @@ void qmp_device_del(const char *id, Error **errp) if (!obj) { error_set(errp, ERROR_CLASS_DEVICE_NOT_FOUND, "Device '%s' not found", id); - return; + return NULL; } if (!object_dynamic_cast(obj, TYPE_DEVICE)) { error_setg(errp, "%s is not a hotpluggable device", id); - return; + return NULL; } - qdev_unplug(DEVICE(obj), errp); + return DEVICE(obj); +} + +void qmp_device_del(const char *id, Error **errp) +{ + DeviceState *dev = find_device_state(id, errp); + if (dev != NULL) { + qdev_unplug(dev, errp); + } } void qdev_machine_init(void)