From: Peter Xu <peterx@redhat.com>
To: qemu-devel@nongnu.org
Cc: Juan Quintela <quintela@redhat.com>,
Fabiano Rosas <farosas@suse.de>,
peterx@redhat.com
Subject: [PATCH RFC 7/7] migration: Further unify paths for multifd normal or sync requests
Date: Sun, 22 Oct 2023 16:12:11 -0400 [thread overview]
Message-ID: <20231022201211.452861-8-peterx@redhat.com> (raw)
In-Reply-To: <20231022201211.452861-1-peterx@redhat.com>
Provide multifd_send_execute() for merging duplicated codes.
The trick here is multifd_send_execute() will conditionally hold the mutex
when returned, depending on the retval.
Signed-off-by: Peter Xu <peterx@redhat.com>
---
migration/multifd.c | 51 ++++++++++++++++++++++-----------------------
1 file changed, 25 insertions(+), 26 deletions(-)
diff --git a/migration/multifd.c b/migration/multifd.c
index fe8d746ff9..0052e5daee 100644
--- a/migration/multifd.c
+++ b/migration/multifd.c
@@ -717,6 +717,29 @@ static bool multifd_do_send(MultiFDSendParams *p, Error **errp)
return true;
}
+/*
+ * When succeed: returns true, mutex held.
+ * When failed: returns false, mutex released.
+ */
+static bool multifd_send_execute(MultiFDSendParams *p, Error **errp)
+{
+ if (!multifd_send_prepare(p, errp)) {
+ qemu_mutex_unlock(&p->mutex);
+ assert(*errp);
+ return false;
+ }
+
+ /* Send the packets without mutex */
+ qemu_mutex_unlock(&p->mutex);
+ if (!multifd_do_send(p, errp)) {
+ assert(*errp);
+ return false;
+ }
+ qemu_mutex_lock(&p->mutex);
+
+ return true;
+}
+
static void *multifd_send_thread(void *opaque)
{
MultiFDSendParams *p = opaque;
@@ -746,40 +769,16 @@ static void *multifd_send_thread(void *opaque)
qemu_mutex_lock(&p->mutex);
if (p->pending_job) {
- if (!multifd_send_prepare(p, &local_err)) {
- assert(local_err);
- qemu_mutex_unlock(&p->mutex);
+ if (!multifd_send_execute(p, &local_err)) {
goto out;
}
-
- /* Send the packets without mutex */
- qemu_mutex_unlock(&p->mutex);
- if (!multifd_do_send(p, &local_err)) {
- assert(local_err);
- goto out;
- }
- qemu_mutex_lock(&p->mutex);
-
- /* Send successful, mark the task completed */
p->pending_job = false;
} else if (p->pending_sync) {
p->flags |= MULTIFD_FLAG_SYNC;
-
- if (!multifd_send_prepare(p, &local_err)) {
- assert(local_err);
- qemu_mutex_unlock(&p->mutex);
- goto out;
- }
-
- /* Send the packets without mutex */
- qemu_mutex_unlock(&p->mutex);
- if (!multifd_do_send(p, &local_err)) {
- assert(local_err);
+ if (!multifd_send_execute(p, &local_err)) {
goto out;
}
- qemu_mutex_lock(&p->mutex);
-
qemu_sem_post(&p->sem_sync);
p->pending_sync = false;
}
--
2.41.0
prev parent reply other threads:[~2023-10-22 20:13 UTC|newest]
Thread overview: 20+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-10-22 20:12 [PATCH RFC 0/7] migration/multifd: quit unitifications and separate sync packet Peter Xu
2023-10-22 20:12 ` [PATCH RFC 1/7] migration: Drop stale comment for multifd zero copy Peter Xu
2023-10-23 14:16 ` Fabiano Rosas
2023-10-22 20:12 ` [PATCH RFC 2/7] migration: Fix error leak in multifd_tls_outgoing_handshake() Peter Xu
2023-10-23 14:17 ` Fabiano Rosas
2023-10-22 20:12 ` [PATCH RFC 3/7] migration: multifd_send_kick_main() Peter Xu
2023-10-23 14:43 ` Fabiano Rosas
2023-11-08 22:49 ` Fabiano Rosas
2023-11-09 16:50 ` Peter Xu
2023-11-09 17:00 ` Fabiano Rosas
2023-10-22 20:12 ` [PATCH RFC 4/7] migration: Drop MultiFDSendParams.quit and cleanup error paths Peter Xu
2023-10-23 14:42 ` Fabiano Rosas
2023-10-23 14:53 ` Peter Xu
2023-10-23 15:35 ` Fabiano Rosas
2023-10-23 15:54 ` Peter Xu
2023-10-22 20:12 ` [PATCH RFC 5/7] migration: Modulize multifd send threads with a few helpers Peter Xu
2023-10-22 20:12 ` [PATCH RFC 6/7] migration: Split multifd pending_job into two booleans Peter Xu
2023-10-23 15:15 ` Fabiano Rosas
2023-10-23 15:52 ` Peter Xu
2023-10-22 20:12 ` Peter Xu [this message]
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=20231022201211.452861-8-peterx@redhat.com \
--to=peterx@redhat.com \
--cc=farosas@suse.de \
--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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.