diff options
author | Alan Cox <alan@lxorguk.ukuu.org.uk> | 2006-09-12 11:55:12 -0400 |
---|---|---|
committer | Jeff Garzik <jeff@garzik.org> | 2006-09-19 01:58:00 -0400 |
commit | 93590859884784520a1850767f86296abc2cdc6d (patch) | |
tree | 7465312f962467d8af3b24dd0f7510ea7113e010 /drivers/ata/libata-core.c | |
parent | 4a3381feb823e06c8e2da7e283c17b0b6fdbddcf (diff) |
[PATCH] libata: improve handling of diagostic fail (and hardware that misreports it)
Our ATA probe code checks that a device is not reporting a diagnostic
failure during start up. Unfortunately at least one device seems to like
doing this - the Gigabyte iRAM.
This is only done for the master right now (which is fine for the iRAM
as it is SATA), as with PATA some combinations of ATAPI device seem to
fool the check into seeing a drive that isn't there if it is applied to
the slave.
Signed-off-by: Alan Cox <alan@redhat.com>
Signed-off-by: Jeff Garzik <jeff@garzik.org>
Diffstat (limited to 'drivers/ata/libata-core.c')
-rw-r--r-- | drivers/ata/libata-core.c | 19 |
1 files changed, 17 insertions, 2 deletions
diff --git a/drivers/ata/libata-core.c b/drivers/ata/libata-core.c index e85c2f8cf193..753b0152afd1 100644 --- a/drivers/ata/libata-core.c +++ b/drivers/ata/libata-core.c | |||
@@ -616,8 +616,11 @@ ata_dev_try_classify(struct ata_port *ap, unsigned int device, u8 *r_err) | |||
616 | if (r_err) | 616 | if (r_err) |
617 | *r_err = err; | 617 | *r_err = err; |
618 | 618 | ||
619 | /* see if device passed diags */ | 619 | /* see if device passed diags: if master then continue and warn later */ |
620 | if (err == 1) | 620 | if (err == 0 && device == 0) |
621 | /* diagnostic fail : do nothing _YET_ */ | ||
622 | ap->device[device].horkage |= ATA_HORKAGE_DIAGNOSTIC; | ||
623 | else if (err == 1) | ||
621 | /* do nothing */ ; | 624 | /* do nothing */ ; |
622 | else if ((device == 0) && (err == 0x81)) | 625 | else if ((device == 0) && (err == 0x81)) |
623 | /* do nothing */ ; | 626 | /* do nothing */ ; |
@@ -1523,6 +1526,18 @@ int ata_dev_configure(struct ata_device *dev, int print_info) | |||
1523 | cdb_intr_string); | 1526 | cdb_intr_string); |
1524 | } | 1527 | } |
1525 | 1528 | ||
1529 | if (dev->horkage & ATA_HORKAGE_DIAGNOSTIC) { | ||
1530 | /* Let the user know. We don't want to disallow opens for | ||
1531 | rescue purposes, or in case the vendor is just a blithering | ||
1532 | idiot */ | ||
1533 | if (print_info) { | ||
1534 | ata_dev_printk(dev, KERN_WARNING, | ||
1535 | "Drive reports diagnostics failure. This may indicate a drive\n"); | ||
1536 | ata_dev_printk(dev, KERN_WARNING, | ||
1537 | "fault or invalid emulation. Contact drive vendor for information.\n"); | ||
1538 | } | ||
1539 | } | ||
1540 | |||
1526 | ata_set_port_max_cmd_len(ap); | 1541 | ata_set_port_max_cmd_len(ap); |
1527 | 1542 | ||
1528 | /* limit bridge transfers to udma5, 200 sectors */ | 1543 | /* limit bridge transfers to udma5, 200 sectors */ |