293 lines
12 KiB
Diff
293 lines
12 KiB
Diff
|
|
From c2402b63ecb10b9a25695b710f2664dbcbc01ec4 Mon Sep 17 00:00:00 2001
|
||
|
|
From: Chuan Zheng <zhengchuan@huawei.com>
|
||
|
|
Date: Sat, 30 Jan 2021 14:57:54 +0800
|
||
|
|
Subject: [PATCH] migration: Add multi-thread compress method
|
||
|
|
|
||
|
|
A multi-thread compress method parameter is added to hold the method we
|
||
|
|
are going to use. By default the 'zlib' method is used to maintain the
|
||
|
|
compatibility as before.
|
||
|
|
|
||
|
|
Signed-off-by: Chuan Zheng <zhengchuan@huawei.com>
|
||
|
|
Signed-off-by: Zeyu Jin <jinzeyu@huawei.com>
|
||
|
|
Signed-off-by: Ying Fang <fangying1@huawei.com>
|
||
|
|
---
|
||
|
|
hw/core/qdev-properties-system.c | 11 +++++++++++
|
||
|
|
include/hw/qdev-properties.h | 4 ++++
|
||
|
|
migration/migration-hmp-cmds.c | 13 +++++++++++++
|
||
|
|
migration/options.c | 15 +++++++++++++++
|
||
|
|
monitor/hmp-cmds.c | 1 +
|
||
|
|
qapi/migration.json | 32 ++++++++++++++++++++++++++++++--
|
||
|
|
util/oslib-posix.c | 2 +-
|
||
|
|
7 files changed, 75 insertions(+), 3 deletions(-)
|
||
|
|
|
||
|
|
diff --git a/hw/core/qdev-properties-system.c b/hw/core/qdev-properties-system.c
|
||
|
|
index f2e2718c74..cd5571fcfb 100644
|
||
|
|
--- a/hw/core/qdev-properties-system.c
|
||
|
|
+++ b/hw/core/qdev-properties-system.c
|
||
|
|
@@ -1202,6 +1202,17 @@ const PropertyInfo qdev_prop_uuid = {
|
||
|
|
.set_default_value = set_default_uuid_auto,
|
||
|
|
};
|
||
|
|
|
||
|
|
+/* --- CompressMethod --- */
|
||
|
|
+const PropertyInfo qdev_prop_compress_method = {
|
||
|
|
+ .name = "CompressMethod",
|
||
|
|
+ .description = "multi-thread compression method, "
|
||
|
|
+ "zlib",
|
||
|
|
+ .enum_table = &CompressMethod_lookup,
|
||
|
|
+ .get = qdev_propinfo_get_enum,
|
||
|
|
+ .set = qdev_propinfo_set_enum,
|
||
|
|
+ .set_default_value = qdev_propinfo_set_default_value_enum,
|
||
|
|
+};
|
||
|
|
+
|
||
|
|
/* --- s390 cpu entitlement policy --- */
|
||
|
|
|
||
|
|
QEMU_BUILD_BUG_ON(sizeof(CpuS390Entitlement) != sizeof(int));
|
||
|
|
diff --git a/include/hw/qdev-properties.h b/include/hw/qdev-properties.h
|
||
|
|
index 25743a29a0..63602c2c74 100644
|
||
|
|
--- a/include/hw/qdev-properties.h
|
||
|
|
+++ b/include/hw/qdev-properties.h
|
||
|
|
@@ -60,6 +60,7 @@ extern const PropertyInfo qdev_prop_int64;
|
||
|
|
extern const PropertyInfo qdev_prop_size;
|
||
|
|
extern const PropertyInfo qdev_prop_string;
|
||
|
|
extern const PropertyInfo qdev_prop_on_off_auto;
|
||
|
|
+extern const PropertyInfo qdev_prop_compress_method;
|
||
|
|
extern const PropertyInfo qdev_prop_size32;
|
||
|
|
extern const PropertyInfo qdev_prop_array;
|
||
|
|
extern const PropertyInfo qdev_prop_link;
|
||
|
|
@@ -168,6 +169,9 @@ extern const PropertyInfo qdev_prop_link;
|
||
|
|
DEFINE_PROP(_n, _s, _f, qdev_prop_string, char*)
|
||
|
|
#define DEFINE_PROP_ON_OFF_AUTO(_n, _s, _f, _d) \
|
||
|
|
DEFINE_PROP_SIGNED(_n, _s, _f, _d, qdev_prop_on_off_auto, OnOffAuto)
|
||
|
|
+#define DEFINE_PROP_COMPRESS_METHOD(_n, _s, _f, _d) \
|
||
|
|
+ DEFINE_PROP_SIGNED(_n, _s, _f, _d, qdev_prop_compress_method, \
|
||
|
|
+ CompressMethod)
|
||
|
|
#define DEFINE_PROP_SIZE32(_n, _s, _f, _d) \
|
||
|
|
DEFINE_PROP_UNSIGNED(_n, _s, _f, _d, qdev_prop_size32, uint32_t)
|
||
|
|
|
||
|
|
diff --git a/migration/migration-hmp-cmds.c b/migration/migration-hmp-cmds.c
|
||
|
|
index 86ae832176..261ec1e35c 100644
|
||
|
|
--- a/migration/migration-hmp-cmds.c
|
||
|
|
+++ b/migration/migration-hmp-cmds.c
|
||
|
|
@@ -22,6 +22,7 @@
|
||
|
|
#include "qapi/qapi-commands-migration.h"
|
||
|
|
#include "qapi/qapi-visit-migration.h"
|
||
|
|
#include "qapi/qmp/qdict.h"
|
||
|
|
+#include "qapi/qapi-visit-migration.h"
|
||
|
|
#include "qapi/string-input-visitor.h"
|
||
|
|
#include "qapi/string-output-visitor.h"
|
||
|
|
#include "qemu/cutils.h"
|
||
|
|
@@ -291,6 +292,9 @@ void hmp_info_migrate_parameters(Monitor *mon, const QDict *qdict)
|
||
|
|
MigrationParameter_str(MIGRATION_PARAMETER_DECOMPRESS_THREADS),
|
||
|
|
params->decompress_threads);
|
||
|
|
assert(params->has_throttle_trigger_threshold);
|
||
|
|
+ monitor_printf(mon, "%s: %s\n",
|
||
|
|
+ MigrationParameter_str(MIGRATION_PARAMETER_COMPRESS_METHOD),
|
||
|
|
+ CompressMethod_str(params->compress_method));
|
||
|
|
monitor_printf(mon, "%s: %u\n",
|
||
|
|
MigrationParameter_str(MIGRATION_PARAMETER_THROTTLE_TRIGGER_THRESHOLD),
|
||
|
|
params->throttle_trigger_threshold);
|
||
|
|
@@ -519,6 +523,7 @@ void hmp_migrate_set_parameter(Monitor *mon, const QDict *qdict)
|
||
|
|
MigrateSetParameters *p = g_new0(MigrateSetParameters, 1);
|
||
|
|
uint64_t valuebw = 0;
|
||
|
|
uint64_t cache_size;
|
||
|
|
+ CompressMethod compress_method;
|
||
|
|
Error *err = NULL;
|
||
|
|
int val, ret;
|
||
|
|
|
||
|
|
@@ -544,6 +549,14 @@ void hmp_migrate_set_parameter(Monitor *mon, const QDict *qdict)
|
||
|
|
p->has_decompress_threads = true;
|
||
|
|
visit_type_uint8(v, param, &p->decompress_threads, &err);
|
||
|
|
break;
|
||
|
|
+ case MIGRATION_PARAMETER_COMPRESS_METHOD:
|
||
|
|
+ p->has_compress_method = true;
|
||
|
|
+ visit_type_CompressMethod(v, param, &compress_method, &err);
|
||
|
|
+ if (err) {
|
||
|
|
+ break;
|
||
|
|
+ }
|
||
|
|
+ p->compress_method = compress_method;
|
||
|
|
+ break;
|
||
|
|
case MIGRATION_PARAMETER_THROTTLE_TRIGGER_THRESHOLD:
|
||
|
|
p->has_throttle_trigger_threshold = true;
|
||
|
|
visit_type_uint8(v, param, &p->throttle_trigger_threshold, &err);
|
||
|
|
diff --git a/migration/options.c b/migration/options.c
|
||
|
|
index 8d8ec73ad9..af7ea7b346 100644
|
||
|
|
--- a/migration/options.c
|
||
|
|
+++ b/migration/options.c
|
||
|
|
@@ -47,6 +47,7 @@
|
||
|
|
#define DEFAULT_MIGRATE_DECOMPRESS_THREAD_COUNT 2
|
||
|
|
/*0: means nocompress, 1: best speed, ... 9: best compress ratio */
|
||
|
|
#define DEFAULT_MIGRATE_COMPRESS_LEVEL 1
|
||
|
|
+#define DEFAULT_MIGRATE_COMPRESS_METHOD COMPRESS_METHOD_ZLIB
|
||
|
|
/* Define default autoconverge cpu throttle migration parameters */
|
||
|
|
#define DEFAULT_MIGRATE_THROTTLE_TRIGGER_THRESHOLD 50
|
||
|
|
#define DEFAULT_MIGRATE_CPU_THROTTLE_INITIAL 20
|
||
|
|
@@ -113,6 +114,9 @@ Property migration_properties[] = {
|
||
|
|
DEFINE_PROP_UINT8("x-decompress-threads", MigrationState,
|
||
|
|
parameters.decompress_threads,
|
||
|
|
DEFAULT_MIGRATE_DECOMPRESS_THREAD_COUNT),
|
||
|
|
+ DEFINE_PROP_COMPRESS_METHOD("compress-method", MigrationState,
|
||
|
|
+ parameters.compress_method,
|
||
|
|
+ DEFAULT_MIGRATE_COMPRESS_METHOD),
|
||
|
|
DEFINE_PROP_UINT8("x-throttle-trigger-threshold", MigrationState,
|
||
|
|
parameters.throttle_trigger_threshold,
|
||
|
|
DEFAULT_MIGRATE_THROTTLE_TRIGGER_THRESHOLD),
|
||
|
|
@@ -953,6 +957,8 @@ MigrationParameters *qmp_query_migrate_parameters(Error **errp)
|
||
|
|
params->compress_wait_thread = s->parameters.compress_wait_thread;
|
||
|
|
params->has_decompress_threads = true;
|
||
|
|
params->decompress_threads = s->parameters.decompress_threads;
|
||
|
|
+ params->has_compress_method = true;
|
||
|
|
+ params->compress_method = s->parameters.compress_method;
|
||
|
|
params->has_throttle_trigger_threshold = true;
|
||
|
|
params->throttle_trigger_threshold = s->parameters.throttle_trigger_threshold;
|
||
|
|
params->has_cpu_throttle_initial = true;
|
||
|
|
@@ -1025,6 +1031,7 @@ void migrate_params_init(MigrationParameters *params)
|
||
|
|
params->has_compress_threads = true;
|
||
|
|
params->has_compress_wait_thread = true;
|
||
|
|
params->has_decompress_threads = true;
|
||
|
|
+ params->has_compress_method = true;
|
||
|
|
params->has_throttle_trigger_threshold = true;
|
||
|
|
params->has_cpu_throttle_initial = true;
|
||
|
|
params->has_cpu_throttle_increment = true;
|
||
|
|
@@ -1259,6 +1266,10 @@ static void migrate_params_test_apply(MigrateSetParameters *params,
|
||
|
|
dest->decompress_threads = params->decompress_threads;
|
||
|
|
}
|
||
|
|
|
||
|
|
+ if (params->has_compress_method) {
|
||
|
|
+ dest->compress_method = params->compress_method;
|
||
|
|
+ }
|
||
|
|
+
|
||
|
|
if (params->has_throttle_trigger_threshold) {
|
||
|
|
dest->throttle_trigger_threshold = params->throttle_trigger_threshold;
|
||
|
|
}
|
||
|
|
@@ -1380,6 +1391,10 @@ static void migrate_params_apply(MigrateSetParameters *params, Error **errp)
|
||
|
|
s->parameters.decompress_threads = params->decompress_threads;
|
||
|
|
}
|
||
|
|
|
||
|
|
+ if (params->has_compress_method) {
|
||
|
|
+ s->parameters.compress_method = params->compress_method;
|
||
|
|
+ }
|
||
|
|
+
|
||
|
|
if (params->has_throttle_trigger_threshold) {
|
||
|
|
s->parameters.throttle_trigger_threshold = params->throttle_trigger_threshold;
|
||
|
|
}
|
||
|
|
diff --git a/monitor/hmp-cmds.c b/monitor/hmp-cmds.c
|
||
|
|
index 871898ac46..5bb3c9cd46 100644
|
||
|
|
--- a/monitor/hmp-cmds.c
|
||
|
|
+++ b/monitor/hmp-cmds.c
|
||
|
|
@@ -24,6 +24,7 @@
|
||
|
|
#include "qapi/qapi-commands-control.h"
|
||
|
|
#include "qapi/qapi-commands-misc.h"
|
||
|
|
#include "qapi/qmp/qdict.h"
|
||
|
|
+#include "qapi/qapi-visit-migration.h"
|
||
|
|
#include "qemu/cutils.h"
|
||
|
|
#include "hw/intc/intc.h"
|
||
|
|
#include "qemu/log.h"
|
||
|
|
diff --git a/qapi/migration.json b/qapi/migration.json
|
||
|
|
index eb2f883513..cafaa5ccb3 100644
|
||
|
|
--- a/qapi/migration.json
|
||
|
|
+++ b/qapi/migration.json
|
||
|
|
@@ -708,6 +708,19 @@
|
||
|
|
'bitmaps': [ 'BitmapMigrationBitmapAlias' ]
|
||
|
|
} }
|
||
|
|
|
||
|
|
+##
|
||
|
|
+# @CompressMethod:
|
||
|
|
+#
|
||
|
|
+# An enumeration of multi-thread compression methods.
|
||
|
|
+#
|
||
|
|
+# @zlib: use zlib compression method.
|
||
|
|
+#
|
||
|
|
+# Since: 5.0
|
||
|
|
+#
|
||
|
|
+##
|
||
|
|
+{ 'enum': 'CompressMethod',
|
||
|
|
+ 'data': [ 'zlib' ] }
|
||
|
|
+
|
||
|
|
##
|
||
|
|
# @MigrationParameter:
|
||
|
|
#
|
||
|
|
@@ -746,6 +759,9 @@
|
||
|
|
# fast as compression, so set the decompress-threads to the number
|
||
|
|
# about 1/4 of compress-threads is adequate.
|
||
|
|
#
|
||
|
|
+# @compress-method: Which multi-thread compression method to use.
|
||
|
|
+# Defaults to none. (Since 5.0)
|
||
|
|
+#
|
||
|
|
# @throttle-trigger-threshold: The ratio of bytes_dirty_period and
|
||
|
|
# bytes_xfer_period to trigger throttling. It is expressed as
|
||
|
|
# percentage. The default value is 50. (Since 5.0)
|
||
|
|
@@ -892,6 +908,7 @@
|
||
|
|
{ 'name': 'compress-level', 'features': [ 'deprecated' ] },
|
||
|
|
{ 'name': 'compress-threads', 'features': [ 'deprecated' ] },
|
||
|
|
{ 'name': 'decompress-threads', 'features': [ 'deprecated' ] },
|
||
|
|
+ { 'name': 'compress-method', 'features': [ 'deprecated' ] },
|
||
|
|
{ 'name': 'compress-wait-thread', 'features': [ 'deprecated' ] },
|
||
|
|
'throttle-trigger-threshold',
|
||
|
|
'cpu-throttle-initial', 'cpu-throttle-increment',
|
||
|
|
@@ -935,6 +952,9 @@
|
||
|
|
#
|
||
|
|
# @decompress-threads: decompression thread count
|
||
|
|
#
|
||
|
|
+# @compress-method: Set compression method to use in multi-thread compression.
|
||
|
|
+# Defaults to none. (Since 5.0)
|
||
|
|
+#
|
||
|
|
# @throttle-trigger-threshold: The ratio of bytes_dirty_period and
|
||
|
|
# bytes_xfer_period to trigger throttling. It is expressed as
|
||
|
|
# percentage. The default value is 50. (Since 5.0)
|
||
|
|
@@ -1066,8 +1086,9 @@
|
||
|
|
#
|
||
|
|
# @deprecated: Member @block-incremental is deprecated. Use
|
||
|
|
# blockdev-mirror with NBD instead. Members @compress-level,
|
||
|
|
-# @compress-threads, @decompress-threads and @compress-wait-thread
|
||
|
|
-# are deprecated because @compression is deprecated.
|
||
|
|
+# @compress-threads, @decompress-threads, @compress-method
|
||
|
|
+# and @compress-wait-thread are deprecated because
|
||
|
|
+# @compression is deprecated.
|
||
|
|
#
|
||
|
|
# @unstable: Members @x-checkpoint-delay and @x-vcpu-dirty-limit-period
|
||
|
|
# are experimental.
|
||
|
|
@@ -1090,6 +1111,8 @@
|
||
|
|
'features': [ 'deprecated' ] },
|
||
|
|
'*decompress-threads': { 'type': 'uint8',
|
||
|
|
'features': [ 'deprecated' ] },
|
||
|
|
+ '*compress-method': { 'type': 'CompressMethod',
|
||
|
|
+ 'features': [ 'deprecated' ] },
|
||
|
|
'*throttle-trigger-threshold': 'uint8',
|
||
|
|
'*cpu-throttle-initial': 'uint8',
|
||
|
|
'*cpu-throttle-increment': 'uint8',
|
||
|
|
@@ -1161,6 +1184,9 @@
|
||
|
|
#
|
||
|
|
# @decompress-threads: decompression thread count
|
||
|
|
#
|
||
|
|
+# @compress-method: Which multi-thread compression method to use.
|
||
|
|
+# Defaults to none. (Since 5.0)
|
||
|
|
+#
|
||
|
|
# @throttle-trigger-threshold: The ratio of bytes_dirty_period and
|
||
|
|
# bytes_xfer_period to trigger throttling. It is expressed as
|
||
|
|
# percentage. The default value is 50. (Since 5.0)
|
||
|
|
@@ -1315,6 +1341,8 @@
|
||
|
|
'features': [ 'deprecated' ] },
|
||
|
|
'*decompress-threads': { 'type': 'uint8',
|
||
|
|
'features': [ 'deprecated' ] },
|
||
|
|
+ '*compress-method': { 'type': 'CompressMethod',
|
||
|
|
+ 'features': [ 'deprecated' ] },
|
||
|
|
'*throttle-trigger-threshold': 'uint8',
|
||
|
|
'*cpu-throttle-initial': 'uint8',
|
||
|
|
'*cpu-throttle-increment': 'uint8',
|
||
|
|
diff --git a/util/oslib-posix.c b/util/oslib-posix.c
|
||
|
|
index 9ca3fee2b8..43af077fed 100644
|
||
|
|
--- a/util/oslib-posix.c
|
||
|
|
+++ b/util/oslib-posix.c
|
||
|
|
@@ -346,7 +346,7 @@ static void *do_touch_pages(void *arg)
|
||
|
|
}
|
||
|
|
qemu_mutex_unlock(&page_mutex);
|
||
|
|
|
||
|
|
- while (started_num_threads != memset_args->context.num_threads) {
|
||
|
|
+ while (started_num_threads != memset_args->context->num_threads) {
|
||
|
|
smp_mb();
|
||
|
|
}
|
||
|
|
|
||
|
|
--
|
||
|
|
2.27.0
|
||
|
|
|