From: Andreas Färber Date: Tue, 10 Apr 2012 23:33:33 +0000 (+0200) Subject: target-lm32: QOM'ify CPU init X-Git-Tag: v1.1-rc0~117^2~1 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=8d7d505adda444220c93ee5ad09df4176b366bd7;p=thirdparty%2Fqemu.git target-lm32: QOM'ify CPU init Move code from cpu_lm32_init() to an initfn; call cpu_reset() instead of cpu_state_reset(). Signed-off-by: Andreas Färber Acked-by: Michael Walle --- diff --git a/target-lm32/cpu.c b/target-lm32/cpu.c index 4ce7e3bf4cb..70251d05445 100644 --- a/target-lm32/cpu.c +++ b/target-lm32/cpu.c @@ -34,6 +34,18 @@ static void lm32_cpu_reset(CPUState *s) cpu_state_reset(env); } +static void lm32_cpu_initfn(Object *obj) +{ + LM32CPU *cpu = LM32_CPU(obj); + CPULM32State *env = &cpu->env; + + cpu_exec_init(env); + + env->flags = 0; + + cpu_reset(CPU(cpu)); +} + static void lm32_cpu_class_init(ObjectClass *oc, void *data) { LM32CPUClass *lcc = LM32_CPU_CLASS(oc); @@ -47,6 +59,7 @@ static const TypeInfo lm32_cpu_type_info = { .name = TYPE_LM32_CPU, .parent = TYPE_CPU, .instance_size = sizeof(LM32CPU), + .instance_init = lm32_cpu_initfn, .abstract = false, .class_size = sizeof(LM32CPUClass), .class_init = lm32_cpu_class_init, diff --git a/target-lm32/helper.c b/target-lm32/helper.c index 3cf86d7b765..9de777f43ec 100644 --- a/target-lm32/helper.c +++ b/target-lm32/helper.c @@ -211,10 +211,7 @@ CPULM32State *cpu_lm32_init(const char *cpu_model) env->num_bps = def->num_breakpoints; env->num_wps = def->num_watchpoints; env->cfg = cfg_by_def(def); - env->flags = 0; - cpu_exec_init(env); - cpu_state_reset(env); qemu_init_vcpu(env); if (tcg_enabled() && !tcg_initialized) {