[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PULL 06/13] nbd: remove peppering of nbd_client_connected
From: |
Peter Maydell |
Subject: |
Re: [PULL 06/13] nbd: remove peppering of nbd_client_connected |
Date: |
Thu, 12 May 2022 17:16:04 +0100 |
On Tue, 26 Apr 2022 at 21:21, Eric Blake <eblake@redhat.com> wrote:
>
> From: Paolo Bonzini <pbonzini@redhat.com>
>
> It is unnecessary to check nbd_client_connected() because every time
> s->state is moved out of NBD_CLIENT_CONNECTED the socket is shut down
> and all coroutines are resumed.
Hi; Coverity points out (CID 1488362) that this part of this change
has resulted in some dead code:
> @@ -512,7 +508,7 @@ static int coroutine_fn
> nbd_co_send_request(BlockDriverState *bs,
> if (qiov) {
> qio_channel_set_cork(s->ioc, true);
> rc = nbd_send_request(s->ioc, request);
> - if (nbd_client_connected(s) && rc >= 0) {
> + if (rc >= 0) {
> if (qio_channel_writev_all(s->ioc, qiov->iov, qiov->niov,
> NULL) < 0) {
> rc = -EIO;
because the change means this code is now
if (rc >= 0) {
if (qio_channel_writev_all(s->ioc, qiov->iov, qiov->niov,
NULL) < 0) {
rc = -EIO;
}
} else if (rc >= 0) {
rc = -EIO;
}
and the "else if" clause is dead and can be deleted.
thanks
-- PMM
- Re: [PULL 06/13] nbd: remove peppering of nbd_client_connected,
Peter Maydell <=