# UMC

T-52-33-61

**UM8388** 

# Single-Chip Floppy Disk Controller



PRELIMINARY

#### **Features**

- IBM PC XT/AT drive system compatible
- Supports 2 drives (MS-DOS support)
- 1.44M/1.2M/360K/720K format selectable
- IBM PC drive system address decoder
- Only 4 components needed for the drive
- Internal write precompensation circuit; precompensation values: 250-125 ns
- Internal data separator circuit
- Supports 8", 5¼", and 3½" drives

#### **General Description**

The UM8388 is a VLSI Floppy Disk Controller (FDC) chip, which contains the circuitry and control functions for interfacing a processor with up to 2 floppy disk drives. It is capable of supporting 360K Bytes, 1,2M Bytes (in 5%" diskette drives), 720K Bytes, and 1,44M Bytes, (in 3%" diskette drives) FDDs using MFM coded, and double sided recording. UM8388 includes an internal data separator, write precompensation, circuit address decoder, timing control and other control logics. It simplifies design of a diskette drive system and only 4 components are needed in the IBM PC/AT drive system.

Handshaking signals are provided in UM8388 which

makes DMA operation easy to incorporate with the aid of an external DMA control chip. The FDC will operate in either the DMA or Non-DMA mode. In the Non-DMA mode, the FDC generates interrupts to the processor every time a data byte is available. In the DMA mode, the processor needs only to load the command into the FDC and all data transfers occur under control of the UM8388 and DMA controller.

Many diskette drive parameters are programmable and a write-protection feature is supported. One interrupt level is used to indicate when an operation is completed, or a status condition requires the microprocessor's attention.

# Storage

#### Pin Configurations



#### **Block Diagram**





**UM8388** 







4-102







#### **Absolute Maximum Ratings\***

# 

#### \*Comments

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only. Functional operation of this device at these or any other conditions above those indicated in the operational sections of this specification is not implied and exposure to absolute maximum rating conditions for extended periods may affect device reliability.

#### DC Electrical Characteristics

 $(T_A = 0^{\circ}C \text{ to } +70^{\circ}C, V_{CC} = +5V \pm 5\%).$ 

| 0                                 | Danas                          | Limits |                 | Unit | Test Conditions                         |
|-----------------------------------|--------------------------------|--------|-----------------|------|-----------------------------------------|
| Symbol                            | Parameters                     | Min.   | Max.            | Oiii | 1 63 CONDITIONS                         |
| V <sub>IL</sub>                   | Input low voltage              |        | 0,8             | V    |                                         |
| V <sub>IH</sub>                   | Input high voltage             | 2,0    |                 | V    |                                         |
| V <sub>OL</sub>                   |                                |        | 0.4             | V    | I <sub>OL</sub> = 8.0 mA                |
| V <sub>OH</sub>                   |                                |        | V <sub>cc</sub> | V    | I <sub>OH</sub> = 4.0 mA                |
| Icc                               | V <sub>CC</sub> supply current |        | 200             | mA   |                                         |
| IIL                               | Input leakage current          |        | 10              | μΑ   | 0 ≤ V <sub>0</sub> ≤ V <sub>CC</sub>    |
| High level output leakage current |                                | •      | 10              | μΑ   | V <sub>O</sub> = V <sub>CC</sub>        |
| Output float leakage current      |                                |        | 10              | μΑ   | 0.4V ≤ V <sub>O</sub> ≤ V <sub>CC</sub> |

## A.C. Characteristics ( $T_A = 0^{\circ}C$ to $+70^{\circ}C$ , $V_{CC} = +5.0V \pm 10\%$ ) PROCESSOR WRITE CYCLE

| Symbol            | Parameter                         | Min.   | Max.    |
|-------------------|-----------------------------------|--------|---------|
| t <sub>AW</sub>   | address setup to <del>IOW</del> ↓ | 10 ns  |         |
| t <sub>WA</sub>   | address hold from IOW †           | 5 ns   |         |
| tww               | 10W pulse width                   | 250 ns |         |
| t <sub>DW</sub>   | data setup to IOW 1               | 150 ns |         |
| t <sub>WD</sub> . | data hold from IOW 1              | 10 ns  | •       |
| t <sub>WI</sub>   | IRQ delay from IOW 1              |        | 500 ns* |

