From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([2001:4830:134:3::10]:46421) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1V7Eu5-0003hR-1c for qemu-devel@nongnu.org; Wed, 07 Aug 2013 21:20:42 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1V7Etz-0000iA-AD for qemu-devel@nongnu.org; Wed, 07 Aug 2013 21:20:36 -0400 Received: from mail6.webfaction.com ([74.55.86.74]:34624 helo=smtp.webfaction.com) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1V7Etz-0000hv-46 for qemu-devel@nongnu.org; Wed, 07 Aug 2013 21:20:31 -0400 Message-ID: <5202F25D.8010601@ctshepherd.com> Date: Thu, 08 Aug 2013 02:20:29 +0100 From: Charlie Shepherd MIME-Version: 1.0 References: <1375728247-1306-1-git-send-email-charlie@ctshepherd.com> <1375728247-1306-2-git-send-email-charlie@ctshepherd.com> <20130806083912.GC32024@stefanha-thinkpad.redhat.com> In-Reply-To: <20130806083912.GC32024@stefanha-thinkpad.redhat.com> Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Subject: Re: [Qemu-devel] [PATCH 1/5] Add an explanation of when a function should be marked coroutine_fn List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Stefan Hajnoczi Cc: kwolf@redhat.com, pbonzini@redhat.com, gabriel@kerneis.info, qemu-devel@nongnu.org On 06/08/2013 09:39, Stefan Hajnoczi wrote: > On Mon, Aug 05, 2013 at 08:44:03PM +0200, Charlie Shepherd wrote: >> From: Charlie Shepherd >> >> Coroutine functions that can yield directly or indirectly should be annotated >> with a coroutine_fn annotation. Add an explanation to that effect in >> include/block/coroutine.h. >> --- >> include/block/coroutine.h | 3 +++ >> 1 file changed, 3 insertions(+) >> >> diff --git a/include/block/coroutine.h b/include/block/coroutine.h >> index 377805a..3b94b6d 100644 >> --- a/include/block/coroutine.h >> +++ b/include/block/coroutine.h >> @@ -37,6 +37,9 @@ >> * static checker support for catching such errors. This annotation might make >> * it possible and in the meantime it serves as documentation. >> * >> + * A function must be marked with coroutine_fn if it can yield execution, either >> + * directly or indirectly. >> + * > This is correct except for the case of dynamic functions that do: > > if (qemu_in_coroutine()) { > } else { > Coroutine *co = qemu_coroutine_new(...); > ... > } > > Here the function is coroutine_fn only if the caller is in coroutine > context. > > I think your comment update should include a note about this. When > you've split all dynamic functions into coroutine/non-coroutine versions > then the note can be removed. Hmm ok, I can add a note to that effect. Charlie