public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* PATCH: Pre UDMA EIDE PIO mode selection
@ 2006-01-09 17:14 Alan Cox
  2006-01-17 13:25 ` Jeff Garzik
  0 siblings, 1 reply; 2+ messages in thread
From: Alan Cox @ 2006-01-09 17:14 UTC (permalink / raw)
  To: linux-kernel, akpm, jgarzik

I misread the spec when doing the original. I've tested the corrected
version with pre UDMA drives and it now picks the right modes. This is a
specific bug fix rather than an update or new feature item.

Signed-off-by: Alan Cox <alan@redhat.com>

diff -u --new-file --recursive --exclude-from /usr/src/exclude linux.vanilla-2.6.15-mm2/drivers/scsi/libata-core.c linux-2.6.15-mm2/drivers/scsi/libata-core.c
--- linux.vanilla-2.6.15-mm2/drivers/scsi/libata-core.c	2006-01-09 14:33:45.000000000 +0000
+++ linux-2.6.15-mm2/drivers/scsi/libata-core.c	2006-01-09 15:19:14.000000000 +0000
@@ -1052,18 +1057,22 @@
 {
 	u16 modes;
 
-	/* Usual case. Word 53 indicates word 88 is valid */
-	if (adev->id[ATA_ID_FIELD_VALID] & (1 << 2)) {
+	/* Usual case. Word 53 indicates word 64 is valid */
+	if (adev->id[ATA_ID_FIELD_VALID] & (1 << 1)) {
 		modes = adev->id[ATA_ID_PIO_MODES] & 0x03;
 		modes <<= 3;
 		modes |= 0x7;
 		return modes;
 	}
 
-	/* If word 88 isn't valid then Word 51 holds the PIO timing number
-	   for the maximum. Turn it into a mask and return it */
-	modes = (2 << (adev->id[ATA_ID_OLD_PIO_MODES] & 0xFF)) - 1 ;
+	/* If word 64 isn't valid then Word 51 high byte holds the PIO timing
+	   number for the maximum. Turn it into a mask and return it */
+	modes = (2 << ((adev->id[ATA_ID_OLD_PIO_MODES] >> 8) & 0xFF)) - 1 ;
 	return modes;
+	/* But wait.. there's more. Design your standards by committee and
+	   you too can get a free iordy field to process. However its the 
+	   speeds not the modes that are supported... Note drivers using the
+	   timing API will get this right anyway */
 }
 
 struct ata_exec_internal_arg {


^ permalink raw reply	[flat|nested] 2+ messages in thread

* Re: PATCH: Pre UDMA EIDE PIO mode selection
  2006-01-09 17:14 PATCH: Pre UDMA EIDE PIO mode selection Alan Cox
@ 2006-01-17 13:25 ` Jeff Garzik
  0 siblings, 0 replies; 2+ messages in thread
From: Jeff Garzik @ 2006-01-17 13:25 UTC (permalink / raw)
  To: Alan Cox; +Cc: linux-kernel, akpm

Alan Cox wrote:
> I misread the spec when doing the original. I've tested the corrected
> version with pre UDMA drives and it now picks the right modes. This is a
> specific bug fix rather than an update or new feature item.
> 
> Signed-off-by: Alan Cox <alan@redhat.com>

applied to 'upstream'



^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2006-01-17 13:26 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2006-01-09 17:14 PATCH: Pre UDMA EIDE PIO mode selection Alan Cox
2006-01-17 13:25 ` Jeff Garzik

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox