]> git.ipfire.org Git - thirdparty/libvirt.git/commitdiff
qemuProcessStop: Use XATTRs to restore seclabels on disks a domain is mirroring into
authorMichal Privoznik <mprivozn@redhat.com>
Mon, 18 May 2020 13:07:46 +0000 (15:07 +0200)
committerMichal Privoznik <mprivozn@redhat.com>
Mon, 18 May 2020 13:13:14 +0000 (15:13 +0200)
In v5.10.0-rc1~42 (which was later fixed in v6.0.0-rc1~487) I am
removing XATTRs for a file that QEMU is mirroring a disk into but
it is killed meanwhile. Well, we can call
qemuSecurityRestoreImageLabel() which will not only remove XATTRs
but also use them to restore the original owner of the file.

This would be done by blockjob code when the job finishes, but in
this case the job won't finish - QEMU is killed meanwhile

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
src/qemu/qemu_process.c

index f7f6793113253a64101b63ed4a5bbc3317bb9421..7e41695e03b0a75e0f87e2de1b25b0132e039bd3 100644 (file)
@@ -7597,8 +7597,10 @@ void qemuProcessStop(virQEMUDriverPtr driver,
         for (i = 0; i < def->ndisks; i++) {
             virDomainDiskDefPtr disk = def->disks[i];
 
-            if (disk->mirror)
-                qemuBlockRemoveImageMetadata(driver, vm, disk->dst, disk->mirror);
+            if (disk->mirror) {
+                if (qemuSecurityRestoreImageLabel(driver, vm, disk->mirror, false) < 0)
+                    VIR_WARN("Unable to restore security label on %s", disk->dst);
+            }
 
             qemuBlockRemoveImageMetadata(driver, vm, disk->dst, disk->src);
         }