aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKevin Wolf <kwolf@redhat.com>2015-02-10 11:17:53 +0100
committerKevin Wolf <kwolf@redhat.com>2015-03-09 11:11:59 +0100
commit315a1309defd8ddf910c6c17e28cbbd7faf92f2e (patch)
tree9c43363b81766c220df0b0ad144044b3bdf2d802
parent6608c7e9eb65727524f6f590b1e716ec6e7877d4 (diff)
coroutine: Fix use after free with qemu_coroutine_yield()
Instead of using the same function for entering and exiting coroutines, and hoping that it doesn't add any functionality that hurts with the parameters used for exiting, we can just directly call into the real task switch in qemu_coroutine_switch(). This fixes a use-after-free scenario where reentering a coroutine that has yielded still accesses the old parent coroutine (which may have meanwhile terminated) in the part of coroutine_swap() that follows qemu_coroutine_switch(). Cc: qemu-stable@nongnu.org Signed-off-by: Kevin Wolf <kwolf@redhat.com> Reviewed-by: Paolo Bonzini <pbonzini@redhat.com>
-rw-r--r--qemu-coroutine.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/qemu-coroutine.c b/qemu-coroutine.c
index 525247b050..5019b81dd5 100644
--- a/qemu-coroutine.c
+++ b/qemu-coroutine.c
@@ -148,5 +148,5 @@ void coroutine_fn qemu_coroutine_yield(void)
}
self->caller = NULL;
- coroutine_swap(self, to);
+ qemu_coroutine_switch(self, to, COROUTINE_YIELD);
}