public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
From: Andrew Morton <akpm@osdl.org>
To: Sergei Shtylyov <sshtylyov@ru.mvista.com>
Cc: bzolnier@gmail.com, linux-ide@vger.kernel.org,
	linux-kernel@vger.kernel.org
Subject: Re: [PATCH] ide_dma_speed() fixes
Date: Mon, 15 May 2006 08:00:53 -0700	[thread overview]
Message-ID: <20060515080053.296c4c55.akpm@osdl.org> (raw)
In-Reply-To: <446885BE.4090404@ru.mvista.com>

Sergei Shtylyov <sshtylyov@ru.mvista.com> wrote:
>
> Hello.
> 
> Andrew Morton wrote:
> 
> >>    ide_dma_speed() fails to actually honor the IDE drivers' mode support 
> >> masks) because of the bogus checks -- thus, selecting the DMA transfer mode 
> >> that the driver explicitly refuses to support is possible. Additionally, there 
> >> is no check for validity of the UltraDMA mode data in the drive ID, and the 
> >> function is misdocumented.
> 
> > drivers/ide/ide-lib.c: In function `ide_dma_speed':
> > drivers/ide/ide-lib.c:86: warning: `ultra_mask' might be used uninitialized in this function
> 
> > Looks like a real bug to me - it depends up on the values of `mode' and
> > id->field_value.
> 
> > Anyway, I'll drop it, please review and fix.  I assume that warning was
> > occurring for you as well - please spend more time over these things. 
> > Especially when working on IDE, where bugs are slow to show themselves and
> > have particularly bad consequences.
> 
>     That's what gcc thinks. The code is 100% correct -- it will never reach 
> the switch statement with mode > 0 (in which case ultra_mask isn't used) and 
> ultra_mask unitialized.

hm, OK.

> I may add an explicit initializer in the declaration if you like...

Opinions vary.  I think that's less bad than spitting a warning at all
developers for all time.

But we can redo things like below and save a little code in the process. 
Look OK?

--- devel/drivers/ide/ide-lib.c~ide_dma_speed-fixes-warning-fix	2006-05-15 07:56:28.000000000 -0700
+++ devel-akpm/drivers/ide/ide-lib.c	2006-05-15 08:00:12.000000000 -0700
@@ -90,9 +90,9 @@ u8 ide_dma_speed(ide_drive_t *drive, u8 
 		return 0;
 
 	/* Capable of UltraDMA modes? */
-	if (id->field_valid & 4)
-		ultra_mask = id->dma_ultra & hwif->ultra_mask;
-	else
+	ultra_mask = id->dma_ultra & hwif->ultra_mask;
+
+	if (!(id->field_valid & 4))
 		mode = 0;	/* fallback to MW/SW DMA if no UltraDMA */
 
 	switch (mode) {
_


  parent reply	other threads:[~2006-05-15 15:04 UTC|newest]

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2006-05-12  2:36 [PATCH] ide_dma_speed() fixes Sergei Shtylyov
2006-05-14 12:05 ` Andrew Morton
2006-05-15 13:44   ` Sergei Shtylyov
2006-05-15 14:08     ` Alan Cox
2006-05-15 15:00     ` Andrew Morton [this message]
2006-05-15 15:27       ` Alan Cox

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20060515080053.296c4c55.akpm@osdl.org \
    --to=akpm@osdl.org \
    --cc=bzolnier@gmail.com \
    --cc=linux-ide@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=sshtylyov@ru.mvista.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox