|
|
032100 |
From 4c906acec14efe3893491d749465ed7e285a825c Mon Sep 17 00:00:00 2001
|
|
|
032100 |
Message-Id: <4c906acec14efe3893491d749465ed7e285a825c@dist-git>
|
|
|
032100 |
From: Jiri Denemark <jdenemar@redhat.com>
|
|
|
032100 |
Date: Wed, 29 Jun 2022 12:00:03 +0200
|
|
|
032100 |
Subject: [PATCH] qemu: Pass migration flags to qemuMigrationParamsApply
|
|
|
032100 |
|
|
|
032100 |
The flags will later be used to determine which parameters should
|
|
|
032100 |
actually be applied.
|
|
|
032100 |
|
|
|
032100 |
Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
|
|
|
032100 |
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
|
|
|
032100 |
(cherry picked from commit 0eae541257cd4f01c9d90db62056ad8d03c5af23)
|
|
|
032100 |
|
|
|
032100 |
https://bugzilla.redhat.com/show_bug.cgi?id=2111070
|
|
|
032100 |
|
|
|
032100 |
Signed-off-by: Jiri Denemark <jdenemar@redhat.com>
|
|
|
032100 |
---
|
|
|
032100 |
src/qemu/qemu_driver.c | 6 +++---
|
|
|
032100 |
src/qemu/qemu_migration.c | 8 ++++----
|
|
|
032100 |
src/qemu/qemu_migration_params.c | 11 ++++++++---
|
|
|
032100 |
src/qemu/qemu_migration_params.h | 3 ++-
|
|
|
032100 |
4 files changed, 17 insertions(+), 11 deletions(-)
|
|
|
032100 |
|
|
|
032100 |
diff --git a/src/qemu/qemu_driver.c b/src/qemu/qemu_driver.c
|
|
|
032100 |
index 847c96639d..17e4c23199 100644
|
|
|
032100 |
--- a/src/qemu/qemu_driver.c
|
|
|
032100 |
+++ b/src/qemu/qemu_driver.c
|
|
|
032100 |
@@ -13091,7 +13091,7 @@ qemuDomainMigrateSetMaxDowntime(virDomainPtr dom,
|
|
|
032100 |
goto endjob;
|
|
|
032100 |
|
|
|
032100 |
if (qemuMigrationParamsApply(driver, vm, VIR_ASYNC_JOB_NONE,
|
|
|
032100 |
- migParams) < 0)
|
|
|
032100 |
+ migParams, 0) < 0)
|
|
|
032100 |
goto endjob;
|
|
|
032100 |
} else {
|
|
|
032100 |
qemuDomainObjEnterMonitor(driver, vm);
|
|
|
032100 |
@@ -13273,7 +13273,7 @@ qemuDomainMigrateSetCompressionCache(virDomainPtr dom,
|
|
|
032100 |
goto endjob;
|
|
|
032100 |
|
|
|
032100 |
if (qemuMigrationParamsApply(driver, vm, VIR_ASYNC_JOB_NONE,
|
|
|
032100 |
- migParams) < 0)
|
|
|
032100 |
+ migParams, 0) < 0)
|
|
|
032100 |
goto endjob;
|
|
|
032100 |
} else {
|
|
|
032100 |
qemuDomainObjEnterMonitor(driver, vm);
|
|
|
032100 |
@@ -13360,7 +13360,7 @@ qemuDomainMigrateSetMaxSpeed(virDomainPtr dom,
|
|
|
032100 |
goto endjob;
|
|
|
032100 |
|
|
|
032100 |
if (qemuMigrationParamsApply(driver, vm, VIR_ASYNC_JOB_NONE,
|
|
|
032100 |
- migParams) < 0)
|
|
|
032100 |
+ migParams, 0) < 0)
|
|
|
032100 |
goto endjob;
|
|
|
032100 |
} else {
|
|
|
032100 |
int rc;
|
|
|
032100 |
diff --git a/src/qemu/qemu_migration.c b/src/qemu/qemu_migration.c
|
|
|
032100 |
index 76903d612b..8cbd73a809 100644
|
|
|
032100 |
--- a/src/qemu/qemu_migration.c
|
|
|
032100 |
+++ b/src/qemu/qemu_migration.c
|
|
|
032100 |
@@ -3259,7 +3259,7 @@ qemuMigrationDstPrepareActive(virQEMUDriver *driver,
|
|
|
032100 |
}
|
|
|
032100 |
|
|
|
032100 |
if (qemuMigrationParamsApply(driver, vm, VIR_ASYNC_JOB_MIGRATION_IN,
|
|
|
032100 |
- migParams) < 0)
|
|
|
032100 |
+ migParams, flags) < 0)
|
|
|
032100 |
goto error;
|
|
|
032100 |
|
|
|
032100 |
if (mig->nbd &&
|
|
|
032100 |
@@ -4847,7 +4847,7 @@ qemuMigrationSrcRun(virQEMUDriver *driver,
|
|
|
032100 |
goto error;
|
|
|
032100 |
|
|
|
032100 |
if (qemuMigrationParamsApply(driver, vm, VIR_ASYNC_JOB_MIGRATION_OUT,
|
|
|
032100 |
- migParams) < 0)
|
|
|
032100 |
+ migParams, flags) < 0)
|
|
|
032100 |
goto error;
|
|
|
032100 |
|
|
|
032100 |
if (flags & VIR_MIGRATE_ZEROCOPY) {
|
|
|
032100 |
@@ -6941,7 +6941,7 @@ qemuMigrationSrcToFile(virQEMUDriver *driver, virDomainObj *vm,
|
|
|
032100 |
QEMU_DOMAIN_MIG_BANDWIDTH_MAX * 1024 * 1024) < 0)
|
|
|
032100 |
return -1;
|
|
|
032100 |
|
|
|
032100 |
- if (qemuMigrationParamsApply(driver, vm, asyncJob, migParams) < 0)
|
|
|
032100 |
+ if (qemuMigrationParamsApply(driver, vm, asyncJob, migParams, 0) < 0)
|
|
|
032100 |
return -1;
|
|
|
032100 |
|
|
|
032100 |
priv->migMaxBandwidth = QEMU_DOMAIN_MIG_BANDWIDTH_MAX;
|
|
|
032100 |
@@ -7037,7 +7037,7 @@ qemuMigrationSrcToFile(virQEMUDriver *driver, virDomainObj *vm,
|
|
|
032100 |
QEMU_MIGRATION_PARAM_MAX_BANDWIDTH,
|
|
|
032100 |
saveMigBandwidth * 1024 * 1024) == 0)
|
|
|
032100 |
ignore_value(qemuMigrationParamsApply(driver, vm, asyncJob,
|
|
|
032100 |
- migParams));
|
|
|
032100 |
+ migParams, 0));
|
|
|
032100 |
} else {
|
|
|
032100 |
if (qemuDomainObjEnterMonitorAsync(driver, vm, asyncJob) == 0) {
|
|
|
032100 |
qemuMonitorSetMigrationSpeed(priv->mon, saveMigBandwidth);
|
|
|
032100 |
diff --git a/src/qemu/qemu_migration_params.c b/src/qemu/qemu_migration_params.c
|
|
|
032100 |
index cc66ed8229..398c07efd0 100644
|
|
|
032100 |
--- a/src/qemu/qemu_migration_params.c
|
|
|
032100 |
+++ b/src/qemu/qemu_migration_params.c
|
|
|
032100 |
@@ -833,8 +833,10 @@ qemuMigrationCapsToJSON(virBitmap *caps,
|
|
|
032100 |
* @vm: domain object
|
|
|
032100 |
* @asyncJob: migration job
|
|
|
032100 |
* @migParams: migration parameters to send to QEMU
|
|
|
032100 |
+ * @apiFlags: migration flags, some of them may affect which parameters are applied
|
|
|
032100 |
*
|
|
|
032100 |
- * Send all parameters stored in @migParams to QEMU.
|
|
|
032100 |
+ * Send parameters stored in @migParams to QEMU. If @apiFlags is non-zero, some
|
|
|
032100 |
+ * parameters that do not make sense for the enabled flags will be ignored.
|
|
|
032100 |
*
|
|
|
032100 |
* Returns 0 on success, -1 on failure.
|
|
|
032100 |
*/
|
|
|
032100 |
@@ -842,7 +844,8 @@ int
|
|
|
032100 |
qemuMigrationParamsApply(virQEMUDriver *driver,
|
|
|
032100 |
virDomainObj *vm,
|
|
|
032100 |
int asyncJob,
|
|
|
032100 |
- qemuMigrationParams *migParams)
|
|
|
032100 |
+ qemuMigrationParams *migParams,
|
|
|
032100 |
+ unsigned long apiFlags G_GNUC_UNUSED)
|
|
|
032100 |
{
|
|
|
032100 |
qemuDomainObjPrivate *priv = vm->privateData;
|
|
|
032100 |
bool xbzrleCacheSize_old = false;
|
|
|
032100 |
@@ -1245,7 +1248,9 @@ qemuMigrationParamsReset(virQEMUDriver *driver,
|
|
|
032100 |
if (!virDomainObjIsActive(vm) || !origParams)
|
|
|
032100 |
goto cleanup;
|
|
|
032100 |
|
|
|
032100 |
- if (qemuMigrationParamsApply(driver, vm, asyncJob, origParams) < 0)
|
|
|
032100 |
+ /* Do not pass apiFlags to qemuMigrationParamsApply here to make sure all
|
|
|
032100 |
+ * parameters and capabilities are reset. */
|
|
|
032100 |
+ if (qemuMigrationParamsApply(driver, vm, asyncJob, origParams, 0) < 0)
|
|
|
032100 |
goto cleanup;
|
|
|
032100 |
|
|
|
032100 |
qemuMigrationParamsResetTLS(driver, vm, asyncJob, origParams, apiFlags);
|
|
|
032100 |
diff --git a/src/qemu/qemu_migration_params.h b/src/qemu/qemu_migration_params.h
|
|
|
032100 |
index d1184acded..9e990e09bd 100644
|
|
|
032100 |
--- a/src/qemu/qemu_migration_params.h
|
|
|
032100 |
+++ b/src/qemu/qemu_migration_params.h
|
|
|
032100 |
@@ -98,7 +98,8 @@ int
|
|
|
032100 |
qemuMigrationParamsApply(virQEMUDriver *driver,
|
|
|
032100 |
virDomainObj *vm,
|
|
|
032100 |
int asyncJob,
|
|
|
032100 |
- qemuMigrationParams *migParams);
|
|
|
032100 |
+ qemuMigrationParams *migParams,
|
|
|
032100 |
+ unsigned long apiFlags);
|
|
|
032100 |
|
|
|
032100 |
int
|
|
|
032100 |
qemuMigrationParamsEnableTLS(virQEMUDriver *driver,
|
|
|
032100 |
--
|
|
|
032100 |
2.35.1
|
|
|
032100 |
|