render / rpms / libvirt

Forked from rpms/libvirt 11 months ago
Clone
c1c534
From 3ad4635badd77642d59d3789286da72abb66ee72 Mon Sep 17 00:00:00 2001
c1c534
Message-Id: <3ad4635badd77642d59d3789286da72abb66ee72@dist-git>
c1c534
From: Peter Krempa <pkrempa@redhat.com>
c1c534
Date: Fri, 1 Dec 2017 15:57:02 +0100
c1c534
Subject: [PATCH] qemu: process: Move handling of non-backing files into
c1c534
 qemuDomainDetermineDiskChain
c1c534
c1c534
Until now we would skip loading of the backing chain for files which
c1c534
don't support backing chains only when starting up the VM. Move the
c1c534
check from qemuProcessPrepareHostStorage with some adaptations so that's
c1c534
always applied.
c1c534
c1c534
(cherry picked from commit 24e47ee2b93312742f73a785b9ca788df4677749)
c1c534
c1c534
 Conflicts:
c1c534
	src/qemu/qemu_domain.c:
c1c534
        - since quite lot of the blockdev saga was not backported and
c1c534
        the previous commit is different this one does not apply as
c1c534
        well.
c1c534
c1c534
        The changes are to accomodate the not-backported change in
c1c534
        return code logic of qemuDomainDetermineDiskChain which in this
c1c534
        instance initializes ret to 0 instead of -1, which was changed
c1c534
        in a patch that was not backported.
c1c534
c1c534
https://bugzilla.redhat.com/show_bug.cgi?id=1509110
c1c534
Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
c1c534
---
c1c534
 src/qemu/qemu_domain.c  | 17 +++++++++++++++++
c1c534
 src/qemu/qemu_process.c | 10 ----------
c1c534
 2 files changed, 17 insertions(+), 10 deletions(-)
c1c534
c1c534
diff --git a/src/qemu/qemu_domain.c b/src/qemu/qemu_domain.c
c1c534
index 13d120040b..33cb3df949 100644
c1c534
--- a/src/qemu/qemu_domain.c
c1c534
+++ b/src/qemu/qemu_domain.c
c1c534
@@ -6358,6 +6358,23 @@ qemuDomainDetermineDiskChain(virQEMUDriverPtr driver,
c1c534
     if (force_probe)
c1c534
         virStorageSourceBackingStoreClear(disk->src);
c1c534
 
c1c534
+    /* There is no need to check the backing chain for disks without backing
c1c534
+     * support */
c1c534
+    if (virStorageSourceIsLocalStorage(disk->src) &&
c1c534
+        disk->src->format > VIR_STORAGE_FILE_NONE &&
c1c534
+        disk->src->format < VIR_STORAGE_FILE_BACKING) {
c1c534
+
c1c534
+        if (!virFileExists(disk->src->path)) {
c1c534
+            if (report_broken)
c1c534
+                virStorageFileReportBrokenChain(errno, disk->src, disk->src);
c1c534
+
c1c534
+            ret = -1;
c1c534
+            goto cleanup;
c1c534
+        }
c1c534
+
c1c534
+        goto cleanup;
c1c534
+    }
c1c534
+
c1c534
     if (virStorageSourceHasBacking(disk->src))
c1c534
         goto cleanup;
c1c534
 
c1c534
diff --git a/src/qemu/qemu_process.c b/src/qemu/qemu_process.c
c1c534
index f7808227a8..91426ad3c3 100644
c1c534
--- a/src/qemu/qemu_process.c
c1c534
+++ b/src/qemu/qemu_process.c
c1c534
@@ -5554,20 +5554,10 @@ qemuProcessPrepareHostStorage(virQEMUDriverPtr driver,
c1c534
     for (i = vm->def->ndisks; i > 0; i--) {
c1c534
         size_t idx = i - 1;
c1c534
         virDomainDiskDefPtr disk = vm->def->disks[idx];
c1c534
-        virStorageFileFormat format = virDomainDiskGetFormat(disk);
c1c534
 
c1c534
         if (virStorageSourceIsEmpty(disk->src))
c1c534
             continue;
c1c534
 
c1c534
-        /* There is no need to check the backing chain for disks
c1c534
-         * without backing support, the fact that the file exists is
c1c534
-         * more than enough */
c1c534
-        if (virStorageSourceIsLocalStorage(disk->src) &&
c1c534
-            format > VIR_STORAGE_FILE_NONE &&
c1c534
-            format < VIR_STORAGE_FILE_BACKING &&
c1c534
-            virFileExists(virDomainDiskGetSource(disk)))
c1c534
-            continue;
c1c534
-
c1c534
         if (qemuDomainDetermineDiskChain(driver, vm, disk, true, true) >= 0)
c1c534
             continue;
c1c534
 
c1c534
-- 
c1c534
2.15.1
c1c534