[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[RFC v12 15/65] target/arm: move cpu definitions to common cpu module
From: |
Claudio Fontana |
Subject: |
[RFC v12 15/65] target/arm: move cpu definitions to common cpu module |
Date: |
Fri, 26 Mar 2021 20:36:11 +0100 |
Signed-off-by: Claudio Fontana <cfontana@suse.de>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
---
target/arm/cpu-common.c | 41 +++++++++++++++++++++++++++++++++++++++++
target/arm/tcg/helper.c | 29 -----------------------------
target/arm/meson.build | 1 +
3 files changed, 42 insertions(+), 29 deletions(-)
create mode 100644 target/arm/cpu-common.c
diff --git a/target/arm/cpu-common.c b/target/arm/cpu-common.c
new file mode 100644
index 0000000000..0f8ca94815
--- /dev/null
+++ b/target/arm/cpu-common.c
@@ -0,0 +1,41 @@
+/*
+ * ARM CPU common definitions
+ *
+ * This code is licensed under the GNU GPL v2 or later.
+ *
+ * SPDX-License-Identifier: GPL-2.0-or-later
+ */
+
+#include "qemu/osdep.h"
+#include "qom/object.h"
+#include "qapi/qapi-commands-machine-target.h"
+#include "qapi/error.h"
+#include "cpu.h"
+
+static void arm_cpu_add_definition(gpointer data, gpointer user_data)
+{
+ ObjectClass *oc = data;
+ CpuDefinitionInfoList **cpu_list = user_data;
+ CpuDefinitionInfo *info;
+ const char *typename;
+
+ typename = object_class_get_name(oc);
+ info = g_malloc0(sizeof(*info));
+ info->name = g_strndup(typename,
+ strlen(typename) - strlen("-" TYPE_ARM_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_ARM_CPU, false);
+ g_slist_foreach(list, arm_cpu_add_definition, &cpu_list);
+ g_slist_free(list);
+
+ return cpu_list;
+}
diff --git a/target/arm/tcg/helper.c b/target/arm/tcg/helper.c
index 8e976ceb6a..08456aa50a 100644
--- a/target/arm/tcg/helper.c
+++ b/target/arm/tcg/helper.c
@@ -28,7 +28,6 @@
#include "sysemu/kvm.h"
#include "sysemu/tcg.h"
#include "qemu/range.h"
-#include "qapi/qapi-commands-machine-target.h"
#include "qapi/error.h"
#include "qemu/guest-random.h"
#ifdef CONFIG_TCG
@@ -697,34 +696,6 @@ void arm_cpu_list(void)
g_slist_free(list);
}
-static void arm_cpu_add_definition(gpointer data, gpointer user_data)
-{
- ObjectClass *oc = data;
- CpuDefinitionInfoList **cpu_list = user_data;
- CpuDefinitionInfo *info;
- const char *typename;
-
- typename = object_class_get_name(oc);
- info = g_malloc0(sizeof(*info));
- info->name = g_strndup(typename,
- strlen(typename) - strlen("-" TYPE_ARM_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_ARM_CPU, false);
- g_slist_foreach(list, arm_cpu_add_definition, &cpu_list);
- g_slist_free(list);
-
- return cpu_list;
-}
-
static int bad_mode_switch(CPUARMState *env, int mode, CPSRWriteType
write_type)
{
/* Return true if it is not valid for us to switch to
diff --git a/target/arm/meson.build b/target/arm/meson.build
index 5fb34c1af1..8d6177c1fb 100644
--- a/target/arm/meson.build
+++ b/target/arm/meson.build
@@ -2,6 +2,7 @@ arm_ss = ss.source_set()
arm_ss.add(files(
'cpregs.c',
'cpu.c',
+ 'cpu-common.c',
'cpu-mmu.c',
'cpustate-list.c',
'gdbstub.c',
--
2.26.2
- [RFC v12 03/65] arm: tcg: only build under CONFIG_TCG, (continued)
- [RFC v12 03/65] arm: tcg: only build under CONFIG_TCG, Claudio Fontana, 2021/03/26
- [RFC v12 06/65] target/arm: tcg: move sysemu-only parts of debug_helper, Claudio Fontana, 2021/03/26
- [RFC v12 05/65] target/arm: tcg: split mte_helper user-only and sysemu code, Claudio Fontana, 2021/03/26
- [RFC v12 07/65] target/arm: tcg: split tlb_helper user-only and sysemu-only parts, Claudio Fontana, 2021/03/26
- [RFC v12 09/65] target/arm: only build psci for TCG, Claudio Fontana, 2021/03/26
- [RFC v12 10/65] target/arm: split off cpu-sysemu.c, Claudio Fontana, 2021/03/26
- [RFC v12 08/65] target/arm: tcg: split m_helper user-only and sysemu-only parts, Claudio Fontana, 2021/03/26
- [RFC v12 11/65] target/arm: tcg: fix comment style before move to cpu-mmu, Claudio Fontana, 2021/03/26
- [RFC v12 15/65] target/arm: move cpu definitions to common cpu module,
Claudio Fontana <=
- [RFC v12 12/65] target/arm: move physical address translation to cpu-mmu, Claudio Fontana, 2021/03/26
- [RFC v12 17/65] target/arm: tcg: add stubs for some helpers for non-tcg builds, Claudio Fontana, 2021/03/26
- [RFC v12 13/65] target/arm: fix style in preparation of new cpregs module, Claudio Fontana, 2021/03/26
- [RFC v12 18/65] target/arm: move cpsr_read, cpsr_write to cpu_common, Claudio Fontana, 2021/03/26
- [RFC v12 19/65] target/arm: add temporary stub for arm_rebuild_hflags, Claudio Fontana, 2021/03/26