coroutine: Introduce qemu_coroutine_enter_if_inactive()
In the context of asynchronous work, if we have a worker coroutine that didn't yield, the parent coroutine cannot be reentered because it hasn't yielded yet. In this case we don't even have to reenter the parent because it will see that the work is already done and won't even yield. Signed-off-by: Kevin Wolf <kwolf@redhat.com> Reviewed-by: Eric Blake <eblake@redhat.com> Reviewed-by: Alberto Garcia <berto@igalia.com>
This commit is contained in:
parent
4baaa8c3d8
commit
536fca7f7e
@ -70,6 +70,12 @@ Coroutine *qemu_coroutine_create(CoroutineEntry *entry, void *opaque);
|
|||||||
*/
|
*/
|
||||||
void qemu_coroutine_enter(Coroutine *coroutine);
|
void qemu_coroutine_enter(Coroutine *coroutine);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Transfer control to a coroutine if it's not active (i.e. part of the call
|
||||||
|
* stack of the running coroutine). Otherwise, do nothing.
|
||||||
|
*/
|
||||||
|
void qemu_coroutine_enter_if_inactive(Coroutine *co);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Transfer control back to a coroutine's caller
|
* Transfer control back to a coroutine's caller
|
||||||
*
|
*
|
||||||
|
@ -131,6 +131,13 @@ void qemu_coroutine_enter(Coroutine *co)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void qemu_coroutine_enter_if_inactive(Coroutine *co)
|
||||||
|
{
|
||||||
|
if (!qemu_coroutine_entered(co)) {
|
||||||
|
qemu_coroutine_enter(co);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void coroutine_fn qemu_coroutine_yield(void)
|
void coroutine_fn qemu_coroutine_yield(void)
|
||||||
{
|
{
|
||||||
Coroutine *self = qemu_coroutine_self();
|
Coroutine *self = qemu_coroutine_self();
|
||||||
|
Loading…
Reference in New Issue
Block a user