[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v4 21/43] target/loongarch: Implement qmp_query_cpu_definitions()
From: |
Xiaojuan Yang |
Subject: |
[PATCH v4 21/43] target/loongarch: Implement qmp_query_cpu_definitions() |
Date: |
Tue, 17 May 2022 19:30:01 +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 v4 10/43] target/loongarch: Add floating point arithmetic instruction translation, (continued)
- [PATCH v4 10/43] target/loongarch: Add floating point arithmetic instruction translation, Xiaojuan Yang, 2022/05/17
- [PATCH v4 04/43] target/loongarch: Add fixed point arithmetic instruction translation, Xiaojuan Yang, 2022/05/17
- [PATCH v4 03/43] target/loongarch: Add main translation routines, Xiaojuan Yang, 2022/05/17
- [PATCH v4 11/43] target/loongarch: Add floating point comparison instruction translation, Xiaojuan Yang, 2022/05/17
- [PATCH v4 13/43] target/loongarch: Add floating point move instruction translation, Xiaojuan Yang, 2022/05/17
- [PATCH v4 12/43] target/loongarch: Add floating point conversion instruction translation, Xiaojuan Yang, 2022/05/17
- [PATCH v4 16/43] target/loongarch: Add disassembler, Xiaojuan Yang, 2022/05/17
- [PATCH v4 26/43] target/loongarch: Add LoongArch IOCSR instruction, Xiaojuan Yang, 2022/05/17
- [PATCH v4 36/43] Enable common virtio pci support for LoongArch, Xiaojuan Yang, 2022/05/17
- [PATCH v4 14/43] target/loongarch: Add floating point load/store instruction translation, Xiaojuan Yang, 2022/05/17
- [PATCH v4 21/43] target/loongarch: Implement qmp_query_cpu_definitions(),
Xiaojuan Yang <=
- [PATCH v4 15/43] target/loongarch: Add branch instruction translation, Xiaojuan Yang, 2022/05/17
- [PATCH v4 19/43] target/loongarch: Add CSRs definition, Xiaojuan Yang, 2022/05/17
- [PATCH v4 28/43] target/loongarch: Add other core instructions support, Xiaojuan Yang, 2022/05/17
- [PATCH v4 30/43] hw/loongarch: Add support loongson3 virt machine type., Xiaojuan Yang, 2022/05/17
- [PATCH v4 32/43] hw/intc: Add LoongArch ls7a interrupt controller support(PCH-PIC), Xiaojuan Yang, 2022/05/17
- [PATCH v4 42/43] tests/tcg/loongarch64: Add hello/memory test in loongarch64 system, Xiaojuan Yang, 2022/05/17
- [PATCH v4 23/43] target/loongarch: Add LoongArch interrupt and exception handle, Xiaojuan Yang, 2022/05/17
- [PATCH v4 20/43] target/loongarch: Add basic vmstate description of CPU., Xiaojuan Yang, 2022/05/17
- [PATCH v4 35/43] hw/loongarch: Add irq hierarchy for the system, Xiaojuan Yang, 2022/05/17
- [PATCH v4 37/43] hw/loongarch: Add some devices support for 3A5000., Xiaojuan Yang, 2022/05/17