[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[RFC PATCH v5 04/30] target/loongarch: Implement qmp_query_cpu_definitio
|
From: |
Xiaojuan Yang |
|
Subject: |
[RFC PATCH v5 04/30] target/loongarch: Implement qmp_query_cpu_definitions() |
|
Date: |
Thu, 27 Jan 2022 22:43:46 -0500 |
Signed-off-by: Xiaojuan Yang <yangxiaojuan@loongson.cn>
Signed-off-by: Song Gao <gaosong@loongson.cn>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
---
qapi/machine-target.json | 6 ++++--
target/loongarch/cpu.c | 26 ++++++++++++++++++++++++++
2 files changed, 30 insertions(+), 2 deletions(-)
diff --git a/qapi/machine-target.json b/qapi/machine-target.json
index f5ec4bc172..682dc86b42 100644
--- a/qapi/machine-target.json
+++ b/qapi/machine-target.json
@@ -324,7 +324,8 @@
'TARGET_ARM',
'TARGET_I386',
'TARGET_S390X',
- 'TARGET_MIPS' ] } }
+ 'TARGET_MIPS',
+ 'TARGET_LOONGARCH64' ] } }
##
# @query-cpu-definitions:
@@ -340,4 +341,5 @@
'TARGET_ARM',
'TARGET_I386',
'TARGET_S390X',
- 'TARGET_MIPS' ] } }
+ 'TARGET_MIPS',
+ 'TARGET_LOONGARCH64' ] } }
diff --git a/target/loongarch/cpu.c b/target/loongarch/cpu.c
index 6b7d871158..719a791ec0 100644
--- a/target/loongarch/cpu.c
+++ b/target/loongarch/cpu.c
@@ -358,3 +358,29 @@ static const TypeInfo loongarch_cpu_type_infos[] = {
};
DEFINE_TYPES(loongarch_cpu_type_infos)
+
+static void loongarch_cpu_add_definition(gpointer data, gpointer user_data)
+{
+ ObjectClass *oc = data;
+ CpuDefinitionInfoList **cpu_list = user_data;
+ CpuDefinitionInfo *info = g_new0(CpuDefinitionInfo, 1);
+ const char *typename = object_class_get_name(oc);
+
+ info->name = g_strndup(typename,
+ strlen(typename) - strlen("-" TYPE_LOONGARCH_CPU));
+ info->q_typename = g_strdup(typename);
+
+ QAPI_LIST_PREPEND(*cpu_list, info);
+}
+
+CpuDefinitionInfoList *qmp_query_cpu_definitions(Error **errp)
+{
+ CpuDefinitionInfoList *cpu_list = NULL;
+ GSList *list;
+
+ list = object_class_get_list(TYPE_LOONGARCH_CPU, false);
+ g_slist_foreach(list, loongarch_cpu_add_definition, &cpu_list);
+ g_slist_free(list);
+
+ return cpu_list;
+}
--
2.27.0
- [RFC PATCH v5 00/30] Add LoongArch softmmu support, Xiaojuan Yang, 2022/01/27
- [RFC PATCH v5 00/30] Add LoongArch softmmu support, Xiaojuan Yang, 2022/01/27
- [RFC PATCH v5 02/30] target/loongarch: Add CSRs definition, Xiaojuan Yang, 2022/01/27
- [RFC PATCH v5 01/30] target/loongarch: Add system emulation introduction, Xiaojuan Yang, 2022/01/27
- [RFC PATCH v5 05/30] target/loongarch: Add constant timer support, Xiaojuan Yang, 2022/01/27
- [RFC PATCH v5 04/30] target/loongarch: Implement qmp_query_cpu_definitions(),
Xiaojuan Yang <=
- [RFC PATCH v5 08/30] target/loongarch: Add LoongArch IOCSR instruction, Xiaojuan Yang, 2022/01/27
- [RFC PATCH v5 03/30] target/loongarch: Add basic vmstate description of CPU., Xiaojuan Yang, 2022/01/27
- [RFC PATCH v5 06/30] target/loongarch: Add MMU support for LoongArch CPU., Xiaojuan Yang, 2022/01/27
- [RFC PATCH v5 07/30] target/loongarch: Add LoongArch CSR instruction, Xiaojuan Yang, 2022/01/27
- [RFC PATCH v5 09/30] target/loongarch: Add TLB instruction support, Xiaojuan Yang, 2022/01/27
- [RFC PATCH v5 11/30] target/loongarch: Add LoongArch interrupt and exception handle, Xiaojuan Yang, 2022/01/27
- [RFC PATCH v5 13/30] target/loongarch: Add gdb support., Xiaojuan Yang, 2022/01/27
- [RFC PATCH v5 17/30] hw/loongarch: Add LoongArch ipi interrupt support(IPI), Xiaojuan Yang, 2022/01/27
- [RFC PATCH v5 12/30] target/loongarch: Add timer related instructions support., Xiaojuan Yang, 2022/01/27
- [RFC PATCH v5 16/30] hw/loongarch: Add LoongArch cpu interrupt support(CPUINTC), Xiaojuan Yang, 2022/01/27