#### PROCESSOR READ CYCLE

| Symbol          | Parameter                        | Min.   | Max.    |
|-----------------|----------------------------------|--------|---------|
| t <sub>AR</sub> | address setup to IOR ↓           | 10 ns  |         |
| t <sub>RA</sub> | address hold from IOR 1          | 5 ns   |         |
| t <sub>RR</sub> | IOR pulse width                  | 250 ns | •       |
| t <sub>RD</sub> | data delay from <del>IOR</del> ↓ |        | 230 ns  |
| t <sub>DF</sub> | output floating delay from IOR 1 | 10 ns  | 30 ns   |
| t <sub>RI</sub> | IRQ delay fro IOR ↑              |        | 500 ns* |

Note: \*: The values are for 8 MHz clock rate, multiply timings by 2/1.67 when using 4/4.8 MHz clock rates.





T-52-33-61

#### **DMA OPERATION\***

| Symbol            | Parameter              | Min.   | Max.   |
|-------------------|------------------------|--------|--------|
| t <sub>ROCY</sub> | DRQ cycle period       | 13 µs  |        |
| <sup>†</sup> AKRO | DACK ↓ to DRQ ↓        |        | 200 ns |
| t <sub>ROR</sub>  | DRQ↑ to lOR ↓          | 800 ns |        |
| t <sub>ROW</sub>  | DRQ ↑ to JOW ↓         | 250 ns |        |
| tronw             | DRQ1 to IOR 1 or IOW 1 |        | 12 µs  |

## Terminal Count, Reset, Index

| Symbol           | bol Parameter Min.   |                   | Тур.                 | Max. |
|------------------|----------------------|-------------------|----------------------|------|
| t <sub>IDX</sub> | index pulse width    |                   | 10t <sub>CY</sub> ** |      |
| t <sub>TC</sub>  | terminal count width | 1t <sub>CY</sub>  |                      |      |
| t <sub>RST</sub> | reset width          | 14t <sub>CY</sub> |                      |      |

#### Notes:

#### FDD INTERFACE

| Symbol                                       | Parameter             | Parameter Min. |                 | Max. |  |
|----------------------------------------------|-----------------------|----------------|-----------------|------|--|
| twop                                         | write data width      |                | 125/208/250 ns* |      |  |
| twcy                                         | write data cycle time |                | 1/1.67/2 μs*    |      |  |
| t <sub>RDD</sub> read data active time (low) |                       | 40 ns          | 125/208/250 ns* |      |  |
| t <sub>RCY</sub> read data cycle time        |                       |                | 1/1.67/2 μs*    |      |  |

#### **SEEK OPERATION\*\*\***

| Symbol                                | Parameter       | Min,  | Тур,          | Max. |  |
|---------------------------------------|-----------------|-------|---------------|------|--|
| t <sub>STP</sub> step active time     |                 | •     | 5. <b>μ</b> s |      |  |
| t <sub>SC</sub>                       | step cycle time | 33 μs |               |      |  |
| t <sub>DST</sub> DIR setup to step †  |                 | 1 μs  |               |      |  |
| t <sub>STD</sub> DIR hold from step ↓ |                 | 24 μs |               |      |  |

#### Notes:

<sup>\*:</sup> The values listed for DMA operation are for 8 MHz clock rate, multiply timings by 2/1.67 when using 4/4.8 MHz clock rates,

<sup>\*\*:</sup> tCY is the clock rate of Drive System,

<sup>\* :</sup> The specified values are for 8/4.8/4 MHz respectively.

<sup>\*\*\*:</sup> The values listed for seek operation are for 8 MHz clock period, multiply timings by 2/1.67 when using 4/4,8 MHz clock rates.



UM8388





**Processor Write Operation** 



**DMA Operation** 



