[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v6 21/43] target/loongarch: Implement qmp_query_cpu_definitions()
From: |
Xiaojuan Yang |
Subject: |
[PATCH v6 21/43] target/loongarch: Implement qmp_query_cpu_definitions() |
Date: |
Wed, 1 Jun 2022 18:24:47 +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 v6 15/43] target/loongarch: Add branch instruction translation, (continued)
- [PATCH v6 15/43] target/loongarch: Add branch instruction translation, Xiaojuan Yang, 2022/06/01
- [PATCH v6 23/43] target/loongarch: Add LoongArch interrupt and exception handle, Xiaojuan Yang, 2022/06/01
- [PATCH v6 33/43] hw/intc: Add LoongArch ls7a msi interrupt controller support(PCH-MSI), Xiaojuan Yang, 2022/06/01
- [PATCH v6 25/43] target/loongarch: Add LoongArch CSR instruction, Xiaojuan Yang, 2022/06/01
- [PATCH v6 06/43] target/loongarch: Add fixed point bit instruction translation, Xiaojuan Yang, 2022/06/01
- [PATCH v6 39/43] hw/loongarch: Add LoongArch load elf function., Xiaojuan Yang, 2022/06/01
- [PATCH v6 03/43] target/loongarch: Add main translation routines, Xiaojuan Yang, 2022/06/01
- [PATCH v6 34/43] hw/intc: Add LoongArch extioi interrupt controller(EIOINTC), Xiaojuan Yang, 2022/06/01
- [PATCH v6 36/43] Enable common virtio pci support for LoongArch, Xiaojuan Yang, 2022/06/01
- [PATCH v6 21/43] target/loongarch: Implement qmp_query_cpu_definitions(),
Xiaojuan Yang <=
- [PATCH v6 04/43] target/loongarch: Add fixed point arithmetic instruction translation, Xiaojuan Yang, 2022/06/01
- [PATCH v6 38/43] hw/loongarch: Add LoongArch ls7a rtc device support, Xiaojuan Yang, 2022/06/01
- [PATCH v6 02/43] target/loongarch: Add core definition, Xiaojuan Yang, 2022/06/01
- [PATCH v6 18/43] target/loongarch: Add system emulation introduction, Xiaojuan Yang, 2022/06/01
- [PATCH v6 32/43] hw/intc: Add LoongArch ls7a interrupt controller support(PCH-PIC), Xiaojuan Yang, 2022/06/01
- [PATCH v6 05/43] target/loongarch: Add fixed point shift instruction translation, Xiaojuan Yang, 2022/06/01
- [PATCH v6 31/43] hw/loongarch: Add LoongArch ipi interrupt support(IPI), Xiaojuan Yang, 2022/06/01
- [PATCH v6 35/43] hw/loongarch: Add irq hierarchy for the system, Xiaojuan Yang, 2022/06/01
- [PATCH v6 40/43] hw/loongarch: Add LoongArch power manager support, Xiaojuan Yang, 2022/06/01