OSDN Git Service

target-cris: Start QOM'ifying CPU init
authorAndreas Färber <afaerber@suse.de>
Wed, 11 Apr 2012 21:41:06 +0000 (23:41 +0200)
committerEdgar E. Iglesias <edgar.iglesias@gmail.com>
Tue, 24 Apr 2012 14:04:56 +0000 (16:04 +0200)
Move VR-independent code from cpu_cris_init() into an initfn.

Signed-off-by: Andreas Färber <afaerber@suse.de>
target-cris/cpu.c
target-cris/translate.c

index 93c7e00..c596609 100644 (file)
@@ -55,6 +55,14 @@ static void cris_cpu_reset(CPUState *s)
 #endif
 }
 
+static void cris_cpu_initfn(Object *obj)
+{
+    CRISCPU *cpu = CRIS_CPU(obj);
+    CPUCRISState *env = &cpu->env;
+
+    cpu_exec_init(env);
+}
+
 static void cris_cpu_class_init(ObjectClass *oc, void *data)
 {
     CPUClass *cc = CPU_CLASS(oc);
@@ -68,6 +76,7 @@ static const TypeInfo cris_cpu_type_info = {
     .name = TYPE_CRIS_CPU,
     .parent = TYPE_CPU,
     .instance_size = sizeof(CRISCPU),
+    .instance_init = cris_cpu_initfn,
     .abstract = false,
     .class_size = sizeof(CRISCPUClass),
     .class_init = cris_cpu_class_init,
index d3dbac2..e353ea3 100644 (file)
@@ -3514,7 +3514,7 @@ CPUCRISState *cpu_cris_init (const char *cpu_model)
     env = &cpu->env;
 
        env->pregs[PR_VR] = vr_by_name(cpu_model);
-       cpu_exec_init(env);
+
     cpu_reset(CPU(cpu));
        qemu_init_vcpu(env);