diff options
author | Richard Henderson <richard.henderson@linaro.org> | 2023-09-17 18:38:59 -0700 |
---|---|---|
committer | Richard Henderson <richard.henderson@linaro.org> | 2023-11-06 18:49:33 -0800 |
commit | d3ae32d4d208bd73c8e1bc81d76017268e2455fc (patch) | |
tree | 445ab04ed5d7b8eb3b76f524ffed2fa2c53576ef | |
parent | 9cf2112be4fe84d41083435e44fa146d13d3f8d7 (diff) | |
download | qemu-d3ae32d4d208bd73c8e1bc81d76017268e2455fc.zip qemu-d3ae32d4d208bd73c8e1bc81d76017268e2455fc.tar.gz qemu-d3ae32d4d208bd73c8e1bc81d76017268e2455fc.tar.bz2 |
target/hppa: Implement cpu_list
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
-rw-r--r-- | target/hppa/cpu.c | 24 | ||||
-rw-r--r-- | target/hppa/cpu.h | 5 |
2 files changed, 29 insertions, 0 deletions
diff --git a/target/hppa/cpu.c b/target/hppa/cpu.c index 07fae42..27c74f0 100644 --- a/target/hppa/cpu.c +++ b/target/hppa/cpu.c @@ -161,6 +161,30 @@ static ObjectClass *hppa_cpu_class_by_name(const char *cpu_model) return object_class_by_name(TYPE_HPPA_CPU); } +static void hppa_cpu_list_entry(gpointer data, gpointer user_data) +{ + ObjectClass *oc = data; + CPUClass *cc = CPU_CLASS(oc); + const char *tname = object_class_get_name(oc); + g_autofree char *name = g_strndup(tname, strchr(tname, '-') - tname); + + if (cc->deprecation_note) { + qemu_printf(" %s (deprecated)\n", name); + } else { + qemu_printf(" %s\n", name); + } +} + +void hppa_cpu_list(void) +{ + GSList *list; + + list = object_class_get_list_sorted(TYPE_HPPA_CPU, false); + qemu_printf("Available CPUs:\n"); + g_slist_foreach(list, hppa_cpu_list_entry, NULL); + g_slist_free(list); +} + #ifndef CONFIG_USER_ONLY #include "hw/core/sysemu-cpu-ops.h" diff --git a/target/hppa/cpu.h b/target/hppa/cpu.h index 48ddcff..301c821 100644 --- a/target/hppa/cpu.h +++ b/target/hppa/cpu.h @@ -396,4 +396,9 @@ int hppa_artype_for_page(CPUHPPAState *env, target_ulong vaddr); #endif G_NORETURN void hppa_dynamic_excp(CPUHPPAState *env, int excp, uintptr_t ra); +#define CPU_RESOLVING_TYPE TYPE_HPPA_CPU + +#define cpu_list hppa_cpu_list +void hppa_cpu_list(void); + #endif /* HPPA_CPU_H */ |