aboutsummaryrefslogtreecommitdiff
path: root/sys/i386/isa/atapi.c
diff options
context:
space:
mode:
authorMike Smith <msmith@FreeBSD.org>1998-01-27 16:45:23 +0000
committerMike Smith <msmith@FreeBSD.org>1998-01-27 16:45:23 +0000
commitfacf6a3fbe87c0b86aea25f98c9ea9dab3b9460b (patch)
tree50782b2b8554ffdf888eceeeb14a7025b105e9ff /sys/i386/isa/atapi.c
parent3bbee664ba02e1a1cc53f39d3e768e3ac318f3c5 (diff)
Check the status port after waiting for DRQ; some drives seem to be very
slow coming off the bus (eg. Iomega's ATAPI Zip). Failure to do this results in a false probe of an ATAPI device with garbage data.
Notes
Notes: svn path=/head/; revision=32825
Diffstat (limited to 'sys/i386/isa/atapi.c')
-rw-r--r--sys/i386/isa/atapi.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/sys/i386/isa/atapi.c b/sys/i386/isa/atapi.c
index 56fbbfbaf43b..09439cb5ae2e 100644
--- a/sys/i386/isa/atapi.c
+++ b/sys/i386/isa/atapi.c
@@ -422,6 +422,15 @@ static struct atapi_params *atapi_probe (int port, int unit)
return (0);
}
+ /* check that DRQ isn't a fake */
+ if (inb (port + AR_STATUS) == 0xff) {
+ print (("atapiX.%d at 0x%x: no device\n", unit, port));
+ if (unit == 1)
+ /* Select unit 0. */
+ outb (port + AR_DRIVE, ARD_DRIVE0);
+ return (0);
+ }
+
/* Obtain parameters. */
insw (port + AR_DATA, tb, sizeof(tb) / sizeof(short));