sh: Make sure indexes are positive
authorRoel Kluin <roel.kluin@gmail.com>
Mon, 2 Nov 2009 16:14:42 +0000 (16:14 +0000)
committerPaul Mundt <lethal@linux-sh.org>
Wed, 4 Nov 2009 02:48:07 +0000 (11:48 +0900)
The indexes are signed, make sure they are not negative
when we read array elements.

Signed-off-by: Roel Kluin <roel.kluin@gmail.com>
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
arch/sh/boards/mach-highlander/setup.c
arch/sh/boards/mach-r2d/irq.c
arch/sh/mm/numa.c

index 566e69d..f663c14 100644 (file)
@@ -384,7 +384,7 @@ static unsigned char irl2irq[HL_NR_IRL];
 
 static int highlander_irq_demux(int irq)
 {
-       if (irq >= HL_NR_IRL || !irl2irq[irq])
+       if (irq >= HL_NR_IRL || irq < 0 || !irl2irq[irq])
                return irq;
 
        return irl2irq[irq];
index c70fece..78d7b27 100644 (file)
@@ -116,7 +116,7 @@ static unsigned char irl2irq[R2D_NR_IRL];
 
 int rts7751r2d_irq_demux(int irq)
 {
-       if (irq >= R2D_NR_IRL || !irl2irq[irq])
+       if (irq >= R2D_NR_IRL || irq < 0 || !irl2irq[irq])
                return irq;
 
        return irl2irq[irq];
index 9b784fd..6c52444 100644 (file)
@@ -60,7 +60,7 @@ void __init setup_bootmem_node(int nid, unsigned long start, unsigned long end)
        unsigned long bootmem_paddr;
 
        /* Don't allow bogus node assignment */
-       BUG_ON(nid > MAX_NUMNODES || nid == 0);
+       BUG_ON(nid > MAX_NUMNODES || nid <= 0);
 
        start_pfn = start >> PAGE_SHIFT;
        end_pfn = end >> PAGE_SHIFT;