|
|
a83cc2 |
From 5e1535771bba299aae4de2d810100fa7fedfeca8 Mon Sep 17 00:00:00 2001
|
|
|
a83cc2 |
From: Peter Xu <peterx@redhat.com>
|
|
|
a83cc2 |
Date: Tue, 29 Jun 2021 14:13:56 -0400
|
|
|
a83cc2 |
Subject: [PATCH 02/39] migration: Allow reset of postcopy_recover_triggered
|
|
|
a83cc2 |
when failed
|
|
|
a83cc2 |
MIME-Version: 1.0
|
|
|
a83cc2 |
Content-Type: text/plain; charset=UTF-8
|
|
|
a83cc2 |
Content-Transfer-Encoding: 8bit
|
|
|
a83cc2 |
|
|
|
a83cc2 |
RH-Author: Leonardo BrĂ¡s <leobras@redhat.com>
|
|
|
a83cc2 |
RH-MergeRequest: 25: migration: Move yank outside qemu_start_incoming_migration()
|
|
|
a83cc2 |
RH-Commit: [2/2] b766a7f36df4f889d74a2e8d518e1100e52ab726 (LeoBras/centos-qemu-kvm)
|
|
|
a83cc2 |
RH-Bugzilla: 1974683
|
|
|
a83cc2 |
RH-Acked-by: Miroslav Rezanina <mrezanin@redhat.com>
|
|
|
a83cc2 |
RH-Acked-by: Peter Xu <Peter Xu <peterx@redhat.com>>
|
|
|
a83cc2 |
|
|
|
a83cc2 |
It's possible qemu_start_incoming_migration() failed at any point, when it
|
|
|
a83cc2 |
happens we should reset postcopy_recover_triggered to false so that the user
|
|
|
a83cc2 |
can still retry with a saner incoming port.
|
|
|
a83cc2 |
|
|
|
a83cc2 |
Signed-off-by: Peter Xu <peterx@redhat.com>
|
|
|
a83cc2 |
Message-Id: <20210629181356.217312-3-peterx@redhat.com>
|
|
|
a83cc2 |
Reviewed-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
|
|
|
a83cc2 |
Signed-off-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
|
|
|
a83cc2 |
(cherry picked from commit b7f9afd48e7bc5c341e55348f2c2eed08314be7d)
|
|
|
a83cc2 |
Fixes: b5eea99e ("migration: Add yank feature", 2021-01-13)
|
|
|
a83cc2 |
Signed-off-by: Leonardo Bras <leobras@redhat.com>
|
|
|
a83cc2 |
Signed-off-by: Miroslav Rezanina <mrezanin@redhat.com>
|
|
|
a83cc2 |
---
|
|
|
a83cc2 |
migration/migration.c | 13 +++++++++++++
|
|
|
a83cc2 |
1 file changed, 13 insertions(+)
|
|
|
a83cc2 |
|
|
|
a83cc2 |
diff --git a/migration/migration.c b/migration/migration.c
|
|
|
a83cc2 |
index f077640df2..9d185f0e28 100644
|
|
|
a83cc2 |
--- a/migration/migration.c
|
|
|
a83cc2 |
+++ b/migration/migration.c
|
|
|
a83cc2 |
@@ -2109,6 +2109,13 @@ void qmp_migrate_recover(const char *uri, Error **errp)
|
|
|
a83cc2 |
{
|
|
|
a83cc2 |
MigrationIncomingState *mis = migration_incoming_get_current();
|
|
|
a83cc2 |
|
|
|
a83cc2 |
+ /*
|
|
|
a83cc2 |
+ * Don't even bother to use ERRP_GUARD() as it _must_ always be set by
|
|
|
a83cc2 |
+ * callers (no one should ignore a recover failure); if there is, it's a
|
|
|
a83cc2 |
+ * programming error.
|
|
|
a83cc2 |
+ */
|
|
|
a83cc2 |
+ assert(errp);
|
|
|
a83cc2 |
+
|
|
|
a83cc2 |
if (mis->state != MIGRATION_STATUS_POSTCOPY_PAUSED) {
|
|
|
a83cc2 |
error_setg(errp, "Migrate recover can only be run "
|
|
|
a83cc2 |
"when postcopy is paused.");
|
|
|
a83cc2 |
@@ -2127,6 +2134,12 @@ void qmp_migrate_recover(const char *uri, Error **errp)
|
|
|
a83cc2 |
* to continue using that newly established channel.
|
|
|
a83cc2 |
*/
|
|
|
a83cc2 |
qemu_start_incoming_migration(uri, errp);
|
|
|
a83cc2 |
+
|
|
|
a83cc2 |
+ /* Safe to dereference with the assert above */
|
|
|
a83cc2 |
+ if (*errp) {
|
|
|
a83cc2 |
+ /* Reset the flag so user could still retry */
|
|
|
a83cc2 |
+ qatomic_set(&mis->postcopy_recover_triggered, false);
|
|
|
a83cc2 |
+ }
|
|
|
a83cc2 |
}
|
|
|
a83cc2 |
|
|
|
a83cc2 |
void qmp_migrate_pause(Error **errp)
|
|
|
a83cc2 |
--
|
|
|
a83cc2 |
2.27.0
|
|
|
a83cc2 |
|