Fix ali5451 dereferenced before NULL check

From: Eugene Teo
Date: Wed Mar 15 2006 - 20:36:12 EST


pvoice is missing a NULL check. channel needs a bound check too.

Coverity bug #862

Signed-off-by: Eugene Teo <eugene.teo@xxxxxxxxxxxxx>

--- linux-2.6/sound/pci/ali5451/ali5451.c~ 2006-03-15 10:05:45.000000000 +0800
+++ linux-2.6/sound/pci/ali5451/ali5451.c 2006-03-16 09:27:53.000000000 +0800
@@ -990,7 +990,13 @@
if (!(old & mask))
return;

+ if (channel < 0 || channel >= ALI_CHANNELS)
+ return;
+
pvoice = &codec->synth.voices[channel];
+ if (pvoice == NULL)
+ return;
+
runtime = pvoice->substream->runtime;

udelay(100);

--
1024D/A6D12F80 print D51D 2633 8DAC 04DB 7265 9BB8 5883 6DAA A6D1 2F80
main(i) { putchar(182623909 >> (i-1) * 5&31|!!(i<7)<<6) && main(++i); }

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/