mirror of https://github.com/xemu-project/xemu.git
block/nbd: move nbd_recv_coroutines_wake_all() up
We are going to use it in nbd_channel_error(), so move it up. Note, that we are going also refactor and rename nbd_recv_coroutines_wake_all() in future anyway, so keeping it where it is and making forward declaration doesn't make real sense. Signed-off-by: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com> Reviewed-by: Eric Blake <eblake@redhat.com> Message-Id: <20210902103805.25686-3-vsementsov@virtuozzo.com> Signed-off-by: Eric Blake <eblake@redhat.com>
This commit is contained in:
parent
cb116da7d7
commit
3bc0bd1f42
28
block/nbd.c
28
block/nbd.c
|
@ -127,6 +127,20 @@ static bool nbd_client_connected(BDRVNBDState *s)
|
||||||
return qatomic_load_acquire(&s->state) == NBD_CLIENT_CONNECTED;
|
return qatomic_load_acquire(&s->state) == NBD_CLIENT_CONNECTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void nbd_recv_coroutines_wake_all(BDRVNBDState *s)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; i < MAX_NBD_REQUESTS; i++) {
|
||||||
|
NBDClientRequest *req = &s->requests[i];
|
||||||
|
|
||||||
|
if (req->coroutine && req->receiving) {
|
||||||
|
req->receiving = false;
|
||||||
|
aio_co_wake(req->coroutine);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void nbd_channel_error(BDRVNBDState *s, int ret)
|
static void nbd_channel_error(BDRVNBDState *s, int ret)
|
||||||
{
|
{
|
||||||
if (nbd_client_connected(s)) {
|
if (nbd_client_connected(s)) {
|
||||||
|
@ -143,20 +157,6 @@ static void nbd_channel_error(BDRVNBDState *s, int ret)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void nbd_recv_coroutines_wake_all(BDRVNBDState *s)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
|
|
||||||
for (i = 0; i < MAX_NBD_REQUESTS; i++) {
|
|
||||||
NBDClientRequest *req = &s->requests[i];
|
|
||||||
|
|
||||||
if (req->coroutine && req->receiving) {
|
|
||||||
req->receiving = false;
|
|
||||||
aio_co_wake(req->coroutine);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static void reconnect_delay_timer_del(BDRVNBDState *s)
|
static void reconnect_delay_timer_del(BDRVNBDState *s)
|
||||||
{
|
{
|
||||||
if (s->reconnect_delay_timer) {
|
if (s->reconnect_delay_timer) {
|
||||||
|
|
Loading…
Reference in New Issue