render / rpms / libvirt

Forked from rpms/libvirt 11 months ago
Clone
d759b5
From 2c1a60343710fc11a5c8bcfd022fd2a8aa6681ff Mon Sep 17 00:00:00 2001
d759b5
Message-Id: <2c1a60343710fc11a5c8bcfd022fd2a8aa6681ff@dist-git>
d759b5
From: Peter Krempa <pkrempa@redhat.com>
d759b5
Date: Fri, 16 Aug 2019 14:36:56 +0200
d759b5
Subject: [PATCH] qemu: driver: Improve error suppression in
d759b5
 qemuDomainStorageUpdatePhysical
d759b5
MIME-Version: 1.0
d759b5
Content-Type: text/plain; charset=UTF-8
d759b5
Content-Transfer-Encoding: 8bit
d759b5
d759b5
None of the callers of qemuDomainStorageUpdatePhysical care about
d759b5
errors.
d759b5
d759b5
Use the new flag for qemuDomainStorageOpenStat which suppresses some
d759b5
errors and move the reset of the rest of the uncommon errors into this
d759b5
function. Document what is happening in a comment for the function.
d759b5
d759b5
Signed-off-by: Peter Krempa <pkrempa@redhat.com>
d759b5
Reviewed-by: Ján Tomko <jtomko@redhat.com>
d759b5
(cherry picked from commit 3d7ea4165b890880f43074e1e5e6e10bf0ad21d6)
d759b5
https: //bugzilla.redhat.com/show_bug.cgi?id=1724808
d759b5
Message-Id: <65325f9c156ebab937b81e89c9bfe6c1b6d8251b.1565958905.git.pkrempa@redhat.com>
d759b5
Reviewed-by: Ján Tomko <jtomko@redhat.com>
d759b5
---
d759b5
 src/qemu/qemu_driver.c | 24 ++++++++++++++++++------
d759b5
 1 file changed, 18 insertions(+), 6 deletions(-)
d759b5
d759b5
diff --git a/src/qemu/qemu_driver.c b/src/qemu/qemu_driver.c
d759b5
index 91eeb05319..72c75e308b 100644
d759b5
--- a/src/qemu/qemu_driver.c
d759b5
+++ b/src/qemu/qemu_driver.c
d759b5
@@ -11849,6 +11849,19 @@ qemuDomainStorageCloseStat(virStorageSourcePtr src,
d759b5
 }
d759b5
 
d759b5
 
d759b5
+/**
d759b5
+ * qemuDomainStorageUpdatePhysical:
d759b5
+ * @driver: qemu driver
d759b5
+ * @cfg: qemu driver configuration object
d759b5
+ * @vm: domain object
d759b5
+ * @src: storage source to update
d759b5
+ *
d759b5
+ * Update the physical size of the disk by reading the actual size of the image
d759b5
+ * on disk.
d759b5
+ *
d759b5
+ * Returns 0 on successful update and -1 otherwise (some uncommon errors may be
d759b5
+ * reported but are reset (thus only logged)).
d759b5
+ */
d759b5
 static int
d759b5
 qemuDomainStorageUpdatePhysical(virQEMUDriverPtr driver,
d759b5
                                 virQEMUDriverConfigPtr cfg,
d759b5
@@ -11862,8 +11875,11 @@ qemuDomainStorageUpdatePhysical(virQEMUDriverPtr driver,
d759b5
     if (virStorageSourceIsEmpty(src))
d759b5
         return 0;
d759b5
 
d759b5
-    if (qemuDomainStorageOpenStat(driver, cfg, vm, src, &fd, &sb, false) < 0)
d759b5
+    if ((ret = qemuDomainStorageOpenStat(driver, cfg, vm, src, &fd, &sb, true)) <= 0) {
d759b5
+        if (ret < 0)
d759b5
+            virResetLastError();
d759b5
         return -1;
d759b5
+    }
d759b5
 
d759b5
     ret = virStorageSourceUpdatePhysicalSize(src, fd, &sb);
d759b5
 
d759b5
@@ -12058,7 +12074,6 @@ qemuDomainGetBlockInfo(virDomainPtr dom,
d759b5
         if (qemuDomainStorageUpdatePhysical(driver, cfg, vm, disk->src) == 0) {
d759b5
             info->physical = disk->src->physical;
d759b5
         } else {
d759b5
-            virResetLastError();
d759b5
             info->physical = entry->physical;
d759b5
         }
d759b5
     } else {
d759b5
@@ -20132,12 +20147,9 @@ qemuDomainGetStatsOneBlock(virQEMUDriverPtr driver,
d759b5
         QEMU_ADD_BLOCK_PARAM_ULL(record, maxparams, block_idx,
d759b5
                                  "physical", entry->physical);
d759b5
     } else {
d759b5
-        if (qemuDomainStorageUpdatePhysical(driver, cfg, dom, src) == 0) {
d759b5
+        if (qemuDomainStorageUpdatePhysical(driver, cfg, dom, src) == 0)
d759b5
             QEMU_ADD_BLOCK_PARAM_ULL(record, maxparams, block_idx,
d759b5
                                      "physical", src->physical);
d759b5
-        } else {
d759b5
-            virResetLastError();
d759b5
-        }
d759b5
     }
d759b5
 
d759b5
     if (qemuDomainGetStatsOneBlockNode(record, maxparams, src, block_idx,
d759b5
-- 
d759b5
2.22.1
d759b5