Code used for DEBUG_SHIRQ in free_irq() is unreachable -- the for() loop within never terminates otherwise than by return. This is an obvious fix. Signed-off-by: Maciej W. Rozycki <macro@linux-mips.org> --- Please apply. While at it, I have a question about the complementary code within request_irq(): when the option in question is enabled, a spurious IRQ is posted before internal setup is done by setup_irq(). This includes the ->depth counter. Now if the interrupt handler of some driver calls disable_irq_nosync(), then code in setup_irq() will mess up the state of ->depth afterwards if this is the first handler being installed (i.e. within the "if (!shared)" block). This is reported later on when enable_irq() called by the driver, by means of a message like this: Unbalanced enable for IRQ 34 WARNING: at kernel/irq/manage.c:158 enable_irq() Now given DEBUG_SHIRQ is a debug facility, not to be normally used for production, is the phenomenon as described considered a design limitation we can live with, or is it a bug that qualifies for a fix? I can reproduce this problem easily with phylib. Maciej patch-mips-2.6.23-rc5-20070904-debug-shirq-0 diff -up --recursive --new-file linux-mips-2.6.23-rc5-20070904.macro/kernel/irq/manage.c linux-mips-2.6.23-rc5-20070904/kernel/irq/manage.c --- linux-mips-2.6.23-rc5-20070904.macro/kernel/irq/manage.c 2007-09-04 04:56:21.000000000 +0000 +++ linux-mips-2.6.23-rc5-20070904/kernel/irq/manage.c 2007-09-11 23:58:59.000000000 +0000 @@ -448,7 +448,7 @@ void free_irq(unsigned int irq, void *de if (action->flags & IRQF_SHARED) handler = action->handler; kfree(action); - return; + break; } printk(KERN_ERR "Trying to free already-free IRQ %d\n", irq); spin_unlock_irqrestore(&desc->lock, flags); -
| Satyam Sharma | Re: 2.6.23-rc6-mm1 |
| Linus Torvalds | Linux 2.6.25-rc1 |
| Rafael J. Wysocki | [RFC][PATCH 0/3] PM: Rework suspend and hibernation code for devices (rev. 3) |
| Mark Weber | hdparm standby timeout not working for WD raptors? |
git: | |
| Martin Langhoff | Handling large files with GIT |
| Pierre Habouzit | [PATCH] git-revert is one of the most misunderstood command in git, help users out. |
| Junio C Hamano | Re: [PATCH 0/2] Making "git commit" to mean "git commit -a". |
| Shawn Pearce | Re: [RFC] Submodules in GIT |
| Marius ROMAN | 1440x900 resolution problem |
| GVG GVG | ssh_exchange_identification: Connection closed by remote host |
| Juan Miscaro | When will OpenBSD support UTF8? |
| Christophe Rioux | OpenBSD as host for VMWare Server |
| Matheos Worku | 2.6.24 BUG: soft lockup - CPU#X |
| Daniel J Blueman | [sky2, solved] transmit timeouts and firmware update... |
| Octavian Purdila | [RFC] support for IEEE 1588 |
| Evgeniy Polyakov | [resend take 2 0/4] Distributed storage. |
