IDE knowledge anyone?
Oliver Lehmann
lehmann at ans-netz.de
Wed Dec 30 13:01:58 CST 2015
I checked now with MS-DOS and issuing a simple "DIR D:\" command with
a power cycled disk:
Command: C4h (Read Multiple)
-> 51h, 51h -> 04h
Command: 10h (Obsolete???)
-> 50h, 50h -> 04h
Command: 91h (Initialize Drive Parameters)
-> d0h, d0h, d0h, .... 50h
Command: C6h (Set Multiple Mode)
-> 50h
Command: C4h (Read Multiple)
-> 58h
The first C4h Command returns the same error, but
after this it seems like the drive is "initialized"
and then the 2nd C4 command afterwards works! Great.
I guess C6h is only needed because read multiple is
used, so I probably have to do only the 10h and
91h stuff... just need to find out more about it.
Does anyone know what command 10h is? The documentation
I have only states "obsolete".
Oliver Lehmann <lehmann at ans-netz.de> wrote:
> OK,
>
> detatching the power cord of the disk from my PC while
> running FreeBSD and reattaching it also brings up error
> code 4 on the next access. This does not happen with
> other drives. So it must be some sort of initialisation
> the OS or BIOS does which readies up the drive.
>
>
> Oliver Lehmann <lehmann at ans-netz.de> wrote:
>
>> OK, I just got my Logic Analysator and traced the
>> communication on my PC while forcing it to do PIO
>> instead of DMA.
>> I then changed my AVR code to do the exact same
>> commands and nearly the same timings and... nothing
>> changed - the drive still responds with error code
>> 0x04 after the read sector 0x20 command is issued.
>>
>> On the PC:
>> I noticed a time frame of 115,230ns between the
>> 0x20 Command and the first alternate status register
>> read. during that time, INTRQ goes high so the drive
>> "is done" and wants the host to interact with it
>> again. IORDY is the whole time high from the host.
>> The status read is 0x58 on the PC.
>>
>> On the AVR:
>> IORDY is the whole time low (it is not connected),
>> INTRQ stays low the whole time, and the first status
>> read back is 0xD0 for a long time and then it goes to
>> 0xD1 and then 0x59.
>>
>> Things I plan to try next:
>>
>> - power down the drive on the pc, power it up and then
>> try to access sector 1 again and see what happens.
>> Maybe some magic "initialization" is done on bootup
>> what I don't do.
>> - make IORDY high on my AVR too
More information about the cctalk
mailing list