[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[qemu-s390x] [PULL 20/26] qmp: add query-cpus-fast
From: |
Cornelia Huck |
Subject: |
[qemu-s390x] [PULL 20/26] qmp: add query-cpus-fast |
Date: |
Tue, 27 Feb 2018 14:21:44 +0100 |
From: Luiz Capitulino <address@hidden>
The query-cpus command has an extremely serious side effect:
it always interrupts all running vCPUs so that they can run
ioctl calls. This can cause a huge performance degradation for
some workloads. And most of the information retrieved by the
ioctl calls are not even used by query-cpus.
This commit introduces a replacement for query-cpus called
query-cpus-fast, which has the following features:
o Never interrupt vCPUs threads. query-cpus-fast only returns
vCPU information maintained by QEMU itself, which should be
sufficient for most management software needs
o Drop "halted" field as it can not be retrieved in a fast
way on most architectures
o Drop irrelevant fields such as "current", "pc" and "arch"
o Rename some fields for better clarification & proper naming
standard
Signed-off-by: Luiz Capitulino <address@hidden>
Signed-off-by: Viktor Mihajlovski <address@hidden>
Message-Id: <address@hidden>
Reviewed-by: Cornelia Huck <address@hidden>
Reviewed-by: Eric Blake <address@hidden>
Signed-off-by: Cornelia Huck <address@hidden>
---
cpus.c | 38 ++++++++++++++++++++++++++++++
qapi-schema.json | 70 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
2 files changed, 108 insertions(+)
diff --git a/cpus.c b/cpus.c
index 6006931d3a..6df6660ccf 100644
--- a/cpus.c
+++ b/cpus.c
@@ -2156,6 +2156,44 @@ CpuInfoList *qmp_query_cpus(Error **errp)
return head;
}
+/*
+ * fast means: we NEVER interrupt vCPU threads to retrieve
+ * information from KVM.
+ */
+CpuInfoFastList *qmp_query_cpus_fast(Error **errp)
+{
+ MachineState *ms = MACHINE(qdev_get_machine());
+ MachineClass *mc = MACHINE_GET_CLASS(ms);
+ CpuInfoFastList *head = NULL, *cur_item = NULL;
+ CPUState *cpu;
+
+ CPU_FOREACH(cpu) {
+ CpuInfoFastList *info = g_malloc0(sizeof(*info));
+ info->value = g_malloc0(sizeof(*info->value));
+
+ info->value->cpu_index = cpu->cpu_index;
+ info->value->qom_path = object_get_canonical_path(OBJECT(cpu));
+ info->value->thread_id = cpu->thread_id;
+
+ info->value->has_props = !!mc->cpu_index_to_instance_props;
+ if (info->value->has_props) {
+ CpuInstanceProperties *props;
+ props = g_malloc0(sizeof(*props));
+ *props = mc->cpu_index_to_instance_props(ms, cpu->cpu_index);
+ info->value->props = props;
+ }
+
+ if (!cur_item) {
+ head = cur_item = info;
+ } else {
+ cur_item->next = info;
+ cur_item = info;
+ }
+ }
+
+ return head;
+}
+
void qmp_memsave(int64_t addr, int64_t size, const char *filename,
bool has_cpu, int64_t cpu_index, Error **errp)
{
diff --git a/qapi-schema.json b/qapi-schema.json
index 94d560ed13..815f072876 100644
--- a/qapi-schema.json
+++ b/qapi-schema.json
@@ -552,6 +552,12 @@
#
# Returns a list of information about each virtual CPU.
#
+# This command causes vCPU threads to exit to userspace, which causes
+# a small interruption to guest CPU execution. This will have a negative
+# impact on realtime guests and other latency sensitive guest workloads.
+# It is recommended to use @query-cpus-fast instead of this command to
+# avoid the vCPU interruption.
+#
# Returns: a list of @CpuInfo for each virtual CPU
#
# Since: 0.14.0
@@ -585,6 +591,70 @@
{ 'command': 'query-cpus', 'returns': ['CpuInfo'] }
##
+# @CpuInfoFast:
+#
+# Information about a virtual CPU
+#
+# @cpu-index: index of the virtual CPU
+#
+# @qom-path: path to the CPU object in the QOM tree
+#
+# @thread-id: ID of the underlying host thread
+#
+# @props: properties describing to which node/socket/core/thread
+# virtual CPU belongs to, provided if supported by board
+#
+# Since: 2.12
+#
+##
+{ 'struct': 'CpuInfoFast',
+ 'data': {'cpu-index': 'int', 'qom-path': 'str',
+ 'thread-id': 'int', '*props': 'CpuInstanceProperties' } }
+
+##
+# @query-cpus-fast:
+#
+# Returns information about all virtual CPUs. This command does not
+# incur a performance penalty and should be used in production
+# instead of query-cpus.
+#
+# Returns: list of @CpuInfoFast
+#
+# Notes: The CPU architecture name is not returned by query-cpus-fast.
+# Use query-target to retrieve that information.
+#
+# Since: 2.12
+#
+# Example:
+#
+# -> { "execute": "query-cpus-fast" }
+# <- { "return": [
+# {
+# "thread-id": 25627,
+# "props": {
+# "core-id": 0,
+# "thread-id": 0,
+# "socket-id": 0
+# },
+# "qom-path": "/machine/unattached/device[0]",
+# "cpu-index": 0
+# },
+# {
+# "thread-id": 25628,
+# "props": {
+# "core-id": 0,
+# "thread-id": 0,
+# "socket-id": 1
+# },
+# "qom-path": "/machine/unattached/device[2]",
+# "cpu-index": 1
+# }
+# ]
+# }
+##
+{ 'command': 'query-cpus-fast', 'returns': [ 'CpuInfoFast' ] }
+
+##
# @IOThreadInfo:
#
# Information about an iothread
--
2.13.6
- [qemu-s390x] [PULL 07/26] s390-ccw: set up interactive boot menu parameters, (continued)
- [qemu-s390x] [PULL 07/26] s390-ccw: set up interactive boot menu parameters, Cornelia Huck, 2018/02/27
- [qemu-s390x] [PULL 11/26] s390-ccw: set cp_receive mask only when needed and consume pending service irqs, Cornelia Huck, 2018/02/27
- [qemu-s390x] [PULL 10/26] s390-ccw: read user input for boot index via the SCLP console, Cornelia Huck, 2018/02/27
- [qemu-s390x] [PULL 12/26] s390-ccw: use zipl values when no boot menu options are present, Cornelia Huck, 2018/02/27
- [qemu-s390x] [PULL 13/26] s390-ccw: interactive boot menu for scsi, Cornelia Huck, 2018/02/27
- [qemu-s390x] [PULL 16/26] s390/stattrib: Make SaveVMHandlers data static, Cornelia Huck, 2018/02/27
- [qemu-s390x] [PULL 18/26] s390x/tcg: add various alignment checks, Cornelia Huck, 2018/02/27
- [qemu-s390x] [PULL 15/26] s390x/cpu: expose the guest crash information, Cornelia Huck, 2018/02/27
- [qemu-s390x] [PULL 17/26] s390x/tcg: fix disabling/enabling DAT, Cornelia Huck, 2018/02/27
- [qemu-s390x] [PULL 21/26] qmp: add architecture specific cpu data for query-cpus-fast, Cornelia Huck, 2018/02/27
- [qemu-s390x] [PULL 20/26] qmp: add query-cpus-fast,
Cornelia Huck <=
- [qemu-s390x] [PULL 19/26] qmp: expose s390-specific CPU info, Cornelia Huck, 2018/02/27
- [qemu-s390x] [PULL 22/26] qemu-doc: deprecate query-cpus, Cornelia Huck, 2018/02/27
- [qemu-s390x] [PULL 23/26] hmp: change hmp_info_cpus to use query-cpus-fast, Cornelia Huck, 2018/02/27
- [qemu-s390x] [PULL 24/26] s390x/cpumodel: document S390FeatDef.bit not applicable, Cornelia Huck, 2018/02/27
- [qemu-s390x] [PULL 26/26] s390x: remove s390_get_memslot_count, Cornelia Huck, 2018/02/27
- [qemu-s390x] [PULL 25/26] s390x/sclp: remove memory hotplug support, Cornelia Huck, 2018/02/27
- [qemu-s390x] [PULL 14/26] pc-bios/s390: Rebuild the s390x firmware images with the boot menu changes, Cornelia Huck, 2018/02/27