Terminal Count, Reset, Index





FDD Write/Read Operation



Seek Operation





T-52-33-61 UM8388 - 200

# Pin Description

| Pin   | Symbol                | 1/0 | Description                                                                                                                                                        |  |  |
|-------|-----------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 1     | V <sub>cc</sub>       | 1   | Power supply, connected to +5V power supply.                                                                                                                       |  |  |
| 2~9   | D7 ~ D0               | 1/0 | Bi-directional — 8-bit data bus                                                                                                                                    |  |  |
| 10    | AEN                   |     | Input from DMA — Address Enable. When this line is active (low) the DMA controller has control of the address bus,                                                 |  |  |
| 11~20 | A9 ~ A0               | -   | Input from processor — 10-bit Address Bus.                                                                                                                         |  |  |
| 21    | RESET                 | ı   | Input from processor — places FDC in idle state. Resets output lines to FDD to "0" (low). Does not affect SRT, HUT or HLT in Specify command.                      |  |  |
| 22    | DRQ                   | 0   | Output to DMA DMA Request is being made by FDC when DRQ = "1".                                                                                                     |  |  |
| 23    | IOW .                 | 1   | Input from processor — Control signal for transfer of data to FDC via Data Bus, when "0".                                                                          |  |  |
| 24    | ior'                  | ı   | Input from processor — Control signal for transfer of data from FDC to Data Bus, when "0".                                                                         |  |  |
| 25    | GND                   | 1   | Ground, Normally connected to +0V ground                                                                                                                           |  |  |
| 26    | IRQ                   | 0   | Output to processor — Interrupt request generated by FDC,                                                                                                          |  |  |
| 27    | DACK                  | I   | Input from DMA — DMA cycle is active when "0" (low) and controller is performing DMA transfer.                                                                     |  |  |
| 28    | тс                    | 1   | Input from DMA — Indicates the termination of a DMA transfer when "1" (high). It terminates data transfer during Read/Write/Scan command in DMA or interrupt mode. |  |  |
| 29    | DRIVE GROUP<br>SELECT | J   | The primary address will be applied when this signal is active high (3FX) The secondary address will be applied when this signal is low (37X)                      |  |  |
| 30    | GATE 245              | 0   | Output low to enable the extra 74LS245 Buffer on data bus.                                                                                                         |  |  |
| 31    | DRIVER TYPE           | 0   | Output low to enable the extra disk drive type port. It's address is 3F1.                                                                                          |  |  |
| 32    | HDC                   | ı   | Set this input to low, when your system has a hard disk control card. Otherwise, set this input to high.                                                           |  |  |
| 33    | CLOCK IN              | ı   | 24 MHz clock input.                                                                                                                                                |  |  |
| 34    | DISKETTE<br>CHANGE    | l   | Input from FDD — This input is high when a diskette is present again and a step pulse is issued from FDC.                                                          |  |  |







# Pin Description (Continued)

