From: Stefan Hajnoczi <stefanha@redhat.com>
To: qemu-devel@nongnu.org
Cc: Peter Maydell <peter.maydell@linaro.org>,
Max Reitz <mreitz@redhat.com>,
"Michael S. Tsirkin" <mst@redhat.com>,
Kevin Wolf <kwolf@redhat.com>,
qemu-block@nongnu.org, Stefan Hajnoczi <stefanha@redhat.com>,
Peter Xu <peterx@redhat.com>
Subject: [Qemu-devel] [PULL 6/7] iothread: push gcontext earlier in the thread_fn
Date: Fri, 8 Mar 2019 16:53:43 +0000 [thread overview]
Message-ID: <20190308165344.10685-7-stefanha@redhat.com> (raw)
In-Reply-To: <20190308165344.10685-1-stefanha@redhat.com>
From: Peter Xu <peterx@redhat.com>
We were pushing the context until right before running the gmainloop.
Now since we have everything unconditionally, we can move this
earlier.
One benefit is that now it's done even before init_done_sem, so as
long as the iothread user calls iothread_create() and completes, we
know that the thread stack is ready.
Signed-off-by: Peter Xu <peterx@redhat.com>
Message-id: 20190306115532.23025-5-peterx@redhat.com
Message-Id: <20190306115532.23025-5-peterx@redhat.com>
[Tweaked comment wording as discussed with Peter Xu.
--Stefan]
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
---
iothread.c | 9 ++++++---
1 file changed, 6 insertions(+), 3 deletions(-)
diff --git a/iothread.c b/iothread.c
index 9abdbace66..ad64c757ac 100644
--- a/iothread.c
+++ b/iothread.c
@@ -53,7 +53,11 @@ static void *iothread_run(void *opaque)
IOThread *iothread = opaque;
rcu_register_thread();
-
+ /*
+ * g_main_context_push_thread_default() must be called before anything
+ * in this new thread uses glib.
+ */
+ g_main_context_push_thread_default(iothread->worker_context);
my_iothread = iothread;
iothread->thread_id = qemu_get_thread_id();
qemu_sem_post(&iothread->init_done_sem);
@@ -66,12 +70,11 @@ static void *iothread_run(void *opaque)
* changed in previous aio_poll()
*/
if (iothread->running && atomic_read(&iothread->run_gcontext)) {
- g_main_context_push_thread_default(iothread->worker_context);
g_main_loop_run(iothread->main_loop);
- g_main_context_pop_thread_default(iothread->worker_context);
}
}
+ g_main_context_pop_thread_default(iothread->worker_context);
rcu_unregister_thread();
return NULL;
}
--
2.20.1
next prev parent reply other threads:[~2019-03-08 16:54 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-03-08 16:53 [Qemu-devel] [PULL 0/7] Block patches Stefan Hajnoczi
2019-03-08 16:53 ` [Qemu-devel] [PULL 1/7] MAINTAINERS: add missing support status fields Stefan Hajnoczi
2019-03-08 16:53 ` [Qemu-devel] [PULL 2/7] hw/block/virtio-blk: Clean req->dev repetitions Stefan Hajnoczi
2019-03-08 16:53 ` [Qemu-devel] [PULL 3/7] iothread: replace init_done_cond with a semaphore Stefan Hajnoczi
2019-03-08 16:53 ` [Qemu-devel] [PULL 4/7] iothread: create the gcontext unconditionally Stefan Hajnoczi
2019-03-08 16:53 ` [Qemu-devel] [PULL 5/7] iothread: create main loop unconditionally Stefan Hajnoczi
2019-03-08 16:53 ` Stefan Hajnoczi [this message]
2019-03-08 16:53 ` [Qemu-devel] [PULL 7/7] iothread: document about why we need explicit aio_poll() Stefan Hajnoczi
2019-03-09 20:55 ` [Qemu-devel] [PULL 0/7] Block patches Peter Maydell
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=20190308165344.10685-7-stefanha@redhat.com \
--to=stefanha@redhat.com \
--cc=kwolf@redhat.com \
--cc=mreitz@redhat.com \
--cc=mst@redhat.com \
--cc=peter.maydell@linaro.org \
--cc=peterx@redhat.com \
--cc=qemu-block@nongnu.org \
--cc=qemu-devel@nongnu.org \
/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).