libvirt/tests/qemucapabilitiesdata
Michal Privoznik d00816209e qemu_capabilities: Probe SEV capabilities even for QEMU_CAPS_SEV_SNP_GUEST
While it's very unlikely to have QEMU that supports SEV-SNP but
doesn't support plain SEV, for completeness sake we ought to
query SEV capabilities if QEMU supports either. And similarly to
QEMU_CAPS_SEV_GUEST we need to clear the capability if talking to
QEMU proves SEV is not really supported.

This in turn removes the 'sev-snp-guest' capability from one of
our test cases as Peter's machine he uses to refresh capabilities
is not SEV capable. But that's okay. It's consistent with
'sev-guest' capability.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Jiri Denemark <jdenemar@redhat.com>
Reviewed-by: Daniel P. Berrangé <berrange@redhat.com>
2024-06-25 14:46:00 +02:00
..
caps_4.2.0_aarch64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_4.2.0_aarch64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_4.2.0_ppc64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_4.2.0_ppc64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_4.2.0_s390x.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_4.2.0_s390x.xml qemu_capabilities: Retire QEMU_CAPS_DEVICE_VFIO_PCI 2023-09-06 14:09:43 +02:00
caps_4.2.0_x86_64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_4.2.0_x86_64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_5.0.0_aarch64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_5.0.0_aarch64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_5.0.0_ppc64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_5.0.0_ppc64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_5.0.0_riscv64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_5.0.0_riscv64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_5.0.0_x86_64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_5.0.0_x86_64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_5.1.0_sparc.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_5.1.0_sparc.xml qemu: capabilities: Retire QEMU_CAPS_QUERY_HOTPLUGGABLE_CPUS 2023-09-04 10:31:52 +02:00
caps_5.1.0_x86_64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_5.1.0_x86_64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_5.2.0_aarch64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_5.2.0_aarch64.xml qemu: introduce QEMU_CAPS_MACHINE_VIRT_RAS capability 2024-05-02 13:17:16 +02:00
caps_5.2.0_ppc64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_5.2.0_ppc64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_5.2.0_riscv64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_5.2.0_riscv64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_5.2.0_s390x.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_5.2.0_s390x.xml qemu_capabilities: Retire QEMU_CAPS_DEVICE_VFIO_PCI 2023-09-06 14:09:43 +02:00
caps_5.2.0_x86_64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_5.2.0_x86_64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_6.0.0_aarch64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_6.0.0_aarch64.xml qemu: introduce QEMU_CAPS_MACHINE_VIRT_RAS capability 2024-05-02 13:17:16 +02:00
caps_6.0.0_s390x.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_6.0.0_s390x.xml qemu_capabilities: Add QEMU_CAPS_DISPLAY_RELOAD 2024-03-08 17:00:15 +01:00
caps_6.0.0_x86_64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_6.0.0_x86_64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_6.1.0_x86_64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_6.1.0_x86_64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_6.2.0_aarch64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_6.2.0_aarch64.xml qemu: introduce QEMU_CAPS_MACHINE_VIRT_RAS capability 2024-05-02 13:17:16 +02:00
caps_6.2.0_ppc64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_6.2.0_ppc64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_6.2.0_x86_64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_6.2.0_x86_64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_7.0.0_aarch64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_7.0.0_aarch64.xml qemu: introduce QEMU_CAPS_MACHINE_VIRT_RAS capability 2024-05-02 13:17:16 +02:00
caps_7.0.0_aarch64+hvf.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_7.0.0_aarch64+hvf.xml qemu: introduce QEMU_CAPS_MACHINE_VIRT_RAS capability 2024-05-02 13:17:16 +02:00
caps_7.0.0_ppc64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_7.0.0_ppc64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_7.0.0_x86_64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_7.0.0_x86_64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_7.1.0_ppc64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_7.1.0_ppc64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_7.1.0_x86_64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_7.1.0_x86_64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_7.2.0_ppc.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_7.2.0_ppc.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_7.2.0_x86_64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_7.2.0_x86_64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_7.2.0_x86_64+hvf.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_7.2.0_x86_64+hvf.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_8.0.0_riscv64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_8.0.0_riscv64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_8.0.0_x86_64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_8.0.0_x86_64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_8.1.0_s390x.replies tests: Update capabilities for QEMU 8.1.0 on s390x 2024-02-12 11:28:12 +01:00
caps_8.1.0_s390x.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_8.1.0_x86_64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_8.1.0_x86_64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_USB_MTP capability 2024-03-19 17:36:19 +01:00
caps_8.2.0_aarch64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_8.2.0_aarch64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_VIRTIO_SOUND capability 2024-05-02 15:37:53 +02:00
caps_8.2.0_armv7l.replies qemucapabilitiestest: Add test dump for 'armv7l' architecture 2024-03-06 16:30:35 +01:00
caps_8.2.0_armv7l.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_VIRTIO_SOUND capability 2024-05-02 15:37:53 +02:00
caps_8.2.0_loongarch64.replies Add test script for loongarch 2024-03-21 14:42:27 +01:00
caps_8.2.0_loongarch64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_VIRTIO_SOUND capability 2024-05-02 15:37:53 +02:00
caps_8.2.0_s390x.replies tests: Add capabilities for QEMU 8.2.0 on s390x 2024-02-12 11:28:14 +01:00
caps_8.2.0_s390x.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_VIRTIO_SOUND capability 2024-05-02 15:37:53 +02:00
caps_8.2.0_x86_64.replies tests: qemucaps: Make JSON output identical to python's 'json.dump' method 2024-02-01 10:39:40 +01:00
caps_8.2.0_x86_64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_VIRTIO_SOUND capability 2024-05-02 15:37:53 +02:00
caps_9.0.0_x86_64.replies qemucapabilitiestest: Update qemu capability dump for qemu-9.0 release 2024-04-24 14:12:17 +02:00
caps_9.0.0_x86_64.xml qemu_capabilities: Add QEMU_CAPS_DEVICE_VIRTIO_SOUND capability 2024-05-02 15:37:53 +02:00
caps_9.1.0_x86_64.replies qemucapabilitiestest: Update test data for qemu 9.1 dev cycle 2024-06-12 08:21:12 +02:00
caps_9.1.0_x86_64.xml qemu_capabilities: Probe SEV capabilities even for QEMU_CAPS_SEV_SNP_GUEST 2024-06-25 14:46:00 +02:00
README.rst qemucapabilitiesdata: Document faked caps dumps 2024-03-06 16:30:35 +01:00

