Don't fire domain-stopped/-shutdown while VM is still Dying
Lots of code expects the VM to be Halted after receiving one of these events, but it could also be Dying or Crashed. Get rid of the Dying case at least, by waiting until the VM has transitioned out of it. Fixes e.g. the following DispVM cleanup bug: $ qvm-create -C DispVM --prop auto_cleanup=True -l red dispvm $ qvm-start dispvm $ qvm-shutdown --wait dispvm # this won't remove dispvm $ qvm-start dispvm $ qvm-kill dispvm # but this will
This commit is contained in:
parent
4f52a3b62e
commit
f96fd70f76
@ -975,6 +975,8 @@ class QubesVM(qubes.vm.mix.net.NetVMMixin, qubes.vm.BaseVM):
|
|||||||
# an exception gets thrown.
|
# an exception gets thrown.
|
||||||
self._domain_stopped_event_handled = True
|
self._domain_stopped_event_handled = True
|
||||||
|
|
||||||
|
while self.get_power_state() == 'Dying':
|
||||||
|
yield from asyncio.sleep(0.25)
|
||||||
yield from self.fire_event_async('domain-stopped')
|
yield from self.fire_event_async('domain-stopped')
|
||||||
yield from self.fire_event_async('domain-shutdown')
|
yield from self.fire_event_async('domain-shutdown')
|
||||||
|
|
||||||
@ -1458,7 +1460,7 @@ class QubesVM(qubes.vm.mix.net.NetVMMixin, qubes.vm.BaseVM):
|
|||||||
``'Paused'`` Machine is paused.
|
``'Paused'`` Machine is paused.
|
||||||
``'Suspended'`` Machine is S3-suspended.
|
``'Suspended'`` Machine is S3-suspended.
|
||||||
``'Halting'`` Machine is in process of shutting down.
|
``'Halting'`` Machine is in process of shutting down.
|
||||||
``'Dying'`` Machine crashed and is unusable.
|
``'Dying'`` Machine is still in process of shutting down.
|
||||||
``'Crashed'`` Machine crashed and is unusable, probably because of
|
``'Crashed'`` Machine crashed and is unusable, probably because of
|
||||||
bug in dom0.
|
bug in dom0.
|
||||||
``'NA'`` Machine is in unknown state (most likely libvirt domain
|
``'NA'`` Machine is in unknown state (most likely libvirt domain
|
||||||
|
Loading…
Reference in New Issue
Block a user