From 9f8bda6ea643b10c5e35b2c3c8d0dc561f9573ff Mon Sep 17 00:00:00 2001 From: mattf Date: Thu, 16 Aug 2007 20:06:19 +0000 Subject: Merged revisions 2858 via svnmerge from https://origsvn.digium.com/svn/zaptel/branches/1.4 ................ r2858 | mattf | 2007-08-16 15:04:27 -0500 (Thu, 16 Aug 2007) | 9 lines Merged revisions 2857 via svnmerge from https://origsvn.digium.com/svn/zaptel/branches/1.2 ........ r2857 | mattf | 2007-08-16 15:02:58 -0500 (Thu, 16 Aug 2007) | 1 line Fix for when voicebus based cards stop taking interrupts on some systems ........ ................ git-svn-id: http://svn.digium.com/svn/zaptel/trunk@2859 5390a7c7-147a-4af0-8ec9-7488f05a26cb --- wctdm24xxp/base.c | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/wctdm24xxp/base.c b/wctdm24xxp/base.c index 086ebaa..e7537f1 100644 --- a/wctdm24xxp/base.c +++ b/wctdm24xxp/base.c @@ -1671,6 +1671,15 @@ ZAP_IRQ_HANDLER(wctdm_interrupt) wctdm_setctl(wc, 0x0008, 0x00000000); #endif } + + if (ints & 0x0000a3ae) { + /* This will allow us to recover if interrupts are held for a long period of time */ + if (debug & DEBUG_CARD) + printk("Abnormal interrupt %08x detected\n", ints); + wctdm_setctl(wc, 0x0008, 0x00000000); + wctdm_setctl(wc, 0x0010, 0x00000000); + } + #ifdef LINUX26 return IRQ_RETVAL(1); #endif @@ -3799,8 +3808,8 @@ static void wctdm_locate_modules(struct wctdm *wc) for (x=0;x<10;x++) schluffen(&wc->regq); printk("After resetting the modules...\n"); - /* Switch to caring only about receive interrupts */ - wctdm_setintmask(wc, 0x00010040); + + wctdm_setintmask(wc, 0x0001f7fe); /* Make sure all units go into daisy chain mode */ spin_lock_irqsave(&wc->reglock, flags); -- cgit v1.2.3