Blame SOURCES/virt-manager-cli-add-ioapic.driver-to-features.patch

ba559b
From a024c96367ce5f1f8e24e19e9d0735de308d870b Mon Sep 17 00:00:00 2001
ba559b
From: Jonathon Jongsma <jjongsma@redhat.com>
ba559b
Date: Tue, 11 Jan 2022 11:21:39 -0600
ba559b
Subject: [PATCH] cli: add 'ioapic.driver' to --features
ba559b
ba559b
Add the ability to set the ioapic driver using the --features argument:
ba559b
ba559b
    $ virt-install --features ioapic.driver=qemu ...
ba559b
ba559b
This results in the following xml:
ba559b
ba559b
  <features>
ba559b
    ...
ba559b
    <ioapic driver="qemu"/>
ba559b
  </features>
ba559b
ba559b
This is required in order to install a guest with >255 cpus. Such a
ba559b
configuration requires an iommu with extended interrupt mode enabled,
ba559b
which in turn requires IOMMU interrupt remapping to be enabled, which in
ba559b
turn requires a split I/O APIC.
ba559b
ba559b
Signed-off-by: Jonathon Jongsma <jjongsma@redhat.com>
ba559b
(cherry picked from commit 9766beea0432faad7cded9e0285d05851659020e)
ba559b
ba559b
Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=2039127
ba559b
ba559b
Signed-off-by: Jonathon Jongsma <jjongsma@redhat.com>
ba559b
---
ba559b
 tests/data/cli/compare/virt-install-singleton-config-3.xml | 1 +
ba559b
 tests/data/xmlparse/change-guest-out.xml                   | 1 +
ba559b
 tests/test_cli.py                                          | 2 +-
ba559b
 tests/test_xmlparse.py                                     | 1 +
ba559b
 virtinst/cli.py                                            | 1 +
ba559b
 virtinst/domain/features.py                                | 1 +
ba559b
 6 files changed, 6 insertions(+), 1 deletion(-)
ba559b
ba559b
diff --git a/tests/data/cli/compare/virt-install-singleton-config-3.xml b/tests/data/cli/compare/virt-install-singleton-config-3.xml
ba559b
index d2e7a363..a36c7bf2 100644
ba559b
--- a/tests/data/cli/compare/virt-install-singleton-config-3.xml
ba559b
+++ b/tests/data/cli/compare/virt-install-singleton-config-3.xml
ba559b
@@ -73,6 +73,7 @@
ba559b
     <pvspinlock state="off"/>
ba559b
     <smm state="off"/>
ba559b
     <vmcoreinfo state="on"/>
ba559b
+    <ioapic driver="qemu"/>
ba559b
   </features>
ba559b
   <cpu>
ba559b
     <topology sockets="1" cores="3" threads="2"/>
ba559b
diff --git a/tests/data/xmlparse/change-guest-out.xml b/tests/data/xmlparse/change-guest-out.xml
ba559b
index 17af0826..3faf8783 100644
ba559b
--- a/tests/data/xmlparse/change-guest-out.xml
ba559b
+++ b/tests/data/xmlparse/change-guest-out.xml
ba559b
@@ -32,6 +32,7 @@
ba559b
       <hidden state="on"/>
ba559b
     </kvm>
ba559b
     <pvspinlock state="on"/>
ba559b
+    <ioapic driver="qemu"/>
ba559b
   </features>
ba559b
   <numatune>
ba559b
     <memory nodeset="2,4,6"/>
