aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorRoel Kluin <roel.kluin@gmail.com>2009-05-22 04:46:52 -0400
committerLi Yang <leoli@freescale.com>2009-05-22 04:46:52 -0400
commitf47edc6dab11801c2e97088ba7bbce042ded867c (patch)
tree99de3f248d23b997813ba0da149359601ed281e1 /drivers
parent0899d6349c60e4021224b51c8c97f49b829dfefd (diff)
fsldma: fix check on potential fdev->chan[] overflow
Fix the check of potential array overflow when using corrupted channel device tree nodes. Signed-off-by: Roel Kluin <roel.kluin@gmail.com> Signed-off-by: Li Yang <leoli@freescale.com>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/dma/fsldma.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/dma/fsldma.c b/drivers/dma/fsldma.c
index da8a8ed9e411..391b1bd7098b 100644
--- a/drivers/dma/fsldma.c
+++ b/drivers/dma/fsldma.c
@@ -830,7 +830,7 @@ static int __devinit fsl_dma_chan_probe(struct fsl_dma_device *fdev,
830 new_fsl_chan->reg.end - new_fsl_chan->reg.start + 1); 830 new_fsl_chan->reg.end - new_fsl_chan->reg.start + 1);
831 831
832 new_fsl_chan->id = ((new_fsl_chan->reg.start - 0x100) & 0xfff) >> 7; 832 new_fsl_chan->id = ((new_fsl_chan->reg.start - 0x100) & 0xfff) >> 7;
833 if (new_fsl_chan->id > FSL_DMA_MAX_CHANS_PER_DEVICE) { 833 if (new_fsl_chan->id >= FSL_DMA_MAX_CHANS_PER_DEVICE) {
834 dev_err(fdev->dev, "There is no %d channel!\n", 834 dev_err(fdev->dev, "There is no %d channel!\n",
835 new_fsl_chan->id); 835 new_fsl_chan->id);
836 err = -EINVAL; 836 err = -EINVAL;