From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([2001:4830:134:3::10]:44721) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1bCO8J-0008Ol-Ki for qemu-devel@nongnu.org; Mon, 13 Jun 2016 05:26:12 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1bCO8E-0007H9-EN for qemu-devel@nongnu.org; Mon, 13 Jun 2016 05:26:10 -0400 Received: from mail-wm0-x22d.google.com ([2a00:1450:400c:c09::22d]:37882) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1bCO8E-0007Gx-7S for qemu-devel@nongnu.org; Mon, 13 Jun 2016 05:26:06 -0400 Received: by mail-wm0-x22d.google.com with SMTP id k204so70514556wmk.0 for ; Mon, 13 Jun 2016 02:26:06 -0700 (PDT) From: Alex =?utf-8?Q?Benn=C3=A9e?= In-reply-to: Date: Mon, 13 Jun 2016 10:26:27 +0100 Message-ID: <87h9cx783g.fsf@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit Subject: Re: [Qemu-devel] [RFC 03/10] cpus: Introduce async_wait_run_on_cpu() List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: alvise rigo Cc: Sergey Fedorov , MTTCG Devel , QEMU Developers , Jani Kokkonen , Claudio Fontana , VirtualOpenSystems Technical Team , KONRAD =?utf-8?B?RnLDqWTDqXJpYw==?= , Paolo Bonzini , Richard Henderson , "Emilio G. Cota" , Peter Maydell alvise rigo writes: > I think that async_safe_run_on_cpu() does a different thing: it > queries a job to the target vCPU and wants all the other to "observe" > the submitted task. However, we will have the certainty that only the > target vCPU observed the task, the other might still be running in the > guest code. For the code to have run every will have come out of the run loop and synced up at that point. No safe work is run with guest code executing. > > alvise > > On Wed, Jun 8, 2016 at 5:20 PM, Alex Bennée wrote: >> >> Sergey Fedorov writes: >> >>> On 08/06/16 17:10, alvise rigo wrote: >>>> Using run_on_cpu() we might deadlock QEMU if other vCPUs are waiting >>>> for the current vCPU. We need to exit from the vCPU loop in order to >>>> avoid this. >>> >>> I see, we could deadlock indeed. Alternatively, we may want fix >>> run_on_cpu() to avoid waiting for completion by itself when called from >>> CPU loop. >> >> async_safe_run_on_cpu can't deadlock as all vCPUs are suspended (or >> waiting) for the work to complete. The tasks are run in strict order so >> if you queued async tasks for other vCPUs first you could ensure >> everything is in the state you want it when you finally service the >> calling vCPU. >> >>> >>> Kind regards, >>> Sergey >> >> >> -- >> Alex Bennée -- Alex Bennée