2008-01-29 21:15:54 +03:00
# include <config.h>
2007-11-26 15:03:34 +03:00
# include <unistd.h>
2007-07-19 01:34:22 +04:00
# include <sys/types.h>
# include <fcntl.h>
2013-04-16 17:41:44 +04:00
# include "testutils.h"
2020-10-05 18:52:29 +03:00
# include "internal.h"
# include "testutilsqemu.h"
# include "virfilewrapper.h"
# include "configmake.h"
2007-11-26 15:03:34 +03:00
2021-04-09 16:41:53 +03:00
# define LIBVIRT_QEMU_CAPSPRIV_H_ALLOW
# include "qemu/qemu_capspriv.h"
2020-10-05 18:52:29 +03:00
# define VIR_FROM_THIS VIR_FROM_NONE
2013-06-07 19:10:28 +04:00
2012-11-28 20:43:10 +04:00
static virQEMUDriver driver ;
2007-07-19 01:34:22 +04:00
2015-03-23 19:24:43 +03:00
enum {
WHEN_INACTIVE = 1 ,
WHEN_ACTIVE = 2 ,
WHEN_BOTH = 3 ,
} ;
2016-01-28 00:03:52 +03:00
2021-04-09 16:41:53 +03:00
static int
testXML2XMLCommon ( const struct testQemuInfo * info )
{
2021-08-17 16:30:44 +03:00
if ( testQemuInfoInitArgs ( ( struct testQemuInfo * ) info ) < 0 )
return - 1 ;
2023-03-02 19:44:21 +03:00
virFileCacheClear ( driver . qemuCapsCache ) ;
2023-03-08 19:34:25 +03:00
if ( qemuTestCapsCacheInsert ( driver . qemuCapsCache , info - > qemuCaps ) < 0 )
2021-08-17 16:30:44 +03:00
return - 1 ;
2021-04-09 16:41:53 +03:00
return 0 ;
}
2015-03-23 19:24:43 +03:00
static int
testXML2XMLActive ( const void * opaque )
{
2019-03-31 19:36:27 +03:00
const struct testQemuInfo * info = opaque ;
2015-03-23 19:24:43 +03:00
2021-08-17 17:35:20 +03:00
if ( testXML2XMLCommon ( info ) < 0 | |
testCompareDomXML2XMLFiles ( driver . caps , driver . xmlopt ,
info - > infile , info - > outfile , true ,
info - > parseFlags ,
TEST_COMPARE_DOM_XML2XML_RESULT_SUCCESS ) < 0 ) {
2021-04-09 16:41:53 +03:00
return - 1 ;
2021-08-17 17:35:20 +03:00
}
2021-04-09 16:41:53 +03:00
2021-08-17 17:35:20 +03:00
return 0 ;
2015-03-23 19:24:43 +03:00
}
2010-07-25 02:18:18 +04:00
2011-04-25 02:25:10 +04:00
static int
2015-03-23 19:24:43 +03:00
testXML2XMLInactive ( const void * opaque )
2011-04-25 02:25:10 +04:00
{
2019-03-31 19:36:27 +03:00
const struct testQemuInfo * info = opaque ;
2015-03-23 19:24:43 +03:00
2021-08-17 17:35:20 +03:00
if ( testXML2XMLCommon ( info ) < 0 | |
testCompareDomXML2XMLFiles ( driver . caps , driver . xmlopt ,
info - > infile , info - > outfile , false ,
info - > parseFlags ,
TEST_COMPARE_DOM_XML2XML_RESULT_SUCCESS ) < 0 ) {
2021-04-09 16:41:53 +03:00
return - 1 ;
2021-08-17 17:35:20 +03:00
}
2021-04-09 16:41:53 +03:00
2021-08-17 17:35:20 +03:00
return 0 ;
2015-03-23 19:24:43 +03:00
}
2010-07-25 02:18:18 +04:00
2015-03-23 19:24:43 +03:00
2021-03-26 20:53:32 +03:00
static void
2019-03-31 19:36:27 +03:00
testInfoSetPaths ( struct testQemuInfo * info ,
2019-04-16 01:43:32 +03:00
const char * suffix ,
2019-03-31 19:21:45 +03:00
int when )
2018-03-02 18:47:32 +03:00
{
2019-03-31 19:33:52 +03:00
VIR_FREE ( info - > infile ) ;
VIR_FREE ( info - > outfile ) ;
2019-10-22 16:26:14 +03:00
info - > infile = g_strdup_printf ( " %s/qemuxml2argvdata/%s.xml " , abs_srcdir ,
info - > name ) ;
2015-03-23 19:24:43 +03:00
2019-10-22 16:26:14 +03:00
info - > outfile = g_strdup_printf ( " %s/qemuxml2xmloutdata/%s-%s%s.xml " ,
abs_srcdir , info - > name ,
when = = WHEN_ACTIVE ? " active " : " inactive " , suffix ) ;
2015-03-23 19:24:43 +03:00
2019-03-31 19:33:52 +03:00
if ( ! virFileExists ( info - > outfile ) ) {
VIR_FREE ( info - > outfile ) ;
2013-09-25 18:56:05 +04:00
2019-10-22 16:26:14 +03:00
info - > outfile = g_strdup_printf ( " %s/qemuxml2xmloutdata/%s%s.xml " ,
abs_srcdir , info - > name , suffix ) ;
2014-04-17 17:23:21 +04:00
}
2007-07-19 01:34:22 +04:00
}
2018-03-02 18:47:32 +03:00
2008-05-29 19:31:49 +04:00
static int
2011-04-29 20:21:20 +04:00
mymain ( void )
2007-07-19 01:34:22 +04:00
{
int ret = 0 ;
2020-09-04 09:59:08 +03:00
g_autoptr ( virQEMUDriverConfig ) cfg = NULL ;
2021-08-17 17:26:58 +03:00
g_autoptr ( GHashTable ) capslatest = testQemuGetLatestCaps ( ) ;
2022-07-13 23:26:51 +03:00
g_autoptr ( GHashTable ) capscache = virHashNew ( virObjectUnref ) ;
2020-06-25 17:34:30 +03:00
g_autoptr ( virConnect ) conn = NULL ;
2021-08-17 17:26:58 +03:00
struct testQemuConf testConf = { . capslatest = capslatest ,
. capscache = capscache ,
2021-08-20 17:34:26 +03:00
. qapiSchemaCache = NULL } ;
2019-03-31 23:44:25 +03:00
if ( ! capslatest )
return EXIT_FAILURE ;
2008-02-27 07:35:08 +03:00
2019-08-12 18:06:22 +03:00
/* Required for tpm-emulator tests
*/
virFileWrapperAddPrefix ( SYSCONFDIR " /qemu/firmware " ,
abs_srcdir " /qemufirmwaredata/etc/qemu/firmware " ) ;
virFileWrapperAddPrefix ( PREFIX " /share/qemu/firmware " ,
abs_srcdir " /qemufirmwaredata/usr/share/qemu/firmware " ) ;
virFileWrapperAddPrefix ( " /home/user/.config/qemu/firmware " ,
abs_srcdir " /qemufirmwaredata/home/user/.config/qemu/firmware " ) ;
2015-09-15 09:16:02 +03:00
if ( qemuTestDriverInit ( & driver ) < 0 )
2012-03-22 15:33:35 +04:00
return EXIT_FAILURE ;
2008-02-27 07:35:08 +03:00
2016-05-19 11:53:55 +03:00
cfg = virQEMUDriverGetConfig ( & driver ) ;
2020-06-25 17:34:30 +03:00
if ( ! ( conn = virGetConnect ( ) ) )
goto cleanup ;
virSetConnectInterface ( conn ) ;
virSetConnectNetwork ( conn ) ;
virSetConnectNWFilter ( conn ) ;
virSetConnectNodeDev ( conn ) ;
virSetConnectSecret ( conn ) ;
virSetConnectStorage ( conn ) ;
2021-08-16 18:02:16 +03:00
# define DO_TEST_FULL(_name, suffix, when, ...) \
2017-11-03 15:09:47 +03:00
do { \
2019-04-16 01:19:19 +03:00
static struct testQemuInfo info = { \
. name = _name , \
} ; \
2021-08-17 16:30:44 +03:00
testQemuInfoSetArgs ( & info , & testConf , __VA_ARGS__ ) ; \
2017-11-03 15:09:47 +03:00
\
2019-03-31 19:33:52 +03:00
if ( when & WHEN_INACTIVE ) { \
2021-03-26 20:53:32 +03:00
testInfoSetPaths ( & info , suffix , WHEN_INACTIVE ) ; \
2021-08-20 17:34:26 +03:00
virTestRunLog ( & ret , " QEMU XML-2-XML-inactive " _name , testXML2XMLInactive , & info ) ; \
2017-11-03 15:09:47 +03:00
} \
\
2019-03-31 19:33:52 +03:00
if ( when & WHEN_ACTIVE ) { \
2021-03-26 20:53:32 +03:00
testInfoSetPaths ( & info , suffix , WHEN_ACTIVE ) ; \
2021-08-20 17:34:26 +03:00
virTestRunLog ( & ret , " QEMU XML-2-XML-active " _name , testXML2XMLActive , & info ) ; \
2017-11-03 15:09:47 +03:00
} \
2019-03-31 19:36:27 +03:00
testQemuInfoClear ( & info ) ; \
2010-07-25 02:18:18 +04:00
} while ( 0 )
2020-10-05 18:52:29 +03:00
# define DO_TEST_CAPS_INTERNAL(name, arch, ver, ...) \
2021-08-16 18:02:16 +03:00
DO_TEST_FULL ( name , " . " arch " - " ver , WHEN_BOTH , \
ARG_CAPS_ARCH , arch , \
ARG_CAPS_VER , ver , \
__VA_ARGS__ , \
ARG_END )
2019-04-16 01:43:32 +03:00
2020-10-05 18:52:29 +03:00
# define DO_TEST_CAPS_ARCH_LATEST_FULL(name, arch, ...) \
2019-04-16 01:43:32 +03:00
DO_TEST_CAPS_INTERNAL ( name , arch , " latest " , __VA_ARGS__ )
2020-10-05 18:52:29 +03:00
# define DO_TEST_CAPS_ARCH_VER_FULL(name, arch, ver, ...) \
2019-07-02 18:35:33 +03:00
DO_TEST_CAPS_INTERNAL ( name , arch , ver , __VA_ARGS__ )
2020-10-05 18:52:29 +03:00
# define DO_TEST_CAPS_ARCH_LATEST(name, arch) \
2019-04-16 01:43:32 +03:00
DO_TEST_CAPS_ARCH_LATEST_FULL ( name , arch , ARG_END )
2023-03-27 20:47:27 +03:00
# define DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE(name, arch) \
DO_TEST_CAPS_ARCH_LATEST_FULL ( name , arch , \
ARG_PARSEFLAGS , VIR_DOMAIN_DEF_PARSE_ABI_UPDATE , \
ARG_END )
2020-10-05 18:52:29 +03:00
# define DO_TEST_CAPS_ARCH_VER(name, arch, ver) \
2019-07-02 18:35:33 +03:00
DO_TEST_CAPS_ARCH_VER_FULL ( name , arch , ver , ARG_END )
2019-07-02 18:33:31 +03:00
2020-10-05 18:52:29 +03:00
# define DO_TEST_CAPS_LATEST(name) \
2019-04-16 01:43:32 +03:00
DO_TEST_CAPS_ARCH_LATEST ( name , " x86_64 " )
2016-01-28 00:19:40 +03:00
2023-05-16 17:50:37 +03:00
# define DO_TEST_CAPS_LATEST_ABI_UPDATE(name) \
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE ( name , " x86_64 " )
2020-10-05 18:52:29 +03:00
# define DO_TEST_CAPS_VER(name, ver) \
2019-07-02 18:33:31 +03:00
DO_TEST_CAPS_ARCH_VER ( name , " x86_64 " , ver )
2020-10-05 18:52:29 +03:00
# define DO_TEST(name, ...) \
2021-08-16 18:02:16 +03:00
DO_TEST_FULL ( name , " " , WHEN_BOTH , \
ARG_QEMU_CAPS , __VA_ARGS__ , QEMU_CAPS_LAST , ARG_END )
2019-07-02 18:33:31 +03:00
2010-07-25 02:18:18 +04:00
/* Unset or set all envvars here that are copied in qemudBuildCommandLine
* using ADD_ENV_COPY , otherwise these tests may fail due to unexpected
* values for these envvars */
2019-12-18 20:16:19 +03:00
g_setenv ( " PATH " , " /bin " , TRUE ) ;
2021-04-01 19:57:36 +03:00
g_unsetenv ( " QEMU_AUDIO_DRV " ) ;
g_unsetenv ( " SDL_AUDIODRIVER " ) ;
2008-04-26 00:46:13 +04:00
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " minimal " ) ;
2019-04-16 02:00:46 +03:00
DO_TEST_CAPS_LATEST ( " genid " ) ;
DO_TEST_CAPS_LATEST ( " genid-auto " ) ;
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " machine-core-on " ) ;
DO_TEST_CAPS_LATEST ( " machine-core-off " ) ;
2022-05-13 17:00:09 +03:00
DO_TEST_CAPS_LATEST ( " machine-smm-on " ) ;
2022-05-13 17:05:26 +03:00
DO_TEST_CAPS_LATEST ( " machine-smm-off " ) ;
2023-03-10 05:38:09 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " machine-loadparm-hostdev " , " s390x " ) ;
2023-03-24 17:10:25 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " machine-loadparm-multiple-disks-nets-s390 " , " s390x " ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " default-kvm-host-arch " ) ;
DO_TEST_CAPS_LATEST ( " default-qemu-host-arch " ) ;
DO_TEST_CAPS_LATEST ( " boot-cdrom " ) ;
DO_TEST_CAPS_LATEST ( " boot-network " ) ;
DO_TEST_CAPS_LATEST ( " boot-floppy " ) ;
2017-02-23 20:47:36 +03:00
DO_TEST ( " boot-floppy-q35 " ,
QEMU_CAPS_DEVICE_IOH3420 ,
QEMU_CAPS_ICH9_AHCI ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " boot-multi " ) ;
DO_TEST_CAPS_LATEST ( " boot-menu-enable-with-timeout " ) ;
DO_TEST_CAPS_LATEST ( " boot-menu-disable " ) ;
DO_TEST_CAPS_LATEST ( " boot-menu-disable-with-timeout " ) ;
DO_TEST_CAPS_LATEST ( " boot-order " ) ;
2016-07-29 16:13:56 +03:00
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " reboot-timeout-enabled " ) ;
DO_TEST_CAPS_LATEST ( " reboot-timeout-disabled " ) ;
2016-07-29 16:13:56 +03:00
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " clock-utc " ) ;
DO_TEST_CAPS_LATEST ( " clock-localtime " ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " cpu-empty " ) ;
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " cpu-kvmclock " ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " cpu-host-kvmclock " ) ;
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " cpu-host-passthrough-features " ) ;
DO_TEST_CAPS_LATEST ( " cpu-host-model-features " ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " cpu-host-model-vendor " ) ;
2019-12-10 02:15:21 +03:00
DO_TEST ( " clock-catchup " , QEMU_CAPS_KVM_PIT_TICK_POLICY ) ;
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " kvmclock " ) ;
DO_TEST_CAPS_LATEST ( " clock-timer-hyperv-rtc " ) ;
2020-02-07 15:11:42 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " clock-timer-armvtimer " , " aarch64 " ) ;
2023-08-14 15:28:48 +03:00
DO_TEST_CAPS_LATEST ( " clock-realtime " ) ;
2022-04-26 18:00:36 +03:00
DO_TEST_CAPS_LATEST ( " clock-absolute " ) ;
2016-07-29 16:13:56 +03:00
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " cpu-eoi-disabled " ) ;
DO_TEST_CAPS_LATEST ( " cpu-eoi-enabled " ) ;
DO_TEST_CAPS_LATEST ( " eoi-disabled " ) ;
DO_TEST_CAPS_LATEST ( " eoi-enabled " ) ;
DO_TEST_CAPS_LATEST ( " pv-spinlock-disabled " ) ;
DO_TEST_CAPS_LATEST ( " pv-spinlock-enabled " ) ;
2016-07-29 16:13:56 +03:00
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " hyperv " ) ;
DO_TEST_CAPS_LATEST ( " hyperv-off " ) ;
DO_TEST_CAPS_LATEST ( " hyperv-panic " ) ;
DO_TEST_CAPS_LATEST ( " hyperv-passthrough " ) ;
DO_TEST_CAPS_LATEST ( " hyperv-stimer-direct " ) ;
2016-07-29 16:13:56 +03:00
2023-08-14 15:28:48 +03:00
DO_TEST_CAPS_LATEST ( " kvm-features " ) ;
DO_TEST_CAPS_LATEST ( " kvm-features-off " ) ;
2016-07-29 16:13:56 +03:00
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " pmu-feature " ) ;
DO_TEST_CAPS_LATEST ( " pmu-feature-off " ) ;
2016-07-29 16:13:56 +03:00
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " pages-discard " ) ;
2022-11-03 12:28:40 +03:00
DO_TEST_CAPS_LATEST ( " pages-discard-hugepages " ) ;
DO_TEST_CAPS_LATEST ( " pages-dimm-discard " ) ;
DO_TEST_CAPS_LATEST ( " hugepages-default " ) ;
DO_TEST_CAPS_LATEST ( " hugepages-default-2M " ) ;
DO_TEST_CAPS_LATEST ( " hugepages-default-system-size " ) ;
DO_TEST_CAPS_LATEST ( " hugepages-nodeset " ) ;
DO_TEST_CAPS_LATEST ( " hugepages-numa-default-2M " ) ;
DO_TEST_CAPS_LATEST ( " hugepages-numa-default-dimm " ) ;
DO_TEST_CAPS_LATEST ( " hugepages-numa-nodeset " ) ;
DO_TEST_CAPS_LATEST ( " hugepages-numa-nodeset-part " ) ;
DO_TEST_CAPS_LATEST ( " hugepages-shared " ) ;
DO_TEST_CAPS_LATEST ( " hugepages-memaccess " ) ;
DO_TEST_CAPS_LATEST ( " hugepages-memaccess2 " ) ;
DO_TEST_CAPS_LATEST ( " hugepages-memaccess3 " ) ;
DO_TEST_CAPS_LATEST ( " hugepages-nvdimm " ) ;
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " nosharepages " ) ;
DO_TEST_CAPS_LATEST ( " restore-v2 " ) ;
DO_TEST_CAPS_LATEST ( " migrate " ) ;
DO_TEST_CAPS_LATEST ( " qemu-ns-no-env " ) ;
2021-03-15 18:35:52 +03:00
DO_TEST_CAPS_LATEST ( " qemu-ns " ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " disk-aio " ) ;
2020-04-21 15:19:37 +03:00
DO_TEST_CAPS_LATEST ( " disk-aio-io_uring " ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " disk-cdrom " ) ;
2023-08-15 15:43:20 +03:00
/* The 'disk-cdrom-empty-network-invalid' test case uses separate
* ' - active ' / ' - inactive ' output files to work around ' virschematest '
* thinking the output file is invalid XML */
2019-10-15 16:19:58 +03:00
DO_TEST_CAPS_LATEST ( " disk-cdrom-empty-network-invalid " ) ;
2022-04-20 10:26:57 +03:00
DO_TEST_CAPS_LATEST ( " disk-cdrom-network " ) ;
2020-10-08 22:35:58 +03:00
DO_TEST ( " disk-cdrom-bus-other " , QEMU_CAPS_DEVICE_USB_STORAGE ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " disk-floppy " ) ;
2020-10-08 22:35:58 +03:00
DO_TEST ( " disk-usb-device " , QEMU_CAPS_DEVICE_USB_STORAGE ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " disk-virtio " ) ;
DO_TEST_CAPS_LATEST ( " floppy-drive-fat " ) ;
2021-09-09 06:34:44 +03:00
DO_TEST_CAPS_LATEST ( " disk-virtio-queues " ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " disk-boot-disk " ) ;
DO_TEST_CAPS_LATEST ( " disk-boot-cdrom " ) ;
DO_TEST_CAPS_LATEST ( " disk-error-policy " ) ;
2021-05-21 15:13:50 +03:00
DO_TEST_CAPS_LATEST ( " disk-transient " ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " disk-fmt-qcow " ) ;
2020-01-22 19:15:35 +03:00
DO_TEST_CAPS_LATEST ( " disk-cache " ) ;
2021-01-06 20:20:22 +03:00
DO_TEST_CAPS_LATEST ( " disk-metadata-cache " ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " disk-network-nbd " ) ;
2020-10-08 19:02:12 +03:00
DO_TEST ( " disk-network-iscsi " , QEMU_CAPS_VIRTIO_SCSI ,
QEMU_CAPS_SCSI_BLOCK ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " disk-network-gluster " ) ;
DO_TEST_CAPS_LATEST ( " disk-network-rbd " ) ;
2021-10-24 12:51:29 +03:00
DO_TEST_CAPS_LATEST ( " disk-network-rbd-encryption " ) ;
2023-03-13 12:50:21 +03:00
DO_TEST_CAPS_LATEST ( " disk-network-rbd-encryption-layering " ) ;
2023-03-13 12:50:23 +03:00
DO_TEST_CAPS_LATEST ( " disk-network-rbd-encryption-luks-any " ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " disk-network-source-auth " ) ;
DO_TEST_CAPS_LATEST ( " disk-network-sheepdog " ) ;
2023-08-15 14:18:33 +03:00
DO_TEST_CAPS_VER ( " disk-network-vxhs " , " 5.0.0 " ) ;
2021-01-07 00:32:32 +03:00
DO_TEST_CAPS_LATEST ( " disk-network-nfs " ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " disk-network-tlsx509-nbd " ) ;
2022-03-10 12:05:53 +03:00
DO_TEST_CAPS_LATEST ( " disk-network-tlsx509-nbd-hostname " ) ;
2023-08-15 14:18:33 +03:00
DO_TEST_CAPS_VER ( " disk-network-tlsx509-vxhs " , " 5.0.0 " ) ;
2022-07-15 17:35:27 +03:00
DO_TEST_CAPS_LATEST ( " disk-nvme " ) ;
2021-01-25 20:13:29 +03:00
DO_TEST_CAPS_LATEST ( " disk-vhostuser " ) ;
2023-03-02 15:15:50 +03:00
DO_TEST_CAPS_LATEST ( " disk-sata-device " ) ;
2020-05-13 04:55:47 +03:00
DO_TEST_CAPS_LATEST ( " disk-scsi " ) ;
2017-11-27 13:54:33 +03:00
DO_TEST ( " disk-virtio-scsi-reservations " ,
2020-10-08 19:02:12 +03:00
QEMU_CAPS_VIRTIO_SCSI ,
QEMU_CAPS_PR_MANAGER_HELPER ,
QEMU_CAPS_SCSI_BLOCK ) ;
2019-01-28 12:47:21 +03:00
DO_TEST ( " controller-virtio-scsi " , QEMU_CAPS_VIRTIO_SCSI ) ;
2023-03-24 17:10:25 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " disk-virtio-s390-zpci " , " s390x " ) ;
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " disk-mirror-old " ) ;
DO_TEST_CAPS_LATEST ( " disk-mirror " ) ;
DO_TEST_CAPS_LATEST ( " disk-active-commit " ) ;
2019-12-10 02:15:26 +03:00
DO_TEST ( " graphics-listen-network " ,
QEMU_CAPS_DEVICE_CIRRUS_VGA ,
QEMU_CAPS_VNC ) ;
DO_TEST ( " graphics-vnc " ,
QEMU_CAPS_DEVICE_CIRRUS_VGA ,
QEMU_CAPS_VNC ) ;
DO_TEST ( " graphics-vnc-websocket " ,
QEMU_CAPS_DEVICE_CIRRUS_VGA ,
QEMU_CAPS_VNC ) ;
DO_TEST ( " graphics-vnc-sasl " ,
QEMU_CAPS_DEVICE_CIRRUS_VGA ,
QEMU_CAPS_VNC ) ;
DO_TEST ( " graphics-vnc-tls " ,
QEMU_CAPS_DEVICE_CIRRUS_VGA ,
QEMU_CAPS_VNC ) ;
DO_TEST ( " graphics-vnc-no-listen-attr " ,
QEMU_CAPS_DEVICE_CIRRUS_VGA ,
QEMU_CAPS_VNC ) ;
DO_TEST ( " graphics-vnc-remove-generated-socket " ,
QEMU_CAPS_DEVICE_CIRRUS_VGA ,
QEMU_CAPS_VNC ) ;
2016-05-19 11:53:55 +03:00
cfg - > vncAutoUnixSocket = true ;
2019-12-10 02:15:26 +03:00
DO_TEST ( " graphics-vnc-auto-socket-cfg " ,
QEMU_CAPS_DEVICE_CIRRUS_VGA ,
QEMU_CAPS_VNC ) ;
2016-05-19 11:53:55 +03:00
cfg - > vncAutoUnixSocket = false ;
2019-12-10 02:15:26 +03:00
DO_TEST ( " graphics-vnc-socket " ,
QEMU_CAPS_DEVICE_CIRRUS_VGA ,
QEMU_CAPS_VNC ) ;
DO_TEST ( " graphics-vnc-auto-socket " ,
QEMU_CAPS_DEVICE_CIRRUS_VGA ,
QEMU_CAPS_VNC ) ;
2018-12-07 16:53:46 +03:00
DO_TEST ( " graphics-vnc-egl-headless " ,
2019-12-10 02:15:26 +03:00
QEMU_CAPS_DEVICE_CIRRUS_VGA ,
2021-06-15 12:46:54 +03:00
QEMU_CAPS_VNC ,
QEMU_CAPS_EGL_HEADLESS ) ;
2019-10-18 18:30:11 +03:00
2023-08-15 17:30:21 +03:00
DO_TEST_CAPS_LATEST ( " graphics-dbus " ) ;
DO_TEST_CAPS_LATEST ( " graphics-dbus-address " ) ;
DO_TEST_CAPS_LATEST ( " graphics-dbus-p2p " ) ;
DO_TEST_CAPS_LATEST ( " graphics-dbus-audio " ) ;
DO_TEST_CAPS_LATEST ( " graphics-dbus-chardev " ) ;
2022-05-13 21:38:11 +03:00
2019-11-25 13:54:26 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " default-video-type-aarch64 " , " aarch64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " default-video-type-ppc64 " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " default-video-type-riscv64 " , " riscv64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " default-video-type-s390x " , " s390x " ) ;
2019-12-10 02:15:27 +03:00
DO_TEST ( " default-video-type-x86_64-caps-test-0 " ,
QEMU_CAPS_DEVICE_VGA ,
QEMU_CAPS_SPICE ) ;
DO_TEST ( " default-video-type-x86_64-caps-test-1 " ,
QEMU_CAPS_DEVICE_CIRRUS_VGA ,
QEMU_CAPS_SPICE ) ;
2019-11-25 13:54:26 +03:00
2021-06-15 12:46:54 +03:00
DO_TEST ( " graphics-sdl " , QEMU_CAPS_DEVICE_VGA , QEMU_CAPS_SDL ) ;
DO_TEST ( " graphics-sdl-fullscreen " , QEMU_CAPS_DEVICE_CIRRUS_VGA , QEMU_CAPS_SDL ) ;
2019-12-10 02:15:27 +03:00
cfg - > spiceTLS = true ;
2021-10-13 18:03:33 +03:00
DO_TEST_CAPS_LATEST ( " graphics-spice " ) ;
DO_TEST_CAPS_LATEST ( " graphics-spice-compression " ) ;
DO_TEST_CAPS_LATEST ( " graphics-spice-qxl-vga " ) ;
DO_TEST_CAPS_LATEST ( " graphics-spice-socket " ) ;
DO_TEST_CAPS_LATEST ( " graphics-spice-auto-socket " ) ;
2016-05-18 15:11:20 +03:00
cfg - > spiceAutoUnixSocket = true ;
2021-10-13 18:03:33 +03:00
DO_TEST_CAPS_LATEST ( " graphics-spice-auto-socket-cfg " ) ;
2016-05-18 15:11:20 +03:00
cfg - > spiceAutoUnixSocket = false ;
2019-12-10 02:15:27 +03:00
cfg - > spiceTLS = false ;
2021-10-13 18:03:33 +03:00
DO_TEST_CAPS_LATEST ( " graphics-spice-egl-headless " ) ;
DO_TEST_CAPS_LATEST ( " graphics-spice-timeout " ) ;
2016-05-18 15:11:20 +03:00
2018-12-07 16:53:46 +03:00
DO_TEST ( " graphics-egl-headless-rendernode " ,
2019-10-18 18:30:11 +03:00
QEMU_CAPS_DEVICE_CIRRUS_VGA ,
2019-11-25 13:54:24 +03:00
QEMU_CAPS_EGL_HEADLESS_RENDERNODE ,
2021-06-15 12:46:54 +03:00
QEMU_CAPS_EGL_HEADLESS ) ;
2018-11-27 10:23:13 +03:00
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " input-usbmouse " ) ;
DO_TEST_CAPS_LATEST ( " input-usbtablet " ) ;
DO_TEST_CAPS_LATEST ( " misc-acpi " ) ;
2019-12-10 02:15:22 +03:00
DO_TEST ( " misc-disable-s3 " , QEMU_CAPS_PIIX_DISABLE_S3 ) ;
2021-10-11 15:46:46 +03:00
DO_TEST_CAPS_LATEST ( " pc-i440fx-acpi-root-hotplug-disable " ) ;
DO_TEST_CAPS_LATEST ( " pc-i440fx-acpi-root-hotplug-enable " ) ;
2019-12-10 02:15:22 +03:00
DO_TEST ( " misc-disable-suspends " ,
QEMU_CAPS_PIIX_DISABLE_S3 ,
QEMU_CAPS_PIIX_DISABLE_S4 ) ;
DO_TEST ( " misc-enable-s4 " , QEMU_CAPS_PIIX_DISABLE_S4 ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " misc-no-reboot " ) ;
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " misc-uuid " ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " net-vhostuser " ) ;
DO_TEST_CAPS_LATEST ( " net-user " ) ;
2023-08-14 15:28:48 +03:00
DO_TEST_CAPS_LATEST ( " net-user-addr " ) ;
2023-02-20 23:14:23 +03:00
DO_TEST_CAPS_LATEST ( " net-user-passt " ) ;
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " net-virtio " ) ;
DO_TEST_CAPS_LATEST ( " net-virtio-device " ) ;
DO_TEST_CAPS_LATEST ( " net-virtio-disable-offloads " ) ;
DO_TEST_CAPS_LATEST ( " net-eth " ) ;
DO_TEST_CAPS_LATEST ( " net-eth-ifname " ) ;
DO_TEST_CAPS_LATEST ( " net-eth-hostip " ) ;
DO_TEST_CAPS_LATEST ( " net-eth-unmanaged-tap " ) ;
DO_TEST_CAPS_LATEST ( " net-virtio-network-portgroup " ) ;
DO_TEST_CAPS_LATEST ( " net-virtio-rxtxqueuesize " ) ;
2020-01-23 00:24:10 +03:00
DO_TEST ( " net-virtio-teaming " ,
QEMU_CAPS_DEVICE_VFIO_PCI ) ;
DO_TEST ( " net-virtio-teaming-network " ,
conf: parse/format <teaming> element in plain <hostdev>
The <teaming> element in <interface> allows pairing two interfaces
together as a simple "failover bond" network device in a guest. One of
the devices is the "transient" interface - it will be preferred for
all network traffic when it is present, but may be removed when
necessary, in particular during migration, when traffic will instead
go through the other interface of the pair - the "persistent"
interface. As it happens, in the QEMU implementation of this teaming
pair (called "virtio failover" in QEMU) the transient interface is
always a host network device assigned to the guest using VFIO (aka
"hostdev"); the persistent interface is always an emulated virtio NIC.
When support was initially added for <teaming>, it was written to
require that the transient/hostdev device be defined using <interface
type='hostdev'>; this was done because the virtio failover
implementation in QEMU and the virtio guest driver demands that the
two interfaces in the pair have matching MAC addresses, and the only
way libvirt can guarantee the MAC address of a hostdev network device
is to use <interface type='hostdev'>, whose main purpose is to
configure the device's MAC address before handing the device to
QEMU. (note that <interface type='hostdev'> in turn requires that the
network device be an SRIOV VF (Virtual Function), as that is the only
type of network device whose MAC address we can set in a way that will
survive the device's driver init in the guest).
It has recently come up that some users are unable to use <teaming>
because they are running in a container environment where libvirt
doesn't have the necessary privileges or resources to set the VF's MAC
address (because setting the VF MAC is done via the same device's PF
(Physical Function), and the PF is not exposed to libvirt's container).
At the same time, these users *are* able to set the VF's MAC address
themselves in advance of staring up libvirt in the container. So they
could theoretically use the <teaming> feature if libvirt just skipped
the "setting the MAC address" part.
Fortunately, that is *exactly* the difference between <interface
type='hostdev'> (which must be a "hostdev VF") and <hostdev> (a "plain
hostdev" - it could be *any* PCI device; libvirt doesn't know what type
of PCI device it is, and doesn't care).
But what is still needed is for libvirt to provide a small bit of
information on the QEMU commandline argument for the hostdev, telling
QEMU that this device will be part of a team ("failover pair"), and
the id of the other device in the pair.
To make both of those goals simultaneously possible, this patch adds
support for the <teaming> element to plain <hostdev> - libvirt doesn't
try to set any MAC addresses, and QEMU gets the extra commandline
argument it needs)
(actually, this patch adds only the parsing/formatting of the
<teaming> element in <hostdev>. The next patch will actually wire that
into the qemu driver.)
Signed-off-by: Laine Stump <laine@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
2021-02-11 08:58:29 +03:00
QEMU_CAPS_DEVICE_VFIO_PCI ) ;
DO_TEST ( " net-virtio-teaming-hostdev " ,
2020-01-23 00:24:10 +03:00
QEMU_CAPS_DEVICE_VFIO_PCI ) ;
2020-01-29 18:29:21 +03:00
DO_TEST_CAPS_LATEST ( " net-isolated-port " ) ;
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " net-hostdev " ) ;
DO_TEST_CAPS_LATEST ( " net-hostdev-bootorder " ) ;
2019-12-10 02:15:18 +03:00
DO_TEST ( " net-hostdev-vfio " , QEMU_CAPS_DEVICE_VFIO_PCI ) ;
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " net-midonet " ) ;
DO_TEST_CAPS_LATEST ( " net-openvswitch " ) ;
2023-05-09 14:13:19 +03:00
DO_TEST_CAPS_LATEST ( " sound-device " ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " watchdog " ) ;
2022-11-08 11:10:57 +03:00
DO_TEST_CAPS_LATEST ( " watchdog-q35-multiple " ) ;
2019-12-10 02:15:26 +03:00
DO_TEST ( " net-bandwidth " , QEMU_CAPS_DEVICE_VGA , QEMU_CAPS_VNC ) ;
DO_TEST ( " net-bandwidth2 " , QEMU_CAPS_DEVICE_VGA , QEMU_CAPS_VNC ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " net-mtu " ) ;
DO_TEST_CAPS_LATEST ( " net-coalesce " ) ;
2023-08-15 13:21:07 +03:00
DO_TEST_CAPS_LATEST ( " net-many-models " ) ;
2020-10-14 20:08:27 +03:00
DO_TEST ( " net-vdpa " , QEMU_CAPS_NETDEV_VHOST_VDPA ) ;
2022-03-02 01:55:21 +03:00
DO_TEST ( " net-vdpa-multiqueue " , QEMU_CAPS_NETDEV_VHOST_VDPA ) ;
2022-01-10 00:07:35 +03:00
DO_TEST_CAPS_LATEST ( " net-virtio-rss " ) ;
2016-07-29 16:13:56 +03:00
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " serial-tcp-tlsx509-chardev " ) ;
2023-08-14 15:28:48 +03:00
DO_TEST_CAPS_LATEST ( " serial-tcp-tlsx509-chardev-notls " ) ;
2019-12-10 02:15:27 +03:00
cfg - > spiceTLS = true ;
DO_TEST ( " serial-spiceport " ,
QEMU_CAPS_DEVICE_QXL ,
QEMU_CAPS_SPICE ) ;
cfg - > spiceTLS = false ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " serial-debugcon " ) ;
DO_TEST_CAPS_LATEST ( " console-compat " ) ;
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " console-compat2 " ) ;
DO_TEST_CAPS_LATEST ( " console-virtio-many " ) ;
DO_TEST_CAPS_LATEST ( " channel-guestfwd " ) ;
DO_TEST_CAPS_LATEST ( " channel-virtio " ) ;
DO_TEST_CAPS_LATEST ( " channel-virtio-state " ) ;
2016-07-29 16:13:56 +03:00
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " channel-unix-source-path " ) ;
2017-05-11 15:09:35 +03:00
2022-07-12 14:00:33 +03:00
DO_TEST_CAPS_LATEST ( " hostdev-usb-address " ) ;
DO_TEST_CAPS_LATEST ( " hostdev-pci-address " ) ;
2019-12-17 23:35:02 +03:00
DO_TEST ( " hostdev-pci-address-unassigned " , QEMU_CAPS_DEVICE_VFIO_PCI ) ;
2019-12-10 02:15:18 +03:00
DO_TEST ( " hostdev-pci-multifunction " , QEMU_CAPS_DEVICE_VFIO_PCI ) ;
DO_TEST ( " hostdev-vfio " , QEMU_CAPS_DEVICE_VFIO_PCI ) ;
2023-03-24 17:10:25 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " hostdev-vfio-zpci " , " s390x " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " hostdev-vfio-zpci-multidomain-many " , " s390x " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " hostdev-vfio-zpci-autogenerate " , " s390x " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " hostdev-vfio-zpci-autogenerate-uids " , " s390x " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " hostdev-vfio-zpci-autogenerate-fids " , " s390x " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " hostdev-vfio-zpci-boundaries " , " s390x " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " hostdev-vfio-zpci-ccw-memballoon " , " s390x " ) ;
2019-12-10 02:15:18 +03:00
DO_TEST ( " hostdev-mdev-precreated " , QEMU_CAPS_DEVICE_VFIO_PCI ) ;
2019-10-18 18:30:11 +03:00
DO_TEST ( " hostdev-mdev-display " ,
QEMU_CAPS_DEVICE_QXL ,
2019-12-10 02:15:18 +03:00
QEMU_CAPS_VFIO_PCI_DISPLAY ,
2019-12-10 02:15:26 +03:00
QEMU_CAPS_DEVICE_VFIO_PCI ,
QEMU_CAPS_VNC ) ;
2020-06-23 21:29:56 +03:00
DO_TEST_CAPS_LATEST ( " hostdev-mdev-display-ramfb " ) ;
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " pci-rom " ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " pci-rom-disabled " ) ;
DO_TEST_CAPS_LATEST ( " pci-rom-disabled-invalid " ) ;
DO_TEST_CAPS_LATEST ( " pci-serial-dev-chardev " ) ;
2016-07-29 16:13:56 +03:00
2020-02-05 20:18:39 +03:00
DO_TEST_CAPS_LATEST ( " disk-slices " ) ;
2021-03-31 12:17:07 +03:00
DO_TEST_CAPS_LATEST ( " disk-rotation " ) ;
2020-02-05 20:18:39 +03:00
2022-07-15 17:35:27 +03:00
DO_TEST_CAPS_LATEST ( " encrypted-disk " ) ;
DO_TEST_CAPS_LATEST ( " encrypted-disk-usage " ) ;
2022-01-05 12:23:42 +03:00
DO_TEST_CAPS_LATEST ( " luks-disks " ) ;
DO_TEST_CAPS_LATEST ( " luks-disks-source " ) ;
2020-01-10 19:35:10 +03:00
DO_TEST_CAPS_LATEST ( " luks-disks-source-qcow2 " ) ;
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " memtune " ) ;
DO_TEST_CAPS_LATEST ( " memtune-unlimited " ) ;
DO_TEST_CAPS_LATEST ( " blkiotune " ) ;
DO_TEST_CAPS_LATEST ( " blkiotune-device " ) ;
2023-02-22 17:57:47 +03:00
DO_TEST_CAPS_LATEST ( " cputune " ) ;
DO_TEST_CAPS_LATEST ( " cputune-zero-shares " ) ;
DO_TEST_CAPS_LATEST ( " cputune-numatune " ) ;
DO_TEST_CAPS_LATEST ( " vcpu-placement-static " ) ;
2020-06-11 14:57:07 +03:00
DO_TEST_CAPS_LATEST ( " cputune-cpuset-big-id " ) ;
2020-06-10 21:35:52 +03:00
DO_TEST_CAPS_LATEST ( " numavcpus-topology-mismatch " ) ;
2010-04-27 14:01:32 +04:00
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " smp " ) ;
2023-02-22 17:23:04 +03:00
DO_TEST_CAPS_LATEST ( " iothreads-ids " ) ;
2022-03-07 17:13:39 +03:00
DO_TEST_CAPS_LATEST ( " iothreads-ids-pool-sizes " ) ;
2023-02-22 17:23:04 +03:00
DO_TEST_CAPS_LATEST ( " iothreads-ids-partial " ) ;
DO_TEST_CAPS_LATEST ( " iothreads-disk " ) ;
2023-02-22 17:37:52 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " iothreads-disk-virtio-ccw " , " s390x " ) ;
DO_TEST_CAPS_LATEST ( " iothreads-virtio-scsi-pci " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " iothreads-virtio-scsi-ccw " , " s390x " ) ;
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " lease " ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " event_idx " ) ;
DO_TEST_CAPS_LATEST ( " vhost_queues " ) ;
DO_TEST_CAPS_LATEST ( " interface-driver " ) ;
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " net-server " ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " virtio-lun " ) ;
2016-07-29 16:13:56 +03:00
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " usb-none " ) ;
DO_TEST_CAPS_LATEST ( " usb-controller " ) ;
2016-07-29 17:09:53 +03:00
DO_TEST ( " usb-piix3-controller " ,
QEMU_CAPS_PIIX3_USB_UHCI ) ;
DO_TEST ( " usb-controller-default-q35 " ,
qemu: initially reserve one open pcie-root-port for hotplug
For machinetypes with a pci-root bus (all legacy PCI), libvirt will
make a "fake" reservation for one extra slot prior to assigning
addresses to unaddressed PCI endpoint devices in the domain. This will
trigger auto-adding of a pci-bridge for the final device to be
assigned an address *if that device would have otherwise instead been
the last device on the last available pci-bridge*; thus it assures
that there will always be at least one slot left open in the domain's
bus topology for expansion (which is important both for hotplug (since
a new pci-bridge can't be added while the guest is running) as well as
for offline additions to the config (since adding a new device might
otherwise in some cases require re-addressing existing devices, which
we want to avoid)).
It's important to note that for the above case (legacy PCI), we must
check for the special case of all slots on all buses being occupied
*prior to assigning any addresses*, and avoid attempting to reserve
the extra address in that case, because there is no free address in
the existing topology, so no place to auto-add a pci-bridge for
expansion (i.e. it would always fail anyway). Since that condition can
only be reached by manual intervention, this is acceptable.
For machinetypes with pcie-root (Q35, aarch64 virt), libvirt's
methodology for automatically expanding the bus topology is different
- pcie-root-ports are plugged into slots (soon to be functions) of
pcie-root as needed, and the new endpoint devices are assigned to the
single slot in each pcie-root-port. This is done so that the devices
are, by default, hotpluggable (the slots of pcie-root don't support
hotplug, but the single slot of the pcie-root-port does). Since
pcie-root-ports can only be plugged into pcie-root, and we don't
auto-assign endpoint devices to the pcie-root slots, this means
topology expansion doesn't compete with endpoint devices for slots, so
we don't need to worry about checking for all "useful" slots being
free *prior* to assigning addresses to new endpoint devices - as a
matter of fact, if we attempt to reserve the open slots before the
used slots, it can lead to errors.
Instead this patch just reserves one slot for a "future potential"
PCIe device after doing the assignment for actual devices, but only
if the only PCI controller defined prior to starting address
assignment was pcie-root, and only if we auto-added at least one PCI
controller during address assignment. This assures two things:
1) that reserving the open slots will only be done when the domain is
initially defined, never at any time after, and
2) that if the user understands enough about PCI controllers that they
are adding them manually, that we don't mess up their plan by
adding extras - if they know enough to add one pcie-root-port, or
to manually assign addresses such that no pcie-root-ports are
needed, they know enough to add extra pcie-root-ports if they want
them (this could be called the "libguestfs clause", since
libguestfs needs to be able to create domains with as few
devices/controllers as possible).
This is set to reserve a single free port for now, but could be
increased in the future if public sentiment goes in that direction
(it's easy to increase later, but essentially impossible to decrease)
2016-09-28 03:37:30 +03:00
QEMU_CAPS_DEVICE_IOH3420 ,
2017-02-23 20:47:36 +03:00
QEMU_CAPS_PCI_OHCI ,
QEMU_CAPS_PIIX3_USB_UHCI ,
2016-07-29 17:09:53 +03:00
QEMU_CAPS_NEC_USB_XHCI ) ;
DO_TEST ( " usb-controller-explicit-q35 " ,
qemu: initially reserve one open pcie-root-port for hotplug
For machinetypes with a pci-root bus (all legacy PCI), libvirt will
make a "fake" reservation for one extra slot prior to assigning
addresses to unaddressed PCI endpoint devices in the domain. This will
trigger auto-adding of a pci-bridge for the final device to be
assigned an address *if that device would have otherwise instead been
the last device on the last available pci-bridge*; thus it assures
that there will always be at least one slot left open in the domain's
bus topology for expansion (which is important both for hotplug (since
a new pci-bridge can't be added while the guest is running) as well as
for offline additions to the config (since adding a new device might
otherwise in some cases require re-addressing existing devices, which
we want to avoid)).
It's important to note that for the above case (legacy PCI), we must
check for the special case of all slots on all buses being occupied
*prior to assigning any addresses*, and avoid attempting to reserve
the extra address in that case, because there is no free address in
the existing topology, so no place to auto-add a pci-bridge for
expansion (i.e. it would always fail anyway). Since that condition can
only be reached by manual intervention, this is acceptable.
For machinetypes with pcie-root (Q35, aarch64 virt), libvirt's
methodology for automatically expanding the bus topology is different
- pcie-root-ports are plugged into slots (soon to be functions) of
pcie-root as needed, and the new endpoint devices are assigned to the
single slot in each pcie-root-port. This is done so that the devices
are, by default, hotpluggable (the slots of pcie-root don't support
hotplug, but the single slot of the pcie-root-port does). Since
pcie-root-ports can only be plugged into pcie-root, and we don't
auto-assign endpoint devices to the pcie-root slots, this means
topology expansion doesn't compete with endpoint devices for slots, so
we don't need to worry about checking for all "useful" slots being
free *prior* to assigning addresses to new endpoint devices - as a
matter of fact, if we attempt to reserve the open slots before the
used slots, it can lead to errors.
Instead this patch just reserves one slot for a "future potential"
PCIe device after doing the assignment for actual devices, but only
if the only PCI controller defined prior to starting address
assignment was pcie-root, and only if we auto-added at least one PCI
controller during address assignment. This assures two things:
1) that reserving the open slots will only be done when the domain is
initially defined, never at any time after, and
2) that if the user understands enough about PCI controllers that they
are adding them manually, that we don't mess up their plan by
adding extras - if they know enough to add one pcie-root-port, or
to manually assign addresses such that no pcie-root-ports are
needed, they know enough to add extra pcie-root-ports if they want
them (this could be called the "libguestfs clause", since
libguestfs needs to be able to create domains with as few
devices/controllers as possible).
This is set to reserve a single free port for now, but could be
increased in the future if public sentiment goes in that direction
(it's easy to increase later, but essentially impossible to decrease)
2016-09-28 03:37:30 +03:00
QEMU_CAPS_DEVICE_IOH3420 ,
2017-02-23 20:47:36 +03:00
QEMU_CAPS_PCI_OHCI ,
QEMU_CAPS_PIIX3_USB_UHCI ,
2016-07-29 17:09:53 +03:00
QEMU_CAPS_NEC_USB_XHCI ) ;
2023-03-09 13:23:33 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " ppc64-usb-controller " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " ppc64-usb-controller-legacy " , " ppc64 " ) ;
2019-12-10 02:15:16 +03:00
DO_TEST ( " usb-port-missing " , QEMU_CAPS_USB_HUB ) ;
2022-05-12 10:40:03 +03:00
DO_TEST ( " usb-redir " , QEMU_CAPS_USB_REDIR ,
QEMU_CAPS_SPICE ,
QEMU_CAPS_DEVICE_CIRRUS_VGA ) ;
2020-10-13 23:10:08 +03:00
DO_TEST ( " usb-redir-filter " ,
QEMU_CAPS_USB_REDIR ,
2022-05-12 10:40:03 +03:00
QEMU_CAPS_USB_REDIR_FILTER ,
QEMU_CAPS_SPICE ,
QEMU_CAPS_DEVICE_CIRRUS_VGA ) ;
2020-10-13 23:10:08 +03:00
DO_TEST ( " usb-redir-filter-version " ,
QEMU_CAPS_USB_REDIR ,
2022-05-12 10:40:03 +03:00
QEMU_CAPS_USB_REDIR_FILTER ,
QEMU_CAPS_SPICE ,
QEMU_CAPS_DEVICE_CIRRUS_VGA ) ;
2020-05-04 19:16:26 +03:00
DO_TEST_CAPS_LATEST ( " blkdeviotune " ) ;
DO_TEST_CAPS_LATEST ( " blkdeviotune-max " ) ;
DO_TEST_CAPS_LATEST ( " blkdeviotune-group-num " ) ;
DO_TEST_CAPS_LATEST ( " blkdeviotune-max-length " ) ;
2022-01-05 15:01:10 +03:00
DO_TEST_CAPS_LATEST ( " controller-usb-order " ) ;
2020-06-10 21:11:49 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " ppc64-tpmproxy-single " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " ppc64-tpmproxy-with-tpm " , " ppc64 " ) ;
2011-09-02 19:09:14 +04:00
2021-08-17 16:12:21 +03:00
DO_TEST_FULL ( " seclabel-dynamic-baselabel " , " " , WHEN_INACTIVE , ARG_END ) ;
DO_TEST_FULL ( " seclabel-dynamic-override " , " " , WHEN_INACTIVE , ARG_END ) ;
DO_TEST_FULL ( " seclabel-dynamic-labelskip " , " " , WHEN_INACTIVE , ARG_END ) ;
DO_TEST_FULL ( " seclabel-dynamic-relabel " , " " , WHEN_INACTIVE , ARG_END ) ;
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " seclabel-static " ) ;
DO_TEST_CAPS_LATEST ( " seclabel-static-labelskip " ) ;
DO_TEST_CAPS_LATEST ( " seclabel-none " ) ;
DO_TEST_CAPS_LATEST ( " seclabel-dac-none " ) ;
DO_TEST_CAPS_LATEST ( " seclabel-dynamic-none " ) ;
DO_TEST_CAPS_LATEST ( " seclabel-device-multiple " ) ;
2021-08-16 18:02:16 +03:00
DO_TEST_FULL ( " seclabel-dynamic-none-relabel " , " " , WHEN_INACTIVE ,
2019-12-10 02:15:12 +03:00
ARG_QEMU_CAPS , QEMU_CAPS_DEVICE_CIRRUS_VGA ,
2021-08-17 14:46:55 +03:00
QEMU_CAPS_SPICE , QEMU_CAPS_LAST ,
2021-08-16 18:02:16 +03:00
ARG_END ) ;
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " numad-static-vcpu-no-numatune " ) ;
2011-12-23 04:47:46 +04:00
2016-07-29 16:27:03 +03:00
DO_TEST ( " disk-scsi-disk-vpd " ,
2023-07-18 16:47:56 +03:00
QEMU_CAPS_SCSI_LSI , QEMU_CAPS_VIRTIO_SCSI ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " disk-source-pool " ) ;
DO_TEST_CAPS_LATEST ( " disk-source-pool-mode " ) ;
2012-12-06 14:23:02 +04:00
2020-05-04 19:53:31 +03:00
DO_TEST_CAPS_LATEST ( " disk-discard " ) ;
DO_TEST_CAPS_LATEST ( " disk-detect-zeroes " ) ;
2023-06-09 13:47:36 +03:00
DO_TEST_CAPS_LATEST ( " disk-discard_no_unref " ) ;
2013-05-14 16:44:54 +04:00
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " disk-serial " ) ;
2017-11-20 14:14:08 +03:00
2020-05-06 12:40:18 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " disk-arm-virtio-sd " , " aarch64 " ) ;
2019-01-22 22:02:27 +03:00
DO_TEST ( " virtio-rng-random " ,
2020-10-09 21:18:53 +03:00
QEMU_CAPS_DEVICE_VIRTIO_RNG ,
QEMU_CAPS_OBJECT_RNG_RANDOM ) ;
2019-01-22 22:02:27 +03:00
DO_TEST ( " virtio-rng-egd " ,
2020-10-09 21:18:53 +03:00
QEMU_CAPS_DEVICE_VIRTIO_RNG ,
QEMU_CAPS_OBJECT_RNG_EGD ) ;
2020-01-09 11:00:08 +03:00
DO_TEST_CAPS_LATEST ( " virtio-rng-builtin " ) ;
2013-02-12 20:56:00 +04:00
2022-05-21 17:54:56 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " pseries-nvram " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " pseries-panic-missing " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " pseries-panic-no-address " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " pseries-phb-simple " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " pseries-phb-default-missing " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " pseries-phb-numa-node " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " pseries-many-devices " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " pseries-many-buses-1 " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " pseries-many-buses-2 " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " pseries-hostdevs-1 " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " pseries-hostdevs-2 " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " pseries-hostdevs-3 " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " pseries-features " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " pseries-serial-native " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " pseries-serial+console-native " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " pseries-serial-compat " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " pseries-serial-pci " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " pseries-serial-usb " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " pseries-console-native " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " pseries-console-virtio " , " ppc64 " ) ;
2018-03-29 13:51:55 +03:00
2023-03-24 18:40:53 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " mach-virt-serial-native " , " aarch64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " mach-virt-serial+console-native " , " aarch64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " mach-virt-serial-compat " , " aarch64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " mach-virt-serial-pci " , " aarch64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " mach-virt-serial-usb " , " aarch64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " mach-virt-console-native " , " aarch64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " mach-virt-console-virtio " , " aarch64 " ) ;
2017-11-09 19:14:57 +03:00
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " balloon-device-auto " ) ;
DO_TEST_CAPS_LATEST ( " balloon-device-period " ) ;
DO_TEST_CAPS_LATEST ( " channel-virtio-auto " ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " console-compat-auto " ) ;
2016-07-29 16:27:03 +03:00
DO_TEST ( " disk-scsi-device-auto " ,
2018-03-29 13:51:55 +03:00
QEMU_CAPS_SCSI_LSI ) ;
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " console-virtio " ) ;
DO_TEST_CAPS_LATEST ( " serial-target-port-auto " ) ;
2019-12-10 02:15:26 +03:00
DO_TEST ( " graphics-listen-network2 " ,
QEMU_CAPS_DEVICE_CIRRUS_VGA ,
QEMU_CAPS_VNC ) ;
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " numad-auto-vcpu-no-numatune " ) ;
DO_TEST_CAPS_LATEST ( " numad-auto-memory-vcpu-no-cpuset-and-placement " ) ;
DO_TEST_CAPS_LATEST ( " numad-auto-memory-vcpu-cpuset " ) ;
DO_TEST_CAPS_LATEST ( " usb-ich9-ehci-addr " ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " disk-copy_on_read " ) ;
2019-08-20 14:42:03 +03:00
DO_TEST_CAPS_LATEST ( " tpm-passthrough " ) ;
DO_TEST_CAPS_LATEST ( " tpm-passthrough-crb " ) ;
DO_TEST_CAPS_LATEST ( " tpm-emulator " ) ;
2022-01-04 10:38:37 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " tpm-emulator-spapr " , " ppc64 " ) ;
2019-08-20 14:42:03 +03:00
DO_TEST_CAPS_LATEST ( " tpm-emulator-tpm2 " ) ;
DO_TEST_CAPS_LATEST ( " tpm-emulator-tpm2-enc " ) ;
2021-01-04 05:31:59 +03:00
DO_TEST_CAPS_LATEST ( " tpm-emulator-tpm2-pstate " ) ;
2021-06-25 16:31:35 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " aarch64-tpm " , " aarch64 " ) ;
2022-10-17 16:20:24 +03:00
DO_TEST_CAPS_LATEST ( " tpm-external " ) ;
2016-07-29 16:13:56 +03:00
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " metadata " ) ;
DO_TEST_CAPS_LATEST ( " metadata-duplicate " ) ;
2012-01-24 06:26:18 +04:00
2016-07-29 16:27:03 +03:00
DO_TEST ( " pci-bridge " ,
2017-02-23 20:47:36 +03:00
QEMU_CAPS_DEVICE_PCI_BRIDGE ,
QEMU_CAPS_VNC ,
QEMU_CAPS_DEVICE_CIRRUS_VGA ) ;
DO_TEST ( " pci-many " ,
QEMU_CAPS_DEVICE_CIRRUS_VGA ) ;
2016-07-29 16:27:03 +03:00
DO_TEST ( " pci-bridge-many-disks " ,
QEMU_CAPS_DEVICE_PCI_BRIDGE ) ;
DO_TEST ( " pci-autoadd-addr " ,
2017-02-23 20:47:36 +03:00
QEMU_CAPS_DEVICE_PCI_BRIDGE ,
QEMU_CAPS_DEVICE_CIRRUS_VGA ) ;
2016-07-29 16:27:03 +03:00
DO_TEST ( " pci-autoadd-idx " ,
2017-02-23 20:47:36 +03:00
QEMU_CAPS_DEVICE_PCI_BRIDGE ,
QEMU_CAPS_DEVICE_CIRRUS_VGA ) ;
2019-10-18 18:30:11 +03:00
DO_TEST ( " pci-autofill-addr " , QEMU_CAPS_DEVICE_CIRRUS_VGA ) ;
2016-01-28 00:03:52 +03:00
2016-07-29 16:27:03 +03:00
DO_TEST ( " q35 " ,
2017-02-23 20:47:36 +03:00
QEMU_CAPS_DEVICE_PCI_BRIDGE ,
QEMU_CAPS_DEVICE_DMI_TO_PCI_BRIDGE ,
qemu: initially reserve one open pcie-root-port for hotplug
For machinetypes with a pci-root bus (all legacy PCI), libvirt will
make a "fake" reservation for one extra slot prior to assigning
addresses to unaddressed PCI endpoint devices in the domain. This will
trigger auto-adding of a pci-bridge for the final device to be
assigned an address *if that device would have otherwise instead been
the last device on the last available pci-bridge*; thus it assures
that there will always be at least one slot left open in the domain's
bus topology for expansion (which is important both for hotplug (since
a new pci-bridge can't be added while the guest is running) as well as
for offline additions to the config (since adding a new device might
otherwise in some cases require re-addressing existing devices, which
we want to avoid)).
It's important to note that for the above case (legacy PCI), we must
check for the special case of all slots on all buses being occupied
*prior to assigning any addresses*, and avoid attempting to reserve
the extra address in that case, because there is no free address in
the existing topology, so no place to auto-add a pci-bridge for
expansion (i.e. it would always fail anyway). Since that condition can
only be reached by manual intervention, this is acceptable.
For machinetypes with pcie-root (Q35, aarch64 virt), libvirt's
methodology for automatically expanding the bus topology is different
- pcie-root-ports are plugged into slots (soon to be functions) of
pcie-root as needed, and the new endpoint devices are assigned to the
single slot in each pcie-root-port. This is done so that the devices
are, by default, hotpluggable (the slots of pcie-root don't support
hotplug, but the single slot of the pcie-root-port does). Since
pcie-root-ports can only be plugged into pcie-root, and we don't
auto-assign endpoint devices to the pcie-root slots, this means
topology expansion doesn't compete with endpoint devices for slots, so
we don't need to worry about checking for all "useful" slots being
free *prior* to assigning addresses to new endpoint devices - as a
matter of fact, if we attempt to reserve the open slots before the
used slots, it can lead to errors.
Instead this patch just reserves one slot for a "future potential"
PCIe device after doing the assignment for actual devices, but only
if the only PCI controller defined prior to starting address
assignment was pcie-root, and only if we auto-added at least one PCI
controller during address assignment. This assures two things:
1) that reserving the open slots will only be done when the domain is
initially defined, never at any time after, and
2) that if the user understands enough about PCI controllers that they
are adding them manually, that we don't mess up their plan by
adding extras - if they know enough to add one pcie-root-port, or
to manually assign addresses such that no pcie-root-ports are
needed, they know enough to add extra pcie-root-ports if they want
them (this could be called the "libguestfs clause", since
libguestfs needs to be able to create domains with as few
devices/controllers as possible).
This is set to reserve a single free port for now, but could be
increased in the future if public sentiment goes in that direction
(it's easy to increase later, but essentially impossible to decrease)
2016-09-28 03:37:30 +03:00
QEMU_CAPS_DEVICE_IOH3420 ,
2017-02-23 20:47:36 +03:00
QEMU_CAPS_ICH9_AHCI ,
QEMU_CAPS_ICH9_USB_EHCI1 ,
2016-10-11 18:42:37 +03:00
QEMU_CAPS_DEVICE_QXL ) ;
2016-07-29 16:27:03 +03:00
DO_TEST ( " q35-usb2 " ,
QEMU_CAPS_DEVICE_PCI_BRIDGE ,
QEMU_CAPS_DEVICE_DMI_TO_PCI_BRIDGE ,
qemu: initially reserve one open pcie-root-port for hotplug
For machinetypes with a pci-root bus (all legacy PCI), libvirt will
make a "fake" reservation for one extra slot prior to assigning
addresses to unaddressed PCI endpoint devices in the domain. This will
trigger auto-adding of a pci-bridge for the final device to be
assigned an address *if that device would have otherwise instead been
the last device on the last available pci-bridge*; thus it assures
that there will always be at least one slot left open in the domain's
bus topology for expansion (which is important both for hotplug (since
a new pci-bridge can't be added while the guest is running) as well as
for offline additions to the config (since adding a new device might
otherwise in some cases require re-addressing existing devices, which
we want to avoid)).
It's important to note that for the above case (legacy PCI), we must
check for the special case of all slots on all buses being occupied
*prior to assigning any addresses*, and avoid attempting to reserve
the extra address in that case, because there is no free address in
the existing topology, so no place to auto-add a pci-bridge for
expansion (i.e. it would always fail anyway). Since that condition can
only be reached by manual intervention, this is acceptable.
For machinetypes with pcie-root (Q35, aarch64 virt), libvirt's
methodology for automatically expanding the bus topology is different
- pcie-root-ports are plugged into slots (soon to be functions) of
pcie-root as needed, and the new endpoint devices are assigned to the
single slot in each pcie-root-port. This is done so that the devices
are, by default, hotpluggable (the slots of pcie-root don't support
hotplug, but the single slot of the pcie-root-port does). Since
pcie-root-ports can only be plugged into pcie-root, and we don't
auto-assign endpoint devices to the pcie-root slots, this means
topology expansion doesn't compete with endpoint devices for slots, so
we don't need to worry about checking for all "useful" slots being
free *prior* to assigning addresses to new endpoint devices - as a
matter of fact, if we attempt to reserve the open slots before the
used slots, it can lead to errors.
Instead this patch just reserves one slot for a "future potential"
PCIe device after doing the assignment for actual devices, but only
if the only PCI controller defined prior to starting address
assignment was pcie-root, and only if we auto-added at least one PCI
controller during address assignment. This assures two things:
1) that reserving the open slots will only be done when the domain is
initially defined, never at any time after, and
2) that if the user understands enough about PCI controllers that they
are adding them manually, that we don't mess up their plan by
adding extras - if they know enough to add one pcie-root-port, or
to manually assign addresses such that no pcie-root-ports are
needed, they know enough to add extra pcie-root-ports if they want
them (this could be called the "libguestfs clause", since
libguestfs needs to be able to create domains with as few
devices/controllers as possible).
This is set to reserve a single free port for now, but could be
increased in the future if public sentiment goes in that direction
(it's easy to increase later, but essentially impossible to decrease)
2016-09-28 03:37:30 +03:00
QEMU_CAPS_DEVICE_IOH3420 ,
2016-07-29 16:27:03 +03:00
QEMU_CAPS_ICH9_AHCI ,
2017-02-23 20:47:36 +03:00
QEMU_CAPS_ICH9_USB_EHCI1 ,
2016-10-11 18:42:37 +03:00
QEMU_CAPS_DEVICE_QXL ) ;
2016-07-29 16:27:03 +03:00
DO_TEST ( " q35-usb2-multi " ,
2017-02-23 20:47:36 +03:00
QEMU_CAPS_DEVICE_PCI_BRIDGE ,
QEMU_CAPS_DEVICE_DMI_TO_PCI_BRIDGE ,
qemu: initially reserve one open pcie-root-port for hotplug
For machinetypes with a pci-root bus (all legacy PCI), libvirt will
make a "fake" reservation for one extra slot prior to assigning
addresses to unaddressed PCI endpoint devices in the domain. This will
trigger auto-adding of a pci-bridge for the final device to be
assigned an address *if that device would have otherwise instead been
the last device on the last available pci-bridge*; thus it assures
that there will always be at least one slot left open in the domain's
bus topology for expansion (which is important both for hotplug (since
a new pci-bridge can't be added while the guest is running) as well as
for offline additions to the config (since adding a new device might
otherwise in some cases require re-addressing existing devices, which
we want to avoid)).
It's important to note that for the above case (legacy PCI), we must
check for the special case of all slots on all buses being occupied
*prior to assigning any addresses*, and avoid attempting to reserve
the extra address in that case, because there is no free address in
the existing topology, so no place to auto-add a pci-bridge for
expansion (i.e. it would always fail anyway). Since that condition can
only be reached by manual intervention, this is acceptable.
For machinetypes with pcie-root (Q35, aarch64 virt), libvirt's
methodology for automatically expanding the bus topology is different
- pcie-root-ports are plugged into slots (soon to be functions) of
pcie-root as needed, and the new endpoint devices are assigned to the
single slot in each pcie-root-port. This is done so that the devices
are, by default, hotpluggable (the slots of pcie-root don't support
hotplug, but the single slot of the pcie-root-port does). Since
pcie-root-ports can only be plugged into pcie-root, and we don't
auto-assign endpoint devices to the pcie-root slots, this means
topology expansion doesn't compete with endpoint devices for slots, so
we don't need to worry about checking for all "useful" slots being
free *prior* to assigning addresses to new endpoint devices - as a
matter of fact, if we attempt to reserve the open slots before the
used slots, it can lead to errors.
Instead this patch just reserves one slot for a "future potential"
PCIe device after doing the assignment for actual devices, but only
if the only PCI controller defined prior to starting address
assignment was pcie-root, and only if we auto-added at least one PCI
controller during address assignment. This assures two things:
1) that reserving the open slots will only be done when the domain is
initially defined, never at any time after, and
2) that if the user understands enough about PCI controllers that they
are adding them manually, that we don't mess up their plan by
adding extras - if they know enough to add one pcie-root-port, or
to manually assign addresses such that no pcie-root-ports are
needed, they know enough to add extra pcie-root-ports if they want
them (this could be called the "libguestfs clause", since
libguestfs needs to be able to create domains with as few
devices/controllers as possible).
This is set to reserve a single free port for now, but could be
increased in the future if public sentiment goes in that direction
(it's easy to increase later, but essentially impossible to decrease)
2016-09-28 03:37:30 +03:00
QEMU_CAPS_DEVICE_IOH3420 ,
2017-02-23 20:47:36 +03:00
QEMU_CAPS_ICH9_AHCI ,
QEMU_CAPS_ICH9_USB_EHCI1 ,
2016-10-11 18:42:37 +03:00
QEMU_CAPS_DEVICE_QXL ) ;
2016-07-29 16:27:03 +03:00
DO_TEST ( " q35-usb2-reorder " ,
2017-02-23 20:47:36 +03:00
QEMU_CAPS_DEVICE_PCI_BRIDGE ,
QEMU_CAPS_DEVICE_DMI_TO_PCI_BRIDGE ,
qemu: initially reserve one open pcie-root-port for hotplug
For machinetypes with a pci-root bus (all legacy PCI), libvirt will
make a "fake" reservation for one extra slot prior to assigning
addresses to unaddressed PCI endpoint devices in the domain. This will
trigger auto-adding of a pci-bridge for the final device to be
assigned an address *if that device would have otherwise instead been
the last device on the last available pci-bridge*; thus it assures
that there will always be at least one slot left open in the domain's
bus topology for expansion (which is important both for hotplug (since
a new pci-bridge can't be added while the guest is running) as well as
for offline additions to the config (since adding a new device might
otherwise in some cases require re-addressing existing devices, which
we want to avoid)).
It's important to note that for the above case (legacy PCI), we must
check for the special case of all slots on all buses being occupied
*prior to assigning any addresses*, and avoid attempting to reserve
the extra address in that case, because there is no free address in
the existing topology, so no place to auto-add a pci-bridge for
expansion (i.e. it would always fail anyway). Since that condition can
only be reached by manual intervention, this is acceptable.
For machinetypes with pcie-root (Q35, aarch64 virt), libvirt's
methodology for automatically expanding the bus topology is different
- pcie-root-ports are plugged into slots (soon to be functions) of
pcie-root as needed, and the new endpoint devices are assigned to the
single slot in each pcie-root-port. This is done so that the devices
are, by default, hotpluggable (the slots of pcie-root don't support
hotplug, but the single slot of the pcie-root-port does). Since
pcie-root-ports can only be plugged into pcie-root, and we don't
auto-assign endpoint devices to the pcie-root slots, this means
topology expansion doesn't compete with endpoint devices for slots, so
we don't need to worry about checking for all "useful" slots being
free *prior* to assigning addresses to new endpoint devices - as a
matter of fact, if we attempt to reserve the open slots before the
used slots, it can lead to errors.
Instead this patch just reserves one slot for a "future potential"
PCIe device after doing the assignment for actual devices, but only
if the only PCI controller defined prior to starting address
assignment was pcie-root, and only if we auto-added at least one PCI
controller during address assignment. This assures two things:
1) that reserving the open slots will only be done when the domain is
initially defined, never at any time after, and
2) that if the user understands enough about PCI controllers that they
are adding them manually, that we don't mess up their plan by
adding extras - if they know enough to add one pcie-root-port, or
to manually assign addresses such that no pcie-root-ports are
needed, they know enough to add extra pcie-root-ports if they want
them (this could be called the "libguestfs clause", since
libguestfs needs to be able to create domains with as few
devices/controllers as possible).
This is set to reserve a single free port for now, but could be
increased in the future if public sentiment goes in that direction
(it's easy to increase later, but essentially impossible to decrease)
2016-09-28 03:37:30 +03:00
QEMU_CAPS_DEVICE_IOH3420 ,
2017-02-23 20:47:36 +03:00
QEMU_CAPS_ICH9_AHCI ,
QEMU_CAPS_ICH9_USB_EHCI1 ,
2016-10-11 18:42:37 +03:00
QEMU_CAPS_DEVICE_QXL ) ;
2022-08-25 17:44:55 +03:00
DO_TEST_CAPS_LATEST ( " q35-pcie " ) ;
qemu: auto-add pcie-root-port/dmi-to-pci-bridge controllers as needed
Previously libvirt would only add pci-bridge devices automatically
when an address was requested for a device that required a legacy PCI
slot and none was available. This patch expands that support to
dmi-to-pci-bridge (which is needed in order to add a pci-bridge on a
machine with a pcie-root), and pcie-root-port (which is needed to add
a hotpluggable PCIe device). It does *not* automatically add
pcie-switch-upstream-ports or pcie-switch-downstream-ports (and
currently there are no plans for that).
Given the existing code to auto-add pci-bridge devices, automatically
adding pcie-root-ports is fairly straightforward. The
dmi-to-pci-bridge support is a bit tricky though, for a few reasons:
1) Although the only reason to add a dmi-to-pci-bridge is so that
there is a reasonable place to plug in a pci-bridge controller,
most of the time it's not the presence of a pci-bridge *in the
config* that triggers the requirement to add a dmi-to-pci-bridge.
Rather, it is the presence of a legacy-PCI device in the config,
which triggers auto-add of a pci-bridge, which triggers auto-add of
a dmi-to-pci-bridge (this is handled in
virDomainPCIAddressSetGrow() - if there's a request to add a
pci-bridge we'll check if there is a suitable bus to plug it into;
if not, we first add a dmi-to-pci-bridge).
2) Once there is already a single dmi-to-pci-bridge on the system,
there won't be a need for any more, even if it's full, as long as
there is a pci-bridge with an open slot - you can also plug
pci-bridges into existing pci-bridges. So we have to make sure we
don't add a dmi-to-pci-bridge unless there aren't any
dmi-to-pci-bridges *or* any pci-bridges.
3) Although it is strongly discouraged, it is legal for a pci-bridge
to be directly plugged into pcie-root, and we don't want to
auto-add a dmi-to-pci-bridge if there is already a pci-bridge
that's been forced directly into pcie-root.
Although libvirt will now automatically create a dmi-to-pci-bridge
when it's needed, the code still remains for now that forces a
dmi-to-pci-bridge on all domains with pcie-root (in
qemuDomainDefAddDefaultDevices()). That will be removed in a future
patch.
For now, the pcie-root-ports are added one to a slot, which is a bit
wasteful and means it will fail after 31 total PCIe devices (30 if
there are also some PCI devices), but helps keep the changeset down
for this patch. A future patch will have 8 pcie-root-ports sharing the
functions on a single slot.
2016-09-19 21:38:47 +03:00
/* same as q35-pcie, but all PCI controllers are added automatically */
2022-08-25 17:44:55 +03:00
DO_TEST_CAPS_LATEST ( " q35-pcie-autoadd " ) ;
DO_TEST_CAPS_LATEST ( " q35-default-devices-only " ) ;
DO_TEST_CAPS_LATEST ( " q35-multifunction " ) ;
DO_TEST_CAPS_LATEST ( " q35-virt-manager-basic " ) ;
2016-07-29 16:27:03 +03:00
DO_TEST ( " pcie-root " ,
2017-02-23 20:47:36 +03:00
QEMU_CAPS_DEVICE_IOH3420 ,
QEMU_CAPS_ICH9_AHCI ,
2016-10-11 18:42:37 +03:00
QEMU_CAPS_DEVICE_QXL ) ;
2017-03-16 19:41:21 +03:00
/* Test automatic and manual setting of pcie-root-port attributes */
2016-07-29 16:27:03 +03:00
DO_TEST ( " pcie-root-port " ,
2017-02-23 20:47:36 +03:00
QEMU_CAPS_DEVICE_IOH3420 ,
QEMU_CAPS_ICH9_AHCI ,
2016-10-11 18:42:37 +03:00
QEMU_CAPS_DEVICE_QXL ) ;
2017-03-16 19:41:21 +03:00
/* Make sure the default model for PCIe Root Ports is picked correctly
* based on QEMU binary capabilities . We use x86 / q35 for the test , but
* any PCIe machine type ( such as aarch64 / virt ) will behave the same */
DO_TEST ( " pcie-root-port-model-generic " ,
QEMU_CAPS_DEVICE_PCIE_ROOT_PORT ,
2018-03-29 00:20:45 +03:00
QEMU_CAPS_DEVICE_IOH3420 ) ;
2017-03-16 19:41:21 +03:00
DO_TEST ( " pcie-root-port-model-ioh3420 " ,
2018-03-29 00:20:45 +03:00
QEMU_CAPS_DEVICE_IOH3420 ) ;
2020-03-03 20:23:52 +03:00
DO_TEST_CAPS_LATEST ( " pcie-root-port-nohotplug " ) ;
2016-07-29 16:27:03 +03:00
DO_TEST ( " pcie-switch-upstream-port " ,
2017-02-23 20:47:36 +03:00
QEMU_CAPS_DEVICE_IOH3420 ,
QEMU_CAPS_DEVICE_X3130_UPSTREAM ,
QEMU_CAPS_ICH9_AHCI ,
2016-10-11 18:42:37 +03:00
QEMU_CAPS_DEVICE_QXL ) ;
2016-07-29 16:27:03 +03:00
DO_TEST ( " pcie-switch-downstream-port " ,
2017-02-23 20:47:36 +03:00
QEMU_CAPS_DEVICE_IOH3420 ,
QEMU_CAPS_DEVICE_X3130_UPSTREAM ,
QEMU_CAPS_DEVICE_XIO3130_DOWNSTREAM ,
QEMU_CAPS_ICH9_AHCI ,
2016-10-11 18:42:37 +03:00
QEMU_CAPS_DEVICE_QXL ) ;
2016-07-29 16:27:03 +03:00
DO_TEST ( " pci-expander-bus " ,
2017-02-23 20:47:36 +03:00
QEMU_CAPS_DEVICE_PXB ) ;
2016-07-29 16:27:03 +03:00
DO_TEST ( " pcie-expander-bus " ,
2017-02-23 20:47:36 +03:00
QEMU_CAPS_DEVICE_IOH3420 ,
QEMU_CAPS_DEVICE_X3130_UPSTREAM ,
QEMU_CAPS_DEVICE_XIO3130_DOWNSTREAM ,
QEMU_CAPS_DEVICE_PXB_PCIE ) ;
2021-07-22 16:06:03 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " pcie-expander-bus-aarch64 " , " aarch64 " ) ;
2016-07-29 16:27:03 +03:00
DO_TEST ( " autoindex " ,
2017-02-23 20:47:36 +03:00
QEMU_CAPS_DEVICE_PCI_BRIDGE ,
QEMU_CAPS_DEVICE_DMI_TO_PCI_BRIDGE ,
QEMU_CAPS_DEVICE_IOH3420 ,
QEMU_CAPS_DEVICE_X3130_UPSTREAM ,
QEMU_CAPS_DEVICE_XIO3130_DOWNSTREAM ,
QEMU_CAPS_ICH9_AHCI ,
QEMU_CAPS_ICH9_USB_EHCI1 ,
2016-07-29 16:27:03 +03:00
QEMU_CAPS_NEC_USB_XHCI ) ;
2016-10-12 18:02:37 +03:00
/* Make sure the user can always override libvirt's default device
* placement policy by providing an explicit PCI address */
DO_TEST ( " q35-pci-force-address " ,
QEMU_CAPS_DEVICE_PCI_BRIDGE ,
QEMU_CAPS_DEVICE_DMI_TO_PCI_BRIDGE ,
QEMU_CAPS_DEVICE_IOH3420 ,
QEMU_CAPS_HDA_DUPLEX ) ;
2016-07-29 16:27:03 +03:00
2023-03-24 17:10:25 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " hostdev-scsi-vhost-scsi-ccw " , " s390x " ) ;
2016-11-22 06:58:20 +03:00
DO_TEST ( " hostdev-scsi-vhost-scsi-pci " ,
2018-09-18 13:29:10 +03:00
QEMU_CAPS_VIRTIO_SCSI ,
QEMU_CAPS_DEVICE_VHOST_SCSI ) ;
2022-08-25 17:44:55 +03:00
DO_TEST_CAPS_LATEST ( " hostdev-scsi-vhost-scsi-pcie " ) ;
2016-07-29 16:27:03 +03:00
DO_TEST ( " hostdev-scsi-lsi " ,
2018-09-18 13:29:10 +03:00
QEMU_CAPS_VIRTIO_SCSI ,
QEMU_CAPS_SCSI_LSI ) ;
2016-07-29 16:27:03 +03:00
DO_TEST ( " hostdev-scsi-virtio-scsi " ,
2018-09-18 13:29:10 +03:00
QEMU_CAPS_VIRTIO_SCSI ,
QEMU_CAPS_SCSI_LSI ) ;
2016-07-29 16:27:03 +03:00
DO_TEST ( " hostdev-scsi-shareable " ,
2018-09-18 13:29:10 +03:00
QEMU_CAPS_VIRTIO_SCSI ,
QEMU_CAPS_SCSI_LSI ) ;
2016-07-29 16:27:03 +03:00
DO_TEST ( " hostdev-scsi-autogen-address " ,
2018-09-18 13:29:10 +03:00
QEMU_CAPS_VIRTIO_SCSI ,
QEMU_CAPS_SCSI_LSI ) ;
2016-07-29 16:27:03 +03:00
DO_TEST ( " hostdev-scsi-large-unit " ,
2018-09-18 13:29:10 +03:00
QEMU_CAPS_VIRTIO_SCSI ,
QEMU_CAPS_SCSI_LSI ) ;
2016-07-29 16:27:03 +03:00
2023-03-24 17:10:25 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " hostdev-subsys-mdev-vfio-ccw " , " s390x " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " hostdev-subsys-mdev-vfio-ccw-boot " , " s390x " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " hostdev-subsys-mdev-vfio-ap " , " s390x " ) ;
2018-05-07 17:41:14 +03:00
2021-06-11 11:21:57 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " s390-defaultconsole " , " s390x " ) ;
2023-03-24 17:10:25 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " s390-panic " , " s390x " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " s390-panic-missing " , " s390x " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " s390-panic-no-address " , " s390x " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " s390-serial " , " s390x " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " s390-serial-2 " , " s390x " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " s390-serial-console " , " s390x " ) ;
2013-06-17 18:17:36 +04:00
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " pcihole64 " ) ;
DO_TEST_CAPS_LATEST ( " pcihole64-gib " ) ;
2016-07-29 16:27:03 +03:00
DO_TEST ( " pcihole64-q35 " ,
qemu: initially reserve one open pcie-root-port for hotplug
For machinetypes with a pci-root bus (all legacy PCI), libvirt will
make a "fake" reservation for one extra slot prior to assigning
addresses to unaddressed PCI endpoint devices in the domain. This will
trigger auto-adding of a pci-bridge for the final device to be
assigned an address *if that device would have otherwise instead been
the last device on the last available pci-bridge*; thus it assures
that there will always be at least one slot left open in the domain's
bus topology for expansion (which is important both for hotplug (since
a new pci-bridge can't be added while the guest is running) as well as
for offline additions to the config (since adding a new device might
otherwise in some cases require re-addressing existing devices, which
we want to avoid)).
It's important to note that for the above case (legacy PCI), we must
check for the special case of all slots on all buses being occupied
*prior to assigning any addresses*, and avoid attempting to reserve
the extra address in that case, because there is no free address in
the existing topology, so no place to auto-add a pci-bridge for
expansion (i.e. it would always fail anyway). Since that condition can
only be reached by manual intervention, this is acceptable.
For machinetypes with pcie-root (Q35, aarch64 virt), libvirt's
methodology for automatically expanding the bus topology is different
- pcie-root-ports are plugged into slots (soon to be functions) of
pcie-root as needed, and the new endpoint devices are assigned to the
single slot in each pcie-root-port. This is done so that the devices
are, by default, hotpluggable (the slots of pcie-root don't support
hotplug, but the single slot of the pcie-root-port does). Since
pcie-root-ports can only be plugged into pcie-root, and we don't
auto-assign endpoint devices to the pcie-root slots, this means
topology expansion doesn't compete with endpoint devices for slots, so
we don't need to worry about checking for all "useful" slots being
free *prior* to assigning addresses to new endpoint devices - as a
matter of fact, if we attempt to reserve the open slots before the
used slots, it can lead to errors.
Instead this patch just reserves one slot for a "future potential"
PCIe device after doing the assignment for actual devices, but only
if the only PCI controller defined prior to starting address
assignment was pcie-root, and only if we auto-added at least one PCI
controller during address assignment. This assures two things:
1) that reserving the open slots will only be done when the domain is
initially defined, never at any time after, and
2) that if the user understands enough about PCI controllers that they
are adding them manually, that we don't mess up their plan by
adding extras - if they know enough to add one pcie-root-port, or
to manually assign addresses such that no pcie-root-ports are
needed, they know enough to add extra pcie-root-ports if they want
them (this could be called the "libguestfs clause", since
libguestfs needs to be able to create domains with as few
devices/controllers as possible).
This is set to reserve a single free port for now, but could be
increased in the future if public sentiment goes in that direction
(it's easy to increase later, but essentially impossible to decrease)
2016-09-28 03:37:30 +03:00
QEMU_CAPS_DEVICE_IOH3420 ,
2017-02-23 20:47:36 +03:00
QEMU_CAPS_ICH9_AHCI ,
2022-08-11 20:08:35 +03:00
QEMU_CAPS_DEVICE_QXL ) ;
2013-08-12 15:39:04 +04:00
2020-10-14 00:38:07 +03:00
DO_TEST ( " panic " , QEMU_CAPS_DEVICE_PANIC ) ;
DO_TEST ( " panic-double " , QEMU_CAPS_DEVICE_PANIC ) ;
DO_TEST ( " panic-no-address " , QEMU_CAPS_DEVICE_PANIC ) ;
2022-05-21 17:54:56 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " panic-pseries " , " ppc64 " ) ;
2013-12-09 13:11:15 +04:00
2023-02-20 19:12:56 +03:00
DO_TEST_CAPS_LATEST ( " pvpanic-pci-x86_64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " pvpanic-pci-aarch64 " , " aarch64 " ) ;
2023-02-20 19:12:58 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " pvpanic-pci-no-address-aarch64 " , " aarch64 " ) ;
2023-02-20 19:12:56 +03:00
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " disk-backing-chains-index " ) ;
DO_TEST_CAPS_LATEST ( " disk-backing-chains-noindex " ) ;
2014-04-17 17:37:51 +04:00
2022-12-19 17:54:59 +03:00
DO_TEST_CAPS_LATEST ( " disk-source-fd " ) ;
2020-03-25 18:18:50 +03:00
DO_TEST_CAPS_LATEST ( " disk-network-http " ) ;
2019-01-22 22:02:27 +03:00
DO_TEST ( " chardev-label " ,
2020-10-09 21:18:53 +03:00
QEMU_CAPS_DEVICE_VIRTIO_RNG ,
QEMU_CAPS_OBJECT_RNG_EGD ) ;
2014-05-16 16:31:28 +04:00
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " cpu-numa1 " ) ;
DO_TEST_CAPS_LATEST ( " cpu-numa2 " ) ;
DO_TEST_CAPS_LATEST ( " cpu-numa-no-memory-element " ) ;
DO_TEST_CAPS_LATEST ( " cpu-numa-disordered " ) ;
DO_TEST_CAPS_LATEST ( " cpu-numa-disjoint " ) ;
DO_TEST_CAPS_LATEST ( " cpu-numa-memshared " ) ;
DO_TEST_CAPS_LATEST ( " numatune-auto-prefer " ) ;
DO_TEST_CAPS_LATEST ( " numatune-memnode " ) ;
DO_TEST_CAPS_LATEST ( " numatune-memnode-no-memory " ) ;
DO_TEST_CAPS_LATEST ( " numatune-distances " ) ;
2023-08-14 15:28:48 +03:00
DO_TEST_CAPS_LATEST ( " numatune-no-vcpu " ) ;
2022-11-03 12:52:40 +03:00
DO_TEST ( " numatune-hmat " , QEMU_CAPS_NUMA_HMAT ) ;
2023-05-16 11:22:39 +03:00
DO_TEST_CAPS_LATEST ( " numatune-hmat-none " ) ;
2021-04-13 09:38:06 +03:00
DO_TEST_CAPS_LATEST ( " numatune-memnode-restrictive-mode " ) ;
2014-06-09 17:00:22 +04:00
2023-02-08 21:10:48 +03:00
DO_TEST_CAPS_LATEST ( " firmware-manual-bios " ) ;
DO_TEST_CAPS_LATEST ( " firmware-manual-bios-stateless " ) ;
DO_TEST_CAPS_LATEST ( " firmware-manual-efi " ) ;
2023-04-11 18:56:45 +03:00
DO_TEST_CAPS_LATEST ( " firmware-manual-efi-features " ) ;
2023-02-08 21:15:55 +03:00
DO_TEST_CAPS_LATEST ( " firmware-manual-efi-rw " ) ;
2023-05-26 19:19:24 +03:00
DO_TEST_CAPS_LATEST ( " firmware-manual-efi-rw-legacy-paths " ) ;
DO_TEST_CAPS_LATEST ( " firmware-manual-efi-rw-modern-paths " ) ;
2023-02-08 21:15:55 +03:00
DO_TEST_CAPS_LATEST ( " firmware-manual-efi-rw-implicit " ) ;
2023-03-16 19:36:45 +03:00
DO_TEST_CAPS_LATEST ( " firmware-manual-efi-loader-secure " ) ;
2023-05-26 19:19:24 +03:00
DO_TEST_CAPS_LATEST ( " firmware-manual-efi-loader-path-nonstandard " ) ;
2023-03-15 21:39:06 +03:00
DO_TEST_CAPS_LATEST ( " firmware-manual-efi-secboot " ) ;
DO_TEST_CAPS_LATEST ( " firmware-manual-efi-no-enrolled-keys " ) ;
DO_TEST_CAPS_LATEST ( " firmware-manual-efi-no-secboot " ) ;
2023-02-08 21:15:55 +03:00
DO_TEST_CAPS_LATEST ( " firmware-manual-efi-stateless " ) ;
DO_TEST_CAPS_LATEST ( " firmware-manual-efi-nvram-template " ) ;
2023-05-26 19:19:24 +03:00
DO_TEST_CAPS_LATEST ( " firmware-manual-efi-nvram-template-nonstandard " ) ;
2022-06-09 16:54:36 +03:00
DO_TEST_CAPS_LATEST ( " firmware-manual-efi-nvram-network-iscsi " ) ;
DO_TEST_CAPS_LATEST ( " firmware-manual-efi-nvram-network-nbd " ) ;
DO_TEST_CAPS_LATEST ( " firmware-manual-efi-nvram-file " ) ;
2023-02-08 21:15:55 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " firmware-manual-efi-acpi-aarch64 " , " aarch64 " ) ;
DO_TEST_CAPS_LATEST ( " firmware-manual-efi-acpi-q35 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " firmware-manual-efi-noacpi-aarch64 " , " aarch64 " ) ;
DO_TEST_CAPS_LATEST ( " firmware-manual-noefi-acpi-q35 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " firmware-manual-noefi-noacpi-aarch64 " , " aarch64 " ) ;
DO_TEST_CAPS_LATEST ( " firmware-manual-noefi-noacpi-q35 " ) ;
2023-05-26 19:19:24 +03:00
/* Ensure that legacy firmware paths keep working */
DO_TEST_CAPS_LATEST ( " firmware-manual-efi-secboot-legacy-paths " ) ;
DO_TEST_CAPS_LATEST ( " firmware-manual-efi-no-enrolled-keys-legacy-paths " ) ;
DO_TEST_CAPS_LATEST ( " firmware-manual-efi-no-secboot-legacy-paths " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " firmware-manual-efi-aarch64-legacy-paths " , " aarch64 " ) ;
2022-06-09 16:54:36 +03:00
DO_TEST_CAPS_LATEST ( " firmware-auto-bios " ) ;
conf: support stateless UEFI firmware
Normally when an UEFI firmware is marked as read-only, an associated
NVRAM file will be created. Some builds of UEFI firmware, however, wish
to remain stateless and so will be read-only, but never have any NVRAM
file. To represent this concept a 'stateless' tristate bool attribute
is introduced on the <loader/> element.
There are rather a large number of permutations to consider.
With default firmware selection
* <os/>
=> Historic default, no change
* <os>
<loader stateless='yes'/>
</os>
=> Explicit version of historic default, no change
* <os>
<loader stateless='no'/>
</os>
=> Invalid, bios is always stateless
With manual legacy BIOS selection
* <os>
<loader>/path/to/seabios</loader>
...
</os>
=> Historic default, no change
* <os>
<loader stateless='yes'>/path/to/seabios</loader>
...
</os>
=> Explicit version of historic default, no change
* <os>
<loader stateless='no'>/path/to/seabios</loader>
...
</os>
=> Invalid, bios is always stateless
With manual UEFI selection
* <os>
<loader type='pflash'>/path/to/edk2</loader>
...
</os>
=> Historic default, no change
* <os>
<loader type='pflash' stateless='yes'>/path/to/edk2</loader>
...
</os>
=> Skip auto-filling NVRAM / template
* <os>
<loader type='pflash' stateless='no'>/path/to/edk2</loader>
...
</os>
=> Explicit version of historic default, no change
With automatic firmware selection
* <os firmware='bios'/>
=> Historic default, no change
* <os firmware='bios'>
<loader stateless='yes'/>
</os>
=> Explicit version of historic default, no change
* <os firmware='bios'>
<loader stateless='no'/>
</os>
=> Invalid, bios is always stateless
* <os firmware='uefi'/>
=> Historic default, no change
* <os firmware='uefi'>
<loader stateless='yes'/>
</os>
=> Skip auto-filling NVRAM / template
* <os firmware='uefi'>
<loader stateless='no'/>
</os>
=> Explicit version of historic default, no change
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
2022-07-22 17:27:55 +03:00
DO_TEST_CAPS_LATEST ( " firmware-auto-bios-stateless " ) ;
2022-06-09 16:54:36 +03:00
DO_TEST_CAPS_LATEST ( " firmware-auto-efi " ) ;
2023-05-26 19:19:24 +03:00
DO_TEST_CAPS_LATEST_ABI_UPDATE ( " firmware-auto-efi-abi-update " ) ;
2023-02-08 21:15:55 +03:00
DO_TEST_CAPS_LATEST ( " firmware-auto-efi-stateless " ) ;
2023-05-26 19:19:24 +03:00
DO_TEST_CAPS_LATEST ( " firmware-auto-efi-rw " ) ;
2022-06-09 16:54:36 +03:00
DO_TEST_CAPS_LATEST ( " firmware-auto-efi-loader-secure " ) ;
2023-05-26 19:19:24 +03:00
DO_TEST_CAPS_LATEST_ABI_UPDATE ( " firmware-auto-efi-loader-secure-abi-update " ) ;
conf: Remove some firmware validation checks
libvirt 8.6.0 introduced these checks and very clearly delineated
two possible firmware selection scenarios: manual firmware
selection, where the user is responsible for providing all
information, and firmware autoselection, where a list of desired
features is provided and everything else is handled by libvirt.
In the interest of maintaining the clear separation between these
two scenarios, setting most attributes when firmware autoselection
is active will result in the configuration being rejected.
This works fine, but is unnecessarily restrictive: in most cases,
the additional information that the user has provided matches
the information that libvirt would have discovered on its own by
looking at firmware descriptors, and asking the user to scrub it
from the XML only result in pointless friction.
Remove these checks entirely.
Unsurprisingly, this results in a few test cases that were
rejected until now to suddenly start working and producing
sensible results.
The firmware-auto-efi-loader-path-nonstandard test case is
notable: while we can now enable the xml2xml part of the test,
the xml2argv part is still failing, although in a slightly
different way. This is expected: since the firmware binary is a
non-standard one, libvirt is unable to figure out the missing
information from a firmware descriptor, and the configuration
is still ultimately an invalid one. However, if we were to find
such a configuration on disk at daemon startup, we would not
ignore it completely and instead would offer the user a chance
to fix it.
Signed-off-by: Andrea Bolognani <abologna@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
2023-03-15 01:02:46 +03:00
DO_TEST_CAPS_LATEST ( " firmware-auto-efi-loader-insecure " ) ;
DO_TEST_CAPS_LATEST ( " firmware-auto-efi-loader-path " ) ;
DO_TEST_CAPS_LATEST ( " firmware-auto-efi-loader-path-nonstandard " ) ;
2022-06-09 16:56:32 +03:00
DO_TEST_CAPS_LATEST ( " firmware-auto-efi-secboot " ) ;
DO_TEST_CAPS_LATEST ( " firmware-auto-efi-no-secboot " ) ;
DO_TEST_CAPS_LATEST ( " firmware-auto-efi-enrolled-keys " ) ;
2022-06-09 16:54:36 +03:00
DO_TEST_CAPS_LATEST ( " firmware-auto-efi-no-enrolled-keys " ) ;
2023-02-10 19:40:29 +03:00
DO_TEST_CAPS_LATEST ( " firmware-auto-efi-smm-off " ) ;
2022-06-09 16:54:36 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " firmware-auto-efi-aarch64 " , " aarch64 " ) ;
2023-03-27 20:56:46 +03:00
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE ( " firmware-auto-efi-abi-update-aarch64 " , " aarch64 " ) ;
2023-05-26 19:16:24 +03:00
DO_TEST_CAPS_LATEST ( " firmware-auto-efi-nvram-path " ) ;
2023-05-26 19:19:24 +03:00
DO_TEST_CAPS_LATEST ( " firmware-auto-efi-nvram-template " ) ;
DO_TEST_CAPS_LATEST ( " firmware-auto-efi-nvram-template-nonstandard " ) ;
2023-02-10 19:40:29 +03:00
DO_TEST_CAPS_LATEST ( " firmware-auto-efi-nvram-file " ) ;
DO_TEST_CAPS_LATEST ( " firmware-auto-efi-nvram-network-nbd " ) ;
DO_TEST_CAPS_LATEST ( " firmware-auto-efi-nvram-network-iscsi " ) ;
2014-08-06 15:18:53 +04:00
2023-02-08 20:47:39 +03:00
DO_TEST_CAPS_LATEST ( " firmware-auto-efi-format-loader-qcow2 " ) ;
2023-08-03 16:19:59 +03:00
DO_TEST_CAPS_LATEST ( " firmware-auto-efi-format-loader-qcow2-nvram-path " ) ;
2023-02-08 20:47:39 +03:00
DO_TEST_CAPS_LATEST ( " firmware-auto-efi-format-nvram-qcow2 " ) ;
DO_TEST_CAPS_LATEST ( " firmware-auto-efi-format-nvram-qcow2-path " ) ;
DO_TEST_CAPS_LATEST ( " firmware-auto-efi-format-nvram-qcow2-network-nbd " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " firmware-auto-efi-format-loader-raw " , " aarch64 " ) ;
2023-05-26 19:19:24 +03:00
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE ( " firmware-auto-efi-format-loader-raw-abi-update " , " aarch64 " ) ;
2023-02-08 20:47:39 +03:00
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " tap-vhost " ) ;
DO_TEST_CAPS_LATEST ( " tap-vhost-incorrect " ) ;
2020-10-13 21:12:59 +03:00
DO_TEST ( " shmem " , QEMU_CAPS_DEVICE_IVSHMEM ) ;
2020-07-24 06:34:11 +03:00
DO_TEST ( " shmem-plain-doorbell " ,
QEMU_CAPS_DEVICE_IVSHMEM_PLAIN , QEMU_CAPS_DEVICE_IVSHMEM_DOORBELL ) ;
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " smbios " ) ;
DO_TEST_CAPS_LATEST ( " smbios-multiple-type2 " ) ;
2023-08-14 15:28:48 +03:00
DO_TEST_CAPS_LATEST ( " smbios-type-fwcfg " ) ;
2014-09-11 19:11:28 +04:00
2023-03-24 18:48:38 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " aarch64-aavmf-virtio-mmio " , " aarch64 " ) ;
2022-08-25 17:44:55 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " aarch64-virtio-pci-default " , " aarch64 " ) ;
2023-03-28 15:41:57 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " aarch64-virtio-pci-manual-addresses " , " aarch64 " ) ;
2023-03-24 18:48:38 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " aarch64-video-virtio-gpu-pci " , " aarch64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " aarch64-pci-serial " , " aarch64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " aarch64-traditional-pci " , " aarch64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " aarch64-video-default " , " aarch64 " ) ;
2016-02-03 16:35:41 +03:00
2023-03-24 18:47:03 +03:00
DO_TEST_FULL ( " aarch64-gic-none " , " .aarch64-latest " , WHEN_BOTH ,
ARG_CAPS_ARCH , " aarch64 " , ARG_CAPS_VER , " latest " ,
ARG_GIC , GIC_NONE , ARG_END ) ;
DO_TEST_FULL ( " aarch64-gic-none-v2 " , " .aarch64-latest " , WHEN_BOTH ,
ARG_CAPS_ARCH , " aarch64 " , ARG_CAPS_VER , " latest " ,
ARG_GIC , GIC_V2 , ARG_END ) ;
DO_TEST_FULL ( " aarch64-gic-none-v3 " , " .aarch64-latest " , WHEN_BOTH ,
ARG_CAPS_ARCH , " aarch64 " , ARG_CAPS_VER , " latest " ,
ARG_GIC , GIC_V3 , ARG_END ) ;
DO_TEST_FULL ( " aarch64-gic-none-both " , " .aarch64-latest " , WHEN_BOTH ,
ARG_CAPS_ARCH , " aarch64 " , ARG_CAPS_VER , " latest " ,
ARG_GIC , GIC_BOTH , ARG_END ) ;
DO_TEST_FULL ( " aarch64-gic-none-tcg " , " .aarch64-latest " , WHEN_BOTH ,
ARG_CAPS_ARCH , " aarch64 " , ARG_CAPS_VER , " latest " ,
ARG_GIC , GIC_BOTH , ARG_END ) ;
DO_TEST_FULL ( " aarch64-gic-default " , " .aarch64-latest " , WHEN_BOTH ,
ARG_CAPS_ARCH , " aarch64 " , ARG_CAPS_VER , " latest " ,
ARG_GIC , GIC_NONE , ARG_END ) ;
DO_TEST_FULL ( " aarch64-gic-default-v2 " , " .aarch64-latest " , WHEN_BOTH ,
ARG_CAPS_ARCH , " aarch64 " , ARG_CAPS_VER , " latest " ,
ARG_GIC , GIC_V2 , ARG_END ) ;
DO_TEST_FULL ( " aarch64-gic-default-v3 " , " .aarch64-latest " , WHEN_BOTH ,
ARG_CAPS_ARCH , " aarch64 " , ARG_CAPS_VER , " latest " ,
ARG_GIC , GIC_V3 , ARG_END ) ;
DO_TEST_FULL ( " aarch64-gic-default-both " , " .aarch64-latest " , WHEN_BOTH ,
ARG_CAPS_ARCH , " aarch64 " , ARG_CAPS_VER , " latest " ,
ARG_GIC , GIC_BOTH , ARG_END ) ;
DO_TEST_FULL ( " aarch64-gic-v2 " , " .aarch64-latest " , WHEN_BOTH ,
ARG_CAPS_ARCH , " aarch64 " , ARG_CAPS_VER , " latest " ,
ARG_GIC , GIC_NONE , ARG_END ) ;
DO_TEST_FULL ( " aarch64-gic-v2 " , " .aarch64-latest " , WHEN_BOTH ,
ARG_CAPS_ARCH , " aarch64 " , ARG_CAPS_VER , " latest " ,
ARG_GIC , GIC_V2 , ARG_END ) ;
DO_TEST_FULL ( " aarch64-gic-v2 " , " .aarch64-latest " , WHEN_BOTH ,
ARG_CAPS_ARCH , " aarch64 " , ARG_CAPS_VER , " latest " ,
ARG_GIC , GIC_V3 , ARG_END ) ;
DO_TEST_FULL ( " aarch64-gic-v2 " , " .aarch64-latest " , WHEN_BOTH ,
ARG_CAPS_ARCH , " aarch64 " , ARG_CAPS_VER , " latest " ,
ARG_GIC , GIC_BOTH , ARG_END ) ;
DO_TEST_FULL ( " aarch64-gic-v3 " , " .aarch64-latest " , WHEN_BOTH ,
ARG_CAPS_ARCH , " aarch64 " , ARG_CAPS_VER , " latest " ,
ARG_GIC , GIC_NONE , ARG_END ) ;
DO_TEST_FULL ( " aarch64-gic-v3 " , " .aarch64-latest " , WHEN_BOTH ,
ARG_CAPS_ARCH , " aarch64 " , ARG_CAPS_VER , " latest " ,
ARG_GIC , GIC_V2 , ARG_END ) ;
DO_TEST_FULL ( " aarch64-gic-v3 " , " .aarch64-latest " , WHEN_BOTH ,
ARG_CAPS_ARCH , " aarch64 " , ARG_CAPS_VER , " latest " ,
ARG_GIC , GIC_V3 , ARG_END ) ;
DO_TEST_FULL ( " aarch64-gic-v3 " , " .aarch64-latest " , WHEN_BOTH ,
ARG_CAPS_ARCH , " aarch64 " , ARG_CAPS_VER , " latest " ,
ARG_GIC , GIC_BOTH , ARG_END ) ;
DO_TEST_FULL ( " aarch64-gic-host " , " .aarch64-latest " , WHEN_BOTH ,
ARG_CAPS_ARCH , " aarch64 " , ARG_CAPS_VER , " latest " ,
ARG_GIC , GIC_NONE , ARG_END ) ;
DO_TEST_FULL ( " aarch64-gic-host " , " .aarch64-latest " , WHEN_BOTH ,
ARG_CAPS_ARCH , " aarch64 " , ARG_CAPS_VER , " latest " ,
ARG_GIC , GIC_V2 , ARG_END ) ;
DO_TEST_FULL ( " aarch64-gic-host " , " .aarch64-latest " , WHEN_BOTH ,
ARG_CAPS_ARCH , " aarch64 " , ARG_CAPS_VER , " latest " ,
ARG_GIC , GIC_V3 , ARG_END ) ;
DO_TEST_FULL ( " aarch64-gic-host " , " .aarch64-latest " , WHEN_BOTH ,
ARG_CAPS_ARCH , " aarch64 " , ARG_CAPS_VER , " latest " ,
ARG_GIC , GIC_BOTH , ARG_END ) ;
2015-09-30 17:36:24 +03:00
2019-06-24 16:22:24 +03:00
/* SVE aarch64 CPU features work on modern QEMU */
DO_TEST_CAPS_ARCH_LATEST ( " aarch64-features-sve " , " aarch64 " ) ;
2023-03-24 18:33:06 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " aarch64-usb-controller " , " aarch64 " ) ;
2023-03-09 13:23:33 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " memory-hotplug-ppc64-nonuma " , " ppc64 " ) ;
2023-05-30 18:48:58 +03:00
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE ( " memory-hotplug-ppc64-nonuma-abi-update " , " ppc64 " ) ;
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " memory-hotplug " ) ;
2020-07-28 11:51:32 +03:00
DO_TEST ( " memory-hotplug-dimm " , QEMU_CAPS_DEVICE_PC_DIMM ) ;
2022-07-26 20:26:52 +03:00
DO_TEST_CAPS_LATEST ( " memory-hotplug-dimm-addr " ) ;
2019-12-18 03:36:00 +03:00
DO_TEST ( " memory-hotplug-nvdimm " , QEMU_CAPS_DEVICE_NVDIMM ) ;
DO_TEST ( " memory-hotplug-nvdimm-access " , QEMU_CAPS_DEVICE_NVDIMM ) ;
DO_TEST ( " memory-hotplug-nvdimm-label " , QEMU_CAPS_DEVICE_NVDIMM ) ;
DO_TEST ( " memory-hotplug-nvdimm-align " , QEMU_CAPS_DEVICE_NVDIMM ) ;
DO_TEST ( " memory-hotplug-nvdimm-pmem " , QEMU_CAPS_DEVICE_NVDIMM ) ;
2020-10-14 16:11:13 +03:00
DO_TEST ( " memory-hotplug-nvdimm-readonly " , QEMU_CAPS_DEVICE_NVDIMM ,
QEMU_CAPS_DEVICE_NVDIMM_UNARMED ) ;
2023-03-09 13:23:33 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " memory-hotplug-nvdimm-ppc64 " , " ppc64 " ) ;
2023-05-30 18:48:58 +03:00
DO_TEST_CAPS_ARCH_LATEST_ABI_UPDATE ( " memory-hotplug-nvdimm-ppc64-abi-update " , " ppc64 " ) ;
2020-12-07 17:24:17 +03:00
DO_TEST_CAPS_LATEST ( " memory-hotplug-virtio-pmem " ) ;
conf: Introduce virtio-mem <memory/> model
The virtio-mem is paravirtualized mechanism of adding/removing
memory to/from a VM. A virtio-mem-pci device is split into blocks
of equal size which are then exposed (all or only a requested
portion of them) to the guest kernel to use as regular memory.
Therefore, the device has two important attributes:
1) block-size, which defines the size of a block
2) requested-size, which defines how much memory (in bytes)
is the device requested to expose to the guest.
The 'block-size' is configured on command line and immutable
throughout device's lifetime. The 'requested-size' can be set on
the command line too, but also is adjustable via monitor. In
fact, that is how management software places its requests to
change the memory allocation. If it wants to give more memory to
the guest it changes 'requested-size' to a bigger value, and if it
wants to shrink guest memory it changes the 'requested-size' to a
smaller value. Note, value of zero means that guest should
release all memory offered by the device. Of course, guest has to
cooperate. Therefore, there is a third attribute 'size' which is
read only and reflects how much memory the guest still has. This
can be different to 'requested-size', obviously. Because of name
clash, I've named it 'current' and it is dealt with in future
commits (it is a runtime information anyway).
In the backend, memory for virtio-mem is backed by usual objects:
memory-backend-{ram,file,memfd} and their size puts the cap on
the amount of memory that a virtio-mem device can offer to a
guest. But we are already able to express this info using <size/>
under <target/>.
Therefore, we need only two more elements to cover 'block-size'
and 'requested-size' attributes. This is the XML I've came up
with:
<memory model='virtio-mem'>
<source>
<nodemask>1-3</nodemask>
<pagesize unit='KiB'>2048</pagesize>
</source>
<target>
<size unit='KiB'>2097152</size>
<node>0</node>
<block unit='KiB'>2048</block>
<requested unit='KiB'>1048576</requested>
</target>
<address type='pci' domain='0x0000' bus='0x00' slot='0x04' function='0x0'/>
</memory>
I hope by now it is obvious that:
1) 'requested-size' must be an integer multiple of
'block-size', and
2) virtio-mem-pci device goes onto PCI bus and thus needs PCI
address.
Then there is a limitation that the minimal 'block-size' is
transparent huge page size (I'll leave this without explanation).
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
2021-01-18 18:13:12 +03:00
DO_TEST_CAPS_LATEST ( " memory-hotplug-virtio-mem " ) ;
2023-06-22 14:56:06 +03:00
DO_TEST_CAPS_LATEST ( " memory-hotplug-multiple " ) ;
2020-12-02 21:56:57 +03:00
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " net-udp " ) ;
2014-10-06 16:18:37 +04:00
2019-10-18 18:30:11 +03:00
DO_TEST ( " video-virtio-gpu-device " , QEMU_CAPS_DEVICE_VIRTIO_GPU ) ;
DO_TEST ( " video-virtio-gpu-virgl " ,
QEMU_CAPS_DEVICE_VIRTIO_GPU ,
QEMU_CAPS_VIRTIO_GPU_VIRGL ) ;
DO_TEST ( " video-virtio-gpu-spice-gl " ,
QEMU_CAPS_DEVICE_VIRTIO_GPU ,
2019-12-10 02:15:27 +03:00
QEMU_CAPS_VIRTIO_GPU_VIRGL ,
QEMU_CAPS_SPICE ,
QEMU_CAPS_SPICE_GL ,
QEMU_CAPS_SPICE_RENDERNODE ) ;
2019-10-18 18:30:11 +03:00
DO_TEST ( " video-virtio-gpu-sdl-gl " ,
QEMU_CAPS_DEVICE_VIRTIO_GPU ,
2021-06-15 12:46:54 +03:00
QEMU_CAPS_VIRTIO_GPU_VIRGL ,
QEMU_CAPS_SDL ) ;
2018-09-05 18:51:24 +03:00
DO_TEST ( " virtio-input " ,
QEMU_CAPS_VIRTIO_KEYBOARD ,
QEMU_CAPS_VIRTIO_MOUSE ,
QEMU_CAPS_VIRTIO_TABLET ) ;
DO_TEST ( " virtio-input-passthrough " ,
QEMU_CAPS_VIRTIO_INPUT_HOST ) ;
2015-11-25 11:42:32 +03:00
2021-05-21 14:01:07 +03:00
DO_TEST_CAPS_LATEST ( " input-linux " ) ;
2023-08-11 17:40:22 +03:00
DO_TEST_CAPS_LATEST ( " memorybacking-set " ) ;
DO_TEST_CAPS_LATEST ( " memorybacking-unset " ) ;
2018-09-05 18:51:24 +03:00
2020-04-23 16:15:06 +03:00
DO_TEST_CAPS_LATEST ( " virtio-options " ) ;
2017-02-02 16:27:32 +03:00
2022-11-03 18:01:02 +03:00
DO_TEST ( " fd-memory-numa-topology " , QEMU_CAPS_KVM ) ;
DO_TEST ( " fd-memory-numa-topology2 " , QEMU_CAPS_KVM ) ;
DO_TEST ( " fd-memory-numa-topology3 " , QEMU_CAPS_KVM ) ;
2021-09-15 17:05:49 +03:00
DO_TEST_CAPS_LATEST ( " fd-memory-numa-topology4 " ) ;
2019-03-29 18:58:23 +03:00
2022-11-03 18:01:02 +03:00
DO_TEST ( " fd-memory-no-numa-topology " , QEMU_CAPS_KVM ) ;
2019-03-29 18:58:23 +03:00
2022-01-05 12:23:42 +03:00
DO_TEST_CAPS_LATEST ( " memfd-memory-numa " ) ;
DO_TEST_CAPS_LATEST ( " memfd-memory-default-hugepage " ) ;
2019-03-29 18:58:23 +03:00
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " acpi-table " ) ;
2016-04-18 18:13:02 +03:00
2017-02-23 20:47:36 +03:00
DO_TEST ( " video-device-pciaddr-default " ,
QEMU_CAPS_KVM ,
QEMU_CAPS_VNC ,
QEMU_CAPS_DEVICE_QXL ) ;
2019-10-18 18:30:11 +03:00
DO_TEST ( " video-qxl-heads " , QEMU_CAPS_DEVICE_QXL ) ;
DO_TEST ( " video-qxl-noheads " , QEMU_CAPS_DEVICE_QXL ) ;
DO_TEST ( " video-qxl-resolution " , QEMU_CAPS_DEVICE_QXL ) ;
DO_TEST ( " video-virtio-gpu-secondary " , QEMU_CAPS_DEVICE_VIRTIO_GPU ) ;
2023-03-24 17:10:25 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " video-virtio-gpu-ccw " , " s390x " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " video-virtio-gpu-ccw-auto " , " s390x " ) ;
2019-12-10 02:15:26 +03:00
DO_TEST ( " video-none-device " , QEMU_CAPS_VNC ) ;
2021-06-09 11:32:27 +03:00
DO_TEST_CAPS_LATEST ( " video-virtio-vga-gpu-gl " ) ;
2022-02-24 00:06:55 +03:00
DO_TEST_CAPS_LATEST ( " video-virtio-blob-on " ) ;
DO_TEST_CAPS_LATEST ( " video-virtio-blob-off " ) ;
2015-12-11 16:43:10 +03:00
2019-05-17 15:45:36 +03:00
DO_TEST_CAPS_LATEST ( " intel-iommu " ) ;
DO_TEST_CAPS_LATEST ( " intel-iommu-caching-mode " ) ;
DO_TEST_CAPS_LATEST ( " intel-iommu-eim " ) ;
DO_TEST_CAPS_LATEST ( " intel-iommu-device-iotlb " ) ;
2020-06-04 10:42:42 +03:00
DO_TEST_CAPS_LATEST ( " intel-iommu-aw-bits " ) ;
2019-05-17 14:23:16 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " iommu-smmuv3 " , " aarch64 " ) ;
2021-09-23 15:46:23 +03:00
DO_TEST_CAPS_LATEST ( " virtio-iommu-x86_64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " virtio-iommu-aarch64 " , " aarch64 " ) ;
2016-06-22 17:28:22 +03:00
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " cpu-check-none " ) ;
DO_TEST_CAPS_LATEST ( " cpu-check-partial " ) ;
DO_TEST_CAPS_LATEST ( " cpu-check-full " ) ;
DO_TEST_CAPS_LATEST ( " cpu-check-default-none " ) ;
DO_TEST_CAPS_LATEST ( " cpu-check-default-none2 " ) ;
DO_TEST_CAPS_LATEST ( " cpu-check-default-partial " ) ;
DO_TEST_CAPS_LATEST ( " cpu-check-default-partial2 " ) ;
2019-12-18 03:36:03 +03:00
DO_TEST ( " vmcoreinfo " , QEMU_CAPS_DEVICE_VMCOREINFO ) ;
2017-03-01 18:12:07 +03:00
2019-12-18 03:36:02 +03:00
DO_TEST ( " smartcard-host " , QEMU_CAPS_CCID_EMULATED ) ;
DO_TEST ( " smartcard-host-certificates " , QEMU_CAPS_CCID_EMULATED ) ;
DO_TEST ( " smartcard-host-certificates-database " ,
QEMU_CAPS_CCID_EMULATED ) ;
DO_TEST ( " smartcard-passthrough-tcp " , QEMU_CAPS_CCID_PASSTHRU ) ;
2022-05-12 10:40:03 +03:00
DO_TEST ( " smartcard-passthrough-spicevmc " ,
QEMU_CAPS_CCID_PASSTHRU ,
QEMU_CAPS_SPICE ,
QEMU_CAPS_DEVICE_CIRRUS_VGA ) ;
2019-12-18 03:36:02 +03:00
DO_TEST ( " smartcard-controller " , QEMU_CAPS_CCID_EMULATED ) ;
2017-08-03 15:26:47 +03:00
2022-05-21 17:54:56 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " pseries-cpu-compat-power9 " , " ppc64 " ) ;
2022-05-03 23:15:05 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " pseries-cpu-compat-power10 " , " ppc64 " ) ;
2022-05-21 17:54:56 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " pseries-cpu-compat " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " pseries-cpu-exact " , " ppc64 " ) ;
2017-09-18 10:59:18 +03:00
2022-07-15 17:35:27 +03:00
DO_TEST_CAPS_LATEST ( " user-aliases " ) ;
2023-03-24 17:10:25 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " input-virtio-ccw " , " s390x " ) ;
2017-10-20 17:48:14 +03:00
2022-01-05 12:23:42 +03:00
DO_TEST_CAPS_LATEST ( " tseg-explicit-size " ) ;
2018-05-11 00:37:18 +03:00
2022-01-05 12:23:42 +03:00
DO_TEST_CAPS_LATEST ( " vhost-vsock " ) ;
DO_TEST_CAPS_LATEST ( " vhost-vsock-auto " ) ;
2023-03-24 17:10:25 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " vhost-vsock-ccw " , " s390x " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " vhost-vsock-ccw-auto " , " s390x " ) ;
2021-01-27 21:46:59 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " vhost-vsock-ccw-iommu " , " s390x " ) ;
2018-08-06 18:41:07 +03:00
2019-07-16 08:01:30 +03:00
DO_TEST_CAPS_LATEST ( " vhost-user-fs-fd-memory " ) ;
DO_TEST_CAPS_LATEST ( " vhost-user-fs-hugepages " ) ;
2020-09-07 23:07:35 +03:00
DO_TEST_CAPS_LATEST ( " vhost-user-fs-sock " ) ;
2019-07-16 08:01:30 +03:00
2023-03-03 10:12:39 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " riscv64-virt " , " riscv64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " riscv64-virt-pci " , " riscv64 " ) ;
2022-01-06 00:19:40 +03:00
DO_TEST_CAPS_LATEST ( " x86-kvm-32-on-64 " ) ;
2018-05-22 12:21:15 +03:00
2019-04-16 01:46:44 +03:00
DO_TEST_CAPS_LATEST ( " virtio-transitional " ) ;
DO_TEST_CAPS_LATEST ( " virtio-non-transitional " ) ;
2019-01-11 23:06:05 +03:00
2019-06-12 13:25:28 +03:00
/* Simple headless guests for various architectures */
DO_TEST_CAPS_ARCH_LATEST ( " aarch64-virt-headless " , " aarch64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " ppc64-pseries-headless " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " riscv64-virt-headless " , " riscv64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " s390x-ccw-headless " , " s390x " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " x86_64-pc-headless " , " x86_64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " x86_64-q35-headless " , " x86_64 " ) ;
/* Simple guests with graphics for various architectures */
DO_TEST_CAPS_ARCH_LATEST ( " aarch64-virt-graphics " , " aarch64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " ppc64-pseries-graphics " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " riscv64-virt-graphics " , " riscv64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " s390x-ccw-graphics " , " s390x " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " x86_64-pc-graphics " , " x86_64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " x86_64-q35-graphics " , " x86_64 " ) ;
2019-10-18 17:14:23 +03:00
DO_TEST_CAPS_LATEST ( " cpu-Icelake-Server-pconfig " ) ;
2019-10-11 21:15:03 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " aarch64-default-cpu-kvm-virt-4.2 " , " aarch64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " aarch64-default-cpu-tcg-virt-4.2 " , " aarch64 " ) ;
2019-10-11 21:15:03 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " ppc64-default-cpu-kvm-pseries-2.7 " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " ppc64-default-cpu-tcg-pseries-2.7 " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " ppc64-default-cpu-kvm-pseries-3.1 " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " ppc64-default-cpu-tcg-pseries-3.1 " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " ppc64-default-cpu-kvm-pseries-4.2 " , " ppc64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " ppc64-default-cpu-tcg-pseries-4.2 " , " ppc64 " ) ;
2020-02-06 12:18:49 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " s390-default-cpu-kvm-ccw-virtio-2.7 " , " s390x " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " s390-default-cpu-tcg-ccw-virtio-2.7 " , " s390x " ) ;
2019-10-11 21:15:03 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " s390-default-cpu-kvm-ccw-virtio-4.2 " , " s390x " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " s390-default-cpu-tcg-ccw-virtio-4.2 " , " s390x " ) ;
2019-10-11 21:15:03 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " x86_64-default-cpu-kvm-pc-4.2 " , " x86_64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " x86_64-default-cpu-tcg-pc-4.2 " , " x86_64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " x86_64-default-cpu-kvm-q35-4.2 " , " x86_64 " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " x86_64-default-cpu-tcg-q35-4.2 " , " x86_64 " ) ;
2021-11-03 15:15:41 +03:00
DO_TEST_CAPS_ARCH_LATEST ( " x86_64-default-cpu-tcg-features " , " x86_64 " ) ;
2019-10-11 21:15:03 +03:00
2020-03-30 21:05:33 +03:00
DO_TEST_CAPS_LATEST ( " virtio-9p-multidevs " ) ;
2020-10-08 17:32:24 +03:00
DO_TEST_CAPS_LATEST ( " virtio-9p-createmode " ) ;
2023-08-15 14:27:41 +03:00
DO_TEST_CAPS_LATEST ( " downscript " ) ;
2020-03-30 21:05:33 +03:00
2021-02-23 21:32:25 +03:00
/* Simplest possible <audio>, all supported with ENV */
2023-05-09 17:58:10 +03:00
DO_TEST_CAPS_LATEST ( " audio-none-minimal " ) ;
DO_TEST_CAPS_LATEST ( " audio-alsa-minimal " ) ;
DO_TEST_CAPS_LATEST ( " audio-coreaudio-minimal " ) ;
DO_TEST_CAPS_LATEST ( " audio-oss-minimal " ) ;
DO_TEST_CAPS_LATEST ( " audio-pulseaudio-minimal " ) ;
DO_TEST_CAPS_LATEST ( " audio-sdl-minimal " ) ;
DO_TEST_CAPS_LATEST ( " audio-spice-minimal " ) ;
DO_TEST_CAPS_LATEST ( " audio-file-minimal " ) ;
2021-02-23 21:32:25 +03:00
/* Best <audio> still compat with old ENV */
2023-05-09 17:58:10 +03:00
DO_TEST_CAPS_LATEST ( " audio-none-best " ) ;
DO_TEST_CAPS_LATEST ( " audio-alsa-best " ) ;
DO_TEST_CAPS_LATEST ( " audio-coreaudio-best " ) ;
DO_TEST_CAPS_LATEST ( " audio-oss-best " ) ;
DO_TEST_CAPS_LATEST ( " audio-pulseaudio-best " ) ;
DO_TEST_CAPS_LATEST ( " audio-sdl-best " ) ;
DO_TEST_CAPS_LATEST ( " audio-spice-best " ) ;
DO_TEST_CAPS_LATEST ( " audio-file-best " ) ;
2021-03-02 20:22:47 +03:00
/* Full <audio> only compat with new QEMU -audiodev args */
2023-05-09 17:58:10 +03:00
DO_TEST_CAPS_LATEST ( " audio-none-full " ) ;
DO_TEST_CAPS_LATEST ( " audio-alsa-full " ) ;
DO_TEST_CAPS_LATEST ( " audio-coreaudio-full " ) ;
DO_TEST_CAPS_LATEST ( " audio-jack-full " ) ;
DO_TEST_CAPS_LATEST ( " audio-oss-full " ) ;
DO_TEST_CAPS_LATEST ( " audio-pulseaudio-full " ) ;
DO_TEST_CAPS_LATEST ( " audio-sdl-full " ) ;
DO_TEST_CAPS_LATEST ( " audio-spice-full " ) ;
DO_TEST_CAPS_LATEST ( " audio-file-full " ) ;
2021-02-23 21:32:25 +03:00
2021-02-24 17:40:19 +03:00
DO_TEST_CAPS_LATEST ( " audio-many-backends " ) ;
2021-02-24 17:24:10 +03:00
/* Validate auto-creation of <audio> for legacy compat */
g_setenv ( " QEMU_AUDIO_DRV " , " sdl " , TRUE ) ;
g_setenv ( " SDL_AUDIODRIVER " , " esd " , TRUE ) ;
DO_TEST_CAPS_LATEST ( " audio-default-sdl " ) ;
g_unsetenv ( " QEMU_AUDIO_DRV " ) ;
g_unsetenv ( " SDL_AUDIODRIVER " ) ;
g_setenv ( " QEMU_AUDIO_DRV " , " alsa " , TRUE ) ;
driver . config - > vncAllowHostAudio = true ;
DO_TEST_CAPS_LATEST ( " audio-default-vnc " ) ;
driver . config - > vncAllowHostAudio = false ;
g_unsetenv ( " QEMU_AUDIO_DRV " ) ;
DO_TEST_CAPS_LATEST ( " audio-default-spice " ) ;
g_setenv ( " QEMU_AUDIO_DRV " , " alsa " , TRUE ) ;
driver . config - > nogfxAllowHostAudio = true ;
DO_TEST_CAPS_LATEST ( " audio-default-nographics " ) ;
driver . config - > nogfxAllowHostAudio = false ;
g_unsetenv ( " QEMU_AUDIO_DRV " ) ;
2021-04-06 17:01:20 +03:00
DO_TEST_CAPS_LATEST ( " devices-acpi-index " ) ;
2023-03-08 19:12:07 +03:00
DO_TEST_CAPS_ARCH_LATEST_FULL ( " hvf-x86_64-q35-headless " , " x86_64 " , ARG_CAPS_VARIANT , " +hvf " , ARG_END ) ;
2023-03-08 19:12:07 +03:00
DO_TEST_CAPS_ARCH_LATEST_FULL ( " hvf-aarch64-virt-headless " , " aarch64 " , ARG_CAPS_VARIANT , " +hvf " , ARG_END ) ;
2023-03-08 19:12:07 +03:00
2022-03-19 01:04:05 +03:00
DO_TEST_CAPS_LATEST ( " channel-qemu-vdagent " ) ;
DO_TEST_CAPS_LATEST ( " channel-qemu-vdagent-features " ) ;
2022-01-04 19:27:01 +03:00
2022-11-11 04:21:23 +03:00
DO_TEST_CAPS_VER ( " sgx-epc " , " 7.0.0 " ) ;
2023-01-17 04:46:50 +03:00
DO_TEST_CAPS_LATEST ( " crypto-builtin " ) ;
2023-03-01 13:27:30 +03:00
DO_TEST_CAPS_LATEST ( " cpu-phys-bits-limit " ) ;
2023-04-25 12:11:59 +03:00
DO_TEST_CAPS_LATEST ( " cpu-phys-bits-emulate-bare " ) ;
2023-03-01 13:27:30 +03:00
2023-07-05 09:20:26 +03:00
DO_TEST_CAPS_LATEST ( " async-teardown " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " s390-async-teardown " , " s390x " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " s390-async-teardown-no-attrib " , " s390x " ) ;
DO_TEST_CAPS_ARCH_LATEST ( " s390-async-teardown-disabled " , " s390x " ) ;
DO_TEST_CAPS_ARCH_VER ( " s390-async-teardown-disabled " , " s390x " , " 6.0.0 " ) ;
2020-06-25 17:34:30 +03:00
cleanup :
2015-09-15 09:16:02 +03:00
qemuTestDriverFree ( & driver ) ;
2019-08-12 18:06:22 +03:00
virFileWrapperClearPrefixes ( ) ;
2007-07-19 01:34:22 +04:00
2014-03-17 13:38:38 +04:00
return ret = = 0 ? EXIT_SUCCESS : EXIT_FAILURE ;
2007-07-19 01:34:22 +04:00
}
2017-06-01 19:48:52 +03:00
VIR_TEST_MAIN_PRELOAD ( mymain ,
2019-08-21 19:13:16 +03:00
VIR_TEST_MOCK ( " virpci " ) ,
VIR_TEST_MOCK ( " virrandom " ) ,
2020-10-21 17:53:26 +03:00
VIR_TEST_MOCK ( " domaincaps " ) )