[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH 58/59] migration: Disable hotplug/unplug during migr
From: |
Juan Quintela |
Subject: |
[Qemu-devel] [PATCH 58/59] migration: Disable hotplug/unplug during migration |
Date: |
Wed, 19 Apr 2017 22:59:22 +0200 |
Until we have reviewed what can/can't be hotplugged during migration,
disable it. We can enable it later for the things that we know that
work. For instance, memory hotplug during postcopy doesn't work
currently.
Signed-off-by: Juan Quintela <address@hidden>
Reviewed-by: zhanghailiang <address@hidden>
--
- Fix typo. Thanks Thomas.
- Delay migration check after we have checked that we can hotplug that
device.
- more typos
Signed-off-by: Juan Quintela <address@hidden>
---
qdev-monitor.c | 11 +++++++++++
1 file changed, 11 insertions(+)
diff --git a/qdev-monitor.c b/qdev-monitor.c
index bb3d8ba..e61d596 100644
--- a/qdev-monitor.c
+++ b/qdev-monitor.c
@@ -29,6 +29,7 @@
#include "qemu/error-report.h"
#include "qemu/help_option.h"
#include "sysemu/block-backend.h"
+#include "migration/migration.h"
/*
* Aliases were a bad idea from the start. Let's keep them
@@ -603,6 +604,11 @@ DeviceState *qdev_device_add(QemuOpts *opts, Error **errp)
return NULL;
}
+ if (!migration_is_idle()) {
+ error_setg(errp, "device_add not allowed while migrating");
+ return NULL;
+ }
+
/* create device */
dev = DEVICE(object_new(driver));
@@ -853,6 +859,11 @@ void qdev_unplug(DeviceState *dev, Error **errp)
return;
}
+ if (!migration_is_idle()) {
+ error_setg(errp, "device_del not allowed while migrating");
+ return;
+ }
+
qdev_hot_removed = true;
hotplug_ctrl = qdev_get_hotplug_handler(dev);
--
2.9.3
- Re: [Qemu-devel] [PATCH 49/59] ram: Remember last_page instead of last_offset, (continued)
- [Qemu-devel] [PATCH 50/59] ram: Change offset field in PageSearchStatus to page, Juan Quintela, 2017/04/19
- [Qemu-devel] [PATCH 51/59] ram: Use ramblock and page offset instead of absolute offset, Juan Quintela, 2017/04/19
- [Qemu-devel] [PATCH 53/59] ram: Use RAMBitmap type for coherence, Juan Quintela, 2017/04/19
- [Qemu-devel] [PATCH 52/59] ram: rename last_ram_offset() last_ram_pages(), Juan Quintela, 2017/04/19
- [Qemu-devel] [PATCH 54/59] migration: Remove MigrationState parameter from migration_is_idle(), Juan Quintela, 2017/04/19
- [Qemu-devel] [PATCH 55/59] qdev: qdev_hotplug is really a bool, Juan Quintela, 2017/04/19
- [Qemu-devel] [PATCH 57/59] qdev: Move qdev_unplug() to qdev-monitor.c, Juan Quintela, 2017/04/19
- [Qemu-devel] [PATCH 59/59] ram: Remove migration_bitmap_extend(), Juan Quintela, 2017/04/19
- [Qemu-devel] [PATCH 56/59] qdev: Export qdev_hot_removed, Juan Quintela, 2017/04/19
- [Qemu-devel] [PATCH 58/59] migration: Disable hotplug/unplug during migration,
Juan Quintela <=
- Re: [Qemu-devel] [PATCH 00/59] RAMState + qdev, no-reply, 2017/04/19