mirror of
https://github.com/virt-manager/virt-manager.git
synced 2025-01-10 01:18:03 +03:00
domain: tweak q35 <-> pc editing
* add_q35_pcie_controllers already skips adding controllers if any type=pci already exist, so delete the extra checking * be more paranoid and only run the live edits when the machine type actually changed from an expected config Signed-off-by: Cole Robinson <crobinso@redhat.com>
This commit is contained in:
parent
78064728e6
commit
258df88eab
@ -480,10 +480,16 @@ def testNewKVMQ35Tweaks(app):
|
||||
details.combo_check_default("Chipset:", "Q35")
|
||||
details.combo_check_default("Firmware:", "BIOS")
|
||||
|
||||
# Switch i440FX and back
|
||||
# Unchanged machine
|
||||
details.combo_select("Chipset:", "i440FX")
|
||||
details.combo_select("Chipset:", "Q35")
|
||||
appl.click()
|
||||
lib.utils.check(lambda: not appl.sensitive)
|
||||
# Switch i440FX
|
||||
details.combo_select("Chipset:", "i440FX")
|
||||
appl.click()
|
||||
lib.utils.check(lambda: not appl.sensitive)
|
||||
# Switch back to Q35
|
||||
details.combo_select("Chipset:", "Q35")
|
||||
appl.click()
|
||||
lib.utils.check(lambda: not appl.sensitive)
|
||||
|
@ -694,7 +694,10 @@ class vmmDomain(vmmLibvirtObject):
|
||||
title=_SENTINEL, loader=_SENTINEL,
|
||||
nvram=_SENTINEL, firmware=_SENTINEL):
|
||||
guest = self._make_xmlobj_to_define()
|
||||
|
||||
old_machine = None
|
||||
if machine != _SENTINEL:
|
||||
old_machine = guest.os.machine
|
||||
guest.os.machine = machine
|
||||
self._domain_caps = None
|
||||
if description != _SENTINEL:
|
||||
@ -723,18 +726,14 @@ class vmmDomain(vmmLibvirtObject):
|
||||
if nvram != _SENTINEL:
|
||||
guest.os.nvram = nvram
|
||||
|
||||
if guest.os.machine == "q35":
|
||||
pcie_controllers_already_created = False
|
||||
for dev in guest.devices.controller:
|
||||
if dev.model in ["pcie-root", "pcie-root-port"]:
|
||||
pcie_controllers_already_created = True
|
||||
break
|
||||
if not pcie_controllers_already_created:
|
||||
guest.add_q35_pcie_controllers()
|
||||
elif guest.os.machine == "pc":
|
||||
if old_machine == "pc" and guest.os.machine == "q35":
|
||||
guest.add_q35_pcie_controllers()
|
||||
|
||||
elif old_machine == "q35" and guest.os.machine == "pc":
|
||||
for dev in guest.devices.controller:
|
||||
if dev.model in ["pcie-root", "pcie-root-port"]:
|
||||
guest.remove_device(dev)
|
||||
|
||||
self._redefine_xmlobj(guest)
|
||||
|
||||
def define_os(self, os_name=_SENTINEL):
|
||||
|
Loading…
Reference in New Issue
Block a user