QEMU capabilities testing

Purpose

Test data in this directory is used:

  • to excercise the capability parsing code in qemucapabilitiestest
  • provides "real" capabilities data for test suites such as domaincapstest qemuxmlconftest, and others
  • provides the required data to validate the QMP commands used by libvirt against qemu's QMP schema

Naming

Files in this directory have the following naming scheme:

caps_$QEMUVERSION_$ARCHITECTURE.$SUFFIX

or:

caps_$QEMUVERSION_$ARCHITECTURE+$VARIANT.$SUFFIX

$QEMUVERSION

Numeric representation of the qemu version, e.g.: 7.0.0

$ARCHITECTURE

Architecture string such as x86_64, aarch64, etc.

$SUFFIX

.replies for the dump of the QMP communication used to probe qemu. .xml for the generated capability dump

$VARIANT

The variant name is an optional arbitrary string, not containing any dot.

A variant is an additional named version of capabilities for given version and architecture tuple. This allows for testing special cases which e.g. depend on a specific host platform or operating system feature, which differs from the main tests. Note that in the test code the variant name is an empty string or includes the '+' sign for ease of use.

Known test variants

+hvf

Variant of the test data using the Apple OSX Hypervisor Framework acceleration for qemu.

Usage in tests

Test suites such as qemucapabilitiestest or domaincapstest pick up the test data automatically once the corresponding .xml or .replies file is present in tests/qemucapabilitiesdata.

Other test suites such as qemuxmlconftest provide macros which invoke test cases using this data such as DO_TEST_CAPS_LATEST.

Capturing QEMU capabilities

QEMU capabilities are captured by running the qemucapsprobe on the QEMU binary on given architecture and then capturing the output. Since virtualization acceleration is also probed it's required to run it on real hardware.

The capabilities dumps contain also host-specific information such as the exact CPU definition of the machine where it was ran on, thus they can differ significantly when run on other machines.

Probing QEMU

Run the qemucapsprobe tool:

$ LIBVIRT_BUILDDIR/tests/qemucapsprobe /path/to/qemu > output.replies

The tool spawns the qemu binary and performs probing as if libvirt would do that. The QMP conversation between qemu and libvirt is dumped to stdout. User running the probe must be able to access the virtualization accelerator (e.g. have proper permissions on /dev/kvm)

Generating the output files

Place the captured output .replies file into this directory and run:

$ VIR_TEST_REGENERATE_OUTPUT=1 ninja test

This runs the test-suite instructing it to update and/or generate all new data the test would normally expect.

Manual modifications the .replies file

In certain cases it's impractical or impossible to re-generate the .replies file on a code change causing a change to the actual QMP query process.

In such case a careful manual modification of the .replies is tolerated.

To aid such modification the tool scripts/qemu-replies-tool.py can be used.

The tool validates and updates the numbering of the entries in the QMP dump in case something was modified.

The tool also allows programatic modification of the .replies file.

Fake test data dumps for certain architectures

For some architectures it was impossible or impractical to fetch real capability dumps. To ensure coverate of certain cases the dumps were collected from corresponding binaries running on a different architecture.

Capabilities dumps for the following architectures are usually produced on real hardware:

  • x86_64
  • aarch64
  • ppc64
  • s390x

In most other cases, x86_64 will be used as the host architecture. A fake caps dump can be usually spotted by absence of KVM support.