diff options
author | Alan Cox <alan@lxorguk.ukuu.org.uk> | 2007-03-08 18:22:59 -0500 |
---|---|---|
committer | Jeff Garzik <jeff@garzik.org> | 2007-04-28 14:15:58 -0400 |
commit | 432729f0b0c299ae9731aaa31beaa0dd3a9751eb (patch) | |
tree | 39a9cc9762136e2f049b6081637b6daf5fa1e882 | |
parent | 04351821b43e6c0c91ad50d7e4be54a935f749e1 (diff) |
libata-core: Fix the iordy methods
This alone isn't sufficient to save the universe from prehistoric disks
and controllers but it is a first important step. Split off a separate
function to provide a mode filter when controller iordy is not available.
Signed-off-by: Alan Cox <alan@redhat.com>
Signed-off-by: Jeff Garzik <jeff@garzik.org>
-rw-r--r-- | drivers/ata/libata-core.c | 36 |
1 files changed, 25 insertions, 11 deletions
diff --git a/drivers/ata/libata-core.c b/drivers/ata/libata-core.c index 14b469f7b23e..d01bb5d50fcc 100644 --- a/drivers/ata/libata-core.c +++ b/drivers/ata/libata-core.c | |||
@@ -1379,30 +1379,44 @@ unsigned int ata_do_simple_cmd(struct ata_device *dev, u8 cmd) | |||
1379 | * Check if the current speed of the device requires IORDY. Used | 1379 | * Check if the current speed of the device requires IORDY. Used |
1380 | * by various controllers for chip configuration. | 1380 | * by various controllers for chip configuration. |
1381 | */ | 1381 | */ |
1382 | 1382 | ||
1383 | unsigned int ata_pio_need_iordy(const struct ata_device *adev) | 1383 | unsigned int ata_pio_need_iordy(const struct ata_device *adev) |
1384 | { | 1384 | { |
1385 | int pio; | 1385 | /* Controller doesn't support IORDY. Probably a pointless check |
1386 | int speed = adev->pio_mode - XFER_PIO_0; | 1386 | as the caller should know this */ |
1387 | 1387 | if (adev->ap->flags & ATA_FLAG_NO_IORDY) | |
1388 | if (speed < 2) | ||
1389 | return 0; | 1388 | return 0; |
1390 | if (speed > 2) | 1389 | /* PIO3 and higher it is mandatory */ |
1390 | if (adev->pio_mode > XFER_PIO_2) | ||
1391 | return 1; | 1391 | return 1; |
1392 | /* We turn it on when possible */ | ||
1393 | if (ata_id_has_iordy(adev->id)) | ||
1394 | return 1; | ||
1395 | return 0; | ||
1396 | } | ||
1392 | 1397 | ||
1398 | /** | ||
1399 | * ata_pio_mask_no_iordy - Return the non IORDY mask | ||
1400 | * @adev: ATA device | ||
1401 | * | ||
1402 | * Compute the highest mode possible if we are not using iordy. Return | ||
1403 | * -1 if no iordy mode is available. | ||
1404 | */ | ||
1405 | |||
1406 | static u32 ata_pio_mask_no_iordy(const struct ata_device *adev) | ||
1407 | { | ||
1393 | /* If we have no drive specific rule, then PIO 2 is non IORDY */ | 1408 | /* If we have no drive specific rule, then PIO 2 is non IORDY */ |
1394 | |||
1395 | if (adev->id[ATA_ID_FIELD_VALID] & 2) { /* EIDE */ | 1409 | if (adev->id[ATA_ID_FIELD_VALID] & 2) { /* EIDE */ |
1396 | pio = adev->id[ATA_ID_EIDE_PIO]; | 1410 | u16 pio = adev->id[ATA_ID_EIDE_PIO]; |
1397 | /* Is the speed faster than the drive allows non IORDY ? */ | 1411 | /* Is the speed faster than the drive allows non IORDY ? */ |
1398 | if (pio) { | 1412 | if (pio) { |
1399 | /* This is cycle times not frequency - watch the logic! */ | 1413 | /* This is cycle times not frequency - watch the logic! */ |
1400 | if (pio > 240) /* PIO2 is 240nS per cycle */ | 1414 | if (pio > 240) /* PIO2 is 240nS per cycle */ |
1401 | return 1; | 1415 | return 3 << ATA_SHIFT_PIO; |
1402 | return 0; | 1416 | return 7 << ATA_SHIFT_PIO; |
1403 | } | 1417 | } |
1404 | } | 1418 | } |
1405 | return 0; | 1419 | return 3 << ATA_SHIFT_PIO; |
1406 | } | 1420 | } |
1407 | 1421 | ||
1408 | /** | 1422 | /** |