On Wed, 07/29 09:37, Paolo Bonzini wrote:
> 
> 
> On 29/07/2015 06:42, Fam Zheng wrote:
> > @@ -2613,6 +2613,8 @@ bool bdrv_aio_poll(AioContext *ctx, bool blocking)
> >  {
> >      bool ret;
> >  
> > +    aio_disable_clients(ctx, AIO_CLIENT_DATAPLANE | AIO_CLIENT_NBD_SERVER);
> >      ret = aio_poll(ctx, blocking);
> > +    aio_enable_clients(ctx, AIO_CLIENT_DATAPLANE | AIO_CLIENT_NBD_SERVER);
> >      return ret;
> 
> This is not enough, because another thread's aio_poll can sneak in
> between calls to bdrv_aio_poll if the AioContext lock is released, and
> they will use the full set of clients.
> 
> Similar to your v1, it works with the large critical sections we
> currently have, but it has the same problem in the longer term.

Can we add more disable/enable pairs around bdrv_drain on top?

Fam

> 
> The clients have to be disabled around calls to bdrv_drain, as you were
> doing when you had pause/resume notifiers.  Patches 1-8 however are ok.
> 
> Paolo
> 

Reply via email to