From d8e2fc0c4df5b73c63dd94d2519bde36cd7c1dd1 Mon Sep 17 00:00:00 2001 From: Yingshun Cui Date: Thu, 2 Jan 2025 15:07:47 +0800 Subject: [PATCH] vIOMMU: Add tests of intel iommu without ioapic feature Update to cover intremap on and off. Signed-off-by: Yingshun Cui --- .../vIOMMU/intel_iommu_without_ioapic.cfg | 8 ++++- .../vIOMMU/intel_iommu_without_ioapic.py | 30 +++++++++++-------- spell.ignore | 2 ++ 3 files changed, 26 insertions(+), 14 deletions(-) diff --git a/libvirt/tests/cfg/sriov/vIOMMU/intel_iommu_without_ioapic.cfg b/libvirt/tests/cfg/sriov/vIOMMU/intel_iommu_without_ioapic.cfg index f4c9f5168b..77c03b0822 100644 --- a/libvirt/tests/cfg/sriov/vIOMMU/intel_iommu_without_ioapic.cfg +++ b/libvirt/tests/cfg/sriov/vIOMMU/intel_iommu_without_ioapic.cfg @@ -3,6 +3,12 @@ start_vm = "yes" enable_guest_iommu = "yes" feature_name = "ioapic" - err_msg = "IOMMU interrupt remapping requires split I/O APIC" iommu_dict = {'model': 'intel', 'driver': {'intremap': 'on'}} only q35 + variants: + - default: + iommu_dict = {'model': 'intel'} + - intremap_on: + func_supported_since_libvirt_ver = (10, 10, 0) + iommu_dict = {'model': 'intel', 'driver': {'intremap': 'on'}} + auto_add_ioapic = "yes" diff --git a/libvirt/tests/src/sriov/vIOMMU/intel_iommu_without_ioapic.py b/libvirt/tests/src/sriov/vIOMMU/intel_iommu_without_ioapic.py index 1c9a321a62..b7b3cb5252 100644 --- a/libvirt/tests/src/sriov/vIOMMU/intel_iommu_without_ioapic.py +++ b/libvirt/tests/src/sriov/vIOMMU/intel_iommu_without_ioapic.py @@ -1,15 +1,17 @@ +from virttest import libvirt_version +from virttest import virsh from virttest.libvirt_xml import vm_xml -from virttest.libvirt_xml import xcepts from virttest.utils_libvirt import libvirt_vmxml def run(test, params, env): """ - Check for the error message when using an Intel iommu device - but without defined in the VM + libvirt will automatically add "" + if is set for the intel iommu device """ + libvirt_version.is_libvirt_feature_supported(params) iommu_dict = eval(params.get('iommu_dict', '{}')) - err_msg = params.get("err_msg", "I/O APIC") + auto_add_ioapic = params.get("auto_add_ioapic", "no") == "yes" feature_name = params.get("feature_name", "ioapic") vm_name = params.get("main_vm", "avocado-vt-vm1") @@ -27,15 +29,17 @@ def run(test, params, env): iommu_dev = libvirt_vmxml.create_vm_device_by_type('iommu', iommu_dict) vmxml.add_device(iommu_dev) vmxml.xmltreefile.write() - try: - vmxml.sync() - except xcepts.LibvirtXMLError as details: - test.log.debug("Check '%s' in %s.", err_msg, details) - if not str(details).count(err_msg): - test.fail("Incorrect error message, it should be '{}', but " - "got '{}'.".format(err_msg, details)) + vmxml.sync() + + vmxml = vm_xml.VMXML.new_from_dumpxml(vm_name) + features = vmxml.features + tmp_msg = "" if auto_add_ioapic else "not " + msg = (f"{feature_name} should {tmp_msg}be " + f"added automatically! Actual feature list: {features}") + if auto_add_ioapic == features.has_feature(feature_name): + test.log.debug(msg) else: - test.fail("Vm is expected to fail on defining with intel iommu " - "without ioapic feature, while it succeeds.") + test.fail(msg) + virsh.start(vm.name, debug=True, ignore_status=False) finally: backup_vmxml.sync() diff --git a/spell.ignore b/spell.ignore index 819b5d464e..91c416ce83 100644 --- a/spell.ignore +++ b/spell.ignore @@ -435,6 +435,8 @@ inodes inpect installable installroot +intel +intremap invtsc inx io