# 82078 CHMOS Single-Chip Floppy Disk Controller



### 82078 CHMOS Single-Chip Floppy Disk Controller

| CONTENTS                                              | PAGE |
|-------------------------------------------------------|------|
| 82078 CHMOS SINGLE-CHIP FLOPPY DISK CONTROLLER        | 1    |
| 82078 44 PIN CHMOS SINGLE-CHIP FLOPPY DISK CONTROLLER |      |
| 82078 64 PIN CHMOS SINGLE-CHIP FLOPPY DISK CONTROLLER |      |

Intel Corporation makes no warranty for the use of its products and assumes no responsibility for any errors which may appear in this document nor does it make a commitment to update the information contained herein.

Intel retains the right to make changes to these specifications at any time, without notice.

Contact your local Intel sales office or your distributor to obtain the latest specifications before placing your product order.

MDS is an ordering code only and is not used as a product name or trademark of Intel Corporation.

Intel Corporation and Intel's FASTPATH are not affiliated with Kinetics, a division of Excelan, Inc. or its FASTPATH trademark or products.

\*Other brands and names are the property of their respective owners.

Additional copies of this document or other Intel literature may be obtained from:

Intel Corporation Literature Sales P.O. Box 7641 Mt. Prospect, IL 60056-7641

or call 1-800-879-4683

### int<sub>el</sub>.

### 82078 CHMOS SINGLE-CHIP FLOPPY DISK CONTROLLER

- Small Footprint and Low Height Packages
- Supports Standard 5.0V as Well as Low Voltage 3.3V Platforms
  - Selectable 3.3V and 5.0V Configuration
  - 5.0V Tolerant Drive Interface
- Enhanced Power Management
  - Application Software Transparency
  - Programmable Powerdown Command
  - --- Save and Restore Commands for 0V Powerdown
  - Auto Powerdown and Wakeup Modes
  - Two External Power Management Pins
  - Consumes No Power While in Powerdown
- Programmable Internal Oscillator
- Floppy Drive Support Features
   Drive Specification Command
  - --- Media ID Capability Provides Media Recognition
  - Drive ID Capability Allows the User to Recognize the Type of Drive
  - Selectable Boot Drive
  - Standard IBM and ISO Format Features
  - Format with Write Command for High Performance in Mass Floppy Duplication
- Integrated Host/Disk Interface Drivers

- Integrated Analog Data Separator — 250 Kbits/sec
  - 300 Kbits/ sec
  - 500 Kbits/ sec
  - -1 Mbits/sec
  - -2 Mbits/sec
- Integrated Tape Drive Support
   Standard 1 Mbps/500 Kbps/ 250 Kbps Tape Drives
   New 2 Mbps Tape Drive Mode
- Perpendicular Recording Support for 4 MB Drives
- Fully Decoded Drive Select and Motor Signals
- Programmable Write Precompensation Delays
- Addresses 256 Tracks Directly, Supports Unlimited Tracks
- 16 Byte FIFO
- Single-Chip Floppy Disk Controller Solution for Portables and Desktops — 100% PC-AT\* Compatible
  - 100% PS/2\* Compatible
  - 100% PS/2 Model 30 Compatible
  - Fully Compatible with Intel's 386SL Microprocessor SuperSet
  - Integrated Drive and Data Bus Buffers
- Available in 64 Pin QFP and 44 Pin QFP Package (See Package Specification Order Number 240800 Package)

(See Package Specification Order Number 240800, Package Type S)

The 82078 Product Family brings a set of enhanced floppy disk controllers. These include several features that allow for easy implementation in both the portable and desktop market. The current family includes a 64 pin and a 44 pin part in the smaller form factor QFP package. The 3.3V version of the 64 pin part provides an ideal solution for the rapidly emerging 3.3V platforms. It also allows for a 5.0V tolerant floppy drive interface that lets the users retain their normal 5.0V drives. Another version of the 64 pin part provides support for 2 Mbps data rate tape drives.

\*Other brands and names are the property of their respective owners.

1

#### Table 1-0. 64 Pin Part Versions

| 82078SL | 3.3V | 5.0V | 2 Mbps Data Rate |  |
|---------|------|------|------------------|--|
|         | X    | X    |                  |  |
| 82078-1 |      | X    | x                |  |

The 44 pin is targeted for platforms that are operated at 3.3V or 5.0V and do not require more than two drive support. The 82078-5 is designed for price sensitive 5.0V designs which do not include 4 MB drive support.

| Table 2-0. 44 F | in Part Versions |
|-----------------|------------------|
|-----------------|------------------|

|         | 3.3V | 5.0V | 1 Mbps Data Rate |
|---------|------|------|------------------|
| 82078   |      | x    | X                |
| 82078-5 |      | X    |                  |
| 82078-3 | X    |      | Х                |

Both parts can be operated at 1 Mbps/500 Kbps/300 Kbps/250 Kbps. Additionally, one version of the 64 pin part provides 2 Mbps data rate operation specific for the new tape drives.

The 82078 is fabricated with Intel's advanced CHMOS III technology.





·

### ENDER 82078 44 PIN CHMOS SINGLE-CHIP FLOPPY DISK CONTROLLER

- Small Footprint and Low Height Package
- Enhanced Power Management — Application Software Transparency
  - Programmable Powerdown Command
  - Save and Restore Commands for Zero-Volt Powerdown
  - Auto Powerdown and Wakeup Modes
  - Two External Power Management Pins
  - Consumes No Power While in Powerdown
- Integrated Analog Data Separator
  - 250 Kbps
  - 300 Kbps
  - 500 Kbps
  - 1 Mbps
- Programmable Internal Oscillator
- Floppy Drive Support Features
  - Drive Specification Command
  - Selectable Boot Drive
  - Standard IBM and ISO Format Features
  - Format with Write Command for High Performance in Mass Floppy Duplication

- Integrated Tape Drive Support
   Standard 1 Mbps/500 Kbps/ 250 Kbps Tape Drives
- Perpendicular Recording Support for 4 MB Drives
- Integrated Host/Disk Interface Drivers
- Fully Decoded Drive Select and Motor Signals
- Programmable Write Precompensation Delays
- Addresses 256 Tracks Directly, Supports Unlimited Tracks
- 16 Byte FIFO
- Single-Chip Floppy Disk Controller Solution for Portables and Desktops — 100% PC/AT\* Compatible
  - Fully Compatible with Intel386™ SL
  - Integrated Drive and Data Bus Buffers
- Separate 5.0V and 3.3V Versions of the 44 Pin part are Available
- Available in a 44 Pin QFP Package

The 82078, a 24 MHz crystal, a resistor package, and a device chip select implements a complete solution. All programmable options default to 82078 compatible values. The dual PLL data separator has better performance than most board level/discrete PLL implementations. The FIFO allows better system performance in multi-master (e.g., Microchannel, EISA).

The 82078 maintains complete software compatibility with the 82077SL/82077AA/8272A floppy disk controllers. It contains programmable power management features while integrating all of the logic required for floppy disk control. The power management features are transparent to any application software.

The 82078 is fabricated with Intel's advanced CHMOS III technology and is also available in a 64-lead QFP package.

\*Other brands and names are the property of their respective owners.

5

### 82078 44 Pin CHMOS Single-Chip Floppy Disk Controller

| CONTENTS                                           | PAGE |
|----------------------------------------------------|------|
| 1.0 INTRODUCTION                                   | 12   |
| 2.0 MICROPROCESSOR INTERFACE                       | 13   |
| 2.1 Status, Data, and Control<br>Registers         | 13   |
| 2.1.1 Status Register B (SRB,<br>EREG EN = 1)      | 13   |
| 2.1.2 Digital Output Register<br>(DOR)             | 14   |
| 2.1.3 Enhanced Tape Drive<br>Register (TDR)        | 15   |
| 2.1.4 Datarate Select Register<br>(DSR)            | 15   |
| 2.1.5 Main Status Register<br>(MSR)                | 17   |
| 2.1.6 FIFO (DATA)                                  | 17   |
| 2.1.7 Digital Input Register (DIR)                 | 18   |
| 2.2 Reset                                          |      |
| 2.2.1 Reset Pin ("HARDWARE")<br>Reset              | 18   |
| 2.2.2 DOR Reset vs DSR Reset<br>("SOFTWARE" RESET) |      |
| 2.3 DMA Transfers                                  | 18   |
| 3.0 DRIVE INTERFACE                                | 18   |
| 3.1 Cable Interface                                | 18   |
| 3.2 Host and FDD Interface Drivers .               | 19   |
| 3.3 Data Separator                                 | 19   |
| 3.3.1 Jitter Tolerance                             | 20   |
| 3.3.2 Locktime (t <sub>LOCK</sub> )                | 20   |
| 3.3.3 Capture Range                                | 20   |
| 3.4 Write Precompensation                          | 20   |

### CONTENTS

PAGE

| 4.0 POWER MANAGEMENT<br>FEATURES                           |
|------------------------------------------------------------|
| 4.1 Power Management Scheme 21                             |
| 4.2 Oscillator Power Management 21                         |
| 4.3 Part Power Management                                  |
| 4.3.1 Direct Powerdown                                     |
| 4.3.2 Auto Powerdown                                       |
| 4.3.3 Wake Up Modes                                        |
| 4.3.3.1 Wake Up from DSR                                   |
| Powerdown                                                  |
| 4.3.3.2 Wake Up from Auto<br>Powerdown                     |
| 4.4 Register Behavior                                      |
| 4.5 Pin Behavior                                           |
| 4.5.1 System Interface Pins                                |
| 4.5.2 FDD Interface Pins                                   |
|                                                            |
| 5.0 CONTROLLER PHASES                                      |
| 5.1 Command Phase 24                                       |
| 5.2 Execution Phase                                        |
| 5.2.1 Non-DMA Mode, Transfers<br>from the FIFO to the Host |
| 5.2.2 Non-DMA Mode, Transfers<br>from the Host to the FIFO |
| 5.2.3 DMA Mode, Transfers from the FIFO to the Host        |
| 5.2.4 DMA Mode, Transfers from<br>the Host to the FIFO     |
| 5.2.5 Data Transfer Termination 26                         |
| 5.3 Result Phase 26                                        |

### CONTENTS

| 6.0 COMMAND SET/DESCRIPTIONS                   | 26 |
|------------------------------------------------|----|
| 6.1 Data Transfer Commands                     | 38 |
| 6.1.1 Read Data                                | 38 |
| 6.1.2 Read Deleted Data                        | 39 |
| 6.1.3 Read Track                               | 39 |
| 6.1.4 Write Data                               |    |
| 6.1.5 Write Deleted Data                       | 40 |
| 6.1.6 Verify                                   |    |
| 6.1.7 Format Track                             |    |
| 6.1.7.1 Format Fields                          |    |
| 6.2 Scan Commands                              |    |
| 6.3 Control Commands                           |    |
| 6.3.1 Read ID                                  | 43 |
| 6.3.2 Recalibrate                              | 43 |
| 6.3.3 Drive Specification<br>Command           | 43 |
| 6.3.4 Seek                                     | 44 |
| 6.3.5 Sense Interrupt Status                   | 44 |
| 6.3.6 Sense Drive Status                       | 45 |
| 6.3.7 Specify                                  | 45 |
| 6.3.8 Configure                                | 45 |
| 6.3.9 Version                                  | 46 |
| 6.3.10 Relative Seek                           | 46 |
| 6.3.11 DUMPREG                                 | 47 |
| 6.3.12 Perpendicular Mode<br>Command           | 47 |
| 6.3.12.1 About Perpendicular<br>Recording Mode | 47 |
| 6.3.12.2 The Perpendicular<br>Mode Command     |    |
| 6.3.13 Powerdown Mode<br>Command               | 48 |
| 6.3.14 Part ID Command                         |    |
| 6.3.15 Option Command                          | 48 |
| 6.3.16 Save Command                            | 48 |
| 6.3.17 Restore Command                         | 48 |
| 6.3.18 Format and Write<br>Command             | 40 |
|                                                |    |
| 6.3.19 Lock                                    | 49 |

### PAGE CONTENTS

#### PAGE

| 7.0 STATUS REGISTER ENCODING                              | 50 |
|-----------------------------------------------------------|----|
| 7.1 Status Register 0                                     | 50 |
| 7.2 Status Register 1                                     | 50 |
| 7.3 Status Register 2                                     | 51 |
| 7.4 Status Register 3                                     | 51 |
| 8.0 COMPATIBILITY                                         |    |
| 8.1 Compatibility with the FIFO                           |    |
| 8.2 Drive Polling                                         | 52 |
| 9.0 PROGRAMMING GUIDELINES                                | 52 |
| 9.1 Command and Result Phase<br>Handshaking               | 53 |
| 9.2 Initialization                                        |    |
| 9.3 Recalibrates and Seeks                                |    |
| 9.4 Read/Write Data Operations                            |    |
| 9.5 Formatting                                            |    |
| 9.6 Save and Restore                                      |    |
| 9.7 Verifies                                              |    |
| 9.8 Powerdown State and Recovery                          |    |
| 9.8.1 Oscillator Power                                    | 50 |
| Management<br>9.8.2 Part Power Management                 |    |
| 9.8.2.1 Powerdown Modes                                   |    |
| 9.8.2.2 Wake Up Modes                                     |    |
|                                                           |    |
| 10.0 DESIGN APPLICATIONS                                  | 60 |
| 10.1 Operating the 82078 in a 3.3V<br>Design              | 60 |
| 10.2 Selectable Boot Drive                                |    |
| 10.3 How to Disable the Native Floppy                     |    |
| Contoller on the Motherboard                              | 63 |
| 10.4 Replacing the 82077SL with a 82078 in a 5.0V design: | 63 |
| 11.0 D.C. SPECIFICATIONS                                  | 66 |
| 11.1 Absolute Maximum Ratings                             | 66 |
| 11.2 D.C. Characteristics                                 | 66 |
| 11.3 Oscillator                                           | 67 |
| 12.0 A.C. SPECIFICATIONS                                  | 68 |
| 12.1 Package Outline for the 44-Pin<br>QFP Part           | 74 |
| 13.0 REVISION HISTORY                                     | 75 |

7



#### Figure 1-0. 82078 44 Pin Pinout

#### Table 1.0. 82078 (44 Pin) Description

| Symbol  | Pin #  | 1/0 | @ H/W<br>Reset |     |              |            |              | Description                                                            |            |
|---------|--------|-----|----------------|-----|--------------|------------|--------------|------------------------------------------------------------------------|------------|
| HOST IN | TERFAC | E   |                |     |              |            |              | · · · · · · · · · · · · · · · · · · ·                                  |            |
| RESET   | 34     | 1   | N/A            |     |              |            |              | s the 82078 in a known idle state.<br>pt those set by the Specify comm |            |
| A0      | 40     | 1   | N/A            | ADD | RES          | S: Sel     | ects one of  | the host interface registers:                                          | ,          |
| A1      | 39     |     |                | A2  | <b>A1</b>    | <b>A</b> 0 | Access       | Register                                                               |            |
| A2      | 38     |     |                | 0   | 0            | 0          | R            | Reserved                                                               |            |
|         |        |     |                | 0   | 0            | 1          | R/W          | Status Register B                                                      | SRB        |
|         |        |     |                | 0   | 1            | 0          | R/W          | Digital Output Register                                                | DOR        |
|         |        |     |                | 0   | 1            | 1          | R/W          | Tape Drive Register                                                    | TDR        |
|         | l      |     |                | 1   | 0            | 0          | R            | Main Status Register                                                   | MSR        |
|         | r.     | r   |                | 1   | 0            | 0          | W            | Data Rate Select Register                                              | DSR        |
|         |        |     |                | 1   | 0            | 1          | R/W          | Data Register (FIFO)                                                   | FIFO       |
|         |        |     |                | 1   | 1            | 0          | Reserved     | t i                                                                    |            |
|         |        | l   |                | 1   | 1            | 1          | R            | Digital Input Register                                                 | DIR        |
|         |        |     |                | 1   | 1            | 1          | W            | <b>Configuration Control Register</b>                                  | CCR        |
| CS#     | 41     | .1  | N/A            |     | P SEL<br>WR# |            | Decodes t    | he base address range and qualif                                       | ies RD#    |
| RD#     | 42     | 1   | N/A            |     | D: Resyster  |            | ontrol signa | I for data transfers from the flopp                                    | y drive to |

## int<sub>el</sub>.

| Symbol                                               | ₽in #                                  | 1/0     | @ H/W<br>Reset | Description                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------------------------------------------------|----------------------------------------|---------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HOST INTER                                           | FACE (Co                               | ontinue | d)             |                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| WR#                                                  | 43                                     | l       | N/A            | WRITE: Write control signal for data transfers to the floppy drive from the system.                                                                                                                                                                                                                                                                                                                                               |
| DRQ                                                  | 44                                     | 0       |                | <b>DMA REQUEST:</b> Requests service from a DMA controller.<br>Normally active high, but will go to high impedance in AT and<br>Model 30 modes when the appropriate bit is set in the DOR.                                                                                                                                                                                                                                        |
| DACK#                                                | 1                                      | I       | N/A            | <b>DMA ACKNOWLEDGE:</b> Control input that qualifies the RD#,<br>WR# inputs in DMA cycles. Normally active low, but is disabled<br>in AT and Model 30 modes when the appropriate bit is set in the<br>DOR.                                                                                                                                                                                                                        |
| DB0<br>DB1<br>DB2<br>DB3<br>DB4<br>DB5<br>DB6<br>DB7 | 2<br>3<br>4<br>5<br>8<br>9<br>10<br>11 | 1/0     |                | DATA BUS: 12 mA data bus.                                                                                                                                                                                                                                                                                                                                                                                                         |
| INT                                                  | 12                                     | 0       |                | <b>INTERRUPT:</b> Signals a data transfer in non-DMA mode and when status is valid. Normally active high, but goes to high impedance when the appropriate bit is set in the DOR.                                                                                                                                                                                                                                                  |
| тс                                                   | 13                                     | 1       | N/A            | <b>TERMINAL COUNT:</b> Control line from a DMA controller that terminates the current disk transfer. TC is effective only when qualified by DACK #. This input is active high.                                                                                                                                                                                                                                                    |
| X1<br>X2                                             | 36<br>35                               |         | N/A            | <b>EXTERNAL CLOCK OR CRYSTAL:</b> Connection for a 24 MHz fundamental mode parallel resonant crystal. X1 can also be driven by an external clock (external oscillator) which can be either at 48 MHz or 24 MHz. If external oscillator is used then the PDOSC bit can be set to turn off the internal oscillator. Also, if a 48 MHz external oscillator is used then the CLK48 bit must be set in the enhanced CONFIGURE command. |
| PLL SECTIO                                           | N                                      |         |                |                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| RDDATA#                                              | 20                                     | I       | N/A            | READ DATA: Serial data from the floppy disk.                                                                                                                                                                                                                                                                                                                                                                                      |
| DISK CONTR                                           | ROL                                    |         |                |                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| TRK0#                                                | 14                                     | 1       | N/A            | <b>TRACK0:</b> This is an active low signal that indicates that the head on track 0.                                                                                                                                                                                                                                                                                                                                              |
| INDX#                                                | 15                                     | I       | N/A            | <b>INDEX:</b> This is an active low signal that indicates the beginning of the track.                                                                                                                                                                                                                                                                                                                                             |
| WP#                                                  | 16                                     | I       | N/A            | WRITE PROTECT: This is an active low signal that indicates whether the floppy disk in the drive is write protected.                                                                                                                                                                                                                                                                                                               |
| DSKCHG#                                              | 19                                     | I       | N/A            | <b>DISK CHANGE:</b> This is an input from the floppy drive reflected in the DIR.                                                                                                                                                                                                                                                                                                                                                  |
| DRVDEN0,<br>DRVDEN1                                  | 21<br>22                               | 0       |                | <b>DRIVE DENSITY:</b> These signals are used by the floppy drive to configure the drive for the appropriate media.                                                                                                                                                                                                                                                                                                                |
| WRDATA#                                              | 23                                     | 0       |                | WRITE DATA: MFM serial data to the drive. Precompensation value is selectable through software.                                                                                                                                                                                                                                                                                                                                   |

#### Table 1.0 82078 (44 Pin) Description (Continued)

I

#### Table 1.0 82078 (44 Pin) Description (Continued)

| Symbol          | Pin #     | 1/0 | @ H/W<br>Reset | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------|-----------|-----|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DISK CONTROL (C | Continued | )   |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| WE#             | 24        | 0   |                | <b>WRITE ENABLE:</b> Floppy drive control signal that enables the head to write onto the floppy disk.                                                                                                                                                                                                                                                                                                                                                                         |
| STEP#           | 27        | 0   |                | <b>STEP:</b> Supplies step pulses to the floppy drive to move the head between tracks.                                                                                                                                                                                                                                                                                                                                                                                        |
| DIR#            | 29        | 0   |                | <sup>7</sup> <b>DIRECTION:</b> It is an active low signal which controls the direction the head moves when a step signal is present. The head moves inwards towards the center if this signal is active.                                                                                                                                                                                                                                                                      |
| HDSEL#          | 25        | 0   |                | <b>HEAD SELECT:</b> Selects which side of the floppy disk is<br>to be used for the corresponding data transfer. It is active<br>low and an active level selects head 1, otherwise it<br>defaults to head 0.                                                                                                                                                                                                                                                                   |
| FDME0#          | 32        | 0   |                | FLOPPY DRIVE MOTOR ENABLE 0: Decoded motor<br>enable for drive 0. The motor enable pins are directly<br>controlled via the DOR and are a function of the mapping<br>based on BOOTSEL bits in the TDR.                                                                                                                                                                                                                                                                         |
| FDME1#/IDLE#    | 30        | 0   |                | FLOPPY DRIVE MOTOR ENABLE or IDLE: One of these<br>is selected based on the level of the 44PDEN bit in the<br>auto powerdown command.                                                                                                                                                                                                                                                                                                                                         |
|                 |           |     |                | FLOPPY DRIVE MOTOR ENABLE 1: Decoded motor<br>enable for drive 1. The motor enable pins are directly<br>controlled via the DOR and are a function of the mapping<br>based on BOOTSEL bits in the TDR.                                                                                                                                                                                                                                                                         |
|                 |           |     |                | <b>IDLE:</b> This pin indicates that the part is in the IDLE state<br>and can be powered down. IDLE state is defined as<br>MSR = 80H, $INT = 0$ , and the head being "unloaded"<br>(as defined in the section describing powerdown).<br>Whenever the part is in this state, IDLE pin is active low. If<br>the part is powered down by the Auto Powerdown Mode,<br>IDLE pin is set low. If the part is powered down by setting<br>the DSR POWERDOWN bit, IDLE pin is set high. |
| FDS0#           | 33        | 0   |                | <b>FLOPPY DRIVE SELECT 0:</b> Decoded floppy drive select<br>for drive 0. These outputs are decoded from the select<br>bits in the DOR and are a function of the mapping based<br>on BOOTSEL bits in the TDR.                                                                                                                                                                                                                                                                 |
| FDS1 #/PD #     | 31        | 0   |                | FLOPPY DRIVE MOTOR ENABLE or PD: One of these<br>is selected based on the level of the 44PDEN bit in the<br>auto powerdown command.                                                                                                                                                                                                                                                                                                                                           |
|                 |           |     |                | <b>FLOPPY DRIVE SELECT 1:</b> Decoded floppy drive select<br>for drive 1. These outputs are decoded from the select<br>bits in the DOR and are a function of the mapping based<br>on BOOTSEL bits in the TDR.                                                                                                                                                                                                                                                                 |
|                 |           |     |                | <b>POWERDOWN:</b> This pin is active low whenever the part<br>is in powerdown state, either via DSR POWERDOWN bit<br>or via the Auto Powerdown Mode. This pin can be used to<br>disable an external oscillator's output.                                                                                                                                                                                                                                                      |

| Symbol           | Pin #    | 1/0   | @ H/W<br>Reset | Description                                                 |
|------------------|----------|-------|----------------|-------------------------------------------------------------|
| POWER            | AND GRC  | UND S | IGNALS         |                                                             |
| V <sub>CC</sub>  | 7        |       | N/A            | Power Supply*                                               |
| V <sub>SSP</sub> | 6        |       | N/A            | GROUND: 0V                                                  |
| V <sub>SS</sub>  | 26<br>37 |       | N/A            | GROUND: 0V                                                  |
| AV <sub>CC</sub> | 18       |       | N/A            | ANALOG VOLTAGE                                              |
| V <sub>CCF</sub> | 28       |       | N/A            | VOLTAGE: +5V for a 5V floppy drive, +3.3V for a 3.3V drive. |
| AVSS             | 17       |       | N/A            | ANALOG GROUND                                               |

#### Table 1.0. 82078 (44 Pin) Description (Continued)

**NOTE:** \*The digital power supply  $V_{CC}$  and the analog power supply  $AV_{CC}$  should either be the same or regulated to be within 0.1V of either.

### int<sub>el</sub>.

#### **1.0 INTRODUCTION**

The 82078 (44 pin) enhanced floppy disk controller incorporates several new features allowing for easy implementation in both the portable and desktop markets. It provides a low cost, small form factor solution targeted for 5.0V and 3.3V platforms that do not require more than two drive support.

The 82078 (44 pin) implements these new features while remaining functionally compatible with 82077SL/82077AA/8272A floppy disk controllers.

Together with a 24 MHz crystal, a resistor package and a device chip select, these devices allow for the most integrated solution available. The integrated analog PLL data separator has better performance than most board level discrete PLL implementations and can be operated at 1 Mbps/500 Kbps/ 300 Kbps/250 Kbps. A 16-byte FIFO substantially improves system performance especially in multimaster systems (e.g. Microchannel, EISA).

Figure 1-1 is a block diagram of the 82078.



Figure 1-1. 82078 Block Diagram

### 2.0 MICROPROCESSOR INTERFACE

The interface consists of the standard asynchronous signals: RD#, WR#, CS#, A0-A2, INT, DMA control and a data bus. The address lines select between configuration registers, the FIFO and control/status registers.

#### 2.1 Status, Data, and Control Registers

As shown below, the base address range is supplied via the CS# pin. For PC-AT or PS/2 designs, the primary and secondary address ranges are 3F0 Hex to 3F7 Hex and 370 Hex to 377 Hex respectively.

| A2 | A1 | A0 | Access<br>Type | Register                       |      |
|----|----|----|----------------|--------------------------------|------|
| 0  | 0  | 0  |                | Reserved                       |      |
| 0  | 0  | 1  | R/W            | Status Register B              | SRB  |
| 0  | 1  | 0  | R/W            | Digital Output Register        | DOR  |
| 0  | 1  | 1  | R/W            | Tape Drive Register            | TDR  |
| 1  | 0  | 0  | R              | Main Status Register           | MSR  |
| 1  | 0  | 0  | w              | Data Rate Select Register      | DSR  |
| 1  | 0  | 1  | R/W            | Data (First In First Out)      | FIFO |
| 1  | 1  | 0  |                | Reserved                       |      |
| 1  | 1  | 1  | R              | Digital Input Register         | DIR  |
| 1  | 1  | 1  | w              | Configuration Control Register | CCR  |

In the following sections, the various registers are shown in their powerdown state. The "UC" notation stands for a value that is returned without change from the active mode. The notation "\*" means that the value is reflecting the required status (for powerdown). "N/A" means not applicable. "X" indicates that the value is undefined.

#### 2.1.1 STATUS REGISTER B (SRB, EREG EN = 1)

In the AT/EISA mode the SRB is made available whenever the EREG EN bit in the auto powerdown command is set. The register functionality is defined as follows (bits 7 through 3 are reserved):

|              |      |      |      | SRB  |      |         |      |      |
|--------------|------|------|------|------|------|---------|------|------|
| R/W          | 7    | 6    | 5    | 4    | 3    | 2       | 1    | 0    |
| R            | RSVD | RSVD | RSVD | RSVD | RSVD | IDLEMSK | PD   | IDLE |
| H/W<br>Reset | X    | x    | x    | X    | x    | 0       | PD   | IDLE |
| Auto<br>PD   | x    |      | X    | X    | X    | UC      | UC   | UC D |
| W            | 0    | 0    | 0    | 0    | 0    | IDLEMSK | RSVD | RSVD |
| H/W<br>Reset | N/A  | N/A  | N/A  | N/A  | N/A  | 0       | N/A  | N/A  |
| Auto<br>PD   | N/A  | N/A  | N/A  | N/A  | N/A  | UC      | N/A  | N/A  |

PD and IDLE reflect the inverted values on the corresponding pins when 44PD EN = 1 (these pins are muxed with FDS1 and FDME1). The signal on the IDLE# pin can be masked by setting IDLEMSK bit high in this register. The IDLE bit will remain unaffected. Since some systems will use the IDLE# pin to provide interrupt to the SMM power management, its disabling allows less external interrupt logic and reduction in board space. Only hardware reset will clear the IDLEMSK bit to zero. When the IDLEMSK bit is set, there is no way to distinguish between autopowerdown and DSR powerdown.

#### NOTE:

The 44 pin versions of the 82078 are designed to support *either* PD# and IDLE# or FDME1# and FDS1#, but not both simultaneously.

| IDLEMSK | IDLE # (pin) |
|---------|--------------|
| 0       | unmasked     |
| 1       | masked       |

#### 2.1.2 DIGITAL OUTPUT REGISTER (DOR)

The Digital Output Register contains the drive select and motor enable bits, a reset bit and a DMAGATE # bit.

| Bits            | 7    | 6    | 5          | 4          | 3             | 2      | 1    | 0            |
|-----------------|------|------|------------|------------|---------------|--------|------|--------------|
| Function        | RSVD | RSVD | MOT<br>EN1 | MOT<br>EN0 | DMA<br>.GATE# | RESET# | RSVD | DRIVE<br>SEL |
| H/W Reset State | 0    | 0    | 0          | 0          | 0             | 0      | 0    | 0            |
| Auto PD State   | 0    | 0    | 0,*        | 0*         | UC            | 1*     | UC   | UC           |

The MOT ENx bits directly control their respective motor enable pins (FDME0-1). The DRIVE SEL bit is decoded to provide four drive select lines and only one may be active at a time. Standard programming practice is to set both MOT ENx and DRIVE SELx bits at the same time.

#### NOTE:

The 44 pin versions of the 82078 are designed to support *either* PD# and IDLE# or FDME1# and FDS1#, but not both simultaneously.

Table 2-1 lists a set of DOR values to activate the drive select and motor enable for each drive.

#### Table 2-1. Drive Activation Value

| Drive | DOR Value |  |  |
|-------|-----------|--|--|
| 0     | 1CH       |  |  |
| 1     | 2DH       |  |  |

The DMAGATE# bit is enabled only in PC-AT. If DMAGATE# is set low, the INT and DRQ outputs are tri-stated and the DACK# and TC inputs are disabled. DMAGATE# set high will enable INT, DRQ, TC, and DACK# to the system.

The DOR reset bit and the Motor Enable bits have to be inactive when the 82078 is in powerdown. The DMAGATE# and DRIVE SEL bits are unchanged. During powerdown, writing to the DOR does not awaken the 82078 with the exception of activating any of the motor enable bits. Setting the motor enable bits active (high) will wake up the part.

This RESET# bit clears the basic core of the 82078 and the FIFO circuits when the LOCK bit is set to "0" (see Section 5.3.2 for LOCK bit definitions). Once set, it remains set until the user clears this bit. This bit is set by a chip reset and the 82078 is held in a reset state until the user clears this bit. The RESET# bit has no effect upon the register.

|              |      | -    |      | TDR  |      |         |          |          |
|--------------|------|------|------|------|------|---------|----------|----------|
| R/W          | 7*   | 6*   | 5*   | 4*   | 3*   | 2*      | 1        | 0        |
| R            | RSVD | RSVD | RSVD | RSVD | RSVD | BOOTSEL | TAPESEL1 | TAPESEL0 |
| H/W<br>Reset | N/A  | N/A  | N/A  | N/A  | N/A  | 0       | 0        | 0        |
| Auto<br>PD   | N/A  | N/A  | N/A  | N/A  | N/A  | UC      | UC       | UC       |
| W            | 0    | 0    | 0    | 0    | 0    | BOOTSEL | TAPESEL1 | TAPESEL0 |
| H/W<br>Reset | N/A  | N/A  | N/A  | N/A  | N/A  | 0       | 0        | 0        |
| Auto<br>PD   | N/A  | N/A  | N/A  | N/A  | N/A  | UC      | UC       | UC       |

#### 2.1.3 ENHANCED TAPE DRIVE REGISTER (TDR)

#### NOTE:

\*These bits are only available when EREG EN = 1, otherwise the bits are tri-stated.

This register allows the user to assign tape support to a particular drive during initialization. Any future references to that drive number automatically invokes tape support. Hardware reset clears this register; software resets have no effect. The tape select bits are hardware RESET to zeros, making Drive 0 **not** available for tape support. Drive 0 is reserved for the floppy boot drive.

The BOOTSEL bit in the 44 pin part is used to remap the drive selects and motor enables. The functionality is as described below:

| 44PD EN | BOOTSEL(TDR) |         |               | Mapping                                                                                        |
|---------|--------------|---------|---------------|------------------------------------------------------------------------------------------------|
| 0       | 0            | Default | $\rightarrow$ | DS0 → FDS0, ME0 → FDME0<br>DS1 → FDS1, ME1 → FDME1                                             |
| 0       | 1            |         |               | $DS0 \rightarrow FDS1, ME0 \rightarrow FDME1$<br>$DS1 \rightarrow FDS0, ME1 \rightarrow FDME0$ |
| 1       | x            |         | _             | $DS0 \rightarrow FDS0, ME0 \rightarrow FDME0$<br>$DS1 \rightarrow PD, ME1 \rightarrow IDLE$    |

The 44PD EN bit in the Auto Powerdown command has precedence over the BOOTSEL bit mapping as shown above.

#### 2.1.4 DATARATE SELECT REGISTER (DSR)

| Bits               | 7            | 6             | 5     | 4             | 3             | 2             | 1             | 0             |
|--------------------|--------------|---------------|-------|---------------|---------------|---------------|---------------|---------------|
| Function           | S/W<br>RESET | POWER<br>DOWN | PDOSC | PRE-<br>COMP2 | PRE<br>COMP1  | PRE<br>COMP0  | DRATE<br>SEL1 | DRATE<br>SEL0 |
| H/W Reset<br>State | 0            | 0             | 0     | 0             | 0             | 0             | 1             | 0             |
| Auto PD<br>State   | S/W<br>RESET | POWER<br>DOWN | PDOSC | PRE-<br>COMP2 | PRE-<br>COMP1 | PRE-<br>COMP0 | DRATE<br>SEL1 | DRATE<br>SEL0 |

This register ensures backward compatibility with the 82072 floppy controller and is write-only. Changing the data rate changes the timings of the drive control signals. To ensure that drive timings are not violated when changing data rates, choose a drive timing such that the fastest data rate will not violate the timing.

The PDOSC bit is used to implement crystal oscillator power management. The internal oscillator in the 82078 can be programmed to be either powered on or off via PDOSC. This capability is independent of the chip's powerdown state. Auto powerdown mode and powerdown via the POWERDOWN bit have no effect over the power state of the oscillator.

In the default state the PDOSC bit is low and the oscillator is powered up. When this bit is programmed to a one, the oscillator is shut off. Hardware reset clears this bit to a zero. Neither of the software resets (via DOR or DSR) have any effect on this bit. Note, PDOSC should only be set high when the part is in the powerdown state, otherwise the part will not function correctly and must be hardware reset once the oscillator has turned back on and stabilized. Setting the PDOSC bit has no effect on the clock input to the 82078 (the X1 pin). The clock input is separately disabled when the part is powered down. The SAVE command checks the status of PDOSC, however the RESTORE command will not restore the bit high.

S/W RESET behaves the same as DOR RESET except that this reset is self cleaning.

POWERDOWN bit implements direct powerdown. Setting this bit high will put the 82078 into the powerdown state regardless of the state of the part. The part is internally reset and then put into powerdown. No status is saved and any operation in progress is aborted. A hardware or software reset will exit the 82078 from this powerdown state.

PRECOMP 0-2 adjusts the WRDATA output to the disk to compensate for magnetic media phenomena known as bit shifting. The data patterns that are susceptible to bit shifting are well understood and the 82078 compensates the data pattern as it is written to the disk. The amount of pre-compensation is dependent upon the drive and media but in most cases the default value is acceptable.

| Table 2-2. Precompe | ensation Delays |
|---------------------|-----------------|
|---------------------|-----------------|

| PRECOMP    | Precompensation Delays |
|------------|------------------------|
| DSR[4,3,2] | x1 @ 24 MHz            |
| 111        | 0.00 ns - Disabled     |
| 001        | 41.67                  |
| 010        | 83.34                  |
| 011        | 125.00                 |
| 100        | 166.67                 |
| 101        | 208.33                 |
| 110        | 250.00                 |
| 000        | DEFAULT                |

| Data<br>Rate | Precompensation<br>Delays (ns) |
|--------------|--------------------------------|
| 1 Mbps       | 41.67                          |
| 0.5 Mbps     | 125                            |
| 0.3 Mbps     | 125                            |
| 0.25 Mbps    | 125                            |

The 82078 starts pre-compensating the data pattern starting on Track 0. The CONFIGURE command can change the track that pre-compensating starts on. Table 2-2 lists the pre-compensation values that can be selected and Table 2-3 lists the default pre-compensation values. The default value is selected if the three bits are zeroes.

DRATE 0-1 select one of the four data rates as listed in Table 2-4. The default value is 250 Kbps upon after a "Hardware" reset. Other "Software" Resets do not affect the DRATE or PRECOMP bits.

| Table 2-4. | Data Rates |
|------------|------------|
|------------|------------|

| DRATESEL0 | DRATESEL1 | DATA RATE |
|-----------|-----------|-----------|
| 1         | 1 .       | 1 Mbps    |
| 0         | 0         | 500 Kbps  |
| 0         | 1         | 300 Kbps  |
| 1         | 0         | 250 Kbps  |

#### 2.1.5 MAIN STATUS REGISTER (MSR)

| Bits            | 7   | 6   | 5          | 4          | 3    | 2    | 1            | 0            |
|-----------------|-----|-----|------------|------------|------|------|--------------|--------------|
| Function        | RQM | DIO | NON<br>DMA | CMD<br>BSY | RSVD | RSVD | DRV1<br>BUSY | DRV0<br>BUSY |
| H/W Reset State | 0   | х   | X          | X          | x    | X    | X            | x            |
| Auto PD State   | 1   | 0   | 0          | 0          | 0    | 0    | 0            | 0            |

The Main Status Register is a read-only register and is used for controlling command input and result output for all commands.

RQM—Indicates that the host can transfer data if set to 1. No access is permitted if set to a 0.

DIO—Indicates the direction of a data transfer once RQM is set. A 1 indicates a read and a 0 indicates a write is required.

NON-DMA—This mode is selected in the SPECIFY command and will be set to a 1 during the execution phase of a command. This is for polled data transfers and helps differentiate between the data transfer phase and the reading of result bytes.

COMMAND BUSY—This bit is set to a one when a command is in progress. It goes active after the command byte has been accepted and goes inactive at the end of the results phase. If there is no result phase (SEEK, RECALIBRATE commands), the bit returns to a 0 after the last command byte.

DRV x BUSY—These bits are set to ones when a drive is in the seek portion of a command, including seeks and recalibrates.

Some example values of the MSR are:

- MSR = 80H; The controller is ready to receive a command.
- MSR = 90H; executing a command or waiting for the host to read status bytes (assume DMA mode).
- MSR = D0H; waiting for the host to write status bytes.

#### 2.1.6 FIFO (DATA)

All command parameter information and disk data transfers go through the FIFO. The FIFO is 16 bytes in size and has programmable threshold values. Data transfers are governed by the RQM and DIO bits in the Main Status Register. The FIFO defaults to an 8272A compatible mode after a "Hardware" reset (Reset via pin 32). "Software" Resets (Reset via DOR or DSR register) can also place the 82078 into 8272A compatible mode if the LOCK bit is set to "0" (See the definition of the LOCK bit), maintaining PC-AT hardware compatibility. The default values can be changed through the CONFIGURE command (enable full FIFO operation with threshold control). The advantage of the FIFO is that it allows the system a larger DMA latency without causing a disk error. Table 2-5 gives several examples of the delays with a FIFO. The data is based upon the following formula:

Threshold#  $\times$  1/DATA RATE  $\times$  8 - 1.5  $\mu$ s = DELAY

Table 2-5. Delay Servicing Time

| FIFO Threshold<br>Examples | Maximum Delay to Servicing<br>at 1 Mbps Data Rate*  |
|----------------------------|-----------------------------------------------------|
| 1 byte                     | $1 \times 8 \mu s - 1.5 \mu s = 6.5 \mu s$          |
| 2 bytes                    | $2 \times 8 \mu s - 1.5 \mu s = 14.5 \mu s$         |
| 8 bytes                    | 8 × 8 μs − 1.5 μs = 62.5 μs                         |
| 15 bytes                   | $15 \times 8 \ \mu s - 1.5 \ \mu s = 118.5 \ \mu s$ |

#### NOTE:

\*Not available on the 82078-5.

| FIFO Threshold<br>Examples | Maximum Delay to Servicing<br>at 500 Kbps Data Rate* |  |  |  |
|----------------------------|------------------------------------------------------|--|--|--|
| 1 byte                     | $1 \times 16 \mu s - 1.5 \mu s = 14.5 \mu s$         |  |  |  |
| 2 bytes                    | $2 \times 16 \ \mu s - 1.5 \ \mu s = 30.5 \ \mu s$   |  |  |  |
| 8 bytes                    | $8 \times 16 \mu s - 1.5 \mu s = 126.5 \mu s$        |  |  |  |
| 15 bytes                   | 15 	imes 16 μs $-$ 1.5 μs $=$ 238.5 μs               |  |  |  |

At the start of a command, the FIFO action is always disabled and command parameters must be sent based upon the RQM and DIO bit settings. As the 82078 enters the command execution phase, it clears the FIFO of any data to ensure that invalid data is not transferred. An overrun or underrun will terminate the current command and the transfer of data. Disk writes will complete the current sector by generating a 00 pattern and valid CRC.

#### 2.1.7 DIGITAL INPUT REGISTER (DIR)

Only bit 7 is driven, all other bits remain tri-stated.

| Bits            | 7        | 6 | 5   | .4 | 3 | 2          | 1 | 0 |
|-----------------|----------|---|-----|----|---|------------|---|---|
| Function        | DSK CHG# |   |     | -  |   | <b>—</b> , | — | — |
| H/W Reset State | DSK CHG# |   | · _ | —  | _ | -          | — |   |
| Auto PD State   | 0        | _ | _   |    | _ | _          |   | — |

#### NOTE:

(---) means these bits are tri-stated.

DSKCHG# monitors the pin of the same name and reflects the opposite value seen on the disk cable. The DSKCHG# bit is forced inactive along with all the inputs from the floppy disk drive. All the other bits remain tri-stated.

#### 2.2 Reset

There are three sources of reset on the 82078; the RESET pin, a reset generated via a bit in the DOR and a reset generated via a bit in the DSR. All resets take the 82078 out of the powerdown state.

In entering the reset state, all operations are terminated and the 82078 enters an idle state. Activating reset while a disk write activity is in progress will corrupt the data and CRC.

On exiting the reset state, various internal registers are cleared, and the 82078 waits for a new command. Drive polling will start unless disabled by a new CONFIGURE command.

#### 2.2.1 RESET PIN ("HARDWARE") RESET

The RESET pin is a global reset and clears all registers except those programmed by the SPECIFY command. The DOR Reset bit is enabled and must be cleared by the host to exit the reset state.

#### 2.2.2 DOR RESET vs DSR RESET ("SOFTWARE" RESET)

These two resets are functionally the same. The DSR Reset is included to maintain 82072 compatibility. Both will reset the 8272 core which affects drive status information. The FIFO circuits will also be reset if the LOCK bit is a "0" (see definition of the LOCK bit). The DSR Reset clears itself automatically while the DOR Reset requires the host to manually clear it. DOR Reset has precedence over the DSR Reset. The DOR Reset is set automatically upon a pin RESET. The user must manually clear this reset bit in the DOR to exit the reset state. The t30a specification in the A.C. Specifications gives the minimum amount of time that the DOR reset must be held active. This amount of time that the DOR reset must be held active is dependent upon the data rate. 82078 requires that the DOR reset bit must be held active for at least 0.5  $\mu$ s at 250 Kbps. This is less than a typical ISA I/O cycle time.

#### 2.3 DMA Transfers

DMA transfers are enabled with the SPECIFY command and are initiated by the 82078 by activating the DRQ pin during a data transfer command. The FIFO is enabled directly by asserting DACK# and addresses need not be valid (CS# can be held inactive during DMA transfers).

#### 3.0 DRIVE INTERFACE

The 82078 has integrated all of the logic needed to interface to a floppy disk or a tape drive which use floppy interface. All drive outputs have 12 mA drive capability and all inputs use a receive buffer with hysteresis. The internal analog data separator requires no external components, yet allows for an extremely wide capture range with high levels of read-data jitter, and ISV. The designer needs only to run the 82078 disk drive signals to the disk or tape drive connector.

#### 3.1 Cable Interface

Generally, 5.25" drive uses open collector drivers and 3.5" drives use totem-pole drivers. The output buffers on the 82078 do not change between open collector or totem-pole, they are always totem-pole.

DRVDEN0 and DRVDEN1 connect to pins 2 and 6 or 33 (on most disk drives) to select the data rate sent from the drive to the 82078. The polarity of DRVDEN0 and DRVDEN1 can be programmed through the Drive Specification command (see the command description for more information).

#### 3.2 Host and FDD Interface Drivers

The chart below shows the drive capabilities of the 82078.

| Drive         | 3.3V                                   | 5.0V                                     |
|---------------|----------------------------------------|------------------------------------------|
| Requirement   | (I <sub>OL</sub> /I <sub>OH</sub> )    | (I <sub>OL</sub> /I <sub>OH</sub> )      |
| 82078 Drivers | FDD = 6  mA/-2  mA<br>SYS = 6 mA/-2 mA | FDD = 12  mA/-4  mA<br>SYS = 12 mA/-4 mA |

Today's floppy disk drives have reduced the output buffer's drive requirements on the floppy drive interface to 6 mA per drive at 5.0V. To support 2 drives, the drive output buffer drive capability needs to be 12 mA (at 5.0V). This is a reduction from 40 mA needed on the 82077SL. At 3.3V the 82078 halves the drive capability to 6 mA (3 mA per drive).

The slew rate control on the output buffers of the 82078 has been changed to reduce noise. The di/dt of the output drivers has been controlled such that the noise on the signal is minimized. The transition times are illustrated in the table below:

| Signai<br>Edge  | Transition<br>Time (ns) |
|-----------------|-------------------------|
| t <sub>HL</sub> | >5 ns                   |
| tLH             | >5 ns                   |

#### NOTE:

\*At 5.6V, 0°C, 50 pF load, 10% V<sub>CC</sub> to 90% V<sub>CC</sub>.

#### 3.3 Data Separator

The function of the data separator is to lock onto the incoming serial read data. When lock is achieved the serial front end logic of the chip is provided with a clock which is synchronized to the read data. The synchronized clock, called Data Window, is used to internally sample the serial data. One state of Data Window is used to sample the data portion of the bit cell, and the alternate state samples the clock portion. Serial to parallel conversion logic separates the read data into clock and data bytes.

To support reliable disk reads the data separator must track fluctuations in the read data frequency. Frequency errors primarily arise from two sources: motor rotation speed variation and instantaneous speed variation (ISV). A second condition, and one that opposes the ability to track frequency shifts is the response to bit jitter.

The internal data separator consists of two analog phase lock loops (PLLs) as shown in Figure 3-1. The two PLLs are referred to as the reference PLL and the data PLL. The reference PLL (the master PLL) is used to bias the data PLL (the slave PLL). The reference PLL adjusts the data PLL's operating point as a function of process, junction temperature and supply voltage. Using this architecture it was possible to eliminate the need for external trim components.



Figure 3-1. Data Separator Block Diagram

## int<sub>el</sub>.



Figure 3-2. Data PLL

Figure 3-2 shows the data PLL. The reference PLL has control over the loop gain by its influence on the charge pump and the VCO. In addition, the reference PLL controls the loop filter time constant. As a result, the closed loop transfer function of the data PLL is controlled, and immune to the first order, to environmental factors and process variation.

Systems with analog PLLs are often very sensitive to noise. In the design of this data separator, many steps were taken to avoid noise sensitivity problems. The analog section of the chip has a separate V<sub>SS</sub> pin (AV<sub>SS</sub>) which should be connected externally to a noise free ground. This provides a clean basis for V<sub>SS</sub> referenced signals. In addition, many analog circuit features were employed to make the overall system as insensitive to noise as possible.

#### 3.3.1 JITTER TOLERANCE

The jitter immunity of the system is dominated by the data PLL's response to phase impulses. This is measured as a percentage of the theoretical data window by dividing the maximum readable bit shift by a  $1/_4$  bitcell distance. For instance, if the maximum allowable bit shift is 300 ns for a 500 Kbps data stream, the jitter tolerance is 60%.

#### 3.3.2 LOCKTIME (tLOCK)

The lock, or settling time of the data PLL is designed to be 64-bit times (8 sync bytes). The value assumes that the sync field jitter is 5% the bit cell or less. This level of jitter is realistic for a constant bit pattern. Intersymbol interference should be equal, thus nearly eliminating random bit shifting.

#### 3.3.3 CAPTURE RANGE

Capture Range is the maximum frequency range over which the data separator will acquire phase lock with the incoming RDDATA signal. In a floppy disk environment, this frequency variation is composed of two components: drive motor speed error and ISV. Frequency is a factor which may determine the maximum level of the ISV (Instantaneous Speed Variation) component. In general, as frequency increases the allowed magnitude of the ISV component will decrease. When determining the capture range requirements, the designer should take the maximum amount of frequency error for the disk drive and double it to account for media switching between drives.

#### 3.4 Write Precompensation

The write precompensation logic is used to minimize bit shifts in the RDDATA stream from the disk drive. The shifting of bits is a known phenomena of magnetic media and is dependent upon the disk media AND the floppy drive.

The 82078 monitors the bit stream that is being sent to the drive. The data patterns that require precompensation are well known. Depending upon the pattern, the bit is shifted either early or late (or not at all) relative to the surrounding bits. Figure 3-3 is a block diagram of the internal circuit.

The top block is a 13-bit shift register with the no delay tap being in the center. This allows 6 levels of early and late shifting with respect to nominal. The shift register is clocked at the main clock rate (24 MHz). The output is fed into 2 multiplexors, one for early and one for late. A final stage of multiplexors combines the early, late and normal data stream back into one which is the WRDATA output.



Figure 3-3. Precompensation Block Diagram

#### 4.0 POWER MANAGEMENT FEATURES

The 82078 contains power management features that makes it ideal for design of portable personal computers. These features can be classified into power management of the part and that of the internal oscillator. The powerdown of the part is done independently of the internal oscillator in the 82078.

#### 4.1 Power Management Scheme

The portable market share of the personal computing market has increased significantly. To improve power conservation on portable platforms, designs are migrating from 5.0V to 3.3V. Intel's 82078-3 allows designers to incorporate 3.3V floppy disk controller support in their systems.

The 82078 supports two powerdown modes, direct powerdown and automatic powerdown. Direct powerdown refers to direct action by the software to powerdown without dependence on external factors. Automatic powerdown results from 82078's monitoring of the current conditions according to a previously programmed mode. Any hardware reset disables the automatic POWERDOWN command, however software resets have no effect on the command. The 82078 also supports powerdown of its internal crystal oscillator independent of the powerdown modes described above. By setting bit 5 (PDOSC) in the DSR register, the internal oscillator is turned off. This bit has sole control of the oscillator powerdown, allowing the internal clock to be turned off when an external oscillator is used.

#### 4.2 Oscillator Power Management

The 82078 supports a built-in crystal oscillator that can be programmed to be either powered down or active, independent of the power state of the chip. This capability is implemented by the PDOSC bit in the DSR. When PDOSC is set low, the internal oscillator is on. When PDOSC is set high, the internal oscillator is off. Note, a DSR powerdown does not turn off the oscillator.

When the external oscillator is used, power can be saved by turning off the internal oscillator. If the internal oscillator is used, the oscillator may be powered up (even when the rest of the chip is powered off) allowing the chip to wake up quickly and in a stable state. It is recommended to keep the internal oscillator on even when in the powerdown state. The main reason for this is that the recovery time of the oscillator during wake up may take tens of milliseconds under the worst case, which may create problems with any sensitive application software. In a typical application the internal oscillator should be on unless the system goes into a power saving or standby mode (such a mode request would be made by a system time out or by a user). In this case, the system software would take over and must turn on the oscillator sufficiently ahead of awakening the part.

In the case of the external oscillators, the power up characteristics are similar. If the external source remains active during the time the 82078 is powered down, then the recovery time effect is minimized. The PD# pin can be used to turn off the external source. While the PD# pin is active 82078 does not require a clock source. However, when the PD# pin is inactive, the clocking source, once it starts oscillating, must be completely stable to ensure that the 82078 operates properly.

#### 4.3 Part Power Management

This section deals with the power management of the rest of the chip excluding the oscillator. This section explains powerdown modes and wake up modes.

#### 4.3.1 DIRECT POWERDOWN

Direct powerdown is conducted via the POWER-DOWN bit in the DSR register (bit 6). Programming this bit high will powerdown 82078. All status is lost if this type of powerdown mode is used. The part can exit powerdown from this mode via any hardware or software reset. This type of powerdown overrides the automatic powerdown. When the part is in automatic powerdown and the DSR powerdown is issued, the previous status of the part is lost and the 82078 resets to software default values.

#### 4.3.2 AUTO POWERDOWN

Automatic powerdown is conducted via a "Powerdown Mode" command. There are four conditions required before the part will enter powerdown. All of these conditions must be true for the part to initiate the powerdown sequence. These conditions follow:

- 1. The motor enable pins FDME[0:1] must be inactive.
- The part must be idle; this is indicated by MSR = 80H and INT = 0 (INT may be high even if MSR = 80H due to polling interrupt).
- 3. The Head Unload Timer (HUT, explained in the SPECIFY command) must have expired.
- 4. The auto powerdown timer must have timed out.

The command can be used to enable powerdown by setting the AUTO PD bit in the command to high. The command also provides a capability of programming a minimum power up time via the MIN DLY bit in the command. The minimum power up time refers to a minimum amount of time the part will remain powered up after being awakened or reset. An internal timer is initiated as soon as the auto powerdown command is enabled. The part is then powered down provided all the remaining conditions are met. Any software reset will reinitialize the timer. Changing of data rate extends the auto powerdown timer by up to 10 ms, but only if the data rate is changed during the countdown.

Disabling the auto powerdown mode cancels the timers and holds the 82078 out of auto powerdown.

The IDLE # pin can be masked via the IDLEMSK bit in Status Register B (EREG EN = 1).

#### 4.3.3 WAKE UP MODES

This section describes the conditions for awakening the part from both direct and automatic powerdown. Power conservation or extension of battery life is the main reason power management is required. This means that the 82078 must be kept in powerdown state as long as possible and should be powered up as late as possible without compromising software transparency.

To keep the part in powerdown mode as late as possible implies that the part should wake up as fast as possible. However, some amount of time is required for the part to exit powerdown state and prepare the internal microcontroller to accept commands. Application software is very sensitive to such a delay and in order to maintain software transparency, the recovery time of the wake up process must be carefully controlled by the system software.

#### 4.3.3.1 Wake Up from DSR Powerdown

If the 82078 enters the powerdown through the DSR powerdown bit, it must be reset to exit. Any form of software or hardware reset will serve, although DSR is recommended. No other register access will awaken the part, including writing to the DOR's motor enable (FDME[0:1]) bits.

If DSR powerdown is used when the part is in auto powerdown, the DSR powerdown will override the auto powerdown. However, when the part is awakened by a software reset, the auto powerdown command (including the minimum delay timer) will once again become effective as previously programmed. If the part is awakened via a hardware reset, the auto powerdown is disabled.

After reset, the part will go through a normal sequence. The drive status will be initialized. The FIFO mode will be set to default mode on a hardware reset or on a software reset if the LOCK command has not blocked it. Finally, after a delay, the polling interrupt will be issued.

#### 4.3.3.2 Wake Up from Auto Powerdown

If the part enters the powerdown state through the auto powerdown mode, then the part can be awakened by reset or by appropriate access to certain registers.

If a hardware or software reset is used then the part will go through the normal reset sequence. If the access is through the selected registers, then the 82078 resumes operation as though it was never in powerdown. Besides activating the RESET pin or

one of the software reset bits in the DOR or DSR, the following register accesses will wake up the part:

- Enabling any one of the motor enable bits in the DOR register (reading the DOR does not awaken the part)
- 2. A read from the MSR register
- 3. A read or write to the FIFO register

Any of these actions will wake up the part. Once awake, 82078 will reinitiate the auto powerdown timer for 10 ms or 0.5s (depending on the MIN DLY bit the auto powerdown command). The part will powerdown again when all the auto powerdown conditions are satisfied.

#### 4.4 Register Behavior

The register descriptions and their values in the powerdown state are listed in the Microprocessor Interface section. Table 4-1 reiterates the configuration registers available. It also shows the type of access permitted. In order to maintain software transparency, access to all the registers must be maintained. As Table 4-1 shows, two sets of registers are distinguished based on whether their access results in the part remaining in powerdown state or exiting it.

| Address   | Available Registers                                    | Access |  |  |  |
|-----------|--------------------------------------------------------|--------|--|--|--|
|           | Access to these registers<br>DOES NOT wake up the part |        |  |  |  |
| 000       |                                                        |        |  |  |  |
| 001       | SRB (EREG EN = 1)                                      | R/W    |  |  |  |
| 010       | DOR*                                                   | R/W    |  |  |  |
| 011       | TDR                                                    | R/W    |  |  |  |
| 100       | DSR*                                                   | W      |  |  |  |
| 110       | _                                                      | —      |  |  |  |
| 111       | DIR                                                    | R      |  |  |  |
| 111       | CCR                                                    | w      |  |  |  |
| Access to | Access to these registers wakes up the part            |        |  |  |  |
| 100       | MSR                                                    | R      |  |  |  |
| 101       | FIFO                                                   | R/W    |  |  |  |

#### Table 4-1. 82078 Register Behavior

#### NOTE:

\*Writing to the DOR or DSR does not wake up the part, however, writing any of the motor enable bits or doing a software reset (either via DOR or DSR reset bits) will wake up the part. Access to all other registers is possible without awakening the part. These registers can be accessed during powerdown without changing the status of the part. A read from these registers will reflect the true status as shown in the register description in Section 2.1. A write to the part will result in the part retaining the data and subsequently reflecting it when the part awakens. Accessing the part during powerdown may cause an increase in the power consumption by the part. The part will revert back to its low power mode when the access has been completed. None of the extended registers effect the behavior of the powerdown mode.

#### 4.5 Pin Behavior

The 82078 is specifically designed for the portable PC systems in which the power conservation is a primary concern. This makes the behavior of the pins during powerdown very important.

The pins of 82078 can be divided into two major categories; system interface and floppy disk drive interface. The floppy disk drive pins are disabled such that no power will be drawn through the 82078 as a result of any voltage applied to the pin within the 82078's power supply range. The floppy disk drive interface pins are configurable by the FDI TRI bit in the auto powerdown command. When the bit is set the output pins of the floppy disk drive retain their original state. All other pins are either disabled or unchanged as depicted in Table 4-4. Most of the system interface pins are left active to monitor system accesses that may wake up the part.

#### 4.5.1 System Interface Pins

Table 4-2 gives the state of the system interface pins in the powerdown state. Pins unaffected by powerdown are labeled "UC". Input pins are "DIS-ABLED" to prevent them from causing currents internal to the 82078 when they have indeterminate input values.

| System<br>Pins | State In<br>Power Down | System<br>Pins | State In<br>Power Down         |
|----------------|------------------------|----------------|--------------------------------|
| Ir             | iput Pins              | Output Pins    |                                |
| CS#            | UC                     | DRQ            | UC (Low)                       |
| RD#            | UC                     | INT            | UC (Low)                       |
| WR#            | UC                     | PD#*           | HIGH                           |
| A[0:2]         | UC                     | IDLE#*         | High (Auto PD)<br>Low (DSR PD) |
| DB[0:7]        | UC                     | DB[0:7]        | UC                             |
| RESET          | UC                     |                |                                |
| DACK#          | Disabled               |                |                                |
| TC             | Disabled               | 1              |                                |
| X[1:2]         | Programmable           |                |                                |

**Table 4-2. System Interface Pins** 

#### NOTE:

\*These pins are muxed with FDS1 and FDME1 and are only available when 44PD EN = 1.

Two pins which can be used to indicate the status of the part are IDLE # and PD#. Table 4-3 shows how these pins reflect the 82078 status. Note that these pins are only enabled when 44PD EN = 1.

| PD | IDLE | MSR                      | Part Status    |
|----|------|--------------------------|----------------|
| 1  | 1    | 80H                      | Auto Powerdown |
| 1  | 0    | RQM = 1;<br>MSR[6:0] = X | DSR Powerdown  |
| 0  | 1    | 80H                      | ldle           |
| 0  | 0    | _                        | Busy           |

Table 4-3. 82078 Status Pins

The IDLE# pin indicates when the part is in idle state and can be powered down. It is a combination of MSR equaling 80H, the head being unloaded and the INT pin being low. As shown in the table, the IDLE# pin will be low when the part is in DSR powerdown state. The PD# pin is active whenever the part is in the powerdown state. It is active for either mode of powerdown. The PD# pin can be used to turn off an external oscillator of other floppy disk drive interface hardware.

#### 4.5.2 FDD INTERFACE PINS

The FDD interface "input" pins during powerdown are disabled or unchanged as shown in Table 4-4. The floppy disk drive "output" pins are programmable by the FDI TRI bit in the auto powerdown command. Setting of the FDI TRI bit in the auto power down command results in the interface retaining its normal state. When this bit is low (default state) all output pins in the FDD interface to the floppy disk drive itself are tri-stated. Pins used for local logic control or part programming are unaffected. Table 4-4 depicts the state of the floppy disk interface pins in the powerdown state (FDI TRI is low).

| Table 4-4. 02070 FDD Internace Fins |                                    |                  |                       |  |  |
|-------------------------------------|------------------------------------|------------------|-----------------------|--|--|
| FDD Pins                            | FDD Pins State In<br>Powerdown FDD |                  | State In<br>Powerdown |  |  |
| Input Pins                          |                                    | Outpu<br>(FDI TR |                       |  |  |
| RDDATA#                             | Disabled                           | FDME[0:1] #      | Tristated             |  |  |
| WP#                                 | Disabled                           | FDS[0:1] #       | Tristated             |  |  |
| TRK0#                               | Disabled                           | DIR#             | Tristated             |  |  |
| INDX#                               | Disabled                           | STEP#            | Tristated             |  |  |
| DSKCHG#                             | Disabled                           | WRDATA#          | Tristated             |  |  |
|                                     |                                    | WE#              | Tristated             |  |  |
|                                     |                                    | HDSEL#           | Tristated             |  |  |
|                                     |                                    | DRVDEN[0:1]      | Tristated             |  |  |

Table 4-4. 82078 FDD Interface Pins

#### 5.0 CONTROLLER PHASES

For simplicity, command handling in the 82078 can be divided into three phases: Command, Execution and Result. Each phase is described in the following sections.

When there is no command in progress, the 82078 can be in idle, drive polling or powerdown state.

#### 5.1 Command Phase

After a reset, the 82078 enters the command phase and is ready to accept a command from the host. For each of the commands, a defined set of command code bytes and parameter bytes has to be written to the 82078 before the command phase is complete (Please refer to Section 6.0 for the command descriptions). These bytes of data must be transferred in the order prescribed.

Before writing to the 82078, the host must examine the RQM and DIO bits of the Main Status Register. RQM, DIO must be equal to "1" and "0" respectively before command bytes may be written. RQM is set false by the 82078 after each write cycle until the received byte is processed. The 82078 asserts RQM again to request each parameter byte of the command, unless an illegal command condition is detected. After the last parameter byte is received, RQM remains "0", and the 82078 automatically enters the next phase as defined by the command definition.

## int<sub>el</sub>.

The FIFO is disabled during the command phase to retain compatibility with the 8272A, and to provide for the proper handling of the "Invalid Command" condition.

#### 5.2 Execution Phase

All data transfers to or from the 82078 occur during the execution phase, which can proceed in DMA or non-DMA mode as indicated in the SPECIFY command.

Each data byte is transferred by an INT or DRQ depending on the DMA mode. The CONFIGURE command can enable the FIFO and set the FIFO threshold value.

The following paragraphs detail the operation of the FIFO flow control. In these descriptions, (threshold) is defined as the number of bytes available to the 82078 when service is requested from the host, and ranges from 1 to 16. The parameter FIFOTHR which the user programs is one less, and ranges from 0 to 15.

A low threshold value (i.e. 2) results in longer periods of time between service requests, but requires faster servicing of the request, for both read and write cases. The host reads (writes) from (to) the FIFO until empty (full), then the transfer request goes inactive. The host must be very responsive to the service request. This is the desired case for use with a "fast" system.

A high value of threshold (i.e. 12) is used with a "sluggish" system by affording a long latency period after a service request, but results in more frequent service requests.

#### 5.2.1 NON-DMA MODE, TRANSFERS FROM THE FIFO TO THE HOST

The INT pin and RQM bits in the Main Status Register are activated when the FIFO contains 16 (or set threshold) bytes, or the last bytes of a full sector transfer have been placed in the FIFO. The INT pin can be used for interrupt driven systems and RQM can be used for polled sytems. The host must respond to the request by reading data from the FIFO. This process is repeated until the last byte is transferred out of the FIFO, then 82078 deactivates the INT pin and RQM bit.

#### 5.2.2 NON-DMA MODE, TRANSFERS FROM THE HOST TO THE FIFO

The INT pin and RQM bit in the Main Status Register are activated upon entering the execution phase of data transfer commands. The host must respond to the request by writing data into the FIFO. The INT pin and RQM bit remain true until the FIFO becomes full. They are set true again when the FIFO has (threshold) bytes remaining in the FIFO. The INT pin will also be deactivated if TC and DACK# both go inactive. The 82078 enters the result phase after the last byte is taken by the 82078 from the FIFO (i.e. FIFO empty condition).

### 5.2.3 DMA MODE, TRANSFERS FROM THE FIFO TO THE HOST

The 82078 activates the DRQ pin when the FIFO contains 16 (or set threshold) bytes, or the last byte of a full sector transfer has been placed in the FIFO. The DMA controller must respond to the request by reading data from the FIFO. The 82078 will deactivate the DRQ pin when the FIFO becomes empty. DRQ goes inactive after DACK# goes active for the last byte of a data transfer (or on the active edge of RD#, on the last byte, if no edge is present on DACK#) Note that DACK# and TC must overlap for at least 50 ns for proper functionality.

#### 5.2.4 DMA MODE, TRANSFERS FROM THE HOST TO THE FIFO

The 82078 activates the DRQ pin when entering the execution phase of the data transfer commands. The DMA controller must respond by activating the DACK# and WR# pins and placing data in the FIFO. DRQ remains active until the FIFO becomes full. DRQ is again set true when the FIFO has (threshold) bytes remaining in the FIFO. The 82078 will also deactivate the DRQ pin when TC becomes true (qualified by DACK# by overlapping by 50 ns), indicating that no more data is required. DRQ goes inactive after DACK# goes active for the last byte of a data transfer (or on the active edge of WR# of the last byte, if no edge is present on DACK#).

### int<sub>el</sub>.

#### 5.2.5 DATA TRANSFER TERMINATION

The 82078 supports terminal count explicitly through the TC pin and implicitly through the underrun/overrun and end-of-track (EOT) functions. For full sector transfers, the EOT parameter can define the last sector to be transferred in a single or multisector transfer. If the last sector to be transferred is a partial sector, the host can stop transferring the data in mid-sector, and the 82078 will continue to complete the sector as if a hardware TC was received. The only difference between these implicit functions and TC is that they return "abnormal termination" result status. Such status indications can be ignored if they were expected.

Note that when the host is sending data to the FIFO of the 82078, the internal sector count will be complete when 82078 reads the last byte from its side of the FIFO. There may be a delay in the removal of the transfer request signal of up to the time taken for the 82078 to read the last 16 bytes from the FIFO. The host must tolerate this delay.

#### 5.3 Result Phase

The generation of INT determines the beginning of the result phase. For each of the commands, a de-

fined set of result bytes has to be read from the 82078 before the result phase is complete. (Refer to Section 6.0 on command descriptions.) These bytes of data must be read out for another command to start.

RQM and DIO must both equal "1" before the result bytes may be read from the FIFO. After all the result bytes have been read, the RQM and DIO bits switch to "1" and "0" respectively, and the CB bit is cleared. This indicates that the 82078 is ready to accept the next command.

#### 6.0 COMMAND SET/DESCRIPTIONS

Commands can be written whenever the 82078 is in the command phase. Each command has a unique set of needed parameters and status results. The 82078 checks to see that the first byte is a valid command and, if valid, proceeds with the command. If it was invalid, the next time the RQM bit in the MSR register is a "1" the DIO and CB bits will also be "1", indicating the FIFO must be read. A result byte of 80H will be read out of the FIFO, indicating an invalid command was issued. After reading the result byte from the FIFO the 82078 will return to the command phase. Table 6-1 is a summary of the Command set.

#### 82078 44 PIN

#### Table 6-1. 82078 Command Set

| Phase     | R/W    | DATA BUS |                |                |                |                |     |                                       |     | Remarks                                             |  |
|-----------|--------|----------|----------------|----------------|----------------|----------------|-----|---------------------------------------|-----|-----------------------------------------------------|--|
|           |        | D7       | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | Ð2  | D <sub>1</sub>                        | Do  |                                                     |  |
|           |        |          |                |                |                | DDATA          |     |                                       |     |                                                     |  |
| Command   | W      | мт       | MFM<br>0       | SK             | 0              | 0              | 1   | 1                                     | 0   | Command Codes                                       |  |
|           | w      | 0        | U              | 0              | c              | 0              | HDS | DS1                                   | DS0 | Sector ID Information Drive                         |  |
|           | Ŵ      |          |                |                |                |                |     |                                       |     | Sector ID Information Prior<br>to Command Execution |  |
|           | Ŵ      |          |                |                |                | <u></u>        |     |                                       |     | to command Excoution                                |  |
|           | w      |          |                |                |                |                |     |                                       |     |                                                     |  |
|           | Ŵ      |          |                |                | EOT            |                |     |                                       |     |                                                     |  |
|           | Ŵ      |          |                |                |                |                |     |                                       |     |                                                     |  |
|           | ŵ      |          |                |                |                |                |     |                                       |     |                                                     |  |
| Execution |        |          |                |                | 2.1            |                |     |                                       |     | Data Transfer Between the<br>FDD and System         |  |
| Desult    |        |          |                |                | et o           |                |     |                                       |     | Chabus Information After                            |  |
| Result    | R      |          |                |                | ST 0           |                |     |                                       |     | Status Information After<br>Command Execution       |  |
|           | R      |          |                |                |                |                |     |                                       |     | Command Execution                                   |  |
|           | R      |          |                |                |                |                |     |                                       |     |                                                     |  |
|           | R      |          |                |                | й              |                |     |                                       |     | Sector ID Information After                         |  |
|           | R      |          |                |                |                |                |     |                                       |     | Command Execution                                   |  |
|           | R      |          |                |                |                |                |     |                                       |     |                                                     |  |
|           |        |          |                |                | READ DE        |                |     | · · · · · · · · · · · · · · · · · · · |     |                                                     |  |
| Command   | w      | MT       | MFM            | SK             | 0              | 1              | 1   | 0                                     | 0   | Command Codes                                       |  |
|           | W      | 0        | 0              | 0              | 0              | 0              | HDS | DS1                                   | DS0 |                                                     |  |
|           | W      | <u></u>  |                |                |                |                |     |                                       |     | Sector ID Information Prior                         |  |
|           | W      |          |                |                |                |                |     |                                       |     | to Command Execution                                |  |
|           | W      |          |                |                |                |                |     |                                       |     |                                                     |  |
|           | W      |          |                |                |                |                |     |                                       |     |                                                     |  |
|           | w<br>w |          |                |                | EU1            |                |     |                                       |     |                                                     |  |
|           | w      |          |                |                |                |                |     |                                       |     |                                                     |  |
| Execution | vv     |          |                |                |                |                |     |                                       |     | Data Transfer Between the                           |  |
|           |        |          |                |                |                |                |     |                                       |     | FDD and System                                      |  |
| Result    | R      |          |                |                | ST 0           |                |     |                                       |     | Status Information After                            |  |
|           | R      |          |                |                | ST 1           |                |     |                                       |     | Command Execution                                   |  |
|           | R      |          |                |                | ST 2           |                |     |                                       |     |                                                     |  |
|           | R      |          |                |                |                |                |     |                                       |     | 0.1.1017                                            |  |
|           | R      |          |                |                |                |                |     |                                       |     | Sector ID Information After<br>Command Execution    |  |
|           | R      |          |                |                |                |                |     |                                       |     | Command Execution                                   |  |
| ·····     | R      |          |                |                |                |                |     |                                       |     |                                                     |  |
| Command   | w      | MT       | MFM            | 0              | 0              | E DATA         | 1   | 0                                     | 1   | Command Codes                                       |  |
| Command   | ŵ      | 0        | 0              | ŏ              | õ              | õ              | HDS | DS1                                   | DS0 | Command Coulds                                      |  |
|           | W      |          |                |                |                |                |     |                                       |     | Sector ID Information Prior                         |  |
|           | W      |          |                |                |                |                |     |                                       |     | to Command Execution                                |  |
|           | w      |          |                |                | R              |                |     |                                       |     |                                                     |  |
|           | W      |          |                |                |                |                |     | - ,                                   |     |                                                     |  |
|           | W      |          |                |                | EOT            |                |     |                                       |     |                                                     |  |
|           | W      |          |                |                |                |                |     |                                       |     |                                                     |  |
| Fuendar   | w      |          |                |                | DTL            |                |     |                                       |     | Data Transfer Dature "                              |  |
| Execution |        |          |                |                |                |                |     |                                       |     | Data Transfer Between the<br>FDD and System         |  |
| Result    | R      |          |                |                |                |                |     |                                       |     | Status Information After                            |  |
|           | R      |          |                |                |                |                |     |                                       |     | Command Execution                                   |  |
|           | R      |          |                |                | ST 2           |                |     |                                       |     |                                                     |  |
|           | R      |          |                |                | c              |                |     | · · · · · ·                           |     |                                                     |  |
|           |        |          |                |                |                |                |     |                                       |     | Sector ID Information After                         |  |
|           | R      |          |                |                |                |                |     |                                       |     |                                                     |  |
|           | R      |          |                |                |                |                |     |                                       |     | Command Execution                                   |  |

#### 82078 44 PIN

### intel

| Phase     | R/W              |             |                                        |                | D      | ATA B                   | US             |                                       |            |          | Remarks                                                            |
|-----------|------------------|-------------|----------------------------------------|----------------|--------|-------------------------|----------------|---------------------------------------|------------|----------|--------------------------------------------------------------------|
|           |                  | D7          | D <sub>6</sub>                         | D <sub>5</sub> | D4     |                         | D <sub>3</sub> | D <sub>2</sub>                        | <b>D</b> 1 | Do       |                                                                    |
| -         |                  | · · · · · · |                                        |                |        | TE DEI                  | ETED I         |                                       |            |          | · · · · · · · · · · · · · · · · · · ·                              |
| Command   | W                | MT          | MFM                                    | 0              | 0      |                         | 0              | 0                                     | 0          | 1        | Command Codes                                                      |
|           | W<br>W           | 0           | 0                                      | 0              | 0      | с                       | U              | HDS                                   | DS1        | DS0      | Sector ID Information Prior                                        |
|           | Ŵ                |             |                                        |                |        |                         |                |                                       |            |          | to Command Execution                                               |
|           | Ŵ                |             |                                        |                |        |                         |                |                                       |            |          |                                                                    |
|           | Ŵ                |             |                                        |                |        |                         |                |                                       |            |          |                                                                    |
|           | w                |             |                                        |                |        |                         |                |                                       |            |          |                                                                    |
|           | w                |             |                                        |                |        |                         |                |                                       |            |          |                                                                    |
|           | w                |             |                                        |                |        | DTL                     |                |                                       |            |          |                                                                    |
| Execution |                  |             |                                        |                |        |                         |                |                                       |            |          | Data Transfer Between the<br>FDD and System                        |
| Result    | R                |             |                                        |                |        |                         |                |                                       |            |          | Status Information After                                           |
|           | R                |             |                                        |                |        |                         |                |                                       |            |          | Command Execution                                                  |
|           | R                |             |                                        |                |        |                         |                |                                       |            |          |                                                                    |
|           | R                |             | ····· · · ·                            |                |        |                         |                |                                       |            |          |                                                                    |
|           | R                |             |                                        |                |        |                         |                |                                       |            |          | Sector ID Information After<br>Command Execution                   |
|           | R.<br>R          |             |                                        |                |        |                         |                |                                       |            |          | Command Execution                                                  |
|           | <u>n</u>         |             |                                        |                |        |                         | TRACK          | ,                                     |            |          | · · · · · · · · · · · · · · · · · · ·                              |
| Command   | w                | 0           | MFM                                    | 0              | 0      |                         |                | 0                                     | 1          | 0        | Command Codes                                                      |
| Communia  | ŵ                | ŏ           | 0                                      | ŏ              | ŏ      |                         | ŏ.             |                                       | DS1        | DSO      | Command Couco                                                      |
|           | w                |             |                                        |                |        | С.                      |                |                                       | -          | h        | Sector ID Information Prior                                        |
|           | w                |             |                                        |                |        |                         |                |                                       |            |          | to Command Execution                                               |
|           | w                |             |                                        |                |        |                         |                |                                       |            | _        |                                                                    |
|           | w                |             |                                        |                |        | N.                      |                |                                       |            |          |                                                                    |
|           | W                |             |                                        |                |        | EOT                     |                |                                       |            | _        |                                                                    |
|           | W                | ·           |                                        |                |        | GPL .                   |                |                                       |            |          |                                                                    |
| -         | w                |             |                                        |                |        | DIL                     |                |                                       |            |          | Data Transfer Between the                                          |
| Execution |                  |             |                                        |                |        |                         |                |                                       |            |          | FDD and System. FDC<br>Reads All Sectors from<br>Index Hole to EOT |
| Result    | R                |             |                                        |                |        | ST 0                    |                |                                       |            |          | Status Information After                                           |
|           | R                |             |                                        |                |        |                         |                |                                       |            |          | Command Execution                                                  |
|           | R                |             |                                        |                |        |                         |                |                                       |            |          | - 10 - 10 - 10 - 10 - 10 - 10 - 10 - 10                            |
|           | R                |             |                                        |                |        |                         |                |                                       |            |          |                                                                    |
|           | R                |             |                                        |                |        |                         |                | · · · · · · · · · · · · · · · · · · · |            |          | Sector ID Information After                                        |
|           | R                |             |                                        |                |        |                         |                |                                       |            |          | Command Execution                                                  |
|           | R                |             |                                        |                |        |                         |                |                                       |            |          |                                                                    |
| 0         |                  | 1.47        | LACLA                                  | 01/            |        |                         | RIFY<br>0      | 1                                     |            |          | 0                                                                  |
| Command   | W                | MT<br>EC    | MFM<br>0                               | SK<br>0        | 1<br>0 |                         | 0              | HDS                                   | 1<br>DS1   | 0<br>DS0 | Command Codes                                                      |
|           | Ŵ                |             | v                                      | Ū              | v      | с                       | v              | 1100                                  | 001        | 000      | Sector ID Information Prior                                        |
|           | ŵ                |             |                                        |                |        |                         |                |                                       |            |          | to Command Execution                                               |
|           | Ŵ                |             |                                        |                |        |                         |                |                                       |            |          |                                                                    |
|           | ŵ                |             |                                        |                |        | N                       |                |                                       |            |          |                                                                    |
|           | Ŵ                |             |                                        |                |        | EOT                     |                |                                       |            |          |                                                                    |
|           | Ŵ                |             |                                        |                |        | GPL                     |                |                                       |            |          |                                                                    |
|           | w                |             |                                        |                | C      | DTL/SO                  | 2              |                                       |            |          |                                                                    |
| Execution |                  |             |                                        |                |        |                         |                |                                       |            |          | No Data Transfer Takes<br>Place                                    |
|           |                  | 1. S.       |                                        |                |        | ST 0                    |                |                                       |            |          | Status Information After                                           |
| Result    | R                |             |                                        |                |        | ST 1                    |                |                                       |            |          | Command Execution                                                  |
| Result    | R                |             |                                        |                |        |                         |                |                                       |            |          | 1                                                                  |
| Result    |                  |             |                                        |                |        | ST 2                    |                |                                       |            | _        |                                                                    |
| Result    | R<br>R<br>R      |             |                                        |                |        | С                       |                |                                       |            |          |                                                                    |
| Result    | R<br>R<br>R      |             | · · · · · · · · · · · · · · · · · · ·  |                |        | С<br>Н                  |                |                                       |            |          | Sector ID Information After                                        |
| Result    | R<br>R<br>R<br>R |             |                                        |                |        | C<br>H<br>R             |                |                                       |            | `        | Sector ID Information After<br>Command Execution                   |
| Result    | R<br>R<br>R      |             | ······································ |                |        | C<br>H<br>R<br>N        |                |                                       |            | <br>     |                                                                    |
| Result    | R<br>R<br>R<br>R | 0           | 0                                      | 0              |        | C<br>H<br>R<br>N<br>VEF |                | 0                                     | 0          |          |                                                                    |

#### Table 6-1. 82078 Command Set (Continued)

#### 82078 44 PIN

| Phase R/W |   |    |                | Remarks        |        |                |                                       |                                                                                                                 |          |                                       |
|-----------|---|----|----------------|----------------|--------|----------------|---------------------------------------|-----------------------------------------------------------------------------------------------------------------|----------|---------------------------------------|
|           |   | D7 | D <sub>6</sub> | D <sub>5</sub> | D4     | D <sub>3</sub> | D <sub>2</sub>                        | D <sub>1</sub>                                                                                                  | Do       | nomarks                               |
|           |   |    |                |                | FOR    | MAT TRA        | СК                                    |                                                                                                                 |          | ·                                     |
| Command   | w | 0  | MFM            | 0              | 0      | 1              | 1                                     | 0                                                                                                               | 1        | Command Codes                         |
|           | w | 0  | 0              | 0              | 0      | 0              | HDS                                   | DS1                                                                                                             | DS0      |                                       |
|           | w |    | ·              |                |        | N              |                                       |                                                                                                                 |          | Bytes/Sector                          |
|           | W |    |                |                |        | C              |                                       | An aire                                                                                                         |          | Sectors/Cylinder                      |
|           | W |    |                |                |        | PL             |                                       |                                                                                                                 |          | Gap3                                  |
|           | w |    |                |                | _ '    | C              | t                                     |                                                                                                                 |          | Filler Byte                           |
| Execution |   |    |                |                |        |                |                                       |                                                                                                                 |          |                                       |
| For Each  | w |    |                |                | (      | 2              |                                       |                                                                                                                 |          |                                       |
| Sector    | Ŵ |    |                |                |        | -              |                                       |                                                                                                                 |          | Input Sector                          |
| Repeat:   | w |    |                |                |        | 7              |                                       |                                                                                                                 |          | Parameters                            |
|           | w |    |                |                |        | Ň              |                                       |                                                                                                                 |          |                                       |
|           |   |    |                |                |        |                |                                       |                                                                                                                 |          |                                       |
|           |   |    |                |                |        |                |                                       |                                                                                                                 |          | 82078 Formats an Entire<br>Cylinder   |
| Result    | R |    |                |                | _ 51   | го             |                                       | Hold of the second s |          | Status Information After              |
|           | R |    | A data         |                | S1     | ľ 1            |                                       |                                                                                                                 |          | Command Execution                     |
|           | R |    |                |                |        | 2              |                                       |                                                                                                                 |          |                                       |
|           | R |    |                |                | _ Unde | fined          |                                       |                                                                                                                 |          |                                       |
|           | R |    |                |                | Unde   | fined          |                                       |                                                                                                                 |          |                                       |
|           | R |    |                |                | Unde   | fined          |                                       |                                                                                                                 |          |                                       |
|           | R |    |                |                | _ Unde | fined          |                                       |                                                                                                                 | <u> </u> |                                       |
|           |   |    |                |                | SC     | AN EQUA        | L                                     |                                                                                                                 |          | · · · · · · · · · · · · · · · · · · · |
| Command   | w | мт | MFM            | SK             | 1      | 0              | 0                                     | 0                                                                                                               | 0        | Command Codes                         |
|           | w | 0  | 0              | 0              | 0      | 0              | HDS                                   | DS1                                                                                                             | DS0      |                                       |
|           | w |    |                |                |        | 0              |                                       |                                                                                                                 |          | Sector ID Information                 |
|           | w |    |                |                |        | -              |                                       |                                                                                                                 |          | Prior to Command                      |
|           | w |    |                |                |        | 7              |                                       |                                                                                                                 |          | Execution                             |
|           | w |    |                |                |        | N .            |                                       |                                                                                                                 |          |                                       |
|           | w |    |                |                | _ EC   |                |                                       |                                                                                                                 |          |                                       |
|           | w |    |                |                | _ G    |                |                                       | · · · · · · · · · · · · · · · · · · ·                                                                           |          |                                       |
|           | w |    |                |                | _ S    | TP             |                                       |                                                                                                                 |          |                                       |
| Execution |   |    |                |                |        |                |                                       |                                                                                                                 |          | Data Compared                         |
|           |   |    |                |                |        |                |                                       |                                                                                                                 |          | Between the FDO                       |
|           |   |    |                |                |        |                |                                       |                                                                                                                 |          | and Main-System                       |
| Result    | R |    |                |                | S1     | ro .           |                                       |                                                                                                                 |          | Status Information                    |
|           | R |    |                |                |        | Г <b>1</b> .   |                                       |                                                                                                                 |          | After Command                         |
|           | R |    |                |                | _      | [2]            |                                       |                                                                                                                 |          | Execution                             |
|           | R |    |                |                |        | ς.             |                                       |                                                                                                                 |          |                                       |
|           | R |    |                |                |        | H .            |                                       |                                                                                                                 |          | Sector ID Information                 |
|           | R |    |                |                | _      | <b>٦</b> .     | · · · · · · · · · · · · · · · · · · · |                                                                                                                 |          | After Command                         |
|           | R |    |                |                | 1      | N              |                                       |                                                                                                                 |          | Execution                             |

#### Table 6-1. 82078 Command Set (Continued)

#### 82078 44 PIN

| Phase     | R/W    | -  |                |                | DA             | TA BU        | IS             |                |                |                                       | Remarks                               |
|-----------|--------|----|----------------|----------------|----------------|--------------|----------------|----------------|----------------|---------------------------------------|---------------------------------------|
| Phase     | H/W    | D7 | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | -            | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub>                        | Remarks                               |
|           |        |    |                |                | SCA            | LOW          | ORE            | QUAL           |                |                                       | · · · · · · · · · · · · · · · · · · · |
| Command   | w      | MT | MFM            | SK             | 1              |              | 1              | 0              | 0              | 1 \                                   | Command Codes                         |
|           | w      | 0  | 0              | 0              | 0              |              | 0              | HDS            | DS1            | DS0                                   |                                       |
|           | w      |    |                |                | _              | С            |                |                |                |                                       | Sector ID Information                 |
|           | W      | ·  |                |                | -              | н            |                |                |                |                                       | Prior to Command                      |
|           | w      |    |                |                | -              | R            |                |                | · · · · ·      |                                       | Execution                             |
|           | w      |    |                |                | -              | N            |                |                |                |                                       |                                       |
|           | w      |    |                |                |                | EOT<br>GPL   |                |                |                |                                       |                                       |
|           | w      |    |                |                |                | STP          |                |                |                |                                       |                                       |
|           | , w    |    |                |                | -              | 315          | •              |                |                |                                       |                                       |
| Execution |        |    |                |                |                |              |                |                |                |                                       | Data Compared                         |
|           |        |    |                |                |                |              |                |                |                |                                       | Between the FDO                       |
|           |        |    |                |                |                |              |                |                |                |                                       | and Main-System                       |
|           |        |    |                |                |                |              |                |                |                |                                       |                                       |
| Result    | R      |    |                |                | _              | ST 0         |                |                |                |                                       | Status Information<br>After Command   |
|           | R      |    | · · · · · ·    |                |                | ST 1<br>ST 2 |                |                |                |                                       | Execution                             |
|           | R      |    | ¢. ;           |                | -              | C            |                |                |                |                                       | Execution                             |
|           | R      |    |                |                |                | н            |                |                |                |                                       | Sector ID Information                 |
|           | R      |    |                |                |                | R            |                |                |                |                                       | After Command                         |
|           | R      |    |                |                | -              | N            |                |                |                |                                       | Execution                             |
|           |        |    |                |                | SCA            |              | ORE            | QUAL           |                |                                       |                                       |
| Command   | w      | MT | MFM            | SK             | 1              |              | 1              | 1              | 0              | 1                                     | Command Codes                         |
|           | w      | 0  | 0              | 0              | 0              |              | 0              | HDS            | DS1            | DS0                                   |                                       |
|           | w -    | ·  |                |                | _              | С            |                |                |                |                                       | Sector ID Information                 |
|           | w      |    |                |                |                | н            |                |                |                |                                       | Prior to Command                      |
|           | w ·    |    |                |                |                | R            |                |                |                |                                       | Execution                             |
|           | w      |    |                |                | -              | Ν            |                |                |                |                                       |                                       |
|           | w      |    |                |                | -              | EOT          |                |                |                |                                       |                                       |
|           | w      |    |                |                | -              | GPL          |                |                |                | · · · · · · · · · · · · · · · · · · · | · ·                                   |
|           | w      |    |                |                | _              | STP          |                |                |                |                                       |                                       |
| Execution |        |    |                |                |                |              |                |                |                |                                       | Data Compared                         |
|           |        |    |                |                |                |              |                |                |                |                                       | Between the FDO                       |
|           |        |    |                |                |                |              |                |                |                |                                       | and Main-System                       |
|           |        |    |                |                |                | 0 <b>-</b> 0 |                |                |                |                                       | Otatus Information                    |
| Result    | R      |    |                |                |                | ST 0         |                |                |                |                                       | Status Information<br>After Command   |
|           | R<br>R |    |                |                | _              | ST 1<br>ST 2 |                |                |                |                                       | Execution                             |
|           | R      |    |                |                | -              | 512<br>C     |                |                |                |                                       |                                       |
|           | R      |    |                |                | -              | н            |                |                |                |                                       | Sector ID Information                 |
|           | R      |    |                |                | -              | R            |                |                |                |                                       | After Command                         |
|           | R      |    |                |                |                | N            |                |                |                |                                       | Execution                             |
|           | L      |    |                |                | _              |              |                |                |                |                                       |                                       |

#### Table 6-1. 82078 Command Set (Continued)

intel

| Phase     | R/W                                    |         |                |         | DAT      | A BUS          |                |                |          | Remarks                                                |
|-----------|----------------------------------------|---------|----------------|---------|----------|----------------|----------------|----------------|----------|--------------------------------------------------------|
| 11490     | n/ w                                   | D7      | D <sub>6</sub> | D5      | D4       | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | Do       | nemarks                                                |
|           |                                        | _       |                |         | RE       | CALIBRAT       | E              |                |          |                                                        |
| Command   | w                                      | 0       | 0              | 0       | 0        | 0              | 1              | 1              | 1        | Command Codes                                          |
|           | w                                      | 0       | 0              | 0       | 0        | 0              | 0              | DS0            | DS1      | Enhanced Controller                                    |
| Execution |                                        |         | · · · ·        |         |          |                |                |                |          | Head Retracted to Track 0                              |
|           | ······································ |         |                |         | SENSE IN | TERRUPT        | STATUS         |                |          |                                                        |
| Command   | w                                      | 0       | 0              | 0       | 0        | 1              | 0              | 0              | 0        | Command Codes                                          |
| Result    | R                                      |         |                |         | . S      | то _           |                |                |          | Status Information at the                              |
|           | R                                      |         |                |         | - P      | CN _           |                |                |          | End of Each Seek<br>Operation                          |
|           |                                        |         |                | · · · · |          | SPECIFY        |                |                |          |                                                        |
| Command   | w                                      | 0       | 0              | 0       | 0        | 0              | 0              | 1              | 1        | Command Codes                                          |
|           | w                                      |         | S              | ат      |          |                | ні             | דע             |          |                                                        |
|           | w                                      |         |                |         | _ HLT    |                |                |                | ND       |                                                        |
|           | <u>.</u>                               | _       |                |         |          | DRIVE ST       |                |                |          | 1                                                      |
| Command   | w w                                    | 0<br>0  | 0              | 0       | 0<br>0   | 0              | 1<br>HDS       | 0<br>DS1       | 0<br>DS0 | Command Codes                                          |
| Result    | R                                      |         |                |         |          | тз _           |                |                |          | Status Information About<br>FDD                        |
|           | íí                                     |         |                | DR      | IVE SPEC | FICATION       | COMMAND        |                |          |                                                        |
| Command   | w                                      | 1       | 0              | 0       | 0        | 1              | 1              | 1              | 0        | Command Codes                                          |
| Phase     | w                                      | 0       | FD1            | FD0     | PTS      | DRT1           | DRT0           | DT1            | DT0      |                                                        |
|           | w                                      | :<br>DN | :<br>NRP       | :<br>0  | : 0      | :<br>0         | :<br>0         | :<br>0         | :<br>0   | 0-46 Bytes Issued                                      |
| Result    | R                                      | 0       | 0              | 0       | PTS      | DRT1           | DRT0           | DT1            | DTO      | Drive 0                                                |
| Phase     | R                                      | õ       | ŏ              | o       | PTS      | DRT1           | DRTO           | DT1            | DTO      | Drive 1                                                |
|           | R                                      | 0       | 0              | 0       | 0        | 0              | 0              | 0              | 0        | RSVD                                                   |
|           | R                                      | 0       | 0              | 0       | 0        | 0              | 0              | 0              | 0        | RSVD                                                   |
|           | <u>гт</u>                              |         |                |         |          | SEEK           |                |                |          |                                                        |
| Command   | W                                      | 0       | 0              | 0       | 0        | 1              | 1              | 1              | 1        | Command Codes                                          |
|           | w<br>w                                 | 0       | 0              | 0       | 0<br>N   | 0<br>CN _      | HDS            | DS1            | DS0      |                                                        |
| Execution |                                        |         |                |         |          |                |                |                |          | Head is Positioned Over<br>Proper Cylinder on Diskette |
|           |                                        |         |                |         | C        | ONFIGURE       |                |                |          | · · · · · · · · · · · · · · · · · · ·                  |
| Command   | w                                      | 0       | 0              | 0       | 1        | 0              | 0              | 1              | 1        | Command Code                                           |
|           | w                                      | 0       | 0              | 0       | 0        | 0              | 0              | 0              | 0        |                                                        |
|           | w<br>w                                 | 0       | EIS            | EFIFO   | POLL     |                | F              | FIFOTHR _      |          |                                                        |
|           |                                        |         |                |         |          | ATIVE SEE      | ĸ              | +              |          | 1                                                      |
| Command   | w                                      | 1       | DIR            | 0.      | 0        | 1              | 1              | . 1            | - 1      |                                                        |
|           | w                                      | o       | 0              | 0       | 0        | 0              | HDS            | DS1            | DS0      |                                                        |
|           | w                                      |         |                |         | R        | CN             |                |                | <u> </u> | n                                                      |

#### Table 6-1. 82078 Command Set (Continued)

#### 82078 44 PIN

|                      | <b>B</b> (14) |      |                |                | DATA       |                |                |                |                                       |                                                                                   |
|----------------------|---------------|------|----------------|----------------|------------|----------------|----------------|----------------|---------------------------------------|-----------------------------------------------------------------------------------|
| Phase                | R/W           | D7   | D <sub>6</sub> | D <sub>5</sub> | D4         | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub>                        | Remarks                                                                           |
|                      |               |      |                |                | DI         | JMPREG         |                |                |                                       |                                                                                   |
| Command<br>Execution | W             | 0    | 0              | 0              | 0          | 1              | 1              | 1              | 0                                     | *Note<br>Registers Placed in FIFO                                                 |
| Result               | R             |      |                |                | PCN-Dr     | ive O          |                |                |                                       |                                                                                   |
|                      | R             |      |                |                | PCN-Dr     |                |                |                |                                       |                                                                                   |
|                      | R             |      |                |                | RSV        |                |                |                |                                       |                                                                                   |
|                      | R             |      | e              | RT             | RSV        | D .            |                | UT             |                                       |                                                                                   |
|                      | R             |      | 3              | · ·            | HLT        |                |                |                | ND                                    |                                                                                   |
|                      | R             |      |                |                | SC/E       | от             |                |                |                                       |                                                                                   |
|                      | R             | LOCK | 0              | 0              | 0          | D <sub>1</sub> | Do             | GAP            | WGATE                                 |                                                                                   |
|                      | R             | 0    | EIS            | EFIFO          | POLL       |                | FIF            | OTHR _         |                                       |                                                                                   |
|                      | R             |      |                |                | PRET       | RK             |                |                |                                       |                                                                                   |
|                      |               |      |                |                | R          | EAD ID         |                |                |                                       |                                                                                   |
| Command              | w             | 0    | MFM            | 0              | 0          | 1              | 0              | 1              | 0                                     | Commands                                                                          |
| -                    | w             | 0    | 0              | 0              | 0          | 0              | HDS            | DS1            | DS0                                   | The First O                                                                       |
| Execution            |               |      |                |                |            |                |                |                |                                       | The First Correct ID<br>Information on the Cylinder<br>is Stored in Data Register |
| Result               | R             |      |                |                | ST (       | 0              |                |                |                                       | Status Information After                                                          |
|                      | R             |      |                |                | ST         |                |                |                |                                       | Command Execution                                                                 |
|                      | R             |      |                |                | ST :       | 2 _            |                |                |                                       |                                                                                   |
|                      | R             |      |                |                | c          | -              |                |                |                                       |                                                                                   |
|                      | R.            |      |                | <u></u>        |            | -              |                |                | · · · · · · · · · · · · · · · · · · · | Disk Status After the                                                             |
|                      | R             |      |                |                | R<br>N     | -              |                |                |                                       | Command has Completed                                                             |
|                      |               |      |                |                | PERPEN     |                | MODE           |                |                                       | L.,                                                                               |
| Command              | w             | 0    | 0              | 0              | 1          | 0              | 0              | 1              | 0                                     | Command Codes                                                                     |
| Continuand           | Ŵ             | ow   | ō              | ŏ              | 0<br>0     | D <sub>1</sub> | DO             | GAP            | WGATE                                 |                                                                                   |
|                      |               |      |                |                |            | LOCK           |                |                |                                       |                                                                                   |
| Command              | w             | LOCK | 0              | 0              | 1          | 0              | 1              | 0              | 0                                     | Command Codes                                                                     |
| Result               | R             | 0    | Ō              | ō              | LOCK       | 0              | Ó              | Ō              | 0                                     |                                                                                   |
|                      |               |      |                |                | P          | ARTID          |                |                |                                       | · · · · · · · · · · · · · · · · · · ·                                             |
| Command              | w             | 0    | 0              | 0              | 1          | 1              | 0              | 0              | 0                                     | Command Code                                                                      |
| Result               | R             | 0    | 1              | ō              | ·          |                | PING           | -              | 1                                     | Part ID Number                                                                    |
|                      |               |      |                |                | POWER      | DOWN N         | ODE            |                |                                       |                                                                                   |
| Command              | w             | 0    | 0              | 0              | 1          | 0              | 1              | 1              | 1                                     | Command Code                                                                      |
|                      | w             | 0    | 0              | EREG           | 44PD       | 0              | FDI            | MIN            | AUTO                                  |                                                                                   |
|                      |               |      |                | EN             | EN         | 0              | TRI            | DLY            | PD                                    |                                                                                   |
| David                |               |      | 0              | 5050           | 4400       | •              |                |                | AUTO                                  |                                                                                   |
| Result               | R             | 0    | U              | EREG<br>EN     | 44PD<br>EN | 0              | FDI<br>TRI     | MIN<br>DLY     | AUTO<br>PD                            |                                                                                   |
|                      | L             | L    |                |                |            | OPTION         |                |                |                                       | I                                                                                 |
| Command              | w             | 0    | 0              | 1              | 1          | 0              | 0              | 1              | 1                                     | Command Code                                                                      |
| Command              | w             | l v  | v              | '              |            | U              | v              |                | ISO                                   | Command Code                                                                      |

#### Table 6-1. 82078 Command Set (Continued)

intel



| ····             |     |                |                |                |          | TA BUS         |                | t (Continue                            | <u>, , , , , , , , , , , , , , , , , , , </u> |                                |
|------------------|-----|----------------|----------------|----------------|----------|----------------|----------------|----------------------------------------|-----------------------------------------------|--------------------------------|
| Phase            | R/W | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | DA<br>D4 | D3             |                | D <sub>1</sub>                         |                                               | Remarks                        |
|                  | L   | 07             | Dę             | <u> </u>       | 04       | SAVE           | D <sub>2</sub> | <u> </u>                               | D <sub>0</sub>                                | L                              |
| Command          | w   | 0              | 0              | 1              | 0        | 1              | 1              | 1                                      | 0                                             | Command Code                   |
| Phase            | **  | U              | 0              | I              | Ū        |                | 1              | I                                      | Ū                                             | Command Code                   |
| Result<br>Phase  | R   | RSVD           | SEL<br>3V#*    | PD<br>OSC      | PC2      | PC1            | PC0            | DRATE1                                 | DRATE0                                        | Save Info to Reprogram the FDC |
|                  | R   | 0              | 0              | 0              | 0        | 0              | 0              | 0                                      | ISO                                           |                                |
|                  | R   |                |                |                | PCN-D    | )rive 0        |                |                                        |                                               |                                |
|                  | R   |                |                |                | PCN-D    | rive 1         |                |                                        |                                               |                                |
|                  | R   |                |                |                | RS       |                |                |                                        |                                               |                                |
|                  | R   |                |                |                | RS       |                |                |                                        |                                               |                                |
|                  | R   |                | S              | RT             |          |                |                | нит _                                  |                                               |                                |
|                  | R   |                | 0              |                | . HLT    |                |                |                                        | ND                                            |                                |
|                  | R   |                |                |                | SC/I     |                |                |                                        |                                               |                                |
|                  | R   | LOCK           | 0              | 0              | 0        | D1             |                | CAD                                    | WGATE                                         |                                |
|                  |     |                |                |                |          | U1             | D <sub>0</sub> | GAP                                    | WGATE                                         |                                |
|                  | R   | 0              | EIS            | EFIFO          | POLL     |                | F              | IFOTHR .                               | ·····                                         |                                |
|                  | R   |                |                |                | PRE      |                |                |                                        |                                               | ]                              |
|                  | R   | 0              | 0              | EREG           | 44PD     | RSVD           | FDI            | MIN                                    | AUTO                                          |                                |
|                  |     |                |                | EN             | EN       |                | TRI            | DLY                                    | PD                                            |                                |
|                  | R   |                |                |                | DISK/S   | TATUS          |                |                                        |                                               |                                |
|                  | R   |                |                |                | _ RS'    | VD             |                | ······································ |                                               |                                |
|                  |     |                |                |                |          | RESTOR         | E              |                                        |                                               |                                |
| Command<br>Phase | w   | Ó              | 1              | 0              | 0        | 1              | 1              | 1                                      | 0                                             | Command Code                   |
|                  | w   | 0              | SEL<br>3V#*    | 0              | PC2      | PC1            | PC0            | DRATE1                                 | DRATE0                                        | Restore Original               |
| -                | w   | 0              | 0              | 0              | 0        | 0              | 0              | 0                                      | ISO                                           | Register Status                |
|                  | · w | Ť              | -              | -              | PCN-E    |                | •              | •                                      |                                               |                                |
|                  | ŵ   |                |                |                | PCN-E    |                |                |                                        |                                               |                                |
|                  | Ŵ   |                |                |                | RS'      |                |                |                                        |                                               |                                |
|                  |     |                |                |                |          |                |                |                                        |                                               |                                |
|                  | W   |                |                | DT             | - RS     | VD             |                |                                        | ·······                                       |                                |
|                  | w   |                | \$             | RT             |          |                |                | HUT                                    |                                               |                                |
|                  | W   |                |                |                | HLT      |                |                |                                        | ND                                            |                                |
|                  | w   |                |                |                | _ SC/I   |                | ·              |                                        |                                               |                                |
|                  | w   | LOCK           | 0              | 0              | 0        | D <sub>1</sub> | Do             | GAP                                    | WGATE                                         | }                              |
|                  | w   | 0              | EIS            | EFIFO          | POLL     |                | F              | ifothr _                               | ~                                             |                                |
|                  | w   |                |                |                | PRE      |                |                |                                        |                                               | 1                              |
|                  | w   | 0              | 0              | EREG           | 44PD     | RSVD           | FDI            | MIN                                    | AUTO                                          |                                |
|                  |     |                |                | EN             | EN       |                | TRI            | DLY                                    | PD                                            | 1                              |
|                  | w   |                |                |                | DISK/S   | TATUS          |                |                                        |                                               |                                |
|                  | w   |                |                |                | RS       |                |                |                                        |                                               |                                |
|                  | w   |                |                |                |          |                |                |                                        |                                               |                                |

Table 6-1. 82078 Command Set (Continued)

#### NOTE:

\*For the 82078, 82078-5, SEL3V# = 1. For the 82078-3, SEL3V# = 0.

| Phase     | R/W    |                          |                                       |                | DATA           |                |                |                |     |                                                                    |
|-----------|--------|--------------------------|---------------------------------------|----------------|----------------|----------------|----------------|----------------|-----|--------------------------------------------------------------------|
| rnase     | R/W    | D <sub>7</sub>           | D <sub>6</sub>                        | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | Do  | - Remarks                                                          |
|           |        |                          |                                       |                | FORMA          | T AND W        | RITE           |                |     |                                                                    |
| Command   | w      | 1                        | MFM                                   | 1              | 0              | 1              | 1              | 0              | 1   | Command Code                                                       |
|           | w      | 0                        | 0                                     | 0              | 0              | 0              | HDS            | DS1            | DS0 |                                                                    |
|           | w<br>w |                          |                                       |                | _ N<br>SC      |                |                |                |     |                                                                    |
|           | w      |                          |                                       |                | GP             |                |                |                |     |                                                                    |
|           | w      |                          |                                       |                | _ D            |                |                |                |     |                                                                    |
| Execution | w      |                          |                                       |                | _ c            |                |                |                |     |                                                                    |
| Repeated  | w      |                          |                                       |                | _ н            |                |                |                |     | Input                                                              |
| for each  | w      |                          |                                       |                | _ R            |                |                |                |     | Sector                                                             |
| Sector    | w      |                          | · · · · · · · · · · · · · · · · · · · |                | N              |                | ·              |                |     | Parameters                                                         |
|           | w      | Data Transfer of N Bytes |                                       |                |                |                |                |                |     |                                                                    |
|           |        |                          |                                       |                |                |                |                |                |     | 82078 Formats and Writes<br>Entire Track                           |
| Result    | R      |                          |                                       |                | _ ST           | -              |                |                |     | 1                                                                  |
| Phase     | R      |                          |                                       |                | _ ST           |                |                |                |     |                                                                    |
|           | R      |                          |                                       |                |                |                |                |                |     |                                                                    |
|           | R      |                          |                                       |                | Undefi         |                |                |                |     |                                                                    |
|           | R      |                          |                                       |                | _ Undefi       |                |                |                |     |                                                                    |
|           | R      |                          |                                       |                | _ Undef        | ined           |                |                |     |                                                                    |
|           |        |                          |                                       |                | 11             | VALID          |                |                |     |                                                                    |
| Command   | W      |                          |                                       |                | Invalid (      | Codes          |                |                |     | Invalid Command Codes<br>(NoOp — 82078 Goes into<br>Standby State) |
| Result    | R      | <u> </u>                 |                                       |                | ST             | 0              |                |                |     | ST 0 = 80H                                                         |

## Table 6-1. 82078 Command Set (Continued)

intel

## Parameter Abbreviations

## Symbol

44PD EN

DIR

Description

Powerdown pin status. This bit allows the PD and IDLE pins to be available at FDS1 and FDME1 instead of the DS1 and ME1 pins. The BOOTSEL bit in the 44 pin part remaps the drive selects and motor enables when this bit is low. See the table below for functionality:

| 44PD EN | BOOTSEL(TDR) | Mapping |               |                                                                                                |  |
|---------|--------------|---------|---------------|------------------------------------------------------------------------------------------------|--|
| 0       | 0            | Default | $\rightarrow$ | $DS0 \rightarrow FDS0, ME0 \rightarrow FDME0$<br>$DS1 \rightarrow FDS1, ME1 \rightarrow FDME1$ |  |
| 0       | 1            | -       |               | $DS0 \rightarrow FDS1, ME0 \rightarrow FDME1$<br>$DS1 \rightarrow FDS0, ME1 \rightarrow FDME0$ |  |
| 1       | X            |         |               | $DS0 \rightarrow FDS0, ME0 \rightarrow FDME0$<br>$DS1 \rightarrow PD, ME1 \rightarrow IDLE$    |  |

DTL

| AUTO PD | Auto powerdown control. If this bit is<br>0, then the automatic powerdown is<br>disabled. If it is set to 1, then the auto-<br>matic powerdown is enabled. |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| С       | Cylinder address. The currently se-<br>lected cylinder address, 0 to 255.                                                                                  |

D0, D1 Drive Select 0-3. Designates which drives are Perpendicular drives, a "1" indicating Perpendicular drive.

- D Data pattern. The pattern to be written in each sector data field during formatting.
- DN Done. This bit indicates that this is the last byte of the drive specification command. The 82078 checks to see if this bit is high or low. If it is low, it expects more bytes.
  - DN = 0 82078 expects more subsequent bytes.
  - DN = 1 Terminates the command phase and jumps to the results phase. An additional benefit is that by setting this bit high, a direct check of the current drive specifications can be done.

Direction control. If this bit is 0, then the head will step out from the spindle during a relative seek. If set to a 1, the head will step in toward the spindle.

DS0, DS1 Disk Drive Select.

| DS1 | DS0 |         |
|-----|-----|---------|
| 0   | 0   | drive 0 |
| 0   | 1   | drive 1 |
| 1   | 0   | RSVD    |
| 1   | 1   | RSVD    |

Special sector size. By setting N to zero (00), DTL may be used to control the number of bytes transferred in disk read/write commands. The sector size (N = 0) is set to 128. If the actual sector (on the diskette) is larger than DTL, the remainder of the actual sector is read but is not passed to the host during read commands; during write commands, the remainder of the actual sector is written with all zero bytes. The CRC check code is calculated with the actual sector. When N is not zero, DTL has no meaning and should be set to FF HEX.

DRATE[0:1] Data rate values from the DSR register.

DRT0, DRT1 Data rate table select. These two bits select between the different data rate tables. The default is the conventional table. These also provide mapping of the data rates selected in the DSR and CCR. The table below shows this.

|      | Bits in DSR/CCR |               |      |              |                                 |  |  |  |  |
|------|-----------------|---------------|------|--------------|---------------------------------|--|--|--|--|
| DRTO | DRT1            | DRATE1 DRATE0 |      | Data<br>Rate | Operation                       |  |  |  |  |
| 0    | 0               | 1             | 1    | 1 Mbps       | Default                         |  |  |  |  |
|      |                 | 0             | 0    | 500 Kbps     |                                 |  |  |  |  |
|      |                 | 0             | 1    | 300 Kbps     |                                 |  |  |  |  |
|      |                 | 1             | 0    | 250 Kbps     |                                 |  |  |  |  |
| 0    | 1               | RSVD          | RSVD | RSVD         | RSVD                            |  |  |  |  |
| 1    | 0               | RSVD          | RSVD | RSVD         | RSVD                            |  |  |  |  |
| 1    | 1               | 1             | 1    | 1 Mbps       | Perpendic-<br>ular mode<br>FDDs |  |  |  |  |
|      |                 | 0             | 0    | 500 Kbps     |                                 |  |  |  |  |
|      |                 | 0             | 1    | RSVD         |                                 |  |  |  |  |
|      |                 | 1             | 0    | 250 Kbps     |                                 |  |  |  |  |

- DT0, DT1 Drive density select type. These bits select the outputs on DRVDEN0 and DRVDEN1 based on mode of operation that was selected via the IDENT1 and IDENT0 pins. More information is available in the Design Applications section.
- EC Enable Count. When this bit is "1" the "DTL" parameter of the Verify Command becomes SC (Number of sectors per track).
- EFIFO Enable FIFO. When this bit is 0, the FIFO is enabled. A "1" puts the 82078 in the 8272A compatible mode where the FIFO is disabled.

EIS Enable implied seek. When set, a seek operation will be performed before executing any read or write command that requires the C parameter in the command phase. A "0" disables the implied seek.

EOT End of track. The final sector number of the current track.

EREG EN Enhanced Register Enable.

- EREG EN = 1 The TDR register is extended and SRB is made visible to the user.
- EREG EN = 0 Standard registers are used.
- FDI TRI Floppy Drive Interface Tristate: If this bit is 0, then the output pins of the floppy disk drive interface are tri-stated. This is also the default state. If it is set to 1, then the floppy disk drive interface remains unchanged.
- FD0, FD1 Floppy drive select. These two bits select which physical drive is being specified. The FDn corresponds to FDSn and FDMEn on the floppy drive interface. The drive is selected independent of the BOOTSELn bits. Please refer to Section 2.1.1 which explains the distinction between physical drives and their virtual mapping as defined by the BOOTSEL1 and BOOTSEL0 bits.

| FD1 | FD0 | Drive<br>Slot |  |
|-----|-----|---------------|--|
| 0   | 0   | drive 0       |  |
| 0   | 1   | drive 1       |  |
| 1   | 0   | RSVD          |  |
| 1   | 1   | RSVD          |  |

- Alters Gap2 length when using Perpendicular Mode.
- Gap length. The Gap3 size. (Gap3 is the space between sectors excluding the VCO synchronization field).

Head address. Selected head: 0 or 1 (disk side 0 or 1) as encoded in the sector ID field.

- Head load time. The time interval that 82078 waits after loading the head and before initiating a read or write operation. Refer to the SPECIFY command for actual delays.
  - Head unload time. The time interval from the end of the execution phase (of a read or write command) until the head is unloaded. Refer to the SPECI-FY command for actual delays.

ISO Format: If this bit is set high the ISO format is used for all data transfer commands. When this bit is set low the normal IBM system 34 and perpendicular is used. The default is ISO = 0.

ISO

GAP

GPL

HDS

HLT

HUT

36

## intel

- Lock Lock defines whether EFIFO, FIFOTHR, and PRETRK parameters of the CONFIGURE command can be reset to their default values by a "Software Reset" (Reset made by setting the proper bit in the DSR or DOR registers).
- MFM MFM mode. A one selects the double density (MFM) mode. A zero is reserved.

MIN DLY Minimum power up time control. This bit is active only if AUTO PD bit is enabled. Setting this bit to a 0, assigns a 10 ms minimum power up time and setting this bit to a 1, assigns a 0.5s minimum power up time.

Multi-track selector. When set, this flag selects the multi-track operating mode. In this mode, the 82078 treats a complete cylinder, under head 0 and 1, as a single track. The 82078 operates as if this expanded track started at the first sector under head 0 and ended at the last sector under head 1. With this flag set, a multitrack read or write operation will automatically continue to the first sector under head 1 when the 82078 finishes operating on the last sector under head 0.

> Sector size code. This specifies the number of bytes in a sector. If this parameter is "00", then the sector size is 128 bytes. The number of bytes transferred is determined by the DTL parameter. Otherwise the sector size is (2 raised to the "N'th" power) times 128. All values up to "07" hex are allowable. "07"h would equal a sector size of 16K. It is the users responsibility to not select combinations that are not possible with the drive.

| N  | Sector Size |
|----|-------------|
| 00 | 128 bytes   |
| 01 | 256 bytes   |
| 02 | 512 bytes   |
| 03 | 1024        |
| •• |             |
| 07 | 16 Kbytes   |

NCN

New cylinder number. The desired cylinder number.

- ND Non-DMA mode flag. When set to 1, indicates that the 82078 is to operate in the non-DMA mode. In this mode, the host is interrupted for each data transfer. When set to 0, the 82078 operates in DMA mode, interfacing to a DMA controller by means of the DRQ and DACK # signals.
- NRP No Results phase. When this bit is set high the result phase is skipped. When this bit is low the result phase will be generated.
- OW The bits denoted D0, D1, D2, and D3 of the PERPENDICULAR MODE command can only be overwritten when the OW bit is set to "1".
- PCN Present cylinder number. The current position of the head at the completion of SENSE INTERRUPT STATUS command.
- PC2, PC1, Precompensation values from the PC0 DSR register.
- PDOSC When this bit is set, the internal oscillator is turned off.

PTS

R

SC

- Precompensation table select. This bit selects whether to enable the precompensation value programmed in the DSR or not. In the default state, the value programmed in DSR will be used.
  - PTS = 0 DSR programmed precompensation delays
  - PTS = 1 No precompensation delay is selected for the corresponding drive.
- POLL Polling disable. When set, the internal polling routine is disabled. When clear, polling is enabled.
- PRETRK Precompensation start track number. Programmable from track 00 to FFH.
  - Sector address. The sector number to be read or written. In multi-sector transfers, this parameter specifies the sector number of the first sector to be read or written.
- RCN Relative cylinder number. Relative cylinder offset from present cylinder as used by the RELATIVE SEEK command.
  - Number of sectors. The number of sectors to be initialized by the FOR-MAT command. The number of sectors to be verified during a Verify Command, when EC is set.

MT

N

SK

Skip flag. When set to 1, sectors containing a deleted data address mark will automatically be skipped during the execution of READ DATA. If READ DELETED is executed, only sectors with a deleted address mark will be accessed. When set to "0", the sector is read or written the same as the read and write commands.

SRT Step rate interval. The time interval between step pulses issued by the 82078. Programmable from 0.5 ms to 8 ms, in increments of 0.5 ms at the 1 Mbit data rate. Refer to the SPECIFY command for actual delays.

ST0-3 Status registers 0-3. Registers within the 82078 that store status information after a command has been executed. This status information is available to the host during the result phase after command execution.

- STEPPING These bits identify the stepping of the 82078.
- WGATE Write gate alters timing of WE, to allow for pre-erase loads in perpendicular drives.

## 6.1 Data Transfer Commands

All of the READ DATA, WRITE DATA and VERIFY type commands use the same parameter bytes and return the same results information. The only difference being the coding of bits 0-4 in the first byte.

An implied seek will be executed if the feature was enabled by the CONFIGURE command. This seek is completely transparent to the user. The Drive Busy bit for the drive will go active in the Main Status Register during the seek portion of the command. If the seek portion fails, it will be reflected in the results status normally returned for a READ/WRITE DATA command. Status Register 0 (ST0) would contain the error code and C would contain the cylinder on which the seek failed.

## 6.1.1 READ DATA

A set of nine (9) bytes is required to place the 82078 into the Read Data Mode. After the READ DATA command has been issued, the 82078 loads the head (if it is in the unloaded state), waits the specified head settling time (defined in the SPECIFY command), and begins reading ID Address Marks and ID fields. When the sector address read off the diskette matches with the sector address specified in the command, the 82078 reads the sector's data field and transfers the data to the FIFO.

one, and the data from the next logical sector is read and output via the FIFO. This continuous read function is called "Multi-Sector Read Operation". Upon receipt of TC, or an implied TC (FIFO overrun/underrun), the 82078 stops sending data, but will continue to read data from the current sector, check the CRC bytes, and at the end of the sector terminate the READ DATA Command. N determines the number of bytes per sector (see

Table 6-2). If N is set to zero, the sector size is set to 128. The DTL value determines the number of bytes to be transferred. If DTL is less than 128, the 82078 transfers the specified number of bytes to the host. For reads, it continues to read the entire 128 byte sector and checks for CRC errors. For writes it completes the 128 byte sector by filling in zeroes. If N is not set to 00 Hex. DTL should be set to FF Hex. and has no impact on the number of bytes transferred.

After completion of the read operation from the current sector, the sector address is incremented by

| Table | 6-2. | Sector | Sizes |
|-------|------|--------|-------|
|-------|------|--------|-------|

| N  | Sector Size |
|----|-------------|
| 00 | 128 bytes   |
| 01 | 256 bytes   |
| 02 | 512 bytes   |
| 03 | 1024 bytes  |
|    | _           |
| 07 | 16 Kbytes   |

The amount of data which can be handled with a single command to the 82078 depends upon MT (multi-track) and N (Number of bytes/sector).

Table 6-3. Effects of MT and N Bits

| мт | N | Max. Transfer<br>Capacity | Final Sector Read<br>from Disk |
|----|---|---------------------------|--------------------------------|
| 0  | 1 | $256 \times 26 = 6656$    | 26 at side 0 or 1              |
| 1  | 1 | $256 \times 52 = 13312$   | 26 at side 1                   |
| 0  | 2 | $512 \times 15 = 7680$    | 15 at side 0 or 1              |
| 1  | 2 | $512 \times 30 = 15360$   | 15 at side 1                   |
| 0  | 3 | $1024 \times 8 = 8192$    | 8 at side 0 or 1               |
| 1  | 3 | $1024 \times 16 = 16384$  | 16 at side 1                   |

The Multi-Track function (MT) allows the 82078 to read data from both sides of the diskette. For a particular cylinder, data will be transferred starting at Sector 1, Side 0 and completing at the last sector of the same track at Side 1.

If the host terminates a read or write operation in the 82078, then the ID information in the result phase is dependent upon the state of the MT bit and EOT byte. Refer to Table 6-6. The termination must be normal.

At the completion of the READ DATA Command, the head is not unloaded until after the Head Unload Time Interval (specified in the SPECIFY command) has elapsed. If the host issues another command before the head unloads then the head settling time may be saved between subsequent reads.

If the 82078 detects a pulse on the INDX # pin twice without finding the specified sector (meaning that the diskette's index hole passes through index detect logic in the drive twice), the 82078 sets the IC code in Status Register 0 to "01" (Abnormal termination), and sets the ND bit in Status Register 1 to "1" indicating a sector not found, and terminates the READ DATA Command.

After reading the ID and Data Fields in each sector, the 82078 checks the CRC bytes. If a CRC error occurs in the ID or data field, the 82078 sets the IC code in Status Register 0 to "01" (Abnormal termination), sets the DE bit flag in Status Register 1 to "1", sets the DD bit in Status Register 2 to "1" if CRC is incorrect in the ID field, and terminates the READ DATA Command.

Table 6-4 below describes the affect of the SK bit on the READ DATA command execution and results.

| Table 0-4. Skip Bit VS READ DATA Command |                          |                 |                    |                                                                    |  |  |  |
|------------------------------------------|--------------------------|-----------------|--------------------|--------------------------------------------------------------------|--|--|--|
| SK                                       | Data Address             | Results         |                    |                                                                    |  |  |  |
| Bit<br>Value                             | Mark Type<br>Encountered | Sector<br>Read? | CM Bit of ST2 Set? | Description of Results                                             |  |  |  |
| 0                                        | Normal Data              | Yes             | No                 | Normal<br>Termination.                                             |  |  |  |
| 0                                        | Deleted Data             | Yes             | Yes                | Address Not<br>Incremented.<br>Next Sector<br>Not Searched<br>For. |  |  |  |
| 1                                        | Normal Data              | Yes             | No                 | Normai<br>Termination.                                             |  |  |  |
| 1                                        | Deleted Data             | No              | Yes                | Normal<br>Termination<br>Sector Not<br>Read<br>("Skipped").        |  |  |  |

| Table 6-4. | Skip | Bit vs | READ | DATA | Command |
|------------|------|--------|------|------|---------|
|------------|------|--------|------|------|---------|

Except where noted in Table 6-4, the C or R value of the sector address is automatically incremented (see Table 6-6).

## 6.1.2 READ DELETED DATA

This command is the same as the READ DATA command, only it operates on sectors that contain a Deleted Data Address Mark at the beginning of a Data Field.

Table 6-5 describes the affect of the SK bit on the READ DELETED DATA command execution and results.

|                    | ۱D |  |
|--------------------|----|--|
| DELETED DATA Comma | nd |  |

| SK           | Data Address             |                 | Resu               | Its                                                                |
|--------------|--------------------------|-----------------|--------------------|--------------------------------------------------------------------|
| Bit<br>Value | Mark Type<br>Encountered | Sector<br>Read? | CM Bit of ST2 Set? | Description<br>of Results                                          |
| 0            | Normal Data              | Yes             | Yes                | Normal<br>Termination.                                             |
| 0            | Deleted Data             | Yes             | No                 | Address Not<br>Incremented.<br>Next Sector<br>Not Searched<br>For. |
| 1            | Normal Data              | No              | Yes                | Normal<br>Termination<br>Sector Not<br>Read<br>("Skipped").        |
| 1            | Deleted Data             | Yes             | No                 | Normal<br>Termination.                                             |

Except where noted in Table 6-5 above, the C or R value of the sector address is automatically incremented (see Table 6-6).

## 6.1.3 READ TRACK

This command is similar to the READ DATA command except that the entire data field is read continuously from each of the sectors of a track. Immediately after encountering a pulse on the INDX # pin, the 82078 starts to read all data fields on the track as continuous blocks of data without regard to logical sector numbers. If the 82078 finds an error in the ID or DATA CRC check bytes, it continues to read data from the track and sets the appropriate error bits at the end of the command. The 82078 compares the ID information read from each sector with the specified value in the command, and sets the ND flag of Status Register 1 to a "1" if there is no comparison.

Multi-track or skip operations are not allowed with this command. The MT and SK bits (Bits D7 and D5 of the first command byte respectively) should always be set to "0".

This command terminates when the EOT specified number of sectors have been read. If the 82078 does not find an ID Address Mark on the diskette after the second occurrence of a pulse on the INDX# pin, then it sets the IC code in Status Register 0 to "01" (Abnormal termination), sets the MA bit in Status Register 1 to "1", and terminates the command.

Table 6-6. Result Phase Table

| мт | Head | Final Sector<br>Transferred |     |     | rmation<br>It Phase |    |  |  |  |  |
|----|------|-----------------------------|-----|-----|---------------------|----|--|--|--|--|
|    |      | to Host                     | С   | Н   | R                   | N  |  |  |  |  |
| 0  | 0    | Less than EOT               | NC  | NC  | R+1                 | NC |  |  |  |  |
|    |      | Equal to EOT                | C+1 | NC  | 01                  | NC |  |  |  |  |
|    | 1    | Less than EOT               | NC  | NC  | R+1                 | NC |  |  |  |  |
|    |      | Equal to EOT                | C+1 | NC  | 01                  | NC |  |  |  |  |
| 1  | 0    | Less than EOT               | NC  | NC  | R+1                 | NC |  |  |  |  |
|    |      | Equal to EOT                | NC  | LSB | 01                  | NC |  |  |  |  |
|    | 1    | Less than EOT               | NC  | NC  | R+1                 | NC |  |  |  |  |
|    |      | Equal to EOT                | C+1 | LSB | 01                  | NC |  |  |  |  |

#### NOTES:

NC: No Change, the same value as the one at the beginning of command execution.

LSB: Least Significant Bit, the LSB of H is complemented.

### 6.1.4 WRITE DATA

After the WRITE DATA command has been issued, the 82078 loads the head (if it is in the unloaded state), waits the specified head load time if unloaded (defined in the SPECIFY command), and begins reading ID Fields. When the sector address read from the diskette matches the sector address specified in the command, the 82078 reads the data from the host via the FIFO, and writes it to the sector's data field.

After writing data into the current sector, the 82078 computes the CRC value and writes it into the CRC field at the end of the sector transfer. The Sector Number stored in "R" is incremented by one, and the 82078 continues writing to the next data field. The 82078 continues this "Multi-Sector Write Operation". Upon receipt of a terminal count signal or if a FIFO over/under run occurs while a data field is being written, then the remainder of the data field is filled with zeros.

The 82078 reads the ID field of each sector and checks the CRC bytes. If it detects a CRC error in one of the ID Fields, it sets the IC code in Status Register 0 to "01" (Abnormal termination), sets the DE bit of Status Register 1 to "1", and terminates the WRITE DATA command.

The WRITE DATA command operates in much the same manner as the READ DATA command. The following items are the same. Please refer to the READ DATA Command for details:

- Transfer Capacity
- EN (End of Cylinder) bit
- ND (No Data) bit
- Head Load, Unload Time Interval
- ID information when the host terminates the command.
- Definition of DTL when N = 0 and when N does not = 0.

### 6.1.5 WRITE DELETED DATA

This command is almost the same as the WRITE DATA command except that a Deleted Data Address Mark is written at the beginning of the Data Field instead of the normal Data Address Mark. This command is typically used to mark a bad sector containing an error on the floppy disk.

#### 6.1.6 VERIFY

The VERIFY command is used to verify the data stored on a disk. This command acts exactly like a READ DATA command except that no data is transferred to the host. Data is read from the disk, CRC computed and checked against the previously stored value.

Because no data is transferred to the host, TC (pin-25) cannot be used to terminate this command. By setting the EC bit to "1" an implicit TC will be issued to the 82078. This implicit TC will occur when the SC value has decrement to 0 (an SC value of 0 will verify 256 sectors). This command can also be terminated by setting the EC bit to "0" and the EOT value equal to the final sector to be checked. If EC is set to "0" DTL/SC should be programmed to 0FFH. Refer to Table 6-6 and Table 6-7 for information concerning the values of MT and EC versus SC and EOT value.

## Definitions:

# Sectors Per Side = Number of formatted sectors per each side of the disk.

# Sectors Remaining = Number of formatted sectors left which can be read, including side 1 of the disk if MT is set to "1".

|    |    | Table 6-7. Verity Command Result Pha                        |                                                  |
|----|----|-------------------------------------------------------------|--------------------------------------------------|
| MT | EC | SC/EOT Value                                                | Termination Result                               |
| 0  | 0  | SC = DTL<br>EOT $\leq #$ Sectors Per Side                   | Successful Termination<br>Result Phase Valid     |
| 0  | 0  | SC = DTL<br>EOT > # Sectors Per Side                        | Unsuccessful Termination<br>Result Phase Invalid |
| 0  | 1  | SC ≤ # Sectors Remaining<br>AND<br>EOT ≤ # Sectors Per Side | Successful Termination<br>Result Phase Valid     |
| 0  | 1  | SC > # Sectors Remaining<br>OR<br>EOT > # Sectors Per Side  | Unsuccessful Termination<br>Result Phase Invalid |
| 1  | 0  | SC = DTL<br>EOT $\leq #$ Sectors Per Side                   | Successful Termination<br>Result Phase Valid     |
| 1  | 0  | SC = DTL<br>EOT > # Sectors Per Side                        | Unsuccessful Termination<br>Result Phase Invalid |
| 1  | 1  | SC ≤ # Sectors Remaining<br>AND<br>EOT ≤ # Sectors Per Side | Successful Termination<br>Result Phase Valid     |
| 1  | 1  | SC > # Sectors Remaining<br>OR<br>EOT > # Sectors Per Side  | Unsuccessful Termination<br>Result Phase Invalid |

## Table 6-7. Verify Command Result Phase Table

#### NOTE:

If MT is set to "1" and the SC value is greater than the number of remaining formatted sectors on Side 0, verifying will continue on Side 1 of the disk.

#### 6.1.7 FORMAT TRACK

The FORMAT command allows an entire track to be formatted. After a pulse from the INDX# pin is detected, the 82078 starts writing data on the disk including Gaps, Address Marks, ID Fields and Data Fields, per the IBM System 34 (MFM). The particular values that will be written to the gap and data field are controlled by the values programmed into N, SC, GPL, and D which are specified by the host during the command phase. The data field of the sector is filled with the data byte specified by D. The ID Field for each sector is supplied by the host; that is, four data bytes per sector are needed by the 82078 for C, H, R, and N (cylinder, head, sector number and sector size respectively).

After formatting each sector, the host must send new values for C, H, R and N to the 82078 for the next sector on the track. The R value (sector number) is the only value that must be changed by the host after each sector is formatted. This allows the disk to be formatted with nonsequential sector addresses (interleaving). This incrementing and formatting continues for the whole track until the 82078 encounters a pulse on the INDX# pin again and it terminates the command.

Table 6-8 contains typical values for gap fields which are dependent upon the size of the sector and the number of sectors on each track. Actual values can vary due to drive electronics.

| Drive<br>Form | MEDIA | Sector<br>Size | N  | sc | GPL1 | GPL2 |
|---------------|-------|----------------|----|----|------|------|
| 5.25″         | 1.2M  | 512            | 02 | 0F | 2A   | 50   |
|               | 360K  | 512            | 02 | 09 | 2A   | 50   |
| 3.5″          | 2.88M | 512            | 02 | 24 | 38   | 53   |
|               | 1.44M | 512            | 02 | 18 | 1B   | 54   |
|               | 720K  | 512            | 02 | 09 | 1B   | 54   |

#### NOTE:

All values except Sector Size are in Hex.

Gap3 is programmable during reads, writes, and formats.

GPL1 = suggested Gap3 values in read and write commands to avoid splice point between data field and ID field of contiguous sections.

GPL2 = suggested Gap3 value in FORMAT TRACK command.

## 6.1.7.1 Format Fields

| 1 - 12x - | 1 | SYNC<br>12x<br>00 | I FC | GAP1<br>50x<br>4E |  | 1 1 66 | C<br>Y<br>L |  | 0 | N<br>O |  |  | 1 | DA<br>A<br>3x |  | DATA |  | GAP3 | GAP<br>4b |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|-------------------|------|-------------------|--|--------|-------------|--|---|--------|--|--|---|---------------|--|------|--|------|-----------|
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|-------------------|------|-------------------|--|--------|-------------|--|---|--------|--|--|---|---------------|--|------|--|------|-----------|

### Table 6-9. System 34 Format Double Density

### Table 6-10. ISO Format

| GAP1<br>32x | SYNC<br>12x | ID,      | AM | c | н | SF | N | C | GAP2<br>22x | SYNC<br>12x |          | M<br>M   | DATA | C | GAP3 | GAP |  |
|-------------|-------------|----------|----|---|---|----|---|---|-------------|-------------|----------|----------|------|---|------|-----|--|
| 4E          | 00          | Зх<br>А1 | FE | L | D | C  | 0 | C | 22x<br>4E   | 00          | 3x<br>A1 | FB<br>F8 | DATA | Ċ | GAFS | 4b  |  |

### **Table 6-11. Perpendicular Format**

| GAP<br>4a<br>80x<br>4E | SYNC<br>12x<br>00 | IAM<br>3x<br>C2 FC | GAP1<br>50x<br>4E | SYNC<br>12x<br>00 | IDAM<br>3x<br>A1 FE | C<br>Y<br>L | н<br>D | S<br>E<br>C | N<br>O | C<br>R<br>C | GAP2<br>41x<br>4E | SYNC<br>12x<br>00 | DAT<br>AN<br>3x<br>A1 |  | DATA | C<br>R<br>C | GAP3 | GAP<br>4b |  |
|------------------------|-------------------|--------------------|-------------------|-------------------|---------------------|-------------|--------|-------------|--------|-------------|-------------------|-------------------|-----------------------|--|------|-------------|------|-----------|--|
|------------------------|-------------------|--------------------|-------------------|-------------------|---------------------|-------------|--------|-------------|--------|-------------|-------------------|-------------------|-----------------------|--|------|-------------|------|-----------|--|

## 6.2 Scan Commands

The SCAN Commands allow data which is being read from the diskette to be compared against data which is being supplied from the main system (Processor in NON-DMA mode, and DMA Controller in DMA mode). The FDC compares the data on a byte-by-byte basis, and looks for a sector of data which meets the conditions of D<sub>FDD</sub> = D<sub>Processor</sub>, D<sub>FDD</sub>  $\leq$  D<sub>Processor</sub>, or D<sub>FDD</sub>  $\geq$  D<sub>Processor</sub>. Ones comple-

ment arithmetic is used for comparison (FF = largest number, 00 = smallest number). After a whole sector of data is compared, if the conditions are not met, the sector number is incremented (R + STP  $\rightarrow$  R), and the scan operation is continued. The scan operation continues until one of the following conditions occur, the conditions for scan are met (equal, low, or high), the last sector on the track is reached (EOT), or the terminal count signal is received.

| Tab | le 6- | 12. | Scan | Status | Codes |
|-----|-------|-----|------|--------|-------|
|-----|-------|-----|------|--------|-------|

| Command            | Status R    | Commente    |                                                                                                                                     |
|--------------------|-------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Command            | Bit 2 = SN  | Bit 3 = SH  | Comments                                                                                                                            |
| Scan Equal         | 0           | 1<br>0      | D <sub>FDD</sub> = D <sub>Processor</sub><br>D <sub>FDD</sub> ≠ D <sub>Processor</sub>                                              |
| Scan Low or Equal  | 0<br>0<br>1 | 1<br>0<br>0 | D <sub>FDD</sub> = D <sub>Processor</sub><br>D <sub>FDD</sub> < D <sub>Processor</sub><br>D <sub>FDD</sub> ≯ D <sub>Processor</sub> |
| Scan High or Equal | 0<br>0<br>1 | 1<br>0<br>0 | D <sub>FDD</sub> = D <sub>Processor</sub><br>D <sub>FDD</sub> > D <sub>Processor</sub><br>D <sub>FDD</sub> ≮ D <sub>Proceeeor</sub> |

If the conditions for scan are met then the FDC sets the SH (Scan Hit) flag of Status Register 2 to a 1 (high), and terminates the Scan Command, If the conditions for scan are not met between the starting sector (as specified by R) and the last sector on the cylinder (EOT), then the FDC sets the SN (Scan Not Satisfied) flag of Status Register 2 to a 1 (high), and terminates the Scan Command. The receipt of a TERMINAL COUNT signal from the Processor or DMA Controller during the scan operation will cause the FDC to complete the comparison of the particular byte which is in process, and then to terminate the command. Table 6-12 shows the status of bits SH and SN under various conditions of SCAN.

If the FDC encounters a Deleted Data Address Mark on one of the sectors (and SK = 0), then it regards the sector as the last sector on the cylinder, sets CM (Control Mark) flag of Status Register 2 to a 1 (high) and terminates the command. If SK = 1, the FDC skips the sector with the Deleted Address Mark, and reads the next sector. In the second case (SK = 1), the FDC sets the CM (Control Mark) flag of Status Register 2 to a 1 (high) in order to show that a Deleted Sector had been encountered.

When either the STP (contiguous sectors STP = 01, or alternate sectors STP = 02 sectors are read) or the MT (Multi-Track) are programmed, it is necessary to remember that the last sector on the track must be read. For example, if STP = 02, MT = 0, the sectors are numbered sequentially 1 through 26, and we start the Scan Command at sector 21; the following will happen. Sectors 21, 23, and 25 will be read, then the next sector (26) will be skipped and the index Hole will be encountered before the EOT value of 26 can be read. This will result in an abnormal termination of the command. If the EOT had been set at 25 or the scanning started at sector 20, then the Scan Command would be completed in a normal manner.

During the Scan Command data is supplied by either the processor or DMA Controller for comparison against the data read from the diskette. In order to avoid having the OR (Over Run) flag set in Status Register 1, it is necessary to have the data available in less than 13  $\mu$ s. If an Overrun occurs the FDC terminates the command.

## 6.3 Control Commands

Control commands differ from the other commands in that no data transfer takes place. Three commands generate an interrupt when complete; READ ID, RECALIBRATE and SEEK. The other control commands do not generate an interrupt.

## 6.3.1 READ ID

The READ ID command is used to find the present position of the recording heads. The 82078 stores the values from the first ID Field it is able to read into its registers. If the 82078 does not find an ID Address Mark on the diskette after the second occurrence of a pulse on the INDX# pin, it then sets the IC code in Status Register 0 to "01" (Abnormal termination), sets the MA bit in Status Register 1 to "1", and terminates the command.

The following commands will generate an interrupt upon completion. They do not return any result bytes. It is highly recommended that control commands be followed by the SENSE INTERRUPT STATUS command. Otherwise, valuable interrupt status information will be lost.

## 6.3.2 RECALIBRATE

This command causes the read/write head within the 82078 to retract to the track 0 position. The 82078 clears the contents of the PCN counter, and checks the status of the TRK0 pin from the FDD. As long as the TRK0 pin is low, the DIR pin remains 0 and step pulses are issued. When the TRK0 pin goes high, the SE bit in Status Register 0 is set to "1", and the command is terminated. If the TRK0 pin is still low after 79 step pulses the command is terminated. Disks capable of handling more than 80 tracks per side may require more than one RECALI-BRATE command to return the head back to physical Track 0.

The RECALIBRATE command does not have a result phase. SENSE INTERRUPT STATUS command must be issued after the RECALIBRATE command to effectively terminate it and to provide verification of the head position (PCN). During the command phase of the recalibrate operation, the 82078 is in the BUSY state, but during the execution phase it is in a NON BUSY state. At this time another RECALI-BRATE command may be issued, and in this manner, parallel RECALIBRATE operations may be done on up to 2 drives at once.

Upon power up, the software must issue a RECALI-BRATE command to properly initialize all drives and the controller.

## 6.3.3 DRIVE SPECIFICATION COMMAND

The 82078 uses two pins, DRVDEN0 and DRVDEN1 to select the density for modern drives. These signals inform the drive of the type of diskette in the drive. The Drive Specification command specifies the polarity of the DRVDEN0 and DRVDEN1 pins. It also enables or disables DSR programmed precompensation.

This command removes the need for a hardware workaround to accommodate differing specifications among drives. By programming this command during BIOS's POST routine, the floppy disk controller will internally configure the correct values for DRVDEN0 and DRVDEN1 with corresponding precompensation value and data rate table enabled for the particular type of drive.

This command is protected from software resets. After executing the DRIVE SPEC command, subsequent software resets will not clear the programmed parameters. Only another DRIVE SPEC command or H/W reset can reset it to default values. The 6 LSBs of the last byte of this command are reserved for future use.

The DRATE0 and DRATE1 are values as programmed in the DSR register. The DENSEL is high for high data rates (1 Mbps and 500 Kbps) and low for low data rates (300 Kbps and 250 Kbps).

The following table describes the drives that are supported with the DT0, DT1 bits of the Drive Specification command:

| DT0 | DT1 | Data<br>Rate | DRVDENO | DRVDEN1 |
|-----|-----|--------------|---------|---------|
| 0*  | 0*  | 1 Mbps       | 1       | 1       |
|     |     | 500 Kbps     | 1       | Ó       |
|     |     | 300 Kbps     | 0       | 1       |
|     |     | 250 Kbps     | 0       | 0       |
| 0   | 1   | 1 Mbps       | 1       | 1       |
|     |     | 500 Kbps     | 0       | 0       |
|     |     | 300 Kbps     | 0       | 1       |
|     |     | 250 Kbps     | 1.      | 0       |
| 1   | 0   | 1 Mbps       | 0       | 1       |
| ·   |     | 500 Kbps     | 0       | 0       |
|     |     | 300 Kbps     | 1       | 1       |
|     |     | 250 Kbps     | 1       | 0       |
| 1   | 1   | 1 Mbps       | 1       | 1       |
|     |     | 500 Kbps     | 0       | 0       |
|     |     | 300 Kbps     | 1       | 0       |
|     |     | 250 Kbps     | 0       | 1       |

DRVDENn Polarities

#### NOTE:

(\*) Denotes the default setting.

### 6.3.4 SEEK

The read/write head within the drive is moved from track to track under the control of the SEEK command. The 82078 compares the PCN which is the current head position with the NCN and performs the following operation if there is a difference:

PCN < NCN: Direction signal to drive set to "1" (step in), and issues step pulses.

PCN > NCN: Direction signal to drive set to "0" (step out), and issues step pulses.

The rate at which step pulses are issued is controlled by SRT (Stepping Rate Time) in the SPECIFY command. After each step pulse is issued, NCN is compared against PCN, and when NCN = PCN, then the SE bit in Status Register 0 is set to "1", and the command is terminated.

During the command phase of the seek or recalibrate operation, the 82078 is in the BUSY state, but during the execution phase it is in the NON BUSY state.

Note that if implied seek is not enabled, the read and write commands should be preceded by:

- 1. SEEK command; Step to the proper track
- 2. SENSE INTERRUPT STATUS command; Terminate the Seek command
- 3. READ ID. Verify head is on proper track
- 4. Issue READ/WRITE command.

The SEEK command does not have a result phase. Therefore, it is highly recommended that the SENSE INTERRUPT STATUS command be issued after the SEEK command to terminate it and to provide verification of the head position (PCN). The H bit (Head Address) in ST0 will always return a "0". When exiting DSR POWERDOWN mode, the 82078 clears the PCN value and the status information to zero. Prior to issuing the DSR POWERDOWN command, it is highly recommended that the user service all pending interrupts through the SENSE INTERRUPT STATUS command.

### 6.3.5 SENSE INTERRUPT STATUS

An interrupt signal on INT pin is generated by the 82078 for one of the following reasons:

- 1. Upon entering the Result Phase of:
  - a. READ DATA Command
  - b. READ TRACK Command
  - c. READ ID Command
  - d. READ DELETED DATA Command
  - e. WRITE DATA Command

- f. FORMAT TRACK Command
- g. WRITE DELETED DATA Command
- h. VERIFY Command
- 2. End of SEEK, RELATIVE SEEK or RECALI-BRATE Command
- 3. 82078 requires a data transfer during the execution phase in the non-DMA Mode

The SENSE INTERRUPT STATUS command resets the interrupt signal and via the IC code and SE bit of Status Register 0, identifies the cause of the interrupt. If a SENSE INTERRUPT STATUS command is issued when no active interrupt condition is present, the status register ST0 will return a value of 80H (invalid command).

| SE | IC | Interrupt Due To                                       |  |  |
|----|----|--------------------------------------------------------|--|--|
| 0  | 11 | Polling                                                |  |  |
| 1  | 00 | Normal Termination of SEEK or<br>RECALIBRATE command   |  |  |
| 1  | 01 | Abnormal Termination of SEEK or<br>RECALIBRATE command |  |  |

The SEEK, RELATIVE SEEK and the RECALI-BRATE commands have no result phase. SENSE INTERRUPT STATUS command must be issued immediately after these commands to terminate them and to provide verification of the head position (PCN). The H (Head Address) bit in ST0 will always return a "0". If a SENSE INTERRUPT STATUS is not issued, the drive, will continue to be BUSY and may effect the operation of the next command.

## 6.3.6 SENSE DRIVE STATUS

SENSE DRIVE STATUS obtains drive status information. It has no execution phase and goes directly to the result phase from the command phase. STATUS REGISTER 3 contains the drive status information.

## 6.3.7 SPECIFY

The SPECIFY command sets the initial values for each of the three internal timers. The HUT (Head Unload Time) defines the time from the end of the execution phase of one of the read/write commands to the head unload state. The SRT (Step Rate Time) defines the time interval between adjacent step pulses. Note that the spacing between the first and second step pulses may be shorter than the remaining step pulses. The HLT (Head Load Time) defines the time between the command phase to the execution phase of a read/write data command. The Head Unload Time (HUT) timer starts at the end of the execution phase to the beginning of the result phase of a read/write command. The values change with the data rate speed selection and are documented in Table 6-14.

## Table 6-14. Drive Control Delays (ms)

|   | HUT |      |      |      |            | S    | RT   |      |
|---|-----|------|------|------|------------|------|------|------|
|   | 1M  | 500K | 300K | 250K | 1 <b>M</b> | 500K | 300K | 250K |
| 0 | 128 | 256  | 426  | 512  | 8.0        | 16   | 26.7 | 32   |
| 1 | 8   | 16   | 26.7 | 32   | 7.5        | 15   | 25   | 30   |
| — |     |      |      |      |            |      | ·    |      |
| Α | 80  | 160  | 267  | 320  | 3.0        | 6.0  | 10.2 | 12   |
| в | 88  | 176  | 294  | 352  | 2.5        | 5.0  | 8.35 | 10   |
| С | 96  | 192  | 320  | 384  | 2.0        | 4.0  | 6.68 | 8    |
| D | 104 | 208  | 346  | 416  | 1.5        | 3.0  | 5.01 | 6    |
| E | 112 | 224  | 373  | 448  | 1.0        | 2.0  | 3.33 | 4    |
| F | 120 | 240  | 400  | 480  | 0.5        | 1.0  | 1.67 | 2    |

Table 6-15. Head Load Time (ms)

|    | HLT        |      |      |      |  |  |  |
|----|------------|------|------|------|--|--|--|
|    | 1 <b>M</b> | 500K | 300K | 250K |  |  |  |
| 00 | 128        | 256  | 426  | 512  |  |  |  |
| 01 | 1          | 2    | 3.3  | 4    |  |  |  |
| 02 | 2          | 4    | 6.7  | 8    |  |  |  |
|    | —          | ·    |      |      |  |  |  |
| 7E | 126        | 252  | 420  | 504  |  |  |  |
| 7F | 127        | 254  | 423  | 508  |  |  |  |

The choice of DMA or NON-DMA operations is made by the ND bit. When this bit is "1", the NON-DMA mode is selected, and when ND is "0", the DMA mode is selected. In DMA mode, data transfers are signalled by the DRQ pin. Non-DMA mode uses the RQM bit and the INT pin to signal data transfers.

## 6.3.8 CONFIGURE

Issue the configure command to enable features like the programmable FIFO and set the beginning track for pre-compensation. A CONFIGURE command need not be issued if the default values of the 82078 meet the system requirements.

## **CONFIGURE DEFAULT VALUES:**

| EIS     | No Implied Seeks                |
|---------|---------------------------------|
| EFIFO   | FIFO Disabled                   |
| POLL    | Polling Enabled                 |
| FIFOTHR | FIFO Threshold Set to 1 Byte    |
| PRETRK  | Pre-Compensation Set to Track 0 |

EIS—Enable Implied Seek. When set to "1", the 82078 will perform a SEEK operation before executing a read or write command. Defaults to no implied seek.

ntel

EFIFO—A "1" puts the FIFO into the 8272A compatible mode where the FIFO is disabled. This means data transfers are asked for on a byte by byte basis. Defaults to "1", FIFO disabled. The threshold defaults to one.

POLL—Disable polling of the drives. Defaults to "0", polling enabled. When enabled, a single interrupt is generated after a RESET. No polling is performed while the drive head is loaded and the head unload delay has not expired.

FIFOTHR—The FIFO threshold in the execution phase of read or write commands. This is programmable from 1 to 16 bytes. Defaults to one byte. A "00" selects one byte, "0F" selects 16 bytes.

PRETRK—Pre-compensation start track number. Programmable from track 0 to 255. Defaults to track 0. A "00" selects track 0, "FF" selects 255.

### 6.3.9 VERSION

The VERSION command checks to see if the controller is an enhanced type (82077, 82077AA, 82077SL) or the older type (8272A/765A). A value of 90H is returned as the result byte, defining an enhanced FDD controller is in use. No interrupts are generated. Refer to the Part ID command for more identification information on the 82078.

## 6.3.10 RELATIVE SEEK

The command is coded the same as for SEEK, except for the MSB of the first byte and the DIR bit.

DIR Head Step Direction Control

| DIR | Action        |
|-----|---------------|
| 0   | Step Head Out |
| 1   | Step Head In  |

RCN Relative Cylinder Number that determines how many tracks to step the head in or out from the current track number.

The RELATIVE SEEK command differs from the SEEK command in that it steps the head the absolute number of tracks specified in the command instead of making a comparison against an internal register. The SEEK command is good for drives that support a maximum of 256 tracks. RELATIVE SEEKs cannot be overlapped with other RELATIVE SEEKs. Only one RELATIVE SEEK can be active at a time. Bit 4 of Status Register 0 (EC) will be set if RELATIVE SEEK attempts to step outward beyond Track 0.

As an example, assume that a floppy drive has 300 useable tracks and that the host needs to read track 300 and the head is on any track (0—255). If a SEEK command was issued, the head would stop at track 255. If a RELATIVE SEEK command was issued, the 82078 would move the head the specified number of tracks, regardless of the internal cylinder position register (but would increment the register). If the head had been on track 40 (D), the maximum track that the 82078 could position the head on using RELATIVE SEEK, would be 296 (D), the initial track, +256 (D). The maximum count that the head can be moved with a single RELATIVE SEEK command is 256 (D).

The internal register, PCN, would overflow as the cylinder number crossed track 255 and would contain 40 (D). The resulting PCN value is thus (NCN + PCN) mod 256. Functionally, the 82078 starts counting from 0 again as the track number goes above 255(D). It is the users responsibility to compensate 82078 functions (precompensation track number) when accessing tracks greater than 255. The 82078 does not keep track that it is working in an "extended track area" (greater than 255). Any command issued would use the current PCN value except for the RECALIBRATE command which only looks for the TRACK0 signal. RECALIBRATE would return an error if the head was farther than 79 due to its limitation of issuing a maximum 80 step pulses. The user simply needs to issue a second RECALIBRATE command. The SEEK command and implied seeks will function correctly within the 44 (D) track (299-255) area of the "extended track area". It is the users responsibility not to issue a new track position that would exceed the maximum track that is present in the extended area.

To return to the standard floppy range (0-255) of tracks, a RELATIVE SEEK would be issued to cross the track 255 boundary.

A RELATIVE SEEK can be used instead of the normal SEEK but the host is required to calculate the difference between the current head location and the new (target) head location. This may require the host to issue a READ ID command to ensure that the head is physically on the track that software assumes it to be. Different 82078 commands will return different cylinder results which may be difficult to keep track of with software without the READ ID command.

## 6.3.11 DUMPREG

The DUMPREG command is designed to support system run-time diagnostics and application software development and debug. The command returns pertinent information regarding the internal status of the 82078. This can be used to verify the values initialized in the 82078.

## 6.3.12 PERPENDICULAR MODE COMMAND

Note, perpendicular mode functionality is not available on the 82078-5.

### 6.3.12.1 About Perpendicular Recording Mode

An added capability of the 82078 is the ability to interface directly to perpendicular recording floppy drives. Perpendicular recording differs from the traditional longitudinal method by orienting the magnetic bits vertically. This scheme packs in more data bits for the same area.

### 6.3.12.2 The Perpendicular Mode Command

The PERPENDICULAR MODE command allows the system designers to designate specific drives as Perpendicular recording drives. Data transfers between Conventional and Perpendicular drives are allowed without having to issue PERPENDICULAR MODE commands between the accesses of the two different drives, nor having to change write pre-compensation values.

With this command, the length of the Gap2 field and VCO enable timing can be altered to accommodate the unique requirements of these drives. Table 6-16 describes the effects of the WGATE and GAP bits for the PERPENDICULAR MODE command.

When both GAP and WGATE equal "0" the PER-PENDICULAR MODE command will have the following effect on the 82078-1) if any of the new bits D0, D1, D2, and D3 are programmed to "1" the corresponding drive will automatically be programmed for Perpendicular mode (ie: GAP2 being written during a write operation, the programmed Data Rate will determine the length of GAP2.), and data will be written with 0 ns write pre-compensation. 2) Any of the new bits (D0-D1) that are programmed for "0", the designated drive, will be programmed for Conventional Mode and data will be written with the currently programmed write pre-compensation value. 3) Bits D0 and D1 can only be over written when the OW bit is written as a "1". The status of these bits can be determined by interpreting the eighth result byte of the DUMPREG command.

#### NOTE:

If either the GAP or WGATE bit is a "1", then bits D0-D1 are ignored.

"Software" and "Hardware" RESET will have the following effects on the enhanced PERPENDICU-LAR MODE command:

- "Software" RESETs (Reset via DOR or DSR registers) will only clear GAP and WGATE bits to "0", D1 and D0 will retain their previously programmed values.
- "Hardware" RESETs (Reset via pin-32) will clear all bits (GAP, WGATE, D0 and D1) to "0" (All Drives Conventional Mode).

| GAP | WGATE | MODE                                       | VCO Low<br>Time after<br>Index Pulse | Length of<br>Gap2 Format<br>Field | Portion of Gap2<br>Written by Write<br>Data Operation | Gap2 VCO Low<br>Time for<br>Read Operations |
|-----|-------|--------------------------------------------|--------------------------------------|-----------------------------------|-------------------------------------------------------|---------------------------------------------|
| 0   | 0     | Conventional Mode                          | 33 Bytes                             | 22 Bytes                          | 0 Bytes                                               | 24 Bytes                                    |
| 0   | 1     | Perpendicular Mode<br>(500 Kbps Data Rate) | 33 Bytes                             | 22 Bytes                          | 19 Bytes                                              | 24 Bytes                                    |
| 1   | 0     | Reserved<br>(Conventional)                 | 33 Bytes                             | 22 Bytes                          | 0 Bytes                                               | 24 Bytes                                    |
| 1   | 1     | Perpendicular Mode<br>(1 Mbps Data Rate)   | 18 Bytes                             | 41 Bytes                          | 38 Bytes                                              | 43 Bytes                                    |

## Table 6-16. Effects of WGATE and GAP Bits

NOTE:

When either GAP or WGATE bit is set, the current value of precompensation in the DSR is used.

### 6.3.13 POWERDOWN MODE COMMAND

The POWERDOWN MODE command allows the automatic power management and enables the enhanced registers (EREG EN) of the 82078. The use of the command can extend the battery life in portable PC applications. To enable auto powerdown the command may be issued during the BIOS power on self test (POST).

This command includes the ability to configure the 82078 into the enhanced mode extending the SRB and TDR registers. These extended registers accommodate bits that give more information about floppy drive interface, allow for boot drive selection, and identify the values of the PD and IDLE status.

As soon as the command is enabled, a 10 ms or a 0.5s minimum power up timer is initiated depending on whether the MIN DLY bit is set to 0 or 1. This timer is one of the required conditions that has to be satisfied before the part will enter auto powerdown. Any software reset will reinitialize the timer. The timer countdown is also extended by up to 10 ms if the data rate is changed during the timer's countdown. Without this timer 82078 would have been put to sleep immediately after 82078 is idle. The minimum delay gives software a chance to interact with 82078 without incurring an additional overhead due to recovery time.

The command also allows the output pins of floppy disk drive interface to be tri-stated or left unaltered during auto powerdown. This is done by the FDI TRI bit. In the default condition (FDI TRI = 0) the output pins of the floppy disk drive are tri-stated. Setting this bit leaves the interface unchanged from the normal state.

The results phase returns the values programmed for MIN DLY, FDI TRI and AUTO PD. The auto powerdown mode is disabled by a hardware reset. Software results have no effect on the POWERDOWN MODE command parameters.

### 6.3.14 PART ID COMMAND

This command can be used to identify the floppy disk controller as an enhanced controller. The first stepping of the 82078 (all 44 pin versions) will yield 0x41 in the result phase of this command. Any future enhancements on these parts will be denoted by the 5 LSBs (0x01 to 0x1F).

#### 6.3.15 OPTION COMMAND

The standard IBM format includes an index address field consisting of 80 bytes of GAP4a, 12 bytes of the sync field, four bytes identifying the IAM and 50 bytes of GAP1. Under the ISO format, most of this preamble is not used. The ISO format allows only 32 bytes of GAP1 after the index mark. The ISO bit in this command allows the 82078 to configure the data transfer commands to recognize this format. The MSBs in this command are reserved for any other enhancements made available to the user in the future.

#### 6.3.16 SAVE COMMAND

The first byte corresponds to the values programmed in the DSR with the exception of CLK48. The DRATE1, DRATE0 used here are unmapped. The second byte is used for configuring the bits from the OPTION command. All future enhancements to the OPTION command will be reflected in this byte as well. The next nine result bytes are explained in the Parameter Abbreviations section after the command summary. The 13th byte is the value associated with the auto powerdown command. The disk status is used internally by 82078. There are two reserved bytes at the end of this command for future use.

This command is similar to the Dumpreg command but it additionally allows the user to read back the precompensation values as well as the programmed data rate. It also allows the user to read the values programmed in the auto power down command. The precompensation values will be returned as programmed in the DSR register. This command is used in conjunction with the Restore command should prove very useful for SMM power management. This command reserves the last two bytes for future enhancements.

#### 6.3.17 RESTORE COMMAND

Using Restore with the Save command, allows the SMM power management to restore the 82078 to its original state after a system powerdown. It also serves as a succinct way to provide most of the initialization requirements normally handled by the system. The sequence of initializing the 82078 after a reset occurred and assuming a Save command was issued follows:

- Issue the Drive Spec command (if the design utilizes this command)
- Issue the Restore command (pass the 16 bytes retrieved previously during SAVE)

The Restore command will program the data rate and precompensation value via the DSR. It then restores the values normally programmed through the Configure, Specify, and Perpendicular commands. It also enables the previously selected values for the AUTO Powerdown command. The PCN values are set restored to their previous values and the user is responsible for issuing the seek and recalibrate commands to restore the head to the proper location. There are some drives that do not recalibrate in which case the Restore command will restore the previous state completely. The PDOSC bit is retrievable using the Save command, however, the system designer must set it correctly. The software must allow at least 20µs to execute the Restore command. When using the BOOTSEL bits in the TDR, the user must restore or reinitialize these bits to their proper values.

## 6.3.18 FORMAT AND WRITE COMMAND

The format and write command is capable of simultaneously formatting and writing data to the diskette. It is essentially the same as the normal format command. With the exception that included in the execution for each sector is not only the C, H, R, and N but also the data transfer of N bytes. The D value is ignored. This command formats the entire track. High speed floppy diskette duplication can be done fast and efficiently with this command. The user can format the diskette and put data on it in a single pass. This is very useful for software duplication applications by reducing the time required to format and copy diskettes.

### 6.3.19 LOCK

The LOCK command is included to protect a system with long DMA latencies against older application software packages that can disable the 82078's FIFO. [Note: This command should only be used by the system's FDC routines, and ISVs (Independent Software Vendors) should refrain from using it. If an ISV's application calls for having the 82078 FIFO disabled, a CONFIGURE command should be used to toggle the EFIFO (Enable FIFO) bit. ISV can determine the value of the LOCK bit by interpreting the eighth result byte of an DUMPREG command.]

The LOCK command defines whether EFIFO, FIFOTHR, and PRETRK parameters of the CON-FIGURE command can be RESET by the DOR and DSR registers. When the LOCK bit is set to a "1" all subsequent "software" RESETs by the DOR and DSR registers will not change the previously set parameter values in the CONFIGURE command. When the LOCK bit is set to a "0", "software" RESETs the DOR or DSR registers will return these parameters to their default values. All "hardware" Resets will set the LOCK bit to a "0" value, and will return EFIFO, FIFOTHR, and PRETRK to their default values. A Status byte is returned immediately after issuing the command byte. This Status byte reflects the value of the Lock bit set by the command byte.

#### NOTE:

No interrupts are generated at the end of this command.

## 7.0 STATUS REGISTER ENCODING

The contents of these registers are available only through a command sequence.

## 7.1 Status Register 0

| Bit # | Symbol | Name               | Description                                                                                                                                                                                                                                                                                                                                                                      |  |
|-------|--------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 7,6   | IC     | Interrupt<br>Code  | <ul> <li>00— Normal termination of command. The specified command was properly executed and completed without error.</li> <li>01— Abnormal termination of command. Command execution was started, but was not successfully completed.</li> <li>10— Invalid command. The requested command could not be executed.</li> <li>11— Abnormal termination caused by Polling.</li> </ul> |  |
| 5     | SE     | Seek End           | The 82078 completed a SEEK or RECALIBRATE command, or a READ or WRITE with implied seek command.                                                                                                                                                                                                                                                                                 |  |
| 4     | EC     | Equipment<br>Check | <ul> <li>The TRK0 pin failed to become a "1" after:</li> <li>1. 80 step pulses in the RECALIBRATE command.</li> <li>2. The RELATIVE SEEK command causes the 82078 to step outward beyond Track 0.</li> </ul>                                                                                                                                                                     |  |
| 3     | —      |                    | Unused. This bit is always "0".                                                                                                                                                                                                                                                                                                                                                  |  |
| 2     | Н      | Head Address       | The current head address.                                                                                                                                                                                                                                                                                                                                                        |  |
| 1,0   | DS1, 0 | Drive Select       | The current selected drive.                                                                                                                                                                                                                                                                                                                                                      |  |

## 7.2 Status Register 1

| Bit # | Symbol | Name                    | Description                                                                                                                                                                                                                                                                                                         |  |  |  |
|-------|--------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 7     | EN     | End of Cylinder         | The 82078 tried to access a sector beyond the final sector of the track (255D). Will be set if TC is not issued after Read or Write.                                                                                                                                                                                |  |  |  |
| 6     |        | _                       | Unused. This bit is always "0".                                                                                                                                                                                                                                                                                     |  |  |  |
| 5     | DE     | Data Error              | The 82078 detected a CRC error in either the ID field or the data field of a sector.                                                                                                                                                                                                                                |  |  |  |
| 4     | OR     | Overrun/<br>Underrun    | Becomes set if the 82078 does not receive CPU or DMA service within the required time interval, resulting in data overrun or underrun.                                                                                                                                                                              |  |  |  |
| 3     |        | <u> </u>                | Unused. This bit is always "0".                                                                                                                                                                                                                                                                                     |  |  |  |
| 2     | ND     | No Data                 | <ol> <li>Any one of the following:</li> <li>READ DATA, READ DELETED DATA command, the 82078 did<br/>not find the specified sector.</li> <li>READ ID command, the 82078 cannot read the ID field without<br/>an error.</li> <li>READ TRACK command, the 82078 cannot find the proper<br/>sector sequence.</li> </ol> |  |  |  |
| 1     | NW     | Not Writable            | WP pin became a "1" while the 82078 is executing a WRITE DATA, WRITE DELETED DATA, or FORMAT TRACK command.                                                                                                                                                                                                         |  |  |  |
| 0     | MA     | Missing<br>Address Mark | <ul> <li>Any one of the following:</li> <li>1. The 82078 did not detect an ID address mark at the specified track after encountering the index pulse from the INDX # pin twice.</li> <li>2. The 82078 cannot detect a data address mark or a deleted data address mark on the specified track.</li> </ul>           |  |  |  |

## 7.3 Status Register 2

| Bit # | Symbol | Name                         | Description                                                                                                                                                                                                                         |
|-------|--------|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7     | _      | <u> </u>                     | Unused. This bit is always "0".                                                                                                                                                                                                     |
| 6     | СМ     | Control Mark                 | <ol> <li>Any of the following:</li> <li>READ DATA command, the 82078 encounters a deleted data address mark.</li> <li>READ DELETED DATA command, the 82078 encountered a data address mark.</li> </ol>                              |
| 5     | DD     | Data Error in Data Field     | The 82078 detected a CRC error in the date field.                                                                                                                                                                                   |
| 4     | WC     | Wrong Cylinder               | The track address from the sector ID field is different from the track address maintained inside the 82078.                                                                                                                         |
| 3     |        |                              | Unused. This bit is always "0".                                                                                                                                                                                                     |
| 2     |        | · _                          | Unused. This bit is always "0".                                                                                                                                                                                                     |
| 1     | BC     | Bad Cylinder                 | The track address from the sector ID field is different from<br>the track address maintained inside the 82078 and is equal<br>to FF hex which indicates a bad track with a hard error<br>according to the IBM soft-sectored format. |
| 0     | MD     | Missing Data<br>Address Mark | The 82078 cannot detect a data address mark or a deleted data address mark.                                                                                                                                                         |

## 7.4 Status Register 3

1

| Bit # | Symbol | Name            | Description                                |
|-------|--------|-----------------|--------------------------------------------|
| 7     |        | · · ·           | Unused. This bit is always "0".            |
| 6     | WP     | Write Protected | Indicates the status of the WP pin.        |
| 5     | _      |                 | Unused. This bit is always "1".            |
| 4     | то     | TRACK 0         | Indicates the status of TRK0 pin.          |
| 3     |        |                 | Unused. This bit is always "1".            |
| 2     | HD     | Head Address    | Indicates the status of the HDSEL pin.     |
| 1,0   | DS1, 0 | Drive Select    | Indicates the status of the DS1, DS0 pins. |

## 8.0 COMPATIBILITY

The 82078 was designed with software compatibility in mind. It is a fully backwards compatible solution with the older generation 8272A and NEC765A/B disk controllers. It is fully compatible with Intel's 386/486SL Microprocessor Superset.

## 8.1 Compatibility with the FIFO

The FIFO of the 82078 is designed to be transparent to non-FIFO disk controller software developed on the older generation 8272A standard. Operation of the 82078 FIFO can be broken down into two tiers of compatibility. For first tier compatibility, the FIFO is left in the default disabled condition upon a "Hardware" reset. In this mode the FIFO operates in a byte mode and provides complete compability with non-FIFO based software. For second tier compatibility, the FIFO is enabled via the CONFIGURE command. When the FIFO is enabled, it will temporarily enter a byte mode during the command and result phase of disk controller operation. This allows for compatible operation when interrogating the Main Status Register (MSR) for the purpose of transferring a byte at a time to or from the disk controller. For normal disk controller applications, the system designer can still take advantage of the FIFO for time critical data transfers during the execution phase and not create any conflicts with non-FIFO software during the command or result phase.

In some instances, use of the FIFO in any form has conflicted with certain specialized software. An example of a compatibility conflict using the FIFO is with software that monitors the progress of a data transfer during the execution phase. If the software assumed the disk controller was operating in a single byte mode and counted the number of bytes transferred to or from the disk controller to trigger some time dependent event on the disk media (i.e. head position over a specific data field), the same software will not have an identical time relationship if the FIFO is enabled. This is because the FIFO allows data to be queued up, and then burst transferred across the host bus. To accommodate software of this type, it is recommended that the FIFO be disabled.

## 8.2 Drive Polling

The 82078 supports the polling mode of the older generation 8272A. This mode is enabled upon a reset and can be disabled via the CONFIGURE command. This mode is supported for the sole purpose of providing backward compatibility with software that expects it's presence.

The intended purpose of drive polling dates back to 8" drives as a means to monitor any change in status for each disk drive present in the system. Each of the drives is selected for a period of time and its READY signal sampled. After a delay, the next drive is selected. Since the 82078 does not support READY in this capacity (internally tied true), the polling sequence is only simulated and does not affect the drive select lines (DS0-DS3) when it is active. If enabled, it occurs whenever the 82078 is waiting for a command or during SEEKs and RECALIBRATEs (but not IMPLIED SEEKs). Each drive is assumed to be not ready after a reset and a "ready" value for each drive is saved in an internal register as the simulated drive is polled. An interrupt will be generated on the first polling loop because of the initial "not ready" status. This interrupt must be followed with a SENSE INTERRUPT STATUS command from the host to clear the interrupt condition for each of the four logical drives.

## 9.0 PROGRAMMING GUIDELINES

Programming the 82078 is identical to any other 8272A compatible disk controller with the exception of some additional commands. For the new designer it is useful to provide some guidelines on how to program the 82078. A typical disk operation involves more than issuing a command and waiting for the results. The control of the floppy disk drive is a low level operation that requires software intervention at different stages. New commands and features have been added to the 82078 to reduce the complexity of this software interface.

## 9.1 Command and Result Phase Handshaking

Before a command or parameter byte can be issued to the 82078, the Main Status Register (MSR) must be interrogated for a ready status and proper FIFO direction. A typical floppy controller device driver should contain a subroutine for sending command or parameter bytes. For this discussion, the routine will be called "Send\_byte" with the flowchart shown in Figure 9-1.



Figure 9-1. Send\_Byte Routine

The routine loops until RQM is 1 and DIO is 0 indicating a ready status and FIFO direction is inward. If this condition is true, the 82078 is ready to accept a command or parameter byte. A timeout counter is used to insure software response within a reasonable amount of time in case of no response by the 82078. As a note, the programmer must be careful how the maximum delay is chosen to avoid unnecessary timeouts. For example, if a new command is issued when the 82078 is in the middle of a polling routine, the MSR will not indicate a ready status for the next parameter byte until the polling sequence completes the loop. This could cause a delay between the first and second bytes of up to 250 µs (@ 250 Kbps). If polling is disabled, this maximum delay is 175 µs. There should also be enough timeout margin to accommodate a shift of the software to a higher speed system. A timeout value that results in satisfactory operation on a 16 MHz CPU might fail when the software is moved to a system with a 25 MHz CPU. A recommended solution is to

derive the timeout counter from a system hardware counter that is fixed in frequency from CPU clock to CPU clock.



Figure 9-2. Get\_Byte Routine

For reading result bytes from the 82078, a similar routine is used. Figure 9-2 illustrates the flowchart for the routine "Get\_byte". The MSR is polled until RQM is 1 and DIO is 1, which indicates a ready status and outward FIFO direction. At this point, the host can read a byte from the FIFO. As in the Send\_byte routine, a timout counter should be incorporated in case of a disk controller lock-up condition. For example, if a disk was not inserted into the disk drive at the time of a read operation, the controller would fail to receive the index pulse and lockup since the index pulses are required for termination of the execution phase.

## 9.2 Initialization

Initializing the 82078 involves setting up the appropriate configuration after a reset. Parameters set by the SPECIFY command are undefined after a system reset and will need to be reinitialized. CONFIG-URE command parameters default to a known state after a system reset but will need to be reinitialized if the system requirements are different from the default settings. This can be accomplished in two ways; either issue the individual commands, or issue the Restore command (assuming the Save command was issued). The Restore command is a succinct way to initialize the 82078, this is the preferable method if the system power management powers

## intel

the 82078 on and off frequently. The flowchart for the recommended initialization sequence of the 82078 is shown in Figure 9-3.

Following a reset of the 82078, the Configuration Control Register (CCR) should be reinitialized for the appropriate data rate. An external reset via the RESET pin will cause the data rate and write precompensation values to default to 250 Kbps (10b) and 125 ns (000b) respectively. Since the 125 ns write precompensation value is optimal for the 51/4"and 31/2" disk drive environment, most applications will not require the value to be changed in the initialization sequence. As a note, a software reset issued via the DOR or DSR will not affect the data rate or write precompensation values. But it is recommended as a safe programming practice to always program the data rate after a reset, regardless of the type.

Since polling is enabled after a reset of the 82078, four SENSE INTERRUPT STATUS commands need to be issued afterwards to clear the status flags for each drive. The flowchart in Figure 9-3 illustrates how the software clears each of the four interrupt status flags internally queued by the 82078. It should be noted that although four SENSE INTERRUPT STATUS commands are issued, the INT pin is only active until the first SENSE INTERRUPT STATUS command is executed.

As a note, if the CONFIGURE command is issued within 250  $\mu$ s of the trailing edge of reset (@1 Mbps), the polling mode of the 82078 can be disabled before the polling initiated interrupt occurs. Since polling stops when the 82078 enters the command phase, it is only time critical up to the first byte of the CONFIGURE command. If disabled in time, the system software no longer needs to issue the four SENSE INTERRUPT STATUS commands to clear the internal interrupt flags normally caused by polling.

The CONFIGURE command should also be issued if the system requirements are different from the default settings. For example, the CONFIGURE command can be used to enable the FIFO, set the threshold, and enable Implied Seeks.



#### **Figure 9-3. Initialization Flowchart**

The non-DMA mode flag, step rate (SRT), head load (HLT), and head unload times (HUT) programmed by the SPECIFY command do not default to a known state after a reset. This behavior is consistent with the 8272A and has been preserved here for compatibility. Thus, it is necessary to always issue a SPECIFY command in the initialization routine.

## 9.3 Recalibrates and Seeks

Commands that position the disk head are different from the typical READ/WRITE/FORMAT command in the sense that there is no result phase. Once a RECALIBRATE, SEEK, or RELATIVE SEEK command has been issued, the 82078 will return a ready status in the Main Status Register (MSR) and perform the head positioning operation as a background task. When the seek is complete, the 82078 will assert the INT signal to request service. A SENSE INTERRUPT STATUS command should then be asserted to clear the interrupt and read the status of the operation. Since the drive and motor enable signals are directly controlled through the Digital Output Register (DOR) on the 82078, a write to the DOR will need to precede the RECALIBRATE or SEEK command if the drive and motor is not already enabled. Figure 9-4 shows the flow chart for this operation.



Figure 9-4. Recalibrate and Seek Operations

## 9.4 Read/Write Data Operations

A read or write data operation requires several steps to complete successfully. The motor needs to be turned on, the head positioned to the correct cylinder, the DMA controller initialized, the read or write command initiated, and an error recovery scheme implemented. The flowchart in Figure 9-5 highlights a recommended algorithm for performing a read or write data operation.

Before data can be transferred to or from the diskette, the disk drive motor must be brought up to speed. For most  $31/_2$ " disk drives, the spin-up time is 300 ms, while the  $51/_4$ " drive usually requires about 500 ms due to the increased moment of inertia associated with the larger diameter diskette.

One technique for minimizing the motor spin-up delay in the read data case is to begin the read operation immediately after the motor is turned on. When the motor is not initially up to speed, the internal data separator will fail to lock onto the incoming data stream and report a failure in the status registers. The read operation is then repeated until successful status is obtained. There is no risk of a data integrity problem since the data field is CRC validated. But, it is not recommended to use this technique for the write data operation even though it requires successful reading of the ID field before the write takes place. The data separator performance of the 82078 is such that locking to the data stream could take place while the motor speed variation is still significant. This could result in errors when an attempt is made to read the disk media by other disk controllers that have a narrower incoming data stream frequency bandwidth.

After the motor has been turned on, the matching data rate for the media inserted into the disk drive should then be programmed to the 82078 via the Configuration Control Register (CCR). The 82078 is designed to allow a different data rate to be programmed arbitrarily without disrupting the integrity of the device. In some applications, it is required to automatically determine the recorded data rate of the inserted media. One technique for doing this is to perform a READ ID operation at each available data rate until a successful status is returned in the result phase.



Figure 9-5. Read/Write Operation

If implied seeks are not enabled, the disk drive head must be positioned over the correct cylinder by executing a SEEK command. After the seek is complete, a head settling time needs to be asserted before the read or write operation begins. For most drives, this delay should be a minimum of 15 ms. When using implied seeks, the minimum head settling time can be enforced by the head load time (HLT) parameter designated in the SPECIFY command. For example, a HLT value of 8 will yield an effective head settling time of 16 ms for a programmed data rate of 500 Kbps. Of course if the head is already positioned over the correct cylinder, the head settling time does not need to be enforced.

The DMA controller is then initialized for the data transfer and the read or write command is executed. Typically the DMA controller will assert Terminal Count (TC) when the data transfer is complete. The 82078 will then complete the current data transfer and assert the INT signal signifying it has entered the result phase. The result phase can also be entered by the 82078 if an error is encountered or the last sector number equals the End of Track (EOT) parameter.

Based on the algorithm in Figure 9-5, if an error is encountered after reading the result bytes, two more retries are performed by reinitializing the DMA controller and re-issuing the read or write data command. A persisting failure could indicate the seek operation did not achieve proper alignment between the head and the track. The disk head should then be recalibrated and the seek repeated for a maximum of two more tries. Unsuccessful operation after this point should be reported as a disk failure to the operating system.

## 9.5 Formatting

The disk formatting procedure involves positioning the head on each track and creating a fixed format field used for organizing the data fields. The flowchart in Figure 9-6 highlights the typical format procedure.

After the motor has been turned on and the correct data rate programmed, the disk head is recalibrated to track 0. The disk is then allowed to come up to speed via a 500 ms delay. It is important the disk speed has stabilized before the actual formatting to avoid any data rate frequency variations. Since the format fields contain critical information used by the data separator of the disk controller for synchronization purposes, frequency stability of the data stream is imperative for media interchangeability among different systems.

The ID field data created on the disk during the format process is provided by the DMA controller during the execution phase. The DMA controller is initialized to send the C, H, R and N values for each sector ID field. For example, to format cylinder 7, on head 1, with 9 sectors, and a sector size of 2 (512 bytes), the DMA controller should be programmed to transfer 36 bytes (9 sectors  $\times$  4 bytes per sector) with the following data field: 7,1,1,2, 7,1,2,2, 7,1,3,2, ... 7,1,9,2. Since the values provided to the 82078 during the execution phase of the format command are directly recorded as the ID fields on the disk, the data contents can be arbitrary. Some forms of copy protection have been implemented by taking advantage of this capability.



Figure 9-6. Formatting

After each head for a cylinder has been formatted, a seek operation to the next cylinder is performed and the format process is repeated. Since the FORMAT TRACK command does not have implied seek capability, the SEEK command must be used. Also, as discussed in Section 9-2, the head settling time needs to be adhered to after each seek operation.

## 9.6 Save and Restore

The Save and Restore commands were developed for portable systems that use zero-volt powerdown to conserve power. These systems turn off the V<sub>CC</sub> to most of the system and retain the system status in a specific location. In older floppy controller designs, in order for system designers to retrieve the floppy controller status, a lot of separate commands and register reads were required. The Save command stores the key status information in a single command, the Restore command restores this information with a single command. These commands can be integrated into the SMM module that is responsible for zero-volt powerdown.

The sequence of initializing the 82078 after a reset occurred and assuming a Save command was issued follows:

- Issue the Drive Spec command (if the design utilizes this command)
- Issue the Restore command

The Restore command programs the data rate and precompensation value via the DSR. It then restores the values normally programmed through the Configure, Specify, and Perpendicular commands. It also enables the previously selected values for the AUTO Powerdown command. The command then restores the PCN values to its previous values. The user is responsible for issuing the seek and recalibrate commands to restore the head to the proper location. There are some drives that do not recalibrate in which case the Restore command will restore the previous state completely. The PDOSC bit is retrievable using the Save command, however it is up to the system designer to set it correctly. The software must allow at least 20µs to execute the Restore command. When using the BOOTSEL bit in the TDR, the user must restore or reinitialize this bit to it's proper value.

## 9.7 Verifies

In some applications, the sector data needs to be verified immediately after each write operation. One verify technique reinitializes the DMA controller to perform a read transfer or verify transfer (DACK# is asserted but not RD#) immediately after each write operation. Issue a read command to the disk controller and the resulting status indicates if the CRC validated the previously written data. This technique has the drawback of requiring additional software intervention by having to reprogram the DMA controller between each sector write operation. The 82078 supports this verify technique but also provides a VERIFY command that does not require the use of the DMA controller.

To verify a write data transfer or format track operation using the VERIFY command, the software simply issues the command with the same format as a READ DATA command but without the support of the DMA controller. The 82078 will then perform a disk read operation without a host data transfer. The CRC will be calculated for each sector read and compared against the value stored on the disk. When the VERIFY command is complete, the status register reports detected CRC errors.

## 9.8 Powerdown State and Recovery

The two power management modes coupled with the internal oscillator power management forms an important consideration for programming the 82078. The recovery of 82078 and the time it takes to achieve complete recovery depends on how 82078 is powered down and how it is awakened. The following sections describe all the programming concerns and subtleties involved in using power management features of the 82078. The 3.3V version of the 82078 has the same power saving features as the 5.0V versions.

## 9.8.1 OSCILLATOR POWER MANAGEMENT

Section 4.1 covers the power management scheme involved in powering down of both an internal and an external oscillator. Both types of oscillators face drop out effects and require recovery times on the order of tens of milliseconds (this may be objectionable to some application software). This means that if the oscillator is powered down then it is imperative for the software to assure enough time for the oscillator to recover to a stable state. Oscillator power management must be controlled by the system software especially to maintain software transparency. In cases where the system goes into a standby mode (by user request or system time-out), the power management software can turn off the oscillator to conserve power. This can also be controlled in hardware using the Powerdown (PD#) pin. Complete recovery from an oscillator powerdown state requires the software to turn on the oscillator sufficiently ahead of awakening the 82078.

## 9.8.2 PART POWER MANAGEMENT

The part powerdown and wake up modes are covered in Section 4.2 in detail. This section is meant to address the programming concerns for the part (excluding the oscillator) during these modes.

## 9.8.2.1 Powerdown Modes

For both types of powerdown modes—DSR powerdown and auto powerdown, if reset is used to exit the part from powerdown then the internal microcontroller will go through a standard sequence: register initialization followed after some delay by an interrupt.

Software transparency in auto powerdown mode is preserved by MSR retaining the value of 80H which indicates that the part is ready to receive a command. This feature allows the part to powerdown while maintaining its responsiveness to any application software.



The PD and IDLE status bits can be monitored via the Status Register B (SRB, EREG EN = 1). Since the IDLE# pin stays high when the 82078 is in idle state, the IDLEMSK bit can be used to set the pin low again (as part of a power management routine).

#### NOTE:

The IDLEMSK prevents the user from knowing if the part has entered auto powerdown or DSR powerdown.

#### 9.8.2.2 Wake Up Modes

Wake up from DSR powerdown results in the part being internally reset and all present status being lost. During DSR powerdown the RQM bit in the MSR is set. A software or hardware reset will wake up the part.

The case for wake up from auto powerdown is different. The BIOS and application software are very sensitive to delays involved in writing the first command bytes to the 82078. Most programs have short error time-outs in these cases. Such programs would not tolerate any floppy disk controller that was unable to receive the first byte of a command at any time. The following describes how 82078 uniquely sustains its software transparency during wake up sequences.

Prior to writing a command to 82078, it is first necessary to read the MSR to ensure that the 82078 is ready (RQM bit must be set) to receive the command. When the part detects a MSR read, it assumes that another command will follow and begins the wake up process. While the part is waking up it does not change the state of the MSR (MSR = 80H) and is able to receive the command in the FIFO. At this point one of the two following scenarios can occur.

No other command is sent subsequent to the MSR read. The part wakes up and initializes the minimum power up timer. Upon the expiration of this timer the part is once again put in powerdown state. Another command follows the MSR read. If the command is sent during the part's recovery from powerdown, the part remembers the command, clears the RQM bit (to prevent further bytes being written) and acts on the command once it is fully awake.

If the MSR was not checked prior to writing of a command, the part will proceed as stated above with the RQM bit cleared and the command byte held until the internal microcontroller is ready. Writing the motor enable bits in DOR active will initiate the wake up sequence with RQM set high, ready to receive any command.

As it is clear from the above discussion, the immediate access to the floppy disk controller for the first command byte is vital to software transparency. The recovery of the part from powerdown may involve a delay after the first command byte has been issued. However, all programs have tolerance for the delay after the first command byte is issued. In a powered up chip, it is possible for the microcontroller to be in its "polling loop". As a result, the tolerance for this delay provides an excellent window for recovery of the part.

## **10.0 DESIGN APPLICATIONS**

## 10.1 Operating the 82078-3 in a 3.3V Design

The design for 3.3V is the same as it is for 5.0V, however the floppy drive interface signals can be at either 3.3V or 5.0V levels depending on the voltage on the V<sub>CCF</sub> pin. The V<sub>CCF</sub> pin allows the FDD interface to be operated in mixed (3.3V/5.0V) mode. For example, if the system operates at 3.3V and the floppy disk drive operates at 5.0V, the 82078 can be configured to operate at 3.3V with 5.0V available to the drive interface. See Figure 10-1 for a schematic.



<u>6</u>

Figure 10-1. 82078 PC/AT Design

## 10.2 Selectable Boot Drive

Generally a standard personal computer is configured with a 1.2 MB 5.25" disk drive and a 1.44 MB or 2.88 MB 3.5" disk drive. Usually the drive that connects as "A:" is the boot drive. At times the user may want to configure "B:" as the boot drive. Currently some BIOS' use a special implementation in software to accomplish this. The 82078 now offers this capability more efficiently by configuring the boot drives.

The 82078 allows for virtual drive designations. This is a result of multiplexing the boot drive select and motor enable lines, as shown in Figure 10-2.

The DRIVE SEL1 and the DRIVE SEL2 bits in the DOR register decode internally to generate the signals DSn. The MEn signals generate directly from the DOR register. The DSn and MEn signals get mapped to actual FDSn and FDMEn pins based on the BOOTSEL bits (selected in the TDR register). The exact mapping of BOOTSEL vs the FDSn and FDMEn pins is shown in the following table.

| 44PD EN | BOOTSEL (TDR) | Mapping |               |                                                                                                |
|---------|---------------|---------|---------------|------------------------------------------------------------------------------------------------|
| 0       | 0             | Default | $\rightarrow$ | DS0 → FDS0, ME0 → FDME0<br>DS1 → FDS1, ME1 → FDME1                                             |
| 0       | 1             |         |               | $DS0 \rightarrow FDS1, ME0 \rightarrow FDME1$<br>$DS1 \rightarrow FDS0, ME1 \rightarrow FDME0$ |
| 1       | · ×           |         |               | $DS0 \rightarrow FDS0, ME0 \rightarrow FDME0$<br>$DS1 \rightarrow PD, ME1 \rightarrow IDLE$    |



Figure 10-2. Virtual Drive Configuration

The BOOTSEL bit allows users to multiplex the output drive signals allowing different drives to be the boot drive. The DSn and MEn bits are considered virtual designations since the DSn and MEn signals get remapped to different corresponding physical FDSn and FDMEn pins. In other words, once the BOOTSEL bit is configured for a non-default selection, all future references made to the controller will be assumed as virtual designations. Note, due to the virtual designations TAPESEL[1:0] = 00 would never enable tape mode due to boot drive restrictions.

## 10.3 How to Disable the Native Floppy Contoller on the Motherboard

There are occasions when the floppy controller designed onto the motherboard of a system needs to be disabled in order to operate another floppy controller on the expansion bus. This can be done without changing the BIOS or remapping the address of the floppy controller (provided there is a jumper, or another way to disable the chip select on the native controller).

Upon reset, the DOR register in the 82078 is set to 00H. If the CS# is left enabled during the POST, the DOR is set to 0CH, this enables the DMA GATE# bit in the DOR. When this bit is set, the 82078 treats a DACK# and a RD# or WR# as an internal chip select (CS#). Bus contention will occur between the native controller and the auxiliary controller if the DMA GATE# bit becomes active, even if the CS# signal is not present. The proper way to disable the native floppy controller is to disable the CS# before the system is turned on. This will prevent the native controller from getting initialized. Another option is to map the native controller to a secondary address space, then disable the DMA GATE# via the DOR disabling the DMA GATE#. This assumes that the native controller is switched to a secondary address space.

## 10.4 Replacing the 82077SL with a 82078 in a 5.0V Design

The 82078 easily replaces the 5.0V 82077SL with minimum design changes. With a few exceptions, most of the signals are named as they were in the 82077SL. Some pins were eliminated and others renamed to accommodate a reduced pin count and smaller package.

The connections to the AT bus are the same as the 82077SL with the following exceptions: MFM and IDENT have been removed. The PLL0 pin was removed. Tape drive mode on the 82078 must be configured via the Tape Drive Register (TDR).

The Drive Interface on the 82078 is also similar to the 82077SL except as noted: DRVDEN0 and DRVDEN1 on the 82078 take the place of DENSEL, DRATE0, and DRATE1 on the 82077SL. The Drive Specification Command configures the polarity of these pins, thus selecting the density type of the drive. The Motor Enable pins and the Drive Select pins are renamed FDME(0–1) and FDS(0–1) respectively on the 82078. 10K pull-up resistors can be used on the disk interface. See Figure 10-3 for a schematic of the connection.





<u>64</u>

## intel.

## Pin Changes on the 44 Pin Part:

- If the 44PD EN bit in the powerdown command is set, then the FDS1# and FDME1# no longer function as drive select and motor enable. Instead these pins become functional as status outputs of PD and IDLE.
- INVERT# is removed.
- Four NCs (no connects) are removed.
- MFM, IDENT have been removed. The 44 pin 82078 only operates in AT/EISA mode.
- PLL0 is removed. Hardware configurability for tape drive mode is not supported. Configure tape mode via the TDR register.
- DENSEL, DRATE1, DRATE0 pins have been substituted by DRVDEN0, DRVDEN1. The new pins are configured for each drive via the Drive Specification command.
- DRV2 and RDGATE are not available.
- There are 3  $V_{SS}$  pins, 2  $V_{CC}$  pins, one AV\_{SS} and one AV\_{CC} pin.

## 11.0 D.C. SPECIFICATIONS

## 11.1 Absolute Maximum Ratings

| Storage Temperature65°C to +150°C                       |
|---------------------------------------------------------|
| Supply Voltage $-0.5$ to $+8.0$ V                       |
| Voltage on Any Input $\dots$ GND - 2V to 6.5V           |
| Voltage on Any Output . GND $-$ 0.5V to $V_{CC} + 0.5V$ |
| Power Dissipation1W                                     |

NOTICE: This is a production data sheet. The specifications are subject to change without notice.

\* WARNING: Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

## **11.2 D.C. Characteristics** $T_A = 0^{\circ}C$ to $+70^{\circ}C$ , $V_{SS} = AV_{SS} = 0V$

|        | Parameter                                     | $V_{CC} = +5V \pm 10\%$ |                       |                            | $V_{CC} = 3.3V \pm 0.3V$ |                       |                            |
|--------|-----------------------------------------------|-------------------------|-----------------------|----------------------------|--------------------------|-----------------------|----------------------------|
| Symbol |                                               | Min (V)                 | Max (V)               | Test<br>Conditions         | Min (V)                  | Max (V)               | Test<br>Conditions         |
| VILC   | Input Low Voltage,<br>X1                      | -0.5                    | 0.8                   |                            | -0.3                     | 0.8                   |                            |
| VIHC   | Input High<br>Voltage, X1                     | 3.9                     | V <sub>CC</sub> + 0.5 |                            | 2.4                      | V <sub>CC</sub> + 0.3 |                            |
| VIL    | Input Low Voltage<br>(All Pins except<br>X1)  | -0.5                    | 0.8                   |                            | -0.3                     | 0.8                   |                            |
| ViH    | Input High Voltage<br>(All Pins except<br>X1) | 2.0                     | V <sub>CC</sub> + 0.5 |                            | 2.0                      | V <sub>CC</sub> + 0.3 |                            |
| VOL    | System Interface                              |                         | 0.4                   | l <sub>OL</sub> = 12 mA    |                          | 0.4                   | I <sub>OL</sub> = 6 mA     |
| ÷      | FDD Interface<br>Outptus                      |                         | 0.4                   | I <sub>OL</sub> = 12 mA    |                          | 0.4                   | l <sub>OL</sub> = 6 mA     |
| VOH    | All Outputs                                   | 3.0                     |                       | $I_{OH} = -4.0 \text{ mA}$ | 2.4                      |                       | $I_{OH} = -2.0 \text{ mA}$ |
|        | All Outputs                                   | V <sub>CC</sub> - 0.4   |                       | $I_{OH} = -100 \ \mu A$    | V <sub>CC</sub> - 0.2    |                       | $I_{OH} = -100 \mu A$      |

## 44 PIN D.C. CHARACTERISTICS

## 44 PIN D.C. CHARACTERISTICS ICC

| Symbol           | Parameter                                                                                   | \<br>\  | $V_{\rm CC} = +5^{\circ}$ | V ± 10%                            | $V_{CC} = +3.3V \pm 0.3V$ |                 |                                    |
|------------------|---------------------------------------------------------------------------------------------|---------|---------------------------|------------------------------------|---------------------------|-----------------|------------------------------------|
|                  |                                                                                             | Typical | Max                       | <b>Test Condition</b>              | Typical                   | Max             | <b>Test Condition</b>              |
| ICC1             | 1 Mbps Data Rate<br>V <sub>IL</sub> = V <sub>SS</sub> , V <sub>IH</sub> = V <sub>CC</sub>   | 15.4 mA | 25 mA                     | (Notes 1, 2)                       | 8.4 mA                    | 16 mA           | (Notes 1, 2)                       |
| I <sub>CC2</sub> | 1 Mbps Data Rate<br>V <sub>IL</sub> = 0.45, V <sub>IH</sub> = 2.4                           | 20.8 mA | 30 mA                     | (Notes 1, 2)                       | 8.6 mA                    | 16 mA           | (Notes 1, 2)                       |
| ICC3             | 500 Kbps Data Rate<br>V <sub>IL</sub> = V <sub>SS</sub> , V <sub>IH</sub> = V <sub>CC</sub> | 11.8 mA | 20 mA                     | (Notes 1, 2)                       | 6.2 mA                    | 14 mA           | (Notes 1, 2)                       |
| I <sub>CC4</sub> | 500 Kbps Data Rate<br>V <sub>IL</sub> = 0.45, V <sub>IH</sub> = 2.4                         | 17.6 mA | 25 mA                     | (Notes 1, 2)                       | 6.2 mA                    | 14 mA           | (Notes 1, 2)                       |
| ICCSB            | I <sub>CC</sub> in Powerdown                                                                | 0 μΑ    | 60 µA                     | (Notes 3, 4)                       | 0 μΑ                      | 60 µA           | (Notes 3, 4)                       |
| IIL              | Input Load Current (All Input<br>Pins)                                                      |         | 10 μΑ<br>—10 μΑ           | $V_{IN} = V_{CC}$<br>$V_{IN} = 0V$ |                           | 10 μΑ<br>—10 μΑ | $V_{IN} = V_{CC}$<br>$V_{IN} = 0V$ |

## 44 PIN D.C. CHARACTERISTICS ICC (Continued)

| Symbol | Parameter                        |         | $V_{CC} = +5V \pm 10\%$ |                                           |         | $V_{CC} = +3.3V \pm 0.3V$ |                                           |  |
|--------|----------------------------------|---------|-------------------------|-------------------------------------------|---------|---------------------------|-------------------------------------------|--|
| Symbol | Farameter                        | Typical | Max                     | Test Condition                            | Typical | Max                       | Test Condition                            |  |
| IOFL   | Data Bus Output<br>Float Leakage |         | ±10 μA                  | 0.45 < V <sub>OUT</sub> < V <sub>CC</sub> |         | ±10 μA                    | 0.45 < V <sub>OUT</sub> < V <sub>CC</sub> |  |

#### NOTES:

1. Only the data bus inputs may float.

2. Tested while reading a sync field of "00". Outputs not connected to D.C. loads.

3. V<sub>IL</sub> = V<sub>SS</sub>, V<sub>IH</sub> = V<sub>CC</sub>; Outputs not connected to D.C. loads. 4. Typical value with the oscillator off.

### CAPACITANCE

| C <sub>IN</sub>  | Input Capacitance        | 10 | pF | $f = 1 \text{ MHz}, T_A = 25^{\circ}\text{C}$ |
|------------------|--------------------------|----|----|-----------------------------------------------|
| C <sub>IN1</sub> | Clock Input Capacitance  | 20 | рF | Sampled, Not 100% Tested                      |
| C <sub>I/O</sub> | Input/Output Capacitance | 20 | рF |                                               |

### NOTE:

All pins except pins under test are tied to A.C. ground.

## LOAD CIRCUIT



## A.C. TESTING INPUT, OUTPUT WAVEFORM



## 11.3 Oscillator





The 24 MHz clock can be supplied either by a crystal or a MOS level square wave. All internal timings are referenced to this clock or a scaled count which is data rate dependent.

The crystal oscillator must be allowed to run for 10 ms after  $V_{CC}$  has reached 4.5V or exiting the POWERDOWN mode to guarantee that it is stable.

| Frequency:         | 24 MHz ±0.1%                       |
|--------------------|------------------------------------|
| Mode:              | Parallel Resonant Fundamental Mode |
| Series Resistance: | Less than 40 $\Omega$              |
| Shunt Capacitance: | Less than 5 pF                     |

67

## 12.0 A.C. SPECIFICATIONS

 $T_A = 0^{\circ}C$  to +70°C,  $V_{CC} = +5V \pm 10\%$ , +3.3V ±0.3V,  $V_{SS} = AV_{SS} = 0V$ 

| Symbol    | Parameter                             | Min       | Max      | Unit    |
|-----------|---------------------------------------|-----------|----------|---------|
| CLOCK TIM | INGS                                  |           |          |         |
| t1        | Clock Rise Time                       |           | 10       | ns      |
|           | Clock Fall Time                       |           | 10       | ns      |
| t2        | Clock High Time <sup>(7)</sup>        | 16        | 26       | ns      |
| t3        | Clock Low Time <sup>(7)</sup>         | 16        | 26       | ns      |
| t4        | Clock Period                          | 41.66     | 41.66    | ns      |
| t5        | Internal Clock Period <sup>(3)</sup>  |           |          |         |
| HOST READ | CYCLES                                |           |          |         |
| t7        | Address Setup to RD#                  | 5         |          | ns      |
| t8        | RD# Pulse Width                       | 90        |          | ns      |
| t9        | Address Hold from RD#                 | 0         |          | ns      |
| t10       | Data Valid from RD# <sup>(12)</sup>   |           | 80       | ns      |
| t11       | Command Inactive                      | 60        |          | ns      |
| t12       | Output Float Delay                    |           | 35       | ns      |
| t13       | INT Delay from RD#(16)                |           | t5 + 125 | ns      |
| t14       | Data Hold from RD#                    | 5         |          | ns      |
| HOST WRIT | E CYCLES                              |           |          |         |
| t15       | Address Setup to WR #                 | 5         |          | ns      |
| t16       | WR # Pulse Width                      | 90        |          | ns      |
| t17       | Address Hold from WR #                | 0         |          | ns      |
| t18       | Command Inactive                      | 60        |          | ns      |
| t19       | Data Setup to WR #                    | 70        |          | ns      |
| t20       | Data Hold from WR #                   | 0         |          | ns      |
| t21       | INT Delay from WR # (16)              |           | t5 + 125 | ns      |
| DMA CYCLE | ES                                    | •         |          | · · · · |
| t22       | DRQ Cycle Period <sup>(1)</sup>       | 6.5       |          | μs      |
| t23       | DACK# to DRQ Inactive                 |           | 75       | ns      |
| t23a      | DRQ to DACK # Inactive                | (Note 15) |          | ns      |
| t24       | RD# to DRQ Inactive <sup>(4)</sup>    |           | 100      | ns      |
| t25       | DACK # Setup to RD #, WR #            | 5         |          | ns      |
| t26       | DACK# Hold from RD#, WR#              | 0         |          | ns      |
| t27       | DRQ to RD#, WR# Active <sup>(1)</sup> | 0         | 6        | μs      |
| t28       | Terminal Count Width <sup>(10)</sup>  | 50        |          | ns      |
| t29       | TC to DRQ Inactive                    |           | 150      | ns      |

## 12.0 A.C. SPECIFICATIONS

 $T_A = 0^{\circ}C$  to +70°C,  $V_{CC} = +5V \pm 10^{\circ}$ , +3.3V  $\pm 0.3V$ ,  $V_{SS} = AV_{SS} = 0V$  (Continued)

| Symbol     | Parameter                             | Min       | Max       | Unit     |
|------------|---------------------------------------|-----------|-----------|----------|
| RESET      |                                       |           | <u> </u>  | ·        |
| t30        | "Hardware" Reset Width <sup>(5)</sup> | 1.13      |           | μs       |
| t30a       | "Software" Reset Width <sup>(5)</sup> | (Note 11) |           | ns       |
| t31        | Reset to Control Inactive             |           | 2         | μs       |
| WRITE DAT  | A TIMING                              |           |           |          |
| t32        | Data Width <sup>(6)</sup>             |           |           | ns       |
| DRIVE CONT | FROL                                  |           |           |          |
| t35        | DIR # Setup to STEP # (14)            | 1.0       |           | μs       |
| t36        | DIR # Hold from STEP #                | 10        |           | μs       |
| t37        | STEP# Active Time (High)              | 2.5       |           | μs       |
| t38        | STEP # Cycle Time <sup>(2)</sup>      |           |           | μs       |
| t39        | INDEX# Pulse Width                    | 5         |           | t5       |
| t41        | WE# to HDSEL# Change                  | (Note 13) |           | ms       |
| READ DATA  | TIMING                                |           |           |          |
| t40        | Read Data Pulse Width                 | 50        |           | ns       |
| t44        | PLL Data Rate                         | 90        |           | ns       |
|            | 82078                                 |           | 1M        | bits/sec |
| t44        | Data Rate Period = 1/f44              |           | · · · · · |          |
| tLOCK      | Lockup Time                           |           | 64        | t44      |

NOTES:

- 1. This timing is for FIFO threshold = 1. When FIFO threshold is N bytes, the value should be multiplied by N and subtract 1.5  $\mu$ s. The value shown is for 1 Mbps, scales linearly with data rate.
- 2. This value can range from 0.5 ms to 8.0 ms and is dependent upon data rate and the Specify command value.
- 3. Many timings are a function of the selected data rate. The nominal values for the internal clock period (t5) for the various data rates are:
  - 1 Mbps  $3 \times \text{oscillator period} = 125 \text{ ns}$
  - 500 Kbps  $6 \times \text{oscillator period} = 250 \text{ ns}$
  - 300 Kbps  $10 \times \text{oscillator period} = 420 \text{ ns}$
- 250 Kbps  $12 \times \text{oscillator period} = 500 \text{ ns}$ 4. If DACK# transitions before RD#, then this specification is ignored. If there is no transition on DACK#, then this becomes

the DRQ inactive delay.

int<sub>el</sub>.

5. Reset requires a stable oscillator to meet the minimum active period.

6. Based on the internal clock period (t5). For various data rates, the Write Data Width minimum values are:

1 Mbps  $5 \times \text{oscillator period} -50 \text{ ns} = 150 \text{ ns}$ 

500 Kbps  $10 \times \text{oscillator period} -50 \text{ ns} = 360 \text{ ns}$ 

300 Kbps  $16 \times \text{oscillator period} -50 \text{ ns} = 615 \text{ ns}$ 

- 250 Kbps  $19 \times \text{oscillator period} -50 \text{ ns} = 740 \text{ ns}$
- Test points for clock high time are 3.5V. Due to transitional times, clock high time max and clock low time max cannot be met simultaneously. Clock high time min and clock low time max can not be met simultaneously.
- 8. Based on internal clock period (t5).

9. Jitter tolerance is defined as:

(Maximum bit shift from nominal position  $\div \frac{1}{4}$  period of nominal data rate)  $\times 100\%$ 

is a measure of the allowable bit jitter that may be present and still be correctly detected. The data separator jitter tolerance is measured under dynamic conditions that jitters the bit stream according to a reverse precompensation algorithm.

- 10. TC width is defined as the time that both TC and DACK# are active. Note that TC and DACK# must overlap at least 50 ns.
- 11. The minimum reset active period for a software reset is dependent on the data rate, after the 82078 has been properly reset using the t30 spec. The minimum software reset period then becomes:

| 1 Mbps   | 3 × t4 = 125 ns                   |
|----------|-----------------------------------|
| 500 Kbps | 6	imest4 = 250 ns                 |
| 300 Kbps | $10 \times t4 = 420  \mathrm{ns}$ |
| 250 Kbps | $12 \times t4 = 500 \text{ ns}$   |

Status Register's status bits which are not latched may be updated during a Host read operation.
 The minimum MFM values for WE to HDSEL change (t41) for the various data rates are:

| imum M⊢M | values for | WE to HDSE | L change ( | (t41) | for the | various | data | ra |
|----------|------------|------------|------------|-------|---------|---------|------|----|
|          |            | 1 Mbps     | 0.5  ms +  | [8 ×  | GPL1    |         |      |    |

| 1 10003  | 0.0 110  |                      |
|----------|----------|----------------------|
| 500 Kbps | 1.0 ms + | [16 $	imes$ GPL]     |
| 300 Kbps | 1.6 ms + | $[26.66 \times GPL]$ |
| 250 Kbps | 2.0 ms + | [32 	imes GPL]       |
|          |          |                      |

GPL is the size of gap3 defined in the sixth byte of a Write Command.

14. This timing is a function of the selected data rate as follows:

| 1 Mbps   | 1.0 μs min  |
|----------|-------------|
| 500 Kbps | 2.0 µs min  |
| 300 Kbps | 3.3 µs min  |
| 250 Khos | 4.0 u.s min |

- 15. This timing is a function of the internal clock period (t5) and is given as  $(\frac{2}{3})$  t5. The values of t5 are shown in Note 3.
- 16. The timings t13 and t21 are specified for INT signal in the polling mode only. These timings in case of the result phase of the read and write commands are microcode dependent.

I







71

# 82078 44 PIN

# intel







72

# int<sub>el</sub>.



NOTE:

For overlapped seeks, only one step pulse per drive section is issued. Non-overlapped seeks will issue all programmed step pulses.



# 12.1 Package Outline for the 44 Pin QFP Part

82078 addresses the current need of the smaller and thinner packages, for the current market. The size of the part is becoming increasingly important in the portable computer market. The QFP part considerably reduces the real estate consumed. The package outline with the appropriate dimensions are given below:



| Description    | Cumhol | 44 Pin QFP Package                    |                |  |  |
|----------------|--------|---------------------------------------|----------------|--|--|
| Description    | Symbol | Nominal (mm)                          | Tolerance (mm) |  |  |
| Overall Height | A      | 2.10                                  | ±0.25          |  |  |
| Stand Off      | A1     | 0.35                                  | ±0.15          |  |  |
| Lead Width     | В      | 0.30                                  | ±0.10          |  |  |
| Lead Thickness | С      | 0.15                                  | ±0.05          |  |  |
| Terminal       | D      | 12.4                                  | ±0.40          |  |  |
| Long Side      | D1     | 10.0                                  | ±0.10          |  |  |
| Terminal       | E      | 12.4                                  | ±0.40          |  |  |
| Short Side     | E1     | 10.0                                  | ±0.10          |  |  |
| Lead Spacing   | e1     | 0.80                                  | ±0.15          |  |  |
| Lead Count     | N      | · · · · · · · · · · · · · · · · · · · | 44             |  |  |



### 13.0 REVISION HISTORY FOR THE 82078 44 PIN

The following list represents the key differences between version 002 and version 003 of the 82078 44 pin data sheet.

# Section 2.1

Reference to register SRA removed. SRA is not available on the 44 pin 82078.

### Section 2.1.2

DRIVE SEL 1 removed from DOR description. This bit is not available on the 44 pin version of the 82078.

# Section 4.2

Clarification of PDOSC.

# Section 4.4

Reference to register SRA removed. SRA is not available on the 44 pin 82078.

## Section 5.2.3

Redundant information removed.

# Section 5.2.4

Redundant information removed.

# Section 6.3.2

Clarification of command.

# Table 1.0

Reference to register SRA removed. SRA is not available on the 44 pin 82078.

# Table 2-2 and Table 2-3

Table headings swapped to proper tables.

# intel. 82078 64 PIN CHMOS SINGLE-CHIP FLOPPY DISK CONTROLLER

- Small Footprint and Low Height Packages
- Supports Standard 5.0V as well as Low Voltage 3.3V Platforms
  - --- Selectable 3.3V and 5.0V Configuration
  - 5.0V Tolerant Drive Interface
- Enhanced Power Management
  - Application Software Transparency
  - Programmable Powerdown Command
  - --- Save and Restore Commands for Zero-Volt Powerdown
  - Auto Powerdown and Wakeup Modes
  - Two External Power Management Pins
  - Consumes no Power when in Powerdown
- Integrated Analog Data Separator
  - 250 Kbps
  - 300 Kbps
  - 500 Kbps
  - 1 Mbps
  - -2 Mbps
- Programmable Internal Oscillator
- Floppy Drive Support Features
  - Drive Specification Command - Media ID Capability Provides Media
  - Recognition
  - Drive ID Capability Allows the User to Recognize the Type of Drive

- --- Selectable Boot Drive
- Standard IBM and ISO Format Features
- Format with Write Command for High Performance in Mass Floppy Duplication
- Integrated Tape Drive Support
   Standard 1 Mbps/500 Kbps/ 250 Kbps Tape Drives
   New 2 Mbps Tape Drive Mode
- Perpendicular Recording Support for 4 MB Drives
- Integrated Host/Disk Interface Drivers
- Fully Decoded Drive Select and Motor Signals
- Programmable Write Precompensation Delays
- Addresses 256 Tracks Directly, Supports Unlimited Tracks
- 16 Byte FIFO
- Single-Chip Floppy Disk Controller Solution for Portables and Desktops
   — 100% PC AT\* Compatible
  - 100% PS/2\* Compatible
  - 100% PS/2 Model 30 Compatible
  - Fully Compatible with Intel386™ SL Microprocessor SuperSet
- Integrated Drive and Data Bus Buffers
- Available in 64 Pin QFP Package

The 82078, a 24 MHz crystal, a resistor package, and a device chip select implements a complete solution. All programmable options default to 82078 compatible values. The dual PLL data separator has better performance than most board level/discrete PLL implementations. The FIFO allows better system performance in multi-master (e.g., Microchannel, EISA).

The 82078 maintains complete software compatibility with the 82077SL/82077AA/8272A floppy disk controllers. It contains programmable power management features while integrating all of the logic required for floppy disk control. The power management features are transparent to any application software. There are two versions of 82078 floppy disk controllers, the 82078SL and 82078-1.

The 82078 is fabricated with Intel's advanced CHMOS III technology and is also available in a 44-lead QFP package.

\*Other brands and names are the property of their respective owner.

# 82078 64 Pin CHMOS Single-Chip Floppy Disk Controller

| CONTENTS                                                                        |
|---------------------------------------------------------------------------------|
| 1.0 INTRODUCTION                                                                |
| 2.0 MICROPROCESSOR INTERFACE 85                                                 |
| 2.1 Status, Data and Control<br>Registers                                       |
| 2.1.1 Status Register A (SRA, PS/2<br>Mode)85                                   |
| 2.1.2 Status Register A (SRA,<br>Model 30 Mode)                                 |
| 2.1.3 Status Register B (SRB,<br>Enhanced AT/EISA)                              |
| 2.1.4 Status Register B (SRB, PS/2<br>Mode)87                                   |
| 2.1.5 Status Register B (SRB,<br>Model 30 Mode)87                               |
| 2.1.6 Digital Output Register<br>(DOR)87                                        |
| 2.1.7 Tape Drive Register (TDR<br>AT/EISA, PS/2, Model 30)                      |
| 2.1.8 Enhanced Tape Drive<br>Register (TDR, AT, PS/2, Model<br>30, EREG EN = 1) |
| 2.1.9 Datarate Select Register<br>(DSR)                                         |
| 2.1.10 Main Status Register<br>(MSR)91                                          |
| 2.1.11 FIFO (DATA)                                                              |
| 2.1.12 Digital Input Register (DIR,<br>PC-AT MODE)92                            |
| 2.1.13 Digital Input Register (DIR,<br>PS/2 MODE)92                             |
| 2.1.14 Digital Input Register (DIR,<br>MODEL 30 MODE)                           |
| 2.1.15 Configuration Control<br>Register (CCR, PS/2 MODES) 93                   |
| 2.1.16 Configuration Control<br>Register (CCR, MODEL 30<br>MODE)                |
| 2.2 Reset                                                                       |
| 2.2.1 Reset Pin ("HARDWARE")<br>Reset                                           |
| 2.2.2 DOR Reset vs DSR Reset<br>("SOFTWARE" RESET)94                            |
| 2.3 DMA Transfers                                                               |

| <b>CONTENTS</b> PAGE                                           |
|----------------------------------------------------------------|
| <b>3.0 DRIVE INTERFACE</b>                                     |
| 3.1 Cable Interface                                            |
| 3.2 Data Separator                                             |
| 3.2.1 Jitter Tolerance                                         |
| 3.2.2 Locktime (tLOCK)                                         |
| 3.2.3 Capture Range                                            |
| 3.3 Write Precompensation                                      |
| 4.0 POWER MANAGEMENT<br>FEATURES                               |
| 4.1 Power Management Scheme 97                                 |
| 4.2 3.3V Support for Portable<br>Platforms                     |
| 4.3 Oscillator Power Management 97                             |
| 4.4 Part Power Management                                      |
| 4.4.1 Direct Powerdown                                         |
| 4.4.2 Auto Powerdown                                           |
| 4.4.3 Wake Up Modes                                            |
| 4.4.3.1 Wake Up from DSR<br>Powerdown                          |
| 4.4.3.2 Wake Up from Auto<br>Powerdown                         |
| 4.5 Register Behavior                                          |
| 4.6 Pin Behavior 100                                           |
| 4.6.1 System Interface Pins 100                                |
| 4.6.2 FDD Interface Pins 101                                   |
| 5.0 CONTROLLER PHASES 102                                      |
| 5.1 Command Phase 102                                          |
| 5.2 Execution Phase 102                                        |
| 5.2.1 Non-DMA Mode, Transfers<br>from the FIFO to the Host 102 |
| 5.2.2 Non-DMA Mode, Transfers<br>from the Host to the FIFO 102 |
| 5.2.3 DMA Mode, Transfers from<br>the FIFO to the Host         |
| 5.2.4 DMA Mode, Transfers from<br>the Host to the FIFO 103     |
| 5.2.5 Data Transfer Termination 103                            |
| 5.3 Result Phase 103                                           |

# CONTENTS

| 6.0 COMMAND SET/DESCRIPTIONS               | . 103 |
|--------------------------------------------|-------|
| 6.1 Data Transfer Commands                 | . 116 |
| 6.1.1 Read Data                            | . 116 |
| 6.1.2 Read Deleted Data                    | . 117 |
| 6.1.3 Read Track                           | . 117 |
| 6.1.4 Write Data                           | . 118 |
| 6.1.5 Write Deleted Data                   | . 118 |
| 6.1.6 Verify                               | . 118 |
| 6.1.7 Format Track                         | . 120 |
| 6.1.7.1 Format Fields                      | . 120 |
| 6.2 Control Commands                       | . 121 |
| 6.2.1 Read ID                              | . 121 |
| 6.2.2 Recalibrate                          | . 121 |
| 6.2.3 Drive Specification                  |       |
| Command                                    |       |
| 6.2.4 Seek                                 |       |
| 6.2.5 Scan Commands                        |       |
| 6.2.6 Sense Interrupt Status               |       |
| 6.2.7 Sense Drive Status                   |       |
| 6.2.8 Specify                              |       |
| 6.2.9 Configure                            |       |
| 6.2.10 Version                             |       |
| 6.2.11 Relative Seek                       |       |
| 6.2.12 DUMPREG                             | . 126 |
| 6.2.13 Perpendicular Mode<br>Command       | . 126 |
| 6.2.13.1 About Perpendicular               |       |
| Recording Mode                             | . 126 |
| 6.2.13.2 The Perpendicular<br>Mode Command | . 126 |
| 6.2.14 Powerdown Mode<br>Command           | . 127 |
| 6.2.15 Part ID Command                     | . 127 |
| 6.2.16 Option Command                      | . 127 |
| 6.2.17 Save Command                        |       |
| 6.2.18 Restore Command                     | . 128 |
| 6.2.19 Format and Write<br>Command         | . 128 |
| 6.2.20 Lock                                |       |
|                                            |       |

# PAGE CONTENTS

| 7.0 STATUS REGISTER ENCODING                                           | . 129 |
|------------------------------------------------------------------------|-------|
| 7.1 Status Register 0                                                  | . 129 |
| 7.2 Status Register 1                                                  | . 129 |
| 7.3 Status Register 2                                                  | . 130 |
| 7.4 Status Register 3                                                  | . 130 |
| 8.0 COMPATIBILITY                                                      |       |
| 8.1 PS/2 vs. AT vs. Model 30 Mode                                      |       |
| 8.2 Compatibility with the FIFO                                        | . 131 |
| 8.3 Drive Polling                                                      | . 131 |
| 9.0 PROGRAMMING GUIDELINES                                             | . 131 |
| 9.1 Command and Result Phase<br>Handshaking                            | . 131 |
| 9.2 Initialization                                                     |       |
| 9.3 Recalibrates and Seeks                                             | . 134 |
| 9.4 Read/Write Data Operations                                         | . 134 |
| 9.5 Formatting                                                         | . 136 |
| 9.6 Save and Restore                                                   | . 137 |
| 9.7 Verifies                                                           |       |
| 9.8 Powerdown State and Recovery                                       | . 138 |
| 9.8.1 Oscillator Power<br>Management                                   | . 138 |
| 9.8.2 Part Power Management                                            |       |
| 9.8.2.1 Powerdown Modes                                                | . 138 |
| 9.8.2.2 Wake Up Modes                                                  | . 139 |
| 10.0 DESIGN APPLICATIONS                                               | . 139 |
| 10.1 Operating the 82078SL in a 3.3V Design                            | . 139 |
| 10.2 Selectable Boot Drive                                             |       |
| 10.3 How to Disable the Native Floppy<br>Controller on the Motherboard |       |
| 10.4 Replacing the 82077SL with an                                     |       |
| 82078 in a 5.0V Design                                                 | . 142 |
| 11.0 D.C. SPECIFICATIONS                                               | . 145 |
| 11.1 Absolute Maximum Ratings                                          |       |
| 11.2 D.C. Characteristics                                              |       |
| 11.3 Oscillator                                                        | . 147 |
| 12.0 A.C. SPECIFICATIONS                                               | . 148 |
| 12.1 Package Outline for the 64 QFP<br>Part                            | . 154 |
| 13.0 REVISION HISTORY                                                  |       |
|                                                                        |       |



### Figure 1-0. 82078 Pinout

| Symbol  | Pin<br>#       | 1/0                        | @ H/W<br>Reset | Description |                                                                                                                                       |              |              |                                   |            |  |
|---------|----------------|----------------------------|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------|-----------------------------------|------------|--|
| HOST IN | HOST INTERFACE |                            |                |             |                                                                                                                                       |              |              |                                   |            |  |
| RESET   | 50             | ļ                          | N/A            |             | <b>RESET:</b> A high level places the 82078 in a known idle state. All registers are cleared except those set by the Specify command. |              |              |                                   |            |  |
| A0      | 58             | 1                          | N/A            | AD          | DRES                                                                                                                                  | <b>S:</b> Se | lects one of | the host interface registers:     |            |  |
| A1      | 57             | $({\bf k}_{ij})_{i \in I}$ |                | A2          | A1                                                                                                                                    | <b>A</b> 0   | Access       | Register                          |            |  |
| A2      | 55             |                            |                | 0           | 0                                                                                                                                     | 0            | R            | Status Register A                 | SRA        |  |
|         |                |                            |                | 0           | 0                                                                                                                                     | 1            | R/W          | Status Register B                 | SRB        |  |
|         |                |                            |                | 0           | 1                                                                                                                                     | 0            | R/W          | Digital Output Register           | DOR        |  |
|         |                |                            |                | 0           | 1                                                                                                                                     | 1            | R/W          | Tape Drive Register               | TDR        |  |
|         |                |                            |                | 1           | 0                                                                                                                                     | 0            | R            | Main Status Register              | MSR        |  |
|         |                |                            |                | 1           | 0                                                                                                                                     | 0            | W            | Data Rate Select Register         | DSR        |  |
|         |                |                            |                | 1           | 0                                                                                                                                     | 1            | R/W          | Data Register (FIFO)              | FIFO       |  |
|         |                |                            |                | 1           | 1                                                                                                                                     | 0            | Reserved     |                                   |            |  |
|         |                |                            |                | 1           | 1                                                                                                                                     | 1            | R            | Digital Input Register            | DIR        |  |
|         |                | 1                          | · · · ·        | 1           | 1                                                                                                                                     | 1            | W            | Configuration Control Register    | CCR        |  |
| CS#     | 60             | I                          | N/A            | CHI<br>WR   |                                                                                                                                       | LECT         | : Decodes t  | he base address range and qualifi | es RD# and |  |

I

| Table 1-0. 82078 (64 Pin) Description (Continued)    |                                     |       |                |                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|------------------------------------------------------|-------------------------------------|-------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Symbol                                               | Pin<br>#                            | 1/0   | @ H/W<br>Reset | Description                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| HOST IN                                              | TERF                                | ACE ( | Continued      | )                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
| RD#                                                  | 61                                  | I     | N/A            | <b>READ:</b> Read control signal for data transfers from the floppy drive to the system.                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
| WR#                                                  | 63                                  | 1     | N/A            | WRITE: Write control signal for data transfers to the floppy drive from the system.                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| DRQ                                                  | 64                                  | 0     |                | <b>DMA REQUEST:</b> Requests service from a DMA controller. Normally active high, but will go to high impedance in AT and Model 30 modes when the appropriate bit is set in the DOR.                                                                                                                                                                                                                                             |  |  |  |  |  |
| DACK#                                                | 1                                   | •     | N/A            | <b>DMA ACKNOWLEDGE:</b> Control input that qualifies the RD#, WR# inputs in DMA cycles. Normally active low, but is disabled in AT and Model 30 modes when the appropriate bit is set in the DOR.                                                                                                                                                                                                                                |  |  |  |  |  |
| DB0<br>DB1<br>DB2<br>DB3<br>DB4<br>DB5<br>DB6<br>DB7 | 2<br>5<br>7<br>10<br>12<br>13<br>15 | 1/0   |                | DATA BUS: 12 mA data bus.                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| IDENTO<br>IDENT1                                     | 6<br>11                             | -     | N/A            | IDENTITY: These inputs decode between the several operation modes available to the user. These pins have no effect on the DRVDEN pins.         IDENT0       IDENT1       INTERFACE         1       1       AT mode         1       0       ILLEGAL         0       1       PS/2 mode         0       0       Model 30                                                                                                            |  |  |  |  |  |
|                                                      |                                     |       |                | AT MODE: Major options are: enables DMA gate logic, TC is active high,<br>Status Register B is available based on a bit the powerdown command.<br>PS/2 MODE: Major options are: no DMA gate logic, TC is active low, Status<br>Registers A & B are available.<br>MODEL 30 MODE: Major options are: enable DMA gate logic, TC is active<br>high, Status Registers A & B are available.                                            |  |  |  |  |  |
| INT                                                  | 17                                  | 0     |                | <b>INTERRUPT:</b> Signals a data transfer in non-DMA mode and when status is valid. Normally active high, but goes to high impedance when the appropriate bit is set in the DOR.                                                                                                                                                                                                                                                 |  |  |  |  |  |
| TC                                                   | 18                                  | I     | N/A            | <b>TERMINAL COUNT:</b> Control line from a DMA controller that terminates the current disk transfer. TC is effective only when qualified by DACK #. This input is active high in the AT, and Model 30 modes when the appropriate bit is set in the DOR.                                                                                                                                                                          |  |  |  |  |  |
| X1<br>X2                                             | 52<br>51                            |       | N/A            | <b>EXTERNAL CLOCK OR CRYSTAL:</b> Connection for a 24 MHz fundamental mode parallel resonant crystal. X1 can also be driven by an external clock (external oscillator) which can be either at 48 MHz or 24 MHz. If external oscillator is used then the PDOSC bit can be set to turn off the internal oscillator. Also, if a 48 MHz exernal oscillator is used then the CLK48 bit must be set in the enhanced CONFIGURE command. |  |  |  |  |  |

## Table 1-0. 82078 (64 Pin) Description (Continued)

| Symbol                                                           | Pin<br>#             | 1/0  | @ H/W<br>Reset | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------------------------------------------------------------|----------------------|------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| POWER MA                                                         | NAGE                 | MENT |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| SEL3V#                                                           | 16                   | I    | N/A            | <b>SELECT 3.3V:</b> This is a control pin that is used to select between 3.3V operation and 5.0V operation. This is an active low signal and selects 3.3V mode of operation when tied to ground.                                                                                                                                                                                                                                                                      |
| PD                                                               | 54                   | 0    |                | <b>POWERDOWN:</b> This pin is active high whenever the part is in powerdown state, either via DSR POWERDOWN bit or via the Auto Powerdown Mode. This pin can be used to disable an external oscillator's output.                                                                                                                                                                                                                                                      |
| IDLE                                                             | 59                   | 0    |                | <b>IDLE:</b> This pin indicates that the part is in the IDLE state and can be powered down. IDLE state is defined as $MSR = 80H$ , $INT = 0$ , and the head being "unloaded" (as defined in Section 4.0, Power Management Features). Whenever the part is in this state, IDLE pin is active high. If the part is powered down by the Auto Powerdown Mode, IDLE pin is set high and if the part is powered down by setting the DSR POWERDOWN bit, IDLE pin is set low. |
| PLL SECTIO                                                       | N                    |      |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| RDDATA#                                                          | 27                   | 1 -  | N/A            | READ DATA: Serial data from the floppy disk.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| RDGATE                                                           | 49                   | 0    |                | READ GATE: This signal is basically used for diagnostic purposes.                                                                                                                                                                                                                                                                                                                                                                                                     |
| DISK CONT                                                        | ROL                  |      |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| DRV2#                                                            | 19                   | I    | N/A            | <b>DRIVE2:</b> This is an active low signal that indicates whether a second drive is installed and is reflected in SRA.                                                                                                                                                                                                                                                                                                                                               |
| TRK0#                                                            | 20                   | I    | N/A            | TRACK0: This is an active low signal that indicates that the head is on track 0.                                                                                                                                                                                                                                                                                                                                                                                      |
| INDX#                                                            | 21                   | I    | N/A            | <b>INDEX:</b> This is an active low signal that indicates the beginning of the track.                                                                                                                                                                                                                                                                                                                                                                                 |
| WP#                                                              | 22                   | 1 -  | N/A            | <b>WRITE PROTECT:</b> This is an active low signal that indicates whether the floppy disk in the drive is write protected.                                                                                                                                                                                                                                                                                                                                            |
| MEDID1<br>MEDID0                                                 | 25<br>40             | ł    | N/A            | <b>MEDIA ID:</b> These are active high signals that are output from the drive to indicate the density type of the media installed in the floppy drive. These should be tied low if not being used.                                                                                                                                                                                                                                                                    |
| DSKCHG#                                                          | 26                   | 1    | N/A            | <b>DISK CHANGE:</b> This is an input from the floppy drive reflected in the DIR.                                                                                                                                                                                                                                                                                                                                                                                      |
| DRVDEN0<br>DRVDEN1                                               | 28<br>30             | 0    |                | <b>DRIVE DENSITY:</b> These signals are used by the floppy drive to configure the drive for the appropriate media.                                                                                                                                                                                                                                                                                                                                                    |
| FDME3#<br>FDME2#<br>FDME1#<br>FDME0#                             | 31<br>36<br>44<br>47 | 0    |                | <b>FLOPPY DRIVE MOTOR ENABLE:</b> Decoded motor enables for drives 0 to 3. The motor enable pins are directly controlled via the DOR and are a function of the mapping based on BOOTSEL bits in the TDR.                                                                                                                                                                                                                                                              |
| FDS3 <i>#</i><br>FDS2 <i>#</i><br>FDS1 <i>#</i><br>FDS0 <i>#</i> | 32<br>37<br>45<br>48 | 0    |                | <b>FLOPPY DRIVE SELECT:</b> Decoded floppy drive selects for drives 0 to 3. These outputs are decoded from the select bits in the DOR and are a function of the mapping based on BOOTSEL bits in the TDR.                                                                                                                                                                                                                                                             |
| WRDATA#                                                          | 33                   | 0    |                | WRITE DATA: MFM serial data to the drive. Precompensation value is selectable through software.                                                                                                                                                                                                                                                                                                                                                                       |

# int<sub>el</sub>.

| Symbol                   | Pin<br>#                   | 1/0  | @ H/W<br>Reset | Description                                                                                                                                                                                        |  |  |  |  |  |
|--------------------------|----------------------------|------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| DISK CONTROL (Continued) |                            |      |                |                                                                                                                                                                                                    |  |  |  |  |  |
| WE#                      | 34                         | 0    |                | WRITE ENABLE: Floppy drive control signal that enables the head to write onto the floppy disk.                                                                                                     |  |  |  |  |  |
| HDSEL#                   | 35                         | 0    |                | <b>HEAD SELECT:</b> Selects which side of the floppy disk is to be used for the corresponding data transfer. It is active low and an active level selects head 1, otherwise it defaults to head 0. |  |  |  |  |  |
| STEP#                    | 39                         | 0    |                | STEP: Supplies step pulses to the floppy drive to move the head between tracks.                                                                                                                    |  |  |  |  |  |
| DIR#                     | 42                         | 0    |                | <b>DIRECTION:</b> It is an active low signal which controls the direction the head moves when a step signal is present. The head moves inwards towards the center if this signal is active.        |  |  |  |  |  |
| DRVID0<br>DRVID1         | 46<br>43                   | I    | N/A            | <b>DRIVE ID:</b> These signals are input from the floppy drive and indicate the type of drive being used. These should be tied low if not being used.                                              |  |  |  |  |  |
| POWER A                  | ND G                       | ROUN | D SIGNA        | LS                                                                                                                                                                                                 |  |  |  |  |  |
| V <sub>CCF</sub>         | 41                         |      | N/A            | VOLTAGE: +5V for 5V floppy drive and 3.3V for 3.3V floppy drive.*                                                                                                                                  |  |  |  |  |  |
| V <sub>CC</sub>          | 9<br>56                    |      | N/A            | VOLTAGE: +5V or 3.3V                                                                                                                                                                               |  |  |  |  |  |
| V <sub>SSP</sub>         | 3<br>8                     |      | N/A            | GROUND: 0V                                                                                                                                                                                         |  |  |  |  |  |
| V <sub>SS</sub>          | 14<br>29<br>38<br>53<br>62 |      | N/A            | GROUND: 0V                                                                                                                                                                                         |  |  |  |  |  |
| AV <sub>CC</sub>         | 24                         |      | N/A            | ANALOG VOLTAGE                                                                                                                                                                                     |  |  |  |  |  |
| AVSS                     | 23                         |      | N/A            | ANALOG GROUND                                                                                                                                                                                      |  |  |  |  |  |

### Table 1-0. 82078 (64 Pin) Description (Continued)

#### \*NOTE:

The digital power supply  $V_{CC}$  and the analog power supply  $AV_{CC}$  should either be the same or regulated to be within 0.1V of either.



# **1.0 INTRODUCTION**

The 82078, a 24 MHz (or 48 MHz) oscillator, a resistor package and a chip select implement a complete design. The power management features of the 82078 are transparent to application software, the 82078 seems awake to the software even in powerdown mode. All drive control signals are fully decoded and have 24 mA (12 mA @ 3.3V) drive buffers. Signals returned from the drive are sent through onchip input buffers with hysteresis for noise immunity. The integrated analog data separator needs no external compensation of components, yet allows for wide motor variation with exceptionally low soft error rates. The microprocessor interface has 12 mA drive buffers on the data bus plus 100% hardware register compatibility for PC-AT and Microchannel systems. The 16-byte FIFO with programmable thresholds is extremely useful in multi-master systems (Micro-Channel, EISA) or systems with large bus latency.

The 82078 features:

3.3V operation

- Small QFP package
- · 2 Mbps data rate for tape drives
- Register enhancements from the 82077SL

Several pin changes accommodate the reduced pin count (from the 68 pin 82077SL) and the added features. Functional compatibility refers to software transparency between 82077SL/AA and the 82078. The 64 pin part will implement a superset of the features required to support all platforms, but is not pin to pin compatible to the 82077SL.

The 82078SL is capable of operating at both 3.3V and 5.0V. The 82078-1 only operates at 5.0V but has an available 2 Mbps tape drive data rate. All other features are available on both parts.

| Part<br>Specification | 3.3V | 5.0V | 2 Mbps<br>Data Rate |
|-----------------------|------|------|---------------------|
| 82078SL               | X    | х    |                     |
| 82078-1               |      | X    | Х                   |

Figure 1-1 is a block diagram of the 82078.



Figure 1-1. 82078 Block Diagram

# int<sub>el</sub>.

# 2.0 MICROPROCESSOR INTERFACE

The interface consists of the standard asynchronous signals: RD#, WR#, CS#, A0-A2, INT, DMA control and a data bus. The address lines select between configuration registers, the FIFO and control/status registers. This interface can be switched between PC AT, Model 30, or PS/2 normal modes. The PS/2 register sets are a superset of the registers found in a PC-AT.

# 2.1 Status, Data and Control Registers

As shown below, the base address range is supplied via the CS# pin. For PC-AT or PS/2 designs, the primary and secondary address ranges are 3F0 Hex to 3F7 Hex and 370 Hex to 377 Hex respectively.

| A2 | A1 | AO | Access Type | Register                       |      |
|----|----|----|-------------|--------------------------------|------|
| 0  | 0  | 0  | R           | Status Register A              | SRA  |
| 0  | 0  | 1  | R/W         | Status Register B              | SRB  |
| 0  | 1  | 0  | R/W         | R/W Digital Output Register    |      |
| 0  | 1  | 1  | R/W         | R/W Tape Drive Register        |      |
| 1  | 0  | 0  | R           | Main Status Register           | MSR  |
| 1  | 0  | 0  | W           | Data Rate Select Register      | DSR  |
| 1  | 0  | 1  | R/W         | Data (First In First Out)      | FIFO |
| 1  | 1  | 0  |             | Reserved                       |      |
| 1  | 1  | 1  | R           | Digital Input Register         | DIR  |
| 1  | 1  | 1  | W           | Configuration Control Register | CCR  |

In the following sections, the various registers are shown in their powerdown state. The "UC" notation stands for a value that is returned without change from the active mode. The notation "\*" means that the value is reflecting the required status (for powerdown). "n/a" means not applicable. "X" indicates that the value is undefined.

### 2.1.1 STATUS REGISTER A (SRA, PS/2 MODE)

This register is read-only and monitors the state of the interrupt pin and several disk interface pins. This register is part of the register set, and is not accessible in PC-AT mode.

This register can be accessed during powerdown state without waking up the 82078 from its powerdown state.

| Bits            | 7              | 6     | 5    | 4     | 3     | 2     | 1   | 0   |
|-----------------|----------------|-------|------|-------|-------|-------|-----|-----|
| Function        | INT<br>PENDING | DRV2# | STEP | TRK0# | HDSEL | INDX# | WP# | DIR |
| H/W Reset State | 0              | DRV2# | 0    | TRK0# | 0     | INDX# | WP# | 0   |
| Auto PD State   | 0*             | UC    | 0*   | 1     | 0*    | 1     | 1   | 0*  |

The INT PENDING bit is used by software to monitor the state of the 82078 INTERRUPT pin. By definition, the INT PENDING bit is low in powerdown state. The bits reflecting the floppy disk drive input pins (TRK0, INDEX, and WP) are forced inactive. Floppy disk drive outputs (HDSEL, STEP, and DIR) also go to their inactive, default state.

As a read-only register, there is no default value associated with a reset other than some drive bits will change with a reset. The INT PENDING, STEP, HDSEL, and DIR bits will be low after reset.

| Bits            | 7              | 6   | 5           | 4    | 3      | 2     | 1  | 0    |
|-----------------|----------------|-----|-------------|------|--------|-------|----|------|
| Function        | INT<br>PENDING | DRQ | STEP<br>F/F | TRK0 | HDSEL# | INDX# | WP | DIR# |
| H/W Reset State | 0 -            | 0   | 0           | TRK0 | . 1    | INDX# | WP | 1    |
| Auto PD State   | 0*             | 0*  | 0           | 0    | 1*     | 0     | 0  | 1*   |

#### 2.1.2 STATUS REGISTER A (SRA, MODEL 30 MODE)

This register has the following changes in PS/2 Model 30 Mode. Disk interface pins (Bits 0, 1, 2, 3, and 4) are inverted from PS/2 Mode. The DRQ bit monitors the status of the DMA Request pin. The STEP bit is latched with the Step output going active and is cleared with a read to the DIR register, Hardware or Software RESET.

The DRQ bit is low by definition for 82078 to be in powerdown. The bits reflecting the floppy disk drive input pins (TRK0, INDEX, and WP) are forced to reflect an inactive state. The floppy disk drive outputs (HDSEL, STEP, and DIR) also go to their inactive, default state.

#### 2.1.3 STATUS REGISTER B (SRB, ENHANCED AT/EISA)

In the AT/EISA mode the SRB is made available whenever the EREG EN bit in the auto powerdown command is set. The register functionality is defined as follows (bits 7 through 3 are reserved):

PD and IDLE reflect the values on the corresponding pins. The signal on the IDLE pin can be masked by setting IDLEMSK bit high in this register. The IDLE bit will remain unaffected. Since some systems will use the IDLE pin to provide interrupt to the SMM power management, its disabling allows less external interrupt logic and reduction in board space. Only hardware reset will clear the IDLEMSK bit to zero.

When the IDLEMSK bit is set, the user cannot distinguish between auto powerdown and DSR powerdown (i.e., by using the IDLE pin).

| IDLEMSK | IDLE (pin) |
|---------|------------|
| 0       | unmasked   |
| 1       | masked     |

| SRB       |      |      |      |      |      |         |      |      |  |  |  |  |  |
|-----------|------|------|------|------|------|---------|------|------|--|--|--|--|--|
| Bits      | 7    | 6    | 5    | 4    | 3    | 2       | 1    | 0    |  |  |  |  |  |
| R         | RSVD | RSVD | RSVD | RSVD | RSVD | IDLEMSK | PD   | IDLE |  |  |  |  |  |
| H/W Reset | Х    | Х    | Х    | Х    | X    | 0       | PD   | IDLE |  |  |  |  |  |
| Auto PD   | X    | X    | X    | х    | x    | UC      | UC   | UC   |  |  |  |  |  |
| W         | 0    | 0    | 0    | 0    | 0    | IDLEMSK | RSVD | RSVD |  |  |  |  |  |
| H/W Reset | n/a  | n/a  | n/a  | n/a  | n/a  | 0       | n/a  | n/a  |  |  |  |  |  |
| Auto PD   | n/a  | n/a  | n/a  | n/a  | n/a  | UC      | n/a  | n/a  |  |  |  |  |  |

#### 2.1.4 STATUS REGISTER B (SRB, PS/2 MODE)

| Bits            | 7 | 6 | 5              | 4                | 3                | 2  | 1          | 0          |
|-----------------|---|---|----------------|------------------|------------------|----|------------|------------|
| Function        | 1 | 1 | DRIVE<br>SEL 0 | WRDATA<br>TOGGLE | RDDATA<br>TOGGLE | WE | MOT<br>EN1 | MOT<br>EN2 |
| H/W Reset State | 1 | 1 | 0              | 0                | 0                | 0  | 0          | 0          |
| Auto PD State   | 1 | 1 | UC             | 0                | 0                | 0* | 0          | 0          |

As the only drive input, RDATA TOGGLE's activity reflects the level as seen on the cable.

The two TOGGLE bits do not read back the state of their respective pins directly. Instead, the pins drive a Flip/Flop which produces a wider and more reliable read pulse. Bits 6 and 7 are undefined and always return to a 1.

After any reset, the activity on the TOGGLE pin is cleared. Drive select and Motor bits cleared by the RESET pin and not software resets.

| Bits            | 7     | 6    | 5    | 4             | 3             | 2         | 1    | 0    |
|-----------------|-------|------|------|---------------|---------------|-----------|------|------|
| Function        | DRV2# | DS1# | DS0# | WRDATA<br>F/F | RDDATA<br>F/F | WE<br>F/F | DS3# | DS2# |
| H/W Reset State | DRV2# | 1    | 1    | 0             | 0             | 0         | 1    | 1    |
| Auto PD State   | UC    | UC   | UC   | 0             | . 0           | 0*        | UC   | UC   |

#### 2.1.5 STATUS REGISTER B (SRB, MODEL 30 MODE)

This register has the following changes in Model 30 Mode. Bits 0, 1, 5, and 6 return the decoded value of the Drive Select bits in the DOR register. Bits 2, 3, and 4 are set by their respective active going edges and are cleared by reading the DIR register. The WRDATA bit is triggered by raw WRDATA signals and is not gated by WE. Bits 2, 3, and 4 are cleared to low level by either Hardware or Software RESET.

#### 2.1.6 DIGITAL OUTPUT REGISTER (DOR)

The Digital Output Register contains the drive select and motor enable bits, a reset bit and a DMA GATE # bit.

| Bits            | 7          | 6          | 5          | 4          | 3            | 2      | 1             | 0             |
|-----------------|------------|------------|------------|------------|--------------|--------|---------------|---------------|
| Function        | MOT<br>EN3 | MOT<br>EN2 | MOT<br>EN1 | MOT<br>EN0 | DMA<br>GATE# | RESET# | DRIVE<br>SEL1 | DRIVE<br>SEL2 |
| H/W Reset State | 0          | 0          | 0          | 0          | 0            | 0      | 0             | 0             |
| Auto PD State   | 0*         | 0*         | 0*         | 0*         | UC           | 1*     | UC            | UC            |

The MOT ENx bits directly control their respective motor enable pins (FDME0-3). The DRIVE SELx bits are decoded to provide four drive select lines and only one may be active at a time. Standard programming practice is to set both MOT ENx and DRIVE SELx bits at the same time.

Table 2-1 lists a set of DOR values to activate the drive select and motor enable for each drive.

Table 2-1. Drive Activation Value

| Drive | DOR Value |
|-------|-----------|
| 0     | 1CH       |
| 1     | 2DH       |
| 2     | 4EH       |
| 3     | 8FH       |

The DMAGATE# bit is enabled only in PC-AT and Model 30 Modes. If DMAGATE# is set low, the INT and DRQ outputs are tri-stated and the DACK# and TC inputs are disabled. DMAGATE# set high will enable INT, DRQ, TC, and DACK# to the system. In PS/2 Mode DMAGATE# has no effect upon INT, DRQ, TC, or DACK# pins, they are always active.

The DOR reset bit and the Motor Enable bits have to be inactive when the 82078 is in powerdown. The DMAGATE # and DRIVE SEL bits are unchanged. During powerdown, writing to the DOR does not awaken the 82078 with the exception of activating any of the motor enable bits. Setting the motor enable bits active (high) will wake up the part.

This RESET# bit clears the basic core of the 82078 and the FIFO circuits when the LOCK bit is set to "0" (see Section 5.3.2 for LOCK bit definitions). Once set, it remains set until the user clears this bit. This bit is set by a chip reset and the 82078 is held in a reset state until the user clears this bit. The RESET# bit has no effect upon the register.

| 2.1.7 | TAPE | DRIVE | REGISTER | (TDR | AT/EISA, | PS/2, | MODEL | 30) |  |
|-------|------|-------|----------|------|----------|-------|-------|-----|--|
|       |      |       |          |      |          |       |       |     |  |

| Bits            | 7 | 6 | 5   | 4 | 3 | 2              | 1    | · 0 / |
|-----------------|---|---|-----|---|---|----------------|------|-------|
| Function        | _ | · | · — | — | — |                | TAPE | TAPE  |
|                 |   |   |     |   |   |                | SEL1 | SEL0  |
| H/W Reset State | — |   | —   | - | — |                | 0    | 0     |
| Auto PD State   |   |   | —   | - | _ | — <sup>1</sup> | UC   | UC    |

(---) means these bits are not writable and remain tri-stated if read.

This register allows the user to assign tape support to a particular drive during initialization. Any future references to that drive number automatically invokes tape support. Hardware reset clears this register; software resets have no effect. By default, the tape select bits are hardware RESET to zeros, making Drive 0 not available for tape support.

#### 2.1.8 ENHANCED TAPE DRIVE REGISTER (TDR, AT, PS/2, MODEL 30, EREG EN = 1)

In the PS/2 and Model 30 mode and AT/EISA mode the extended TDR is made available only when the EREG EN bit is set, otherwise the bits are tri-stated. The register functionality is defined as follows:

|           | TDR    |        |        |        |          |          |          |          |
|-----------|--------|--------|--------|--------|----------|----------|----------|----------|
| Bits      | 7      | 6      | 5      | 4      | 3        | 2        | 1        | 0        |
| R         | MEDID1 | MEDIDO | DRVID1 | DRVID0 | BOOTSEL1 | BOOTSELO | TAPESEL1 | TAPESELO |
| H/W Reset | MEDID1 | MEDID0 | DRVID1 | DRVID0 | 0        | 0        | 0        | 0        |
| Auto PD   | UC     | UC     | UC     | UC     | UC       | UC       | UC       | UC       |
| W         | 0      | 0      | 0      | 0      | BOOTSEL1 | BOOTSELO | TAPESEL1 | TAPESELO |
| H/W Reset | n/a    | n/a    | n/a    | n/a    | 0        | 0        | 0        | 0        |
| Auto PD   | n/a    | n/a    | n/a    | n/a    | BOOTSEL1 | BOOTSEL0 | TAPESEL1 | TAPESEL0 |

MEDID1, MEDID0 reflect the values on the respective pins. Similarly, the DRVID0, DRVID1 reflect the values on the DRVID1 and DRVID0 pins.

The TAPESEL1, TAPESEL0 functionality is retained as defined in the non-enhanced TDR, except that the application of boot drive restriction (boot drive cannot be a tape drive) depends on what drive selected is by the BOOTSEL1, BOOTSEL0 bits.



The BOOTSEL1, BOOTSEL0 are not reset by software resets and are decoded as shown below. These bits allow for reconfiguring the boot up drive and only reset by hardware reset. A drive can be enabled by remapping the internal DS0 and ME0 to one of the other drive select and motor enable lines (Refer to "Selectable Boot Drives" in the Design applications chapter). Once a non-default value for BOOTSEL1 and BOOTSEL0 is selected, all programmable bits are virtual designations of drives, i.e., it is the user's responsibility to know the mapping scheme detailed in the following table.

| BOOTSEL1 | BOOTSEL0 | Mapping:                                                                                                                                        |
|----------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 0        | 0        | $DS0 \rightarrow FDS0, ME0 \rightarrow FDME0$<br>$DS1 \rightarrow FDS1, ME1 \rightarrow FDME1$<br>$DS2 \rightarrow FDS2, ME2 \rightarrow FDME2$ |
| 0        | 1        | $DS0 \rightarrow FDS1, ME0 \rightarrow FDME1$<br>$DS1 \rightarrow FDS0, ME1 \rightarrow FDME0$<br>$DS2 \rightarrow FDS2, ME2 \rightarrow FDME2$ |
| 1        | 0        | $DS0 \rightarrow FDS2, ME0 \rightarrow FDME2$<br>$DS1 \rightarrow FDS1, ME1 \rightarrow FDME1$<br>$DS2 \rightarrow FDS0, ME2 \rightarrow FDME0$ |
| 1        | 1        | Reserved                                                                                                                                        |

### 2.1.9 DATARATE SELECT REGISTER (DSR)

| Bits            | 7            | 6             | 5     | 4            | 3            | 2            | 1             | 0             |
|-----------------|--------------|---------------|-------|--------------|--------------|--------------|---------------|---------------|
| Function        | S/W<br>RESET | POWER<br>DOWN | PDOSC | PRE<br>COMP2 | PRE<br>COMP1 | PRE<br>COMP0 | DRATE<br>SEL1 | DRATE<br>SEL0 |
| H/W Reset State | 0            | 0             | 0     | 0            | 0            | 0            | 1             | 0             |
| Auto PD State   | S/W<br>RESET | POWER<br>DOWN | PDOSC | PRE<br>COMP2 | PRE<br>COMP1 | PRE<br>COMP0 | DRATE<br>SEL1 | DRATE<br>SEL0 |

This register ensures backward compatibility with the 82072 floppy controller and is write-only. Changing the data rate changes the timings of the drive control signals. To ensure that drive timings are not violated when changing data rates, choose a drive timing such that the fastest data rate will not violate the timing.

The PDOSC bit is used to implement crystal oscillator power management. The internal oscillator in the 82078 can be programmed to be either powered on or off via PDOSC. This capability is independent of the chip's powerdown state. Auto powerdown mode and powerdown via POWERDOWN bit has no effect over the power state of the oscillator.

In the default state the PDOSC bit is low and the oscillator is powered up. When this bit is programmed to a one, the oscillator is shut off. Hardware reset clears this bit to a zero. Neither of the software resets (via DOR or DSR) have any effect on this bit. Note, PDOSC should only be set high when the part is in the powerdown state, otherwise the part will not function correctly and must be hardware reset once the oscillator has turned back on and stabilized. Setting the PDOSC bit has no effect on the clock input to the 82078 (the X1 pin). The clock input is separately disabled when the part is powered down. The SAVE command checks the status of PDOSC, however, the RESTORE command will not restore the bit high.

S/W RESET behaves the same as DOR RESET except that this reset is self cleaning.

POWERDOWN bit implements direct powerdown. Setting this bit high will put the 82078 into the powerdown state regardless of the state of the part. The part is internally reset and then put into powerdown. No status is saved and any operation in progress is aborted. A hardware or software reset will exit the 82078 from this powerdown state.

PRECOMP 0-2 adjusts the WRDATA output to the disk to compensate for magnetic media phenomena known as bit shifting. The data patterns that are susceptible to bit shifting are well understood and the 82078 compensates the data pattern as it is written to the disk. The amount of pre-compensation is dependent upon the drive and media, but in most cases the default value is acceptable.

| PRECOMP  |             | Precompensation Delays                                                                        |  |  |  |  |  |
|----------|-------------|-----------------------------------------------------------------------------------------------|--|--|--|--|--|
| DSR[432] | x1 @ 24 MHz | x1 @ 48 MHz<br>if CLK48 = 1, enabled only @ 2 Mbps<br>if CLK48 = 0, enabled at all data rates |  |  |  |  |  |
| 111      |             | 0.00 ns-disabled                                                                              |  |  |  |  |  |
| 001      | 41.67       | 20.84                                                                                         |  |  |  |  |  |
| 010      | 83.34       | 41.67                                                                                         |  |  |  |  |  |
| 011      | 125.00      | 62.5                                                                                          |  |  |  |  |  |
| 100      | 166.67      | 83.34                                                                                         |  |  |  |  |  |
| 101      | 208.33      | 104.17                                                                                        |  |  |  |  |  |
| 110      | 250.00      | 125                                                                                           |  |  |  |  |  |
| 000      |             | DEFAULT                                                                                       |  |  |  |  |  |

#### Table 2-2. Precompensation Delays

#### Table 2-3. Default Precompensation Delays

| Data Rate | Precompensation<br>Delays (ns) |
|-----------|--------------------------------|
| 2 Mbps    | 20.84                          |
| 1 Mbps    | 41.67                          |
| 0.5 Mbps  | 125                            |
| 0.3 Mbps  | 125                            |
| 0.25 Mbps | 125                            |

The 82078 starts pre-compensating the data pattern starting on Track 0. The CONFIGURE command can change the track that pre-compensating starts on. Table 2-2 lists the pre-compensation values that can be selected and Table 2-3 lists the default pre-compensation values. The default value is selected if the three bits are zeroes.

DRATE 0-1 select one of the four data rates as listed in Table 2-4. The default value is 250 Kbps after a "Hardware" reset. Other "Software" Resets do not affect the DRATE or PRECOMP bits.

| DRATESEL1 | DRATESEL0 | DATA RATE |  |  |  |  |  |
|-----------|-----------|-----------|--|--|--|--|--|
| 1         | 1         | 1 Mbps    |  |  |  |  |  |
| 0         | 0         | 500 Kbps  |  |  |  |  |  |
| 0         | . 1       | 300 Kbps  |  |  |  |  |  |
| 1         | 0         | 250 Kbps  |  |  |  |  |  |

#### **Table 2-4. Data Rates**

### 2.1.10 MAIN STATUS REGISTER (MSR)

| Bits            | 7   | 6   | 5          | 4          | 3*           | 2            | 1            | 0            |
|-----------------|-----|-----|------------|------------|--------------|--------------|--------------|--------------|
| Function        | RQM | DIO | NON<br>DMA | CMD<br>BSY | DRV3<br>BUSY | DRV2<br>BUSY | DRV1<br>BUSY | DRV0<br>BUSY |
| H/W Reset State | 0   | Х   | X          | x          | Х            | x            | X            | X            |
| Auto PD State   | 1   | 0   | 0          | 0          | 0            | 0            | 0            | 0            |

The Main Status Register is a read-only register and is used for controlling command input and result output for all commands.

RQM-Indicates that the host can transfer data if set to 1. No access is permitted if set to a 0.

DIO—Indicates the direction of a data transfer once RQM is set. A 1 indicates a read and a 0 indicates a write is required.

NON-DMA—This mode is selected in the SPECIFY command and will be set to a 1 during the execution phase of a command. This is for polled data transfers and helps differentiate between the data transfers and the reading of result bytes.

COMMAND BUSY—This bit is set to a one when a command is in progress. This bit goes active after the command byte has been accepted and goes inactive at the end of the results phase. If there is no result phase (SEEK, RECALIBRATE commands), this bit returns to a 0.

DRV x BUSY-These bits are set to ones when a drive is in the seek portion of a command, including seeks and recalibrates.

Some example values of the MSR are:

- MSR = 80H; The controller is ready to receive a command.
- MSR = 90H; executing a command or waiting for the host to read status bytes (assume DMA mode).
- MSR = D0H; waiting for the host to write status bytes.

#### 2.1.11 FIFO (DATA)

All command parameter information and disk data transfers go through the FIFO. The FIFO is 16 bytes in size and has programmable threshold values. Data transfers are governed by the RQM and DIO bits in the Main Status Register.

The FIFO defaults to an 8272A compatible mode after a "Hardware" reset (Reset via pin 32). "Software" Resets (Reset via DOR or DSR register) can also place the 82078 into 8272A compatible mode if the LOCK bit is set to "0" (See the definition of the LOCK bit), maintaining PC-AT hardware compatibility. The default values can be changed through the CONFIGURE command (enable full FIFO operation with threshold control). The advantage of the FIFO is that it allows the system a larger DMA latency without causing a disk error. Table 2-5 gives several examples of the delays with a FIFO. The data is based upon the following formula:

Threshold #  $\times$  1/DATA RATE  $\times$  8 - 1.5  $\mu$ s = DELAY

#### **Table 2-5. FIFO Threshold Examples**

| FIFO Threshold<br>Examples | Maximum Delay to Servicing<br>at 1 Mbps Data Rate |
|----------------------------|---------------------------------------------------|
| 1 byte                     | $1 \times 8 \mu s - 1.5 \mu s = 6.5 \mu s$        |
| 2 bytes                    | $2 \times 8 \mu s - 1.5 \mu s = 14.5 \mu s$       |
| 8 bytes                    | $8 \times 8 \mu s - 1.5 \mu s = 62.5 \mu s$       |
| 15 bytes                   | $15 \times 8 \mu s - 1.5 \mu s = 118.5 \mu s$     |

| FIFO Threshold<br>Examples | Maximum Delay to Servicing<br>at 500 Kbps Data Rate |
|----------------------------|-----------------------------------------------------|
| 1 byte                     | $1 \times 16 \mu s - 1.5 \mu s = 14.5 \mu s$        |
| 2 bytes                    | 2 × 16 μs - 1.5 μs = 30.5 μs                        |
| 8 bytes                    | $8 \times 16 \mu s - 1.5 \mu s = 126.5 \mu s$       |
| 15 bytes                   | $15 \times 16 \mu s - 1.5 \mu s = 238.5 \mu s$      |

At the start of a command, the FIFO action is always disabled and command parameters must be sent based upon the RQM and DIO bit settings. As the 82078 enters the command execution phase, it clears the FIFO of any data to ensure that invalid data is not transferred. An overrun or underrun will terminate the current command and the transfer of data. Disk writes will complete the current sector by generating a 00 pattern and valid CRC.

#### 2.1.12 DIGITAL INPUT REGISTER (DIR, PC-AT MODE)

This register is read only in all modes. In PC-AT mode only bit 7 is driven, all other bits remain tri-stated.

| Bits            | 7          | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----------------|------------|---|---|---|---|---|---|---|
| Function        | DSK<br>CHG |   |   | - | _ |   | — |   |
| H/2 Reset State | DSK<br>CHG | - |   |   | _ |   |   |   |
| Auto PD State   | 0          | _ |   | _ | _ |   |   |   |

(---) means these bits are tri-stated when read.

DSKCHG monitors the pin of the same name and reflects the opposite value seen on the disk cable. The DSKCHG bit is forced inactive along with all the inputs from the floppy disk drive. All the other bits remain tri-stated.

#### 2.1.13 DIGITAL INPUT REGISTER (DIR, PS/2 MODE)

| DIR       |            |      |    |         |   |               |               |               |  |
|-----------|------------|------|----|---------|---|---------------|---------------|---------------|--|
| R/W       | 7          | 6*   | 5* | 4*      | 3 | 2             | 1             | 0             |  |
| R         | DSK<br>CHG | IDLE | PD | IDLEMSK | 1 | DRATE<br>SEL1 | DRATE<br>SEL0 | HIGH<br>DENS# |  |
| H/W Reset | DSK<br>CHG | 1    | 1  | 1       | 1 | 1             | 0             | 1             |  |
| Auto PD   | 0          | 1    | 1  | UC      | 1 | UC            | UC            | UC            |  |

(\*) These bits are only available when PS2 STAT = 1: Bits 5 and 6 show the status of PD (powerdown) and IDLE respectively. Bit 4 shows the status of IDLEMSK, this bit disables the IDLE pin when active.

Bit 3 returns a value of "1", and the DRATE SEL1-0 return the value of the current data rate selected (see Table 2-4 for values).

HIGHDENS# is low whenever the 500 Kbps or 1 Mbps data rates are selected. It is high when either 250 Kbps, 300 Kbps, or 2 Mbps is selected.

The DSKCHG bit is forced inactive along with all the inputs from the floppy disk drive. All the other bits (as applicable) remain unchanged.

The Drive Specification Command modifies the DRATE SEL bits. Refer to Table 6-2 for a description.

| Bits            | 7           | 6*   | 5*  | 4*      | 3            | 2      | 1             | 0             |
|-----------------|-------------|------|-----|---------|--------------|--------|---------------|---------------|
| Function        | DSK<br>CHG# | IDLE | PD  | IDLEMSK | DMA<br>GATE# | NOPREC | DRATE<br>SEL1 | DRATE<br>SEL0 |
| H/W Reset State | N/A         | 0    | 0   | 0       | 0            | 0      | 1             | 0             |
| Auto PD State   | 1           | 1    | . 1 | UC      | UC           | UC     | UC            | UC            |

# 2.1.14 DIGITAL INPUT REGISTER (DIR, MODEL 30 MODE)

(\*) These bits are only available when PS2 STAT = 1: Bits 5 and 6 show the status of PD (powerdown) and IDLE respectively. Bit 4 shows the status of IDLEMSK, this bit disables the IDLE pin when active. Bit 7 (DSKCHG) is inverted in Model 30 Mode.

The DSKCHG # bit is forced inactive along with all the inputs from the floppy disk drive. All the other bits (as applicable) remain unchanged.

The Drive Specification Command modifies the DRATE SEL bits. Refer to Table 6-2 for information regarding the mapping of these bits.

Bit 3 reflects the value of DMAGATE # bit set in the DOR register.

Bit 2 reflects the value of NOPREC bit set in the CCR register.

#### 2.1.15 CONFIGURATION CONTROL REGISTER (CCR, PC AT and PS/2 MODES)

This register sets the datarate and is write only.

| Bits              | 7 | 6 | 5 | 4*      | 3        | 2 | 1             | 0             |
|-------------------|---|---|---|---------|----------|---|---------------|---------------|
| Function          |   | - | _ | IDLEMSK | -        | - | DRATE<br>SEL1 | DRATE<br>SEL0 |
| H/W Restate State | _ | _ | _ |         | <u> </u> |   | 1             | 0             |
| Auto PD State     |   | _ | — | IDLEMSK | _        | _ | DRATE<br>SEL1 | DRATE<br>SEL0 |

(\*) This bit is enabled only when PS2 STAT = 1 (Powerdown Mode). Refer to the table in the Data Rate Select Register for values. Unused bits should be set to 0. IDLEMSK is not available in the CCR for PC AT mode. In PC AT, IDLEMSK is available in the SRB.

#### 2.1.16 CONFIGURATION CONTROL REGISTER (CCR, MODEL 30 MODE)

| Bits            | 7 | 6 | 5 | 4*      | 3 | 2      | 1             | 0             |
|-----------------|---|---|---|---------|---|--------|---------------|---------------|
| Function        | _ | — | - | IDLEMSK | - | NOPREC | DRATE<br>SEL1 | DRATE<br>SEL0 |
| H/W Reset State | _ | — | _ | 0       |   | 0      | 1             | 0             |
| Auto PD State   | _ | _ | _ | UC      | _ | UC     | UC            | UC            |

(\*) This bit is enabled only when PS2 STAT = 1 (Powerdown Mode). NOPREC has no function, and is reset to "0" with a Hardware RESET only.

# 2.2 Reset

There are three sources of reset on the 82078; the RESET pin, a reset generated via a bit in the DOR and a reset generated via a bit in the DSR. All resets take the 82078 out of the powerdown state.

In entering the reset state, all operations are terminated and the 82078 enters an idle state. Activating reset while a disk write activity is in progress will corrupt the data and CRC.

On exiting the reset state, various internal registers are cleared, and the 82078 waits for a new command. Drive polling will start unless disabled by a new CONFIGURE command.

#### 2.2.1 RESET PIN ("HARDWARE") RESET

The RESET pin is a global reset and clears all registers except those programmed by the SPECIFY command. The DOR Reset bit is enabled and must be cleared by the host to exit the reset state.

#### 2.2.2 DOR RESET vs DSR RESET ("SOFTWARE" RESET)

These two resets are functionally the same. The DSR Reset is included to maintain 82072 compatibility. Both will reset the 82072 core which affects drive status information. The FIFO circuits will also be reset if the LOCK bit is a "0" (see definition of the LOCK bit). The DSR Reset clears itself automatically while the DOR Reset requires the host to manually clear it. DOR Reset has precedence over the DSR Reset. The DOR Reset is set automatically upon a pin RESET. The user must manually clear this reset bit in the DOR to exit the reset state.

The t30a specification in the A.C. Specifications gives the minimum amount of time that the DOR reset must be held active. This amount of time that the DOR reset must be held active is dependent upon the data rate. The 82078 requires that the DOR reset bit must be held active for at least 0.5  $\mu$ s at 250 Kbps. This is less than a typical ISA I/O cycle time.

### 2.3 DMA Transfers

DMA transfers are enabled with the SPECIFY command and are initiated by the 82078 by activating the DRQ pin during a data transfer command. The FIFO is enabled directly by asserting DACK# and addresses need not be valid (CS# can be held inactive during DMA transfers).

## 3.0 DRIVE INTERFACE

The 82078 has integrated all of the logic needed to interface to a floppy disk or a tape drive which use floppy interface. All drive outputs have 24 mA drive capability and all inputs use a receive buffer with hysteresis. The internal analog data separator requires no external components, yet allows for an extremely wide capture range with high levels of read-data jitter, and ISV. The designer needs only to run the 82078 disk drive signals to the disk or tape drive connector.

### 3.1 Cable Interface

Generally, 5.25" drive uses open collector drivers and 3.5" drives (as used on PS/2) use totem-pole drivers. The output buffers on the 82078 do not change between open collector or totem-pole, they are always totem-pole.

DRVDEN0 and DRVDEN1 connect to pins 2 and 6 or 33 (on most disk drives) to select the data rate sent from the drive to the 82078. The polarity of DRVDEN0 and DRVDEN1 can be programmed through the Drive Specification command (see the command description for more information).

When the 82078SL is operating at 3.3V, the floppy drive interface can be configured to either 5.0V or 3.3V, via the V<sub>CCF</sub> (pin 41). The drive interface follows the voltage level on V<sub>CCF</sub>. A selectable drive interface allows the system designer the greatest flexibility when designing a low voltage system.

#### 82078 64 PIN

# intel

# 3.2 Data Separator

The function of the data separator is to lock onto the incoming serial read data. When lock is achieved, the serial front end logic of the chip is provided with a clock which is synchronized to the read data. The synchronized clock, called Data Window, is used to internally sample the serial data. One state of Data Window is used to sample the data portion of the bit cell, and the alternate state samples the clock portion. Serial to parallel conversion logic separates the read data into clock and data bytes.

To support reliable disk reads the data separator must track fluctuations in the read data frequency.

Frequency errors primarily arise from two sources: motor rotation speed variation and instantaneous speed variation (ISV). A second condition, and one that opposes the ability to track frequency shifts is the response to bit jitter.

The internal data separator consists of two analog phase lock loops (PLLs) as shown in Figure 3-1. The two PLLs are referred to as the reference PLL and the data PLL. The reference PLL (the master PLL) is used to bias the data PLL (the slave PLL). The reference PLL adjusts the data PLL's operating point as a function of process, junction temperature and supply voltage. Using this architecture it was possible to eliminate the need for external trim components.



Figure 3-1. Data Separator Block Diagram



#### PHASE LOCK LOOP OVERVIEW

Figure 3-2. Data PLL

Figure 3-2 shows the data PLL. The reference PLL has control over the loop gain by its influence on the charge pump and the VCO. In addition the reference PLL controls the loop filter time constant. As a result the closed loop transfer function of the data PLL is controlled, and immune to the first order, to environmental factors and process variation.

Systems with analog PLLs are often very sensitive to noise. In the design of this data separator many steps were taken to avoid noise sensitivity problems. The analog section of the chip has a separate VSS pin (AVSS) which should be connected externally to a noise free ground. This provides a clean basis for VSS referenced signals. In addition many analog circuit features were employed to make the overall system as insensitive to noise as possible.

#### 3.2.1 JITTER TOLERANCE

The jitter immunity of the system is dominated by the data PLL's response to phase impulses. This is measured as a percentage of the theoretical data window by dividing the maximum readable bit shift by a  $1/_4$  bit cell distance. For instance, if the maximum allowable bit shift is 300 ns for a 500 Kbps data stream, the jitter tolerance is 60%.

#### 3.2.2 LOCKTIME (tLOCK)

The lock, or settling time of the data PLL is designed to be 64 bit times (8 sync bytes). The value assumes that the sync field jitter is 5% the bit cell or less. This level of jitter is realistic for a constant bit pattern. Intersymbol interference should be equal, thus nearly eliminating random bit shifting.

#### 3.2.3 CAPTURE RANGE

Capture Range is the maximum frequency range over which the data separator will acquire phase lock with the incoming RDDATA signal. In a floppy disk environment, this frequency variation is composed of two components: drive motor speed error and ISV. Frequency is a factor which may determine the maximum level of the ISV (Instantaneous Speed Variation) component. In general, as frequency increases the allowed magnitude of the ISV component will decrease. When determining the capture range requirements, the designer should take the maximum amount of frequency error for the disk drive and double it to account for media switching between drives.

#### 3.3 Write Precompensation

The write precompensation logic is used to minimize bit shifts in the RDDATA stream from the disk drive. The shifting of bits is a known phenomena of magnetic media and is dependent upon the disk media AND the floppy drive.

The 82078 monitors the bit stream that is being sent to the drive. The data patterns that require precompensation are well known. Depending upon the pattern, the bit is shifted either early or late (or not at all) relative to the surrounding bits. Figure 3-3 is a block diagram of the internal circuit.

The top block is a 13-bit shift register with the no delay tap being in the center. This allows 6 levels of early and late shifting with respect to nominal. The shift register is clocked at the main clock rate (24 MHz). The output is fed into 2 multiplexors one for early and one for late. A final stage of multiplexors combines the early, late and normal data stream back into one which is the WRDATA output.



Figure 3-3. Precompensation Block Diagram

### 4.0 POWER MANAGEMENT FEATURES

The 82078 contains power management features that makes it ideal for design of portable personal computers. In addition to all of the power management features the 82078SL also operates at 3.3V. These features can be classified into power management of the part and that of the internal oscillator. The powerdown of the part is done independently of the internal oscillator in the 82078.

### 4.1 Power Management Scheme

The 82078 supports two powerdown modes, direct powerdown and automatic powerdown. Direct powerdown refers to direct action by the software to powerdown without dependence on external factors. Automatic powerdown results from 82078's monitoring of the current conditions according to a previously programmed mode. Any hardware reset disables the automatic POWERDOWN command, however, software resets have no effect on the command. The 82078 also supports powerdown of its internal crystal oscillator independent of the powerdown modes described above. By setting bit 5 (PDOSC) in the DSR register, the internal oscillator is turned off. This bit has sole control of the oscillator powerdown, allowing the internal clock to be turned off when an external oscillator is used.

### 4.2 3.3V Support for Portable Platforms

The portable market share of the personal computing market has increased significantly. To improve power conservation on portable platforms, designs are migrating from 5.0V to 3.3V. Intel's 82078SL allows designers to incorporate 3.3V floppy disk controller support in their systems. The 82078SL has a SEL3V# pin to allow selection of either 5.0V or 3.3V operation. In order to support the slower migration of floppy drives to 3.3V and allow system vendors to use standard 5.0V floppy drive inventory, the 82078SL accommodates a 5.0V tolerant floppy drive interface. This is achieved by changing the floppy drive's interface power supply, VCCF between 5.0V and 3.3V supplies. The 82078SL's 3.3V D.C. specification conforms to the JEDEC standard that describes the operating voltage levels for Integrated Circuits operating at 3.3V  $\pm$ 0.3V. The 82077SL also maintains compatibility to 5.0V A.C. specifications.

## 4.3 Oscillator Power Management

The 82078 supports a built-in crystal oscillator that can be programmed to be either powered down or active, independent of the power state of the chip. This capability is implemented by the PDOSC bit in the DSR. When PDOSC is set low, the internal oscillator is on, it is off when the bit is high. Note, a DSR powerdown does not turn off the oscillator.

When the external oscillator is used, power can be saved by turning off the internal oscillator. If the internal oscillator is used, the oscillator may be powered up (even when the rest of the chip is powered off) allowing the chip to wake up quickly and in a stable state. It is recommended to keep the internal oscillator on even when in the powerdown state. The main reason for this is that the recovery time of the oscillator during wake up may take tens of milliseconds under the worst case, which may create problems with any sensitive application software. In a typical application the internal oscillator should be on unless the system goes into a power saving or standby mode (such a mode request would be made by a system time out or by a user). In this case, the system software would take over and must turn on the oscillator sufficiently ahead of awakening the part.

#### 82078 64 PIN

In the case of the external oscillators, the power up characteristics are similar. If the external source remains active during the time the 82078 is powered down, then the recovery time effect is minimized. The PD pin can be used to turn off the external source. While the PD pin is active, the 82078 does not require a clock source. However, when the PD pin is inactive, the clocking source, once it starts oscillating, must be completely stable to ensure that the 82078 operates properly.

# 4.4 Part Power Management

This section deals with the power management of the rest of the chip excluding the oscillator. This section explains powerdown modes and wake up modes.

#### 4.4.1 DIRECT POWERDOWN

Direct powerdown is conducted via the POWER-DOWN bit in the DSR register (bit 6). Programming this bit high will powerdown 82078. All status is lost if this type of powerdown mode is used. The part can exit powerdown from this mode via any hardware or software reset. This type of powerdown overrides the automatic powerdown. When the part is in automatic powerdown and the DSR powerdown is issued, the previous status of the part is lost and the 82078 resets to its default values.

### 4.4.2 AUTO POWERDOWN

Automatic powerdown is conducted via a "Powerdown Mode" command. There are four conditions required before the part will enter powerdown. All these conditions must be true for the part to initiate the powerdown sequence. These conditions follow:

- 1. The motor enable pins FDME[0:3] must be inactive.
- The part must be idle; this is indicated by MSR = 80H and INT = 0 (INT may be high even if MSR = 80H due to polling interrupt).
- 3. The head unload timer (HUT, explained in the SPECIFY command) must have expired.
- 4. The auto powerdown timer must have timed out.

The command can be used to enable powerdown by setting the AUTO PD bit in the command to high. The command also provides a capability of programming a minimum power up time via the MIN DLY bit in the command. The minimum power up time refers to a minimum amount of time the part will remain powered up after being awakened or reset. An internal timer is initiated as soon as the auto powerdown command is enabled. The part is then powered down provided all the remaining conditions are met. Any software reset will reinitialize the timer. Changing of data rate extends the auto powerdown timer by up to 10 ms, but only if the data rate is changed during the countdown.

Disabling the auto powerdown mode cancels the timers and holds the 82078 out of auto powerdown.

The IDLE pin can be masked via the IDLEMSK bit in Status Register B (Enhanced AT/EISA). When in PS/2 mode, the PS/2 STAT bit in the Powerdown Command can be set to enable PD and IDLE bits in the DIR register (bits 5 and 6) and IDLEMSK (bit 4) can be enabled.

### 4.4.3 WAKE UP MODES

This section describes the conditions for awakening the part from both direct and automatic powerdown. Power conservation or extension of battery life is the main reason power management is required. This means that the 82078 must be kept in powerdown state as long as possible and should be powered up as late as possible without compromising software transparency.

To keep the part in powerdown mode as late as possible implies that the part should wake up as fast as possible. However, some amount of time is required for the part to exit powerdown state and prepare the internal microcontroller to accept commands. Application software is very sensitive to such a delay and in order to maintain software transparency, the recovery time of the wake up process must be carefully controlled by the system software.

#### 4.4.3.1 Wake Up from DSR Powerdown

If the 82078 enters the powerdown through the DSR powerdown bit, it must be reset to exit. Any form of software or hardware reset will serve, although DSR is recommended. No other register access will awaken the part, including writing to the DOR's motor enable (FDME[0:3]) bits.

If DSR powerdown is used when the part is in auto powerdown, the DSR powerdown will override the auto powerdown. However, when the part is awakened by a software reset, the auto powerdown command (including the minimum delay timer) will once again become effective as previously programmed. If the part is awakened via a hardware reset, the auto powerdown is disabled.

After reset, the part will go through a normal sequence. The drive status will be initialized. The FIFO mode will be set to default mode on a hardware reset or on a software reset if the LOCK command has not blocked it. Finally, after a delay, the polling interrupt will be issued.

#### 4.4.3.2 Wake Up from Auto Powerdown

If the part enters the powerdown state through the auto powerdown mode, then the part can be awakened by reset or by appropriate access to certain registers.

If a hardware or software reset is used then the part will go through the normal reset sequence. If the access is through the selected registers, then the 82078 resumes operation as though it was never in powerdown. Besides activating the RESET pin or one of the software reset bits in the DOR or DSR, the following register accesses will wake up the part:

- 1. Enabling any one of the motor enable bits in the DOR register (reading the DOR does not awaken the part).
- 2. A read from the MSR register.
- 3. A read or write to the FIFO register.

Any of these actions will wake up the part. Once awake, 82078 will reinitiate the auto powerdown timer for 10 ms or 0.5 sec. (depending on the MIN DLY bit the auto powerdown command). When operating at 2 Mbps, the time is halved to 5 ms or 0.25 sec. depending on the MIN DLY bit. The part will powerdown again when all the auto powerdown conditions are satisfied.

# 4.5 Register Behavior

The register descriptions and their values in the powerdown state are listed in the Microprocessor Interface section. Table 4-1 reiterates the AT and PS/2 (including model 30) configuration registers available. It also shows the type of access permitted. In order to maintain software transparency, access to all the registers must be maintained. As Table 4-1 shows, two sets of registers are distinguished based on whether their access results in the part remaining in powerdown state or exiting it.

|         | Available Registers                                 | Acc                | ess       |  |  |  |  |  |  |  |
|---------|-----------------------------------------------------|--------------------|-----------|--|--|--|--|--|--|--|
| Address | PC-AT                                               | PS/2<br>(Model 30) | Permitted |  |  |  |  |  |  |  |
|         | Access to these registers DOES NOT wake up the part |                    |           |  |  |  |  |  |  |  |
| 000     | —                                                   | SRA                | R         |  |  |  |  |  |  |  |
| 001     | SRB (EREG EN = 1)                                   | SRB                | R/W       |  |  |  |  |  |  |  |
| 010     | DOR*                                                | DOR*               | R/W       |  |  |  |  |  |  |  |
| 011     | TDR                                                 | TDR                | R/W       |  |  |  |  |  |  |  |
| 100     | DSR*                                                | DSR*               | W         |  |  |  |  |  |  |  |
| 110     | -                                                   | -                  | —         |  |  |  |  |  |  |  |
| 111     | DIR                                                 | DIR                | R         |  |  |  |  |  |  |  |
| 111     | CCR                                                 | CCR                | W         |  |  |  |  |  |  |  |
|         | Access to these registers                           | wake up the part   | -         |  |  |  |  |  |  |  |
| 100     | MSR                                                 | MSR                | R         |  |  |  |  |  |  |  |
| 101     | FIFO                                                | FIFO               | R/W       |  |  |  |  |  |  |  |

Table 4-1. 82078 Register Behavior

\*Writing to the DOR or DSR does not wake up the part, however, writing any of the motor enable bits or doing a software reset (either via DOR or DSR reset bits) will wake up the part.

#### 82078 64 PIN

# intel

Access to all other registers is possible without awakening the part. These registers can be accessed during powerdown without changing the status of the part. A read from these registers will reflect the true status as shown in the register description in Section 2.1. A write to the part will result in the part retaining the data and subsequently reflecting it when the part awakens. Accessing the part during powerdown may cause an increase in the power consumption by the part. The part will revert back to its low power mode when the access has been completed. None of the extended registers effect the behavior of the powerdown mode.

## 4.6 Pin Behavior

The 82078 is specifically designed for the portable PC systems in which the power conservation is a primary concern. This makes the behavior of the pins during powerdown very important.

The pins of 82078 can be divided into two major categories; system interface and floppy disk drive interface. The floppy disk drive pins are disabled such that no power will be drawn through the 82078 as a result of any voltage applied to the pin within the 82078's power supply range. The floppy disk drive interface pins are configurable by the FDI TRI bit in the auto powerdown command. When the bit is set the output pins of the floppy disk drive retain their original state. All other pins are either disabled or unchanged as depicted in Table 4-4. Most of the system interface pins are left active to monitor system accesses that may wake up the part.

#### 4.6.1 SYSTEM INTERFACE PINS

Table 4-2 gives the state of the system interface pins in the powerdown state. Pins unaffected by powerdown are labeled "UC". Input pins are "DISABLED" to prevent them from causing currents internal to the 82078 when they have indeterminate input values.

| System Pins | State In Powerdown | System Pins | State In Powerdown                    |  |  |
|-------------|--------------------|-------------|---------------------------------------|--|--|
| li          | nput Pins          | Output Pins |                                       |  |  |
| CS#         | UC                 | DRQ         | UC (Low)                              |  |  |
| RD#         | RD# UC             |             | UC (Low)                              |  |  |
| WR#         | WR# UC             |             | HIGH                                  |  |  |
| A[0:2]      | UC                 | IDLE        | High (Auto PD)<br>Low (DSR PD)        |  |  |
| DB[0:7]     | UC                 | DB[0:7]     | UC                                    |  |  |
| RESET       | UC                 |             | · · · · · · · · · · · · · · · · · · · |  |  |
| IDENTn      | UC                 |             |                                       |  |  |
| DACK#       | Disabled           |             |                                       |  |  |
| TC          | Disabled           |             |                                       |  |  |
| X[1:2]      | Programmable       |             |                                       |  |  |

#### **Table 4-2. System Interface Pins**

Two pins which can be used to indicate the status of the part are IDLE and PD. Table 4-3 shows how these pins reflect the 82078 status.

| PD | IDLE | MSR                      | Part Status    |
|----|------|--------------------------|----------------|
| 1  | 1    | 80H                      | Auto Powerdown |
| 1  | 0    | RQM = 1;<br>MSR[6:0] = X | DSR Powerdown  |
| 0  | 1    | 80H                      | ldle           |
| 0  | 0    | —                        | Busy           |

#### Table 4-3. 82078 Status Pins

The IDLE pin indicates when the part is idle state and can be powered down. It is a combination of MSR equalling 80H, the head being unloaded and the INT pin being low. As shown in the table the IDLE pin will be low when the part is in DSR powerdown state. The PD pin is active whenever the part is in the powerdown state. It is active for either mode of powerdown. The PD pin can be used to turn off an external oscillator of other floppy disk drive interface hardware.

#### 4.6.2 FDD INTERFACE PINS

The FDD interface "input" pins during powerdown are disabled or unchanged as shown in Table 4-4. The floppy disk drive "output" pins are programmable by the FDI TRI bit in the auto powerdown command. Setting of the FDI TRI bit in the auto powerdown command results in the interface retaining its normal state. When this bit is low (default state) all output pins in the FDD interface to the floppy disk drive itself are tri-stated. Pins used for local logic control or part programming are unaffected. Table 4-4 depicts the state of the floppy disk interface pins in the powerdown state (FDI TRI is low).

| FDD Pins | State In<br>Powerdown | FDD Pins                     | State in<br>Powerdown |  |  |  |
|----------|-----------------------|------------------------------|-----------------------|--|--|--|
| Inpu     | ıt Pins               | Output Pins<br>(FDI TRI = 0) |                       |  |  |  |
| RDDATA   | Disabled              | FDME[0:3] #                  | Tristated             |  |  |  |
| WP       | Disabled              | FDS[0:3]#                    | Tristated             |  |  |  |
| TRK0     | Disabled              | DIR#                         | Tristated             |  |  |  |
| INDX#    | Disabled              | STEP#                        | Tristated             |  |  |  |
| DRV2#    | Disabled              | WRDATA#                      | Tristated             |  |  |  |
| DSKCHG#  | Disabled              | WE#                          | Tristated             |  |  |  |
|          |                       | HDSEL#                       | Tristated             |  |  |  |
|          |                       | DRVDEN[0:1] #                | Tristated             |  |  |  |

#### Table 4-4. 82078 FDD Interface Pins

# 5.0 CONTROLLER PHASES

For simplicity, command handling in the 82078 can be divided into three phases: Command, Execution and Result. Each phase is described in the following sections.

When there is no command in progress, the 82078 can be in idle, drive polling or powerdown state.

# 5.1 Command Phase

After a reset, the 82078 enters the command phase and is ready to accept a command from the host. For each of the commands, a defined set of command code bytes and parameter bytes has to be written to the 82078 before the command phase is complete (Please refer to Section 6.0 for the command descriptions). These bytes of data must be transferred in the order prescribed.

Before writing to the 82078, the host must examine the RQM and DIO bits of the Main Status Register. RQM, DIO must be equal to "1" and "0" respectively before command bytes may be written. RQM is set false by the 82078 after each write cycle until the received byte is processed. The 82078 asserts RQM again to request each parameter byte of the command, unless an illegal command condition is detected. After the last parameter byte is received, RQM remains "0", and the 82078 automatically enters the next phase as defined by the command definition.

The FIFO is disabled during the command phase to retain compatibility with the 8272A, and to provide for the proper handling of the "Invalid Command" condition.

## 5.2 Execution Phase

All data transfers to or from the 82078 occur during the execution phase, which can proceed in DMA or non-DMA mode as indicated in the SPECIFY command.

Each data byte is transferred by an INT or DRQ depending on the DMA mode. The CONFIGURE command can enable the FIFO and set the FIFO threshold value.

The following paragraphs detail the operation of the FIFO flow control. In these descriptions, (threshold) is defined as the number of bytes available to the 82078 when service is requested from the host, and ranges from 1 to 16. The parameter FIFOTHR which the user programs is one less, and ranges from 0 to 15.

A low threshold value (i.e., 2) results in longer periods of time between service requests, but requires faster servicing of the request, for both read and write cases. The host reads (writes) from (to) the FIFO until empty (full), then the transfer request goes inactive. The host must be very responsive to the service request. This is the desired case for use with a "fast" system.

A high value of threshold (i.e., 12) is used with a "sluggish" system by affording a long latency period after a service request, but results in more frequent service requests.

#### 5.2.1 NON-DMA MODE, TRANSFERS FROM THE FIFO TO THE HOST

The INT pin and RQM bits in the Main Status Register are activated when the FIFO contains 16 (or set threshold) bytes, or the last bytes of a full sector transfer have been placed in the FIFO. The INT pin can be used for interrupt driven systems and RQM can be used for polled sytems. The host must respond to the request by reading data from the FIFO. This process is repeated until the last byte is transferred out of the FIFO, then 82078 deactivates the INT pin and RQM bit.

#### 5.2.2 NON-DMA MODE, TRANSFERS FROM THE HOST TO THE FIFO

The INT pin and RQM bit in the Main Status Register are activated upon entering the execution phase of data transfer commands. The host must respond to the request by writing data into the FIFO. The INT pin and RQM bit remain true until the FIFO becomes full. They are set true again when the FIFO has (threshold) bytes remaining in the FIFO. The INT pin will also be deactivated if TC and DACK# both go inactive. The 82078 enters the result phase after the last byte is taken by the 82078 from the FIFO (i.e., FIFO empty condition).

# 5.2.3 DMA MODE, TRANSFERS FROM THE FIFO TO THE HOST

The 82078 activates the DRQ pin when the FIFO contains 16 (or set threshold) bytes, or the last byte of a full sector transfer has been placed in the FIFO. The DMA controller must respond to the request by reading data from the FIFO. The 82078 will deactivate the DRQ pin when the FIFO becomes empty. DRQ goes inactive after DACK# goes active for the last byte of a data transfer (or on the active edge of RD#, on the last byte, if no edge is present on DACK#). Note that DACK# and TC must overlap for at least 50 ns for proper functionality.

# int<sub>el</sub>.

#### 5.2.4 DMA MODE, TRANSFERS FROM THE HOST TO THE FIFO

The 82078 activates the DRQ pin when entering the execution phase of the data transfer commands. The DMA controller must respond by activating the DACK# and WR# pins and placing data in the FIFO. DRQ remains active until the FIFO becomes full. DRQ is again set true when the FIFO has (threshold) bytes remaining in the FIFO. The 82078 will also deactivate the DRQ pin when TC becomes true (qualified by DACK# by overlapping by 50 ns), indicating that no more data is required. DRQ goes inactive after DACK# goes active for the last byte of a data transfer (or on the active edge of WR# of the last byte, if no edge is present on DACK#).

#### 5.2.5 DATA TRANSFER TERMINATION

The 82078 supports terminal count explicitly through the TC pin and implicitly through the underrun/overrun and end-of-track (EOT) functions. For full sector transfers, the EOT parameter can define the last sector to be transferred in a single or multisector transfer. If the last sector to be transferred is a partial sector, the host can stop transferring the data in mid-sector, and the 82078 will continue to complete the sector as if a hardware TC was received. The only difference between these implicit functions and TC is that they return "abnormal termination" result status. Such status indications can be ignored if they were expected. Note that when the host is sending data to the FIFO of the 82078, the internal sector count will be complete when 82078 reads the last byte from its side of the FIFO. There may be a delay in the removal of the transfer request signal of up to the time taken for the 82078 to read the last 16 bytes from the FIFO. The host must tolerate this delay.

### 5.3 Result Phase

The generation of INT determines the beginning of the result phase. For each of the commands, a defined set of result bytes has to be read from the 82078 before the result phase is complete. (Refer to Section 6.0 on command descriptions.) These bytes of data must be read out for another command to start.

RQM and DIO must both equal "1" before the result bytes may be read from the FIFO. After all the result bytes have been read, the RQM and DIO bits switch to "1" and "0" respectively, and the CB bit is cleared. This indicates that the 82078 is ready to accept the next command.

# 6.0 COMMAND SET/DESCRIPTIONS

Commands can be written whenever the 82078 is in the command phase. Each command has a unique set of needed parameters and status results. The 82078 checks to see that the first byte is a valid command and, if valid, proceeds with the command. If it was invalid, the next time the RQM bit in the MSR register is a "1" the DIO and CB bits will also be "1", indicating the FIFO must be read. A result byte of 80H will be read out of the FIFO, indicating an invalid command was issued. After reading the result byte from the FIFO the 82078 will return to the command phase. Table 6-1 is a summary of the Command set.

### 82078 64 PIN

# intel

| Table 6-1. | 82078 | Command        | Set |
|------------|-------|----------------|-----|
|            | 02010 | <b>Oommana</b> | 000 |

| Dha       |       |          | · · · · · · · · · · · · · · · · · · · |                | DATA     | BUS            |                |                                        |          |                                             |
|-----------|-------|----------|---------------------------------------|----------------|----------|----------------|----------------|----------------------------------------|----------|---------------------------------------------|
| Phase     | R/W   | D7       | D <sub>6</sub>                        | D <sub>5</sub> | D4       | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub>                         | Do       | Remarks                                     |
|           |       |          |                                       |                | REA      | DAT            | ۹              |                                        |          |                                             |
| Command   | w     | МТ       | MFM                                   | SK             | 0        | 0              | 1              | 1                                      | 0        | Command Codes                               |
|           | w     | 0        | 0                                     | 0              | 0        | 0              | HDS            | DS1                                    | DS0      |                                             |
|           | W     |          |                                       |                | c        |                |                |                                        |          | Sector ID Information prior                 |
|           | w     |          |                                       | ·              | Н        |                |                |                                        |          | to Command Execution                        |
|           | w     |          |                                       |                | R        |                |                | · · · · ·                              |          | ·                                           |
|           | w     |          |                                       |                |          |                |                |                                        |          |                                             |
|           | l w l |          |                                       |                | EOT      | •              |                |                                        |          | •                                           |
|           | w     |          |                                       |                | GPL      |                |                |                                        |          |                                             |
|           | w     |          |                                       |                |          |                | -              |                                        |          | -                                           |
| Execution |       |          |                                       |                |          |                |                |                                        |          | Data Transfer between the                   |
| Execution | {     |          |                                       |                |          |                |                |                                        |          | FDD and System                              |
|           |       |          |                                       |                |          |                |                |                                        |          |                                             |
| Result    | R     |          |                                       |                | STO      | )              |                |                                        |          | Status Information after                    |
|           | R     |          |                                       |                |          |                |                |                                        |          | Command Execution                           |
|           | R     |          |                                       |                | ST 2     |                |                |                                        |          |                                             |
|           | R     |          |                                       |                |          |                |                |                                        |          |                                             |
|           | R     |          |                                       |                | н        |                |                |                                        |          | Sector ID Information after                 |
|           |       |          |                                       |                |          |                |                |                                        |          | Command Execution                           |
|           | R     |          |                                       |                |          |                |                |                                        |          | Command Execution                           |
|           | R     |          |                                       |                | <u> </u> |                |                |                                        |          |                                             |
|           |       |          |                                       |                | READ DE  |                | DATA           |                                        |          |                                             |
| Command   | w     | MT       | MFM                                   | SK             | 0        | 1              | _ 1            | 0                                      | 0        | Command Codes                               |
|           | w     | 0        | 0                                     | 0              | 0        | 0              | HDS            | DS1                                    | DS0      |                                             |
|           | w     |          |                                       |                | C        |                |                |                                        |          | Sector ID Information prior                 |
|           | l w   |          |                                       |                | н        |                |                |                                        |          | to Command Execution                        |
|           | w     |          |                                       |                | R        |                |                |                                        |          |                                             |
|           | Ŵ     |          |                                       |                |          |                |                |                                        |          |                                             |
|           | ŵ     |          |                                       |                |          |                |                |                                        |          |                                             |
|           | ŵ     |          |                                       |                |          |                |                |                                        |          |                                             |
|           | Ŵ     |          |                                       |                |          |                |                |                                        |          |                                             |
| Evention  |       |          |                                       |                |          |                |                |                                        |          | Date Transfer between the                   |
| Execution | .     |          |                                       |                |          |                |                |                                        |          | Data Transfer between the<br>FDD and System |
|           |       |          |                                       |                |          |                |                |                                        |          | FDD and System                              |
|           | _     |          |                                       |                |          |                |                |                                        |          |                                             |
| Result    | R     |          |                                       |                | ST C     | )              | <u>`</u>       |                                        |          | Status Information after                    |
|           | R     |          |                                       |                |          |                |                |                                        |          | Command Execution                           |
|           | R     |          |                                       |                |          |                |                |                                        |          |                                             |
|           | R     |          |                                       |                | C        |                |                |                                        |          |                                             |
|           | R     |          |                                       |                | Н        |                |                |                                        |          | Sector ID Information after                 |
|           | R.    |          |                                       |                | R        |                |                |                                        |          | Command Execution                           |
|           | R     | <u> </u> |                                       |                | N        |                |                |                                        |          |                                             |
|           |       |          |                                       |                | WRI      | TE DAT         | A              |                                        |          |                                             |
| Command   | w     | мт       | MFM                                   | 0              | 0        | 0              | 1              | 0                                      | 1        | Command Codes                               |
|           | ŵ     | 0        | 0                                     | ō              | ŏ        | ō              | HDS            | DS1                                    | DS0      |                                             |
|           | · w   | '        | •                                     | •              | c        | -              |                |                                        |          | Sector ID Information prior                 |
|           | ŵ     |          |                                       |                |          |                |                |                                        |          | to Command Execution                        |
|           | Ŵ     |          |                                       |                |          |                |                |                                        |          |                                             |
|           |       |          |                                       |                |          |                |                |                                        |          |                                             |
|           | w     |          |                                       |                |          |                |                |                                        |          |                                             |
|           | W     |          |                                       |                | E01      |                |                |                                        |          |                                             |
|           | W     |          |                                       |                | GPL      |                | ·····          |                                        |          | Į                                           |
|           | W     |          | · · · · · · · · ·                     |                | DTL      |                |                |                                        | <u> </u> |                                             |
| Execution |       |          |                                       |                |          |                |                |                                        |          | Data Transfer between the<br>FDD and System |
| Result    | R     |          |                                       |                | STO      | <b>`</b>       |                |                                        |          | Status Information after                    |
| loaun     |       |          |                                       |                | SIU      | í              |                |                                        |          | Command Execution                           |
|           | R     |          |                                       |                | >        | <u> </u>       |                | ······································ |          | Command Execution                           |
|           | R     |          |                                       |                |          |                |                |                                        |          | 1 · · · · · · · · · · · · · · · · · · ·     |
|           | R     |          |                                       |                | C        |                |                |                                        |          |                                             |
|           | R     |          |                                       |                | Н        |                |                |                                        | <u>.</u> | Sector ID Information after                 |
|           | R     | 1        |                                       |                | R        |                |                |                                        |          | Command Execution                           |
|           | R     |          |                                       |                |          |                |                |                                        |          |                                             |

### 82078 64 PIN

| Dhana               | R/W                        | DATA BUS       |                                       |                |                           |                                        |                |                |          | Bomarka                                                                                         |
|---------------------|----------------------------|----------------|---------------------------------------|----------------|---------------------------|----------------------------------------|----------------|----------------|----------|-------------------------------------------------------------------------------------------------|
| Phase               | H/W                        | D <sub>7</sub> | D <sub>6</sub>                        | D <sub>5</sub> | D4                        | D <sub>3</sub>                         | D <sub>2</sub> | D <sub>1</sub> | Do       | Remarks                                                                                         |
|                     |                            |                | -                                     |                | WRITE                     | DELETED                                | DATA           |                |          |                                                                                                 |
| Command             | W                          | мт             | MFM                                   | 0              | 0                         | 1                                      | 0              | 0              | 1        | Command Codes                                                                                   |
|                     | W                          | 0              | 0                                     | 0              | 0                         | 0                                      | HDS            | DS1            | DS0      | O to - ID lafe method                                                                           |
|                     | Ŵ                          |                |                                       |                | (<br>                     |                                        |                |                |          | Sector ID Information prior<br>to Command Execution                                             |
|                     | Ŵ                          |                |                                       |                |                           |                                        |                |                |          |                                                                                                 |
|                     | w                          |                |                                       |                |                           |                                        |                |                |          |                                                                                                 |
|                     | W                          |                |                                       |                |                           |                                        |                |                |          |                                                                                                 |
|                     | w<br>w                     |                |                                       |                |                           |                                        |                |                |          |                                                                                                 |
| Execution           |                            |                |                                       |                | U                         | · · · · · · · · · · · · · · · · · · ·  |                |                |          | Data Transfer between the                                                                       |
|                     |                            |                |                                       |                |                           |                                        |                |                |          | FDD and System                                                                                  |
| Result              | R                          |                | · · · · · · · · · · · · · · · · · · · |                |                           |                                        |                |                |          | Status Information after                                                                        |
|                     | R                          |                |                                       |                |                           |                                        |                |                |          | Command Execution                                                                               |
|                     | R                          |                |                                       |                |                           |                                        |                |                |          |                                                                                                 |
|                     | R                          |                |                                       |                |                           |                                        |                |                |          | Sector ID Information after                                                                     |
|                     | R                          |                |                                       |                |                           |                                        |                |                |          | Command Execution                                                                               |
|                     | R                          |                |                                       |                |                           | ــــــــــــــــــــــــــــــــــــــ |                |                |          |                                                                                                 |
|                     |                            |                |                                       |                | RE                        | AD TRAC                                | к              |                |          |                                                                                                 |
| Command             | . w<br>. w                 | 0              | MFM<br>0                              | 0<br>0         | 0<br>0                    | 0<br>0                                 | 0<br>HDS       | 1<br>DS1       | 0<br>DS0 | Command Codes                                                                                   |
|                     | ŵ                          |                |                                       | 0              |                           | -                                      |                |                |          | Sector ID Information prior                                                                     |
|                     | w                          |                |                                       |                |                           |                                        |                |                |          | to Command Execution                                                                            |
|                     | w                          |                |                                       |                |                           |                                        | · · · · · ·    |                |          |                                                                                                 |
|                     | Ŵ                          |                |                                       |                |                           |                                        |                |                |          |                                                                                                 |
|                     | Ŵ                          |                |                                       |                |                           |                                        |                |                |          |                                                                                                 |
|                     | Ŵ                          |                |                                       |                |                           |                                        |                |                |          |                                                                                                 |
| Execution           |                            |                |                                       |                |                           |                                        |                |                |          | Data Transfer between the<br>FDD and System. FDC<br>Reads All Sectors from<br>Index Hole to EOT |
| Result              | R                          |                |                                       |                | ST                        | 0                                      |                |                |          | Status Information after                                                                        |
|                     | R                          |                |                                       |                | ST                        | 1                                      |                |                |          | Command Execution                                                                               |
|                     | R                          |                |                                       |                |                           |                                        |                |                | _        |                                                                                                 |
|                     | R                          |                |                                       |                |                           |                                        |                |                |          | Sector ID Information after                                                                     |
|                     | R                          |                |                                       |                |                           |                                        |                |                |          | Command Execution                                                                               |
|                     | R                          |                |                                       |                |                           | <u> </u>                               |                |                |          |                                                                                                 |
| Command             | w                          | МТ             | MFM                                   | SK             | 1                         | VERIFY<br>0                            | 1              |                | 0        | Commond Codes                                                                                   |
| Command             | Ŵ                          | EC             | 0                                     | 0              | 0                         | 0                                      | HDS            | 1<br>DS1       | DS0      | Command Codes                                                                                   |
|                     | w                          |                |                                       |                | (                         |                                        |                |                |          | Sector ID Information prior                                                                     |
|                     | W                          |                |                                       |                |                           |                                        |                |                |          | to Command Execution                                                                            |
|                     | Ŵ                          |                |                                       | ~              |                           |                                        |                |                |          |                                                                                                 |
|                     | Ŵ                          |                |                                       |                | EC                        | от                                     |                |                |          |                                                                                                 |
|                     | i w                        |                |                                       |                | GI                        | า                                      |                |                |          |                                                                                                 |
|                     |                            |                |                                       |                | DTL                       | /SC                                    |                |                |          | D 1. T                                                                                          |
| <b>F</b> undaria -  | Ŵ                          |                |                                       |                |                           |                                        |                |                |          | Data Transfer between the                                                                       |
| Execution           |                            |                |                                       |                |                           |                                        |                |                | ÷        | FDD and System                                                                                  |
|                     | W                          |                |                                       |                | ST                        | 0                                      |                |                |          | Status Information after                                                                        |
|                     | W<br>R<br>R                |                |                                       |                | ST                        | 1                                      |                |                |          | -                                                                                               |
|                     | W<br>R<br>R                |                |                                       |                | S1<br>S1                  | 1<br>2                                 |                |                |          | Status Information after                                                                        |
| Execution<br>Result | W<br>R<br>R<br>R<br>R      |                |                                       |                | \$1<br>\$1<br>(           | 1<br>2                                 |                |                |          | Status Information after<br>Command Execution                                                   |
|                     | W<br>R<br>R<br>R<br>R<br>R |                |                                       |                | \$1<br>\$1<br>(           | 1<br>2<br>2                            |                |                |          | Status Information after                                                                        |
|                     | W<br>R<br>R<br>R<br>R      |                |                                       |                | \$1<br>\$1<br>C<br>H<br>F |                                        |                |                |          | Status Information after<br>Cornmand Execution<br>Sector ID Information after                   |
|                     | W<br>R<br>R<br>R<br>R<br>R | 0              | 0                                     | 0              | \$1<br>\$1<br>C<br>H<br>F | 1<br>2<br>1                            |                |                | 0        | Status Information after<br>Command Execution<br>Sector ID Information after                    |

# Table 6-1. 82078 Command Set (Continued)

| Phase                                  | B/W       |                |                |                | DAT              | BUS            |                |                |                | Remarks                  |
|----------------------------------------|-----------|----------------|----------------|----------------|------------------|----------------|----------------|----------------|----------------|--------------------------|
| Flidae                                 | n/ •      | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D4               | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |                          |
|                                        |           |                |                |                | FOR              | MAT TRA        | СК             |                |                |                          |
| Command                                | w         | 0              | MFM            | 0              | 0                | 1              | 1              | 0              | 1              | Command Codes            |
|                                        | w         | 0              | 0              | 0              | 0                | 0              | HDS            | DS1            | DS0            |                          |
|                                        | w         |                |                |                |                  | N .            |                |                |                | Bytes/Sector             |
|                                        | w         |                |                |                |                  | C              |                |                |                | Sectors/Cylinder         |
|                                        | W         |                |                |                |                  | PL .           |                |                |                | Gap3                     |
|                                        | w         |                |                |                | - '              | <b>D</b>       |                |                |                | Filler Byte              |
| Execution                              |           |                |                |                |                  |                |                |                |                |                          |
| For Each                               | w         |                |                |                | _ (              | с .            |                |                |                |                          |
| Sector                                 | i w i     |                |                |                |                  | +              |                |                |                | Input Sector             |
| Repeat:                                | w         |                |                |                |                  | 7              |                |                |                | Parameters               |
|                                        | w         |                |                | ·              | _ 1              | N              |                |                |                |                          |
|                                        |           |                |                |                |                  |                |                |                |                | 82078 Formats an Entire  |
|                                        |           |                |                |                |                  |                |                |                |                | Cylinder                 |
|                                        |           |                |                |                |                  |                |                |                |                |                          |
| Result                                 | R         |                |                |                | _ s <sup>-</sup> | го             |                |                |                | Status Information after |
|                                        | R         |                |                |                |                  | Γ1             |                |                |                | Command Execution        |
|                                        | R         |                |                |                |                  | Γ2             |                |                |                |                          |
|                                        | R         |                |                |                |                  | fined          |                |                |                |                          |
|                                        | R         |                |                |                |                  | efined         |                |                |                |                          |
|                                        | R         |                |                |                |                  | fined          |                |                |                |                          |
| ······································ | R         |                |                |                |                  | afined         |                |                |                |                          |
|                                        |           |                |                |                |                  | AN EQUA        |                |                |                |                          |
| Command                                | w         | MT<br>0        | MFM<br>0       | SK<br>0        | 1<br>0           | 0<br>0         | 0<br>HDS       | 0<br>DS1       | 1<br>DS0       | Command Codes            |
|                                        | Ŵ         | U              | U              | U              |                  | с <sup>0</sup> | HD3            | 031            | 030            | Sector ID Information    |
|                                        | Ŵ         |                |                |                |                  | 4              |                |                |                | prior to Command         |
|                                        | l w l     |                |                |                |                  | R              |                | ······         |                | Execution                |
|                                        | Ŵ         |                |                |                |                  | N              |                | ·              |                |                          |
|                                        | Ŵ         |                |                |                |                  | Эт             |                |                |                |                          |
|                                        | w         |                |                |                | _ G              | PL             |                |                |                |                          |
|                                        | w         |                |                |                | _ 5              | TP             |                |                |                |                          |
| Execution                              | '         |                |                |                |                  |                |                |                |                | Data Compared            |
| Execution                              |           |                |                |                |                  |                |                |                |                | between the FDD          |
|                                        |           |                |                |                |                  |                |                |                |                | and Main-System          |
|                                        |           |                |                |                |                  |                |                |                |                | -                        |
| Result                                 | R         |                |                |                |                  | го             |                |                |                | Status Information       |
|                                        | R         | ·              |                |                |                  | Γ1             | v.             |                |                | after Command            |
|                                        | R         |                |                |                |                  | Γ2             |                |                |                | Execution                |
|                                        | R         |                |                |                |                  |                |                |                |                | Sector ID Information    |
|                                        | R         |                |                |                |                  | H<br>R         |                |                |                | after Command            |
|                                        | R         |                |                |                |                  | N              |                |                |                | Execution                |
|                                        | · · · · · |                |                |                |                  |                |                |                |                |                          |

## Table 6-1. 82078 Command Set (Continued)

intel

| Dhaaa                                     | Dav    |                |                |                | DATA     | BUS            |                | - <u></u>      | <u></u> | Demostra                           |
|-------------------------------------------|--------|----------------|----------------|----------------|----------|----------------|----------------|----------------|---------|------------------------------------|
| Phase                                     | R/W    | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D4       | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | Do      | Remarks                            |
|                                           |        |                |                |                | SCAN L   | OW OR E        | QUAL           |                |         |                                    |
| Command                                   | w      | MT             | MFM            | SK             | 1        | 1              | 0              | 0              | 1       | Command Codes                      |
|                                           | w      | 0              | 0              | 0              | 0        | 0              | HDS            | DS1            | DS0     |                                    |
|                                           | W      | <del></del>    |                |                | C        |                |                |                |         | Sector ID Information              |
|                                           | w<br>w |                |                |                | _ H      |                |                |                |         | Prior to Command<br>Execution      |
|                                           | w      |                |                |                | n        |                |                |                |         | Execution                          |
|                                           | w l    |                |                |                |          |                |                |                |         |                                    |
|                                           | w      |                |                |                | GF       |                |                |                |         |                                    |
|                                           | w      |                |                |                | ST       | P              |                | . <u> </u>     |         | i -                                |
| Execution                                 |        |                |                |                |          |                |                |                |         | Data Compared                      |
|                                           |        |                |                |                |          |                |                |                |         | Between the FDD                    |
|                                           |        |                |                |                |          |                |                |                |         | and Main-System                    |
| Result                                    | R      |                |                |                | ST       | 0              |                |                |         | Status Information                 |
|                                           | R      |                |                |                | ST       |                |                |                |         | After Command                      |
|                                           | R      |                |                |                | ST       | _              |                |                |         | Execution                          |
| 1. J. | R      |                | <u> </u>       |                | C        |                |                | · <u> </u>     |         |                                    |
|                                           | R      |                |                |                | ~ H      |                | ,              |                |         | Sector ID Information              |
|                                           | R      |                |                |                | _ P      |                |                |                |         | After Command<br>Execution         |
|                                           |        |                |                |                |          | IGH OR E       |                |                |         |                                    |
| Command                                   | w      | MT             | MFM            | SK             | 1        | 1              | 1              | 0              | 1       | Command Codes                      |
|                                           | w      | 0              | 0              | 0              | 0        | 0              | HDS            | DS1            | DS0     | )                                  |
|                                           | w      |                |                |                | _ c      | ;              |                |                |         | Sector ID Information              |
|                                           | w      |                |                |                | H        |                |                | ·              |         | Prior to Command                   |
|                                           | W      |                |                |                | - F      |                |                | ······         |         | Execution                          |
|                                           | W      |                |                |                | - N      |                |                |                |         |                                    |
|                                           | w<br>w |                |                | ·              | EC<br>GF |                |                |                |         |                                    |
|                                           | Ŵ      |                |                |                | ST       |                |                |                |         |                                    |
|                                           |        |                |                |                | 01       | •              |                |                |         |                                    |
| Execution                                 |        |                |                |                |          |                |                |                |         | Data Compared                      |
|                                           |        |                |                |                |          |                |                |                |         | Between the FDD<br>and Main-System |
|                                           |        |                |                |                |          |                |                |                |         |                                    |
| Result                                    | R      |                |                |                | ST       |                |                | ·              |         | Status Information                 |
|                                           | R      |                |                |                | ST       |                |                | - <u>-</u>     |         | After Command                      |
|                                           | R      |                |                |                | _ ST     |                |                |                |         | Execution                          |
|                                           | R      |                |                |                | C        |                |                |                |         | Sector ID Information              |
|                                           | R      |                |                |                | _ F      |                | ·······        | 4              |         | After Command                      |
|                                           | R      |                |                |                | - F      |                |                |                |         | Execution                          |
|                                           | L      |                |                |                |          |                |                |                |         |                                    |

## Table 6-1. 82078 Command Set (Continued)

| Phase     | R/W    |                |                |        | DAT              | ABUS           | DATA BUS       |                                        |                |                                        |  |  |  |  |  |  |
|-----------|--------|----------------|----------------|--------|------------------|----------------|----------------|----------------------------------------|----------------|----------------------------------------|--|--|--|--|--|--|
| Filado    |        | D <sub>7</sub> | D <sub>6</sub> | D5     | D4               | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub>                         | D <sub>0</sub> | Remarks                                |  |  |  |  |  |  |
|           |        |                |                |        | RE               | CALIBRAT       | E              |                                        |                |                                        |  |  |  |  |  |  |
| Command   | w      | 0              | 0              | 0      | 0                | 0              | 1              | 1                                      | 1              | Command Codes                          |  |  |  |  |  |  |
|           | w      | 0              | 0              | 0      | 0                | 0              | 0              | DS1                                    | DS0            | Enhanced Controller                    |  |  |  |  |  |  |
| Execution |        |                |                |        |                  |                |                |                                        |                | Head Retracted to Track 0<br>Interrupt |  |  |  |  |  |  |
|           |        |                |                |        | SENSE IN         | TERRUPT        | STATUS         |                                        |                |                                        |  |  |  |  |  |  |
| Command   | w      | 0              | 0              | 0      | 1                | 0              | 0              | 0                                      | 0              | Command Codes                          |  |  |  |  |  |  |
| Result    | R      |                |                |        | _ s <sup>.</sup> | го _           |                |                                        |                | Status Information at the              |  |  |  |  |  |  |
|           | R      |                |                |        |                  | VN _           |                |                                        |                | End of each Seek<br>Operation          |  |  |  |  |  |  |
|           | L      |                |                |        |                  | SPECIFY        |                |                                        |                |                                        |  |  |  |  |  |  |
| Command   | w      | 0              | 0              | 0      | 0                | 0              | 0              | 1                                      | 1              | Command Codes                          |  |  |  |  |  |  |
|           | w      |                | s              | RT     |                  |                | HL             | лт                                     |                |                                        |  |  |  |  |  |  |
|           | w      |                |                |        | HLT              |                |                |                                        | ND             |                                        |  |  |  |  |  |  |
|           |        |                |                |        | SENSE            | DRIVE ST       | ATUS           |                                        |                | ······································ |  |  |  |  |  |  |
| Command   | w      | 0              | 0              | 0      | 0                | 0              | 1              | 0                                      | 0              | Command Codes                          |  |  |  |  |  |  |
| <b>.</b>  | w      | 0              | 0              | 0      | 0                | 0              | HDS            | DS1                                    | DS0            |                                        |  |  |  |  |  |  |
| Result    | R      |                |                |        | S                | гз             |                |                                        |                | Status Information about FDD           |  |  |  |  |  |  |
|           |        |                |                | DF     | IVE SPEC         | FICATION       | COMMAND        | )                                      |                |                                        |  |  |  |  |  |  |
| Command   | w      | 1              | 0              | 0      | 0                | 1              | 1              | 1                                      | 0              | Command Codes                          |  |  |  |  |  |  |
| Phase     | w      | 0              | FD1            | FD0    | PTS              | DRT1           | DRT0           | DT1                                    | DT0            |                                        |  |  |  |  |  |  |
|           | :<br>w | :<br>DN        | :<br>NRP       | :<br>0 | :<br>0           | :<br>0         | :<br>0         | :<br>0                                 | :<br>0         | 0-46 bytes issued                      |  |  |  |  |  |  |
|           | , w    | DN             | NRF            | U      | U                | 0              | U              | U                                      | 0              |                                        |  |  |  |  |  |  |
| Result    | R      | 0              | 0              | 0      | PTS              | DRT1           | DRT0           | DT1                                    | DT0            | Drive 0                                |  |  |  |  |  |  |
| Phase     | R      | 0              | 0              | 0      | PTS              | DRT1           | DRT0           | DT1                                    | DT0            | Drive 1                                |  |  |  |  |  |  |
|           | R      | 0              | 0              | 0      | PTS              | DRT1           | DRT0           | DT1                                    | DT0            | Drive 2                                |  |  |  |  |  |  |
|           | R      | 0              | 00             | 0      | PTS              | DRT1           | DRT0           | DT1                                    | DTO            | Drive 3                                |  |  |  |  |  |  |
|           |        |                |                |        |                  | SEEK           |                |                                        |                |                                        |  |  |  |  |  |  |
| Command   | w      | 0              | 0              | 0      | 0                | 1              | 1              | 1                                      | 1              | Command Codes                          |  |  |  |  |  |  |
|           | w      | 0              | 0              | 0      | 0                | 0              | HDS            | DS1                                    | DS0            |                                        |  |  |  |  |  |  |
| Execution | w      |                |                |        | N                | CN _           |                | ······································ |                | Head is Positioned over                |  |  |  |  |  |  |
|           |        |                |                | ·      |                  |                |                |                                        |                | Proper Cylinder on Diskette            |  |  |  |  |  |  |
|           |        |                |                |        |                  | ONFIGURE       |                |                                        |                |                                        |  |  |  |  |  |  |
| Command   | w      | CLK48          | 0              | 0      | 1                | 0              | 0              | 1                                      | 1              | Command Code                           |  |  |  |  |  |  |
|           | w      | 0              | 0              | 0      | 0                | 0              | 0              | 0                                      | 0              |                                        |  |  |  |  |  |  |
|           | w      | 0              | EIS            | EFIFO  | POLL             |                |                | FIFOTHR                                |                |                                        |  |  |  |  |  |  |
|           | W      |                |                |        |                  | ATIVE SEE      |                |                                        |                | I                                      |  |  |  |  |  |  |
| Command   | w      | 1              | DIR            | 0      | 0                | 1              | 1              | 1                                      | 1              |                                        |  |  |  |  |  |  |
| Command   | Ŵ      | 0              | 0              | 0      | 0                | 0              | HDS            | DS1                                    | DSO            |                                        |  |  |  |  |  |  |
|           | ŵ      | v              | v              | •      |                  | CN             | 1.00           | 001                                    | 200            |                                        |  |  |  |  |  |  |

|                      |        |                                             | 81             | Die 6- 1.      |                | Comman         | a set (C       | Jonunue        | aa)                                    | ran                                                       |
|----------------------|--------|---------------------------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------------------------------|-----------------------------------------------------------|
| Phase                | R/W    |                                             |                |                |                | ABUS           |                |                |                                        | Remarks                                                   |
|                      |        | D7                                          | D <sub>6</sub> | D5             | D4             | D3             | D <sub>2</sub> | D <sub>1</sub> | Do                                     |                                                           |
|                      |        |                                             |                |                | 1              | DUMPREG        |                |                |                                        |                                                           |
| Command<br>Execution | w      | 0                                           | 0              | 0              | 0              | 1              | 1              | 1              | 0                                      | *Note<br>Registers Placed in FIFO                         |
| Result               | R      |                                             |                |                |                | Drive 0        |                |                |                                        |                                                           |
|                      | R      |                                             |                |                |                | Drive 1        |                |                |                                        |                                                           |
|                      | R      |                                             | ······         |                |                | Drive 2        |                |                | ······································ |                                                           |
|                      | R      | ]                                           |                |                | . PCN-I        | Drive 3        |                |                |                                        | Ì                                                         |
|                      | R      |                                             | s              | RT             |                | <u> </u>       | HI             | UT             |                                        |                                                           |
|                      | R      |                                             |                |                | HLT            |                |                |                | ND                                     |                                                           |
|                      | R      |                                             |                |                |                | EOT            |                |                |                                        |                                                           |
|                      | R      | LOCK                                        | 0              | D3             | D <sub>2</sub> | D1             | D <sub>0</sub> | GAP            | WGATE                                  |                                                           |
|                      | R      | 0                                           | EIS            | EFIFO          | POLL           |                | FIF            | OTHR _         |                                        |                                                           |
|                      | R      | L                                           |                |                | PRE            | TRK            |                |                |                                        |                                                           |
| O                    | w      |                                             |                |                |                | READ ID        |                |                |                                        | 0                                                         |
| Command              | Ŵ      | 0                                           | MFM<br>0       | 0              | 0              | 1<br>0         | 0<br>HDS       | 1<br>DS1       | 0<br>DS0                               | Commands                                                  |
| Execution            |        |                                             | •              | •              | -              | •              |                |                |                                        | The First Correct ID                                      |
|                      |        |                                             |                |                |                |                |                |                |                                        | Information on the Cylinder<br>is Stored in Data Register |
| Result               | R      | (                                           |                |                | e-             | го _           |                |                |                                        | Status Information after                                  |
| Hosuit               | R      |                                             |                |                |                | го <u> </u>    |                |                |                                        | Command Execution                                         |
|                      | R      |                                             |                |                |                | Г2 <u>_</u>    |                |                |                                        |                                                           |
|                      | R      |                                             |                |                |                |                |                |                |                                        |                                                           |
|                      | R      |                                             |                |                |                |                |                |                |                                        | Disk Status after the                                     |
|                      | R      |                                             |                |                |                | i I            |                |                |                                        | Command has Completed                                     |
|                      | R      |                                             |                |                | -              | ч _            |                |                |                                        |                                                           |
|                      | L      | L                                           |                |                | PERPE          | NDICULAR       | MODE           |                |                                        |                                                           |
| Command              | w      | 0                                           | 0              | 0              | 1              | 0              | 0              | 1              | 0                                      | Command Codes                                             |
|                      | w      | ow                                          | 0              | D <sub>3</sub> | $D_2$          | D <sub>1</sub> | D0             | GAP            | WGATE                                  |                                                           |
|                      |        |                                             |                |                |                | LOCK           |                |                |                                        |                                                           |
| Command              | w      | LOCK                                        | 0              | 0              | 1              | 0              | 1              | 0              | 0                                      | Command Codes                                             |
| Result               | R      | 0                                           | 0              | 0              | LOCK           | 0              | 0              | 0              | 0                                      |                                                           |
|                      |        |                                             |                |                |                | PART ID        | <u>.</u>       |                | <u> </u>                               |                                                           |
| Command              | W      | 0                                           | 0              | 0              | 1              | 1              | 0              | 0              | 0,                                     | Command Code                                              |
| Result               | R      | 0                                           | 0              | 0              |                | -STEP          |                |                | 11                                     | Part ID Number                                            |
|                      |        | r                                           |                |                |                | RDOWN          |                |                |                                        | r                                                         |
| Command              | w<br>w | 0                                           | 0              | 0              | 1              | 0              | 1              | 1              | 1                                      | Command Code                                              |
|                      | w      | 0                                           | 0              | EREG           | x              | PS2            | FDI            | MIN            | AUTO                                   |                                                           |
|                      | }      |                                             |                | EN             |                | STAT           | TRI            | DLY            | PD                                     |                                                           |
| Result               | R      | 0                                           | 0              | EREG           | х              | PS2            | FDI            | MłN            | AUTO                                   |                                                           |
|                      |        | Ĩ                                           | v              | EN             | ~              | STAT           | TRI            | DLY            | PD                                     |                                                           |
|                      | L.,    | 4                                           |                |                |                | OPTION         |                |                |                                        | <b>I</b>                                                  |
| Command              | w      | 0                                           | 0              | 1              | 1              | 0              | 0              | 1              | 1                                      | Command Code                                              |
|                      | Ŵ      |                                             | -              |                |                | '              | -              | •              | ISO                                    |                                                           |
|                      |        | <u>ــــــــــــــــــــــــــــــــــــ</u> |                |                |                |                |                |                |                                        | L                                                         |

| Phase            | B/W |           |                |                |                |                |                |                |                |                                |
|------------------|-----|-----------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--------------------------------|
| Phase            | H/W | D7        | D <sub>6</sub> | D <sub>5</sub> | D4             | D <sub>3</sub> | D <sub>2</sub> | D1             | D <sub>0</sub> | Remarks                        |
|                  |     |           |                |                | ·              | SAVE           |                | ·····          | <b>`</b>       |                                |
| Command<br>Phase | w   | 0         | 0              | 1              | 0              | 1              | 1              | 1              | 0              | Command Code                   |
| Result<br>Phase  | R   | CLK<br>48 | SEL<br>3V#     | PD<br>OSC      | PC2            | PC1            | PC0            | DRATE1         | DRATE0         | Save Info to Reprogram the FDC |
|                  | R   | 0         | 0              | 0              | 0              | 0              | 0              | 0              | ISO            |                                |
|                  | R   |           |                |                | PCN-D          | Drive O        |                |                |                |                                |
|                  | R   |           |                |                | PCN-E          | Drive 1        |                |                |                |                                |
|                  | R   |           |                |                | PCN-E          |                |                |                |                |                                |
|                  | R   |           |                |                | PCN-D          |                |                |                |                |                                |
|                  | R   |           | SF             | FON-L          | NIVE 3         |                | нит _          |                |                |                                |
|                  | R   |           | ər             | ··             | HLT            |                |                |                |                |                                |
|                  | R   |           |                |                | SC/I           | FOT            |                |                | ND             |                                |
|                  | R   | LOCK      | 0              | D3             | D <sub>2</sub> | D1             | Do             | GAP            | WGATE          |                                |
|                  | R   | 0         | EIS            | EFIFO          | POLL           | 51             | 0              | FIFOTHR .      | WGATE          |                                |
|                  | R   |           | EIS            | EFIFO          | PRE            |                |                | FIFOTIAN .     |                |                                |
|                  |     | 0         | 0              | 5050           |                |                |                |                | AUTO           |                                |
|                  | R   | 0         | 0              | EREG           | RSVD           | PS2            | FDI            |                | AUTO           |                                |
|                  |     |           |                | EN             |                | STAT           | TRI            | DLY            | PD             |                                |
|                  | R   |           | · · · · · ·    |                | DISK/S         |                |                |                |                |                                |
|                  | R   |           |                |                | RS             |                |                |                |                |                                |
|                  | R   |           |                |                | RS             |                |                |                |                |                                |
|                  |     |           |                |                |                | RESTORE        |                |                |                | r                              |
| Command<br>Phase | w   | . 0       | 1              | 0              | 0              | 1 .            | 1              | 1              | 0              | Command Code                   |
| Result           | w   | CLK48     | SEL 3V#        | . 0            | PC2            | PC1            | PC0            | DRATE1         | DRATE0         | Restore Original               |
|                  | w   | 0         | 0              | 0              | 0              | 0              | 0              | 0              | ISO            | Register Status                |
|                  | w   |           |                |                | PCN-E          | Orive O        |                |                |                |                                |
|                  | w   |           |                |                | PCN-E          | Drive 1        | ·              |                |                | }                              |
|                  | w   |           |                |                | PCN-E          | Drive 2        |                |                |                |                                |
|                  | w   |           |                |                | PCN-E          | -              |                |                |                | 1                              |
|                  | w   |           | SF             | ет             |                |                |                | HUT            |                | 1                              |
|                  | Ŵ   |           | 0/             |                | HLT            |                |                |                | ND             | 1                              |
|                  | w   |           |                |                | SC/            | EOT            |                |                | ND             |                                |
|                  |     | LOCK      | 0              | <u> </u>       |                |                |                | CAD            | MOATE          | 1 ·                            |
|                  | w   | LOCK      | 0              | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | GAP<br>FIFOTHR | WGATE          | 1                              |
|                  | W . | 0         | EIS            | EFIFO          | POLL           |                |                | FIFUTHE .      |                | [                              |
|                  | w   |           |                |                |                | TRK            |                |                |                | 1                              |
|                  | w   | 0         | 0              | EREG           | RSVD           | PS2            | FDI            |                | AUTO           |                                |
|                  |     |           |                | EN             |                | STAT           | TRI            | DLY            | PD             | [                              |
|                  | w   |           |                |                | DISK/S         |                |                |                |                |                                |
|                  | W   |           |                |                | RS             |                |                |                | <u> </u>       | [ · · · ·                      |
|                  | W   |           |                |                | RS             |                |                |                |                |                                |

Table 6-1. 82078 Command Set (Continued)

intel.

## int<sub>el</sub>.

### 82078 64 PIN

| Phase     | B/W    |                |                | Remarks        |                  |                |                                                                    |     |     |                                          |
|-----------|--------|----------------|----------------|----------------|------------------|----------------|--------------------------------------------------------------------|-----|-----|------------------------------------------|
| Fildee    | R/W    | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D4               | D <sub>3</sub> | D <sub>2</sub>                                                     | Di  | Do  | Remarks                                  |
|           |        |                |                |                | FORM             | AT AND W       | RITE                                                               |     |     |                                          |
| Command   | w      | 1              | MFM            | 1              | 0                | 1              | 1                                                                  | 0   | 1   | Command Code                             |
|           | W I    | 0              | 0              | 0              | 0                | 0              | HDS                                                                | DS1 | DS0 |                                          |
|           | w      |                |                |                |                  | N .<br>iC .    | ·                                                                  |     |     | ·                                        |
|           | Ŵ      |                |                |                |                  | PL.            |                                                                    |     |     |                                          |
|           | w      |                |                |                |                  | ב<br>כ         |                                                                    |     |     |                                          |
| Execution | w      |                |                |                |                  | c .            |                                                                    |     |     | Input                                    |
| Repeated  | l w l  |                |                |                |                  | -<br>-         |                                                                    |     |     | Sector                                   |
| for each  | w      |                |                |                |                  |                |                                                                    |     |     | Parameters                               |
| Sector    | w      |                |                |                |                  | N .            |                                                                    |     |     |                                          |
|           | w      |                |                | 1              | Data Transf      | er of N Byte   | s                                                                  |     |     | l                                        |
|           |        |                |                |                |                  |                |                                                                    |     |     | 82078 Formats and Writes<br>Entire Track |
| Result    | R      |                |                |                | _ s <sup>-</sup> | го .           |                                                                    |     |     |                                          |
| Phase     | R      |                |                |                |                  | Γ1.            |                                                                    |     |     |                                          |
|           | R      | ·              |                |                |                  | Г2.            |                                                                    | ·   |     | (                                        |
|           | R      |                |                |                |                  | fined          |                                                                    |     |     | Į                                        |
|           | R      |                |                |                |                  | afined         |                                                                    |     |     |                                          |
|           | R      |                |                |                |                  | efined .       |                                                                    |     |     |                                          |
|           | L.,, L |                |                |                |                  | INVALID        |                                                                    |     |     | <u></u>                                  |
| Command   | w      | Invalid Codes  |                |                |                  |                | Invalid Command Codes<br>(NoOp — 82078 goes into<br>Standby State) |     |     |                                          |
| Result    | R      |                |                |                | S                | го             |                                                                    |     |     | ST 0 = 80H                               |

### Table 6-1. 82078 Command Set (Continued)

**.** . . .

## intel.

### PARAMETER ABBREVIATIONS

. . . . . . . . . .

| Symbol  | Description                                                                                                                                                  |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AUTO PD | Auto powerdown control. If this bit is 0,<br>then the automatic powerdown is dis-<br>abled. If it is set to 1, then the automat-<br>ic powerdown is enabled. |
|         |                                                                                                                                                              |

- C Cylinder address. The currently selected cylinder address, 0 to 255.
- CLK48 CLK48 = 1 indicates an external 48 MHz oscillator is being used.

CLK48 = 0 indicates a 24 MHz clock.

- D0, D1, D2, Drive Select 0-3. Designates which D3 drives are Perpendicular drives, a "1" indicating Perpendicular drive.
- D Data pattern. The pattern to be written in each sector data field during formatting.
- DN Done. This bit indicates that this is the last byte of the drive specification command. The 82078 checks to see if this bit is high or low. If it is low, it expects more bytes.
  - DN = 0 82078 expects more subsequent bytes.
  - DN = 1 Terminates the command phase and jumps to the results phase. An additional benefit is that by setting this bit high, a direct check of the current drive specifications can be done.

DIR

Direction control. If this bit is 0, then the head will step out from the spindle during a relative seek. If set to a 1, the head will step in toward the spindle. DS0, DS1 Disk Drive Select.

| DS1 | DS0 |         |
|-----|-----|---------|
| 0   | 0   | Drive 0 |
| 0   | 1   | Drive 1 |
| 1   | 0   | Drive 2 |
| 1   | 1   | Drive 3 |

Special sector size. By setting N to zero (00), DTL may be used to control the number of bytes transferred in disk read/write commands. The sector size (N = 0) is set to 128. If the actual sector (on the diskette) is larger than DTL, the remainder of the actual sector is read but is not passed to the host during read commands; during write commands, the remainder of the actual sector is written with all zero bytes. The CRC check code is calculated with the actual sector. When N is not zero, DTL has no meaning and should be set to FF HEX.

DRATE1, DRATE0

DRT0, DRT1

DTL

Data rate values from the DSR register.

- Data rate table select. These two bits select between the different data rate tables. The default is the conventional table. These also provide mapping of the data rates selected in the DSR and CCR. The mapped values are provided for read back by the system software are as shown in the DIR (in PS/2 Mode only). Table 6-2 shows this.
- DT0, DT1 Drive density select type. These bits select the outputs on DRVDEN0 and DRVDEN1 based on mode of operation that was selected via the IDENT1 and IDENT0 pins. More information is available in the Design Applications section.

|      |      |                 | 18     | Die 0-2. Dat | a Hate Select |                              |                            |
|------|------|-----------------|--------|--------------|---------------|------------------------------|----------------------------|
|      |      | Bits in DSR/CCR |        |              |               | ned via DIR<br>Ible in PS/2) |                            |
| DRT0 | DRT1 | DRATE0          | DRATE1 | Data<br>Rate | DRATE0        | DRATE1                       | Operation                  |
|      |      | 1               | 1      | 1 Mbps       | 1             | 1                            | Default                    |
| 0    | 0    | 0               | 0      | 500 Kbps     | 0             | 0                            |                            |
|      |      | 1               | 0      | 300 Kbps     | 1             | 0                            |                            |
|      |      | 0               | 1      | 250 Kbps     | 0             | 1                            |                            |
|      |      | 1               | 1      | 1 Mbps       | 1             | 1                            | 2 Mbps                     |
| 0    | 1    | 0               | 0      | 500 Kbps     | 0             | 0                            | Tape Drive                 |
|      |      | 1               | 0      | 2 Mbps       | 1             | 1                            |                            |
|      |      | 0               | 1      | 250 Kbps     | 0             | 1                            |                            |
| 1    | 0    |                 |        | RSVI         | )             |                              | RSVD                       |
|      |      | 1               | 1      | 1 Mbps       | 1             | 1                            | Perpendicular mode<br>FDDs |
| 1    | 1    | 0               | 0      | 500 Kbps     | 0             | 0                            | 1                          |
|      |      | 1               | 0      | RSVD         |               |                              |                            |
|      |      | 0               | 1      | 250 Kbps     | 0             | 1                            |                            |

#### Table 6-2. Data Rate Select Table

- EC Enable Count. When this bit is "1" the "DTL" parameter of the Verify Command becomes SC (Number of sectors per track).
- EFIFO Enable FIFO. When this bit is 0, the FIFO is enabled. A "1" puts the 82078 in the 8272A compatible mode where the FIFO is disabled.
- EIS Enable implied seek. When set, a seek operation will be performed before executing any read or write command that requires the C parameter in the command phase. A "0" disables the implied seek.
- EOT End of track. The final sector number of the current track.
- EREG EN Enhanced Register Enable.
  - EREG EN = 1 In PS/2 mode the TDR register is extended. In AT/EISA mode, the TDR register is extended and SRB is made visible to the user.
  - EREG EN = 0 Standard AT/EISA and PS/2 registers are used.

GAP

GPL

- FDI TRI Floppy Drive Interface Tri-state: If this bit is 0, then the output pins of the floppy disk drive interface are tri-stated. This is also the default state. If it is set to 1, then the floppy disk drive interface remains unchanged.
- FD0, FD1 Floppy drive select. These two bits select which physical drive is being specified. The FDn corresponds to FDSn and FDMEn on the floppy drive interface. The drive is selected independent of the BOOTSELn bits. Please refer to Section 2.1.1 which explains the distinction between physical drives and their virtual mapping as defined by the BOOTSEL1 and BOOTSEL0 bits.

| FD0 | FD1 | Drive Slot |
|-----|-----|------------|
| 0   | 0   | Drive 0    |
| 0   | 1   | Drive 1    |
| 1   | 0   | Drive 2    |
| 1   | 1   | Drive 3    |

Alters Gap 2 length when using Perpendicular Mode.

Gap length. The gap 3 size. (Gap 3 is the space between sectors excluding the VCO synchronization field).

Head address. Selected head: 0 or 1 (disk side 0 or 1) as encoded in the sector ID field.

- HLT Head load time. The time interval that 82078 waits after loading the head and before initiating a read or write operation. Refer to the SPECIFY command for actual delays.
- HUT Head unload time. The time interval from the end of the execution phase (of a read or write command) until the head is unloaded. Refer to the SPECI-FY command for actual delays.

ISO ISO Format: If this bit is set high the ISO format is used for all data transfer commands. When this bit is set low the normal IBM system 34 and perpendicular is used. The default is ISO = 0.

- Lock defines whether EFIFO. Lock FIFOTHR, and PRETRK parameters of the CONFIGURE command can be reset to their default values by a "Software Reset" (Reset made by setting the proper bit in the DSR or DOR registers).
- MFM mode. A one selects the double MFM density (MFM) mode. A zero is reserved.
- MIN DLY Minimum power up time control. This bit is active only if AUTO PD bit is enabled. Setting this bit to a 0, assigns a 10 ms minimum power up time and setting this bit to a 1, assigns a 0.5 sec. minimum power up time (unless 2 Mbps, then 5 ms to 0.25 sec.).
- MT Multi-track selector. When set, this flag selects the multi-track operating mode. In this mode, the 82078 treats a complete cylinder, under head 0 and 1, as a single track. The 82078 operates as if this expanded track started at the first sector under head 0 and ended at the last sector under head 1. With this flag set, a multitrack read or write operation will automatically continue to the first sector under head 1 when the 82078 finishes operating on the last sector under head 0.

Sector size code. This specifies the number of bytes in a sector. If this parameter is "00", then the sector size is 128 bytes. The number of bytes transferred is determined by the DTL parameter. Otherwise the sector size is (2 raised to the "N'th" power) times 128. All values up to "07" hex are allowable. "07"h would equal a sector size of 16k. It is the users responsibility to not select combinations that are not possible with the drive.

| N  | Sector Size |
|----|-------------|
| 00 | 128 bytes   |
| 01 | 256 bytes   |
| 02 | 512 bytes   |
| 03 | 1024 bytes  |
| _  | _           |
| 07 | 16 Kbytes   |

New cylinder number. The desired cylinder number.

NCN

ND

- Non-DMA mode flag. When set to 1, indicates that the 82078 is to operate in the non-DMA mode. In this mode, the host is interrupted for each data transfer. When set to 0, the 82078 operates in DMA mode, interfacing to a DMA controller by means of the DRQ and DACK # signals.
- NRP No Results phase. When this bit is set high the result phase is skipped. When this bit is low the result phase will be generated.
- The bits denoted D0, D1, D2, and D3 of OW the PERPENDICULAR MODE command can only be overwritten when the OW bit is set to "1".
- PCN Present cylinder number. The current position of the head at the completion of SENSE INTERRUPT STATUS command.
- PC2, PC1, Precompensation values from the DSR PC0 register.
- PDOSC When this bit is set, the internal oscillator is turned off.

This may be done if using the external 48 MHz oscillator.

PS/2 status. This bit is functional only PS/2 STAT in the PS/2 mode. In all other modes this bit will not have any effect. When set high this bit enables two bits (bits 5 and 6) in the DIR register to reflect the values of PD and IDLE respectively except when IDLEMSK (bit 4) is set. Default value is 0.

PTS Precompensation table select. This bit selects whether to enable the precompensation value programmed in the DSR or not. In the default state, the value programmed in DSR will be used.

- PTS = 0 DSR programmed precompensation delays.
- PTS = 1 No precompensation delay is selected for the corresponding drive.

N

# intel

- POLL Polling disable. When set, the internal polling routine is disabled. When clear, polling is enabled.
- PRETRK Precompensation start track number. Programmable from track 00 to FFH.

R Sector address. The sector number to be read or written. In multi-sector transfers, this parameter specifies the sector number of the first sector to be read or written.

RCN Relative cylinder number. Relative cylinder offset from present cylinder as used by the RELATIVE SEEK command.

- SC Number of sectors. The number of sectors to be initialized by the FORMAT command. The number of sectors to be verified during a Verify Command, when EC is set.
- SEL3V# SEL3V# = 1 indicates that the part is operating at 5.0V. SEL3V# = 0 indicates that the part is

operating at 3.3V.

Skip flag. When set to 1, sectors containing a deleted data address mark will automatically be skipped during the execution of READ DATA. If READ DE-LETED is executed, only sectors with a deleted address mark will be accessed. When set to "0", the sector is read or written the same as the read and write commands.

SK

- SRT Step rate interval. The time interval between step pulses issued by the 82078. Programmable from 0.5 ms to 8 ms, in increments of 0.5 ms at the 1 Mbit data rate. Refer to the SPECIFY command for actual delays.
- ST0-3 Status registers 0-3. Registers within the 82078 that store status information after a command has been executed. This status information is available to the host during the result phase after command execution.
- STEPPING These bits identify the stepping of the 82078.
- WGATE Write gate alters timing of WE, to allow for pre-erase loads in perpendicular drives.

### 6.1 Data Transfer Commands

All of the READ DATA, WRITE DATA and VERIFY type commands use the same parameter bytes and return the same results information. The only difference being the coding of bits 0–4 in the first byte.

An implied seek will be executed if the feature was enabled by the CONFIGURE command. This seek is completely transparent to the user. The Drive Busy bit for the drive will go active in the Main Status Register during the seek portion of the command. If the seek portion fails, it will be reflected in the results status normally returned for a READ/WRITE DATA command. Status Register 0 (ST0) would contain the error code and C would contain the cylinder on which the seek failed.

#### 6.1.1 READ DATA

A set of nine (9) bytes is required to place the 82078 into the Read Data Mode. After the READ DATA command has been issued, the 82078 loads the head (if it is in the unloaded state), waits the specified head settling time (defined in the SPECIFY command), and begins reading ID Address Marks and ID fields. When the sector address read off the diskette matches with the sector address specified in the command, the 82078 reads the sector's data field and transfers the data to the FIFO.

After completion of the read operation from the current sector, the sector address is incremented by one, and the data from the next logical sector is read and output via the FIFO. This continuous read function is called "Multi-Sector Read Operation". Upon receipt of TC, or an implied TC (FIFO overrun/underrun), the 82078 stops sending data, but will continue to read data from the current sector, check the CRC bytes, and at the end of the sector terminate the READ DATA Command.

N determines the number of bytes per sector (see Table 6-3). If N is set to zero, the sector size is set to 128. The DTL value determines the number of bytes to be transferred. If DTL is less than 128, the 82078 transfers the specified number of bytes to the host. For reads, it continues to read the entire 128 byte sector and checks for CRC errors. For writes it completes the 128 byte sector by filling in zeroes. If N is not set to 00 Hex, DTL should be set to FF Hex, and has no impact on the number of bytes transferred.

#### **Table 6-3. Sector Sizes**

| N  | Sector Size |
|----|-------------|
| 00 | 128 bytes   |
| 01 | 256 bytes   |
| 02 | 512 bytes   |
| 03 | 1024 bytes  |
| -  | _           |
| 07 | 16 Kbytes   |

The amount of data which can be handled with a single command to the 82078 depends upon MT (multi-track) and N (Number of bytes/sector).

Table 6-4. Effects of MT and N Bits

| мт | N | Max. Transfer<br>Capacity | Final Sector Read<br>from Disk |
|----|---|---------------------------|--------------------------------|
| 0  | 1 | $256 \times 26 = 656$     | 26 at side 0 or 1              |
| 1  | 1 | 256 × 52 = 13312          | 26 at side 1                   |
| 0  | 2 | $512 \times 15 = 7680$    | 15 at side 0 or 1              |
| 1  | 2 | 512 × 30 = 15360          | 15 at side 1                   |
| 0  | 3 | $1024 \times 8 = 8192$    | 8 at side 0 or 1               |
| 1  | 3 | 1024 × 16 = 16384         | 16 at side 1                   |

The Multi-Track function (MT) allows the 82078 to read data from both sides of the diskette. For a particular cylinder, data will be transferred starting at Sector 1, Side 0 and completing at the last sector of the same track at Side 1.

If the host terminates a read or write operation in the 82078, then the ID information in the result phase is dependent upon the state of the MT bit and EOT byte. Refer to Table 6-7. The termination must be normal.

At the completion of the READ DATA Command, the head is not unloaded until after the Head Unload Time Interval (specified in the SPECIFY command) has elapsed. If the host issues another command before the head unloads then the head settling time may be saved between subsequent reads.

If the 82078 detects a pulse on the INDX# pin twice without finding the specified sector (meaning that the diskette's index hole passes through index detect logic in the drive twice), the 82078 sets the IC code in Status Register 0 to "01" (Abnormal termination), and sets the ND bit in Status Register 1 to "1" indicating a sector not found, and terminates the READ DATA Command.

After reading the ID and Data Fields in each sector, the 82078 checks the CRC bytes. If a CRC error occurs in the ID or data field, the 82078 sets the IC code in Status Register 0 to "01" (Abnormal termination), sets the DE bit flag in Status Register 1 to "1", sets the DD bit in Status Register 2 to "1" if CRC is incorrect in the ID field, and terminates the READ DATA Command.

Table 6-5 describes the affect of the SK bit on the READ DATA command execution and results.

| SK           | Data Address             |                 | Resu               | ts                                                                 |
|--------------|--------------------------|-----------------|--------------------|--------------------------------------------------------------------|
| Bit<br>Vaiue | Mark Type<br>Encountered | Sector<br>Read? | CM Bit of ST2 Set? | Description<br>of Results                                          |
| 0            | Normal Data              | Yes             | No                 | Normal<br>Termination.                                             |
| 0            | Deleted Data             | Yes             | Yes                | Address Not<br>Incremented.<br>Next Sector<br>Not Searched<br>For. |
| 1            | Normal Data              | Yes             | No                 | Normal<br>Termination.                                             |
| 1            | Deleted Data             | No              | Yes                | Normal<br>Termination<br>Sector Not<br>Read<br>("Skipped").        |

Except where noted in Table 6-5, the C or R value of the sector address is automatically incremented (see Table 6-7).

#### 6.1.2 READ DELETED DATA

This command is the same as the READ DATA command, only it operates on sectors that contain a Deleted Data Address Mark at the beginning of a Data Field. Table 6-6 describes the affect of the SK bit on the READ DELETED DATA command execution and results.

| SK           | Data Address             |                 | Resul              | ts                                                                 |
|--------------|--------------------------|-----------------|--------------------|--------------------------------------------------------------------|
| Bit<br>Value | Mark Type<br>Encountered | Sector<br>Read? | CM Bit of ST2 Set? | Description<br>of Results                                          |
| 0            | Normal Data              | Yes             | Yes                | Normal<br>Termination.                                             |
| 0            | Deleted Data             | Yes             | No                 | Address Not<br>Incremented.<br>Next Sector<br>Not Searched<br>For. |
| 1            | Normal Data              | No              | Yes                | Normal<br>Termination<br>Sector Not<br>Read<br>("Skipped").        |
| 1            | Deleted Data             | Yes             | No                 | Normal<br>Termination.                                             |

|      | Table 6-6. | Skip Bit vs         |
|------|------------|---------------------|
| READ | DELETED    | <b>DATA Command</b> |

Except where noted in Table 6-6 above, the C or R value of the sector address is automatically incremented (see Table 6-7).

#### 6.1.3 READ TRACK

This command is similar to the READ DATA command except that the entire data field is read continuously from each of the sectors of a track. Immediately after encountering a pulse on the INDX# pin, the 82078 starts to read all data fields on the track as continuous blocks of data without regard to logical sector numbers. If the 82078 finds an error in the ID or DATA CRC check bytes, it continues to read data from the track and sets the appropriate error bits at the end of the command. The 82078 compares the ID information read from each sector with the specified value in the command, and sets the ND flag of Status Register 1 to a "1" if there is no comparison.

Multi-track or skip operations are not allowed with this command. The MT and SK bits (Bits D7 and D5 of the first command byte respectively) should always be set to "0".

11

| _  |      |                             |     |     |                  |     |  |  |  |  |  |  |  |  |  |
|----|------|-----------------------------|-----|-----|------------------|-----|--|--|--|--|--|--|--|--|--|
| мт | Head | Final Sector<br>Transferred |     |     | matior<br>t Phas | . 1 |  |  |  |  |  |  |  |  |  |
|    |      | to Host                     | С   | н   | R                | Ν   |  |  |  |  |  |  |  |  |  |
|    | 0    | Less than EOT               | NC  | NC  | R+1              | NC  |  |  |  |  |  |  |  |  |  |
| 0  |      | Equal to EOT                | C+1 | NC  | 01               | NC  |  |  |  |  |  |  |  |  |  |
| 0  | 1    | Less than EOT               | NC  | NC  | R+1              | NC  |  |  |  |  |  |  |  |  |  |
|    |      | Equal to EOT                | C+1 | NC  | 01               | NC  |  |  |  |  |  |  |  |  |  |
|    | 0    | Less than EOT               | NC  | NC  | R+1              | NC  |  |  |  |  |  |  |  |  |  |
| 4  |      | Equal to EOT                | NC  | LSB | 01               | NC  |  |  |  |  |  |  |  |  |  |
|    | 1    | Less than EOT               | NC  | NC  | R+1              | NC  |  |  |  |  |  |  |  |  |  |
|    |      | Equal to EOT                | C+1 | LSB | 01               | NC  |  |  |  |  |  |  |  |  |  |

**Table 6-7. Result Phase Table** 

NC: No Change, the same value as the one at the beginning of command execution.

LSB: Least Significant Bit, the LSB of H is complemented.

This command terminates when the EOT specified number of sectors have been read. If the 82078 does not find an ID Address Mark on the diskette after the second occurrence of a pulse on the INDX# pin, then it sets the IC code in Status Register 0 to "01" (Abnormal termination), sets the MA bit in Status Register 1 to "1", and terminates the command.

#### 6.1.4 WRITE DATA

After the WRITE DATA command has been issued, the 82078 loads the head (if it is in the unloaded state), waits the specified head load time if unloaded (defined in the SPECIFY command), and begins reading ID Fields. When the sector address read from the diskette matches the sector address specified in the command, the 82078 reads the data from the host via the FIFO, and writes it to the sector's data field.

After writing data into the current sector, the 82078 computes the CRC value and writes it into the CRC field at the end of the sector transfer. The Sector Number stored in "R" is incremented by one, and the 82078 continues writing to the next data field. The 82078 continues this "Multi-Sector Write Operation". Upon receipt of a terminal count signal or if a FIFO over/under run occurs while a data field is being written, then the remainder of the data field is filled with zeroes.

The 82078 reads the ID field of each sector and checks the CRC bytes. If it detects a CRC error in one of the ID Fields, it sets the IC code in Status Register 0 to "01" (Abnormal termination), sets the DE bit of Status Register 1 to "1", and terminates the WRITE DATA command.

The WRITE DATA command operates in much the same manner as the READ DATA command. The following items are the same. Please refer to the READ DATA Command for details:

- Transfer Capacity
- (End of Cylinder) bit
- ND (No Data) bit
- Head Load, Unload Time Interval
- ID information when the host terminates the command.
- Definition of DTL when N = 0 and when N does not = 0.

#### 6.1.5 WRITE DELETED DATA

This command is almost the same as the WRITE DATA command except that a Deleted Data Address Mark is written at the beginning of the Data Field instead of the normal Data Address Mark. This command is typically used to mark a bad sector containing an error on the floppy disk.

#### 6.1.6 VERIFY

The VERIFY command is used to verify the data stored on a disk. This command acts exactly like a READ DATA command except that no data is transferred to the host. Data is read from the disk, CRC computed and checked against the previously stored value.

Because no data is transferred to the host, TC (pin 25) cannot be used to terminate this command. By setting the EC bit to "1" an implicit TC will be issued to the 82078. This implicit TC will occur when the SC value has decrement to 0 (an SC value of 0 will verify 256 sectors). This command can also be terminated by setting the EC bit to "0" and the EOT value equal to the final sector to be checked. If EC is set to "0" DTL/SC should be programmed to 0FFH. Refer to Table 6-6 and Table 6-7 for information concerning the values of MT and EC versus SC and EOT value.

Definitions:

# Sectors Per Side = Number of formatted sectors per each side of the disk.

# Sectors Remaining = Number of formatted sectors left which can be read, including side 1 of the disk if MT is set to "1".



| MT | EC | SC/EOT Value                                                        | Termination Result                               |
|----|----|---------------------------------------------------------------------|--------------------------------------------------|
| 0  | 0  | SC = DTL<br>EOT $\leq$ # Sectors Per Side                           | Successful Termination<br>Result Phase Valid     |
| 0  | 0  | SC = DTL<br>EOT > # Sectors Per Side                                | Unsuccessful Termination<br>Result Phase Invalid |
| 0  | 1  | $SC \le #$ Sectors Remaining<br>AND<br>EOT $\le #$ Sectors Per Side | Successful Termination<br>Result Phase Valid     |
| 0  | 1  | SC > # Sectors Remaining<br>OR<br>EOT > # Sectors Per Side          | Unsuccessful Termination<br>Result Phase Invalid |
| 1  | 0  | SC = DTL<br>EOT $\leq$ # Sectors Per Side                           | Successful Termination<br>Result Phase Valid     |
| 1  | 0  | SC = DTL<br>EOT > # Sectors Per Side                                | Unsuccessful Termination<br>Result Phase Invalid |
| 1  | 1  | SC ≤ # Sectors Remaining<br>AND<br>EOT ≤ # Sectors Per Side         | Successful Termination<br>Result Phase Valid     |
| 1  | 1  | SC > # Sectors Remaining<br>OR<br>EOT > # Sectors Per Side          | Unsuccessful Termination<br>Result Phase Invalid |

#### Table 6-8. Verify Command Result Phase Table

#### NOTE:

If MT is set to "1" and the SC value is greater than the number of remaining formatted sectors on Side 0, verifying will continue on Side 1 of the disk.

#### 6.1.7 FORMAT TRACK

The FORMAT command allows an entire track to be formatted. After a pulse from the INDX# pin is detected, the 82078 starts writing data on the disk including Gaps, Address Marks, ID Fields and Data Fields, per the IBM System 34 (MFM). The particular values that will be written to the gap and data field are controlled by the values programmed into N, SC, GPL, and D which are specified by the host during the command phase. The data field of the sector is filled with the data byte specified by D. The ID Field for each sector is supplied by the host; that is, four data bytes per sector are needed by the 82078 for C, H, R, and N (cylinder, head, sector number and sector size respectively). After formatting each sector, the host must send new values for C, H, R and N to the 82078 for the next sector on the track. The R value (sector number) is the only value that must be changed by the host after each sector is formatted. This allows the disk to be formatted with nonsequential sector addresses (interleaving). This incrementing and formatting continues for the whole track until the 82078 encounters a pulse on the INDX # pin again and it terminates the command.

Table 6-9 contains typical values for gap fields which are dependent upon the size of the sector and the number of sectors on each track. Actual values can vary due to drive electronics.

| Drive Form | MEDIA | Sector Size | N  | SC | GPL1 | GPL2 |
|------------|-------|-------------|----|----|------|------|
| E 05%      | 1.2M  | 512         | 02 | 0F | 2A   | 50   |
| 5.25″      | 360K  | 512         | 02 | 09 | 2A   | 50   |
|            | 2.88M | 512         | 02 | 24 | 38   | 53   |
| 3.5″       | 1.44M | 512         | 02 | 18 | 1B   | 54   |
|            | 720K  | 512         | 02 | 09 | 1B   | 54   |

#### Table 6-9. Typical PC-AT Values for Formatting

#### NOTE:

All values except Sector Size are in Hex.

Gap3 is programmable during reads, writes, and formats.

GPL1 = suggested Gap3 values in read and write commands to avoid splice point between data field and ID field of contiguous sections.

GPL2 = suggested Gap3 value in FORMAT TRACK command.

#### 6.1.7.1 Format Fields

Table 6-10. System 34 Format Double Density

| GAP 4     | a SYNC    | IAI      | N  | GAP 1     | SYNC      | IDAM        | с |   | s      | N | С      | GAP 2     | SYNC      | DAT      | A AM     |      | с      |       |        |
|-----------|-----------|----------|----|-----------|-----------|-------------|---|---|--------|---|--------|-----------|-----------|----------|----------|------|--------|-------|--------|
| 80x<br>4E | 12x<br>00 | 3x<br>C2 | FC | 50x<br>4E | 12x<br>00 | 3x<br>A1 FE | Y | D | E<br>C | 0 | R<br>C | 22x<br>4E | 12x<br>00 | 3x<br>A1 | FB<br>F8 | DATA | R<br>C | GAP 3 | GAP 4b |

#### Table 6-11. ISO Format

| GA | <b>&gt;</b> 1 | SYNC | ID/ | ٩M | с | н | s | N | Ċ | GAP 2 | SYNC | DAT | A AM |      | с |       |        |
|----|---------------|------|-----|----|---|---|---|---|---|-------|------|-----|------|------|---|-------|--------|
| 32 |               | 12x  | 3x  | Ц  | Y | D | E |   | R | 22x   | 12x  | 3x  | FB   | DATA | R | GAP 3 | GAP 4b |
| 48 | Ξ             | 00   | A1  | FE | L |   | С |   | С | 4E    | 00   | A1  | F8   |      | C |       |        |

#### Table 6-12. Perpendicular Format

| GAP 4a    | SYNC      | IA       | N  | GAP 1     | SYNC      | IDA      | M  | с      | н | s      | N | с      | GAP 2     | SYNC      | DAT      | A AM     |      | с      |       |        |
|-----------|-----------|----------|----|-----------|-----------|----------|----|--------|---|--------|---|--------|-----------|-----------|----------|----------|------|--------|-------|--------|
| 80x<br>4E | 12x<br>00 | 3x<br>C2 | FC | 50x<br>4E | 12x<br>00 | 3х<br>А1 | FE | Y<br>L | D | E<br>C | 0 | R<br>C | 41x<br>4E | 12x<br>00 | 3x<br>A1 | FB<br>F8 | DATA | R<br>C | GAP 3 | GAP 4b |

### 6.2 Control Commands

Control commands differ from the other commands in that no data transfer takes place. Three commands generate an interrupt when complete; READ ID, RECALIBRATE and SEEK. The other control commands do not generate an interrupt.

#### 6.2.1 READ ID

The READ ID command is used to find the present position of the recording heads. The 82078 stores the values from the first ID Field it is able to read into its registers. If the 82078 does not find an ID Address Mark on the diskette after the second occurrence of a pulse on the INDX# pin, it then sets the IC code in Status Register 0 to "01" (Abnormal termination), sets the MA bit in Status Register 1 to "1", and terminates the command.

The following commands will generate an interrupt upon completion. They do not return any result bytes. It is highly recommended that control commands be followed by the SENSE INTERRUPT STATUS command. Otherwise, valuable interrupt status information will be lost.

#### 6.2.2 RECALIBRATE

This command causes the read/write head within the 82078 to retract to the track 0 position. The 82078 clears the contents of the PCN counter, and checks the status of the TRK0 pin from the FDD. As long as the TRK0 pin is low, the DIR pin remains 0 and step pulses are issued. When the TRK0 pin goes high, the SE bit in Status Register 0 is set to "1", and the command is terminated. If the TRK0 pin is still low after 79 step pulses have been issued, the 82078 sets the SE and the EC bits of Status Register 0 to "1", and terminates the command. Disks capable of handling more than 80 tracks per side may require more than one RECALIBRATE command to return the head back to physical Track 0.

The RECALIBRATE command does not have a result phase. SENSE INTERRUPT STATUS command must be issued after the RECALIBRATE command to effectively terminate it and to provide verification of the head position (PCN). During the command phase of the recalibrate operation, the 82078 is in the BUSY state, but during the execution phase it is in a NON BUSY state. At this time another RECALI-BRATE command may be issued, and in this manner, parallel RECALIBRATE operations may be done on up to 4 drives at once.

Upon power up, the software must issue a RECALI-BRATE command to properly initialize all drives and the controller.

#### 6.2.3 DRIVE SPECIFICATION COMMAND

The 82078 uses two pins, DRVDEN0 and DRVDEN1 to select the density for modern drives. These signals inform the drive of the type of diskette in the drive. The Drive Specification command specifies the polarity of the DRVDEN0 and DRVDEN1 pins. It also enables or disables DSR programmed precompensation.

This command removes the need for a hardware workaround to accommodate differing specifications among drives. By programming this command during BIOS's POST routine, the floppy disk controller will internally configure the correct values for DRVDEN0 and DRVDEN1 with corresponding precompensation value and data rate table enabled for the particular type of drive.

This command is protected from software resets. After executing the DRIVE SPEC command, subsequent software resets will not clear the programmed parameters. Only another DRIVE SPEC command or H/W reset can reset it to default values. The 6 LSBs of the last byte of this command are reserved for future use.

The DRATE0 and DRATE1 are values as programmed in the DSR register. The DENSEL is high for high data rates (1 Mbps and 500 Kbps) and low for low data rates (300 Kbps and 250 Kbps).

Table 6-13 describes the drives that are supported with the DT0, DT1 bits of the Drive Specification command:

## int<sub>el</sub>.

| DTO | DT1 | Data Rate | DRVDEN0 | DRVDEN1 |
|-----|-----|-----------|---------|---------|
|     |     | 1 Mbps    | 1       | 1       |
| 0*  | 0*  | 500 Kbps  | 1       | 0       |
| 0.  | 0.  | 300 Kbps  | 0       | 1       |
|     |     | 250 Kbps  | 0       | 0       |
|     |     | 1 Mbps    | 1       | 1       |
| 0   |     | 500 Kbps  | 0       | 0       |
| 0   | 1   | 300 Kbps  | 0       | 1       |
|     |     | 250 Kbps  | 1       | 0       |
|     |     | 1 Mbps    | 0       | 1       |
| ·   | 0   | 500 Kbps  | 0       | 0       |
| ł.  | U   | 300 Kbps  | 1       | 1       |
|     |     | 250 Kbps  | 1       | 0       |
|     |     | 1 Mbps    | 1       | 1       |
| 4   | 4   | 500 Kbps  | 0       | 0       |
| I   |     | 300 Kbps  | 1       | 0       |
|     |     | 250 Kbps  | 0       | 1       |

### DRVDENn Polarities for AT/EISA Mode (IDENT0, IDENT1 = 11)

(\*) Denotes the default setting

#### DRVDEN Polarities for PS/2, Model 30 Mode (IDENT0, IDENT1 = 0X)

| DT0 | DT1 | Data Rate | DRVDENO | DRVDEN1  |
|-----|-----|-----------|---------|----------|
|     |     | 1 Mbps    | 1       | 1        |
| 0*  | 0*  | 500 Kbps  | 0       | 0        |
|     | 0.  | 300 Kbps  | 1       | 0        |
|     |     | 250 Kbps  | 0       | 1        |
|     |     | 1 Mbps    | 1       | 1 5      |
| о   | 1   | 500 Kbps  | 1       | 0        |
| 0   |     | 300 Kbps  | 0       | 1        |
|     |     | 250 Kbps  | 0       | 0        |
|     |     | 1 Mbps    | 0       | 1        |
| 4   | 0   | 500 Kbps  | 0       | 0        |
| I   | 0   | 300 Kbps  | 1       | 1        |
|     |     | 250 Kbps  | 1       | 0        |
|     |     | 1 Mbps    | 1       | 1        |
|     |     | 500 Kbps  | 0       | 0        |
| I   |     | 300 Kbps  | 0       | 1        |
|     |     | 250 Kbps  | 1       | <b>0</b> |

(\*) Denotes the default setting

#### 6.2.4 SEEK

The read/write head within the drive is moved from track to track under the control of the SEEK Command. The 82078 compares the PCN which is the current head position with the NCN and performs the following operation if there is a difference:

- PCN < NCN: Direction signal to drive set to "1" (step in), and issues step pulses.
- PCN > NCN: Direction signal to drive set to "0" (step out), and issues step pulses.

The rate at which step pulses are issued is controlled by SRT (Stepping Rate Time) in the SPECIFY command. After each step pulse is issued, NCN is compared against PCN, and when NCN = PCN, then the SE bit in Status Register 0 is set to "1", and the command is terminated.

During the command phase of the seek or recalibrate operation, the 82078 is in the BUSY state, but during the execution phase it is in the NON BUSY state.

Note that if implied seek is not enabled, the read and write commands should be preceded by:

- 1. SEEK command; Step to the proper track
- 2. SENSE INTERRUPT STATUS command; Terminate the Seek command
- 3. READ ID. Verify head is on proper track
- 4. Issue READ/WRITE command.

The SEEK command does not have a result phase. Therefore, it is highly recommended that the SENSE INTERRUPT STATUS Command be issued after the SEEK command to terminate it and to provide verification of the head position (PCN). The H bit (Head Address) in ST0 will always return a "0". When exiting DSR POWERDOWN mode, the 82078 clears the PCN value and the status information to zero. Prior to issuing the DSR POWERDOWN command, it is highly recommended that the user service all pending interrupts through the SENSE INTERRUPT STATUS command.

#### 6.2.5 SCAN COMMANDS

The SCAN Commands allow data which is being read from the diskette to be compared against data which is being supplied from the main system (Processor in NON-DMA mode, and DMA Controller in DMA mode). The FDC compares the data on a byte-by-byte basis, and looks for a sector of data which meets the conditions of D<sub>FDD</sub> = D<sub>Processor</sub>, D<sub>FDD</sub>  $\leq$  D<sub>Processor</sub>, or D<sub>FDD</sub>  $\geq$  D<sub>Processor</sub>. Ones complement arithmetic is used for comparison (FF = largest number, 00 = smallest number). After a whole

sector of data is compared, if the conditions are not met, the sector number is incremented ( $R + STP \rightarrow R$ ), and the scan operation is continued. The scan operation continues until one of the following conditions occur; the conditions for scan are met (equal, low, or high), the last sector on the track is reached (EOT), or the terminal count signal is received.

If the conditions for scan are met then the FDC sets the SH (Scan Hit) flag of Status Register 2 to a 1 (high), and terminates the Scan Command. If the conditions for scan are not met between the starting sector (as specified by R) and the last sector on the cylinder (EOT), then the FDC sets the SN (Scan Not Satisfied) flag of Status Register 2 to a 1 (high), and terminates the Scan Command. The receipt of a TERMINAL COUNT signal from the Processor or DMA Controller during the scan operation will cause the FDC to complete the comparison of the particular byte which is in process, and then to terminate the command. Table 6-9 shows the status of bits SH and SN under various conditions of SCAN.

If the FDC encounters a Deleted Data Address Mark on one of the sectors (and SK = 0), then it regards the sector as the last sector on the cylinder, sets CM (Control Mark) flag of Status Register 2 to a 1 (high) and terminates the command. If SK = 1, the FDC skips the sector with the Deleted Address Mark, and reads the next sector. In the second case (SK = 1), the FDC sets the CM (Control Mark) flag of Status Register 2 to a 1 (high) in order to show that a Deleted Sector has been encountered.

When either the STP (contiguous sectors STP = 01, or alternate sectors STP = 02 sectors are read) or the MT (Multi-Track) are programmed, it is necessary to remember that the last sector on the track must be read. For example, if STP = 02, MT = 0, the sectors are numbered sequentially 1 through 26, and we start the Scan Command at sector 21; the following will happen. Sectors 21, 23, and 25 will be read, then the next sector (26) will be skipped and the Index Hole will be encountered before the EOT value of 26 can be read. This will result in an abnormal termination of the command. If the EOT had been set at 25 or the scanning started at sector 20, then the Scan Command would be completed in a normal manner.

During the Scan Command data is supplied by either the processor or DMA Controller for comparison against the data read from the diskette. In order to avoid having the OR (Over Run) flag set in Status Register 1, it is necessary to have the data available in less than 13  $\mu$ s. If an Overrun occurs the FDC terminates the command.

| Table 6- 13. Scall Status Codes |            |            |                                           |  |  |  |
|---------------------------------|------------|------------|-------------------------------------------|--|--|--|
| Command                         | Status R   | Oommonto   |                                           |  |  |  |
| Command                         | Bit 2 = SN | Bit 3 = SH | Comments                                  |  |  |  |
| Scan Equal                      | 0          | 1          | $D_{FDD} = D_{Processor}$                 |  |  |  |
|                                 | 1          | 0          | $D_{FDD} \neq D_{Processor}$              |  |  |  |
| Scan Low or Equal               | 0          | 1          | D <sub>FDD</sub> = D <sub>Processor</sub> |  |  |  |
|                                 | 0          | 0          | D <sub>FDD</sub> < D <sub>Processor</sub> |  |  |  |
|                                 | 1          | 0          | D <sub>FDD</sub> ≯ D <sub>Processor</sub> |  |  |  |
| Scan High or Equal              | 0          | 1          | D <sub>FDD</sub> = D <sub>Processor</sub> |  |  |  |
|                                 | 0          | 0          | D <sub>FDD</sub> > D <sub>Processor</sub> |  |  |  |
|                                 | 1          | 0          | D <sub>FDD</sub> ≮ D <sub>Processor</sub> |  |  |  |

#### Table 6-13. Scan Status Codes

#### 6.2.6 SENSE INTERRUPT STATUS

An interrupt signal on INT pin is generated by the 82078 for one of the following reasons:

- 1. Upon entering the Result Phase of:
  - a. READ DATA Command
  - b. READ TRACK Command
  - c. READ ID Command
  - d. READ DELETED DATA Command
  - e. WRITE DATA Command
  - f. FORMAT TRACK Command
  - g. WRITE DELETED DATA Command
  - h. VERIFY Command
- 2. End of SEEK, RELATIVE SEEK or RECALI-BRATE Command
- 3. 82078 requires a data transfer during the execution phase in the non-DMA Mode

The SENSE INTERRUPT STATUS command resets the interrupt signal and via the IC code and SE bit of Status Register 0, identifies the cause of the interrupt. If a SENSE INTERRUPT STATUS command is issued when no active interrupt condition is present, the status register ST0 will return a value of 80H (invalid command).

**Table 6-14. Interrupt Identification** 

| SE | IC | Interrupt Due To                                       |
|----|----|--------------------------------------------------------|
| 0  | 11 | Polling                                                |
| 1  | 00 | Normal Termination of SEEK or<br>RECALIBRATE command   |
| 1  | 01 | Abnormal Termination of SEEK or<br>RECALIBRATE command |

The SEEK, RELATIVE SEEK and the RECALI-BRATE commands have no result phase. SENSE INTERRUPT STATUS command must be issued immediately after these commands to terminate them and to provide verification of the head position (PCN). The H (Head Address) bit in ST0 will always return a "0". If a SENSE INTERRUPT STATUS is not issued, the drive will continue to be BUSY and may effect the operation of the next command.

#### 6.2.7 SENSE DRIVE STATUS

SENSE DRIVE STATUS obtains drive status information. It has no execution phase and goes directly to the result phase from the command phase. STATUS REGISTER 3 contains the drive status information.

#### 6.2.8 SPECIFY

The SPECIFY command sets the initial values for each of the three internal timers. The HUT (Head Unload Time) defines the time from the end of the execution phase of one of the read/write commands to the head unload state. The SRT (Step Rate Time) defines the time interval between adjacent step pulses. Note that the spacing between the first and second step pulses may be shorter than the remaining step pulses. The HLT (Head Load Time) defines the time between the command phase to the execution phase of a read/write data command. The Head Unload Time (HUT) timer starts at the end of the execution phase to the beginning of the result phase of a read/write command. The values change with the data rate speed selection and are documented in Table 6-15.

#### Table 6-15. Drive Control Delays (ms)

|   | HUT |      |      |      |     | 5        | RT   |      |
|---|-----|------|------|------|-----|----------|------|------|
|   | 1M  | 500K | 300K | 250K | 1M  | 500K     | 300K | 250K |
| 0 | 128 | 256  | 426  | 512  | 8.0 | 16       | 26.7 | 32   |
| 1 | . 8 | 16   | 26.7 | 32   | 7.5 | 15       | 25   | 30   |
| — | -   | —    |      |      | —   | <u> </u> |      | -    |
| A | 80  | 160  | 267  | 320  | 3.0 | 6.0      | 10.2 | 12   |
| В | 88  | 176  | 294  | 352  | 2.5 | 5.0      | 8.35 | 10   |
| C | 96  | 192  | 320  | 384  | 2.0 | 4.0      | 6.68 | 8    |
| D | 104 | 208  | 346  | 416  | 1.5 | 3.0      | 5.01 | 6    |
| E | 112 | 224  | 373  | 448  | 1.0 | 2.0      | 3.33 | 4    |
| F | 120 | 240  | 400  | 480  | 0.5 | 1.0      | 1.67 | 2    |

|      |            | HLT  |      |      |
|------|------------|------|------|------|
|      | 1 <b>M</b> | 500K | 300K | 250K |
| 00   | 128        | 256  | 426  | 512  |
| 01   | 1          | 2    | 3.3  | 4    |
| 02   | 2          | 4    | 6.7  | 8    |
| _ 1  | · _        |      | _    | _    |
| 7E   | 126        | 252  | 420  | 504  |
| 7F . | 127        | 254  | 423  | 508  |

The choice of DMA or NON-DMA operations is made by the ND bit. When this bit is "1", the NON-DMA mode is selected, and when ND is "0", the DMA mode is selected. In DMA mode, data transfers are signalled by the DRQ pin. Non-DMA mode uses the RQM bit and the INT pin to signal data transfers.

#### 6.2.9 CONFIGURE

Issue the configure command to enable features like the programmable FIFO and set the beginning track for pre-compensation. A CONFIGURE command need not be issued if the default values of the 82078 meet the system requirements. The CLK48 bit allows the 82078 to connect to a 48 MHz oscillator, this can reduce board space if there is a 48 MHz signal already available on the system.

#### CONFIGURE DEFAULT VALUES:

- EIS No Implied Seeks
- EFIFO ---- FIFO Disabled
- POLL Polling Enabled
- FIFOTHR FIFO Threshold Set to 1 Byte
- PRETRK Pre-Compensation Set to Track 0

**EIS**—Enable implied seek. When set to "1", the 82078 will perform a SEEK operation before executing a read or write command. Defaults to no implied seek.

**EFIFO**—A "1" puts the FIFO into the 8272A compatible mode where the FIFO is disabled. This means data transfers are asked for on a byte by byte basis. Defaults to "1", FIFO disabled. The threshold defaults to one.

**POLL**—Disable polling of the drives. Defaults to "0", polling enabled. When enabled, a single interrupt is generated after a RESET. No polling is performed while the drive head is loaded and the head unload delay has not expired.

**FIFOTHR**—The FIFO threshold in the execution phase of read or write commands. This is programmable from 1 byte to 16 bytes. Defaults to one byte. A "00" selects one byte, "0F" selects 16 bytes.

**PRETRK**—Pre-compensation start track number. Programmable from track 0 to 255. Defaults to track 0. A "00" selects track 0, "FF" selects 255.

**CLK48**—Default is "0", external clock is assumed to be 24 MHz. If a 48 MHz external oscillator is used the bit must be set high. Note that the 82078 does not support a 48 MHz crystal, only an external oscillator. For more information refer to the section about the 2 Mbps data rate. Note, this must be enabled first during the initialization routine of the POST if a 48 MHz oscillator is used.

#### 6.2.10 VERSION

The VERSION command checks to see if the controller is an enhanced type (82077, 82077AA, 82077SL) or the older type (8272A/765A). A value of 90H is returned as the result byte, defining an enhanced FDD controller is in use. No interrupts are generated.

#### 6.2.11 RELATIVE SEEK

The command is coded the same as for SEEK, except for the MSB of the first byte and the DIR bit.

DIR Head Step Direction Control.

| DIR | Action        |
|-----|---------------|
| 0   | Step Head Out |
| 1   | Step Head In  |

RCN Relative Cylinder Number that determines how many tracks to step the head in or out from the current track number.

The RELATIVE SEEK command differs from the SEEK command in that it steps the head the absolute number of tracks specified in the command instead of making a comparison against an internal register. The SEEK command is good for drives that support a maximum of 256 tracks. RELATIVE SEEKs cannot be overlapped with other RELATIVE SEEKs. Only one RELATIVE SEEK can be active at a time. Bit 4 of Status Register 0 (EC) will be set if RELATIVE SEEK attempts to step outward beyond Track 0.

As an example, assume that a floppy drive has 300 useable tracks and that the host needs to read track 300 and the head is on any track (0-255). If a SEEK

## int<sub>el</sub>.

command was issued, the head would stop at track 255. If a RELATIVE SEEK command was issued, the 82078 would move the head the specified number of tracks, regardless of the internal cylinder position register (but would increment the register). If the head had been on track 40 (D), the maximum track that the 82078 could position the head on using RELATIVE SEEK, would be 296 (D), the initial track, +256 (D). The maximum count that the head can be moved with a single RELATIVE SEEK command is 256 (D).

The internal register, PCN, would overflow as the cylinder number crossed track 255 and would contain 40 (D). The resulting PCN value is thus (NCN + PCN) mod 256. Functionally, the 82078 starts counting from 0 again as the track number goes above 255(D). It is the users responsibility to compensate 82078 functions (precompensation track number) when accessing tracks greater than 255. The 82078 does not keep track that it is working in an "extended track area" (greater than 255). Any command issued would use the current PCN value except for the RECALIBRATE command which only looks for the TRACK0 signal. RECALIBRATE would return an error if the head was farther than 79 due to its limitation of issuing a maximum 80 step pulses. The user simply needs to issue a second RECALIBRATE command. The SEEK command and implied seeks will function correctly within the 44 (D) track (299-255) area of the "extended track area". It is the users responsibility not to issue a new track position that would exceed the maximum track that is present in the extended area.

To return to the standard floppy range (0-255) of tracks, a RELATIVE SEEK would be issued to cross the track 255 boundary.

A RELATIVE SEEK can be used instead of the normal SEEK but the host is required to calculate the difference between the current head location and the new (target) head location. This may require the host to issue a READ ID command to ensure that the head is physically on the track that software assumes it to be. Different 82078 commands will return different cylinder results which may be difficult to keep track of with software without the READ ID command.

#### 6.2.12 DUMPREG

The DUMPREG command is designed to support system run-time diagnostics and application software development and debug. The command returns pertinent information regarding the internal status of the 82078. This can be used to verify the values initialized in the 82078.

#### 6.2.13 PERPENDICULAR MODE COMMAND

#### 6.2.13.1 About Perpendicular Recording Mode

An added capability of the 82078 is the ability to interface directly to perpendicular recording floppy drives. Perpendicular recording differs from the traditional longitudinal method by orienting the magnetic bits vertically. This scheme packs in more data bits for the same area.

#### 6.2.13.2 The Perpendicular Mode Command

The PERPENDICULAR MODE Command allows the system designers to designate specific drives as

| GAP | WGATE    | MODE                                       | VCO Low<br>Time after<br>Index Pulse | Length of<br>Gap2 Format<br>Field | Portion of Gap2<br>Written by Write<br>Data Operation | Gap2 VCO<br>Low Time for<br>Read Operations |
|-----|----------|--------------------------------------------|--------------------------------------|-----------------------------------|-------------------------------------------------------|---------------------------------------------|
| 0   | 0        | Conventional Mode                          | 33 Bytes                             | 22 Bytes                          | 0 Bytes                                               | 24 Bytes                                    |
| 0   | <b>1</b> | Perpendicular Mode<br>(500 Kbps Data Rate) | 33 Bytes                             | 22 Bytes                          | 19 Bytes                                              | 24 Bytes                                    |
| 1   | 0        | Reserved<br>(Conventional)                 | 33 Bytes                             | 22 Bytes                          | 0 Bytes                                               | 24 Bytes                                    |
| 1   | 1        | Perpendicular Mode<br>(1 Mbps Data Rate)   | 18 Bytes                             | 41 Bytes                          | 38 Bytes                                              | 43 Bytes                                    |

#### Table 6-16. Effects of WGATE and GAP Bits

#### NOTE:

When either GAP or WGATE bit is set, the current value of precompensation in the DSR is used.

# intel.

Perpendicular recording drives. Data transfers between Conventional and Perpendicular drives are allowed without having to issue PERPENDICULAR MODE commands between the accesses of the two different drives, nor having to change write pre-compensation values.

With this command, the length of the Gap2 field and VCO enable timing can be altered to accommodate the unique requirements of these drives. Table 6-16 describes the effects of the WGATE and GAP bits for the PERPENDICULAR MODE command.

When both GAP and WGATE equal "0" the PER-PENDICULAR MODE command will have the following effect on the 82078: 1) If any of the new bits D0, D1, D2, and D3 are programmed to "1" the corresponding drive will automatically be programmed for Perpendicular mode (i.e.: GAP2 being written during a write operation, the programmed Data Rate will determine the length of GAP2), and data will be written with 0 ns write pre-compensation. 2) any of the new bits (D0-D3) that are programmed for "0" the designated drive will be programmed for Conventional Mode and data will be written with the currently programmed write pre-compensation value. 3) Bits D0, D1, D2, and D3 can only be over written when the OW bit is written as a "1". The status of these bits can be determined by interpreting the eighth result byte of the DUMPREG Command. (Note: if either the GAP or WGATE bit is a "1", then bits D0-D3 are ignored.)

"Software" and "Hardware" RESET will have the following effects on the enhanced PERPENDICU-LAR MODE command:

- "Software" RESETs (Reset via DOR or DSR registers) will only clear GAP and WGATE bits to "0", D3, D2, D1, and D0 will retain their previously programmed values.
- 2. "Hardware" RESETs (Reset via pin 32) will clear all bits (GAP, WGATE, D0, D1, D2, and D3) to "0" (All Drives Conventional Mode).

#### 6.2.14 POWERDOWN MODE COMMAND

The POWERDOWN MODE command allows the automatic power management and enables the enhanced registers (EREG EN) of the 82078. The use of the command can extend the battery life in portable PC applications. To enable auto powerdown the command may be issued during the BIOS power on self test (POST).

This command includes the ability to configure the 82078 into the enhanced AT/EISA and PS/2 mode. In the enhanced PS/2 and Model 30 modes, this makes the PD and IDLE pin status visible in the DIR

register. In the enhanced AT/EISA modes, this command extends the SRB and TDR register. These extended registers accommodate bits that give more information about floppy drive interface, allow for boot drive selection, and identify the values of the PD and IDLE status.

As soon as the command is enabled, a 10 ms or a 0.5 sec. (5 ms or 0.25 with 2Mbps tape mode) minimum powerup timer is initiated depending on whether the MIN DLY bit is set to 0 or 1. This timer is one of the required conditions that has to be satisfied before the part will enter auto powerdown. Any software reset will reinitialize the timer. The timer countdown is also extended by up to 10 ms if the data rate is changed during the timer's countdown. Without this timer 82078 would have been put to sleep immediately after 82078 is idle. The minimum delay gives software a chance to interact with 82078 without incurring an additional overhead due to recovery time.

The command also allows the output pins of floppy disk drive interface to be tri-stated or left unaltered during auto powerdown. This is done by the FDI TRI bit. In the default condition (FDI TRI=0) the output pins of the floppy disk drive are tri-stated. Setting this bit leaves the interface unchanged from the normal state.

The results phase returns the values programmed for MIN DLY, FDI TRI and AUTO PD. The auto powerdown mode is disabled by a hardware reset. Software results have no effect on the POWERDOWN MODE command parameters.

#### 6.2.15 PART ID COMMAND

This command can be used to identify the floppy disk controller as an enhanced controller. The first stepping of both versions of the 64 pin 82078 will yield 0x01 in the result phase of this command. Any future enhancements on these parts will be denoted by the 5 LSBs (0x01 to 0x1F).

#### 6.2.16 OPTION COMMAND

The standard IBM format includes an index address field consisting of 80 bytes of GAP 4a, 12 bytes of the sync field, four bytes identifying the IAM and 50 bytes of GAP 1. Under the ISO format most of this preamble is not used. The ISO format allows only 32 bytes of GAP 1 after the index mark. The ISO bit in this command allows the 82078 to configure the data transfer commands to recognize this format. The MSBs in this command are reserved for any other enhancements made available to the user in the future.

#### 6.2.17 SAVE COMMAND

The first byte corresponds to the values programmed in the DSR with the exception of CLK48. The DRATE1, DRATE0 used here are unmapped. The second byte is used for configuring the bits from the OPTION command. All future enhancements to the OPTION command will be reflected in this byte as well. The next nine result bytes are explained in the Parameter Abbreviations section after the command summary. The 13th byte is the value associated with the auto powerdown command. The disk status is used internally by 82078. There are two reserved bytes at the end of this command for future use.

This command is similar to the DUMPREG command but it additionally allows the user to read back the precompensation values as well as the programmed data rate. It also allows the user to read the values programmed in the auto powerdown command. The precompensation values will be returned as programmed in the DSR register. This command is used in conjunction with the Restore command should prove very useful for SMM power management. This command reserves the last two bytes for future enhancements.

#### 6.2.18 RESTORE COMMAND

Using Restore with the Save command, allows the SMM power management to restore the 82078 to its original state after a system powerdown. It also serves as a succinct way to provide most of the initialization requirements normally handled by the system. The sequence of initializing the 82078 after a reset occurred and assuming a Save command was issued follows:

- Issue the Drive Spec command (if the design utilizes this command)
- Issue the Restore command (pass the 16 bytes retrieved previously during SAVE)

The Restore command will program the data rate and precompensation value via the DSR. It then restores the values normally programmed through the Configure, Specify, and Perpendicular commands. It also enables the previously selected values for the AUTO Powerdown command. The PCN values are set restored to their previous values and the user is responsible for issuing the seek and recalibrate commands to restore the head to the proper location. There are some drives that do not recalibrate in which case the Restore command will restore the previous state completely. The PDOSC bit is retrievable using the Save command, however, the system designer must set it correctly. The software must allow at least 20  $\mu s$  to execute the Restore command. When using the BOOTSEL bits in the TDR, the user must restore or reinitialize these bits to their proper values.

#### 6.2.19 FORMAT AND WRITE COMMAND

The format and write command is capable of simultaneously formatting and writing data to the diskette. It is essentially the same as the normal format command. With the exception that included in the execution for each sector is not only the C, H, R, and N but also the data transfer of N bytes. The D value is ignored. This command formats the entire track. High speed floppy diskette duplication can be done fast and efficiently with this command. The user can format the diskette and put data on it in a single pass. This is very useful for software duplication applications by reducing the time required to format and copy diskettes.

#### 6.2.20 LOCK

The LOCK command is included to protect a system with long DMA latencies against older application software packages that can disable the 82078's FIFO.

#### NOTE:

This command should only be used by the system's FDC routines, and ISVs (Independent Software Vendors) should refrain from using it. If an ISV's application calls for having the 82078 FIFO disabled a CONFIGURE Command should be used to toggle the EFIFO (Enable FIFO) bit. ISV can determine the value of the LOCK bit by interpreting the eighth result byte of an DUMPREG Command.

The LOCK command defines whether EFIFO, FIFOTHR, and PRETRK parameters of the CON-FIGURE command can be RESET by the DOR and DSR registers. When the LOCK bit is set to a "1" all subsequent "software" RESETs by the DOR and DSR registers will not change the previously set parameter values in the CONFIGURE command. When the LOCK bit is set to a "0" 'software" RESETs by the DOR or DSR registers will return these parameters to their default values. All "hardware" Resets will set the LOCK bit to a "0" value, and will return EFIFO, FIFOTHR, and PRETRK to their default values. A Status byte is returned immediately after issuing the command byte. This Status byte reflects the value of the Lock bit set by the command byte.

#### NOTE:

No interrupts are generated at the end of this command.

## 7.0 STATUS REGISTER ENCODING

The contents of these registers are available only through a command sequence.

| Bit<br>No. | Symbol | Name               | Description                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|------------|--------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 7,6        | IC     | Interrupt<br>Code  | 00—Normal termination of command. The specified command was<br>properly executed and completed without error.<br>01—Abnormal termination of command. Command execution was started,<br>but was not successfully completed.<br>10—Invalid command. The requested command could not be executed.<br>11—Abnormal termination caused by Polling. |  |  |  |
| 5          | SE     | Seek End           | The 82078 completed a SEEK or RECALIBRATE command, or a READ or WRITE with implied seek command.                                                                                                                                                                                                                                             |  |  |  |
| 4          | EC     | Equipment<br>Check | The TRK0 pin failed to become a "1" after:<br>1. 80 step pulses in the RECALIBRATE command.<br>2. The RELATIVE SEEK command causes the 82078 to step outward<br>beyond Track 0.                                                                                                                                                              |  |  |  |
| 3          | _      | -                  | Unused. This bit is always "0".                                                                                                                                                                                                                                                                                                              |  |  |  |
| 2          | н      | Head Address       | The current head address.                                                                                                                                                                                                                                                                                                                    |  |  |  |
| 1, 0       | DS1, 0 | Drive Select       | The current selected drive.                                                                                                                                                                                                                                                                                                                  |  |  |  |

## 7.1 Status Register 0

## 7.2 Status Register 1

| Bit<br>No. | Symbol | Name                    | Description                                                                                                                                                                                                                                                                      |  |
|------------|--------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 7          | EN     | End of<br>Cylinder      | The 82078 tried to access a sector beyond the final sector of the track (255D). Will be set if TC is not issued after Read or Write Data Command.                                                                                                                                |  |
| 6          | _      |                         | Unused. This bit is always "0".                                                                                                                                                                                                                                                  |  |
| 5          | DE     | Data Error              | The 82078 detected a CRC error in either the ID field or the data field of a sector.                                                                                                                                                                                             |  |
| 4          | OR     | Overrun/<br>Underrun    | Becomes set if the 82078 does not receive CPU or DMA service within the required time interval, resulting in data overrun or underrun.                                                                                                                                           |  |
| 3          |        | —                       | Unused. This bit is always "0".                                                                                                                                                                                                                                                  |  |
| 2          | ND     | No Data                 | Any one of the following:<br>1. READ DATA, READ DELETED DATA command, the 82078 did not find<br>the specified sector.<br>2. READ ID command, the 82078 cannot read the ID field without an error.<br>3. READ TRACK command, the 82078 cannot find the proper sector<br>sequence. |  |
| 1          | NW     | Not Writable            | WP pin became a "1" while the 82078 is executing a WRITE DATA, WRITE DELETED DATA, or FORMAT TRACK command.                                                                                                                                                                      |  |
| 0          | MA     | Missing<br>Address Mark | Any one of the following:<br>1. The 82078 did not detect an ID address mark at the specified track after<br>encountering the index pulse from the INDX # pin twice.<br>2. The 82078 cannot detect a data address mark or a deleted data<br>address mark on the specified track.  |  |

## 7.3 Status Register 2

| Bit<br>No. | Symbol | Name                         | Description                                                                                                                                                                                                                          |
|------------|--------|------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          |        | _                            | Unused. This bit is always "0".                                                                                                                                                                                                      |
| 6          | СМ     | Control Mark                 | Any one of the following:<br>1. READ DATA command, the 82078 encounters a deleted data<br>address mark.<br>2. READ DELETED DATA command, the 82078 encountered a data<br>address mark.                                               |
| 5          | DD     | Data Error<br>in Data Field  | The 82078 detected a CRC error in the data field.                                                                                                                                                                                    |
| 4          | WC     | Wrong<br>Cylinder            | The track address from the sector ID field is different from the track address maintained inside the 82078.                                                                                                                          |
| 3          | _      | —                            | Unused. This bit is always "0".                                                                                                                                                                                                      |
| 2          |        |                              | Unused. This bit is always "0".                                                                                                                                                                                                      |
| 1          | BC     | Bad Cylinder                 | The track address from the sector ID field is different from the track<br>address maintained inside the 82078 and is equal to FF hex which<br>indicates a bad track with a hard error according to the IBM soft-<br>sectored format. |
| 0          | MD     | Missing Data<br>Address Mark | The 82078 cannot detect a data address mark or a deleted data address mark.                                                                                                                                                          |

## 7.4 Status Register 3

| Bit<br>No. | Symbol | Name            | Description                                |
|------------|--------|-----------------|--------------------------------------------|
| 7          | _      |                 | Unused. This bit is always "0".            |
| 6          | WP     | Write Protected | Indicates the status of the WP pin.        |
| 5          |        | _               | Unused. This bit is always "1".            |
| 4          | то     | TRACK 0         | Indicates the status of the TRK0 pin.      |
| 3          | _ * *  |                 | Unused. This bit is always "1".            |
| 2          | HD     | Head Address    | Indicates the status of the HDSEL pin.     |
| 1, 0       | DS1,0  | Drive Select    | Indicates the status of the DS1, DS0 pins. |

### 8.0 COMPATIBILITY

The 82078 was designed with software compatibility in mind. It is a fully backwards compatible solution with the older generation 8272A and NEC765A/B disk controllers. The 82078 also implements onboard registers for compatibility with the Personal System/2s as well as PC/AT and PC/XT floppy disk controller subsystems. The 82078 is fully compatible with Intel's 386/486SL Microprocessor Superset. Upon reset, the 82078 samples IDENT0 and IDENT1 to determine PS/2, PC/AT or PS/2 Model 30 mode.

### 8.1 PS/2 vs AT vs Model 30 Mode

The 82078 operates in three different modes: PS/2, PC/AT, and Model 30. The 82078 is placed into the proper mode of operations upon Hardware RESET with the appropriate settings of the IDENT0 and IDENT1 pins.

### 8.2 Compatibility with the FIFO

The FIFO of the 82078 is designed to be transparent to non-FIFO disk controller software developed on the older generation 8272A standard. Operation of the 82078 FIFO can be broken down into two tiers of compatibility. For first tier compatibility, the FIFO is left in the default disabled condition upon a "Hardware" reset. In this mode the FIFO operates in a byte mode and provides complete compability with non-FIFO based software. For second tier compatibility, the FIFO is enabled via the CONFIGURE command. When the FIFO is enabled, it will temporarily enter a byte mode during the command and result phase of disk controller operation. This allows for compatible operation when interrogating the Main Status Register (MSR) for the purpose of transferring a byte at a time to or from the disk controller. For normal disk controller applications, the system designer can still take advantage of the FIFO for time critical data transfers during the execution phase and not create any conflicts with non-FIFO software during the command or result phase.

In some instances, use of the FIFO in any form has conflicted with certain specialized software. An example of a compatibility conflict using the FIFO is with software that monitors the progress of a data transfer during the execution phase. If the software assumed the disk controller was operating in a single byte mode and counted the number of bytes transferred to or from the disk controller to trigger some time dependent event on the disk media (i.e., head position over a specific data field), the same software will not have an identical time relationship if the FIFO is enabled. This is because the FIFO allows data to be queued up, and then burst transferred across the host bus. To accommodate software of this type, it is recommended that the FIFO be disabled.

## 8.3 Drive Polling

The 82078 supports the polling mode of the older generation 8272A. This mode is enabled upon a reset and can be disabled via the CONFIGURE command. This mode is supported for the sole purpose of providing backward compatibility with software that expects its presence.

The intended purpose of drive polling dates back to 8" drives as a means to monitor any change in status for each disk drive present in the system. Each of the drives is selected for a period of time and its READY signal sampled. After a delay, the next drive is selected. Since the 82078 does not support READY in this capacity (internally tied true), the polling sequence is only simulated and does not affect the drive select lines (DS0-DS3) when it is active. If enabled, it occurs whenever the 82078 is waiting for a command or during SEEKs and RE-CALIBRATEs (but not IMPLIED SEEKs). Each drive is assumed to be not ready after a reset and a "ready" value for each drive is saved in an internal register as the simulated drive is polled. An interrupt will be generated on the first polling loop because of the initial "not ready" status. This interrupt must be followed with a SENSE INTERRUPT STATUS command from the host to clear the interrupt condition for each of the four logical drives.

### 9.0 Programming Guidelines

Programming the 82078 is identical to any other 8272A compatible disk controller with the exception of some additional commands. For the new designer, it is useful to provide some guidelines on how to program the 82078. A typical disk operation involves more than issuing a command and waiting for the results. The control of the floppy disk drive is a low level operation that requires software intervention at different stages. New commands and features have been added to the 82078 to reduce the complexity of this software interface.

### 9.1 Command and Result Phase Handshaking

Before a command or parameter byte can be issued to the 82078, the Main Status Register (MSR) must be interrogated for a ready status and proper FIFO direction. A typical floppy controller device driver should contain a subroutine for sending command or



Figure 9-1. Send\_Byte Routine

parameter bytes. For this discussion, the routine will be called "Send\_byte" with the flowchart shown in Figure 9-1.

The routine loops until RQM is 1 and DIO is 0 indicating a ready status and FIFO direction is inward. If this condition is true, the 82078 is ready to accept a command or parameter byte. A timeout counter is used to insure software response within a reasonable amount of time in case of no response by the 82078. As a note, the programmer must be careful how the maximum delay is chosen to avoid unnecessary timeouts. For example, if a new command is issued when the 82078 is in the middle of a polling routine, the MSR will not indicate a ready status for the next parameter byte until the polling sequence completes the loop. This could cause a delay between the first and second bytes of up to 250 µs (@ 250 Kbps). If polling is disabled, this maximum delay is 175 µs. There should also be enough timeout margin to accommodate a shift of the software to a higher speed system. A timeout value that results in satisfactory operation on a 16 MHz CPU might fail when the software is moved to a system with a 25 MHz CPU. A recommended solution is to derive the timeout counter from a system hardware counter that is fixed in frequency from CPU clock to CPU clock.



Figure 9-2. Get\_Byte Routine

For reading result bytes from the 82078, a similar routine is used. Figure 9-2 illustrates the flowchart for the routine "Get\_byte". The MSR is polled until RQM is 1 and DIO is 1, which indicates a ready status and outward FIFO direction. At this point, the host can read a byte from the FIFO. As in the Send\_byte routine, a timeout counter should be incorporated in case of a disk controller lock-up condition. For example, if a disk was not inserted into the disk drive at the time of a read operation, the controller would fail to receive the index pulse and lockup since the index pulses are required for termination of the execution phase.

#### 9.2 Initialization

Initializing the 82078 involves setting up the appropriate configuration after a reset. Parameters set by the SPECIFY command are undefined after a system reset and will need to be reinitialized. CONFIG-URE command parameters default to a known state after a system reset but will need to be reinitialized if the system requirements are different from the default settings. This can be accomplished in two ways, either issue the individual commands, or issue the Restore command (assuming the Save command was issued). The Restore command is a succinct way to initialize the 82078, this is the preferable method if the system power management powers the 82078 on and off frequently. The flowchart for the recommended initialization sequence of the 82078 is shown in Figure 9-3.





Following a reset of the 82078, the Configuration Control Register (CCR) should be reinitialized for the appropriate data rate. An external reset via the RESET pin will cause the data rate and write precompensation values to default to 250 Kbps (10b) and 125 ns (000b) respectively. Since the 125 ns write precompensation value is optimal for the 5  $\frac{1}{4}$ " and 3  $\frac{1}{2}$ " disk drive environment, most applications will not require the value to be changed in the initialization sequence. As a note, a software reset issued via the DOR or DSR will not affect the data rate or write precompensation values. But it is recommended as a safe programming practice to always program the data rate after a reset, regardless of the type.

Since polling is enabled after a reset of the 82078, four SENSE INTERRUPT STATUS commands need to be issued afterwards to clear the status flags for each drive. The flowchart in Figure 9-3 illustrates how the software clears each of the four interrupt status flags internally queued by the 82078. It should be noted that although four SENSE INTERRUPT STATUS commands are issued, the INT pin is only active until the first SENSE INTERRUPT STATUS command is executed.

As a note, if the CONFIGURE command is issued within 250  $\mu$ s of the trailing edge of reset (@1 Mbps), the polling mode of the 82078 can be disabled before the polling initiated interrupt occurs. Since polling stops when the 82078 enters the command phase, it is only time critical up to the first byte of the CONFIGURE command. If disabled in time, the system software no longer needs to issue the four SENSE INTERRUPT STATUS commands to clear the internal interrupt flags normally caused by polling.

The CONFIGURE command should also be issued if the system requirements are different from the default settings. For example, the CONFIGURE command can be used to enable the FIFO, set the threshold, and enable Implied Seeks. The non-DMA mode flag, step rate (SRT), head load (HLT), and head unload times (HUT) programmed by the SPECIFY command do not default to a known state after a reset. This behavior is consistent with the 8272A and has been preserved here for compatibility. Thus, it is necessary to always issue a SPECIFY command in the initialization routine.

### 9.3 Recalibrates and Seeks

Commands that position the disk head are different from the typical READ/WRITE/FORMAT command in the sense that there is no result phase. Once a RECALIBRATE, SEEK, or RELATIVE SEEK command has been issued, the 82078 will return a ready status in the Main Status Register (MSR) and perform the head positioning operation as a background task. When the seek is complete, the 82078 will assert the INT signal to request service. A SENSE INTERRUPT STATUS command should then be asserted to clear the interrupt and read the status of the operation. Since the drive and motor enable signals are directly controlled through the Digital Output Register (DOR) on the 82078, a write to the DOR will need to precede the RECALIBRATE or SEEK command if the drive and motor is not already enabled. Figure 9-4 shows the flow chart for this operation.



Figure 9-4. Recalibrate and Seek Operations

## 9.4 Read/Write Data Operations

A read or write data operation requires several steps to complete successfully. The motor needs to be turned on, the head positioned to the correct cylinder, the DMA controller initialized, the read or write command initiated, and an error recovery scheme implemented. The flowchart in Figure 9-5 highlights a recommended algorithm for performing a read or write data operation.

Before data can be transferred to or from the diskette, the disk drive motor must be brought up to speed. For most 31/2'' disk drives, the spin-up time is 300 ms, while the 51/4'' drive usually requires about 500 ms due to the increased moment of inertia associated with the larger diameter diskette.

One technique for minimizing the motor spin-up delay in the read data case is to begin the read operation immediately after the motor is turned on. When the motor is not initially up to speed, the internal data separator will fail to lock onto the incoming data stream and report a failure in the status registers. The read operation is then repeated until successful status is obtained. There is no risk of a data integrity problem since the data field is CRC validated. But, it is not recommended to use this technique for the write data operation even though it requires successful reading of the ID field before the write takes place. The data separator performance of the 82078 is such that locking to the data stream could take place while the motor speed variation is still significant. This could result in errors when an attempt is made to read the disk media by other disk controllers that have a narrower incoming data stream frequency bandwidth.

After the motor has been turned on, the matching data rate for the media inserted into the disk drive should then be programmed to the 82078 via the Configuration Control Register (CCR). The 82078 is designed to allow a different data rate to be programmed arbitrarily without disrupting the integrity of the device. In some applications, it is required to automatically determine the recorded data rate of the inserted media. One technique for doing this is to perform a READ ID operation at each available data rate until a successful status is returned in the result phase.





135

If implied seeks are not enabled, the disk drive head must be positioned over the correct cylinder by executing a SEEK command. After the seek is complete, a head settling time needs to be asserted before the read or write operation begins. For most drives, this delay should be a minimum of 15 ms. When using implied seeks, the minimum head settling time can be enforced by the head load time (HLT) parameter designated in the SPECIFY command. For example, a HLT value of 8 will yield an effective head settling time of 16 ms for a programmed data rate of 500 Kbps. Of course if the head is already positioned over the correct cylinder, the head settling time does not need to be enforced.

The DMA controller is then initialized for the data transfer and the read or write command is executed. Typically the DMA controller will assert Terminal Count (TC) when the data transfer is complete. The 82078 will then complete the current data transfer and assert the INT signal signifying it has entered the result phase. The result phase can also be entered by the 82078 if an error is encountered or the last sector number equals the End of Track (EOT) parameter.

Based on the algorithm in Figure 9-5, if an error is encountered after reading the result bytes, two more retries are performed by reinitializing the DMA controller and re-issuing the read or write data command. A persisting failure could indicate the seek operation did not achieve proper alignment between the head and the track. The disk head should then be recalibrated and the seek repeated for a maximum of two more tries. Unsuccessful operation after this point should be reported as a disk failure to the operating system.

#### 9.5 Formatting

The disk formatting procedure involves positioning the head on each track and creating a fixed format field used for organizing the data fields. The flowchart in Figure 9-6 highlights the typical format procedure.

After the motor has been turned on and the correct data rate programmed, the disk head is recalibrated to track 0. The disk is then allowed to come up to speed via a 500 ms delay. It is important the disk speed has stabilized before the actual formatting to avoid any data rate frequency variations. Since the format fields contain critical information used by the data separator of the disk controller for synchronization purposes, frequency stability of the data stream is imperative for media interchangeability among different systems.

The ID field data created on the disk during the format process is provided by the DMA controller during the execution phase. The DMA controller is initialized to send the C, H, R and N values for each sector ID field. For example, to format cylinder 7, on head 1, with 9 sectors, and a sector size of 2 (512 bytes), the DMA controller should be programmed to transfer 36 bytes (9 sectors  $\times$  4 bytes per sector) with the following data field: 7,1,1,2, 7,1,2,2, 7,1,3,2, ... 7,1,9,2. Since the values provided to the 82078 during the execution phase of the format command are directly recorded as the ID fields on the disk, the data contents can be arbitrary. Some forms of copy protection have been implemented by taking advantage of this capability.



Figure 9-6. Formatting

After each head for a cylinder has been formatted, a seek operation to the next cylinder is performed and the format process is repeated. Since the FORMAT TRACK command does not have implied seek capability, the SEEK command must be used. Also, as discussed in Section 9.2, the head settling time needs to be adhered to after each seek operation.

### 9.6 Save and Restore

The Save and Restore commands were developed for portable systems that use zero-volt powerdown to conserve power. These systems turn off the V<sub>CC</sub> to most of the system and retain the system status in a specific location. In older floppy controller designs, in order for system designers to retrieve the floppy controller status, a lot of separate commands and register reads were required. The Save command stores the key status information in a single command, the Restore command restores this information with a single command. These commands can be integrated into the SMM module that is responsible for zero-volt powerdown.

The sequence of initializing the 82078 after a reset occurred and assuming a Save command was issued follows:

- Issue the Drive Spec command (if the design utilizes this command)
- · Issue the Restore command

The Restore command programs the data rate and precompensation value via the DSR. It then restores the values normally programmed through the Configure, Specify, and Perpendicular commands. It also enables the previously selected values for the AUTO Powerdown command. The command then restores the PCN values to its previous values. The user is responsible for issuing the seek and recalibrate commands to restore the head to the proper location. There are some drives that do not recalibrate in which case the Restore command will restore the previous state completely. The PDOSC bit is retrievable using the Save command, however it is up to the system designer to set it correctly. The software must allow at least 20 µs to execute the Restore command. When using the BOOTSEL bits in the TDR, the user must restore or reinitialize these bits to their proper values.

### 9.7 Verifies

In some applications, the sector data needs to be verified immediately after each write operation. One verify technique reinitializes the DMA controller to perform a read transfer or verify transfer (DACK# is asserted but not RD#) immediately after each write operation. Issue a read command to the disk controller and the resulting status indicates if the CRC validated the previously written data. This technique has the drawback of requiring additional software intervention by having to reprogram the DMA controller between each sector write operation. The 82078 supports this verify technique but also provides a VERIFY command that does not require the use of the DMA controller.

To verify a write data transfer or format track operation using the VERIFY command, the software simply issues the command with the same format as a READ DATA command but without the support of the DMA controller. The 82078 will then perform a disk read operation without a host data transfer. The CRC will be calculated for each sector read and compared against the value stored on the disk. When the VERIFY command is complete, the status register reports detected CRC errors.

### 9.8 Powerdown State and Recovery

The two power management modes coupled with the internal oscillator power management forms an important consideration for programming the 82078. The recovery of 82078 and the time it takes to achieve complete recovery depends on how 82078 is powered down and how it is awakened. The following sections describe all the programming concerns and subtleties involved in using power management features of the 82078.

#### 9.8.1 OSCILLATOR POWER MANAGEMENT

Section 4.1 covers the power management scheme involved in powering down of both an internal and an external oscillator. Both types of oscillators face drop out effects and require recovery times on the order of tens of milliseconds (this may be objectionable to some application software). This means that if the oscillator is powered down then it is imperative for the software to assure enough time for the oscillator to recover to a stable state. Oscillator power management must be controlled by the system software especially to maintain software transparency. In cases where the system goes into a standby mode (by user request or system time-out), the power management software can turn off the oscillator to conserve power. This can also be controlled in hardware using the Powerdown (PD) pin. Complete recovery from an oscillator powerdown state requires the software to turn on the oscillator sufficiently ahead of awakening the 82078.

#### 9.8.2 PART POWER MANAGEMENT

The part powerdown and wake up modes are covered in Section 4.2 in detail. This section is meant to address the programming concerns for the part (excluding the oscillator) during these modes.

#### 9.8.2.1 Powerdown Modes

For both types of powerdown modes—DSR powerdown and auto powerdown, if reset is used to exit the part from powerdown then the internal microcontroller will go through a standard sequence: register initialization followed after some delay by an interrupt.

## intel

Software transparency in auto powerdown mode is preserved by MSR retaining the value of 80H which indicates that the part is ready to receive a command. This feature allows the part to powerdown while maintaining its responsiveness to any application software.

The PD and IDLE status bits can be monitored via the Status Register B (SRB, enhanced AT/EISA mode) and in the Digital Input Register (DIR, PS/2 and Model 30). Since the IDLE pin stays high when the 82078 is in idle state, the IDLEMSK bit can be used to set the pin low again (as part of a power management routine).

#### 9.8.2.2 Wake Up Modes

Wake up from DSR powerdown results in the part being internally reset and all present status being lost. During DSR powerdown the RQM bit in the MSR is set. A software or hardware reset will wake up the part.

The case for wake up from auto powerdown is different. The BIOS and application software are very sensitive to delays involved in writing the first command bytes to the 82078. Most programs have short error time-outs in these cases. Such programs would not tolerate any floppy disk controller that was unable to receive the first byte of a command at any time. The following describes how 82078 uniquely sustains its software transparency during wake up sequences.

Prior to writing a command to 82078, it is first necessary to read the MSR to ensure that the 82078 is ready (RQM bit must be set) to receive the command. When the part detects a MSR read, it assumes that another command will follow and begins the wake up process. While the part is waking up it does not change the state of the MSR (MSR = 80H) and is able to receive the command in the FIFO. At this point one of the two following scenarios can occur.

No other command is sent subsequent to the MSR read. The part wakes up and initializes the minimum power up timer. Upon the expiration of this timer the part is once again put in powerdown state.

Another command follows the MSR read. If the command is sent during the part's recovery from powerdown, the part remembers the command, clears the RQM bit (to prevent further bytes being written) and acts on the command once it is fully awake.

If the MSR was not checked prior to writing of a command, the part will proceed as stated above with the RQM bit cleared and the command byte held until the internal microcontroller is ready. Writing the motor enable bits in DOR active will initiate the wake up sequence with RQM set high, ready to receive any command.

As it is clear from the above discussion, the immediate access to the floppy disk controller for the first command byte is vital to software transparency. The recovery of the part from powerdown may involve a delay after the first command byte has been issued. However, all programs have tolerance for the delay after the first command byte is issued. In a powered up chip, it is possible for the microcontroller to be in its "polling loop". As a result the tolerance for this delay provides an excellent window for recovery of the part.

#### **10.0 DESIGN APPLICATIONS**

## 10.1 Operating the 82078SL in a 3.3V Design

The design for 3.3V is the same as for 5.0V with two exceptions: The SEL3V# pin must be held low to select 3.3V operation, and the VCCF pin can be either 3.3V or 5.0V (VCCF can only be 5.0V when SEL3V# is high). The VCCF pin allows the controller to be operated in mixed (3.3V/5.0V) mode. For example, if the system operates at 3.3V and the floppy disk drive operate at 5.0V, the 82078 can be configured to operate at 3.3V with 5.0V available to the drive interface. See Figure 10-1 for a schematic.



140

int of

82078 64 PIN

### 10.2 Selectable Boot Drive

Generally a standard personal computer is configured with a 1.2 Mb 5.25" disk drive and a 1.44 or 2.88 Mb 3.5" disk drive. Usually the drive connects as "A:" and is the boot drive. At times the user may want to configure "B:" as the boot drive. Currently some BIOS' use a special implementation in software to accomplish this. The 82078 now offers this capability more efficiently by configuring the boot drives.

The 82078 allows for virtual drive designations. This is a result of allowing multiplexing the boot drive select and motor enable lines. This is shown in the Figure 10-2.

The DRIVE SEL1 and the DRIVE SEL2 bits in the DOR register decode internally to generate the signals DSn. The MEn signals generate directly from the DOR register. The DSn and MEn signals get mapped to actual FDSn and FDMEn pins based on the BOOTSELn bits (selected in the TDR register). The exact mapping of BOOTSEL vs. the FDSn and FDMEn pins is shown in the following table.

| BOOTSEL1 | BOOTSEL0 | Mapping:                                                                                                                                                                                            |
|----------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0        | 0        | $\begin{array}{rcl} DS0 & \rightarrow & FDS0, ME0 & \rightarrow & FDME0 \\ DS1 & \rightarrow & FDS1, ME1 & \rightarrow & FDME1 \\ DS2 & \rightarrow & FDS2, ME2 & \rightarrow & FDME2 \end{array}$  |
| 0        | 1        | $\begin{array}{ccc} DS0 & \rightarrow & FDS1, ME0 & \rightarrow & FDME1 \\ DS1 & \rightarrow & FDS0, ME1 & \rightarrow & FDME0 \\ DS2 & \rightarrow & FDS2, ME2 & \rightarrow & FDME2 \end{array}$  |
| 1        | 0        | $\begin{array}{cccc} DS0 & \rightarrow & FDS2, ME0 & \rightarrow & FDME2 \\ DS1 & \rightarrow & FDS1, ME1 & \rightarrow & FDME1 \\ DS2 & \rightarrow & FDS0, ME2 & \rightarrow & FDME0 \end{array}$ |
| 1        | 1        | Reserved                                                                                                                                                                                            |



Figure 10-2. Virtual Drive Configuration

The BOOTSELn bits allow users to multiplex the output drive signals allowing different drives to be the boot drive. The DSn and MEn bits are considered virtual designations since the DSn and MEn signals get remapped to different corresponding physical FDSn and FDMEn pins. In other words, once the BOOTSELn bits are configured for a non-default selection, all future references made to the controller will be assumed as virtual designations. For example, if BOOTSEL1, BOOTSEL0 = 10 then DOR[1:0] = 00 refers to drive 2 and FDS2, FDME2 lines will be activated. Also, if TAPESEL[1:0] = 10, then tape mode is selected whenever FDS0, FDME0 are selected. Note, due to the virtual designations TAPE-SEL[1:0] = 00 would never enable tape mode due to boot drive restrictions.

### 10.3 How to Disable the Native Floppy Controller on the Motherboard

There are occasions when the floppy controller designed onto the motherboard of a system needs to be disabled in order to operate another floppy controller on the expansion bus. This can be done without changing the BIOS or remapping the address of the floppy controller (provided there is a jumper, or another way to disable the chip select on the native controller).

Upon reset, the DOR register in the 82078 is set to 00H. If the CS# is left enabled during the POST, the DOR is set to 0CH, this enables the DMA GATE# bit in the DOR. When this bit is set the 82078 treats a DACK# and a RD# or WR# as an internal chip select (CS#). Bus contention will occur between the native controller and the auxiliary controller if the DMA GATE# bit becomes active, even if the CS# signal is not present. The proper way to disable the native floppy controller is to disable the CS# before the system is turned on. This will prevent the native controller from getting initialized. Another option is to map the native controller to a secondary address space, then disable the DMA GATE# via the DOR disabling the DMA GATE#. This assumes that the native controller is switchable to a secondary address space.

## 10.4 Replacing the 82077SL with a 82078 in a 5.0V Design

The 82078 easily replaces the 5.0V 82077SL with minimum design changes. With a few exceptions, most of the signals are named as they were in the 82077SL. Some pins were eliminated and other renamed to accommodate a reduced pin count and smaller package.

The connections to the AT bus are the same as the 82077SL with the following exceptions: MFM and IDENT have been replaced by IDENT1 and IDENT0. The PLL0 pin was removed. Configure the tape drive mode on the 82078 via the Tape Drive Register (TDR).

The Drive Interface on the 82078 is also similar to the 82077SL except as noted: DRVDEN0 and DRVDEN1 on the 82078 take the place of DENSEL, DRATE0, and DRATE1 on the 82077SL. The Drive Specification Command configures the polarity of these pins, thus selecting the density type of the drive. The Motor Enable pins (ME0-3) and the Drive Select pins (DS0-3) are renamed FDME(0-3) and FDS(0-3) respectively on the 82078. 10K pull-up resistors can be used on the disk interface. See Figure 10-3 for a schematic of the connection.



Figure 10-3. 82077SL Conversion to 82078-1

143

#### 82078 64 PIN

## intel

#### Pin Changes on the 64 Pin Part:

- INVERT# is removed
- 4 NC's (no connects) are removed
- MFM, IDENT pins on the 82077SL have been changed to IDENT1 and IDENT0 respectively.
- PLL0 pin, which allowed for H/W configuration of tape drive mode is no longer available. Tape mode can be configured via the TDR register.
- DENSEL, DRATE1, DRATE0 pins have been substituted by DRVDEN0, DRVDEN1. The Drive Specification command can be used to configure these pins for various requirements of drives available on the market.
- RDGATE has been added and can be used for diagnostics of the PLL.

- MEDID1, MEDID0 are new, they return media type information to the TDR register.
- DRVID1, DRVID0 return drive type information to the TDR register.
- SEL3V# selects between either 3.3V or 5V mode. Connecting the pin LOW selects 3.3V mode.
- 5 VSS pins, 2 VCC pins, 2 VSSP pins, 1 VCCF pin, and 1 AVCC and 1 AVSS pin.
- VCCF can be used to interface a 5.0V or a 3.3V drive to the 82078 (when SEL3V# is low).
- The Hardware RESET pulse width has changed from 170 times the oscillator period to 100 ns plus 25 times the oscillator period.

## int<sub>el</sub>.

## 11.0 D.C. SPECIFICATIONS

## 11.1 Absolute Maximum Ratings

| Storage Temperature   | −65°C to +150°C                 |
|-----------------------|---------------------------------|
| Supply Voltage        | -0.5V to +8.0V                  |
| Voltage on Any Input  | GND - 2V to 6.5V                |
| Voltage on Any Output | GND $-0.5V$ to $V_{CC}$ $+0.5V$ |
| Power Dissipation     | 1W                              |

## **11.2 D.C. Characteristics** $T_A = 0^{\circ}C$ to 70°C, $V_{SS} = AV_{SS} = 0V$

|                 |                                            | V              | $V_{CC} = +5V \pm 10\%$ |                            | V                     | /cc = 3.3V            | ± 0.3V                    |
|-----------------|--------------------------------------------|----------------|-------------------------|----------------------------|-----------------------|-----------------------|---------------------------|
| Symbol          | Parameter                                  | Min(V)         | Max(V)                  | Test<br>Conditions         | Min(V)                | Max(V)                | Test<br>Conditions        |
| VILC            | Input Low Voltage,<br>X1                   | -0.5           | 0.8                     | · ·                        | -0.3                  | 0.8                   |                           |
| VIHC            | Input High Voltage,<br>X1                  | 3.9            | V <sub>CC</sub> + 0.5   |                            | 2.4                   | V <sub>CC</sub> + 0.3 |                           |
| VIL             | Input Low Voltage<br>(all pins except X1)  | -0.5           | 0.8                     |                            | -0.3                  | 0.8                   |                           |
| VIH             | Input High Voltage<br>(all pins except X1) | 2.0            | V <sub>CC</sub> + 0.5   |                            | 2.0                   | V <sub>CC</sub> + 0.3 |                           |
| VOL             | System Interface                           |                | 0.4                     | l <sub>OL</sub> = 12 mA    |                       | 0.4                   | $I_{OL} = 6  \text{mA}$   |
|                 | FDD Interface<br>outputs                   |                | 0.4                     | I <sub>OL</sub> = 24 mA    |                       | 0.4                   | l <sub>OL</sub> = 12 mA   |
|                 | Status Outputs<br>(Note 6)                 |                | 0.4                     | I <sub>OL</sub> = 4 mA     | n an<br>Film          | 0.4                   | I <sub>OL</sub> = 4 mA    |
| V <sub>OH</sub> | All outputs                                | 3.0            |                         | $I_{OH} = -4.0 \text{ mA}$ | 2.4                   |                       | l <sub>OH</sub> = -2.0 mA |
|                 | All outputs                                | $V_{CC} - 0.4$ |                         | $I_{OH} = -100 \ \mu A$    | V <sub>CC</sub> - 0.2 |                       | I <sub>OH</sub> = −100 μA |

### 64 PIN D.C. CHARACTERISTICS

### 64 PIN D.C. CHARACTERISTICS (I<sub>CC</sub>)

|                  |                                                          | V       | $V_{CC} = +5V \pm 10\%$ |                    |        | $V_{CC} = 3.3V \pm 0.3V$ |                    |
|------------------|----------------------------------------------------------|---------|-------------------------|--------------------|--------|--------------------------|--------------------|
| Symbol           | Parameter                                                | Тур     | Max(A)                  | Test<br>Conditions | Тур    | Max(A)                   | Test<br>Conditions |
| ICC1             | 1 Mbps Data Rate<br>$V_{IL} = V_{SS}, V_{IH} = V_{CC}$   | 15.4 mA | 25 mA                   | (Notes 1, 2, 5)    | 8.4 mA | 16 mA                    | (Notes 1, 2)       |
| I <sub>CC2</sub> | 1 Mbps Data Rate $V_{IL} = 0.45V$ , $V_{IH} = 2.4V$      | 20.8 mA | 30 mA                   | (Notes 1, 2, 5)    | 8.6 mA | 16 mA                    | (Notes 1, 2)       |
| ICC3             | 500 Kbps Data Rate<br>$V_{IL} = V_{SS}, V_{IH} = V_{CC}$ | 11.8 mA | 20 mA                   | (Notes 1, 2)       | 6.2 mA | 14 mA                    | (Notes 1, 2)       |
| I <sub>CC4</sub> | 500 Kbps Data Rate $V_{IL} = 0.45V$ , $V_{IH} = 2.4V$    | 17.6 mA | 25 mA                   | (Notes 1, 2)       | 6.2 mA | 14 mA                    | (Notes 1, 2)       |
| ICCSB            | I <sub>CC</sub> in Powerdown                             | 0 μΑ    | 60 µA                   | (Notes 3, 4)       | 0 μΑ   | 60 µA                    | (Notes 3, 4)       |

### 64 PIN D.C. CHARACTERISTICS (ICC) (Continued)

|                 |                                     | $V_{CC} = +5V \pm 10\%$ |                 | $V_{CC} = 3.3V \pm 0.3V$                     |     |                  |                                           |
|-----------------|-------------------------------------|-------------------------|-----------------|----------------------------------------------|-----|------------------|-------------------------------------------|
| Symbol          | Parameter                           | Тур                     | Max(A)          | Test<br>Conditions                           | Тур | Max(A)           | Test<br>Conditions                        |
| ۱ <sub>۱۲</sub> | Input Load Current (all input pins) |                         | 10 µА<br>—10 µА | $V_{IN} = V_{CC}$<br>$V_{IN} = 0V$           |     | 10 μΑ<br>—10 μΑ  | $V_{IN} = V_{CC}$<br>$V_{IN} = 0V$        |
| OFL             | Data Bus Output<br>Float Leakage    |                         | ±10 μΑ          | 0.45 <<br>V <sub>OUT</sub> < V <sub>CC</sub> | :   | ±10 μA<br>±10 μA | 0.45 < V <sub>OUT</sub> < V <sub>CC</sub> |

#### NOTES:

1. Only the data bus inputs may float.

Only the data bus inputs may hoat.
 Tested while reading a sync field of "00". Outputs not connected to D.C. loads.
 V<sub>IL</sub> = V<sub>SS</sub>, V<sub>IH</sub> = V<sub>CC</sub>; Outputs not connected to D.C. loads.
 Typical value with the oscillator off.
 I<sub>CC</sub> for 2 Mbps Data Rate: Max 40 mA (TTL), 35 mA (CMOS) at 5.5V, typical 29.2 mA (TTL) and 24.4 (CMOS).
 Status outputs are PD, IDLE, and RDGATE.

### 64 PIN MIXED MODE D.C. CHARACTERISTICS

| Symbol          | Parameter                                                                             | $V_{\rm CC} = 3.3$    | / ±0.3V, V <sub>CCI</sub>        | $= +5V \pm 10\%$           |
|-----------------|---------------------------------------------------------------------------------------|-----------------------|----------------------------------|----------------------------|
| Symbol          | Parameter                                                                             | Min(V)                | Max(V)                           | <b>Test Conditions</b>     |
| VILC            | Input Low Voltage, X1                                                                 | -0.3                  | 0.8                              |                            |
| VIHC            | Input High Voltage, X1                                                                | 2.4                   | V <sub>CC</sub> + 0.3            |                            |
| VIL             | Input Low Voltage (system pins except X1)<br>(floppy drive interface pins)            | -0.3<br>-0.5          | 0.8<br>0.8                       |                            |
| V <sub>IH</sub> | Input High Voltage (system interface pins except X1)<br>(floppy drive interface pins) | 2.0<br>2.0            | $V_{CC} + 0.3$<br>$V_{CC} + 0.5$ |                            |
| V <sub>OL</sub> | System Interface                                                                      |                       | 0.4                              | l <sub>OL</sub> = 6 mA     |
|                 | FDD Interface outputs                                                                 |                       | 0.4                              | l <sub>OL</sub> = 24 mA    |
| V <sub>OH</sub> | All system outputs                                                                    | 2.4                   |                                  | $I_{OH} = -2.0 \text{ mA}$ |
|                 | All FDD interface outputs                                                             | 3.0                   | · .                              | $I_{OH} = -4.0 \text{ mA}$ |
|                 | All system outputs                                                                    | V <sub>CC</sub> - 0.2 |                                  | l <sub>OH</sub> = -100 μA  |
|                 | All FDD interface outputs                                                             | V <sub>CC</sub> - 0.4 |                                  | l <sub>OH</sub> = -100 μA  |

### CAPACITANCE

| C <sub>IN</sub>  | Input Capacitance        | 10 | pF | F = 1 MHz, T <sub>A</sub> = 25°C |
|------------------|--------------------------|----|----|----------------------------------|
| C <sub>IN1</sub> | Clock Input Capacitance  | 20 | рF | Sampled, not 100% Tested         |
| C <sub>I/O</sub> | Input/Output Capacitance | 20 | рF |                                  |

### NOTE:

All pins except pins under test are tied to AC ground.

### LOAD CIRCUIT



## 11.3 Oscillator





## A.C. TESTING INPUT, OUTPUT WAVEFORM



The 24 MHz clock can be supplied either by a crystal or a MOS level square wave. All internal timings are referenced to this clock or a scaled count which is data rate dependent.

The crystal oscillator must be allowed to run for 10 ms after  $V_{CC}$  has reached 4.5V or exiting the POWERDOWN mode to guarantee that it is stable.

| Frequency:         | 24 MHz ±0.1%          |
|--------------------|-----------------------|
| Mode:              | Parallel Resonant     |
|                    | Fundamental Mode      |
| Series Resistance: | Less than 40 $\Omega$ |
| Shunt Capacitance: | Less than 5 pF        |

## 12.0 A.C. SPECIFICATIONS

 $T_A$  = 0°C to 70°C,  $V_{CC}$  = +5V ±10%, +3.3V ±0.3V,  $V_{SS}$  = AV\_{SS} = 0V

| Symbol    | Parameter                             | Min                                    | Max      | Unit |
|-----------|---------------------------------------|----------------------------------------|----------|------|
| CLOCK TIM | INGS                                  |                                        | · · · ·  |      |
| t1        | Clock Rise Time                       |                                        | 10       | ns   |
|           | Clock Fall Time                       |                                        | 10       | ns   |
| t2        | Clock High Time <sup>(7)</sup>        | 16                                     | 26       | ns   |
| t3        | Clock Low Time <sup>(7)</sup>         | 16                                     | 26       | ns   |
| t4        | Clock Period                          | 41.66                                  | 41.66    | ns   |
| t5        | Internal Clock Period <sup>(3)</sup>  |                                        |          |      |
| HOST READ | CYCLES                                |                                        |          |      |
| t7 .      | Address Setup to RD#                  | 5                                      |          | ns   |
| t8        | RD# Pulse Width                       | 90                                     | - · · ·  | ns   |
| t9        | Address Hold from RD#                 | 0                                      |          | ns   |
| t10       | Data Valid from RD # (12)             |                                        | 80       | ns   |
| t11       | Command Inactive                      | 60                                     |          | ns   |
| t12       | Output Float Delay                    |                                        | 35       | ns   |
| t13       | INT Delay from RD# <sup>(16)</sup>    |                                        | t5 + 125 | ns   |
| t14       | Data Hold from RD#                    | 5                                      |          | ns   |
| HOST WRIT | E CYCLES                              | •••••••••••••••••••••••••••••••••••••• |          |      |
| t15       | Address Setup to WR#                  | 5                                      | · .      | ns   |
| t16       | WR # Pulse Width                      | 90                                     |          | ns   |
| t17       | Address Hold from WR#                 | 0                                      |          | ns   |
| t18       | Command Inactive                      | 60                                     |          | ns   |
| t19       | Data Setup to WR #                    | 70                                     |          | ns   |
| t20       | Data Hold from WR #                   | 0                                      |          | ns   |
| t21       | INT Delay from WR # (16)              |                                        | t5 + 125 | ns   |
| DMA CYCLE | ĒS                                    | · · · · · · · · · · · · · · · · · · ·  |          | •    |
| t22       | DRQ Cycle Period <sup>(1)</sup>       | 6.5                                    |          | μs   |
| t23       | DACK# to DRQ Inactive                 |                                        | 75       | ns   |
| t23a      | DRQ to DACK # Inactive                | (Note 15)                              |          | ns   |
| t24       | RD# to DRQ Inactive <sup>(4)</sup>    |                                        | 100      | ns   |
| t25       | DACK# Setup to RD#, WR#               | 5                                      |          | ns   |
| t26       | DACK # Hold from RD #, WR #           | 0                                      |          | ns   |
| t27       | DRQ to RD#, WR# Active <sup>(1)</sup> | 0                                      | 6        | μs   |
| t28       | Terminal Count Width <sup>(10)</sup>  | 50                                     |          | ns   |
| t29       | TC to DRQ Inactive                    |                                        | 150      | ns   |
| RESET     | Anna                                  | · · · · · · · · · · · · · · · · · · ·  |          |      |
| t30       | "Hardware" Reset Width <sup>(5)</sup> | 1.13                                   |          | μs   |
| t30a      | "Software" Reset Width <sup>(5)</sup> | (Note 11)                              |          | ns   |
| t31       | Reset to Control Inactive             |                                        | 2        | μs   |

## int<sub>el</sub>.

## A.C. SPECIFICATIONS

 $T_A$  = 0°C to 70°C,  $V_{CC}$  = +5V ±10%, +3.3V ±0.3V,  $V_{SS}$  = AV\_{SS} = 0V (Continued)

| Symbol     | Parameter                        | Min          | Max | Unit     |
|------------|----------------------------------|--------------|-----|----------|
| WRITE DATA | TIMING                           | • <u>•</u> • |     |          |
| t32        | Write Data Width <sup>(6)</sup>  |              |     | ns       |
| DRIVE CONT | ROL                              |              |     |          |
| t35        | DIR # Setup to STEP # (14)       | 1.0          |     | μs       |
| t36        | DIR # Hold from STEP #           | 10           |     | μs       |
| t37        | STEP# Active Time (High)         | 2.5          | -   | μs       |
| t38        | STEP # Cycle Time <sup>(2)</sup> |              |     | μs       |
| t39        | INDEX # Pulse Width              | 5            |     | t5       |
| t41        | WE# to HDSEL# Change             | (Note 13)    |     | ms       |
| READ DATA  | TIMING                           |              |     |          |
| t40        | Read Data Pulse Width            | 50           |     | ns       |
| t44        | 82078-1                          |              | 2M  | bits/sec |
| _          | 82078SL                          |              | 1M  | bits/sec |
| t44        | Data Rate Period = 1/f44         |              |     |          |
| tLOCK      | Lockup Time                      |              | 64  | t44      |

#### NOTES:

- 1. This timing is for FIFO threshold = 1. When FIFO threshold is N bytes, the value should be multiplied by N and subtract 1.5  $\mu$ s. The value shown is for 1 Mbps, scales linearly with data rate.
- 2. This value can range from 0.5 ms to 8.0 ms and is dependent upon data rate and the Specify command value.
- 3. Many timings are a function of the selected data rate. The nominal values for the internal clock period (t5) for the various data rates are:

2 Mbps 1.5x oscillator period = 62.5 ns

- 1 Mbps 3x oscillator period = 125 ns
- 500 Kbps 6x oscillator period = 250 ns
- 300 Kbps 10x oscillator period = 420 ns
- 250 Kbps 12x oscillator period = 500 ns
- 4. If DACK# transitions before RD#, then this specification is ignored. If there is no transition on DACK#, then this becomes the DRQ inactive delay.

5. Reset requires a stable oscillator to meet the minimum active period.

#### 82078 64 PIN

6. Based on the internal clock period (t5). For various data rates, the Write Data Width minimum values are:

- 2 Mbps 2.5x oscillator period -50 ns = 75 ns
- 1 Mbps 5x oscillator period -50 ns = 150 ns
- 500 Kbps 10x oscillator period -50 ns = 360 ns

300 Kbps 16x oscillator period -50 ns = 615 ns

250 Kbps 19x oscillator period -50 ns = 740 ns

7. Test points for clock high time are 3.5V. Due to transitional times, clock high time max and clock low time max cannot be met simultaneously. Clock high time min and clock low time max can not be met simultaneously.

8. Based on internal clock period (t5).

9. Jitter tolerance is defined as:

(Maximum bit shift from nominal position  $\div$  1/4 period of nominal data rate)  $\times$  100% is a measure of the allowable bit jitter that may be present and still be correctly detected. The data separator jitter tolerance is measured under dynamic conditions that jitters the bit stream according to a reverse precompensation algorithm.

10. TC width is defined as the time that both TC and DACK# are active. Note that TC and DACK# must overlap at least 50 ns.

11. The minimum reset active period for a software reset is dependent on the data rate, after the 82078 has been properly reset using the t30 spec. The minimum software reset period then becomes:

| 2 Mbps   | 1.5 x t4 = 62.5 ns |
|----------|--------------------|
| 1 Mbps   | 3 x t4 = 125 ns    |
| 500 Kbps | 6 x t4 = 250 ns    |
| 300 Kbps | 10 x t4 = 420 ns   |
| 250 Kbps | 12 x t4 = 500 ns   |

12. Status Register's status bits which are not latched may be updated during a Host read operation.

13. The minimum MFM values for WE to HDSEL change (t41) for the various data rates are:

| 2 Mbps     | 0.5 ms +      | [4 x GPL]      |
|------------|---------------|----------------|
| 1 Mbps     | 0.5 ms +      | [8 x GPL]      |
| 500 Kbps   | 1.0 ms +      | [16 x GPL]     |
| 300 Kbps   | 1.6 ms +      | [26.66 x GPL]  |
| 250 Kbps   | 2.0 ms +      | [32 x GPL]     |
| CDI is the | size of gen 2 | defined in the |

GPL is the size of gap 3 defined in the sixth byte of a Write Command.

14. This timing is a function of the selected data rate as follows:

 2 Mbps
 0.5 μs Min

 1 Mbps
 1.0 μs Min

 500 Kbps
 2.0 μs Min

 300 Kbps
 3.3 μs Min

250 Kbps 4.0 μs Min

- This timing is a function of the internal clock period (t5) and is given as (<sup>3</sup>/<sub>2</sub>) t5. The values of t5 are shown in Note 3.
   The timings t13 and t21 are specified for INT signal in the polling mode only. These timings in case of the result phase
- of the read and write commands are microcode dependent.

| Part Specification | 3.3V | 5.0V | 2 Mbps Data Rate |
|--------------------|------|------|------------------|
| 82078SL            | X    | X    |                  |
| 82078-1            | -    | X    | X                |

## 82078 64 PIN

## int<sub>el</sub>.







7







152





For overlapped seeks, only one step pulse per drive selection is issued. Non-overlapped seeks will issue all programmed step pulses.



## 12.1 Package Outline for the 64 QFP Part

The 82078 addresses the current need of the smaller and thinner packages, for the current market. The size of the part is becoming increasingly important in the portable computer market. The QFP part considerably reduces the real estate consumed. The package outline, with the appropriate dimensions is given below:



| Description    | Symbol | 64 QFP Package |                |  |
|----------------|--------|----------------|----------------|--|
| Description    |        | Nominal (mm)   | Tolerance (mm) |  |
| Overall Height | А      | 2.35           | ±0.20          |  |
| Stand Off      | A1     | 0.15           | ±0.10          |  |
| Lead Width     | В      | 0.30           | ±0.10          |  |
| Lead Thickness | C      | 0.15           | ± 0.05         |  |
| Terminal       | D      | 15.3           | ±0.40          |  |
| Long Side      | D1     | 12.0           | ±0.10          |  |
| Terminal       | E      | 15.3           | ±0.40          |  |
| Short Side     | E1     | 12.0           | ±0.10          |  |
| Lead Spacing   | e1     | 0.65           | ±0.12          |  |
| Lead Count     | N      | 64             | ·              |  |

## 13.0 REVISION HISTORY FOR THE 82078 64 PIN

The following list represents the key differences between version 002 and version 003 of the 82078 64 pin data sheet.

- Section 5.2.3 Redundant information removed.
- Section 5.2.4 Redundant information removed.
- Section 8.0 Description of IDENT0 and IDENT1 changed to clarify their function.
- Section 11.2 New Vol specification added for status pins.
- Table 6-2
   Data in table reordered to be consistent.

#### ALABAMA

Intel Corp. 600 Boulevard South Suite 104-I Huntsville 35802 Tel: (80) 628-8686 FAX: (205) 883-3511

#### ARIZONA

tintei Corp. 410 North 44th Street Suite 500 Phoenix 85008 Tel: (800) 628-8686 FAX: (602) 244-0446

#### CALIFORNIA

Intel Corp. 3550 Watt Avenue Suite 140 Sacramento 95821 Tel: (800) 628-8686 FAX: (916) 488-1473

†Intel Corp. 9655 Granite Ridge Dr. 3rd Floor, Suite 4A San Diego 92123 Tet: (800) 628-8686 FAX: (619) 467-2460

Intel Corp. 1781 Fox Drive San Jose 95131 Tel: (800) 628-8686 FAX: (408) 441-9540

\*†Intel Corp. 1551 N. Tustin Avenue Suite 800 Santa Ana 92701 Tel: (800) 628-8686 TWX: 910-595-1114 FAX: (714) 541-9157

tintei Corp. 15260 Ventura Boulevard Suite 360 Sherman Oaks 91403 Tel: (800) 628-8686 FAX: (818) 995-6624

#### COLORADO

\*†Intel Corp. 600 S. Cherry St. Suite 700 Denver 80222 Tel: (800) 628-8686 TWX: 910-931-2289 FAX: (303) 322-8670

#### CONNECTICUT

tintel Corp. 103 Mill Plain Road Danbury 06811 Tel: (800) 628-8686 FAX: (203) 794-0339

#### FLORIDA

†Intel Corp. 800 Fairway Drive Suite 160 Deerfield Beach 33441 Tel: (800) 628-8686 FAX: (305) 421-2444

Intel Corp. 2250 Lucien Way Suite 100, Room 8 Maitland 32751 Tel: (800) 628-8686 FAX: (407) 660-1283

†Sales and Service Office \*Field Application Location

## NORTH AMERICAN SALES OFFICES

GEORGIA tintel Corp. 20 Technology Parkway Suite 150 Norcross 30092 Tel: (800) 628-8686 FAX: (404) 605-9762

IDAHO Intel Corp. 9456 Fairview Ave., Suite C Boise 83704 Tel: (800) 628-8686 FAX: (208) 377-1052

ILLINOIS \*†Intel Corp. Woodfield Corp. Center III 300 N. Martingale Road Suite 400 Schaumburg 60173 Tel: (800) 628-8686 FAX: (708) 706-9762

INDIANA †Intel Corp. 8910 Purdue Road Suite 350 Indianapolis 46268 Tel: (800) 628-8686 FAX: (317) 875-8938

MARYLAND \*1Intel Corp. 10010 Junction Dr. Suite 200 Annapolis Junction 20701 Tel: (800) 628-8686 FAX: (410) 206-3678

#### MASSACHUSETTS

\*tintel Corp. Westford Corp. Center 5 Carliste Road 2nd Floor Westford 01886 Tel: (800) 628-8686 TWX: 710-343-6333 FAX: (508) 692-7867

MICHIGAN tintel Corp. 7071 Orchard Lake Road Suite 100 West Bloomfield 48322 Tel: (800) 628-8686 FAX: (313) 851-8770

#### MINNESOTA

1 Intel Corp. 3500 W. 80th St. Suite 360 Bioomington 55431 Tel: (800) 628-8686 TWX: 910-576-2867 FAX: (612) 831-6497

#### NEW JERSEY

Intel Corp. 2001 Route 46, Suite 310 Parsippany 07054-1315 Tel: (800) 628-8686 FAX: (201) 402-4893

\*tintel Corp. Lincroft Office Center 125 Half Mile Road Red Bank 07701 Tel: (800) 628-8686 FAX: (908) 747-0983

#### NEW YORK

\*Intel Corp. 850 Crosskeys Office Park Fairport 14450 Tei: (800) 628-6666 TWX: 510-253-7391 FAX: (716) 223-2561 thtnel Corp. 300 Westage Business Center Suite 230 Fishkill 12524 Tei: (800) 628-6666 FAX: (914) 897-3125 \*Tintel Corp.

\*†intel Corp. 2950 Express Dr., South Suite 130 Islandia 11722 Tel: (800) 628-8686 TWX: 510-227-6236 FAX: (516) 348-7939

OHIO \*Intel Corp. 56 Millord Dr., Suite 205 Hudson 44236 Tel: (800) 628-8686 FAX: (216) 528-1026 \*1Intel Corp. 3401 Park Center Drive Suite 220 Dayton 45414 Tel: (800) 628-8686 FAX: (513) 890-8658

OKLAHOMA

Intel Corp. 6801 N. Broadway Suite 115 Oklahoma City 73162 Tel: (800) 628-8686 FAX: (405) 840-9819

OREGON tintel Corp. 15254 N.W. Greenbrier Pkwy. Building B Beaverton 97006 Tei: (800) 628-8686 TWX: 910-467-8741 FAX: (503) 645-8181

PENNSYLVANIA

\*†intel Corp. 925 Harvest Drive Suite 200 Blue Bell 19422 Tel: (800) 628-8686 FAX: (215) 641-0785

SOUTH CAROLINA

Intel Corp. 7403 Parklane Rd., Suite 3 Columbia 29223 Tei: (800) 628-8686 FAX: (803) 788-7999

Intel Corp. 100 Executive Center Drive Suite 109, B183 Greenville 29615 Tel: (800) 628-8686 FAX: (803) 297-3401

TEXAS tintel Corp. 8911 N. Capital of Texas Hwy. Suite 4230 Austin 78759 Tel: (800) 628-6686 FAX: (512) 338-9335 \*†Intel Corp. 5000 Quorum Drive Suite 750 Dallas 75240 Tel: (800) 628-8686

\*†Intel Corp. 20515 SH 249 Suite 401 Houston 77070 Tel: (800) 628-8686 TWX: 910-881-2490 FAX: (713) 988-3660

#### UTAH

fintel Corp. 428 East 6400 South Suite 135 Murray 84107 Tel: (800) 628-8686 FAX: (801) 268-1457

#### WASHINGTON

tintel Corp. 2800 156th Avenue S.E. Suite 105 Bellevue 98007 Tet: (800) 628-8686 FAX: (206) 746-4495

#### WISCONSIN

Intel Corp. 400 N. Executive Dr. Suite 401 Brookfield 53005 Tel: (800) 628-8686 FAX: (414) 789-2746

#### CANADA

#### BRITISH COLUMBIA

Intel Semiconductor of Canada, Ltd. 999 Canada Place Suite 404, #11 Vancouver V6C 3E2 Tel: (800) 628-8686 FAX: (604) 844-2813

#### ONTARIO

tIntel Semiconductor of Canada, Ltd. 2650 Queensview Drive Suite 250 Ottawa K2B 8H6 Tel: (800) 628-8686 FAX: (613) 820-5936

tintel Semiconductor of Canada, Ltd. 190 Attwell Drive Suite 500 Rexdale M9W 6H8 Tel: (800) 628-8686 FAX: (416) 675-2438

#### QUEBEC

tintel Semiconductor of Canada, Ltd. 1 Rue Holiday Suite 320 Tour East Pt. Claire H9R 5N3 Tel: (800) 628-8686 FAX: 514-694-0064

# ntel

#### BAMA

w/Schweber Electronics 5 Henderson Road tsville 35806 (205) 837-6955 : (205) 721-1581

iilton. Hallmark ) University Square, #1 tsville 35816 (205) 837-8700 : (205) 830-2565

Systems 5 Corporate Dr., #120 tsville 35805 (205) 830-9526 : (205) 830-9557

Here Technologies Group 5 University Square, #5 tsville 35805 (205) 837-9300 : (205) 837-9358

e Laboratories D Governers Drive er Building, 2nd Floor tsville 35806 (205) 830-1119 : (205) 830-1520

#### ZONA

tem Electronics 5 W. 10th Place, #101 10e 85281 (602) 966-6600 1 (602) 966-4826

W/Schweber Electronics 5 W. Erie Drive 1pe 85282 (602) 431-0030 : (602) 252-9109

et Computer 6 S. Edwards Drive 10e 85281 (602) 902-4600 1: (602) 902-4640

nilton Hallmark 7 S. 36th Place enix 85040 (602) 437-1200 1: (602) 437-2348

e Laboratories 1 E. Raymond enix 85040 (602) 437-2088 1: (602) 437-2124

.IFORNIA

nem Electronics 1 Oakdale Ave. Itsworth 91311 (818) 775-1333 1: (818) 775-1302

1em Electronics Idfield Drive 1e 92718-2809 (714) 768-4444 5 (714) 768-6456

hem Electronics Menio Drive, #8 klin 95677 (916) 624-9744 (: (916) 624-9750

hem Electronics 9 Carroll Park Drive 1 Diego 92121 (619) 453-9005 (: (619) 546-7893

hem Electronics 0 Ridder Park Drive 1 Jose 95131 (408) 452-2219 (: (408) 441-4504

w Commercial Systems Group 2 Crocker Avenue ward 94544 (510) 489-5371 (: (510) 489-9393

ow Commercial Systems Group 42 Chambers Road tin 92680 (714) 544-0200

(: (714) 731-8438

Arrow/Schweber Electronics 26707 W. Agoura Road Calabasas 91302 Tel: (818) 880-9686 FAX: (818) 772-8930

Arrow/Schweber Electronics 48834 Kato Road, Suite 103 Fremont 94538 Tel: (510) 490-9477

Arrow/Schweber Electronics 6 Cromwell #100 Irvine 92718 Tel: (714) 838-5422 FAX: (714) 454-4206

Arrow/Schweber Electronics 9511 Ridgehaven Court San Diego 92123 Tel: (619) 565-4800 FAX: (619) 279-8062

Arrow/Schweber Electronics 1180 Murphy Avenue San Jose 95131 Tel: (408) 441-9700 FAX: (408) 453-4810

Avnet Computer 3170 Pullman Street Costa Mesa 92626 Tel: (714) 641-4150 FAX: (714) 641-4170

Avnet Computer 1361B West 190th Street Gardena 90248 Tel: (800) 426-7999 FAX: (310) 327-5389

Avnet Computer 755 Sunrise Boulevard, #150 Roseville 95661 Tel: (916) 781-2521 FAX: (916) 781-3819

Avnet Computer 1175 Bordeaux Drive, #A Sunnyvale 94089 Tei: (408) 743-3454 FAX: (408) 743-3348

Avnet Computer 21150 Califa Street Woodland Hills 91376 Tel: (818) 594-8301 FAX: (818) 594-8333

Hamilton Hallmark 3170 Pullman Street Costa Mesa 92626 Tel: (714) 641-4100 FAX: (714) 641-4122

Hamilton Hallmark 1175 Bordeaux Drive, #A Sunnyvale 94089 Tel: (408) 435-3500 FAX: (408) 745-6679

Hamilton Hallmark 4545 Viewridge Avenue San Diego 92123 Tel: (619) 571-7540 FAX: (619) 277-6136

Hamilton Halimark 21150 Califa St. Woodland Hills 91367 Tel: (818) 594-0404 FAX: (818) 594-8234

Hamilton Hallmark 580 Menlo Drive, #2 Rocklin 95762 Tel: (916) 624-9781 FAX: (916) 961-0922

Pioneer Standard 5850 Canoga Blvd., #400 Woodland Hills 91367 Tel: (818) 883-4640

Pioneer Standard 217 Technology Dr., #110 Irvine 92718 Tel: (714) 753-5090

Pioneer Technologies Group 134 Rio Robles San Jose 95134 Tel: (408) 954-9100 FAX: (408) 954-9113 Wyle Laboratories 15370 Barranca Pkwy. Irvine 92713 Tel: (714) 753-9953 FAX: (714) 753-9877

NORTH AMERICAN DISTRIBUTORS

Wyle Laboratories 15360 Barranca Pkwy., #200 Irvine 92713 Tel: (714) 753-9953 FAX: (714) 753-9877

Wyle Laboratories 2951 Sunrise Blvd., #175 Rancho Cordova 95742 Tel: (916) 638-5282 FAX: (916) 638-1491

Wyle Laboratories 9525 Chesapeake Drive San Diego 92123 Tel: (619) 565-9171 FAX: (619) 365-0512

Wyle Laboratories 3000 Bowers Avenue Santa Clara 95051 Tel: (408) 727-2500 FAX: (408) 727-5896

Wyle Laboratories 17872 Cowan Avenue Irvine 92714 Tel: (714) 863-9953 FAX: (714) 263-0473

Wyle Laboratories 26010 Mureau Road, #150 Calabasas 91302 Tel: (818) 880-9000 FAX: (818) 880-5510

Zeus Arrow Electronics 6276 San Ignacio Ave., #E San Jose 95119 Tel: (408) 629-4789 FAX: (408) 629-4792

Zeus Arrow Electronics 22700 Savi Ranch Pkwy. Yorba Linda 92687-4613 Tel: (714) 921-9000 FAX: (714) 921-2715

COLORADO

Anthem Electronics 373 Inverness Drive South Englewood 80112 Tel: (303) 790-4500 FAX: (303) 790-4532

Arrow/Schweber Electronics 61 Inverness Dr. East, #105 Englewood 80112 Tel: (303) 799-0258 FAX: (303) 373-5760

Hamilton Hallmark 12503 E. Euclid Drive, #20 Englewood 80111 Tel: (303) 790-1662 FAX: (303) 790-4991

Hamilton Hallmark 710 Wooten Road, #102 Colorado Springs 80915 Tel: (719) 637-0055 FAX: (719) 637-0088

Wyle Laboratories 451 E. 124th Avenue Thornton 80241 Tel: (303) 457-9953 FAX: (303) 457-4831

#### CONNECTICUT

Anthem Electronics 61 Mattatuck Heights Road Waterburg 06705 Tel: (203) 575-1575 FAX: (203) 596-3232

Arrow/Schweber Electronics 12 Beaumont Road Wallingford 06492 Tel: (203) 265-7741 FAX: (203) 265-7988 Avnet Computer 55 Federai Road, #103 Danbury 06810 Tel: (203) 797-2880 FAX: (203) 791-9050

Hamilton Hallmark 125 Commerce Court, Unit 6 Cheshire 06410 Tel: (203) 271-2844 FAX: (203) 272-1704

Pioneer Standard 2 Trap Falls Road Shelton 06484 Tel: (203) 929-5600

#### FLORIDA

Anthem Electronics 598 South Northlake Blvd., #1024 Altamonte Springs 32701 Tel: (813) 797-2900 FAX: (813) 796-4880

Arrow/Schweber Electronics 400 Fairway Drive, #102 Deerfield Beach 33441 Tel: (305) 429-8200 FAX: (305) 428-3991

Arrow/Schweber Electronics 37 Skyline Drive, #3101 Lake Mary 32746 Tel: (407) 333-9300 FAX: (407) 333-9320

Avnet Computer 3343 W. Commercial Boulevard Bldg. C/D, Suite 107 Ft. Lauderdale 33309 Tel: (305) 730-9110 FAX: (305) 730-0368

Avnet Computer 3247 Tech Drive North St. Petersburg 33716 Tel: (813) 573-5524 FAX: (813) 572-4324

Hamilton Hallmark 3350 N.W. 53rd St., #105-107 Ft. Lauderdale 33309 Tel: (305) 484-5482 FAX: (305) 484-2995

Hamilton Hallmark 10491 72nd St. North Largo 34647 Tel: (813) 541-7440 FAX: (813) 544-4394

Hamilton Hallmark 7079 University Boulevard Winter Park 32792 Tel: (407) 657-3300 FAX: (407) 678-4414

Pioneer Technologies Group 337 Northlake Blvd., #1000 Alta Monte Springs 32701 Tel: (407) 834-9090 FAX: (407) 834-0865

Pioneer Technologies Group 674 S. Military Trail Deerfield Beach 33442 Tel: (305) 428-8877 FAX: (305) 481-2950

Pioneer Technologies Group 8031-2 Phillips Highway Jacksonville 32256 Tel: (904) 730-0065

Wyle Laboratories 1000 112 Circle North St. Petersburg 33716 Tel: (813) 530-3400 FAX: (813) 579-1518

#### GEORGIA

Arrow Commercial Systems Group 3400 C. Corporate Way Duluth 30136 Tel: (404) 623-8825 FAX: (404) 623-8802 Arrow/Schweber Electronics 4250 E. Rivergreen Pkwy., #E Duluth 30136 Tel: (404) 497-1300 FAX: (404) 476-1493

Avnet Computer 3425 Corporate Way, #G Duluth 30136 Tel: (404) 623-5452 FAX: (404) 476-0125

Hamilton Hallmark 3425 Corporate Way, #G & #A Duluth 30136 Tel: (404) 623-5475 FAX: (404) 623-5490

Pioneer Technologies Group 4250 C. Rivergreen Parkway Duluth 30136 Tel: (404) 623-1003 FAX: (404) 623-0665

Wyle Laboratories 6025 The Corners Pkwy., #111 Norcross 30092 Tei: (404) 441-9045 FAX: (404) 441-9086

ILLINOIS

Anthem Electronics 1300 Remington Road, Suite A Schaumberg 60173 Tel: (708) 884-0200 FAX: (708) 885-0480

Arrow/Schweber Electronics 1140 W. Thorndale Rd. itasca 60143 Tel: (708) 250-0500

Avnet Computer 1124 Thorndale Avenue Bensenville 60106 Tel: (708) 860-8572 FAX: (708) 773-7976

Hamilton Hallmark 1130 Thorndale Avenue Bensenville 60106 Tel: (708) 860-7780 FAX: (708) 860-8530

MTI Systems 1140 W. Thorndale Avenue Itasca 60143 Tel: (708) 250-8222 FAX: (708) 250-8275

Pioneer Standard 2171 Executive Dr., #200 Addison 60101 Tel: (708) 495-9680 FAX: (708) 495-9831

Wyle Laboratories 2055 Army Trail Road, #140 Addison 60101 Tel: (800) 853-9953 FAX: (708) 620-1610

#### INDIANA

Arrow/Schweber Electronics 7108 Lakeview Parkway West Dr. Indianapolis 46268 Tel: (317) 299-2071 FAX: (317) 299-2379

Avnet Computer 485 Gradle Drive Carmel 46032 Tel: (317) 575-8029 FAX: (317) 844-4964

Hamilton Hallmark 4275 W. 96th Indianapolis 46268 Tel: (317) 872-8875 FAX: (317) 876-7165

Pioneer Standard 9350 Priority Way West Dr. Indianapolis 46250 Tel: (317) 573-0880 FAX: (317) 573-0979

#### KANSAS

Arrow/Schweber Electronics 9801 Legler Road Lenexa 66219 Tel: (913) 541-9542 FAX: (913) 541-0328

Avnet Computer 15313 W. 95th Street Lenexa 61219 Tel: (913) 541-7989 FAX: (913) 541-7904

Hamilton Hallmark 10809 Lakeview Avenue Lenexa 66215 Tel: (913) 888-4747 FAX: (913) 888-0523

#### KENTUCKY

Hamilton Hallmark 1847 Mercer Road, #G Lexington 40511 Tel: (800) 235-6039 FAX: (606) 288-4936

#### MARYLAND

Anthem Electronics 7168A Columbia Gateway Drive Columbia 21046 Tel: (410) 995-6640 FAX: (410) 290-9862

Arrow Commercial Systems Group 200 Perry Parkway Gaithersburg 20877 Tef: (301) 670-1600 FAX: (301) 670-0188

Arrow/Schweber Electronics 9800J Patuxent Woods Dr. Columbia 21046 Tel: (301) 596-7800 FAX: (301) 995-6201

Avnet Computer 7172 Columbia Gateway Dr., #G Columbia 21045 Tel: (301) 995-3571 FAX: (301) 995-3515

Hamilton Hallmark 10240 Old Columbia Road Columbia 21046 Tel: (410) 988-9800 FAX: (410) 381-2036

North Atlantic Industries Systems Division 7125 River Wood Dr. Columbia 21046 Tel: (301) 312-5800 FAX: (301) 312-5850

Pioneer Technologies Group 15810 Gaither Road Gaithersburg 20877 Tel: (301) 921-0660 FAX: (301) 670-6746

Wyle Laboratories 7180 Columbia Gateway Dr. Columbia 21046 Tel: (410) 312-4844 FAX: (410) 312-4953

#### MASSACHUSETTS

Anthem Electronics 36 Jonspin Road Wilmington 01887 Tel: (508) 657-5170 FAX: (508) 657-6008

Arrow/Schweber Electronics 25 Upton Dr. Wilmington 01887 Tel: (508) 658-0900 FAX: (508) 694-1754

Avnet Computer 10 D Centennial Drive Peabody 01960 Tel: (508) 532-9886 FAX: (508) 532-9660 Hamilton Hallmark 10 D Centennial Drive Peabody 01960 Tel: (508) 531-7430 FAX: (508) 532-9802

Pioneer Standard 44 Hartwell Avenue Lexington 02173 Tel: (617) 861-9200 FAX: (617) 863-1547

Wyle Laboratories 15 Third Avenue Burlington 01803 Tel: (617) 272-7300 FAX: (617) 272-6809

#### MICHIGAN

Arrow/Schweber Electronics 19880 Haggerty Road Livonia 48152 Tel: (800) 231-7902 FAX: (313) 462-2686

Avnet Computer 2876 28th Street, S.W., #5 Grandville 49418 Tel: (616) 531-9607 FAX: (616) 531-0059

Avnet Computer 41650 Garden Brook Rd. #120 Novi 48375 Tel: (313) 347-1820 FAX: (313) 347-4067

Hamilton Hallmark 44191 Plymouth Oaks Blvd., #1300 Plymouth 48170 Tel: (313) 416-5800 FAX: (313) 416-5811

Hamilton Hailmark 41650 Garden Brook Rd., #100 Novi 49418 Tel: (313) 347-4271 FAX: (313) 347-4021

Pioneer Standard 4505 Broadmoor S.E. Grand Rapids 49512 Tel: (616) 698-1800 FAX: (616) 698-1831

Pioneer Standard 13485 Stamford Livonia 48150 Tel: (313) 525-1800 FAX: (313) 427-3720

#### MINNESOTA

Anthem Electronics 7646 Golden Triangle Drive Eden Prairie 55344 Tel: (612) 944-5454 FAX: (612) 944-3045

Arrow/Schweber Electronics 10100 Viking Drive, #100 Eden Prairie 55344 Tel: (612) 941-5280 FAX: (612) 942-7803

Avnet Computer 10000 West 76th Street Eden Prairie 55344 Tel: (612) 829-0025 FAX: (612) 944-2781

Hamilton Hallmark 9401 James Ave South, #140 Bloomington 55431 Tel: (612) 881-2600 FAX: (612) 881-9461

Pioneer Standard 7625 Golden Triange Dr., #G Eden Prairie 55344 Tel: (612) 944-3355 FAX: (612) 944-3794

Wyle Laboratories 1325 E. 79th Street, #1 Bloomington 55425 Tel: (612) 853-2280 FAX: (612) 853-2298

#### MISSOURI

Arrow/Schweber Electronics 2380 Schuetz Road St. Louis 63141 Tel: (314) 567-6888 FAX: (314) 567-1164

NORTH AMERICAN DISTRIBUTORS (Contd.)

Avnet Computer 741 Goddard Avenue Chesterfield 63005 Tel: (314) 537-2725 FAX: (314) 537-4248

Hamilton Hallmark 3783 Rider Trail South Earth City 63045 Tel: (314) 291-5350 FAX: (314) 291-0362

NEW HAMPSHIRE

Avnet Computer 2 Executive Park Drive Bedford 03102 Tel: (800) 442-8638 FAX: (603) 624-2402

#### NEW JERSEY

Anthem Electronics 26 Chapin Road, Unit K Pine Brook 07058 Tel: (201) 227-7960 FAX: (201) 227-9246

Arrow/Schweber Electronics 4 East Stow Rd., Unit 11 Mariton 08053 Tel: (609) 596-8000 FAX: (609) 596-9632

Arrow/Schweber Electronics 43 Route 46 East Pine Brook 07058 Tel: (201) 227-7880 FAX: (201) 538-4962

Avnet Computer 1-B Keystone Ave., Bldg. 36 Cherry Hill 08003 Tel: (609) 424-8961 FAX: (609) 751-2502

Hamilton Hallmark 1 Keystone Ave., Bldg. 36 Cherry Hill 08003 Tel: (609) 424-0110 FAX: (609) 751-2552

Hamilton Hallmark 10 Lanidex Plaza West Parsippani 07054 Tel: (201) 515-5300 FAX: (201) 515-1601

MTI Systems 43 Route 46 East Pinebrock 07058 Tel: (201) 882-8780 FAX: (201) 539-6430

Pioneer Standard 14-A Macison Rd. Fairfield 07006 Tel: (201) 575-3510 FAX: (201) 575-3454

Wyle Laboratories 20 Chapin Road, Bldg. 10-13 Pinebrook 07058 Tel: (201) 882-8358 FAX: (201) 882-9109

#### NEW MEXICO

Alliance Electronics, Inc. 10510 Research Ave. Albuquerque 87123 Tel: (505) 292-3360 FAX: (505) 275-6392

Avnet Computer 7801 Academy Rd. Bidg. 1, Suite 204 Albuquerque 87109 Tel: (505) 828-9725 FAX: (505) 828-0360

#### NEW YORK

Anthem Electronics 47 Mall Drive Commack 11725 Tel: (516) 864-6600 FAX: (516) 493-2244

Arrow/Schweber Electronics 3375 Brighton Henrietta Townline Rd. Rochester 14623 Tel: (716) 427-0300 FAX: (716) 427-0735

Arrow/Schweber Electronics 20 Oser Avenue Hauppauge 11788 Tel: (516) 231-1000 FAX: (516) 231-1072

Avnet Computer 933 Motor Parkway Hauppauge 11788 Tel: (516) 434-7443 FAX: (516) 434-7426

Avnet Computer 2060 Townline Rd. Rochester 14623 Tel: (716) 272-9110 FAX: (716) 272-9685

Hamilton Hallmark 933 Motor Parkway Hauppauge 11788 Tel: (516) 434-7470 FAX: (516) 434-7491

Hamilton Hallmark 1057 E. Henrietta Road Rochester 14623 Tel: (716) 475-9130 FAX: (716) 475-9119

Hamilton Hallmark 3075 Veterans Memorial Hwy. Ronkonkoma 11779 Tel: (516) 737-0600 FAX: (516) 737-0838

MTI Systems 1 Penn Plaza 250 W. 34th Street New York 10119 Tel: (212) 643-1280 FAX: (212) 643-1288

Pioneer Standard 68 Corporate Drive Binghamton 13904 Tel: (607) 722-9300 FAX: (607) 722-9562

Pioneer Standard 60 Crossway Park West Woodbury, Long Island 11797 Tel: (516) 921-8700 FAX: (516) 921-2143

Pioneer Standard 840 Fairport Park Fairport 14450 Tel: (716) 381-7070 FAX: (716) 381-5955

Zeus Arrow Electronics 100 Midland Avenue Port Chester 10573 Tel: (914) 937-7400 FAX: (914) 937-2553

NORTH CAROLINA

Arrow/Schweber Electronics 5240 Greensdairy Road Raleigh 27604 Tel: (919) 876-3132 FAX: (919) 878-9517

Avnet Computer 2725 Millbrook Rd., #123 Raleigh 27604 Tel: (919) 790-1735 FAX: (919) 872-4972

Hamilton Hallmark 5234 Greens Dairy Road Raleigh 27604 Tel: (919) 878-0819 FAX: (919) 878-8729 Pioneer Technologies Group 2200 Gateway Ctr. Blvd, #21 Morrisville 27560 Tel: (919) 460-1530 FAX: (919) 460-1540

#### OHIO

Arrow Commercial Systems ( 284 Cramer Creek Court Dublin 43017 Tel: (614) 889-9347 FAX: (614) 889-9680

Arrow/Schweber Electronics 6573 Cochran Road, #E Solon 44139 Tel: (216) 248-3990 FAX: (216) 248-1106

Arrow/Schweber Electronics 8200 Washington Village Dr. Centerville 45458 Tel: (513) 435-5563 FAX: (513) 435-2049

Avnet Computer 7764 Washington Village Dr. Dayton 45459 Tel: (513) 439-6756 FAX: (513) 439-6719

Avnet Computer 30325 Bainbridge Rd., Bldg. Solon 44139 Tel: (216) 349-2505 FAX: (216) 349-1894

Hamilton Hallmark 7760 Washington Village Dr. Dayton 45459 Tel: (513) 439-6735 FAX: (513) 439-6711

Hamilton Hallmark 5821 Harper Road Solon 44139 Tel: (216) 498-1100 FAX: (216) 248-4803

Hamilton Hallmark 777 Dearborn Park Lane, #L Worthington 43085 Tel: (614) 888-3313 FAX: (614) 888-0767

MTI Systems 23404 Commerce Park Rd. Beachwood 44122 Tel: (216) 464-6688 FAX: (216) 464-3564

Pioneer Standard 4433 Interpoint Boulevard Dayton 45424 Tel: (513) 236-9900 FAX: (513) 236-8133

Pioneer Standard 4800 E. 131st Street Cleveland 44105 Tel: (216) 587-3600 FAX: (216) 663-1004

#### OKLAHOMA

Arrow/Schweber Electronics 12101 E. 51st Street, #106 Tulsa 74146 Tel: (918) 252-7537 FAX: (918) 254-0917

Hamilton Hallmark 5411 S. 125th E. Ave., #305 Tulsa 74146 Tel: (918) 254-6110 FAX: (918) 254-6207

Pioneer Standard 9717 E. 42nd St., #105 Tulsa 74146 Tel: (918) 665-7840 FAX: (918) 665-1891



#### GON

ic Arrow Electronics N.W. 169th Place rerton 97006 (503) 629-8090 (503) 645-0611

em Electronics I S.W. Gemini Drive verton 97005 (503) 643-1114 (503) 626-7928

t Computer Southwest Nimbus Ave. rerton 97005 (503) 627-0900 (502) 526-6242

ilton Hallmark ) S.W. Nimbus Ave. verton 97005 (503) 526-6200 (503) 641-5939

) Laboratories ) Sunshine Court . G. Suite 200 verton 97005 (503) 643-7900 : (503) 646-5466

#### NSYLVANIA

em Electronics Business Center Dr. ham 19044 (215) 443-5150 ; (215) 675-9875

et Computer Executive Drive, #320 \$ 16046 (412) 772-1888 ; (412) 772-1890

leer Technologies Group Kappa Drive burgh 15238 (412) 782-2300 : (412) 963-8255

eer Technologies Group Enterprise Road n Valley Business Center sham 19044 (713) 530-4700

#### 'AS

hem Electronics N. Plano Road, #401 tardson 75081 (214) 238-7100 : (214) 238-0237

w/Schweber Electronics 00 Metric Blvd., #160 tin 78758 (512) 835-4180 :: (512) 832-5921 Arrow/Schweber Electronics 3220 Commander Dr. Carroliton 75006 Tel: (214) 380-6464 FAX: (214) 248-7208

Arrow/Schweber Electronics 10899 Kinghurst Dr., #100 Houston 77099 Tel: (713) 530-4700

Avnet Computer 4004 Beitline, Suite 200 Dallas 75244 Tel: (214) 308-8181 FAX: (214) 308-8129

Avnet Computer 1235 North Loop West, #525 Houston 77008 Tel: (713) 867-8572 FAX: (713) 861-6851

Hamilton Hallmark 12211 Technology Blvd. Austin 78727 Tel: (512) 258-8848 FAX: (512) 258-3777

Hamilton Hallmark 11420 Page Mill Road Dallas 75243 Tel: (214) 553-4300 FAX: (214) 553-4395

Hamilton Hallmark 8000 Westglen Houston 77063 Tel: (713) 781-6100 FAX: (713) 953-8420

Pioneer Standard 1826-D Kramer Lane Austin 78758 Tel: (512) 835-4000 FAX: (512) 835-9829

Pioneer Standard 13765 Beta Road Dallas 75244 Tel: (214) 263-3168 FAX: (214) 490-6419

Pioneer Standard 10530 Rockley Road, #100 Houston 77099 Tel: (713) 495-4700 FAX: (713) 495-5642

Wyle Laboratories 1810 Greenville Avenue Richardson 75081 Tel: (214) 235-9953 FAX: (214) 644-5064

Wyle Laboratories 4030 West Braker Lane, #330 Austin 78758 Tel: (512) 345-8853 FAX: (512) 345-9330

Wyle Laboratories 11001 South Wilcrest, #100 Houston 77099 Tel: (713) 879-9953 FAX: (713) 879-6540

#### UTAH

Anthem Electronics 1279 West 2200 South Salt Lake City 84119 Tel: (801) 973-8555 FAX: (801) 973-8909

NORTH AMERICAN DISTRIBUTORS (Contd.)

Arrow/Schweber Electronics 1946 W. Parkway Blvd. Salt Lake City 84119 Tel: (801) 973-6913 FAX: (801) 972-0200

Avnet Computer 1100 E. 6600 South, #150 Salt Lake City 84121 Tel: (801) 266-1115 FAX: (801) 266-0362

Hamilton Hallmark 1100 East 6600 South, #120 Salt Lake City 84121 Tel: (801) 266-2022 FAX: (801) 263-0104

Wyle Laboratories 1325 West 2200 South, #E West Valley 84119 Tel: (801) 974-9953 FAX: (801) 972-2524

WASHINGTON

Almac Arrow Electronics 14360 S.E. Eastgate Way Bellevue 98007 Tel: (206) 643-9992 FAX: (206) 643-9709

Anthem Electronics 19017 - 120th Ave., N.E. #102 Bothell 98011 Tel: (206) 483-1700 FAX: (206) 486-0571

Avnet Computer 17761 N.E. 78th Place Redmond 98052 Tel: (206) 867-0160 FAX: (206) 867-0161

Hamilton Hallmark 8630 154th Avenue Redmond 98052 Tel: (206) 881-6697 FAX: (206) 867-0159

Wyle Laboratories 15385 N.E. 90th Street Redmond 98052 Tel: (206) 881-1150 FAX: (206) 881-1567

#### WISCONSIN

Arrow/Schweber Electronics 200 N. Patrick, #100 Brookfield 53045 Tel: (414) 792-0150 FAX: (414) 792-0156

Avnet Computer 20875 Crossroads Circle, #400 Waukesha 53186 Tel: (414) 784-8205 FAX: (414) 784-6006 Hamilton Hallmark 2440 S. 179th Street New Berlin 53146 Tel: (414) 797-7844 FAX: (414) 797-9259

Pioneer Standard 120 Bishop Way #163 Brookfield 53005 Tel: (414) 784-3480 FAX: (414) 780-3613

Wyle Laboratories W226 N555 Eastmound Drive Waukesha 53186 Tel: (414) 521-9333 FAX: (414) 521-9498

#### ALASKA

Avnet Computer 1400 West Benson Blvd., #400 Anchorage 99503 Tel: (907) 274-9899 FAX: (907) 277-2639

#### CANADA

#### ALBERTA

Avnet Computer 2816 21st Street Northeast Calgary T2E 6Z2 Tel: (403) 291-3284 FAX: (403) 250-1591

Zentronics 6815 8th Street N.E., #100 Calgary T2E 7H Tel: (403) 295-8838 FAX: (403) 295-8714

#### BRITISH COLUMBIA

Almac Arrow Electronics 8544 Baxter Place Burnaby V5A 4T8 Tel: (604) 421-2333 FAX: (604) 421-5030

Hamilton Hallmark 8610 Commerce Court Burnaby V5A 4N6 Tel: (604) 420-4101 FAX: (604) 420-5376

Zentronics 11400 Bridgeport Rd., #108 Richmond V6X 1T2 Tel: (604) 273-5575 FAX: (604) 273-2413

#### ONTARIO

Arrow/Schweber Electronics 1093 Meyerside, Unit 2 Mississauga L5T 1M4 Tel: (416) 670-7769 FAX: (416) 670-7781

Arrow/Schweber Electronics 36 Antares Dr., Unit 100 Nepean K2E 7W5 Tel: (613) 226-6903 FAX: (613) 723-2018 Avnet Computer Canada System Engineering Group 151 Superior Blvd. Mississuaga L5T 2L1 Tel: (416) 795-3835 FAX: (416) 677-5091 'n

Avnet Computer 190 Colonade Road Nepean K2E 7J5 Tel: (613) 727-2000 FAX: (613) 226-1184

Hamilton Hallmark 151 Superior Blvd., Unit 1-6 Mississauga L5T 2L1 Tel: (416) 564-6060 FAX: (416) 564-6033

Hamilton Hallmark 190 Colonade Road Nepean K2E 7J5 Tel: (613) 226-1700 FAX: (613) 226-1184

Zentronics 5600 Keaton Crescent, #1 Mississauga L5R 3S5 Tel: (416) 507-2600 FAX: (416) 507-2831

Zentronics 155 Colonnade Rd., South #17 Nepean K2E 7K1 Tel: (613) 226-8840 FAX: (613) 226-6352

#### QUEBEC

Arrow/Schweber Electronics 1100 St. Regis Blvd. Dorval H9P 215 Tel: (514) 421-7411 FAX: (514) 421-7430

Arrow/Schweber Electronics 500 Boul. St.-Jean-Baptiste Ave. Quebec H2E SR9 Tel: (418) 871-7500 FAX: (418) 871-6816

Avnet Computer 2795 Reu Halpern St. Laurent H4S 1P8 Tel: (514) 335-2483 FAX: (514) 335-2481

Hamilton Hallmark 7575 Transcanada Highway #600 St. Laurent H4T 2V6 Tel: (514) 335-1000 FAX: (514) 335-2481

Zentronics 520 McCaffrey St. Laurent H4T 1N3 Tel: (514) 737-9700 FAX: (514) 737-5212

CG/SALE/111293

## 82078 FLOPPY DISK CONTROLLER

1994 Data Sheet Addendum

The 82078 floppy disk controller data sheet is published as a stand-alone document (82078 CHMOS Single-Chip Floppy Disk Controller, December 1993, Order Number: 290474-003) and as part of the 1994 Peripheral Components Data Book (September 1993, Order Number: 290468-003).

Both publications are affected by this data sheet addendum which applies only the 64-lead devices. These changes are listed below:

#### 1. 64-lead device:

a. 82078-1 only: DC characteristics for the 5V device (VCC and VCCF) is changed from the old value of  $+5V\pm10\%$  to the correct value of  $+5V\pm5\%$ .

b. Table 1 "64 Pin Mixed Mode D.C. Characteristics," Symbol VOL: add the parameter "Status Pins," Min(V), MAX(V), and Test Conditions shown below so that the information for VOL appears as follows:

| Symbol | Parameter                        | Min(V) | Max(V) | Test Conditions |
|--------|----------------------------------|--------|--------|-----------------|
| VOL    | System Interface                 |        | 0.4    | IOL = 6mA       |
|        | FDD Interface Outputs            |        | 0.4    | IOL = 24mA      |
|        | Status Pins:<br>IDLE, PD, RDGATE |        | 0.4    | IOL = 4mA       |

### Table 1. 64 Pin Mixed Mode D.C. Characteristics

C

Intel Corporation assumes no responsibility for the use of any circuitry other than circuitry embodied in an Intel product. No other circuit patent licenses are implied. Information contained herein supersedes previously published specifications on these devices from Intel. © INTEL CORPORATION, 1994 Order Number: 247494-001

1. -

UNITED STATES, Intel Corporation 2200 Mission College Blvd., P.O. Box 58119, Santa Clara, CA 95052-8119 Tel: (408) 765-8080

> JAPAN, Intel Japan K.K. 5-6 Tokodai, Tsukuba-shi, Ibaraki, 300-26 Tel: 0298-47-8511

FRANCE, Intel Corporation S.A.R.L. 1, Rue Edison, BP 303, 78054 Saint-Quentin-en-Yvelines Cedex Tel: (33) (1) 30 57 70 00

> UNITED KINGDOM, Intel Corporation (U.K.) Ltd. Pipers Way, Swindon, Wiltshire, England SN3 1RJ Tel: (44) (0793) 696000

> > GERMANY, Intel GmbH Dornacher Strasse 1 8016 Feldkirchen bei Muenchen Tel: (49) 089/90992-0

HONG KONG, Intel Semiconductor Ltd. 32/F Two Pacific Place, 88 Queensway, Central Tel: (852) 844-4555

CANADA, Intel Semiconductor of Canada, Ltd. 190 Attwell Drive, Suite 500 Rexdale, Ontario M9W 6H8 Tel: (416) 675-2105

> Printed in USA/0494/10K/MS TS Peripheral Components

----

9

UNITED STATES Intel Corporation 2200 Mission College Boulevard P.O. Box 58119 Santa Clara, CA 95052-8119

JAPAN Intel Japan K.K. 5-6 Tokodai, Tsukuba-shi Ibaraki, 300-26

FRANCE Intel Corporation S.A.R.L. 1, Rue Edison, BP 303 78054 Saint-Quentin-en-Yvelines Cedex

UNITED KINGDOM Intel Corporation (U.K.) Ltd. Pipers Way Swindon Wiltshire, England SN3 1RJ

GERMANY Intel GmbH Dornacher Strasse 1 85622 Feldkirchen/Muenchen

HONG KONG Intel Semiconductor Ltd. 32/F Two Pacific Place 88 Queensway Central

CANADA Intel Semiconductor of Canada, Ltd. 190 Attwell Drive, Suite 500 Rexdale, Ontario M9W 6H8

Order Number: 290468-003 Printed in USA/0194/LB RRD Peripheral Components