target-alpha: Avoid leaking the alarm timer over reset
authorAndreas Färber <afaerber@suse.de>
Wed, 31 Oct 2012 01:41:11 +0000 (02:41 +0100)
committerAndreas Färber <afaerber@suse.de>
Wed, 19 Dec 2012 00:01:36 +0000 (01:01 +0100)
Move the timer from CPUAlphaState to AlphaCPU to avoid the pointer being
zero'ed once we implement reset. Would cause a segfault in
sys_helper.c:helper_set_alarm().

This also simplifies timer initialization in Typhoon.

Signed-off-by: Andreas Färber <afaerber@suse.de>
Acked-by: Richard Henderson <rth@twiddle.net>
hw/alpha_typhoon.c
target-alpha/cpu-qom.h
target-alpha/cpu.h
target-alpha/sys_helper.c

index 4cc810fb213b3837413dc52973b3b79a5ceea22e..40b3a47c7e0f870396942be9e601609529988da1 100644 (file)
@@ -724,8 +724,7 @@ PCIBus *typhoon_init(ram_addr_t ram_size, ISABus **isa_bus,
         AlphaCPU *cpu = cpus[i];
         s->cchip.cpu[i] = cpu;
         if (cpu != NULL) {
-            CPUAlphaState *env = &cpu->env;
-            env->alarm_timer = qemu_new_timer_ns(rtc_clock,
+            cpu->alarm_timer = qemu_new_timer_ns(rtc_clock,
                                                  typhoon_alarm_timer,
                                                  (void *)((uintptr_t)s + i));
         }
index 6b4ca6d1d19ae77283127dfbc6dbae7370dcc92e..98585d5023fad73a666a66ea7d9f7e35935db397 100644 (file)
@@ -58,6 +58,9 @@ typedef struct AlphaCPU {
     /*< public >*/
 
     CPUAlphaState env;
+
+    /* This alarm doesn't exist in real hardware; we wish it did.  */
+    struct QEMUTimer *alarm_timer;
 } AlphaCPU;
 
 static inline AlphaCPU *alpha_env_get_cpu(CPUAlphaState *env)
index 32e3777cdc51ea93be7974970af73a2757166e8b..e1d771562aed0e10308b63852cedf3ed1a229f8b 100644 (file)
@@ -277,7 +277,6 @@ struct CPUAlphaState {
 #endif
 
     /* This alarm doesn't exist in real hardware; we wish it did.  */
-    struct QEMUTimer *alarm_timer;
     uint64_t alarm_expire;
 
     /* Those resources are used only in QEMU core */
index 40ca49c8837b514a1bed53c0d037965877464703..d4f14efd8671da48e2366f5fa2abc2d580db2592 100644 (file)
@@ -77,11 +77,13 @@ uint64_t helper_get_time(void)
 
 void helper_set_alarm(CPUAlphaState *env, uint64_t expire)
 {
+    AlphaCPU *cpu = alpha_env_get_cpu(env);
+
     if (expire) {
         env->alarm_expire = expire;
-        qemu_mod_timer(env->alarm_timer, expire);
+        qemu_mod_timer(cpu->alarm_timer, expire);
     } else {
-        qemu_del_timer(env->alarm_timer);
+        qemu_del_timer(cpu->alarm_timer);
     }
 }
 #endif /* CONFIG_USER_ONLY */