| Pin | Symbol              | 1/0 | Description                                                                                                                                                                                                                                                 |
|-----|---------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 35  | SIDE 1 SELECT       | 0   | Output to FDD — This output is active (high) for the upper head. Otherwise, the lower head is selected.                                                                                                                                                     |
| 36  | READ DATA           |     | Input from FDD — Each bit detected provides a 250 ns (4 MHz), 208 ns (4.8 MHz), 125 ns (8 MHz) active (low) pulse on this line.                                                                                                                             |
| 37  | WRITE PROTECT       | ì   | Input from FDD — This input is active low when a diskette with a write protect notch is inserted.                                                                                                                                                           |
| 38  | TRACK 00            | 1   | Input from FDD — This signal is low when the upper head is on Track 00 (the outermost track).                                                                                                                                                               |
| 39  | WRITE GATE          | 0   | Output to FDD — An active high level of this output enables the write current circuits, and the Write Data output controls the writing of information.                                                                                                      |
| 40  | WRITE DATA          | 0   | Output to FDD — A 125 ns (8 MHz), 208 ns (4.8 MHz), 250 ns (4 MHz) pulse on this output causes a bit to be written on the disk if Write Gate is active.                                                                                                     |
| 41  | STEP                | 0   | Output to FDD — An active high pulse causes the read/write heads to move in the direction determined by the "direction select" signal. Motion is started each time the signal changes from an active to inactive level (at the trailing edge of the pulse). |
| 42  | DIRECTION<br>SELECT | 0   | Output to FDD — This signal determines the direction the read/write head moves when the step signal is pulsed. A low level indicates away from the center of the diskette (out); a high level indicates toward the center of the diskette (in).             |
| 43  | MOTOR B ON          | 0   | Output to FDD — The spindle motor B runs when this input is active. The drive requires a 1 sec (high density)/750 ms (double density) delay after "motor on" becomes active before and after the trailing edge of the step pulse.                           |
| 44  | DRIVE A<br>SELECT   | 0   | Output to FDD — When "Drive A Select" is at the active level, drive A is enabled. When it is at the inactive level, all drive A outputs are disabled.                                                                                                       |
| 45  | DRIVE B<br>SELECT   | 0   | Output to FDD — When "Drive B Select" is at the active level, drive B is enabled. When it is at the inactive level, all drive B outputs are disabled.                                                                                                       |
| 46  | MOTOR A ON          | 0   | Output to FDD — The spindle motor A runs when this input is active. Drive A requires a 1 sec (high density)/750 ms (double density) delay after "motor on" becomes active before and after the trailing edge of the read or write operation.                |
| 47  | ĪNDĒX               | 1   | Input from FDD — A low pulse appears on this line to indicate the beginning of a disk track when the drive senses the index hole in the diskette.                                                                                                           |
| 48  | REDUCED<br>WRITE    | 0   | Output to FDD — The inactive state low of this signal indicates that high-density media is present, requiring normal write currents, and the active state high indicates low-density media is present, requiring a reduced write current.                   |

Storage



#### Register Description

#### 1. Digital Output Register (IO write 3F2, 372)

The digital output register (DOR) is an output-only register controlling drive motors, drive selection, and feature enable. All bits are cleared by the I/O interface reset line. The bit definitions are as follows.

| Bit 7 | Reserved                                                                      |
|-------|-------------------------------------------------------------------------------|
| Bit 6 | Reserved                                                                      |
| Bit 5 | Drive B Motor Enable                                                          |
| Bit 4 | Drive A Motor Enable                                                          |
| Bit 3 | Enable Diskette Interrupts and DMA                                            |
| Bit 2 | Diskette Function Reset — Diskette function reset when this bit is low ('0'). |
| Bit 1 | Reserved                                                                      |
| Bit 0 | Drive Select — A'0'on this bit indicates that drive A is selected.            |

#### 2. Digital Input Register (IO read 3F7, 377)

The digital input register is an 8-bit, read-only register used for diagnostic purposes. The following are bit definitions for this register.

| Bit 7      | Diskette Change                                  |
|------------|--------------------------------------------------|
| Bits 0 ~ 6 | Apply to the currently selected fixed disk drive |

#### 3. Transfer Rate Register (Diskette Control Register) (10 write 3F7, 377)

The transfer rate register is a 2-bit, output-only register which controls a programmable divider and provides 8M/4.8M/4M Hz clocks for three different data transfer rates. The definition is given as follows:

| Bit 0 | Bit 1 | Transfer Rates | Clock Rates | Reduce write |
|-------|-------|----------------|-------------|--------------|
| 0     | 0     | 500K bps       | 8 MHz       | 0            |
| 1     | . 0   | 300K bps       | 4.8 MHz     | 1            |
| 0     | 1     | 250K bps       | 4 MHz       | 1            |
| 1     | 1     | reserved       | reserved    | 1            |

#### 4. Main Status Register (IO read 3F4, 374)

Those bits in the main status register are defined as follows:

