diff options
author | Andreas Färber <afaerber@suse.de> | 2013-01-20 00:48:29 +0100 |
---|---|---|
committer | Andreas Färber <afaerber@suse.de> | 2013-02-16 14:50:58 +0100 |
commit | 1cc896195bae54d7a5f48f9032037d8f6f65abd5 (patch) | |
tree | 4479002a27f7b5f58b49584127d77bf232c88358 | |
parent | 868e2824276cbe6ef2e202c05c4eb3a3a19d3ee0 (diff) | |
download | qemu-1cc896195bae54d7a5f48f9032037d8f6f65abd5.zip qemu-1cc896195bae54d7a5f48f9032037d8f6f65abd5.tar.gz qemu-1cc896195bae54d7a5f48f9032037d8f6f65abd5.tar.bz2 |
target-m68k: Move TCG initialization to M68kCPU initfn
Add a tcg_enabled() check to suppress it for qtest.
Signed-off-by: Andreas Färber <afaerber@suse.de>
-rw-r--r-- | target-m68k/cpu.c | 6 | ||||
-rw-r--r-- | target-m68k/helper.c | 7 |
2 files changed, 6 insertions, 7 deletions
diff --git a/target-m68k/cpu.c b/target-m68k/cpu.c index e3eaffc..42735db 100644 --- a/target-m68k/cpu.c +++ b/target-m68k/cpu.c @@ -156,8 +156,14 @@ static void m68k_cpu_initfn(Object *obj) { M68kCPU *cpu = M68K_CPU(obj); CPUM68KState *env = &cpu->env; + static bool inited; cpu_exec_init(env); + + if (tcg_enabled() && !inited) { + inited = true; + m68k_tcg_init(); + } } static const VMStateDescription vmstate_m68k_cpu = { diff --git a/target-m68k/helper.c b/target-m68k/helper.c index 3ae6fa0..6030807 100644 --- a/target-m68k/helper.c +++ b/target-m68k/helper.c @@ -103,7 +103,6 @@ CPUM68KState *cpu_m68k_init(const char *cpu_model) M68kCPU *cpu; CPUM68KState *env; ObjectClass *oc; - static int inited; oc = cpu_class_by_name(TYPE_M68K_CPU, cpu_model); if (oc == NULL) { @@ -111,12 +110,6 @@ CPUM68KState *cpu_m68k_init(const char *cpu_model) } cpu = M68K_CPU(object_new(object_class_get_name(oc))); env = &cpu->env; - - if (!inited) { - inited = 1; - m68k_tcg_init(); - } - env->cpu_model_str = cpu_model; register_m68k_insns(env); |