mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-25 14:05:18 +00:00
qemuDomainUndefineFlags: unlink nvram file regardless of domain state
https://bugzilla.redhat.com/show_bug.cgi?id=1467245 Currently, there's a bug when undefining a domain with NVRAM store. Basically, the unlink() of the NVRAM store file happens during the undefine procedure iff domain is inactive. So, if domain is running and undefine is called the file is left behind. It won't be removed in the domain cleanup process either (qemuProcessStop). One of the solutions is to remove if regardless of the domain state and rely on qemu having the file opened. This still has a downside that if the domain is defined back the NVRAM store file is going to be new, any changes to the current one are lost (just like with any other file that is deleted while a process has it opened). But is it really a downside? Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
parent
b9b0aa06a0
commit
e488ebb31d
@ -7364,8 +7364,8 @@ qemuDomainUndefineFlags(virDomainPtr dom,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!virDomainObjIsActive(vm) &&
|
if (vm->def->os.loader &&
|
||||||
vm->def->os.loader && vm->def->os.loader->nvram &&
|
vm->def->os.loader->nvram &&
|
||||||
virFileExists(vm->def->os.loader->nvram)) {
|
virFileExists(vm->def->os.loader->nvram)) {
|
||||||
if ((flags & VIR_DOMAIN_UNDEFINE_NVRAM)) {
|
if ((flags & VIR_DOMAIN_UNDEFINE_NVRAM)) {
|
||||||
if (unlink(vm->def->os.loader->nvram) < 0) {
|
if (unlink(vm->def->os.loader->nvram) < 0) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user