mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-07 09:43:56 -06:00
Migration Pull request (20231020)
In this pull request: - disable analyze-migration on s390x (thomas) - Fix parse_ramblock() (peter) - start merging live update (steve) - migration-test support for using several binaries (fabiano) - multifd cleanups (fabiano) CI:1042492801
Please apply. -----BEGIN PGP SIGNATURE----- iQIzBAABCAAdFiEEGJn/jt6/WMzuA0uC9IfvGFhy1yMFAmUyJMsACgkQ9IfvGFhy 1yP0AQ/9ELr6VJ0crqzfGm2dy2emnZMaQhDtzR4Kk4ciZF6U+GiATdGN9hK499mP 6WzRIjtSzwD8YZvhLfegxIVTGcEttaM93uXFPznWrk7gwny6QTvuA4qtcRYejTSl wE4GQQOsSrukVCUlqcZtY/t2aphVWQzlx8RRJE3XGaodT1gNLMjd+xp34NbbOoR3 32ixpSPUCOGvCd7hb+HG7pEzk+905Pn2URvbdiP71uqhgJZdjMAv8ehSGD3kufdg FMrZyIEq7Eguk2bO1+7ZiVuIafXXRloIVqi1ENmjIyNDa/Rlv2CA85u0CfgeP6qY Ttj+MZaz8PIhf97IJEILFn+NDXYgsGqEFl//uNbLuTeCpmr9NPhBzLw8CvCefPrR rwBs3J+QbDHWX9EYjk6QZ9QfYJy/DXkl0KfdNtQy9Wf+0o1mHDn5/y3s782T24aJ lGo0ph4VJLBNOx58rpgmoO5prRIjqzF5w4j8pCSeGUC4Bcub5af4TufYrwaf+cps iIbNFx79dLXBlfkKIn7i9RLpz7641Fs/iTQ/MZh1eyvX++UDXAPWnbd4GDYOEewA U3WKsTs/ipIbY8nqaO4j1VMzADPUfetBXznBw60xsZcfjynFJsPV6/F/0OpUupdv qPEY4LZ2uwP4K7AlzrUzUn2f3BKrspL0ObX0qTn0WJ8WX5Jp/YA= =m+uB -----END PGP SIGNATURE----- Merge tag 'migration-20231020-pull-request' of https://gitlab.com/juan.quintela/qemu into staging Migration Pull request (20231020) In this pull request: - disable analyze-migration on s390x (thomas) - Fix parse_ramblock() (peter) - start merging live update (steve) - migration-test support for using several binaries (fabiano) - multifd cleanups (fabiano) CI:1042492801
Please apply. # -----BEGIN PGP SIGNATURE----- # # iQIzBAABCAAdFiEEGJn/jt6/WMzuA0uC9IfvGFhy1yMFAmUyJMsACgkQ9IfvGFhy # 1yP0AQ/9ELr6VJ0crqzfGm2dy2emnZMaQhDtzR4Kk4ciZF6U+GiATdGN9hK499mP # 6WzRIjtSzwD8YZvhLfegxIVTGcEttaM93uXFPznWrk7gwny6QTvuA4qtcRYejTSl # wE4GQQOsSrukVCUlqcZtY/t2aphVWQzlx8RRJE3XGaodT1gNLMjd+xp34NbbOoR3 # 32ixpSPUCOGvCd7hb+HG7pEzk+905Pn2URvbdiP71uqhgJZdjMAv8ehSGD3kufdg # FMrZyIEq7Eguk2bO1+7ZiVuIafXXRloIVqi1ENmjIyNDa/Rlv2CA85u0CfgeP6qY # Ttj+MZaz8PIhf97IJEILFn+NDXYgsGqEFl//uNbLuTeCpmr9NPhBzLw8CvCefPrR # rwBs3J+QbDHWX9EYjk6QZ9QfYJy/DXkl0KfdNtQy9Wf+0o1mHDn5/y3s782T24aJ # lGo0ph4VJLBNOx58rpgmoO5prRIjqzF5w4j8pCSeGUC4Bcub5af4TufYrwaf+cps # iIbNFx79dLXBlfkKIn7i9RLpz7641Fs/iTQ/MZh1eyvX++UDXAPWnbd4GDYOEewA # U3WKsTs/ipIbY8nqaO4j1VMzADPUfetBXznBw60xsZcfjynFJsPV6/F/0OpUupdv # qPEY4LZ2uwP4K7AlzrUzUn2f3BKrspL0ObX0qTn0WJ8WX5Jp/YA= # =m+uB # -----END PGP SIGNATURE----- # gpg: Signature made Thu 19 Oct 2023 23:57:15 PDT # gpg: using RSA key 1899FF8EDEBF58CCEE034B82F487EF185872D723 # gpg: Good signature from "Juan Quintela <quintela@redhat.com>" [full] # gpg: aka "Juan Quintela <quintela@trasno.org>" [full] # Primary key fingerprint: 1899 FF8E DEBF 58CC EE03 4B82 F487 EF18 5872 D723 * tag 'migration-20231020-pull-request' of https://gitlab.com/juan.quintela/qemu: tests/qtest: Don't print messages from query instances tests/qtest/migration: Allow user to specify a machine type tests/qtest/migration: Support more than one QEMU binary tests/qtest/migration: Set q35 as the default machine for x86_86 tests/qtest/migration: Specify the geometry of the bootsector tests/qtest/migration: Define a machine for all architectures tests/qtest/migration: Introduce find_common_machine_version tests/qtest: Introduce qtest_resolve_machine_alias tests/qtest: Introduce qtest_has_machine_with_env tests/qtest: Allow qtest_get_machines to use an alternate QEMU binary tests/qtest: Introduce qtest_init_with_env tests/qtest: Allow qtest_qemu_binary to use a custom environment variable migration/multifd: Stop checking p->quit in multifd_send_thread migration: simplify notifiers migration: Fix parse_ramblock() on overwritten retvals migration: simplify blockers tests/qtest/migration-test: Disable the analyze-migration.py test on s390x Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
This commit is contained in:
commit
384dbdda94
44 changed files with 341 additions and 195 deletions
|
@ -91,6 +91,7 @@ struct QTestState
|
|||
|
||||
static GHookList abrt_hooks;
|
||||
static void (*sighandler_old)(int);
|
||||
static bool silence_spawn_log;
|
||||
|
||||
static int qtest_query_target_endianness(QTestState *s);
|
||||
|
||||
|
@ -336,10 +337,17 @@ void qtest_remove_abrt_handler(void *data)
|
|||
}
|
||||
}
|
||||
|
||||
static const char *qtest_qemu_binary(void)
|
||||
static const char *qtest_qemu_binary(const char *var)
|
||||
{
|
||||
const char *qemu_bin;
|
||||
|
||||
if (var) {
|
||||
qemu_bin = getenv(var);
|
||||
if (qemu_bin) {
|
||||
return qemu_bin;
|
||||
}
|
||||
}
|
||||
|
||||
qemu_bin = getenv("QTEST_QEMU_BINARY");
|
||||
if (!qemu_bin) {
|
||||
fprintf(stderr, "Environment variable QTEST_QEMU_BINARY required\n");
|
||||
|
@ -381,7 +389,8 @@ static pid_t qtest_create_process(char *cmd)
|
|||
}
|
||||
#endif /* _WIN32 */
|
||||
|
||||
static QTestState *G_GNUC_PRINTF(1, 2) qtest_spawn_qemu(const char *fmt, ...)
|
||||
static QTestState *G_GNUC_PRINTF(2, 3) qtest_spawn_qemu(const char *qemu_bin,
|
||||
const char *fmt, ...)
|
||||
{
|
||||
va_list ap;
|
||||
QTestState *s = g_new0(QTestState, 1);
|
||||
|
@ -391,14 +400,15 @@ static QTestState *G_GNUC_PRINTF(1, 2) qtest_spawn_qemu(const char *fmt, ...)
|
|||
g_autoptr(GString) command = g_string_new("");
|
||||
|
||||
va_start(ap, fmt);
|
||||
g_string_append_printf(command, CMD_EXEC "%s %s",
|
||||
qtest_qemu_binary(), tracearg);
|
||||
g_string_append_printf(command, CMD_EXEC "%s %s", qemu_bin, tracearg);
|
||||
g_string_append_vprintf(command, fmt, ap);
|
||||
va_end(ap);
|
||||
|
||||
qtest_add_abrt_handler(kill_qemu_hook_func, s);
|
||||
|
||||
g_test_message("starting QEMU: %s", command->str);
|
||||
if (!silence_spawn_log) {
|
||||
g_test_message("starting QEMU: %s", command->str);
|
||||
}
|
||||
|
||||
#ifndef _WIN32
|
||||
s->qemu_pid = fork();
|
||||
|
@ -431,7 +441,8 @@ static QTestState *G_GNUC_PRINTF(1, 2) qtest_spawn_qemu(const char *fmt, ...)
|
|||
return s;
|
||||
}
|
||||
|
||||
QTestState *qtest_init_without_qmp_handshake(const char *extra_args)
|
||||
static QTestState *qtest_init_internal(const char *qemu_bin,
|
||||
const char *extra_args)
|
||||
{
|
||||
QTestState *s;
|
||||
int sock, qmpsock, i;
|
||||
|
@ -456,7 +467,8 @@ QTestState *qtest_init_without_qmp_handshake(const char *extra_args)
|
|||
sock = init_socket(socket_path);
|
||||
qmpsock = init_socket(qmp_socket_path);
|
||||
|
||||
s = qtest_spawn_qemu("-qtest unix:%s "
|
||||
s = qtest_spawn_qemu(qemu_bin,
|
||||
"-qtest unix:%s "
|
||||
"-qtest-log %s "
|
||||
"-chardev socket,path=%s,id=char0 "
|
||||
"-mon chardev=char0,mode=control "
|
||||
|
@ -509,9 +521,14 @@ QTestState *qtest_init_without_qmp_handshake(const char *extra_args)
|
|||
return s;
|
||||
}
|
||||
|
||||
QTestState *qtest_init(const char *extra_args)
|
||||
QTestState *qtest_init_without_qmp_handshake(const char *extra_args)
|
||||
{
|
||||
QTestState *s = qtest_init_without_qmp_handshake(extra_args);
|
||||
return qtest_init_internal(qtest_qemu_binary(NULL), extra_args);
|
||||
}
|
||||
|
||||
QTestState *qtest_init_with_env(const char *var, const char *extra_args)
|
||||
{
|
||||
QTestState *s = qtest_init_internal(qtest_qemu_binary(var), extra_args);
|
||||
QDict *greeting;
|
||||
|
||||
/* Read the QMP greeting and then do the handshake */
|
||||
|
@ -522,6 +539,11 @@ QTestState *qtest_init(const char *extra_args)
|
|||
return s;
|
||||
}
|
||||
|
||||
QTestState *qtest_init(const char *extra_args)
|
||||
{
|
||||
return qtest_init_with_env(NULL, extra_args);
|
||||
}
|
||||
|
||||
QTestState *qtest_vinitf(const char *fmt, va_list ap)
|
||||
{
|
||||
char *args = g_strdup_vprintf(fmt, ap);
|
||||
|
@ -905,7 +927,7 @@ char *qtest_hmp(QTestState *s, const char *fmt, ...)
|
|||
|
||||
const char *qtest_get_arch(void)
|
||||
{
|
||||
const char *qemu = qtest_qemu_binary();
|
||||
const char *qemu = qtest_qemu_binary(NULL);
|
||||
const char *end = strrchr(qemu, '-');
|
||||
|
||||
if (!end) {
|
||||
|
@ -1449,13 +1471,26 @@ struct MachInfo {
|
|||
char *alias;
|
||||
};
|
||||
|
||||
static void qtest_free_machine_list(struct MachInfo *machines)
|
||||
{
|
||||
if (machines) {
|
||||
for (int i = 0; machines[i].name != NULL; i++) {
|
||||
g_free(machines[i].name);
|
||||
g_free(machines[i].alias);
|
||||
}
|
||||
|
||||
g_free(machines);
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Returns an array with pointers to the available machine names.
|
||||
* The terminating entry has the name set to NULL.
|
||||
*/
|
||||
static struct MachInfo *qtest_get_machines(void)
|
||||
static struct MachInfo *qtest_get_machines(const char *var)
|
||||
{
|
||||
static struct MachInfo *machines;
|
||||
static char *qemu_var;
|
||||
QDict *response, *minfo;
|
||||
QList *list;
|
||||
const QListEntry *p;
|
||||
|
@ -1464,11 +1499,21 @@ static struct MachInfo *qtest_get_machines(void)
|
|||
QTestState *qts;
|
||||
int idx;
|
||||
|
||||
if (g_strcmp0(qemu_var, var)) {
|
||||
qemu_var = g_strdup(var);
|
||||
|
||||
/* new qemu, clear the cache */
|
||||
qtest_free_machine_list(machines);
|
||||
machines = NULL;
|
||||
}
|
||||
|
||||
if (machines) {
|
||||
return machines;
|
||||
}
|
||||
|
||||
qts = qtest_init("-machine none");
|
||||
silence_spawn_log = !g_test_verbose();
|
||||
|
||||
qts = qtest_init_with_env(qemu_var, "-machine none");
|
||||
response = qtest_qmp(qts, "{ 'execute': 'query-machines' }");
|
||||
g_assert(response);
|
||||
list = qdict_get_qlist(response, "return");
|
||||
|
@ -1499,6 +1544,8 @@ static struct MachInfo *qtest_get_machines(void)
|
|||
qtest_quit(qts);
|
||||
qobject_unref(response);
|
||||
|
||||
silence_spawn_log = false;
|
||||
|
||||
memset(&machines[idx], 0, sizeof(struct MachInfo)); /* Terminating entry */
|
||||
return machines;
|
||||
}
|
||||
|
@ -1509,7 +1556,7 @@ void qtest_cb_for_every_machine(void (*cb)(const char *machine),
|
|||
struct MachInfo *machines;
|
||||
int i;
|
||||
|
||||
machines = qtest_get_machines();
|
||||
machines = qtest_get_machines(NULL);
|
||||
|
||||
for (i = 0; machines[i].name != NULL; i++) {
|
||||
/* Ignore machines that cannot be used for qtests */
|
||||
|
@ -1525,12 +1572,28 @@ void qtest_cb_for_every_machine(void (*cb)(const char *machine),
|
|||
}
|
||||
}
|
||||
|
||||
bool qtest_has_machine(const char *machine)
|
||||
char *qtest_resolve_machine_alias(const char *var, const char *alias)
|
||||
{
|
||||
struct MachInfo *machines;
|
||||
int i;
|
||||
|
||||
machines = qtest_get_machines();
|
||||
machines = qtest_get_machines(var);
|
||||
|
||||
for (i = 0; machines[i].name != NULL; i++) {
|
||||
if (machines[i].alias && g_str_equal(alias, machines[i].alias)) {
|
||||
return g_strdup(machines[i].name);
|
||||
}
|
||||
}
|
||||
|
||||
return NULL;
|
||||
}
|
||||
|
||||
bool qtest_has_machine_with_env(const char *var, const char *machine)
|
||||
{
|
||||
struct MachInfo *machines;
|
||||
int i;
|
||||
|
||||
machines = qtest_get_machines(var);
|
||||
|
||||
for (i = 0; machines[i].name != NULL; i++) {
|
||||
if (g_str_equal(machine, machines[i].name) ||
|
||||
|
@ -1542,6 +1605,11 @@ bool qtest_has_machine(const char *machine)
|
|||
return false;
|
||||
}
|
||||
|
||||
bool qtest_has_machine(const char *machine)
|
||||
{
|
||||
return qtest_has_machine_with_env(NULL, machine);
|
||||
}
|
||||
|
||||
bool qtest_has_device(const char *device)
|
||||
{
|
||||
static QList *list;
|
||||
|
|
|
@ -55,6 +55,19 @@ QTestState *qtest_vinitf(const char *fmt, va_list ap) G_GNUC_PRINTF(1, 0);
|
|||
*/
|
||||
QTestState *qtest_init(const char *extra_args);
|
||||
|
||||
/**
|
||||
* qtest_init_with_env:
|
||||
* @var: Environment variable from where to take the QEMU binary
|
||||
* @extra_args: Other arguments to pass to QEMU. CAUTION: these
|
||||
* arguments are subject to word splitting and shell evaluation.
|
||||
*
|
||||
* Like qtest_init(), but use a different environment variable for the
|
||||
* QEMU binary.
|
||||
*
|
||||
* Returns: #QTestState instance.
|
||||
*/
|
||||
QTestState *qtest_init_with_env(const char *var, const char *extra_args);
|
||||
|
||||
/**
|
||||
* qtest_init_without_qmp_handshake:
|
||||
* @extra_args: other arguments to pass to QEMU. CAUTION: these
|
||||
|
@ -909,6 +922,16 @@ void qtest_qmp_fds_assert_success(QTestState *qts, int *fds, size_t nfds,
|
|||
void qtest_cb_for_every_machine(void (*cb)(const char *machine),
|
||||
bool skip_old_versioned);
|
||||
|
||||
/**
|
||||
* qtest_resolve_machine_alias:
|
||||
* @var: Environment variable from where to take the QEMU binary
|
||||
* @alias: The alias to resolve
|
||||
*
|
||||
* Returns: the machine type corresponding to the alias if any,
|
||||
* otherwise NULL.
|
||||
*/
|
||||
char *qtest_resolve_machine_alias(const char *var, const char *alias);
|
||||
|
||||
/**
|
||||
* qtest_has_machine:
|
||||
* @machine: The machine to look for
|
||||
|
@ -917,6 +940,15 @@ void qtest_cb_for_every_machine(void (*cb)(const char *machine),
|
|||
*/
|
||||
bool qtest_has_machine(const char *machine);
|
||||
|
||||
/**
|
||||
* qtest_has_machine_with_env:
|
||||
* @var: Environment variable from where to take the QEMU binary
|
||||
* @machine: The machine to look for
|
||||
*
|
||||
* Returns: true if the machine is available in the specified binary.
|
||||
*/
|
||||
bool qtest_has_machine_with_env(const char *var, const char *machine);
|
||||
|
||||
/**
|
||||
* qtest_has_device:
|
||||
* @device: The device to look for
|
||||
|
|
|
@ -11,6 +11,7 @@
|
|||
*/
|
||||
|
||||
#include "qemu/osdep.h"
|
||||
#include "qemu/ctype.h"
|
||||
#include "qapi/qmp/qjson.h"
|
||||
|
||||
#include "migration-helpers.h"
|
||||
|
@ -240,3 +241,54 @@ void wait_for_migration_fail(QTestState *from, bool allow_active)
|
|||
g_assert(qdict_get_bool(rsp_return, "running"));
|
||||
qobject_unref(rsp_return);
|
||||
}
|
||||
|
||||
char *find_common_machine_version(const char *mtype, const char *var1,
|
||||
const char *var2)
|
||||
{
|
||||
g_autofree char *type1 = qtest_resolve_machine_alias(var1, mtype);
|
||||
g_autofree char *type2 = qtest_resolve_machine_alias(var2, mtype);
|
||||
|
||||
g_assert(type1 && type2);
|
||||
|
||||
if (g_str_equal(type1, type2)) {
|
||||
/* either can be used */
|
||||
return g_strdup(type1);
|
||||
}
|
||||
|
||||
if (qtest_has_machine_with_env(var2, type1)) {
|
||||
return g_strdup(type1);
|
||||
}
|
||||
|
||||
if (qtest_has_machine_with_env(var1, type2)) {
|
||||
return g_strdup(type2);
|
||||
}
|
||||
|
||||
g_test_message("No common machine version for machine type '%s' between "
|
||||
"binaries %s and %s", mtype, getenv(var1), getenv(var2));
|
||||
g_assert_not_reached();
|
||||
}
|
||||
|
||||
char *resolve_machine_version(const char *alias, const char *var1,
|
||||
const char *var2)
|
||||
{
|
||||
const char *mname = g_getenv("QTEST_QEMU_MACHINE_TYPE");
|
||||
g_autofree char *machine_name = NULL;
|
||||
|
||||
if (mname) {
|
||||
const char *dash = strrchr(mname, '-');
|
||||
const char *dot = strrchr(mname, '.');
|
||||
|
||||
machine_name = g_strdup(mname);
|
||||
|
||||
if (dash && dot) {
|
||||
assert(qtest_has_machine(machine_name));
|
||||
return g_steal_pointer(&machine_name);
|
||||
}
|
||||
/* else: probably an alias, let it be resolved below */
|
||||
} else {
|
||||
/* use the hardcoded alias */
|
||||
machine_name = g_strdup(alias);
|
||||
}
|
||||
|
||||
return find_common_machine_version(machine_name, var1, var2);
|
||||
}
|
||||
|
|
|
@ -43,4 +43,8 @@ void wait_for_migration_complete(QTestState *who);
|
|||
|
||||
void wait_for_migration_fail(QTestState *from, bool allow_active);
|
||||
|
||||
char *find_common_machine_version(const char *mtype, const char *var1,
|
||||
const char *var2);
|
||||
char *resolve_machine_version(const char *alias, const char *var1,
|
||||
const char *var2);
|
||||
#endif /* MIGRATION_HELPERS_H */
|
||||
|
|
|
@ -71,6 +71,8 @@ static bool got_dst_resume;
|
|||
#define QEMU_VM_FILE_MAGIC 0x5145564d
|
||||
#define FILE_TEST_FILENAME "migfile"
|
||||
#define FILE_TEST_OFFSET 0x1000
|
||||
#define QEMU_ENV_SRC "QTEST_QEMU_BINARY_SRC"
|
||||
#define QEMU_ENV_DST "QTEST_QEMU_BINARY_DST"
|
||||
|
||||
#if defined(__linux__)
|
||||
#include <sys/syscall.h>
|
||||
|
@ -743,6 +745,8 @@ static int test_migrate_start(QTestState **from, QTestState **to,
|
|||
const char *kvm_opts = NULL;
|
||||
const char *arch = qtest_get_arch();
|
||||
const char *memory_size;
|
||||
const char *machine_alias, *machine_opts = "";
|
||||
g_autofree char *machine = NULL;
|
||||
|
||||
if (args->use_shmem) {
|
||||
if (!g_file_test("/dev/shm", G_FILE_TEST_IS_DIR)) {
|
||||
|
@ -755,11 +759,20 @@ static int test_migrate_start(QTestState **from, QTestState **to,
|
|||
got_dst_resume = false;
|
||||
if (strcmp(arch, "i386") == 0 || strcmp(arch, "x86_64") == 0) {
|
||||
memory_size = "150M";
|
||||
arch_opts = g_strdup_printf("-drive file=%s,format=raw", bootpath);
|
||||
|
||||
if (g_str_equal(arch, "i386")) {
|
||||
machine_alias = "pc";
|
||||
} else {
|
||||
machine_alias = "q35";
|
||||
}
|
||||
arch_opts = g_strdup_printf(
|
||||
"-drive if=none,id=d0,file=%s,format=raw "
|
||||
"-device ide-hd,drive=d0,secs=1,cyls=1,heads=1", bootpath);
|
||||
start_address = X86_TEST_MEM_START;
|
||||
end_address = X86_TEST_MEM_END;
|
||||
} else if (g_str_equal(arch, "s390x")) {
|
||||
memory_size = "128M";
|
||||
machine_alias = "s390-ccw-virtio";
|
||||
arch_opts = g_strdup_printf("-bios %s", bootpath);
|
||||
start_address = S390_TEST_MEM_START;
|
||||
end_address = S390_TEST_MEM_END;
|
||||
|
@ -771,11 +784,14 @@ static int test_migrate_start(QTestState **from, QTestState **to,
|
|||
"'nvramrc=hex .\" _\" begin %x %x "
|
||||
"do i c@ 1 + i c! 1000 +loop .\" B\" 0 "
|
||||
"until'", end_address, start_address);
|
||||
arch_opts = g_strdup("-nodefaults -machine vsmt=8");
|
||||
machine_alias = "pseries";
|
||||
machine_opts = "vsmt=8";
|
||||
arch_opts = g_strdup("-nodefaults");
|
||||
} else if (strcmp(arch, "aarch64") == 0) {
|
||||
memory_size = "150M";
|
||||
arch_opts = g_strdup_printf("-machine virt,gic-version=max -cpu max "
|
||||
"-kernel %s", bootpath);
|
||||
machine_alias = "virt";
|
||||
machine_opts = "gic-version=max";
|
||||
arch_opts = g_strdup_printf("-cpu max -kernel %s", bootpath);
|
||||
start_address = ARM_TEST_MEM_START;
|
||||
end_address = ARM_TEST_MEM_END;
|
||||
} else {
|
||||
|
@ -809,12 +825,19 @@ static int test_migrate_start(QTestState **from, QTestState **to,
|
|||
kvm_opts = ",dirty-ring-size=4096";
|
||||
}
|
||||
|
||||
machine = resolve_machine_version(machine_alias, QEMU_ENV_SRC,
|
||||
QEMU_ENV_DST);
|
||||
|
||||
g_test_message("Using machine type: %s", machine);
|
||||
|
||||
cmd_source = g_strdup_printf("-accel kvm%s -accel tcg "
|
||||
"-machine %s,%s "
|
||||
"-name source,debug-threads=on "
|
||||
"-m %s "
|
||||
"-serial file:%s/src_serial "
|
||||
"%s %s %s %s %s",
|
||||
kvm_opts ? kvm_opts : "",
|
||||
machine, machine_opts,
|
||||
memory_size, tmpfs,
|
||||
arch_opts ? arch_opts : "",
|
||||
arch_source ? arch_source : "",
|
||||
|
@ -822,26 +845,28 @@ static int test_migrate_start(QTestState **from, QTestState **to,
|
|||
args->opts_source ? args->opts_source : "",
|
||||
ignore_stderr);
|
||||
if (!args->only_target) {
|
||||
*from = qtest_init(cmd_source);
|
||||
*from = qtest_init_with_env(QEMU_ENV_SRC, cmd_source);
|
||||
qtest_qmp_set_event_callback(*from,
|
||||
migrate_watch_for_stop,
|
||||
&got_src_stop);
|
||||
}
|
||||
|
||||
cmd_target = g_strdup_printf("-accel kvm%s -accel tcg "
|
||||
"-machine %s,%s "
|
||||
"-name target,debug-threads=on "
|
||||
"-m %s "
|
||||
"-serial file:%s/dest_serial "
|
||||
"-incoming %s "
|
||||
"%s %s %s %s %s",
|
||||
kvm_opts ? kvm_opts : "",
|
||||
machine, machine_opts,
|
||||
memory_size, tmpfs, uri,
|
||||
arch_opts ? arch_opts : "",
|
||||
arch_target ? arch_target : "",
|
||||
shmem_opts ? shmem_opts : "",
|
||||
args->opts_target ? args->opts_target : "",
|
||||
ignore_stderr);
|
||||
*to = qtest_init(cmd_target);
|
||||
*to = qtest_init_with_env(QEMU_ENV_DST, cmd_target);
|
||||
qtest_qmp_set_event_callback(*to,
|
||||
migrate_watch_for_resume,
|
||||
&got_dst_resume);
|
||||
|
@ -2972,10 +2997,23 @@ int main(int argc, char **argv)
|
|||
bool has_uffd;
|
||||
const char *arch;
|
||||
g_autoptr(GError) err = NULL;
|
||||
const char *qemu_src = getenv(QEMU_ENV_SRC);
|
||||
const char *qemu_dst = getenv(QEMU_ENV_DST);
|
||||
int ret;
|
||||
|
||||
g_test_init(&argc, &argv, NULL);
|
||||
|
||||
/*
|
||||
* The default QTEST_QEMU_BINARY must always be provided because
|
||||
* that is what helpers use to query the accel type and
|
||||
* architecture.
|
||||
*/
|
||||
if (qemu_src && qemu_dst) {
|
||||
g_test_message("Only one of %s, %s is allowed",
|
||||
QEMU_ENV_SRC, QEMU_ENV_DST);
|
||||
exit(1);
|
||||
}
|
||||
|
||||
has_kvm = qtest_has_accel("kvm");
|
||||
has_tcg = qtest_has_accel("tcg");
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue