From: Peter Xu <peterx@redhat.com>
To: qemu-devel@nongnu.org
Cc: Andrea Arcangeli <aarcange@redhat.com>,
"Daniel P . Berrange" <berrange@redhat.com>,
Juan Quintela <quintela@redhat.com>,
Alexey Perevalov <a.perevalov@samsung.com>,
"Dr . David Alan Gilbert" <dgilbert@redhat.com>,
peterx@redhat.com
Subject: [Qemu-devel] [PATCH v3 22/32] migration: final handshake for the resume
Date: Mon, 16 Oct 2017 14:52:06 +0800 [thread overview]
Message-ID: <20171016065216.18162-23-peterx@redhat.com> (raw)
In-Reply-To: <20171016065216.18162-1-peterx@redhat.com>
Finish the last step to do the final handshake for the recovery.
First source sends one MIG_CMD_RESUME to dst, telling that source is
ready to resume.
Then, dest replies with MIG_RP_MSG_RESUME_ACK to source, telling that
dest is ready to resume (after switch to postcopy-active state).
When source received the RESUME_ACK, it switches its state to
postcopy-active, and finally the recovery is completed.
Reviewed-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
Signed-off-by: Peter Xu <peterx@redhat.com>
---
migration/migration.c | 28 ++++++++++++++++++++++++----
1 file changed, 24 insertions(+), 4 deletions(-)
diff --git a/migration/migration.c b/migration/migration.c
index 52f81c3add..edf7365b69 100644
--- a/migration/migration.c
+++ b/migration/migration.c
@@ -1807,7 +1807,8 @@ static int migrate_handle_rp_resume_ack(MigrationState *s, uint32_t value)
migrate_set_state(&s->state, MIGRATION_STATUS_POSTCOPY_RECOVER,
MIGRATION_STATUS_POSTCOPY_ACTIVE);
- /* TODO: notify send thread that time to continue send pages */
+ /* Notify send thread that time to continue send pages */
+ qemu_sem_post(&s->rp_state.rp_sem);
return 0;
}
@@ -2290,6 +2291,21 @@ typedef enum MigThrError {
MIG_THR_ERR_FATAL = 2,
} MigThrError;
+static int postcopy_resume_handshake(MigrationState *s)
+{
+ qemu_savevm_send_postcopy_resume(s->to_dst_file);
+
+ while (s->state == MIGRATION_STATUS_POSTCOPY_RECOVER) {
+ qemu_sem_wait(&s->rp_state.rp_sem);
+ }
+
+ if (s->state == MIGRATION_STATUS_POSTCOPY_ACTIVE) {
+ return 0;
+ }
+
+ return -1;
+}
+
/* Return zero if success, or <0 for error */
static int postcopy_do_resume(MigrationState *s)
{
@@ -2307,10 +2323,14 @@ static int postcopy_do_resume(MigrationState *s)
}
/*
- * TODO: handshake with dest using MIG_CMD_RESUME,
- * MIG_RP_MSG_RESUME_ACK, then switch source state to
- * "postcopy-active"
+ * Last handshake with destination on the resume (destination will
+ * switch to postcopy-active afterwards)
*/
+ ret = postcopy_resume_handshake(s);
+ if (ret) {
+ error_report("%s: handshake failed: %d", __func__, ret);
+ return ret;
+ }
return 0;
}
--
2.13.5
next prev parent reply other threads:[~2017-10-16 6:53 UTC|newest]
Thread overview: 39+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-10-16 6:51 [Qemu-devel] [PATCH v3 00/32] Migration: postcopy failure recovery Peter Xu
2017-10-16 6:51 ` [Qemu-devel] [PATCH v3 01/32] migration: better error handling with QEMUFile Peter Xu
2017-10-16 6:51 ` [Qemu-devel] [PATCH v3 02/32] migration: reuse mis->userfault_quit_fd Peter Xu
2017-10-16 6:51 ` [Qemu-devel] [PATCH v3 03/32] migration: provide postcopy_fault_thread_notify() Peter Xu
2017-10-16 6:51 ` [Qemu-devel] [PATCH v3 04/32] migration: new postcopy-pause state Peter Xu
2017-10-16 6:51 ` [Qemu-devel] [PATCH v3 05/32] migration: implement "postcopy-pause" src logic Peter Xu
2017-10-16 6:51 ` [Qemu-devel] [PATCH v3 06/32] migration: allow dst vm pause on postcopy Peter Xu
2017-10-16 6:51 ` [Qemu-devel] [PATCH v3 07/32] migration: allow src return path to pause Peter Xu
2017-10-16 6:51 ` [Qemu-devel] [PATCH v3 08/32] migration: allow send_rq to fail Peter Xu
2017-10-16 6:51 ` [Qemu-devel] [PATCH v3 09/32] migration: allow fault thread to pause Peter Xu
2017-10-16 6:51 ` [Qemu-devel] [PATCH v3 10/32] qmp: hmp: add migrate "resume" option Peter Xu
2017-10-16 6:51 ` [Qemu-devel] [PATCH v3 11/32] migration: pass MigrationState to migrate_init() Peter Xu
2017-10-16 6:51 ` [Qemu-devel] [PATCH v3 12/32] migration: rebuild channel on source Peter Xu
2017-10-16 6:51 ` [Qemu-devel] [PATCH v3 13/32] migration: new state "postcopy-recover" Peter Xu
2017-10-16 6:51 ` [Qemu-devel] [PATCH v3 14/32] migration: wakeup dst ram-load-thread for recover Peter Xu
2017-10-16 6:51 ` [Qemu-devel] [PATCH v3 15/32] migration: new cmd MIG_CMD_RECV_BITMAP Peter Xu
2017-10-16 6:52 ` [Qemu-devel] [PATCH v3 16/32] migration: new message MIG_RP_MSG_RECV_BITMAP Peter Xu
2017-10-16 6:52 ` [Qemu-devel] [PATCH v3 17/32] migration: new cmd MIG_CMD_POSTCOPY_RESUME Peter Xu
2017-10-16 6:52 ` [Qemu-devel] [PATCH v3 18/32] migration: new message MIG_RP_MSG_RESUME_ACK Peter Xu
2017-10-16 6:52 ` [Qemu-devel] [PATCH v3 19/32] migration: introduce SaveVMHandlers.resume_prepare Peter Xu
2017-10-16 6:52 ` [Qemu-devel] [PATCH v3 20/32] migration: synchronize dirty bitmap for resume Peter Xu
2017-10-16 6:52 ` [Qemu-devel] [PATCH v3 21/32] migration: setup ramstate " Peter Xu
2017-10-16 6:52 ` Peter Xu [this message]
2017-10-16 6:52 ` [Qemu-devel] [PATCH v3 23/32] migration: free SocketAddress where allocated Peter Xu
2017-10-16 6:52 ` [Qemu-devel] [PATCH v3 24/32] migration: return incoming task tag for sockets Peter Xu
2017-10-16 6:52 ` [Qemu-devel] [PATCH v3 25/32] migration: return incoming task tag for exec Peter Xu
2017-10-16 6:52 ` [Qemu-devel] [PATCH v3 26/32] migration: return incoming task tag for fd Peter Xu
2017-10-16 6:52 ` [Qemu-devel] [PATCH v3 27/32] migration: store listen task tag Peter Xu
2017-10-16 6:52 ` [Qemu-devel] [PATCH v3 28/32] migration: allow migrate_incoming for paused VM Peter Xu
2017-10-16 6:52 ` [Qemu-devel] [PATCH v3 29/32] migration: init dst in migration_object_init too Peter Xu
2017-10-16 6:52 ` [Qemu-devel] [PATCH v3 30/32] migration: delay the postcopy-active state switch Peter Xu
2017-10-16 6:52 ` [Qemu-devel] [PATCH v3 31/32] migration, qmp: new command "migrate-pause" Peter Xu
2017-10-16 7:06 ` Peter Xu
2017-10-16 6:52 ` [Qemu-devel] [PATCH v3 32/32] migration, hmp: new command "migrate_pause" Peter Xu
2017-10-16 7:32 ` [Qemu-devel] [PATCH v3 00/32] Migration: postcopy failure recovery no-reply
2017-10-16 9:41 ` Peter Xu
2017-10-30 9:29 ` Juan Quintela
2017-10-16 8:05 ` no-reply
2017-10-16 9:43 ` Peter Xu
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=20171016065216.18162-23-peterx@redhat.com \
--to=peterx@redhat.com \
--cc=a.perevalov@samsung.com \
--cc=aarcange@redhat.com \
--cc=berrange@redhat.com \
--cc=dgilbert@redhat.com \
--cc=qemu-devel@nongnu.org \
--cc=quintela@redhat.com \
/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).