aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/ide/ide-io.c23
-rw-r--r--drivers/ide/ide-iops.c25
-rw-r--r--include/linux/ide.h2
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
890static 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
439EXPORT_SYMBOL(ide_fixstring); 439EXPORT_SYMBOL(ide_fixstring);
440 440
441int 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
464EXPORT_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);
1200u8 ide_read_error(ide_drive_t *); 1200u8 ide_read_error(ide_drive_t *);
1201void ide_read_bcount_and_ireason(ide_drive_t *, u16 *, u8 *); 1201void ide_read_bcount_and_ireason(ide_drive_t *, u16 *, u8 *);
1202 1202
1203extern int drive_is_ready(ide_drive_t *);
1204
1205int ide_check_atapi_device(ide_drive_t *, const char *); 1203int ide_check_atapi_device(ide_drive_t *, const char *);
1206 1204
1207void ide_init_pc(struct ide_atapi_pc *); 1205void ide_init_pc(struct ide_atapi_pc *);