This is the mail archive of the
systemtap@sourceware.org
mailing list for the systemtap project.
Re: [PATCH] minimize lockdep_on/off side-effect
- From: Mathieu Desnoyers <compudj at krystal dot dyndns dot org>
- To: Andrew Morton <akpm at osdl dot org>
- Cc: Greg Kroah-Hartman <gregkh at suse dot de>, Richard J Moore <richardj_moore at uk dot ibm dot com>, linux-kernel at vger dot kernel dot org, "Martin J. Bligh" <mbligh at mbligh dot org>, Christoph Hellwig <hch at infradead dot org>, Douglas Niehaus <niehaus at eecs dot ku dot edu>, Ingo Molnar <mingo at redhat dot com>, ltt-dev at shafik dot org, systemtap at sources dot redhat dot com, Thomas Gleixner <tglx at linutronix dot de>
- Date: Wed, 24 Jan 2007 12:55:57 -0500
- Subject: Re: [PATCH] minimize lockdep_on/off side-effect
- References: <20061220235216.GA28643@Krystal> <OFAB3D8A6C.1643F2D3-ON80257262.000581E4-80257262.00088F04@uk.ibm.com> <20070116175624.GA16022@Krystal> <20070123202637.970e467b.akpm@osdl.org> <20070124165150.GC4979@Krystal> <20070124172445.GA1145@Krystal>
Minimize lockdep_on/off side-effect on irq tracing in vprintk by using
raw_local_irq_save/restore _around_ lockdep_off/on().
It applies on the previous patch. It has the advantage of not losing the IRQ
events coming between the lockdep disabling and the irq disabling.
Signed-off-by: Mathieu Desnoyers <mathieu.desnoyers@polymtl.ca>
--- a/kernel/printk.c
+++ b/kernel/printk.c
@@ -530,8 +530,8 @@ asmlinkage int vprintk(const char *fmt, va_list args)
zap_locks();
/* This stops the holder of console_sem just where we want him */
+ raw_local_irq_save(flags);
lockdep_off();
- local_irq_save(flags);
spin_lock(&logbuf_lock);
printk_cpu = smp_processor_id();
@@ -640,8 +640,8 @@ asmlinkage int vprintk(const char *fmt, va_list args)
console_locked = 0;
up(&console_sem);
}
- local_irq_restore(flags);
lockdep_on();
+ raw_local_irq_restore(flags);
} else {
/*
* Someone else owns the drivers. We drop the spinlock, which
@@ -650,8 +650,8 @@ asmlinkage int vprintk(const char *fmt, va_list args)
*/
printk_cpu = UINT_MAX;
spin_unlock(&logbuf_lock);
- local_irq_restore(flags);
lockdep_on();
+ raw_local_irq_restore(flags);
}
preempt_enable();
--
OpenPGP public key: http://krystal.dyndns.org:8080/key/compudj.gpg
Key fingerprint: 8CD5 52C3 8E3C 4140 715F BA06 3F25 A8FE 3BAE 9A68