[dahdi-commits] sruffell: linux/trunk r10066 - /linux/trunk/drivers/dahdi/voicebus/voicebus.c

SVN commits to the DAHDI project dahdi-commits at lists.digium.com
Wed Jul 20 22:11:24 CDT 2011


Author: sruffell
Date: Wed Jul 20 22:11:20 2011
New Revision: 10066

URL: http://svnview.digium.com/svn/dahdi?view=rev&rev=10066
Log:
wctdm24xxp, wcte12xp: Run the ISR with interrupts disabled.

Revision 9886, "wcte12xp: Use the in-hardirq versions of
dahdi_receive/dahdi_transmit", changed the call into dahdi_receive and
dahdi_transmit to use versions that assume local interrupts are already
disabled.  Not all versions of the kernel run interrupt service routines with
all interrupts disabled and therefore it was possible to lock up a CPU with a
recursive grab of the chan_lock.

When LOCKDEP was enabled (on debug kernels) interrupt handlers were run
atomically so this problem would only occur on pre 2.6.35 kernels that did not
have lockdep enabled.

Signed-off-by: Shaun Ruffell <sruffell at digium.com>

Modified:
    linux/trunk/drivers/dahdi/voicebus/voicebus.c

Modified: linux/trunk/drivers/dahdi/voicebus/voicebus.c
URL: http://svnview.digium.com/svn/dahdi/linux/trunk/drivers/dahdi/voicebus/voicebus.c?view=diff&rev=10066&r1=10065&r2=10066
==============================================================================
--- linux/trunk/drivers/dahdi/voicebus/voicebus.c (original)
+++ linux/trunk/drivers/dahdi/voicebus/voicebus.c Wed Jul 20 22:11:20 2011
@@ -1881,7 +1881,7 @@
 		goto cleanup;
 
 #if !defined(CONFIG_VOICEBUS_TIMER)
-	retval = request_irq(vb->pdev->irq, vb_isr, DAHDI_IRQ_SHARED,
+	retval = request_irq(vb->pdev->irq, vb_isr, DAHDI_IRQ_SHARED_DISABLED,
 			     board_name, vb);
 	if (retval) {
 		dev_warn(&vb->pdev->dev, "Failed to request interrupt line.\n");




More information about the dahdi-commits mailing list