diff options
-rw-r--r-- | drivers/ide/ide-io.c | 23 | ||||
-rw-r--r-- | drivers/ide/ide-iops.c | 25 | ||||
-rw-r--r-- | include/linux/ide.h | 2 |
3 files changed, 23 insertions, 27 deletions
diff --git a/drivers/ide/ide-io.c b/drivers/ide/ide-io.c index d90cf5d08142..835cf646bb07 100644 --- a/drivers/ide/ide-io.c +++ b/drivers/ide/ide-io.c | |||
@@ -887,6 +887,29 @@ static void ide_plug_device(ide_drive_t *drive) | |||
887 | spin_unlock_irqrestore(q->queue_lock, flags); | 887 | spin_unlock_irqrestore(q->queue_lock, flags); |
888 | } | 888 | } |
889 | 889 | ||
890 | static int drive_is_ready(ide_drive_t *drive) | ||
891 | { | ||
892 | ide_hwif_t *hwif = drive->hwif; | ||
893 | u8 stat = 0; | ||
894 | |||
895 | if (drive->waiting_for_dma) | ||
896 | return hwif->dma_ops->dma_test_irq(drive); | ||
897 | |||
898 | if (hwif->io_ports.ctl_addr && | ||
899 | (hwif->host_flags & IDE_HFLAG_BROKEN_ALTSTATUS) == 0) | ||
900 | stat = hwif->tp_ops->read_altstatus(hwif); | ||
901 | else | ||
902 | /* Note: this may clear a pending IRQ!! */ | ||
903 | stat = hwif->tp_ops->read_status(hwif); | ||
904 | |||
905 | if (stat & ATA_BUSY) | ||
906 | /* drive busy: definitely not interrupting */ | ||
907 | return 0; | ||
908 | |||
909 | /* drive ready: *might* be interrupting */ | ||
910 | return 1; | ||
911 | } | ||
912 | |||
890 | /** | 913 | /** |
891 | * ide_timer_expiry - handle lack of an IDE interrupt | 914 | * ide_timer_expiry - handle lack of an IDE interrupt |
892 | * @data: timer callback magic (hwif) | 915 | * @data: timer callback magic (hwif) |
diff --git a/drivers/ide/ide-iops.c b/drivers/ide/ide-iops.c index cd1f2e464c4b..ee9c60342787 100644 --- a/drivers/ide/ide-iops.c +++ b/drivers/ide/ide-iops.c | |||
@@ -438,31 +438,6 @@ void ide_fixstring (u8 *s, const int bytecount, const int byteswap) | |||
438 | 438 | ||
439 | EXPORT_SYMBOL(ide_fixstring); | 439 | EXPORT_SYMBOL(ide_fixstring); |
440 | 440 | ||
441 | int drive_is_ready (ide_drive_t *drive) | ||
442 | { | ||
443 | ide_hwif_t *hwif = drive->hwif; | ||
444 | u8 stat = 0; | ||
445 | |||
446 | if (drive->waiting_for_dma) | ||
447 | return hwif->dma_ops->dma_test_irq(drive); | ||
448 | |||
449 | if (hwif->io_ports.ctl_addr && | ||
450 | (hwif->host_flags & IDE_HFLAG_BROKEN_ALTSTATUS) == 0) | ||
451 | stat = hwif->tp_ops->read_altstatus(hwif); | ||
452 | else | ||
453 | /* Note: this may clear a pending IRQ!! */ | ||
454 | stat = hwif->tp_ops->read_status(hwif); | ||
455 | |||
456 | if (stat & ATA_BUSY) | ||
457 | /* drive busy: definitely not interrupting */ | ||
458 | return 0; | ||
459 | |||
460 | /* drive ready: *might* be interrupting */ | ||
461 | return 1; | ||
462 | } | ||
463 | |||
464 | EXPORT_SYMBOL(drive_is_ready); | ||
465 | |||
466 | /* | 441 | /* |
467 | * This routine busy-waits for the drive status to be not "busy". | 442 | * This routine busy-waits for the drive status to be not "busy". |
468 | * It then checks the status for all of the "good" bits and none | 443 | * It then checks the status for all of the "good" bits and none |
diff --git a/include/linux/ide.h b/include/linux/ide.h index 6bb104f4e341..2e95adeedff4 100644 --- a/include/linux/ide.h +++ b/include/linux/ide.h | |||
@@ -1200,8 +1200,6 @@ void SELECT_MASK(ide_drive_t *, int); | |||
1200 | u8 ide_read_error(ide_drive_t *); | 1200 | u8 ide_read_error(ide_drive_t *); |
1201 | void ide_read_bcount_and_ireason(ide_drive_t *, u16 *, u8 *); | 1201 | void ide_read_bcount_and_ireason(ide_drive_t *, u16 *, u8 *); |
1202 | 1202 | ||
1203 | extern int drive_is_ready(ide_drive_t *); | ||
1204 | |||
1205 | int ide_check_atapi_device(ide_drive_t *, const char *); | 1203 | int ide_check_atapi_device(ide_drive_t *, const char *); |
1206 | 1204 | ||
1207 | void ide_init_pc(struct ide_atapi_pc *); | 1205 | void ide_init_pc(struct ide_atapi_pc *); |