All of lore.kernel.org
 help / color / mirror / Atom feed
From: Peter Xu <peterx@redhat.com>
To: Stefan Hajnoczi <stefanha@redhat.com>
Cc: qemu-devel@nongnu.org, Stefan Hajnoczi <shajnocz@redhat.com>,
	"Daniel P . Berrange" <berrange@redhat.com>,
	Paolo Bonzini <pbonzini@redhat.com>, Fam Zheng <famz@redhat.com>,
	Juan Quintela <quintela@redhat.com>,
	mdroth@linux.vnet.ibm.com, Eric Blake <eblake@redhat.com>,
	Laurent Vivier <lvivier@redhat.com>,
	Markus Armbruster <armbru@redhat.com>,
	marcandre.lureau@redhat.com,
	"Dr . David Alan Gilbert" <dgilbert@redhat.com>
Subject: Re: [Qemu-devel] [RFC v5 21/26] qmp: isolate responses into io thread
Date: Mon, 18 Dec 2017 15:32:29 +0800	[thread overview]
Message-ID: <20171218073229.GP22308@xz-mi> (raw)
In-Reply-To: <20171218055217.GN22308@xz-mi>

On Mon, Dec 18, 2017 at 01:52:17PM +0800, Peter Xu wrote:
> On Thu, Dec 14, 2017 at 01:43:59PM +0000, Stefan Hajnoczi wrote:
> > On Tue, Dec 05, 2017 at 01:51:55PM +0800, Peter Xu wrote:
> > > @@ -4429,6 +4515,13 @@ void monitor_cleanup(void)
> > >       */
> > >      iothread_stop(mon_global.mon_iothread);
> > >  
> > > +    /*
> > > +     * After we have IOThread to send responses, it's possible that
> > > +     * when we stop the IOThread there are still replies queued in the
> > > +     * responder queue.  Flush all of them.
> > > +     */
> > > +    monitor_qmp_bh_responder(NULL);
> > 
> > This doesn't work because monitor_qmp_bh_responder() does not guarantee
> > that the full response has been written when it returns.
> > 
> > When qemu_chr_fe_write() returns EAGAIN then qemu_chr_fe_add_watch() is
> > used to register an event loop callback when the chardev becomes
> > writable again.  But you stopped the event loop using iothread_stop() so
> > we will never complete the write.
> 
> Good catch...
> 
> Actually I just noticed that for char frontend I missed a place to use
> the chardev context for polling.  So before the flushing I possibly
> need this:
> 
> diff --git a/chardev/char-fe.c b/chardev/char-fe.c                             
> index ee6d596100..462c529f19 100644    
> --- a/chardev/char-fe.c                
> +++ b/chardev/char-fe.c                
> @@ -356,7 +356,7 @@ guint qemu_chr_fe_add_watch(CharBackend *be, GIOCondition cond,                                                                           
>      }                                 
>                                        
>      g_source_set_callback(src, (GSourceFunc)func, user_data, NULL);           
> -    tag = g_source_attach(src, NULL); 
> +    tag = g_source_attach(src, be->chr->gcontext);                            
>      g_source_unref(src);              
>                                        
>      return tag;                       
> 
> Otherwise it'll be still be run in main thread always.
> 
> (I guess I haven't yet encountered an EAGAIN for it so far)
> 
> > 
> > I suggest draining the monitor while the IOThread is still running
> > (that way the AioContext and GMainContext are still operational).  You
> > can:
> > 1. Suspend the monitor so new commands will not be read.
> > 2. Wait until all responses and outbuf are empty.
> > 
> > Another option is moving the chardev back to the main loop but I'm not
> > sure if the chardev subsystem supports that.
> 
> Your suggestion is good to me.  I'll do that in IOThread before it
> stops.  Thanks!

Hmm, after a second thought, I think maybe it would be nicer to just
call monitor_flush() after the monitor iothread is stopped.

Firstly, that is perfectly legal - since AFAICT commit 6cff3e8594
("monitor: protect outbuf and mux_out with mutex", 2014-06-23) is
tailored for doing that, though that was for block iothread, not
monitor.

Then, it's still possible that the write buffer is full and we got
EAGAIN during flushing.  Then we'll plug another task into the monitor
gcontext which will never run since the iothread is stopped already.
IMHO that's totally fine - I think it's already our best effort to
flush the out buffer once at this point.  If the buffer is still full
after one attemp of monitor_flush(), we should just give up the 2nd
flushing instead of waiting here.  After all, we are quitting QEMU.

As a summary, my planned change of this issue would be quite
straightforward: call monitor_flush() when looping over monitors,
before destroying them.  And when destroying, if there is dangling
Monitor.out_watch, detach them.  Hope that works.  Thanks,

-- 
Peter Xu

  reply	other threads:[~2017-12-18  7:32 UTC|newest]

Thread overview: 113+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2017-12-05  5:51 [Qemu-devel] [RFC v5 00/26] QMP: out-of-band (OOB) execution support Peter Xu
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 01/26] qobject: introduce qstring_get_try_str() Peter Xu
2017-12-13 15:25   ` Stefan Hajnoczi
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 02/26] qobject: introduce qobject_get_try_str() Peter Xu
2017-12-13 15:25   ` Stefan Hajnoczi
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 03/26] qobject: let object_property_get_str() use new API Peter Xu
2017-12-13 15:27   ` Stefan Hajnoczi
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 04/26] monitor: move skip_flush into monitor_data_init Peter Xu
2017-12-13 15:28   ` Stefan Hajnoczi
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 05/26] qjson: add "opaque" field to JSONMessageParser Peter Xu
2017-12-13 15:37   ` Stefan Hajnoczi
2017-12-15  7:55     ` Peter Xu
2017-12-15 12:45       ` Stefan Hajnoczi
2017-12-16  3:28         ` Peter Xu
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 06/26] monitor: move the cur_mon hack deeper for QMP Peter Xu
2017-12-13 15:41   ` Stefan Hajnoczi
2017-12-15  8:02     ` Peter Xu
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 07/26] monitor: unify global init Peter Xu
2017-12-13 15:48   ` Stefan Hajnoczi
2017-12-15  8:11     ` Peter Xu
2017-12-15 12:47       ` Stefan Hajnoczi
2017-12-16  3:52         ` Peter Xu
2017-12-16  9:01           ` Stefan Hajnoczi
2017-12-18  3:27             ` Peter Xu
2017-12-18  9:24               ` Stefan Hajnoczi
2017-12-18 10:10                 ` Peter Xu
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 08/26] monitor: let mon_list be tail queue Peter Xu
2017-12-13 15:49   ` Stefan Hajnoczi
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 09/26] monitor: create monitor dedicate iothread Peter Xu
2017-12-13 16:20   ` Stefan Hajnoczi
2017-12-15  8:31     ` Peter Xu
2017-12-15 13:21       ` Stefan Hajnoczi
2017-12-16  4:42         ` Peter Xu
2017-12-16  4:50           ` Peter Xu
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 10/26] monitor: allow to use IO thread for parsing Peter Xu
2017-12-13 16:35   ` Stefan Hajnoczi
2017-12-15  8:50     ` Peter Xu
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 11/26] qmp: introduce QMPCapability Peter Xu
2017-12-13 16:56   ` Stefan Hajnoczi
2017-12-15  9:14     ` Peter Xu
2017-12-15  9:38       ` Fam Zheng
2017-12-16  3:58         ` Peter Xu
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 12/26] qmp: negociate QMP capabilities Peter Xu
2017-12-12 17:39   ` Dr. David Alan Gilbert
2017-12-13 17:19   ` Stefan Hajnoczi
2017-12-15  9:40     ` Fam Zheng
2017-12-15 13:26       ` Stefan Hajnoczi
2017-12-15 13:53         ` Fam Zheng
2017-12-16  5:34           ` Peter Xu
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 13/26] qmp: introduce some capability helpers Peter Xu
2017-12-12 17:44   ` Dr. David Alan Gilbert
2017-12-13 17:20   ` Stefan Hajnoczi
2017-12-15  9:42   ` Fam Zheng
2017-12-16  5:45     ` Peter Xu
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 14/26] monitor: introduce monitor_qmp_respond() Peter Xu
2017-12-13 17:35   ` Stefan Hajnoczi
2017-12-16  5:52     ` Peter Xu
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 15/26] monitor: let suspend_cnt be thread safe Peter Xu
2017-12-13 18:43   ` Stefan Hajnoczi
2017-12-16  6:12     ` Peter Xu
2017-12-16  9:11       ` Stefan Hajnoczi
2017-12-18  5:16         ` Peter Xu
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 16/26] monitor: separate QMP parser and dispatcher Peter Xu
2017-12-13 20:09   ` Stefan Hajnoczi
2017-12-16  6:37     ` Peter Xu
2017-12-16  6:46       ` Peter Xu
2017-12-16  9:23       ` Stefan Hajnoczi
2017-12-18  5:26         ` Peter Xu
2017-12-18  9:10           ` Stefan Hajnoczi
2017-12-18 10:03             ` Peter Xu
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 17/26] qmp: add new event "request-dropped" Peter Xu
2017-12-14 11:16   ` Stefan Hajnoczi
2017-12-16  6:59     ` Peter Xu
2017-12-14 11:32   ` Stefan Hajnoczi
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 18/26] monitor: send event when request queue full Peter Xu
2017-12-14 11:41   ` Stefan Hajnoczi
2017-12-16  7:17     ` Peter Xu
2017-12-16  9:28       ` Stefan Hajnoczi
2017-12-18  5:32         ` Peter Xu
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 19/26] qapi: introduce new cmd option "allow-oob" Peter Xu
2017-12-14 12:42   ` Stefan Hajnoczi
2017-12-15  9:51   ` Fam Zheng
2017-12-16  7:34     ` Peter Xu
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 20/26] qmp: support out-of-band (oob) execution Peter Xu
2017-12-14 13:16   ` Stefan Hajnoczi
2017-12-18  5:37     ` Peter Xu
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 21/26] qmp: isolate responses into io thread Peter Xu
2017-12-14 13:43   ` Stefan Hajnoczi
2017-12-18  5:52     ` Peter Xu
2017-12-18  7:32       ` Peter Xu [this message]
2017-12-18  8:40         ` Stefan Hajnoczi
2017-12-18 10:15           ` Peter Xu
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 22/26] monitor: enable IO thread for (qmp & !mux) typed Peter Xu
2017-12-14 13:44   ` Stefan Hajnoczi
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 23/26] qmp: add command "x-oob-test" Peter Xu
2017-12-14 13:45   ` Stefan Hajnoczi
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 24/26] docs: update QMP documents for OOB commands Peter Xu
2017-12-14 14:30   ` Stefan Hajnoczi
2017-12-18  9:44     ` Peter Xu
2017-12-18 14:09       ` Stefan Hajnoczi
2017-12-19  3:18         ` Peter Xu
2017-12-05  5:51 ` [Qemu-devel] [RFC v5 25/26] tests: qmp-test: verify command batching Peter Xu
2017-12-14 14:39   ` Stefan Hajnoczi
2017-12-18  9:48     ` Peter Xu
2017-12-05  5:52 ` [Qemu-devel] [RFC v5 26/26] tests: qmp-test: add oob test Peter Xu
2017-12-14 14:47   ` Stefan Hajnoczi
2017-12-18  9:51     ` Peter Xu
2017-12-18 13:59       ` Stefan Hajnoczi
2017-12-14 14:52 ` [Qemu-devel] [RFC v5 00/26] QMP: out-of-band (OOB) execution support Stefan Hajnoczi
2017-12-19  6:05   ` Peter Xu
2017-12-15 10:41 ` Fam Zheng
2017-12-15 11:43   ` Dr. David Alan Gilbert
2017-12-15 13:30   ` Stefan Hajnoczi

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=20171218073229.GP22308@xz-mi \
    --to=peterx@redhat.com \
    --cc=armbru@redhat.com \
    --cc=berrange@redhat.com \
    --cc=dgilbert@redhat.com \
    --cc=eblake@redhat.com \
    --cc=famz@redhat.com \
    --cc=lvivier@redhat.com \
    --cc=marcandre.lureau@redhat.com \
    --cc=mdroth@linux.vnet.ibm.com \
    --cc=pbonzini@redhat.com \
    --cc=qemu-devel@nongnu.org \
    --cc=quintela@redhat.com \
    --cc=shajnocz@redhat.com \
    --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.