[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v5 21/43] target/loongarch: Implement qmp_query_cpu_definitions()
From: |
Xiaojuan Yang |
Subject: |
[PATCH v5 21/43] target/loongarch: Implement qmp_query_cpu_definitions() |
Date: |
Tue, 24 May 2022 16:17:42 +0800 |
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 06b0d2ca61..2e267fa458 100644
--- a/qapi/machine-target.json
+++ b/qapi/machine-target.json
@@ -323,7 +323,8 @@
'TARGET_ARM',
'TARGET_I386',
'TARGET_S390X',
- 'TARGET_MIPS' ] } }
+ 'TARGET_MIPS',
+ 'TARGET_LOONGARCH64' ] } }
##
# @query-cpu-definitions:
@@ -339,4 +340,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 c44b2b16a9..bb31502ff9 100644
--- a/target/loongarch/cpu.c
+++ b/target/loongarch/cpu.c
@@ -360,3 +360,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.31.1
- [PATCH v5 06/43] target/loongarch: Add fixed point bit instruction translation, (continued)
- [PATCH v5 06/43] target/loongarch: Add fixed point bit instruction translation, Xiaojuan Yang, 2022/05/24
- [PATCH v5 01/43] target/loongarch: Add README, Xiaojuan Yang, 2022/05/24
- [PATCH v5 10/43] target/loongarch: Add floating point arithmetic instruction translation, Xiaojuan Yang, 2022/05/24
- [PATCH v5 08/43] target/loongarch: Add fixed point atomic instruction translation, Xiaojuan Yang, 2022/05/24
- [PATCH v5 12/43] target/loongarch: Add floating point conversion instruction translation, Xiaojuan Yang, 2022/05/24
- [PATCH v5 11/43] target/loongarch: Add floating point comparison instruction translation, Xiaojuan Yang, 2022/05/24
- [PATCH v5 05/43] target/loongarch: Add fixed point shift instruction translation, Xiaojuan Yang, 2022/05/24
- [PATCH v5 19/43] target/loongarch: Add CSRs definition, Xiaojuan Yang, 2022/05/24
- [PATCH v5 13/43] target/loongarch: Add floating point move instruction translation, Xiaojuan Yang, 2022/05/24
- [PATCH v5 15/43] target/loongarch: Add branch instruction translation, Xiaojuan Yang, 2022/05/24
- [PATCH v5 21/43] target/loongarch: Implement qmp_query_cpu_definitions(),
Xiaojuan Yang <=
- [PATCH v5 24/43] target/loongarch: Add constant timer support, Xiaojuan Yang, 2022/05/24
- [PATCH v5 20/43] target/loongarch: Add basic vmstate description of CPU., Xiaojuan Yang, 2022/05/24
- [PATCH v5 14/43] target/loongarch: Add floating point load/store instruction translation, Xiaojuan Yang, 2022/05/24
- [PATCH v5 02/43] target/loongarch: Add core definition, Xiaojuan Yang, 2022/05/24
- [PATCH v5 22/43] target/loongarch: Add MMU support for LoongArch CPU., Xiaojuan Yang, 2022/05/24
- [PATCH v5 37/43] hw/loongarch: Add some devices support for 3A5000., Xiaojuan Yang, 2022/05/24
- [PATCH v5 03/43] target/loongarch: Add main translation routines, Xiaojuan Yang, 2022/05/24
- [PATCH v5 27/43] target/loongarch: Add TLB instruction support, Xiaojuan Yang, 2022/05/24
- [PATCH v5 28/43] target/loongarch: Add other core instructions support, Xiaojuan Yang, 2022/05/24
- [PATCH v5 40/43] hw/loongarch: Add LoongArch ls7a acpi device support, Xiaojuan Yang, 2022/05/24