From: Peter Xu <peterx@redhat.com>
To: Markus Armbruster <armbru@redhat.com>
Cc: qemu-devel@nongnu.org,
"Dr . David Alan Gilbert" <dgilbert@redhat.com>,
"Stefan Hajnoczi" <stefanha@redhat.com>,
"Marc-André Lureau" <marcandre.lureau@redhat.com>,
"Paolo Bonzini" <pbonzini@redhat.com>
Subject: Re: [Qemu-devel] [PATCH v3] monitor: let cur_mon be per-thread
Date: Wed, 23 May 2018 17:04:50 +0800 [thread overview]
Message-ID: <20180523090450.GC2540@xz-mi> (raw)
In-Reply-To: <87sh6iixvp.fsf@dusky.pond.sub.org>
On Wed, May 23, 2018 at 10:23:22AM +0200, Markus Armbruster wrote:
> Peter Xu <peterx@redhat.com> writes:
>
> > In the future the monitor iothread may be accessing the cur_mon as
> > well (via monitor_qmp_dispatch_one()). Before we introduce a real
> > Out-Of-Band command,
>
> Uh, inhowfar are the commands marked allow-oob: true now not real?
> These are migrate-recover, migrate-pause, x-oob-test.
x-oob-test is unreal; the rest are real.
>
> Aside: having x-oob-test in QEMU proper is awful. Is there really no
> way around it?
I tried hard to think of a way but failed. I need to let the
dispatcher stuck for a while, nothing can guarantee that but a lock. I
was using migration before to make sure dispatcher won't quite very
soon, but we have problems there since:
- some architectures may not even have RAM, so snapshot of those
platforms can still be super fast;
- even if we make sure RAM is big, the time will depend on the speed
of system, say, what if the test environment is running on RAM-disk
which is still super fast even to dump the whole RAM onto disk? As
a conclusion - time based command won't work, because time is always
a relative value, which can be affected by OS scheduler and system
environments.
When there is better suggestion we can remove x-oob-test, but I can't
see any so far.
>
> > let's convert the cur_mon variable to be a
> > per-thread variable to make sure there won't be a race between threads.
> >
> > Note that thread variables are not initialized to a valid value when new
> > thread is created. However for our case we don't need to set it up,
> > since the cur_mon variable is only used in such a pattern:
> >
> > old_mon = cur_mon;
> > cur_mon = xxx;
> > (do something, read cur_mon if necessary in the stack)
> > cur_mon = old_mon;
> >
> > It plays a role as stack variable, so no need to be initialized at all.
> > We only need to make sure the variable won't be changed unexpectedly by
> > other threads.
>
> Do we plan to keep switching cur_mon forever? Or do we intend to work
> towards a 1:1 association between Monitor struct and monitor thread?
I still don't see a good way to remove the cur_mon switching... E.g.,
in qmp_human_monitor_command() we'll switch no matter what.
>
> Even if we want the latter, I'm okay with this patch as an intermediate
> step.
That'll be appreciated. Thanks,
>
> > Signed-off-by: Peter Xu <peterx@redhat.com>
--
Peter Xu
next prev parent reply other threads:[~2018-05-23 9:05 UTC|newest]
Thread overview: 19+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-04-12 6:11 [Qemu-devel] [PATCH v3] monitor: let cur_mon be per-thread Peter Xu
2018-04-12 15:22 ` Eric Blake
2018-04-13 10:43 ` Marc-André Lureau
2018-04-16 8:37 ` Stefan Hajnoczi
2018-04-16 9:17 ` Peter Xu
2018-04-17 7:08 ` Stefan Hajnoczi
2018-04-17 9:05 ` Markus Armbruster
2018-04-18 5:12 ` Stefan Hajnoczi
2018-04-18 6:35 ` Peter Xu
2018-04-18 7:45 ` Markus Armbruster
2018-04-18 8:01 ` Peter Xu
2018-05-22 3:48 ` Peter Xu
2018-05-23 8:23 ` Markus Armbruster
2018-05-23 9:04 ` Peter Xu [this message]
2018-05-23 13:13 ` Markus Armbruster
2018-05-24 4:29 ` Peter Xu
2018-05-24 8:22 ` Markus Armbruster
2018-05-24 8:42 ` Peter Xu
2018-05-24 11:13 ` Markus Armbruster
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=20180523090450.GC2540@xz-mi \
--to=peterx@redhat.com \
--cc=armbru@redhat.com \
--cc=dgilbert@redhat.com \
--cc=marcandre.lureau@redhat.com \
--cc=pbonzini@redhat.com \
--cc=qemu-devel@nongnu.org \
--cc=stefanha@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.