summaryrefslogtreecommitdiffstats
path: root/arch/ia64/kernel/traps.c
diff options
context:
space:
mode:
author <>2005-07-02 08:27:00 +0200
committerTony Luck <tony.luck@intel.com>2005-07-07 00:44:55 +0200
commitaf25e94d4dcfb9608846242fabdd4e6014e5c9f0 (patch)
treef311db4563cb7f101520c737965e3d2180fcda67 /arch/ia64/kernel/traps.c
parentAuto merge with /home/aegl/GIT/linus (diff)
downloadlinux-af25e94d4dcfb9608846242fabdd4e6014e5c9f0.tar.xz
linux-af25e94d4dcfb9608846242fabdd4e6014e5c9f0.zip
[IA64] Make ia64 die() preempt safe
Signed-off-by: Keith Owens <kaos@sgi.com> Signed-off-by: Tony Luck <tony.luck@intel.com>
Diffstat (limited to 'arch/ia64/kernel/traps.c')
-rw-r--r--arch/ia64/kernel/traps.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/arch/ia64/kernel/traps.c b/arch/ia64/kernel/traps.c
index e7e520d90f03..4440c8343fa4 100644
--- a/arch/ia64/kernel/traps.c
+++ b/arch/ia64/kernel/traps.c
@@ -90,14 +90,16 @@ die (const char *str, struct pt_regs *regs, long err)
.lock_owner_depth = 0
};
static int die_counter;
+ int cpu = get_cpu();
- if (die.lock_owner != smp_processor_id()) {
+ if (die.lock_owner != cpu) {
console_verbose();
spin_lock_irq(&die.lock);
- die.lock_owner = smp_processor_id();
+ die.lock_owner = cpu;
die.lock_owner_depth = 0;
bust_spinlocks(1);
}
+ put_cpu();
if (++die.lock_owner_depth < 3) {
printk("%s[%d]: %s %ld [%d]\n",