ba559b
diff --git a/tests/test_cli.py b/tests/test_cli.py
ba559b
index aba1fe3c..2034d21c 100644
ba559b
--- a/tests/test_cli.py
ba559b
+++ b/tests/test_cli.py
ba559b
@@ -558,7 +558,7 @@ c.add_compare("""
ba559b
 --vcpus vcpu.current=3,maxvcpus=4,vcpu.placement=auto
ba559b
 --memory hotplugmemorymax=2048,hotplugmemoryslots=2
ba559b
 --disk none
ba559b
---features apic.eoi=off,hap=on,hyperv.synic.state=on,hyperv.reset.state=off,hyperv.spinlocks.state=on,hyperv.spinlocks.retries=5678,pae=on,pmu.state=on,pvspinlock.state=off,smm.state=off,viridian=on,vmcoreinfo.state=on,vmport.state=off,kvm.hidden.state=on,hyperv.vapic.state=off,hyperv.relaxed.state=off,gic.version=host,kvm.hint-dedicated.state=on
ba559b
+--features apic.eoi=off,hap=on,hyperv.synic.state=on,hyperv.reset.state=off,hyperv.spinlocks.state=on,hyperv.spinlocks.retries=5678,pae=on,pmu.state=on,pvspinlock.state=off,smm.state=off,viridian=on,vmcoreinfo.state=on,vmport.state=off,kvm.hidden.state=on,hyperv.vapic.state=off,hyperv.relaxed.state=off,gic.version=host,kvm.hint-dedicated.state=on,ioapic.driver=qemu
ba559b
 --clock rtc_present=no,pit_present=yes,pit_tickpolicy=catchup,tsc_present=no,platform_present=no,hypervclock_present=no,platform_tickpolicy=foo,hpet_tickpolicy=bar,tsc_tickpolicy=wibble,kvmclock_tickpolicy=wobble,hypervclock_tickpolicy=woo
ba559b
 --boot bios.useserial=no,bios.rebootTimeout=60,cmdline=root=/foo,smbios.mode=host,bootmenu.enable=yes,loader_ro=yes,loader.type=rom,loader=/tmp/foo
ba559b
 --memorybacking access.mode=shared,source.type=anonymous,hugepages=on
ba559b
diff --git a/tests/test_xmlparse.py b/tests/test_xmlparse.py
ba559b
index 6d1aaddb..ac2fb38d 100644
ba559b
--- a/tests/test_xmlparse.py
ba559b
+++ b/tests/test_xmlparse.py
ba559b
@@ -160,6 +160,7 @@ def testAlterGuest():
ba559b
     check("kvm_hidden", None, True)
ba559b
     check("pvspinlock", None, True)
ba559b
     check("gic_version", None, False)
ba559b
+    check("ioapic_driver", None, "qemu")
ba559b
 
ba559b
     check = _make_checker(guest.cpu)
ba559b
     check("match", "exact", "strict")
ba559b
diff --git a/virtinst/cli.py b/virtinst/cli.py
ba559b
index e1a988f9..dbd4a545 100644
ba559b
--- a/virtinst/cli.py
ba559b
+++ b/virtinst/cli.py
ba559b
@@ -2777,6 +2777,7 @@ class ParserFeatures(VirtCLIParser):
ba559b
 
ba559b
         cls.add_arg("smm.state", "smm", is_onoff=True)
ba559b
         cls.add_arg("vmcoreinfo.state", "vmcoreinfo", is_onoff=True)
ba559b
+        cls.add_arg("ioapic.driver", "ioapic_driver")
ba559b
 
ba559b
 
ba559b
 ###################
ba559b
diff --git a/virtinst/domain/features.py b/virtinst/domain/features.py
ba559b
index 246839f2..7d32edc0 100644
ba559b
--- a/virtinst/domain/features.py
ba559b
+++ b/virtinst/domain/features.py
ba559b
@@ -41,6 +41,7 @@ class DomainFeatures(XMLBuilder):
ba559b
 
ba559b
     smm = XMLProperty("./smm/@state", is_onoff=True)
ba559b
     vmcoreinfo = XMLProperty("./vmcoreinfo/@state", is_onoff=True)
ba559b
+    ioapic_driver = XMLProperty("./ioapic/@driver")
ba559b
 
ba559b
 
ba559b
     ##################
ba559b
-- 
ba559b
2.34.1
ba559b