mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2024-10-22 14:09:22 +00:00
cputest: Use virArch enum rather than strings
Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
This commit is contained in:
parent
3944aba1df
commit
1784c03ddb
294
tests/cputest.c
294
tests/cputest.c
@ -56,7 +56,7 @@ enum cpuTestBoolWithError {
|
|||||||
|
|
||||||
|
|
||||||
struct data {
|
struct data {
|
||||||
const char *arch;
|
virArch arch;
|
||||||
const char *host;
|
const char *host;
|
||||||
const char *name;
|
const char *name;
|
||||||
const char **models;
|
const char **models;
|
||||||
@ -72,14 +72,15 @@ static virQEMUDriver driver;
|
|||||||
|
|
||||||
|
|
||||||
static virCPUDefPtr
|
static virCPUDefPtr
|
||||||
cpuTestLoadXML(const char *arch, const char *name)
|
cpuTestLoadXML(virArch arch, const char *name)
|
||||||
{
|
{
|
||||||
char *xml = NULL;
|
char *xml = NULL;
|
||||||
xmlDocPtr doc = NULL;
|
xmlDocPtr doc = NULL;
|
||||||
xmlXPathContextPtr ctxt = NULL;
|
xmlXPathContextPtr ctxt = NULL;
|
||||||
virCPUDefPtr cpu = NULL;
|
virCPUDefPtr cpu = NULL;
|
||||||
|
|
||||||
if (virAsprintf(&xml, "%s/cputestdata/%s-%s.xml", abs_srcdir, arch, name) < 0)
|
if (virAsprintf(&xml, "%s/cputestdata/%s-%s.xml",
|
||||||
|
abs_srcdir, virArchToString(arch), name) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (!(doc = virXMLParseFileCtxt(xml, &ctxt)))
|
if (!(doc = virXMLParseFileCtxt(xml, &ctxt)))
|
||||||
@ -96,7 +97,7 @@ cpuTestLoadXML(const char *arch, const char *name)
|
|||||||
|
|
||||||
|
|
||||||
static virCPUDefPtr *
|
static virCPUDefPtr *
|
||||||
cpuTestLoadMultiXML(const char *arch,
|
cpuTestLoadMultiXML(virArch arch,
|
||||||
const char *name,
|
const char *name,
|
||||||
unsigned int *count)
|
unsigned int *count)
|
||||||
{
|
{
|
||||||
@ -108,7 +109,8 @@ cpuTestLoadMultiXML(const char *arch,
|
|||||||
int n;
|
int n;
|
||||||
size_t i;
|
size_t i;
|
||||||
|
|
||||||
if (virAsprintf(&xml, "%s/cputestdata/%s-%s.xml", abs_srcdir, arch, name) < 0)
|
if (virAsprintf(&xml, "%s/cputestdata/%s-%s.xml",
|
||||||
|
abs_srcdir, virArchToString(arch), name) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (!(doc = virXMLParseFileCtxt(xml, &ctxt)))
|
if (!(doc = virXMLParseFileCtxt(xml, &ctxt)))
|
||||||
@ -145,7 +147,7 @@ cpuTestLoadMultiXML(const char *arch,
|
|||||||
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
cpuTestCompareXML(const char *arch,
|
cpuTestCompareXML(virArch arch,
|
||||||
virCPUDef *cpu,
|
virCPUDef *cpu,
|
||||||
const char *name,
|
const char *name,
|
||||||
bool updateCPU)
|
bool updateCPU)
|
||||||
@ -155,7 +157,7 @@ cpuTestCompareXML(const char *arch,
|
|||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
if (virAsprintf(&xml, "%s/cputestdata/%s-%s.xml",
|
if (virAsprintf(&xml, "%s/cputestdata/%s-%s.xml",
|
||||||
abs_srcdir, arch, name) < 0)
|
abs_srcdir, virArchToString(arch), name) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (!(actual = virCPUDefFormat(cpu, NULL, updateCPU)))
|
if (!(actual = virCPUDefFormat(cpu, NULL, updateCPU)))
|
||||||
@ -457,7 +459,7 @@ cpuTestCPUID(bool guest, const void *arg)
|
|||||||
char *result = NULL;
|
char *result = NULL;
|
||||||
|
|
||||||
if (virAsprintf(&hostFile, "%s/cputestdata/%s-cpuid-%s.xml",
|
if (virAsprintf(&hostFile, "%s/cputestdata/%s-cpuid-%s.xml",
|
||||||
abs_srcdir, data->arch, data->host) < 0)
|
abs_srcdir, virArchToString(data->arch), data->host) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (virTestLoadFile(hostFile, &host) < 0 ||
|
if (virTestLoadFile(hostFile, &host) < 0 ||
|
||||||
@ -523,7 +525,7 @@ cpuTestJSONCPUID(const void *arg)
|
|||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
if (virAsprintf(&json, "%s/cputestdata/%s-cpuid-%s.json",
|
if (virAsprintf(&json, "%s/cputestdata/%s-cpuid-%s.json",
|
||||||
abs_srcdir, data->arch, data->host) < 0 ||
|
abs_srcdir, virArchToString(data->arch), data->host) < 0 ||
|
||||||
virAsprintf(&result, "cpuid-%s-json", data->host) < 0)
|
virAsprintf(&result, "cpuid-%s-json", data->host) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
@ -591,7 +593,7 @@ mymain(void)
|
|||||||
VIR_FREE(tmp); \
|
VIR_FREE(tmp); \
|
||||||
\
|
\
|
||||||
if (virAsprintf(&testLabel, "%s(%s): %s", \
|
if (virAsprintf(&testLabel, "%s(%s): %s", \
|
||||||
#api, arch, name) < 0) { \
|
#api, virArchToString(arch), name) < 0) { \
|
||||||
ret = -1; \
|
ret = -1; \
|
||||||
break; \
|
break; \
|
||||||
} \
|
} \
|
||||||
@ -677,159 +679,159 @@ mymain(void)
|
|||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
/* host to host comparison */
|
/* host to host comparison */
|
||||||
DO_TEST_COMPARE("x86_64", "host", "host", VIR_CPU_COMPARE_IDENTICAL);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "host", VIR_CPU_COMPARE_IDENTICAL);
|
||||||
DO_TEST_COMPARE("x86_64", "host", "host-better", VIR_CPU_COMPARE_INCOMPATIBLE);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "host-better", VIR_CPU_COMPARE_INCOMPATIBLE);
|
||||||
DO_TEST_COMPARE("x86_64", "host", "host-worse", VIR_CPU_COMPARE_SUPERSET);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "host-worse", VIR_CPU_COMPARE_SUPERSET);
|
||||||
DO_TEST_COMPARE("x86_64", "host", "host-amd-fake", VIR_CPU_COMPARE_INCOMPATIBLE);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "host-amd-fake", VIR_CPU_COMPARE_INCOMPATIBLE);
|
||||||
DO_TEST_COMPARE("x86_64", "host", "host-incomp-arch", VIR_CPU_COMPARE_INCOMPATIBLE);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "host-incomp-arch", VIR_CPU_COMPARE_INCOMPATIBLE);
|
||||||
DO_TEST_COMPARE("x86_64", "host", "host-no-vendor", VIR_CPU_COMPARE_IDENTICAL);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "host-no-vendor", VIR_CPU_COMPARE_IDENTICAL);
|
||||||
DO_TEST_COMPARE("x86_64", "host-no-vendor", "host", VIR_CPU_COMPARE_INCOMPATIBLE);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host-no-vendor", "host", VIR_CPU_COMPARE_INCOMPATIBLE);
|
||||||
|
|
||||||
DO_TEST_COMPARE("ppc64", "host", "host", VIR_CPU_COMPARE_IDENTICAL);
|
DO_TEST_COMPARE(VIR_ARCH_PPC64, "host", "host", VIR_CPU_COMPARE_IDENTICAL);
|
||||||
DO_TEST_COMPARE("ppc64", "host", "host-better", VIR_CPU_COMPARE_INCOMPATIBLE);
|
DO_TEST_COMPARE(VIR_ARCH_PPC64, "host", "host-better", VIR_CPU_COMPARE_INCOMPATIBLE);
|
||||||
DO_TEST_COMPARE("ppc64", "host", "host-worse", VIR_CPU_COMPARE_INCOMPATIBLE);
|
DO_TEST_COMPARE(VIR_ARCH_PPC64, "host", "host-worse", VIR_CPU_COMPARE_INCOMPATIBLE);
|
||||||
DO_TEST_COMPARE("ppc64", "host", "host-incomp-arch", VIR_CPU_COMPARE_INCOMPATIBLE);
|
DO_TEST_COMPARE(VIR_ARCH_PPC64, "host", "host-incomp-arch", VIR_CPU_COMPARE_INCOMPATIBLE);
|
||||||
DO_TEST_COMPARE("ppc64", "host", "host-no-vendor", VIR_CPU_COMPARE_IDENTICAL);
|
DO_TEST_COMPARE(VIR_ARCH_PPC64, "host", "host-no-vendor", VIR_CPU_COMPARE_IDENTICAL);
|
||||||
DO_TEST_COMPARE("ppc64", "host-no-vendor", "host", VIR_CPU_COMPARE_INCOMPATIBLE);
|
DO_TEST_COMPARE(VIR_ARCH_PPC64, "host-no-vendor", "host", VIR_CPU_COMPARE_INCOMPATIBLE);
|
||||||
|
|
||||||
/* guest to host comparison */
|
/* guest to host comparison */
|
||||||
DO_TEST_COMPARE("x86_64", "host", "bogus-model", VIR_CPU_COMPARE_ERROR);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "bogus-model", VIR_CPU_COMPARE_ERROR);
|
||||||
DO_TEST_COMPARE("x86_64", "host", "bogus-feature", VIR_CPU_COMPARE_ERROR);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "bogus-feature", VIR_CPU_COMPARE_ERROR);
|
||||||
DO_TEST_COMPARE("x86_64", "host", "min", VIR_CPU_COMPARE_SUPERSET);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "min", VIR_CPU_COMPARE_SUPERSET);
|
||||||
DO_TEST_COMPARE("x86_64", "host", "pentium3", VIR_CPU_COMPARE_SUPERSET);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "pentium3", VIR_CPU_COMPARE_SUPERSET);
|
||||||
DO_TEST_COMPARE("x86_64", "host", "exact", VIR_CPU_COMPARE_SUPERSET);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "exact", VIR_CPU_COMPARE_SUPERSET);
|
||||||
DO_TEST_COMPARE("x86_64", "host", "exact-forbid", VIR_CPU_COMPARE_INCOMPATIBLE);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "exact-forbid", VIR_CPU_COMPARE_INCOMPATIBLE);
|
||||||
DO_TEST_COMPARE("x86_64", "host", "exact-forbid-extra", VIR_CPU_COMPARE_SUPERSET);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "exact-forbid-extra", VIR_CPU_COMPARE_SUPERSET);
|
||||||
DO_TEST_COMPARE("x86_64", "host", "exact-disable", VIR_CPU_COMPARE_SUPERSET);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "exact-disable", VIR_CPU_COMPARE_SUPERSET);
|
||||||
DO_TEST_COMPARE("x86_64", "host", "exact-disable2", VIR_CPU_COMPARE_SUPERSET);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "exact-disable2", VIR_CPU_COMPARE_SUPERSET);
|
||||||
DO_TEST_COMPARE("x86_64", "host", "exact-disable-extra", VIR_CPU_COMPARE_SUPERSET);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "exact-disable-extra", VIR_CPU_COMPARE_SUPERSET);
|
||||||
DO_TEST_COMPARE("x86_64", "host", "exact-require", VIR_CPU_COMPARE_SUPERSET);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "exact-require", VIR_CPU_COMPARE_SUPERSET);
|
||||||
DO_TEST_COMPARE("x86_64", "host", "exact-require-extra", VIR_CPU_COMPARE_INCOMPATIBLE);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "exact-require-extra", VIR_CPU_COMPARE_INCOMPATIBLE);
|
||||||
DO_TEST_COMPARE("x86_64", "host", "exact-force", VIR_CPU_COMPARE_SUPERSET);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "exact-force", VIR_CPU_COMPARE_SUPERSET);
|
||||||
DO_TEST_COMPARE("x86_64", "host", "strict", VIR_CPU_COMPARE_INCOMPATIBLE);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "strict", VIR_CPU_COMPARE_INCOMPATIBLE);
|
||||||
DO_TEST_COMPARE("x86_64", "host", "strict-full", VIR_CPU_COMPARE_IDENTICAL);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "strict-full", VIR_CPU_COMPARE_IDENTICAL);
|
||||||
DO_TEST_COMPARE("x86_64", "host", "strict-disable", VIR_CPU_COMPARE_IDENTICAL);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "strict-disable", VIR_CPU_COMPARE_IDENTICAL);
|
||||||
DO_TEST_COMPARE("x86_64", "host", "strict-force-extra", VIR_CPU_COMPARE_IDENTICAL);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "strict-force-extra", VIR_CPU_COMPARE_IDENTICAL);
|
||||||
DO_TEST_COMPARE("x86_64", "host", "guest", VIR_CPU_COMPARE_SUPERSET);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "guest", VIR_CPU_COMPARE_SUPERSET);
|
||||||
DO_TEST_COMPARE("x86_64", "host", "pentium3-amd", VIR_CPU_COMPARE_INCOMPATIBLE);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host", "pentium3-amd", VIR_CPU_COMPARE_INCOMPATIBLE);
|
||||||
DO_TEST_COMPARE("x86_64", "host-amd", "pentium3-amd", VIR_CPU_COMPARE_SUPERSET);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host-amd", "pentium3-amd", VIR_CPU_COMPARE_SUPERSET);
|
||||||
DO_TEST_COMPARE("x86_64", "host-worse", "penryn-force", VIR_CPU_COMPARE_IDENTICAL);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host-worse", "penryn-force", VIR_CPU_COMPARE_IDENTICAL);
|
||||||
DO_TEST_COMPARE("x86_64", "host-SandyBridge", "exact-force-Haswell", VIR_CPU_COMPARE_IDENTICAL);
|
DO_TEST_COMPARE(VIR_ARCH_X86_64, "host-SandyBridge", "exact-force-Haswell", VIR_CPU_COMPARE_IDENTICAL);
|
||||||
|
|
||||||
DO_TEST_COMPARE("ppc64", "host", "guest-strict", VIR_CPU_COMPARE_IDENTICAL);
|
DO_TEST_COMPARE(VIR_ARCH_PPC64, "host", "guest-strict", VIR_CPU_COMPARE_IDENTICAL);
|
||||||
DO_TEST_COMPARE("ppc64", "host", "guest-exact", VIR_CPU_COMPARE_INCOMPATIBLE);
|
DO_TEST_COMPARE(VIR_ARCH_PPC64, "host", "guest-exact", VIR_CPU_COMPARE_INCOMPATIBLE);
|
||||||
DO_TEST_COMPARE("ppc64", "host", "guest-legacy", VIR_CPU_COMPARE_IDENTICAL);
|
DO_TEST_COMPARE(VIR_ARCH_PPC64, "host", "guest-legacy", VIR_CPU_COMPARE_IDENTICAL);
|
||||||
DO_TEST_COMPARE("ppc64", "host", "guest-legacy-incompatible", VIR_CPU_COMPARE_INCOMPATIBLE);
|
DO_TEST_COMPARE(VIR_ARCH_PPC64, "host", "guest-legacy-incompatible", VIR_CPU_COMPARE_INCOMPATIBLE);
|
||||||
DO_TEST_COMPARE("ppc64", "host", "guest-legacy-invalid", VIR_CPU_COMPARE_ERROR);
|
DO_TEST_COMPARE(VIR_ARCH_PPC64, "host", "guest-legacy-invalid", VIR_CPU_COMPARE_ERROR);
|
||||||
DO_TEST_COMPARE("ppc64", "host", "guest-compat-none", VIR_CPU_COMPARE_IDENTICAL);
|
DO_TEST_COMPARE(VIR_ARCH_PPC64, "host", "guest-compat-none", VIR_CPU_COMPARE_IDENTICAL);
|
||||||
DO_TEST_COMPARE("ppc64", "host", "guest-compat-valid", VIR_CPU_COMPARE_IDENTICAL);
|
DO_TEST_COMPARE(VIR_ARCH_PPC64, "host", "guest-compat-valid", VIR_CPU_COMPARE_IDENTICAL);
|
||||||
DO_TEST_COMPARE("ppc64", "host", "guest-compat-invalid", VIR_CPU_COMPARE_ERROR);
|
DO_TEST_COMPARE(VIR_ARCH_PPC64, "host", "guest-compat-invalid", VIR_CPU_COMPARE_ERROR);
|
||||||
DO_TEST_COMPARE("ppc64", "host", "guest-compat-incompatible", VIR_CPU_COMPARE_INCOMPATIBLE);
|
DO_TEST_COMPARE(VIR_ARCH_PPC64, "host", "guest-compat-incompatible", VIR_CPU_COMPARE_INCOMPATIBLE);
|
||||||
|
|
||||||
/* guest updates for migration
|
/* guest updates for migration
|
||||||
* automatically compares host CPU with the result */
|
* automatically compares host CPU with the result */
|
||||||
DO_TEST_UPDATE("x86_64", "host", "min", VIR_CPU_COMPARE_IDENTICAL);
|
DO_TEST_UPDATE(VIR_ARCH_X86_64, "host", "min", VIR_CPU_COMPARE_IDENTICAL);
|
||||||
DO_TEST_UPDATE("x86_64", "host", "pentium3", VIR_CPU_COMPARE_IDENTICAL);
|
DO_TEST_UPDATE(VIR_ARCH_X86_64, "host", "pentium3", VIR_CPU_COMPARE_IDENTICAL);
|
||||||
DO_TEST_UPDATE("x86_64", "host", "guest", VIR_CPU_COMPARE_SUPERSET);
|
DO_TEST_UPDATE(VIR_ARCH_X86_64, "host", "guest", VIR_CPU_COMPARE_SUPERSET);
|
||||||
DO_TEST_UPDATE("x86_64", "host", "host-model", VIR_CPU_COMPARE_IDENTICAL);
|
DO_TEST_UPDATE(VIR_ARCH_X86_64, "host", "host-model", VIR_CPU_COMPARE_IDENTICAL);
|
||||||
DO_TEST_UPDATE("x86_64", "host", "host-model-nofallback", VIR_CPU_COMPARE_IDENTICAL);
|
DO_TEST_UPDATE(VIR_ARCH_X86_64, "host", "host-model-nofallback", VIR_CPU_COMPARE_IDENTICAL);
|
||||||
DO_TEST_UPDATE("x86_64", "host-invtsc", "host-model", VIR_CPU_COMPARE_SUPERSET);
|
DO_TEST_UPDATE(VIR_ARCH_X86_64, "host-invtsc", "host-model", VIR_CPU_COMPARE_SUPERSET);
|
||||||
DO_TEST_UPDATE_ONLY("x86_64", "host", "host-passthrough");
|
DO_TEST_UPDATE_ONLY(VIR_ARCH_X86_64, "host", "host-passthrough");
|
||||||
DO_TEST_UPDATE_ONLY("x86_64", "host", "host-passthrough-features");
|
DO_TEST_UPDATE_ONLY(VIR_ARCH_X86_64, "host", "host-passthrough-features");
|
||||||
|
|
||||||
DO_TEST_UPDATE("ppc64", "host", "guest", VIR_CPU_COMPARE_IDENTICAL);
|
DO_TEST_UPDATE(VIR_ARCH_PPC64, "host", "guest", VIR_CPU_COMPARE_IDENTICAL);
|
||||||
DO_TEST_UPDATE("ppc64", "host", "guest-nofallback", VIR_CPU_COMPARE_INCOMPATIBLE);
|
DO_TEST_UPDATE(VIR_ARCH_PPC64, "host", "guest-nofallback", VIR_CPU_COMPARE_INCOMPATIBLE);
|
||||||
DO_TEST_UPDATE("ppc64", "host", "guest-legacy", VIR_CPU_COMPARE_IDENTICAL);
|
DO_TEST_UPDATE(VIR_ARCH_PPC64, "host", "guest-legacy", VIR_CPU_COMPARE_IDENTICAL);
|
||||||
DO_TEST_UPDATE("ppc64", "host", "guest-legacy-incompatible", VIR_CPU_COMPARE_INCOMPATIBLE);
|
DO_TEST_UPDATE(VIR_ARCH_PPC64, "host", "guest-legacy-incompatible", VIR_CPU_COMPARE_INCOMPATIBLE);
|
||||||
DO_TEST_UPDATE("ppc64", "host", "guest-legacy-invalid", VIR_CPU_COMPARE_ERROR);
|
DO_TEST_UPDATE(VIR_ARCH_PPC64, "host", "guest-legacy-invalid", VIR_CPU_COMPARE_ERROR);
|
||||||
DO_TEST_UPDATE("ppc64", "host", "guest-compat-none", VIR_CPU_COMPARE_IDENTICAL);
|
DO_TEST_UPDATE(VIR_ARCH_PPC64, "host", "guest-compat-none", VIR_CPU_COMPARE_IDENTICAL);
|
||||||
DO_TEST_UPDATE("ppc64", "host", "guest-compat-valid", VIR_CPU_COMPARE_IDENTICAL);
|
DO_TEST_UPDATE(VIR_ARCH_PPC64, "host", "guest-compat-valid", VIR_CPU_COMPARE_IDENTICAL);
|
||||||
DO_TEST_UPDATE("ppc64", "host", "guest-compat-invalid", VIR_CPU_COMPARE_ERROR);
|
DO_TEST_UPDATE(VIR_ARCH_PPC64, "host", "guest-compat-invalid", VIR_CPU_COMPARE_ERROR);
|
||||||
DO_TEST_UPDATE("ppc64", "host", "guest-compat-incompatible", VIR_CPU_COMPARE_INCOMPATIBLE);
|
DO_TEST_UPDATE(VIR_ARCH_PPC64, "host", "guest-compat-incompatible", VIR_CPU_COMPARE_INCOMPATIBLE);
|
||||||
|
|
||||||
/* computing baseline CPUs */
|
/* computing baseline CPUs */
|
||||||
DO_TEST_BASELINE("x86_64", "incompatible-vendors", 0, -1);
|
DO_TEST_BASELINE(VIR_ARCH_X86_64, "incompatible-vendors", 0, -1);
|
||||||
DO_TEST_BASELINE("x86_64", "no-vendor", 0, 0);
|
DO_TEST_BASELINE(VIR_ARCH_X86_64, "no-vendor", 0, 0);
|
||||||
DO_TEST_BASELINE("x86_64", "some-vendors", 0, 0);
|
DO_TEST_BASELINE(VIR_ARCH_X86_64, "some-vendors", 0, 0);
|
||||||
DO_TEST_BASELINE("x86_64", "1", 0, 0);
|
DO_TEST_BASELINE(VIR_ARCH_X86_64, "1", 0, 0);
|
||||||
DO_TEST_BASELINE("x86_64", "2", 0, 0);
|
DO_TEST_BASELINE(VIR_ARCH_X86_64, "2", 0, 0);
|
||||||
DO_TEST_BASELINE("x86_64", "3", 0, 0);
|
DO_TEST_BASELINE(VIR_ARCH_X86_64, "3", 0, 0);
|
||||||
DO_TEST_BASELINE("x86_64", "3", VIR_CONNECT_BASELINE_CPU_EXPAND_FEATURES, 0);
|
DO_TEST_BASELINE(VIR_ARCH_X86_64, "3", VIR_CONNECT_BASELINE_CPU_EXPAND_FEATURES, 0);
|
||||||
DO_TEST_BASELINE("x86_64", "4", 0, 0);
|
DO_TEST_BASELINE(VIR_ARCH_X86_64, "4", 0, 0);
|
||||||
DO_TEST_BASELINE("x86_64", "4", VIR_CONNECT_BASELINE_CPU_EXPAND_FEATURES, 0);
|
DO_TEST_BASELINE(VIR_ARCH_X86_64, "4", VIR_CONNECT_BASELINE_CPU_EXPAND_FEATURES, 0);
|
||||||
DO_TEST_BASELINE("x86_64", "5", 0, 0);
|
DO_TEST_BASELINE(VIR_ARCH_X86_64, "5", 0, 0);
|
||||||
DO_TEST_BASELINE("x86_64", "5", VIR_CONNECT_BASELINE_CPU_EXPAND_FEATURES, 0);
|
DO_TEST_BASELINE(VIR_ARCH_X86_64, "5", VIR_CONNECT_BASELINE_CPU_EXPAND_FEATURES, 0);
|
||||||
DO_TEST_BASELINE("x86_64", "6", 0, 0);
|
DO_TEST_BASELINE(VIR_ARCH_X86_64, "6", 0, 0);
|
||||||
DO_TEST_BASELINE("x86_64", "6", VIR_CONNECT_BASELINE_CPU_MIGRATABLE, 0);
|
DO_TEST_BASELINE(VIR_ARCH_X86_64, "6", VIR_CONNECT_BASELINE_CPU_MIGRATABLE, 0);
|
||||||
DO_TEST_BASELINE("x86_64", "7", 0, 0);
|
DO_TEST_BASELINE(VIR_ARCH_X86_64, "7", 0, 0);
|
||||||
DO_TEST_BASELINE("x86_64", "8", 0, 0);
|
DO_TEST_BASELINE(VIR_ARCH_X86_64, "8", 0, 0);
|
||||||
|
|
||||||
DO_TEST_BASELINE("ppc64", "incompatible-vendors", 0, -1);
|
DO_TEST_BASELINE(VIR_ARCH_PPC64, "incompatible-vendors", 0, -1);
|
||||||
DO_TEST_BASELINE("ppc64", "no-vendor", 0, 0);
|
DO_TEST_BASELINE(VIR_ARCH_PPC64, "no-vendor", 0, 0);
|
||||||
DO_TEST_BASELINE("ppc64", "incompatible-models", 0, -1);
|
DO_TEST_BASELINE(VIR_ARCH_PPC64, "incompatible-models", 0, -1);
|
||||||
DO_TEST_BASELINE("ppc64", "same-model", 0, 0);
|
DO_TEST_BASELINE(VIR_ARCH_PPC64, "same-model", 0, 0);
|
||||||
DO_TEST_BASELINE("ppc64", "legacy", 0, -1);
|
DO_TEST_BASELINE(VIR_ARCH_PPC64, "legacy", 0, -1);
|
||||||
|
|
||||||
/* CPU features */
|
/* CPU features */
|
||||||
DO_TEST_HASFEATURE("x86_64", "host", "vmx", YES);
|
DO_TEST_HASFEATURE(VIR_ARCH_X86_64, "host", "vmx", YES);
|
||||||
DO_TEST_HASFEATURE("x86_64", "host", "lm", YES);
|
DO_TEST_HASFEATURE(VIR_ARCH_X86_64, "host", "lm", YES);
|
||||||
DO_TEST_HASFEATURE("x86_64", "host", "sse4.1", YES);
|
DO_TEST_HASFEATURE(VIR_ARCH_X86_64, "host", "sse4.1", YES);
|
||||||
DO_TEST_HASFEATURE("x86_64", "host", "3dnowext", NO);
|
DO_TEST_HASFEATURE(VIR_ARCH_X86_64, "host", "3dnowext", NO);
|
||||||
DO_TEST_HASFEATURE("x86_64", "host", "skinit", NO);
|
DO_TEST_HASFEATURE(VIR_ARCH_X86_64, "host", "skinit", NO);
|
||||||
DO_TEST_HASFEATURE("x86_64", "host", "foo", FAIL);
|
DO_TEST_HASFEATURE(VIR_ARCH_X86_64, "host", "foo", FAIL);
|
||||||
|
|
||||||
/* computing guest data and decoding the data into a guest CPU XML */
|
/* computing guest data and decoding the data into a guest CPU XML */
|
||||||
DO_TEST_GUESTCPU("x86_64", "host", "guest", NULL, 0);
|
DO_TEST_GUESTCPU(VIR_ARCH_X86_64, "host", "guest", NULL, 0);
|
||||||
DO_TEST_GUESTCPU("x86_64", "host-better", "pentium3", NULL, 0);
|
DO_TEST_GUESTCPU(VIR_ARCH_X86_64, "host-better", "pentium3", NULL, 0);
|
||||||
DO_TEST_GUESTCPU("x86_64", "host-worse", "guest", NULL, 0);
|
DO_TEST_GUESTCPU(VIR_ARCH_X86_64, "host-worse", "guest", NULL, 0);
|
||||||
DO_TEST_GUESTCPU("x86_64", "host", "strict-force-extra", NULL, 0);
|
DO_TEST_GUESTCPU(VIR_ARCH_X86_64, "host", "strict-force-extra", NULL, 0);
|
||||||
DO_TEST_GUESTCPU("x86_64", "host", "penryn-force", NULL, 0);
|
DO_TEST_GUESTCPU(VIR_ARCH_X86_64, "host", "penryn-force", NULL, 0);
|
||||||
DO_TEST_GUESTCPU("x86_64", "host", "guest", model486, 0);
|
DO_TEST_GUESTCPU(VIR_ARCH_X86_64, "host", "guest", model486, 0);
|
||||||
DO_TEST_GUESTCPU("x86_64", "host", "guest", models, 0);
|
DO_TEST_GUESTCPU(VIR_ARCH_X86_64, "host", "guest", models, 0);
|
||||||
DO_TEST_GUESTCPU("x86_64", "host", "guest", nomodel, -1);
|
DO_TEST_GUESTCPU(VIR_ARCH_X86_64, "host", "guest", nomodel, -1);
|
||||||
DO_TEST_GUESTCPU("x86_64", "host", "guest-nofallback", models, -1);
|
DO_TEST_GUESTCPU(VIR_ARCH_X86_64, "host", "guest-nofallback", models, -1);
|
||||||
DO_TEST_GUESTCPU("x86_64", "host", "host+host-model", models, 0);
|
DO_TEST_GUESTCPU(VIR_ARCH_X86_64, "host", "host+host-model", models, 0);
|
||||||
DO_TEST_GUESTCPU("x86_64", "host", "host+host-model-nofallback", models, -1);
|
DO_TEST_GUESTCPU(VIR_ARCH_X86_64, "host", "host+host-model-nofallback", models, -1);
|
||||||
DO_TEST_GUESTCPU("x86_64", "host-Haswell-noTSX", "Haswell", haswell, 0);
|
DO_TEST_GUESTCPU(VIR_ARCH_X86_64, "host-Haswell-noTSX", "Haswell", haswell, 0);
|
||||||
DO_TEST_GUESTCPU("x86_64", "host-Haswell-noTSX", "Haswell-noTSX", haswell, 0);
|
DO_TEST_GUESTCPU(VIR_ARCH_X86_64, "host-Haswell-noTSX", "Haswell-noTSX", haswell, 0);
|
||||||
DO_TEST_GUESTCPU("x86_64", "host-Haswell-noTSX", "Haswell-noTSX-nofallback", haswell, -1);
|
DO_TEST_GUESTCPU(VIR_ARCH_X86_64, "host-Haswell-noTSX", "Haswell-noTSX-nofallback", haswell, -1);
|
||||||
DO_TEST_GUESTCPU("x86_64", "host-Haswell-noTSX", "Haswell-noTSX", NULL, 0);
|
DO_TEST_GUESTCPU(VIR_ARCH_X86_64, "host-Haswell-noTSX", "Haswell-noTSX", NULL, 0);
|
||||||
|
|
||||||
DO_TEST_GUESTCPU("ppc64", "host", "guest", ppc_models, 0);
|
DO_TEST_GUESTCPU(VIR_ARCH_PPC64, "host", "guest", ppc_models, 0);
|
||||||
DO_TEST_GUESTCPU("ppc64", "host", "guest-nofallback", ppc_models, -1);
|
DO_TEST_GUESTCPU(VIR_ARCH_PPC64, "host", "guest-nofallback", ppc_models, -1);
|
||||||
DO_TEST_GUESTCPU("ppc64", "host", "guest-legacy", ppc_models, 0);
|
DO_TEST_GUESTCPU(VIR_ARCH_PPC64, "host", "guest-legacy", ppc_models, 0);
|
||||||
DO_TEST_GUESTCPU("ppc64", "host", "guest-legacy-incompatible", ppc_models, -1);
|
DO_TEST_GUESTCPU(VIR_ARCH_PPC64, "host", "guest-legacy-incompatible", ppc_models, -1);
|
||||||
DO_TEST_GUESTCPU("ppc64", "host", "guest-legacy-invalid", ppc_models, -1);
|
DO_TEST_GUESTCPU(VIR_ARCH_PPC64, "host", "guest-legacy-invalid", ppc_models, -1);
|
||||||
|
|
||||||
DO_TEST_CPUID("x86_64", "A10-5800K", true);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "A10-5800K", true);
|
||||||
DO_TEST_CPUID("x86_64", "Atom-D510", false);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Atom-D510", false);
|
||||||
DO_TEST_CPUID("x86_64", "Atom-N450", false);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Atom-N450", false);
|
||||||
DO_TEST_CPUID("x86_64", "Core-i5-2500", true);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Core-i5-2500", true);
|
||||||
DO_TEST_CPUID("x86_64", "Core-i5-2540M", true);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Core-i5-2540M", true);
|
||||||
DO_TEST_CPUID("x86_64", "Core-i5-4670T", true);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Core-i5-4670T", true);
|
||||||
DO_TEST_CPUID("x86_64", "Core-i5-6600", true);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Core-i5-6600", true);
|
||||||
DO_TEST_CPUID("x86_64", "Core-i7-2600", true);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Core-i7-2600", true);
|
||||||
DO_TEST_CPUID("x86_64", "Core-i7-3520M", false);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Core-i7-3520M", false);
|
||||||
DO_TEST_CPUID("x86_64", "Core-i7-3740QM", true);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Core-i7-3740QM", true);
|
||||||
DO_TEST_CPUID("x86_64", "Core-i7-3770", true);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Core-i7-3770", true);
|
||||||
DO_TEST_CPUID("x86_64", "Core-i7-4600U", true);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Core-i7-4600U", true);
|
||||||
DO_TEST_CPUID("x86_64", "Core-i7-5600U", true);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Core-i7-5600U", true);
|
||||||
DO_TEST_CPUID("x86_64", "Core2-E6850", true);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Core2-E6850", true);
|
||||||
DO_TEST_CPUID("x86_64", "Core2-Q9500", false);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Core2-Q9500", false);
|
||||||
DO_TEST_CPUID("x86_64", "FX-8150", false);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "FX-8150", false);
|
||||||
DO_TEST_CPUID("x86_64", "Opteron-1352", false);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Opteron-1352", false);
|
||||||
DO_TEST_CPUID("x86_64", "Opteron-2350", true);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Opteron-2350", true);
|
||||||
DO_TEST_CPUID("x86_64", "Opteron-6234", true);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Opteron-6234", true);
|
||||||
DO_TEST_CPUID("x86_64", "Opteron-6282", false);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Opteron-6282", false);
|
||||||
DO_TEST_CPUID("x86_64", "Pentium-P6100", false);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Pentium-P6100", false);
|
||||||
DO_TEST_CPUID("x86_64", "Phenom-B95", true);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Phenom-B95", true);
|
||||||
DO_TEST_CPUID("x86_64", "Xeon-5110", false);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Xeon-5110", false);
|
||||||
DO_TEST_CPUID("x86_64", "Xeon-E3-1245", true);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Xeon-E3-1245", true);
|
||||||
DO_TEST_CPUID("x86_64", "Xeon-E5-2630", true);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Xeon-E5-2630", true);
|
||||||
DO_TEST_CPUID("x86_64", "Xeon-E5-2650", true);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Xeon-E5-2650", true);
|
||||||
DO_TEST_CPUID("x86_64", "Xeon-E7-4820", true);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Xeon-E7-4820", true);
|
||||||
DO_TEST_CPUID("x86_64", "Xeon-W3520", true);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Xeon-W3520", true);
|
||||||
DO_TEST_CPUID("x86_64", "Xeon-X5460", false);
|
DO_TEST_CPUID(VIR_ARCH_X86_64, "Xeon-X5460", false);
|
||||||
|
|
||||||
#if WITH_QEMU && WITH_YAJL
|
#if WITH_QEMU && WITH_YAJL
|
||||||
qemuTestDriverFree(&driver);
|
qemuTestDriverFree(&driver);
|
||||||
|
Loading…
Reference in New Issue
Block a user