* drivers/ide/pci/cs5535.c: array overrun
@ 2007-07-24 12:45 ` Adrian Bunk
2007-07-24 15:59 ` Jordan Crouse
0 siblings, 1 reply; 3+ messages in thread
From: Adrian Bunk @ 2007-07-24 12:45 UTC (permalink / raw)
To: bzolnier; +Cc: linux-ide, linux-kernel
The Coverity checker spotted the following array overrun in
drivers/ide/pci/cs5535.c:
<-- snip -->
...
static unsigned int cs5535_udma_timings[5] =
{ 0x7F7436A1, 0x7F733481, 0x7F723261, 0x7F713161, 0x7F703061 };
...
static void cs5535_set_speed(ide_drive_t *drive, u8 speed)
{
...
if (speed >= XFER_UDMA_0 && speed <= XFER_UDMA_7)
reg |= cs5535_udma_timings[speed - XFER_UDMA_0];
...
<-- snip -->
XFER_UDMA_7 - XFER_UDMA_0 = 7 > (5 - 1)
cu
Adrian
--
"Is there not promise of rain?" Ling Tan asked suddenly out
of the darkness. There had been need of rain for many days.
"Only a promise," Lao Er said.
Pearl S. Buck - Dragon Seed
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: drivers/ide/pci/cs5535.c: array overrun
2007-07-24 12:45 ` drivers/ide/pci/cs5535.c: array overrun Adrian Bunk
@ 2007-07-24 15:59 ` Jordan Crouse
2007-07-26 19:11 ` Bartlomiej Zolnierkiewicz
0 siblings, 1 reply; 3+ messages in thread
From: Jordan Crouse @ 2007-07-24 15:59 UTC (permalink / raw)
To: bunk; +Cc: bzolnier, linux-ide, linux-kernel
[-- Attachment #1: Type: text/plain, Size: 411 bytes --]
> The Coverity checker spotted the following array overrun in
> drivers/ide/pci/cs5535.c:
<-- snip -->
> if (speed >= XFER_UDMA_0 && speed <= XFER_UDMA_7)
> reg |= cs5535_udma_timings[speed - XFER_UDMA_0];
Fix is attached. Somebody got overzealous - the 5535 only supports
up to UDMA4, which matches the array.
Jordan
--
Jordan Crouse
Systems Software Development Engineer
Advanced Micro Devices, Inc.
[-- Attachment #2: 5535-fix-overrun.patch --]
[-- Type: text/x-diff, Size: 1024 bytes --]
[PATCH] Fix an ovverun found in the 5535 IDE driver
From: Jordan Crouse <jordan.crouse@amd.com>
As found by the Coverity checker, and reported by Adrian Bunk, this
fixes a overrun error in the 5535 IDE driver. Somebody got a little
excited with the if() statement - the 5535 only supports UDMA 0-4.
Signed-off-by: Jordan Crouse <jordan.crouse@amd.com>
---
drivers/ide/pci/cs5535.c | 2 +-
1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/drivers/ide/pci/cs5535.c b/drivers/ide/pci/cs5535.c
index ce44e38..9bd526d 100644
--- a/drivers/ide/pci/cs5535.c
+++ b/drivers/ide/pci/cs5535.c
@@ -116,7 +116,7 @@ static void cs5535_set_speed(ide_drive_t *drive, u8 speed)
reg &= 0x80000000UL; /* Preserve the PIO format bit */
- if (speed >= XFER_UDMA_0 && speed <= XFER_UDMA_7)
+ if (speed >= XFER_UDMA_0 && speed <= XFER_UDMA_4)
reg |= cs5535_udma_timings[speed - XFER_UDMA_0];
else if (speed >= XFER_MW_DMA_0 && speed <= XFER_MW_DMA_2)
reg |= cs5535_mwdma_timings[speed - XFER_MW_DMA_0];
^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: drivers/ide/pci/cs5535.c: array overrun
2007-07-24 15:59 ` Jordan Crouse
@ 2007-07-26 19:11 ` Bartlomiej Zolnierkiewicz
0 siblings, 0 replies; 3+ messages in thread
From: Bartlomiej Zolnierkiewicz @ 2007-07-26 19:11 UTC (permalink / raw)
To: Jordan Crouse; +Cc: bunk, linux-ide, linux-kernel
Hi,
On Tuesday 24 July 2007, Jordan Crouse wrote:
> > The Coverity checker spotted the following array overrun in
> > drivers/ide/pci/cs5535.c:
>
> <-- snip -->
>
> > if (speed >= XFER_UDMA_0 && speed <= XFER_UDMA_7)
> > reg |= cs5535_udma_timings[speed - XFER_UDMA_0];
Not a bug per se since the upper layer will never feed this function
with speed > XFER_UDMA_4 (thanks to ->ultra_mask being set to 0x1f).
Worth fixing anyway.
> Fix is attached. Somebody got overzealous - the 5535 only supports
> up to UDMA4, which matches the array.
applied, thanks
Bart
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2007-07-26 19:59 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <06FDA0246543E443ABBB36B1FCD5CC0603CF3360@SAUSEXMB2.amd.com>
2007-07-24 12:45 ` drivers/ide/pci/cs5535.c: array overrun Adrian Bunk
2007-07-24 15:59 ` Jordan Crouse
2007-07-26 19:11 ` Bartlomiej Zolnierkiewicz
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).