From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([2001:4830:134:3::10]:39113) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1b4eEi-0006dG-Sp for qemu-devel@nongnu.org; Sun, 22 May 2016 21:00:49 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1b4eEh-0005FO-RV for qemu-devel@nongnu.org; Sun, 22 May 2016 21:00:48 -0400 Date: Mon, 23 May 2016 09:00:40 +0800 From: Fam Zheng Message-ID: <20160523010040.GA8734@ad.usersys.redhat.com> References: <1463559850-5244-1-git-send-email-famz@redhat.com> <1463559850-5244-2-git-send-email-famz@redhat.com> <20160520080317.GA4861@noname.redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20160520080317.GA4861@noname.redhat.com> Subject: Re: [Qemu-devel] [PATCH 1/3] blockdev-backup: Don't move target AioContext if it's attached List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Kevin Wolf Cc: qemu-devel@nongnu.org, Max Reitz , Markus Armbruster , Stefan Hajnoczi , "Michael S. Tsirkin" , Paolo Bonzini , qemu-block@nongnu.org On Fri, 05/20 10:03, Kevin Wolf wrote: > Am 18.05.2016 um 10:24 hat Fam Zheng geschrieben: > > If the BDS is attached, it will want to stay on the AioContext where its > > BlockBackend is. Don't call bdrv_set_aio_context in this case. > > > > Signed-off-by: Fam Zheng > > --- > > blockdev.c | 12 +++++++++++- > > 1 file changed, 11 insertions(+), 1 deletion(-) > > > > diff --git a/blockdev.c b/blockdev.c > > index 1892b8e..eb15593 100644 > > --- a/blockdev.c > > +++ b/blockdev.c > > @@ -3376,8 +3376,18 @@ void do_blockdev_backup(const char *device, const char *target, > > } > > target_bs = blk_bs(target_blk); > > > > + if (bdrv_get_aio_context(target_bs) != aio_context) { > > + if (!target_bs->blk) { > > How should this ever happen when we have target_bs = blk_bs(target_blk) > two lines above? I must have made a mistake with git or my editor, I meant to change it to bdrv_lookup_bs above. Fam > > > + /* The target BDS is not attached, we can safely move it to another > > + * AioContext. */ > > + bdrv_set_aio_context(target_bs, aio_context); > > + } else { > > + error_setg(errp, "Target is attached to a different thread from " > > + "source."); > > + goto out; > > + } > > + } > > Kevin