]> git.proxmox.com Git - qemu.git/commitdiff
target-ppc: Start QOM'ifying CPU init
authorAndreas Färber <afaerber@suse.de>
Fri, 6 Apr 2012 13:09:01 +0000 (15:09 +0200)
committerAndreas Färber <afaerber@suse.de>
Sun, 15 Apr 2012 15:11:02 +0000 (17:11 +0200)
Move code not dependent on ppc_def_t from cpu_ppc_init() into an initfn.

Signed-off-by: Andreas Färber <afaerber@suse.de>
Acked-by: David Gibson <david@gibson.dropbear.id.au>
target-ppc/helper.c
target-ppc/translate_init.c

index 0d904ddb1072a94437a22824aee1ef243b2c3f91..c5de0eaa819058e336c3e6c109aef76214227a42 100644 (file)
@@ -3196,10 +3196,11 @@ CPUPPCState *cpu_ppc_init (const char *cpu_model)
 
     cpu = POWERPC_CPU(object_new(TYPE_POWERPC_CPU));
     env = &cpu->env;
-    cpu_exec_init(env);
+
     if (tcg_enabled()) {
         ppc_translate_init();
     }
+
     env->cpu_model_str = cpu_model;
     cpu_ppc_register_internal(env, def);
 
index e4d15a59a8689707e3ddf51435cd3bd4440ec736..5a7ac774574bdbe93846b584d9c6364dc46f6b18 100644 (file)
@@ -10217,6 +10217,14 @@ static void ppc_cpu_reset(CPUState *s)
     cpu_state_reset(env);
 }
 
+static void ppc_cpu_initfn(Object *obj)
+{
+    PowerPCCPU *cpu = POWERPC_CPU(obj);
+    CPUPPCState *env = &cpu->env;
+
+    cpu_exec_init(env);
+}
+
 static void ppc_cpu_class_init(ObjectClass *oc, void *data)
 {
     PowerPCCPUClass *pcc = POWERPC_CPU_CLASS(oc);
@@ -10230,6 +10238,7 @@ static const TypeInfo ppc_cpu_type_info = {
     .name = TYPE_POWERPC_CPU,
     .parent = TYPE_CPU,
     .instance_size = sizeof(PowerPCCPU),
+    .instance_init = ppc_cpu_initfn,
     .abstract = false,
     .class_size = sizeof(PowerPCCPUClass),
     .class_init = ppc_cpu_class_init,