ref: 1664c8fbd8d855224d5539213d9fb1709c23322f
parent: 19d1bfd5224e47048f53b0ccbfc6824f8a15dd8a
author: cinap_lenrek <cinap_lenrek@gmx.de>
date: Wed Apr 18 12:49:27 EDT 2012
sdide: make ataidentify wait longer if theres no floating bus
--- a/sys/src/9/pc/sdide.c
+++ b/sys/src/9/pc/sdide.c
@@ -549,7 +549,7 @@
static int
ataidentify(Ctlr*, int cmdport, int ctlport, int dev, int pkt, void* info)
{- int as, command, drdy;
+ int as, command, drdy, rlo, rhi;
if(pkt){command = Cidpkt;
@@ -561,8 +561,21 @@
}
dev &= ~Lba;
as = ataready(cmdport, ctlport, dev, Bsy|Drq, drdy, 103*1000);
- if(as < 0)
- return as;
+ if(as < 0){+ /* try to detect floating bus */
+ outb(cmdport+Cyllo, 0xAA);
+ outb(cmdport+Cylhi, 0x55);
+ outb(cmdport+Sector, 0xFF);
+ rlo = inb(cmdport+Cyllo);
+ rhi = inb(cmdport+Cylhi);
+ if(rlo != 0xAA && (rlo == 0xFF || rhi != 0x55))
+ return as;
+
+ /* theres a device, try waiting some more */
+ as = ataready(cmdport, ctlport, dev, Bsy|Drq, drdy, 6*1000*1000);
+ if(as < 0)
+ return as;
+ }
outb(cmdport+Command, command);
microdelay(1);
--
⑨