aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/kernel/cpu/mcheck/mce.c
diff options
context:
space:
mode:
authorJan Beulich <jbeulich@novell.com>2009-12-08 11:21:37 +0900
committerIngo Molnar <mingo@elte.hu>2009-12-08 05:34:39 +0100
commitbc09effabf0c5c6c7021e5ef9af15a23579b32a8 (patch)
tree03c9c0af55965e5bf2aa6d2cdf60056e06e66cc6 /arch/x86/kernel/cpu/mcheck/mce.c
parenta946d8f11f0da9cfc714248036fcfd3a794d1e27 (diff)
downloadkernel_samsung_smdk4412-bc09effabf0c5c6c7021e5ef9af15a23579b32a8.zip
kernel_samsung_smdk4412-bc09effabf0c5c6c7021e5ef9af15a23579b32a8.tar.gz
kernel_samsung_smdk4412-bc09effabf0c5c6c7021e5ef9af15a23579b32a8.tar.bz2
x86/mce: Set up timer unconditionally
mce_timer must be passed to setup_timer() in all cases, no matter whether it is going to be actually used. Otherwise, when the CPU gets brought down, its call to del_timer_sync() will never return, as the timer won't have a base associated, and hence lock_timer_base() will loop infinitely. Signed-off-by: Jan Beulich <jbeulich@novell.com> Signed-off-by: Hidetoshi Seto <seto.hidetoshi@jp.fujitsu.com> Cc: <stable@kernel.org> LKML-Reference: <4B1DB831.2030801@jp.fujitsu.com> Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/x86/kernel/cpu/mcheck/mce.c')
-rw-r--r--arch/x86/kernel/cpu/mcheck/mce.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/arch/x86/kernel/cpu/mcheck/mce.c b/arch/x86/kernel/cpu/mcheck/mce.c
index d7ebf25..a96e5cd 100644
--- a/arch/x86/kernel/cpu/mcheck/mce.c
+++ b/arch/x86/kernel/cpu/mcheck/mce.c
@@ -1388,13 +1388,14 @@ static void __mcheck_cpu_init_timer(void)
struct timer_list *t = &__get_cpu_var(mce_timer);
int *n = &__get_cpu_var(mce_next_interval);
+ setup_timer(t, mce_start_timer, smp_processor_id());
+
if (mce_ignore_ce)
return;
*n = check_interval * HZ;
if (!*n)
return;
- setup_timer(t, mce_start_timer, smp_processor_id());
t->expires = round_jiffies(jiffies + *n);
add_timer_on(t, smp_processor_id());
}