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 29/32] migration: init dst in migration_object_init too
Date: Mon, 16 Oct 2017 14:52:13 +0800 [thread overview]
Message-ID: <20171016065216.18162-30-peterx@redhat.com> (raw)
In-Reply-To: <20171016065216.18162-1-peterx@redhat.com>
Though we may not need it, now we init both the src/dst migration
objects in migration_object_init() so that even incoming migration
object would be thread safe (it was not).
Reviewed-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
Signed-off-by: Peter Xu <peterx@redhat.com>
---
migration/migration.c | 28 +++++++++++++++-------------
1 file changed, 15 insertions(+), 13 deletions(-)
diff --git a/migration/migration.c b/migration/migration.c
index 387fbefad4..51e771685c 100644
--- a/migration/migration.c
+++ b/migration/migration.c
@@ -104,6 +104,7 @@ enum mig_rp_message_type {
dynamic creation of migration */
static MigrationState *current_migration;
+static MigrationIncomingState *current_incoming;
static bool migration_object_check(MigrationState *ms, Error **errp);
@@ -116,6 +117,18 @@ void migration_object_init(void)
assert(!current_migration);
current_migration = MIGRATION_OBJ(object_new(TYPE_MIGRATION));
+ /*
+ * Init the migrate incoming object as well no matter whether
+ * we'll use it or not.
+ */
+ assert(!current_incoming);
+ current_incoming = g_new0(MigrationIncomingState, 1);
+ current_incoming->state = MIGRATION_STATUS_NONE;
+ qemu_mutex_init(¤t_incoming->rp_mutex);
+ qemu_event_init(¤t_incoming->main_thread_load_event, false);
+ qemu_sem_init(¤t_incoming->postcopy_pause_sem_dst, 0);
+ qemu_sem_init(¤t_incoming->postcopy_pause_sem_fault, 0);
+
if (!migration_object_check(current_migration, &err)) {
error_report_err(err);
exit(1);
@@ -141,19 +154,8 @@ MigrationState *migrate_get_current(void)
MigrationIncomingState *migration_incoming_get_current(void)
{
- static bool once;
- static MigrationIncomingState mis_current;
-
- if (!once) {
- mis_current.state = MIGRATION_STATUS_NONE;
- memset(&mis_current, 0, sizeof(MigrationIncomingState));
- qemu_mutex_init(&mis_current.rp_mutex);
- qemu_event_init(&mis_current.main_thread_load_event, false);
- qemu_sem_init(&mis_current.postcopy_pause_sem_dst, 0);
- qemu_sem_init(&mis_current.postcopy_pause_sem_fault, 0);
- once = true;
- }
- return &mis_current;
+ assert(current_incoming);
+ return current_incoming;
}
void migration_incoming_state_destroy(void)
--
2.13.5
next prev parent reply other threads:[~2017-10-16 6:54 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 ` [Qemu-devel] [PATCH v3 22/32] migration: final handshake for the resume Peter Xu
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 ` Peter Xu [this message]
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-30-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).