diff options
author | Thomas Gleixner <tglx@linutronix.de> | 2012-07-19 13:59:37 -0400 |
---|---|---|
committer | Tony Luck <tony.luck@intel.com> | 2012-08-03 14:45:20 -0400 |
commit | ea22571c8fd912f28e2525f7112bbb84b474ff3a (patch) | |
tree | 6828731f26c15ed0c862807c65934a9e2c6a127d /arch/x86/kernel | |
parent | 0d7614f09c1ebdbaa1599a5aba7593f147bf96ee (diff) |
x86: mce: Disable preemption when calling raise_local()
raise_mce() has a code path which does not disable preemption when the
raise_local() is called. The per cpu variable access in raise_local()
depends on preemption being disabled to be functional. So that code
path was either never tested or never tested with CONFIG_DEBUG_PREEMPT
enabled.
Add the missing preempt_disable/enable() pair around the call.
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Chen Gong <gong.chen@linux.intel.com>
Signed-off-by: Tony Luck <tony.luck@intel.com>
Diffstat (limited to 'arch/x86/kernel')
-rw-r--r-- | arch/x86/kernel/cpu/mcheck/mce-inject.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/arch/x86/kernel/cpu/mcheck/mce-inject.c b/arch/x86/kernel/cpu/mcheck/mce-inject.c index fc4beb393577..753746f6dbd8 100644 --- a/arch/x86/kernel/cpu/mcheck/mce-inject.c +++ b/arch/x86/kernel/cpu/mcheck/mce-inject.c | |||
@@ -194,7 +194,11 @@ static void raise_mce(struct mce *m) | |||
194 | put_online_cpus(); | 194 | put_online_cpus(); |
195 | } else | 195 | } else |
196 | #endif | 196 | #endif |
197 | { | ||
198 | preempt_disable(); | ||
197 | raise_local(); | 199 | raise_local(); |
200 | preempt_enable(); | ||
201 | } | ||
198 | } | 202 | } |
199 | 203 | ||
200 | /* Error injection interface */ | 204 | /* Error injection interface */ |