mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-08 22:15:21 +00:00
qemu: Don't leave beingDestroyed=true on inactive domain
Recent commit v10.4.0-87-gd9935a5c4f made a reasonable change to only reset beingDestroyed back to false when vm->def->id is reset to make sure other code can detect a domain is (about to become) inactive. It even added a comment saying any caller of qemuProcessBeginStopJob is supposed to call qemuProcessStop to clear beingDestroyed. But not every caller really does so because they first call qemuProcessBeginStopJob and then check whether a domain is still running. If not the qemuProcessStop call is skipped leaving beingDestroyed=true. In case of a persistent domain this may block incoming migrations of such domain as the migration code would think the domain died unexpectedly (even though it's still running). The qemuProcessBeginStopJob function is a wrapper around virDomainObjBeginJob, but virDomainObjEndJob was used directly for cleanup. This patch introduces a new qemuProcessEndStopJob wrapper around virDomainObjEndJob to properly undo everything qemuProcessBeginStopJob did. https://issues.redhat.com/browse/RHEL-43309 Signed-off-by: Jiri Denemark <jdenemar@redhat.com> Reviewed-by: Peter Krempa <pkrempa@redhat.com>
This commit is contained in:
parent
c9fa43c48c
commit
bec903cae8
@ -2102,7 +2102,7 @@ qemuDomainDestroyFlags(virDomainPtr dom,
|
|||||||
endjob:
|
endjob:
|
||||||
if (ret == 0)
|
if (ret == 0)
|
||||||
qemuDomainRemoveInactive(driver, vm, 0, false);
|
qemuDomainRemoveInactive(driver, vm, 0, false);
|
||||||
virDomainObjEndJob(vm);
|
qemuProcessEndStopJob(vm);
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
virDomainObjEndAPI(&vm);
|
virDomainObjEndAPI(&vm);
|
||||||
@ -3888,7 +3888,7 @@ processMonitorEOFEvent(virQEMUDriver *driver,
|
|||||||
|
|
||||||
endjob:
|
endjob:
|
||||||
qemuDomainRemoveInactive(driver, vm, 0, false);
|
qemuDomainRemoveInactive(driver, vm, 0, false);
|
||||||
virDomainObjEndJob(vm);
|
qemuProcessEndStopJob(vm);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -8421,7 +8421,8 @@ qemuProcessKill(virDomainObj *vm, unsigned int flags)
|
|||||||
* qemuProcessBeginStopJob:
|
* qemuProcessBeginStopJob:
|
||||||
*
|
*
|
||||||
* Stop all current jobs by killing the domain and start a new one for
|
* Stop all current jobs by killing the domain and start a new one for
|
||||||
* qemuProcessStop.
|
* qemuProcessStop. The caller has to make sure qemuProcessEndStopJob is
|
||||||
|
* called to properly cleanup the job.
|
||||||
*/
|
*/
|
||||||
int
|
int
|
||||||
qemuProcessBeginStopJob(virDomainObj *vm,
|
qemuProcessBeginStopJob(virDomainObj *vm,
|
||||||
@ -8448,8 +8449,9 @@ qemuProcessBeginStopJob(virDomainObj *vm,
|
|||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
/* priv->beingDestroyed is deliberately left set to 'true' here. Caller
|
/* priv->beingDestroyed is deliberately left set to 'true' here. Caller
|
||||||
* is supposed to call qemuProcessStop, which will reset it after
|
* is supposed to call qemuProcessStop (which will reset it after
|
||||||
* 'vm->def->id' is set to -1 */
|
* 'vm->def->id' is set to -1) and/or qemuProcessEndStopJob to do proper
|
||||||
|
* cleanup. */
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
error:
|
error:
|
||||||
@ -8458,6 +8460,16 @@ qemuProcessBeginStopJob(virDomainObj *vm,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
qemuProcessEndStopJob(virDomainObj *vm)
|
||||||
|
{
|
||||||
|
if (!virDomainObjIsActive(vm))
|
||||||
|
QEMU_DOMAIN_PRIVATE(vm)->beingDestroyed = false;
|
||||||
|
|
||||||
|
virDomainObjEndJob(vm);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void qemuProcessStop(virQEMUDriver *driver,
|
void qemuProcessStop(virQEMUDriver *driver,
|
||||||
virDomainObj *vm,
|
virDomainObj *vm,
|
||||||
virDomainShutoffReason reason,
|
virDomainShutoffReason reason,
|
||||||
@ -8800,7 +8812,7 @@ qemuProcessAutoDestroy(virDomainObj *dom,
|
|||||||
|
|
||||||
qemuDomainRemoveInactive(driver, dom, 0, false);
|
qemuDomainRemoveInactive(driver, dom, 0, false);
|
||||||
|
|
||||||
virDomainObjEndJob(dom);
|
qemuProcessEndStopJob(dom);
|
||||||
|
|
||||||
virObjectEventStateQueue(driver->domainEventState, event);
|
virObjectEventStateQueue(driver->domainEventState, event);
|
||||||
}
|
}
|
||||||
|
@ -169,6 +169,7 @@ typedef enum {
|
|||||||
int qemuProcessBeginStopJob(virDomainObj *vm,
|
int qemuProcessBeginStopJob(virDomainObj *vm,
|
||||||
virDomainJob job,
|
virDomainJob job,
|
||||||
bool forceKill);
|
bool forceKill);
|
||||||
|
void qemuProcessEndStopJob(virDomainObj *vm);
|
||||||
void qemuProcessStop(virQEMUDriver *driver,
|
void qemuProcessStop(virQEMUDriver *driver,
|
||||||
virDomainObj *vm,
|
virDomainObj *vm,
|
||||||
virDomainShutoffReason reason,
|
virDomainShutoffReason reason,
|
||||||
|
Loading…
Reference in New Issue
Block a user