[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PATCH v4 4/4] migration: Change zero_copy_send from migration param
From: |
Leonardo Bras Soares Passos |
Subject: |
Re: [PATCH v4 4/4] migration: Change zero_copy_send from migration parameter to migration capability |
Date: |
Mon, 20 Jun 2022 02:46:48 -0300 |
CC: Jiri Denemark <jdenemar@redhat.com>
On Mon, Jun 20, 2022 at 2:40 AM Leonardo Bras <leobras@redhat.com> wrote:
>
> When originally implemented, zero_copy_send was designed as a Migration
> paramenter.
>
> But taking into account how is that supposed to work, and how
> the difference between a capability and a parameter, it only makes sense
> that zero-copy-send would work better as a capability.
>
> Taking into account how recently the change got merged, it was decided
> that it's still time to make it right, and convert zero_copy_send into
> a Migration capability.
>
> Signed-off-by: Leonardo Bras <leobras@redhat.com>
> ---
> qapi/migration.json | 33 ++++++++-------------------
> migration/migration.c | 52 ++++++++++++++++---------------------------
> monitor/hmp-cmds.c | 6 -----
> 3 files changed, 28 insertions(+), 63 deletions(-)
>
> diff --git a/qapi/migration.json b/qapi/migration.json
> index 6130cd9fae..baf8d734de 100644
> --- a/qapi/migration.json
> +++ b/qapi/migration.json
> @@ -461,6 +461,13 @@
> # procedure starts. The VM RAM is saved with running
> VM.
> # (since 6.0)
> #
> +# @zero-copy-send: Controls behavior on sending memory pages on migration.
> +# When true, enables a zero-copy mechanism for sending
> +# memory pages, if host supports it.
> +# Requires that QEMU be permitted to use locked memory
> +# for guest RAM pages.
> +# (since 7.1)
> +#
> # Features:
> # @unstable: Members @x-colo and @x-ignore-shared are experimental.
> #
> @@ -474,7 +481,8 @@
> 'block', 'return-path', 'pause-before-switchover', 'multifd',
> 'dirty-bitmaps', 'postcopy-blocktime', 'late-block-activate',
> { 'name': 'x-ignore-shared', 'features': [ 'unstable' ] },
> - 'validate-uuid', 'background-snapshot'] }
> + 'validate-uuid', 'background-snapshot',
> + { 'name': 'zero-copy-send', 'if' : 'CONFIG_LINUX'}] }
>
> ##
> # @MigrationCapabilityStatus:
> @@ -738,12 +746,6 @@
> # will consume more CPU.
> # Defaults to 1. (Since 5.0)
> #
> -# @zero-copy-send: Controls behavior on sending memory pages on migration.
> -# When true, enables a zero-copy mechanism for sending
> -# memory pages, if host supports it.
> -# Requires that QEMU be permitted to use locked memory
> -# for guest RAM pages.
> -# Defaults to false. (Since 7.1)
> #
> # @block-bitmap-mapping: Maps block nodes and bitmaps on them to
> # aliases for the purpose of dirty bitmap migration.
> Such
> @@ -784,7 +786,6 @@
> 'xbzrle-cache-size', 'max-postcopy-bandwidth',
> 'max-cpu-throttle', 'multifd-compression',
> 'multifd-zlib-level' ,'multifd-zstd-level',
> - { 'name': 'zero-copy-send', 'if' : 'CONFIG_LINUX'},
> 'block-bitmap-mapping' ] }
>
> ##
> @@ -911,13 +912,6 @@
> # will consume more CPU.
> # Defaults to 1. (Since 5.0)
> #
> -# @zero-copy-send: Controls behavior on sending memory pages on migration.
> -# When true, enables a zero-copy mechanism for sending
> -# memory pages, if host supports it.
> -# Requires that QEMU be permitted to use locked memory
> -# for guest RAM pages.
> -# Defaults to false. (Since 7.1)
> -#
> # @block-bitmap-mapping: Maps block nodes and bitmaps on them to
> # aliases for the purpose of dirty bitmap migration.
> Such
> # aliases may for example be the corresponding names
> on the
> @@ -972,7 +966,6 @@
> '*multifd-compression': 'MultiFDCompression',
> '*multifd-zlib-level': 'uint8',
> '*multifd-zstd-level': 'uint8',
> - '*zero-copy-send': { 'type': 'bool', 'if': 'CONFIG_LINUX' },
> '*block-bitmap-mapping': [ 'BitmapMigrationNodeAlias' ] } }
>
> ##
> @@ -1119,13 +1112,6 @@
> # will consume more CPU.
> # Defaults to 1. (Since 5.0)
> #
> -# @zero-copy-send: Controls behavior on sending memory pages on migration.
> -# When true, enables a zero-copy mechanism for sending
> -# memory pages, if host supports it.
> -# Requires that QEMU be permitted to use locked memory
> -# for guest RAM pages.
> -# Defaults to false. (Since 7.1)
> -#
> # @block-bitmap-mapping: Maps block nodes and bitmaps on them to
> # aliases for the purpose of dirty bitmap migration.
> Such
> # aliases may for example be the corresponding names
> on the
> @@ -1178,7 +1164,6 @@
> '*multifd-compression': 'MultiFDCompression',
> '*multifd-zlib-level': 'uint8',
> '*multifd-zstd-level': 'uint8',
> - '*zero-copy-send': { 'type': 'bool', 'if': 'CONFIG_LINUX' },
> '*block-bitmap-mapping': [ 'BitmapMigrationNodeAlias' ] } }
>
> ##
> diff --git a/migration/migration.c b/migration/migration.c
> index 31739b2af9..cc253d66e3 100644
> --- a/migration/migration.c
> +++ b/migration/migration.c
> @@ -163,7 +163,8 @@
> INITIALIZE_MIGRATE_CAPS_SET(check_caps_background_snapshot,
> MIGRATION_CAPABILITY_COMPRESS,
> MIGRATION_CAPABILITY_XBZRLE,
> MIGRATION_CAPABILITY_X_COLO,
> - MIGRATION_CAPABILITY_VALIDATE_UUID);
> + MIGRATION_CAPABILITY_VALIDATE_UUID,
> + MIGRATION_CAPABILITY_ZERO_COPY_SEND);
>
> /* When we add fault tolerance, we could have several
> migrations at once. For now we don't need to add
> @@ -910,10 +911,6 @@ MigrationParameters *qmp_query_migrate_parameters(Error
> **errp)
> params->multifd_zlib_level = s->parameters.multifd_zlib_level;
> params->has_multifd_zstd_level = true;
> params->multifd_zstd_level = s->parameters.multifd_zstd_level;
> -#ifdef CONFIG_LINUX
> - params->has_zero_copy_send = true;
> - params->zero_copy_send = s->parameters.zero_copy_send;
> -#endif
> params->has_xbzrle_cache_size = true;
> params->xbzrle_cache_size = s->parameters.xbzrle_cache_size;
> params->has_max_postcopy_bandwidth = true;
> @@ -1275,6 +1272,18 @@ static bool migrate_caps_check(bool *cap_list,
> }
> }
>
> +#ifdef CONFIG_LINUX
> + if (cap_list[MIGRATION_CAPABILITY_ZERO_COPY_SEND] &&
> + (!cap_list[MIGRATION_CAPABILITY_MULTIFD] ||
> + migrate_use_compression() ||
> + migrate_use_tls())) {
> + error_setg(errp,
> + "Zero copy only available for non-compressed non-TLS
> multifd migration");
> + return false;
> + }
> +#endif
> +
> +
> /* incoming side only */
> if (runstate_check(RUN_STATE_INMIGRATE) &&
> !migrate_multi_channels_is_allowed() &&
> @@ -1497,16 +1506,6 @@ static bool migrate_params_check(MigrationParameters
> *params, Error **errp)
> error_prepend(errp, "Invalid mapping given for block-bitmap-mapping:
> ");
> return false;
> }
> -#ifdef CONFIG_LINUX
> - if (params->zero_copy_send &&
> - (!migrate_use_multifd() ||
> - params->multifd_compression != MULTIFD_COMPRESSION_NONE ||
> - (params->tls_creds && *params->tls_creds))) {
> - error_setg(errp,
> - "Zero copy only available for non-compressed non-TLS
> multifd migration");
> - return false;
> - }
> -#endif
> return true;
> }
>
> @@ -1580,11 +1579,6 @@ static void
> migrate_params_test_apply(MigrateSetParameters *params,
> if (params->has_multifd_compression) {
> dest->multifd_compression = params->multifd_compression;
> }
> -#ifdef CONFIG_LINUX
> - if (params->has_zero_copy_send) {
> - dest->zero_copy_send = params->zero_copy_send;
> - }
> -#endif
> if (params->has_xbzrle_cache_size) {
> dest->xbzrle_cache_size = params->xbzrle_cache_size;
> }
> @@ -1697,11 +1691,6 @@ static void migrate_params_apply(MigrateSetParameters
> *params, Error **errp)
> if (params->has_multifd_compression) {
> s->parameters.multifd_compression = params->multifd_compression;
> }
> -#ifdef CONFIG_LINUX
> - if (params->has_zero_copy_send) {
> - s->parameters.zero_copy_send = params->zero_copy_send;
> - }
> -#endif
> if (params->has_xbzrle_cache_size) {
> s->parameters.xbzrle_cache_size = params->xbzrle_cache_size;
> xbzrle_cache_resize(params->xbzrle_cache_size, errp);
> @@ -2593,7 +2582,7 @@ bool migrate_use_zero_copy_send(void)
>
> s = migrate_get_current();
>
> - return s->parameters.zero_copy_send;
> + return s->enabled_capabilities[MIGRATION_CAPABILITY_ZERO_COPY_SEND];
> }
> #endif
>
> @@ -4249,10 +4238,6 @@ static Property migration_properties[] = {
> DEFINE_PROP_UINT8("multifd-zstd-level", MigrationState,
> parameters.multifd_zstd_level,
> DEFAULT_MIGRATE_MULTIFD_ZSTD_LEVEL),
> -#ifdef CONFIG_LINUX
> - DEFINE_PROP_BOOL("zero_copy_send", MigrationState,
> - parameters.zero_copy_send, false),
> -#endif
> DEFINE_PROP_SIZE("xbzrle-cache-size", MigrationState,
> parameters.xbzrle_cache_size,
> DEFAULT_MIGRATE_XBZRLE_CACHE_SIZE),
> @@ -4290,6 +4275,10 @@ static Property migration_properties[] = {
> DEFINE_PROP_MIG_CAP("x-multifd", MIGRATION_CAPABILITY_MULTIFD),
> DEFINE_PROP_MIG_CAP("x-background-snapshot",
> MIGRATION_CAPABILITY_BACKGROUND_SNAPSHOT),
> +#ifdef CONFIG_LINUX
> + DEFINE_PROP_MIG_CAP("x-zero-copy-send",
> + MIGRATION_CAPABILITY_ZERO_COPY_SEND),
> +#endif
>
> DEFINE_PROP_END_OF_LIST(),
> };
> @@ -4350,9 +4339,6 @@ static void migration_instance_init(Object *obj)
> params->has_multifd_compression = true;
> params->has_multifd_zlib_level = true;
> params->has_multifd_zstd_level = true;
> -#ifdef CONFIG_LINUX
> - params->has_zero_copy_send = true;
> -#endif
> params->has_xbzrle_cache_size = true;
> params->has_max_postcopy_bandwidth = true;
> params->has_max_cpu_throttle = true;
> diff --git a/monitor/hmp-cmds.c b/monitor/hmp-cmds.c
> index 47a27326ee..ca98df0495 100644
> --- a/monitor/hmp-cmds.c
> +++ b/monitor/hmp-cmds.c
> @@ -1311,12 +1311,6 @@ void hmp_migrate_set_parameter(Monitor *mon, const
> QDict *qdict)
> p->has_multifd_zstd_level = true;
> visit_type_uint8(v, param, &p->multifd_zstd_level, &err);
> break;
> -#ifdef CONFIG_LINUX
> - case MIGRATION_PARAMETER_ZERO_COPY_SEND:
> - p->has_zero_copy_send = true;
> - visit_type_bool(v, param, &p->zero_copy_send, &err);
> - break;
> -#endif
> case MIGRATION_PARAMETER_XBZRLE_CACHE_SIZE:
> p->has_xbzrle_cache_size = true;
> if (!visit_type_size(v, param, &cache_size, &err)) {
> --
> 2.36.1
>
- Re: [PATCH v4 3/4] migration: zero-copy flush only at the end of bitmap scanning, (continued)