bryce@cbmvax.UUCP (Bryce Nesbitt) (11/21/88)
Disk Drives - what YOU are doing wrong! --------------------------------------- by Bryce Nesbitt Copyright 1988 Commodore-Amiga, Inc. Originally from AmigaMail (tm) July/August 1988. Premission granted to reproduce provided this notice remains. Several of our third party hardware and software developers have been using the floppy disk drives in an incorrect manner. Remember, using the trackdisk.device is always the safest procedure. If for some reason you go directly to the hardware, or build hardware, then this article is for you. For Software Types: ------------------- This part is primarily directed at people who write custom boot-loaders for game software. Due to defective loaders, there are thousands of Amiga owners who can't load some games, and will NEVER BE ABLE TO BUY THEM. The ultimate source for information on drive timing comes from the manufacturer's specifications. This article simply highlights the most misused points. You would be wise to obtain a copy of a vendor specification for a floppy disk drive. Most large electronics distributors would be happy to send one to you. 1> Don't make bad assumptions. For example; if you depend on the motor being on, turn it on before use. Don't assume that your boot code will be entered with the disk drive or system in anyreliable state. 2> **NEVER** use a loop like this for timing: move.w #$1000,D0 busy_wait dbra d0,busy_wait This fails to produce accurate timing under a large number of circumstances. The speed of the above loop depends on what CPU is installed in the system, what video mode is selected, what type of memory the program is in, in what relation to vertical blank the code executes in, what the blitter is doing, what interrupts are enabled and more other factors than you want to think about. The 8520 chip provides fast, easy timing. See the companion article entitled "How to waste time". 3> The STEP line must be used as a low-going pulse. The direction must be set up FIRST, with a separate write to the register. A typical use would be: or.b #%00000010,$bfd100 ;Set up direction and.b #%11111110,$bfd100 ;Pulse low nop ;Wait a bit nop ; " " " or.b #%00000001,$bfd100 ;Set it high again ;-- now wait 3 miliseconds for the head to ;-- get to the next track We specify that our drives must get to the next track within 3 miliseconds. Some drives will step considerably faster, others will fail at or before 2.8 miliseconds. When the direction of step is changed, the settling time must also be added (a total minimum delay of 18 miliseconds). Note that the TRACK ZERO sensor will not be valid until the head actually reaches the track. 4> When turning on the motor, wait for the READY signal to go low before reading or writing (steps are ok before then). Note that READY is only valid when the motor signal is ON. 5> To determine if a disk is in the drive, look at the DISKCHANGE signal. If it is low, the disk has been removed (and possibly inserted again) since the last check. Step the head to reset the latch and examine the current state. 6> Some code uses an extra track or two for storage or copyprotection. We will not guarantee that our drives will have more than the normal 80 tracks. We will say that using one extra track is rather safe, two tracks is probably ok, and three tracks is a very bad idea. 7> After a disk write DMA has finished, a delay of 1.2 miliseconds is required before any other operations (drive select, step, head change, etc.). The type of disk drives we use have a gap between the erase head and the read-write head. The disk drive keeps the erase head enabled after the end of write gate to compensate for the gap. Failure wait out the delay may result in writing over innocent data on other tracks or sides. For Hardware Folks: ------------------- 1> The disk drive light should not flash on and off during access. Our drive activity light reflects the state of the motor. Typically the same signal is also connected to IN_USE (pin 4). 2> For compatibility with future systems, we require that drives refuse to step past track zero. That is, if the head is already at zero, and an outward step is received, it should not move the head. The drive must still reset it's DISKCHANGE latch, however. 3> The critical specifications for our 90mm (3.5") drives are: 3ms track-to-track. 15ms settling time. >80% radial alignment using a Dysan Alignment disk. 500ms motor spinup. 800ms maximum power on delay.