From: Paolo Bonzini <pbonzini@redhat.com>
To: qemu-devel@nongnu.org
Subject: [Qemu-devel] [PULL 15/15] qdev: correctly send DEVICE_DELETED for recursively-deleted devices
Date: Tue, 1 Jul 2014 10:35:05 +0200 [thread overview]
Message-ID: <1404203705-15674-16-git-send-email-pbonzini@redhat.com> (raw)
In-Reply-To: <1404203705-15674-1-git-send-email-pbonzini@redhat.com>
When a device is unparented (i.e. made completely hidden from management)
we want to send a DEVICE_DELETED event only if the device actually was
realized. This avoids raising DEVICE_DELETED events when device_add
fails.
However, this does not work right for recursively-deleted
devices: the whole tree is _first_ unrealized, _then_ unparented.
Then device_unparent sees realized==false and fails to trigger
the event. The solution is simply to move have_realized into
the DeviceState struct. If device_add fails, we never set the
new field to true and DEVICE_DELETED is not sent.
Fixes qemu-iotests testcase 067 (broken by commit 5942a19, though that
commit in turn fixed a possible segfault in the same test).
Reported-by: Markus Armbruster <armbru@redhat.com>
Reviewed-by: Markus Armbruster <armbru@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
---
hw/core/qdev.c | 5 +++--
include/hw/qdev-core.h | 1 +
2 files changed, 4 insertions(+), 2 deletions(-)
diff --git a/hw/core/qdev.c b/hw/core/qdev.c
index d1eba3c..c520415 100644
--- a/hw/core/qdev.c
+++ b/hw/core/qdev.c
@@ -848,6 +848,7 @@ static void device_set_realized(Object *obj, bool value, Error **errp)
if (dev->hotplugged && local_err == NULL) {
device_reset(dev);
}
+ dev->pending_deleted_event = false;
} else if (!value && dev->realized) {
QLIST_FOREACH(bus, &dev->child_bus, sibling) {
object_property_set_bool(OBJECT(bus), false, "realized",
@@ -862,6 +863,7 @@ static void device_set_realized(Object *obj, bool value, Error **errp)
if (dc->unrealize && local_err == NULL) {
dc->unrealize(dev, &local_err);
}
+ dev->pending_deleted_event = true;
}
if (local_err != NULL) {
@@ -972,7 +974,6 @@ static void device_unparent(Object *obj)
{
DeviceState *dev = DEVICE(obj);
BusState *bus;
- bool have_realized = dev->realized;
if (dev->realized) {
object_property_set_bool(obj, false, "realized", NULL);
@@ -988,7 +989,7 @@ static void device_unparent(Object *obj)
}
/* Only send event if the device had been completely realized */
- if (have_realized) {
+ if (dev->pending_deleted_event) {
gchar *path = object_get_canonical_path(OBJECT(dev));
qapi_event_send_device_deleted(!!dev->id, dev->id, path, &error_abort);
diff --git a/include/hw/qdev-core.h b/include/hw/qdev-core.h
index 9221cfc..0799ff2 100644
--- a/include/hw/qdev-core.h
+++ b/include/hw/qdev-core.h
@@ -156,6 +156,7 @@ struct DeviceState {
const char *id;
bool realized;
+ bool pending_deleted_event;
QemuOpts *opts;
int hotplugged;
BusState *parent_bus;
--
1.8.3.1
next prev parent reply other threads:[~2014-07-01 8:36 UTC|newest]
Thread overview: 17+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-07-01 8:34 [Qemu-devel] [PULL for 2.1 00/15] MemoryRegion QOMification Paolo Bonzini
2014-07-01 8:34 ` [Qemu-devel] [PULL 01/15] qom: add object_property_add_alias() Paolo Bonzini
2014-07-01 8:34 ` [Qemu-devel] [PULL 02/15] qom: add a generic mechanism to resolve paths Paolo Bonzini
2014-07-01 8:34 ` [Qemu-devel] [PULL 03/15] qom: allow creating an alias of a child<> property Paolo Bonzini
2014-07-01 8:34 ` [Qemu-devel] [PULL 04/15] mc146818rtc: add "rtc-time" link to "/machine/rtc" Paolo Bonzini
2014-07-01 8:34 ` [Qemu-devel] [PULL 05/15] qom: object: remove parent pointer when unparenting Paolo Bonzini
2014-07-01 8:34 ` [Qemu-devel] [PULL 06/15] qom: object: Ignore refs/unrefs of NULL Paolo Bonzini
2014-07-01 8:34 ` [Qemu-devel] [PULL 07/15] libqtest: escape strings in QMP commands, fix leak Paolo Bonzini
2014-07-01 8:34 ` [Qemu-devel] [PULL 08/15] memory: MemoryRegion: use /machine as default owner Paolo Bonzini
2014-07-01 8:34 ` [Qemu-devel] [PULL 09/15] memory: MemoryRegion: QOMify Paolo Bonzini
2014-07-01 8:35 ` [Qemu-devel] [PULL 10/15] memory: MemoryRegion: replace owner field with QOM parent Paolo Bonzini
2014-07-01 8:35 ` [Qemu-devel] [PULL 11/15] memory: MemoryRegion: Add container and addr props Paolo Bonzini
2014-07-01 8:35 ` [Qemu-devel] [PULL 12/15] memory: MemoryRegion: Add may-overlap and priority props Paolo Bonzini
2014-07-01 8:35 ` [Qemu-devel] [PULL 13/15] memory: MemoryRegion: Add size property Paolo Bonzini
2014-07-01 8:35 ` [Qemu-devel] [PULL 14/15] memory: do not give a name to the internal exec.c regions Paolo Bonzini
2014-07-01 8:35 ` Paolo Bonzini [this message]
2014-07-01 12:12 ` [Qemu-devel] [PULL for 2.1 00/15] MemoryRegion QOMification Peter Maydell
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1404203705-15674-16-git-send-email-pbonzini@redhat.com \
--to=pbonzini@redhat.com \
--cc=qemu-devel@nongnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).