aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarkus Armbruster <armbru@redhat.com>2019-04-01 11:08:23 +0200
committerMarkus Armbruster <armbru@redhat.com>2019-04-02 13:35:00 +0200
commit2fa23277d58ce7ec527541b3baf52894ded530cc (patch)
treec7ccddf84f04380a921a23978c867bc35fa63f4a
parent5cc8f9eb7a11e2c8635c2e62d7651daf9e3bff42 (diff)
downloadqemu-2fa23277d58ce7ec527541b3baf52894ded530cc.zip
qemu-2fa23277d58ce7ec527541b3baf52894ded530cc.tar.gz
qemu-2fa23277d58ce7ec527541b3baf52894ded530cc.tar.bz2
Revert "vl: Fix to create migration object before block backends again"
This reverts commit e60483f2f8498ae08ae79ca4c6fb03a3317f5e1e. Recent commit cda4aa9a5a0 moved block backend creation before machine property evaluation. This broke block backends registering migration blockers. Commit e60483f2f84 fixed it by moving migration object creation before block backend creation. This broke migration with Xen. Turns out we need to configure the accelerator before we create the migration object so that Xen's accelerator compat properties get applied. Revert the flawed commit. This fixes the Xen regression, but brings back the block backend regression. The next commits will fix it again. Signed-off-by: Markus Armbruster <armbru@redhat.com> Message-Id: <20190401090827.20793-2-armbru@redhat.com> Reviewed-by: Igor Mammedov <imammedo@redhat.com>
-rw-r--r--vl.c15
1 files changed, 7 insertions, 8 deletions
diff --git a/vl.c b/vl.c
index 24572de..9b21534 100644
--- a/vl.c
+++ b/vl.c
@@ -4278,16 +4278,9 @@ int main(int argc, char **argv, char **envp)
}
/*
- * Migration object can only be created after global properties
- * are applied correctly.
- */
- migration_object_init();
-
- /*
* Note: we need to create block backends before
* machine_set_property(), so machine properties can refer to
- * them, and after migration_object_init(), so we can create
- * migration blockers.
+ * them.
*/
configure_blockdev(&bdo_queue, machine_class, snapshot);
@@ -4305,6 +4298,12 @@ int main(int argc, char **argv, char **envp)
machine_class->name, machine_class->deprecation_reason);
}
+ /*
+ * Migration object can only be created after global properties
+ * are applied correctly.
+ */
+ migration_object_init();
+
if (qtest_chrdev) {
qtest_init(qtest_chrdev, qtest_log, &error_fatal);
}