1
0
mirror of https://gitlab.com/libvirt/libvirt.git synced 2025-01-06 17:17:56 +03:00
libvirt/tests/qemucapabilitiesdata
Peter Krempa f38c2c3729 qemucapabilitiestest: Add test data for qemu-9.1 dev cycle
Add test data based on qemu commit v9.0.0-995-g60b54b67c6 on x86_64

Comparison to previous release:

Feature additions:
 - 9.1 machine type added
 - 'SierraForest' cpu type added
 - 'SapphireRapids-v3-x86_64-cpu' added
 - 'VFIO_MIGRATION' event added (and corresponding 'migration-events'
   bool for the device
 - 'exit-on-error' argument for 'migrate-incoming' added
 - 'sev-guest' gained 'legacy-vm-type' boolean
 - cpu topology added 'module' fields
 - 'compat-props' argument 'query-machines' added
 - 'deprecated-props' argument for 'query-cpu-model-expansion' added

Deprecated removals:
 - legacy non-shared-storage migration fully removed (config/stats)
 - legacy migration compression fully removed
 - RDMA support removed
 - dropped 'nios2' field type from 'query-cpus-fast' return data

Note that this dump was done on a newer kernel version which resulted in
the 'pcommit' feature being removed from the few test cases which depend
on the real CPU flag dump.

Signed-off-by: Peter Krempa <pkrempa@redhat.com>
Reviewed-by: Jiri Denemark <jdenemar@redhat.com>
2024-05-28 09:51:40 +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: Add test data for qemu-9.1 dev cycle 2024-05-28 09:51:40 +02:00
caps_9.1.0_x86_64.xml qemucapabilitiestest: Add test data for qemu-9.1 dev cycle 2024-05-28 09:51:40 +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.