summaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
authorIngo Molnar <mingo@elte.hu>2011-02-06 12:59:22 +0100
committerIngo Molnar <mingo@elte.hu>2011-02-06 12:59:38 +0100
commit55835eb62fad1253c9e657a667549945e4be9759 (patch)
tree21626f8fe39d917a955f1f5110d63e4765a3ec93 /kernel
parent83a06bf50bdf2074b9404951ff60e142d159d93b (diff)
parentf266a5110d453b7987194460ac7edd31f1a5426c (diff)
Merge branch 'timers/locking'
Diffstat (limited to 'kernel')
-rw-r--r--kernel/timer.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/kernel/timer.c b/kernel/timer.c
index 43ca9936f2d..d53ce66daea 100644
--- a/kernel/timer.c
+++ b/kernel/timer.c
@@ -969,10 +969,14 @@ EXPORT_SYMBOL(try_to_del_timer_sync);
int del_timer_sync(struct timer_list *timer)
{
#ifdef CONFIG_LOCKDEP
+ unsigned long flags;
+
+ raw_local_irq_save(flags);
local_bh_disable();
lock_map_acquire(&timer->lockdep_map);
lock_map_release(&timer->lockdep_map);
- local_bh_enable();
+ _local_bh_enable();
+ raw_local_irq_restore(flags);
#endif
/*
* don't use it in hardirq context, because it