diff options
author | Kevin Wolf <kwolf@redhat.com> | 2019-02-15 16:53:51 +0100 |
---|---|---|
committer | Kevin Wolf <kwolf@redhat.com> | 2019-02-25 15:03:19 +0100 |
commit | 5ad81b4946baf948c65cf7e1436d9b74803c1280 (patch) | |
tree | f6f97765e84155fd31281f60ecdd42bf0f37b187 /block/nbd-client.h | |
parent | 680f200217748e0920b79ec1d524717c2f50935b (diff) | |
download | qemu-5ad81b4946baf948c65cf7e1436d9b74803c1280.zip qemu-5ad81b4946baf948c65cf7e1436d9b74803c1280.tar.gz qemu-5ad81b4946baf948c65cf7e1436d9b74803c1280.tar.bz2 |
nbd: Restrict connection_co reentrance
nbd_client_attach_aio_context() schedules connection_co in the new
AioContext and this way reenters it in any arbitrary place that has
yielded. We can restrict this a bit to the function call where the
coroutine actually sits waiting when it's idle.
This doesn't solve any bug yet, but it shows where in the code we need
to support this random reentrance and where we don't have to care.
Add FIXME comments for the existing bugs that the rest of this series
will fix.
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
Reviewed-by: Eric Blake <eblake@redhat.com>
Diffstat (limited to 'block/nbd-client.h')
-rw-r--r-- | block/nbd-client.h | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/block/nbd-client.h b/block/nbd-client.h index d990207..09e0301 100644 --- a/block/nbd-client.h +++ b/block/nbd-client.h @@ -35,6 +35,7 @@ typedef struct NBDClientSession { NBDClientRequest requests[MAX_NBD_REQUESTS]; NBDReply reply; + BlockDriverState *bs; bool quit; } NBDClientSession; |