aboutsummaryrefslogtreecommitdiff
path: root/target-alpha/cpu.c
diff options
context:
space:
mode:
authorAndreas Färber <afaerber@suse.de>2012-10-15 17:44:21 +0200
committerAndreas Färber <afaerber@suse.de>2012-12-19 01:01:37 +0100
commit494342b35b55b3b126821141e15c8a49df122ff1 (patch)
tree32256f51cf082a17b96eb901642f3b49a42aec04 /target-alpha/cpu.c
parent0c28246fcd5ea9ccb22aa93ef2e0af14463fec58 (diff)
target-alpha: Add support for -cpu ?
Implement alphabetical listing of CPU subclasses. Signed-off-by: Andreas Färber <afaerber@suse.de> Acked-by: Richard Henderson <rth@twiddle.net>
Diffstat (limited to 'target-alpha/cpu.c')
-rw-r--r--target-alpha/cpu.c41
1 files changed, 41 insertions, 0 deletions
diff --git a/target-alpha/cpu.c b/target-alpha/cpu.c
index a5a98d0fd5..2deb3c1d7d 100644
--- a/target-alpha/cpu.c
+++ b/target-alpha/cpu.c
@@ -33,6 +33,47 @@ static void alpha_cpu_realize(Object *obj, Error **errp)
#endif
}
+typedef struct AlphaCPUListState {
+ fprintf_function cpu_fprintf;
+ FILE *file;
+} AlphaCPUListState;
+
+/* Sort alphabetically by type name. */
+static gint alpha_cpu_list_compare(gconstpointer a, gconstpointer b)
+{
+ ObjectClass *class_a = (ObjectClass *)a;
+ ObjectClass *class_b = (ObjectClass *)b;
+ const char *name_a, *name_b;
+
+ name_a = object_class_get_name(class_a);
+ name_b = object_class_get_name(class_b);
+ return strcmp(name_a, name_b);
+}
+
+static void alpha_cpu_list_entry(gpointer data, gpointer user_data)
+{
+ ObjectClass *oc = data;
+ AlphaCPUListState *s = user_data;
+
+ (*s->cpu_fprintf)(s->file, " %s\n",
+ object_class_get_name(oc));
+}
+
+void alpha_cpu_list(FILE *f, fprintf_function cpu_fprintf)
+{
+ AlphaCPUListState s = {
+ .file = f,
+ .cpu_fprintf = cpu_fprintf,
+ };
+ GSList *list;
+
+ list = object_class_get_list(TYPE_ALPHA_CPU, false);
+ list = g_slist_sort(list, alpha_cpu_list_compare);
+ (*cpu_fprintf)(f, "Available CPUs:\n");
+ g_slist_foreach(list, alpha_cpu_list_entry, &s);
+ g_slist_free(list);
+}
+
/* Models */
#define TYPE(model) model "-" TYPE_ALPHA_CPU