]> xenbits.xensource.com Git - qemu-xen.git/commitdiff
block/nbd-client: save first fatal error in nbd_iter_error
authorVladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com>
Mon, 12 Mar 2018 15:21:22 +0000 (18:21 +0300)
committerEric Blake <eblake@redhat.com>
Tue, 13 Mar 2018 20:38:56 +0000 (15:38 -0500)
It is ok, that fatal error hides previous not fatal, but hiding
first fatal error is a bad feature.

Signed-off-by: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com>
Reviewed-by: Eric Blake <eblake@redhat.com>
Message-Id: <20180312152126.286890-5-vsementsov@virtuozzo.com>
Signed-off-by: Eric Blake <eblake@redhat.com>
block/nbd-client.c

index 7b68499b76a3c74f635f51ca5affb834152709a5..0d9f73a137f48a921d7d8942e807ce30b3bf7fff 100644 (file)
@@ -481,6 +481,7 @@ static coroutine_fn int nbd_co_receive_one_chunk(
 
 typedef struct NBDReplyChunkIter {
     int ret;
+    bool fatal;
     Error *err;
     bool done, only_structured;
 } NBDReplyChunkIter;
@@ -490,11 +491,12 @@ static void nbd_iter_error(NBDReplyChunkIter *iter, bool fatal,
 {
     assert(ret < 0);
 
-    if (fatal || iter->ret == 0) {
+    if ((fatal && !iter->fatal) || iter->ret == 0) {
         if (iter->ret != 0) {
             error_free(iter->err);
             iter->err = NULL;
         }
+        iter->fatal = fatal;
         iter->ret = ret;
         error_propagate(&iter->err, *local_err);
     } else {