From: KOSAKI Motohiro Date: Sat, 3 Jan 2009 18:11:05 +0000 (+0900) Subject: sparseirq: make for_each_irq_desc() more robust X-Git-Tag: v2.6.30-rc1~3^2~10^3~11 X-Git-Url: http://ftp.safe.ca/?a=commitdiff_plain;h=01d07820a0df6b6134c1bb75b1e84c9d0cdab3be;p=safe%2Fjmp%2Flinux-2.6 sparseirq: make for_each_irq_desc() more robust Raja reported for_each_irq_desc() has possibility unsafeness: if anyone write folliwing code, for_each_irq_desc() doesn't work as intended: (right now this code does not exist at all) if (safe) for_each_irq_desc(irq, desc) { ... } else panic(); Reported-by: Raja R Harinath Signed-off-by: KOSAKI Motohiro Signed-off-by: Ingo Molnar --- diff --git a/include/linux/irqnr.h b/include/linux/irqnr.h index 86af92e..52ebbb4 100644 --- a/include/linux/irqnr.h +++ b/include/linux/irqnr.h @@ -28,13 +28,17 @@ extern struct irq_desc *irq_to_desc(unsigned int irq); # define for_each_irq_desc(irq, desc) \ for (irq = 0, desc = irq_to_desc(irq); irq < nr_irqs; \ irq++, desc = irq_to_desc(irq)) \ - if (desc) + if (!desc) \ + ; \ + else # define for_each_irq_desc_reverse(irq, desc) \ for (irq = nr_irqs - 1, desc = irq_to_desc(irq); irq >= 0; \ irq--, desc = irq_to_desc(irq)) \ - if (desc) + if (!desc) \ + ; \ + else #endif /* CONFIG_GENERIC_HARDIRQS */