| Bit 7 | Request for master (RQM) — The data register is ready to send or receive data to or from the processor.  |  |  |
|-------|----------------------------------------------------------------------------------------------------------|--|--|
| Bit 6 | Data Input/Output (DIO) — The direction of data transfer between the diskette control and the processor. |  |  |
| Bit 5 | Non-DMA Mode (NDM) — The diskette controller is in the non-DMA mode,                                     |  |  |
| Bit 4 | Diskette Control Busy (CB) - A Read or Write command is being executed.                                  |  |  |
| Bit 3 | Reserved                                                                                                 |  |  |
| Bit 2 | Reserved                                                                                                 |  |  |
| Bit 1 | Diskette Drive B Busy (DBB) — Diskette drive B is in the seek mode.                                      |  |  |
| Bit 0 | Diskette Drive A Busy (DAB) - Diskette drive A is in the seek mode.                                      |  |  |



T-52-33-61

#### 5. Diskette Data Register (10 read 10 write 3F5 375)

This 8-bit data register actually consists of several registers in a stack and only one register is presented to the data bus at a time when storing data commands, and parameters, or providing diskette-drive status information.

#### 6. Fixed Disk Status Register (10 read 1F7, 177)

The contents of this 8-bit fixed disk status register are checked when system BIOS executes self-test. This register is enabled when PC system has no Hard Disk Control card and bit 7 is of this register is fixed to 1 (high). This register shall be disabled when PC system has a Hard Disk Control card.

Table A-1 The I/O addresses of these five registers mentioned above are given in the following:

| Primary | Secondary | Read                        | Write                   |
|---------|-----------|-----------------------------|-------------------------|
| 3F2     | 372       |                             | Digital output register |
| 3F4     | 374       | Main status register        |                         |
| 3F5     | 375       | Diskette data register      | Diskette data register  |
| 3F7     | 377 ·     | Digital input register      | Transfer rate register  |
| 1F7     | 177       | Fixed Disk Status register* |                         |

<sup>\*:</sup> Fixed disk function

#### **Application Notes**

#### A: General Description

The UM8388 can be easily implemented into a FDC card or a main board and only 4 components (UM8388, 7406\*2 74LS245\*1) are needed in the IBM PC/AT drive system. The address decoder of UM8388 is switchable by setting pin 29 (Drive group select) of UM8388. If pin 29 is set to 1 (high), then the I/O address of the UM8388 is selected in the primary drive group address (3F1  $\sim$  3F7, 1F7). The contents of the UM8388 Hard Disk Status Register will be checked when system BIOS executes selftest. This register's bit 7 should be high by setting pin 32 to high when the PC system has no Hard Disk Control card, otherwise the register's bit 7 should be low by setting pin 32 to low.

# B: PC/AT Application

The UM8388 registers are the same as the PC/AT floppy disk controller's. Therefore, the UM8388 can be directly implemented into the FDC card of the PC/AT to support 1.2M, 720K, 360K 1.44M Bytes FDD and only 4 components (UM8388\*1,7406\*2 74LS245) are needed. The application circuit is shown as Figure A-1.

#### C: PC/XT Application

If the UM8388 is used to support 1.44M, 1.2M, 720K, 360K Byte FDD in the PC/XT an additional FDC program is needed to control the 1.44M, 1.2M Bytes FDD since the PC/XT BIOS doesn't support the 1.2M, 1.44M Byte FDD. During the FDD operation, this additional BIOS reads the contents of the UM8388 Drive Type Register set by pin 31, thus selects the drive to be 1.44M, 1.2M, 360K or 720K.

Storage



Figure A-1 PC/AT (1.44M, 1.2M, 720K, 360K FDD) Application Circuit

UMC

T-52-33-61

UM8388



Figure A-2 PC/XT BIOS ROM Circuit

T-52-33-61



UM8388

# **Ordering Information**

| Part Number | Operating<br>Current (Max.) | Package Type |
|-------------|-----------------------------|--------------|
| UM8388      | 200 mA                      | 48L DIP      |
| UM8388L-*1  | 200 mA                      | 52L PLCC     |
| UM8388L-*2  | 200 mA                      | 68L PLCC     |