From 515c0640f762ff5355aff8ace088f3a3f2ad5216 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marek=20Marczykowski-G=C3=B3recki?= Date: Sun, 13 Oct 2024 15:11:12 +0200 Subject: [PATCH] DEBUG: log list of VMs when startup failed And also basic xen info (including free memory) --- qubes/vm/qubesvm.py | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/qubes/vm/qubesvm.py b/qubes/vm/qubesvm.py index dd76c4a00..7417f153a 100644 --- a/qubes/vm/qubesvm.py +++ b/qubes/vm/qubesvm.py @@ -1222,8 +1222,12 @@ async def start(self, start_guid=True, notify_function=None, self._update_libvirt_domain() + free_mem = subprocess.check_output(["xl", "info", "free_memory"]).decode() + self.log.debug("free mem before start: %s", free_mem) self.libvirt_domain.createWithFlags( libvirt.VIR_DOMAIN_START_PAUSED) + free_mem = subprocess.check_output(["xl", "info", "free_memory"]).decode() + self.log.debug("free mem after start: %s", free_mem) # the above allocates xid, lets announce that self.fire_event('property-reset:xid', name='xid') @@ -1239,6 +1243,10 @@ async def start(self, start_guid=True, notify_function=None, exc = qubes.exc.QubesException( 'Failed to start an HVM qube with PCI devices assigned ' '- hardware does not support IOMMU/VT-d/AMD-Vi') + free_mem = subprocess.check_output(["xl", "info", "free_memory"]).decode() + self.log.debug("free mem after failed start: %s", free_mem) + subprocess.run(["xl", "list"]) + subprocess.run(["xl", "info"]) self.log.error('Start failed: %s', str(exc)) await self.fire_event_async('domain-start-failed', reason=str(exc)) @@ -1757,6 +1765,7 @@ def request_memory(self, mem_required=None): initial_memory = self.memory mem_required = int(initial_memory + stubdom_mem) * 1024 * 1024 + self.log.debug(f"mem required: {mem_required}") qmemman_client = qubes.qmemman.client.QMemmanClient() try: mem_required_with_overhead = mem_required + MEM_OVERHEAD_BASE \ @@ -1767,6 +1776,7 @@ def request_memory(self, mem_required=None): mem_required_with_overhead += self.maxmem * 4096 got_memory = qmemman_client.request_memory( mem_required_with_overhead) + self.log.debug(f"mem required with overhead: {mem_required_with_overhead}") except IOError as e: raise IOError('Failed to connect to qmemman: {!s}'.format(e))