summaryrefslogtreecommitdiffstats
path: root/kernel/softirq.c
diff options
context:
space:
mode:
authorThomas Gleixner <tglx@linutronix.de>2008-10-02 10:50:53 +0200
committerIngo Molnar <mingo@elte.hu>2008-10-02 10:58:04 +0200
commit8e85b4b553fc932e1c5141feb5fda389b7f5db01 (patch)
tree2e3f1894e36be800aadeac7ed86ebb4f9fb992a3 /kernel/softirq.c
parentsoftirq: allocate less vectors (diff)
downloadlinux-8e85b4b553fc932e1c5141feb5fda389b7f5db01.tar.xz
linux-8e85b4b553fc932e1c5141feb5fda389b7f5db01.zip
softirqs, debug: preemption check
if a preempt count leaks out of a softirq handler it can be very hard to figure it out. Add a debug check for this. Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'kernel/softirq.c')
-rw-r--r--kernel/softirq.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/kernel/softirq.c b/kernel/softirq.c
index 82e32aadedd8..1cf1e2f2c406 100644
--- a/kernel/softirq.c
+++ b/kernel/softirq.c
@@ -205,7 +205,18 @@ restart:
do {
if (pending & 1) {
+ int prev_count = preempt_count();
+
h->action(h);
+
+ if (unlikely(prev_count != preempt_count())) {
+ printk(KERN_ERR "huh, entered sotfirq %ld %p"
+ "with preempt_count %08x,"
+ " exited with %08x?\n", h - softirq_vec,
+ h->action, prev_count, preempt_count());
+ preempt_count() = prev_count;
+ }
+
rcu_bh_qsctr_inc(cpu);
}
h++;