2017-03-23 14:06:57 +01:00
|
|
|
#include <config.h>
|
|
|
|
|
|
|
|
#include <unistd.h>
|
|
|
|
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <fcntl.h>
|
|
|
|
|
|
|
|
#include "testutils.h"
|
|
|
|
|
|
|
|
#ifdef WITH_QEMU
|
|
|
|
|
|
|
|
# include "internal.h"
|
|
|
|
# include "conf/domain_conf.h"
|
|
|
|
# include "qemu/qemu_domain.h"
|
|
|
|
|
|
|
|
# include "testutilsqemu.h"
|
|
|
|
|
|
|
|
# define VIR_FROM_THIS VIR_FROM_QEMU
|
|
|
|
|
|
|
|
static virQEMUDriver driver;
|
|
|
|
|
|
|
|
struct testInfo {
|
|
|
|
const char *name;
|
|
|
|
unsigned long long memlock;
|
|
|
|
};
|
|
|
|
|
|
|
|
static int
|
|
|
|
testCompareMemLock(const void *data)
|
|
|
|
{
|
|
|
|
const struct testInfo *info = data;
|
2020-07-28 21:58:18 +02:00
|
|
|
g_autoptr(virDomainDef) def = NULL;
|
2020-07-28 21:57:28 +02:00
|
|
|
g_autofree char *xml = NULL;
|
2017-03-23 14:06:57 +01:00
|
|
|
|
2019-10-22 15:26:14 +02:00
|
|
|
xml = g_strdup_printf("%s/qemumemlockdata/qemumemlock-%s.xml", abs_srcdir,
|
|
|
|
info->name);
|
2017-03-23 14:06:57 +01:00
|
|
|
|
2019-11-27 12:29:21 +00:00
|
|
|
if (!(def = virDomainDefParseFile(xml, driver.xmlopt, NULL,
|
2017-03-23 14:06:57 +01:00
|
|
|
VIR_DOMAIN_DEF_PARSE_INACTIVE))) {
|
2020-07-28 23:17:02 +02:00
|
|
|
return -1;
|
2017-03-23 14:06:57 +01:00
|
|
|
}
|
|
|
|
|
2020-07-28 23:17:02 +02:00
|
|
|
return virTestCompareToULL(info->memlock, qemuDomainGetMemLockLimitBytes(def, false));
|
2017-03-23 14:06:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
mymain(void)
|
|
|
|
{
|
|
|
|
int ret = 0;
|
2020-07-28 21:58:18 +02:00
|
|
|
g_autoptr(virQEMUCaps) qemuCaps = NULL;
|
2017-06-01 18:48:52 +02:00
|
|
|
|
2020-07-28 21:57:28 +02:00
|
|
|
if (qemuTestDriverInit(&driver) < 0)
|
2017-03-23 14:06:57 +01:00
|
|
|
return EXIT_FAILURE;
|
|
|
|
|
|
|
|
# define DO_TEST(name, memlock) \
|
|
|
|
do { \
|
|
|
|
static struct testInfo info = { \
|
|
|
|
name, memlock \
|
|
|
|
}; \
|
|
|
|
if (virTestRun("QEMU MEMLOCK " name, testCompareMemLock, &info) < 0) \
|
|
|
|
ret = -1; \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
/* The tests below make sure that the memory locking limit is being
|
|
|
|
* calculated correctly in a number of situations. Each test is
|
|
|
|
* performed both on x86_64/pc and ppc64/pseries in order to account
|
|
|
|
* for some architecture-specific details.
|
|
|
|
*
|
|
|
|
* kvm: simple KMV guest
|
|
|
|
* tcg: simple TCG guest
|
|
|
|
*
|
|
|
|
* hardlimit: guest where <memtune><hard_limit> has been configured
|
|
|
|
* locked: guest where <memoryBacking><locked> has been enabled
|
|
|
|
* hostdev: guest that has some hostdev assigned
|
|
|
|
*
|
|
|
|
* The remaining tests cover different combinations of the above to
|
|
|
|
* ensure settings are prioritized as expected.
|
|
|
|
*/
|
|
|
|
|
2019-11-26 17:51:22 +00:00
|
|
|
qemuTestSetHostArch(&driver, VIR_ARCH_X86_64);
|
2017-03-23 14:06:57 +01:00
|
|
|
|
|
|
|
DO_TEST("pc-kvm", 0);
|
|
|
|
DO_TEST("pc-tcg", 0);
|
|
|
|
|
2023-03-03 09:27:45 +01:00
|
|
|
qemuCaps = virQEMUCapsNew();
|
2019-12-09 20:15:18 -03:00
|
|
|
|
|
|
|
virQEMUCapsSet(qemuCaps, QEMU_CAPS_DEVICE_VFIO_PCI);
|
|
|
|
|
|
|
|
if (qemuTestCapsCacheInsert(driver.qemuCapsCache, qemuCaps) < 0) {
|
|
|
|
ret = -1;
|
|
|
|
goto cleanup;
|
|
|
|
};
|
|
|
|
|
2017-03-23 14:06:57 +01:00
|
|
|
DO_TEST("pc-hardlimit", 2147483648);
|
|
|
|
DO_TEST("pc-locked", VIR_DOMAIN_MEMORY_PARAM_UNLIMITED);
|
|
|
|
DO_TEST("pc-hostdev", 2147483648);
|
|
|
|
|
|
|
|
DO_TEST("pc-hardlimit+locked", 2147483648);
|
|
|
|
DO_TEST("pc-hardlimit+hostdev", 2147483648);
|
|
|
|
DO_TEST("pc-hardlimit+locked+hostdev", 2147483648);
|
|
|
|
DO_TEST("pc-locked+hostdev", VIR_DOMAIN_MEMORY_PARAM_UNLIMITED);
|
|
|
|
|
2019-11-26 17:51:22 +00:00
|
|
|
qemuTestSetHostArch(&driver, VIR_ARCH_PPC64);
|
2017-11-28 16:00:52 -05:00
|
|
|
|
|
|
|
virQEMUCapsSet(qemuCaps, QEMU_CAPS_DEVICE_SPAPR_PCI_HOST_BRIDGE);
|
|
|
|
if (qemuTestCapsCacheInsert(driver.qemuCapsCache, qemuCaps) < 0) {
|
|
|
|
ret = -1;
|
|
|
|
goto cleanup;
|
|
|
|
};
|
2017-03-23 14:06:57 +01:00
|
|
|
|
|
|
|
DO_TEST("pseries-kvm", 20971520);
|
|
|
|
DO_TEST("pseries-tcg", 0);
|
|
|
|
|
|
|
|
DO_TEST("pseries-hardlimit", 2147483648);
|
|
|
|
DO_TEST("pseries-locked", VIR_DOMAIN_MEMORY_PARAM_UNLIMITED);
|
2017-06-02 15:19:04 +02:00
|
|
|
DO_TEST("pseries-hostdev", 4320133120);
|
2017-03-23 14:06:57 +01:00
|
|
|
|
|
|
|
DO_TEST("pseries-hardlimit+locked", 2147483648);
|
|
|
|
DO_TEST("pseries-hardlimit+hostdev", 2147483648);
|
|
|
|
DO_TEST("pseries-hardlimit+locked+hostdev", 2147483648);
|
|
|
|
DO_TEST("pseries-locked+hostdev", VIR_DOMAIN_MEMORY_PARAM_UNLIMITED);
|
|
|
|
|
2017-11-28 16:00:52 -05:00
|
|
|
cleanup:
|
2017-03-23 14:06:57 +01:00
|
|
|
qemuTestDriverFree(&driver);
|
|
|
|
|
|
|
|
return ret == 0 ? EXIT_SUCCESS : EXIT_FAILURE;
|
|
|
|
}
|
|
|
|
|
2019-11-15 11:56:46 +01:00
|
|
|
VIR_TEST_MAIN_PRELOAD(mymain,
|
|
|
|
VIR_TEST_MOCK("virpci"),
|
|
|
|
VIR_TEST_MOCK("domaincaps"))
|
2017-03-23 14:06:57 +01:00
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
int
|
|
|
|
main(void)
|
|
|
|
{
|
|
|
|
return EXIT_AM_SKIP;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* WITH_QEMU */
|