

#### To all our customers

We are pleased to inform you that National Semiconductor Corporation's Advanced PC (APC) Division joined Winbond Electronics Corporation on May 5<sup>th</sup> 2005. As a result, in this document "National Semiconductor Corporation" and "National" should be understood as "Winbond Electronics Corporation" and "Winbond", respectively.

#### Continuity

There is no change to this datasheet as a result of offering the device as a Winbond product.

For more information see our website: http://www.winbond.com

or contact APC Customer Support: APC.Support@winbond.com

#### **Important Notice**

Winbond products are not designed, intended, authorized or warranted for use as components in systems or equipment intended for surgical implantation, atomic energy control instruments, airplane or spaceship instruments, transportation instruments, traffic signal instruments, combustion control instruments, or for other applications intended to support or sustain life. Further more, Winbond products are not intended for applications wherein failure of Winbond products could result or lead to a situation wherein personal injury, death or severe property or environmental damage could occur.

Winbond customers using or selling these products for use in such applications do so at their own risk and agree to fully indemnify Winbond for any damages resulting from such improper use or sales.





May 1997

# PC87338/PC97338 SuperI/O 3.3V/5V Plug and Play Compatible Chip, with a Floppy Disk Controller, Two UARTs, Full Infrared Support (IrDA, Sharp-IR and Consumer-IR), and an IEEE1284 Parallel Port

#### **General Description**

**Block Diagram** 

The PC87338/PC97338(VLJ/VJG) provides the most commonly used ISA, EISA and MicroChannel<sup>®</sup> peripherals in a single chip. It includes a Floppy Disk Controller (FDC), two full function UARTs, Infrared (IR) support for HP-SIR, Sharp-IR, Consumer-IR and Infrared Data Association (IrDA) modes, a full IEEE1284 parallel port, two general purpose chip select signals that enable game port control, and a configuration register set. In addition, support for power management and for mixed 3.3 V and 5 V operation makes this chip particularly suitable for notebook and sub-notebook applications.

The PC87338/PC97338 provides full Plug and Play support as specified by Microsoft<sup>®</sup> in "Hardware Design Guide for Microsoft Windows<sup>®</sup> 95".

There are a few minor differences between the PC87338 and the PC97338, indicated by the use of *italics* for PC97338 descriptions. For a summary of these differences, please refer to Appendix A, "Comparison of PC87338 and PC97338".

#### **Features**

- 100% compatibility with Plug and Play requirements specified in the "Hardware Design Guide for Microsoft Windows 95", ISA, EISA, and Micro-Channel architectures
- A special Plug and Play module includes:
  - Flexible IRQs, DMAs and base addresses
  - General Interrupt Requests (IRQs) that can be multiplexed to the ten supported IRQs

#### Configuration Input Serial Fast IR CS1.0 Signals Serial Interface Interface Interface General Configuration UART1 UART2 + Fast IR (PC16C550 or PC16450 or Enhanced UART)) Chip Select Registers (PC16C550 or PC16450 or Enhanced UART) Interrupt and DMA Floppy Disk Controller (FDC) Micro-Floppy with processor Drive Address 1 Digital Data Interface Data and Separator (DDS) Control Floppy (Enhanced 8477) Drive Power-**IEEE1284** Interface Plug and Play Parallel Port Down Support Logic High Current Driver

Data

Handshake

TRI-STATE<sup>®</sup> is a registered trademarks of National Semiconductor Corporation. IBM<sup>®</sup>, MicroChannel<sup>®</sup>, PC-AT<sup>®</sup> and PS/2<sup>®</sup> are registered trademarks of International Business Machines Corporation. Microsoft<sup>®</sup> and Windows<sup>®</sup> are registered trademarks of Microsoft Corporation.

Control

DMA

Channels

IRQ IRQ Input

Signals

- A new, high performance, on-chip Floppy Disk Controller (FDC) provides:
  - Software compatibility with the PC8477, which contains a superset of the floppy disk controller functions in the μDP8473, the NEC μPD765A and the N82077
  - A modifiable 13-bit address
  - Ten IRQ channel options
  - Four 8-bit DMA channel options
  - 16-byte FIFO
  - Burst and non-burst modes
  - Low-power CMOS with enhanced power-down mode
  - A new, high-performance, on-chip, digital data separator without external filter components
  - Support for 5.25"/3.5" floppy disk drives
  - Automatic media sense support
  - Perpendicular recording drive support
  - Three mode Floppy Disk Drive (FDD) support
  - Full support for IBM's Tape Drive Register (TDR) implementation
  - Support for new fast tape drives (2 Mbps) and standard tape drives (1 Mbps, 500 Kbps and 250 Kbps)
  - Support for both FM and MFM modes
- Two UARTs provide:
  - Software compatibility with the 16550A and the 16450
  - A modifiable 13-bit address
  - Ten IRQ channel options
  - MIDI baud rate support
  - Four 8-bit DMA channel options on UART2
  - Shadow register support UART write-only bits
- A fast universal Infrared interface on UART2 supports the following:
  - Data rates of up to 115.2 Kbps (SIR)
  - A data rate of 1.152 Mbps (MIR)
  - A data rate of 4.0 Mbps (FIR)
  - Selectable internal or external modulation/demodulation (Sharp-IR)
  - Consumer-IR (TV-Remote) mode
- A bidirectional parallel port that includes:
  - A modifiable 13-bit address
  - Ten IRQ channel options
  - Four 8-bit DMA channel options
  - An Enhanced Parallel Port (EPP) compatible with version EPP 1.9 (IEEE1284 compliant), that also supports version EPP 1.7 of the Xircom specification.

- An Extended Capabilities Port (ECP) that is IEEE1284 compliant, including level 2
- Bidirectional data transfer under either software or hardware control
- Compatibility with ISA, EISA, and MicroChannel parallel ports
- Multiplexing of additional external FDC signals on parallel port pins that enables use of an external Floppy Disk Drive (FDD)
- A protection circuit that prevents damage to the parallel port when an external printer powers up or operates at high voltages
- 14 mA output drivers
- Two general purpose pins for two programmable chip select signals can be programmed for game port control.
- An address decoder that:
  - Selects all primary and secondary ISA addresses, including COM1-4 and LPT1-3
  - Decodes up to 16 address bits
- Clock source:
  - An internal clock multiplier generates all required internal frequencies.
  - A clock input source 14.318 MHz, 24 MHz, or 48 MHz may be selected
- Enhanced power management features:
  - Special power-down configuration registers
  - Enhanced programmable FDC command to trigger power down
  - Programmable power-down and wake-up modes
  - Two dedicated pins for FDC power management
  - Low power-down current consumption (typically less than 10μA).
  - Reduced pin leakage current
  - Low power CMOS technology
  - The ability to shut off clocks to either the entire chip or only to specific modules
- Mixed voltage support provides:
  - Standard 5 V operation
  - Low voltage 3.3 V operation
  - Simultaneous internal 3.3 V operation and reception or transmission to devices that have either 3.3 V or 5 V power supply
- 100-pin TQFP VJG package PC87338/PC97338
- 100-pin PQFP VLJ package PC87338/PC97338





# **Table of Contents**

| 1.0 | Pin I | Descrip          | tion                                                                  |    |
|-----|-------|------------------|-----------------------------------------------------------------------|----|
|     | 1.1   | CONNE            | ECTION DIAGRAMS                                                       | 1  |
|     | 1.2   | SIGNAL           | L/PIN DESCRIPTIONS                                                    | 5  |
| 2.0 | Con   | Configuration    |                                                                       |    |
|     | 2.1   | OVERV            | /IEW                                                                  | 19 |
|     | 2.2   | CONFI            | GURATION REGISTER SETUP                                               | 19 |
|     |       | 2.2.1            | Hardware Device Configuration                                         | 19 |
|     |       | 2.2.2            | Software Device Configuration                                         | 21 |
|     |       | 2.2.3            | Updating Configuration Registers                                      | 21 |
|     |       | 2.2.4            | Reserved Bits in Configuration Registers                              | 21 |
|     |       | 2.2.5            | INDEX and DATA Register Locations                                     |    |
|     |       | 2.2.6            | Plug and Play Protocol                                                | 22 |
|     | 2.3   | THE CO           | ONFIGURATION REGISTERS                                                | 23 |
|     |       | 2.3.1            | Configuration Register Bitmaps                                        | 24 |
|     |       | 2.3.2            | Function Enable Register (FER), Index 00h                             |    |
|     |       | 2.3.3            | Function Address Register (FAR), Index 01h                            |    |
|     |       | 2.3.4            | Power and Test Register (PTR), Index 02h                              |    |
|     |       | 2.3.5            | Function Control Register (FCR), Index 03h                            |    |
|     |       | 2.3.6            | Printer Control Register (PCR), Index 04h                             |    |
|     |       | 2.3.7            | Power Management Control Register (PMC), Index 06h                    |    |
|     |       | 2.3.8            | Tape, UARTs and Parallel Port Configuration Register (TUP), Index 07h |    |
|     |       | 2.3.9            | SuperI/O Chip Identification Register (SID), Index 08h                |    |
|     |       | 2.3.10           | Advanced SuperI/O Chip Configuration Register (ASC), Index 09h        |    |
|     |       | 2.3.11<br>2.3.12 | Chip Select 0 Low Address Register (CS0LA), Index 0Ah                 |    |
|     |       | 2.3.12           | Chip Select 1 Low Address Register (CS1LA), Index 0Ch                 |    |
|     |       | 2.3.13           | Chip Select 1 Configuration Register (CS1CF), Index 00h               |    |
|     |       | 2.3.14           | Chip Select 1 Goringtration register (GS1G1), Index 0511              |    |
|     |       | 2.3.16           | Chip Select 1 High Address Register (CS1HA), Index 11h                |    |
|     |       | 2.3.17           | SuperI/O Chip Configuration Register 0 (SCF0), Index 12h              |    |
|     |       | 2.3.18           | SuperI/O Chip Configuration Register 1 (SCF1), Index 18h              |    |
|     |       | 2.3.19           | Plug and Play Configuration 0 Register (PNP0), Index 1Bh              |    |
|     |       | 2.3.20           | Plug and Play Configuration 1 Register (PNP1), Index 1Ch              |    |
|     |       | 2.3.21           | SuperI/O Chip Configuration Register 2 (SCF2), Index 40h              | 41 |
|     |       | 2.3.22           | Plug and Play Configuration 2 Register (PNP2), Index 41h              | 42 |
|     |       | 2.3.23           | Parallel Port Base Address Low Byte Register (PBAL), Index 42h        | 43 |
|     |       | 2.3.24           | Parallel Port Base Address High Byte Register (PBAH), Index 43h       | 43 |
|     |       | 2.3.25           | UART1 Base Address Low Byte Register (U1BAL), Index 44h               | 44 |
|     |       | 2.3.26           | UART1 Base Address High Byte Register (U1BAH), Index 45h              | 44 |
|     |       | 2.3.27           | UART2 Base Address Low Byte Register (U2BAL), Index 46h               |    |
|     |       | 2.3.28           | UART2 Base Address High Byte Register (U2BAH), Index 47h              |    |
|     |       | 2.3.29           | FDC Base Address Low Byte Register (FBAL), Index 48h                  |    |
|     |       | 2.3.30           | FDC Base Address High Byte Register (FBAH,) Index 49h                 | 45 |

|     |     | 2.3.31    | SIO Base Address Low Byte Register (SBAL), Index 4Ah         | 46 |
|-----|-----|-----------|--------------------------------------------------------------|----|
|     |     | 2.3.32    | SIO Base Address High Byte Register (SBAH), Index 4Bh        |    |
|     |     | 2.3.33    | System IRQ Input 1 Configuration Register (SIRQ1), Index 4Ch |    |
|     |     | 2.3.34    | System IRQ Input 2 Configuration Register (SIRQ2), Index 4Dh |    |
|     |     | 2.3.35    | System IRQ Input 3 Configuration Register (SIRQ3), Index 4Eh |    |
|     |     | 2.3.36    | Plug-and-Play Configuration 3 Register (PNP3), Index 4Fh     | 49 |
|     |     | 2.3.37    | SuperI/O Configuration 3 Register (SCF3), Index 50h          |    |
|     |     | 2.3.38    | Clock Control Register (CLK), Index 51h                      |    |
|     |     | 2.3.39    | Manufacturing Test Register (MTEST), Index 52h               | 51 |
| 3.0 | The | Digital I | Floppy Disk Controller (FDC)                                 |    |
|     | 3.1 | FDC FL    | JNCTIONS                                                     | 52 |
|     |     | 3.1.1     | Microprocessor Interface                                     | 52 |
|     |     | 3.1.2     | System Operation Modes                                       | 53 |
|     | 3.2 | DATA T    | TRANSFER                                                     | 53 |
|     | 0   | 3.2.1     | Data Rates                                                   |    |
|     |     | 3.2.2     | The Data Separator                                           |    |
|     |     | 3.2.3     | Perpendicular Recording Mode Support                         |    |
|     |     | 3.2.4     | Data Rate Selection                                          |    |
|     |     | 3.2.5     | Write Precompensation                                        |    |
|     |     | 3.2.6     | FDC Low-Power Mode Logic                                     |    |
|     |     | 3.2.7     | Reset                                                        |    |
|     | 3.3 | THE RE    | EGISTERS OF THE FDC                                          | 57 |
|     | 0.0 | 3.3.1     | FDC Register Bitmaps                                         |    |
|     |     | 3.3.2     | Status Register A (SRA), Offset 000                          |    |
|     |     | 3.3.3     | Status Register B (SRB), Offset 001                          |    |
|     |     | 3.3.4     | Digital Output Register (DOR), Offset 010                    |    |
|     |     | 3.3.5     | Tape Drive Register (TDR), Offset 011                        |    |
|     |     | 3.3.6     | Main Status Register (MSR), Offset 100                       |    |
|     |     | 3.3.7     | Data Rate Select Register (DSR), Offset 100                  |    |
|     |     | 3.3.8     | Data Register (FIFO), Offset 101                             |    |
|     |     | 3.3.9     | Digital Input Register (DIR), Offset 111                     |    |
|     |     | 3.3.10    | Configuration Control Register (CCR), Offset 111             |    |
|     | 3.4 |           | HASES OF FDC COMMANDS                                        |    |
|     | 3.4 | 3.4.1     | Command Phase                                                |    |
|     |     | 3.4.2     | Execution Phase                                              |    |
|     |     | 3.4.3     | Result Phase                                                 |    |
|     |     | 3.4.4     | Idle Phase                                                   |    |
|     |     | 3.4.5     | Drive Polling Phase                                          |    |
|     | 0.5 |           | •                                                            |    |
|     | 3.5 |           | ESULT PHASE STATUS REGISTERS                                 |    |
|     |     | 3.5.1     | Result Phase Status Register 0 (ST0)                         |    |
|     |     | 3.5.2     | Result Phase Status Register 1 (ST1)                         |    |
|     |     | 3.5.3     | Result Phase Status Register 2 (ST2)                         |    |
|     |     | 3.5.4     | Result Phase Status Register 3 (ST3)                         |    |
|     | 3.6 |           | OC COMMAND SET                                               |    |
|     |     | 3.6.1     | Abbreviations Used in FDC Commands                           | 75 |

|     |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The CONFIGURE Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                       |
|-----|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|
|     |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The DUMPREG Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                       |
|     |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The FORMAT TRACK Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                       |
|     |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The INVALID Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                       |
|     |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The LOCK Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                       |
|     |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The MODE Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                       |
|     |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The NSC Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                       |
|     |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The PERPENDICULAR MODE Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                       |
|     |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The READ DATA Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                       |
|     |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The READ DELETED DATA Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | -                                                                                                     |
|     |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The READ ID Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                       |
|     |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The READ A TRACK Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                       |
|     |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The RECALIBRATE Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                       |
|     |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The RELATIVE SEEK Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 94                                                                                                    |
|     |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The SCAN EQUAL, the SCAN LOW OR EQUAL and the SCAN HIGH OR EQUAL Commands                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                       |
|     |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The SEEK Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                       |
|     |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The SENSE DRIVE STATUS Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | -                                                                                                     |
|     |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The SENSE INTERRUPT Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                       |
|     |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The SET TRACK Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                       |
|     |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The SPECIFY Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                       |
|     |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The VERIFY Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                       |
|     |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The VERSION Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                       |
|     |                     | 3.6.24                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | The WRITE DATA Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 103                                                                                                   |
|     |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                       |
|     |                     | 3.6.25                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | The WRITE DELETED DATA Command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 104                                                                                                   |
|     | 3.7                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The WRITE DELETED DATA Command<br>E OF A FOUR-DRIVE CIRCUIT USING THE PC87338/PC97338                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                       |
| 4.0 |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                       |
| 4.0 |                     | EXAMPLI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | E OF A FOUR-DRIVE CIRCUIT USING THE PC87338/PC97338                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 104                                                                                                   |
| 4.0 | Para                | EXAMPLI<br>Allel Port<br>INTRODU                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | E OF A FOUR-DRIVE CIRCUIT USING THE PC87338/PC97338                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 104                                                                                                   |
| 4.0 | Para                | EXAMPLE  Allel Port  INTRODU  4.1.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | E OF A FOUR-DRIVE CIRCUIT USING THE PC87338/PC97338  JCTION  The Chip Parallel Port Modes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 104<br>106<br>106                                                                                     |
| 4.0 | <b>Para</b><br>4.1  | EXAMPLE  Allel Port  INTRODU  4.1.1 1  4.1.2 [                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | E OF A FOUR-DRIVE CIRCUIT USING THE PC87338/PC97338  JCTION  The Chip Parallel Port Modes  Device Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 104<br>106<br>106<br>106                                                                              |
| 4.0 | Para                | EXAMPLI<br>Allel Port<br>INTRODU<br>4.1.1 7<br>4.1.2 [<br>STANDAI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | E OF A FOUR-DRIVE CIRCUIT USING THE PC87338/PC97338  JCTION  The Chip Parallel Port Modes  Device Configuration  RD PARALLEL PORT MODES                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 104<br>106<br>106<br>106                                                                              |
| 4.0 | <b>Para</b><br>4.1  | EXAMPLE  Allel Port  INTRODU  4.1.1 1  4.1.2 [  STANDAI  4.2.1 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | E OF A FOUR-DRIVE CIRCUIT USING THE PC87338/PC97338  JCTION  The Chip Parallel Port Modes  Device Configuration  RD PARALLEL PORT MODES  Standard Parallel Port (SPP) Modes Register Set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 104<br>106<br>106<br>106<br>107                                                                       |
| 4.0 | <b>Para</b><br>4.1  | EXAMPLE  Allel Port  INTRODU  4.1.1 7  4.1.2 [  STANDAI  4.2.1 5  4.2.2 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | E OF A FOUR-DRIVE CIRCUIT USING THE PC87338/PC97338  JCTION  The Chip Parallel Port Modes  Device Configuration  RD PARALLEL PORT MODES  Standard Parallel Port (SPP) Modes Register Set  SPP Mode Parallel Port Register Bitmaps                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 104<br>106<br>106<br>106<br>107<br>107                                                                |
| 4.0 | <b>Para</b><br>4.1  | EXAMPLE  Allel Port  INTRODU  4.1.1 7  4.1.2 [  STANDAI  4.2.1 5  4.2.2 5  4.2.3 [                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | E OF A FOUR-DRIVE CIRCUIT USING THE PC87338/PC97338  JCTION  The Chip Parallel Port Modes  Device Configuration  RD PARALLEL PORT MODES  Standard Parallel Port (SPP) Modes Register Set  SPP Mode Parallel Port Register Bitmaps  Data Register (DTR), Offset 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 104<br>106<br>106<br>106<br>107<br>107                                                                |
| 4.0 | <b>Para</b><br>4.1  | EXAMPLE Allel Port  INTRODU 4.1.1 1 4.1.2 [  STANDAI 4.2.1 5 4.2.2 5 4.2.3 [ 4.2.4 5 4.2.4 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | E OF A FOUR-DRIVE CIRCUIT USING THE PC87338/PC97338  JCTION  The Chip Parallel Port Modes  Device Configuration  RD PARALLEL PORT MODES  Standard Parallel Port (SPP) Modes Register Set  SPP Mode Parallel Port Register Bitmaps  Data Register (DTR), Offset 0  Status Register (STR), Offset 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 104<br>106<br>106<br>106<br>107<br>107<br>107                                                         |
| 4.0 | <b>Para</b> 4.1 4.2 | EXAMPLE Allel Port  INTRODU 4.1.1 1 4.1.2 [  STANDAI 4.2.1 5 4.2.2 5 4.2.3 [ 4.2.4 5 4.2.5 (                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | E OF A FOUR-DRIVE CIRCUIT USING THE PC87338/PC97338  JCTION  The Chip Parallel Port Modes  Device Configuration  RD PARALLEL PORT MODES  Standard Parallel Port (SPP) Modes Register Set  SPP Mode Parallel Port Register Bitmaps  Data Register (DTR), Offset 0  Status Register (STR), Offset 1  Control Register (CTR), Offset 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 104<br>106<br>106<br>106<br>107<br>107<br>107<br>108<br>109                                           |
| 4.0 | <b>Para</b><br>4.1  | EXAMPLE  Allel Port  INTRODU  4.1.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | E OF A FOUR-DRIVE CIRCUIT USING THE PC87338/PC97338  JCTION  The Chip Parallel Port Modes  Device Configuration  RD PARALLEL PORT MODES  Standard Parallel Port (SPP) Modes Register Set  SPP Mode Parallel Port Register Bitmaps  Data Register (DTR), Offset 0  Status Register (STR), Offset 1  Control Register (CTR), Offset 2  ED PARALLEL PORT (EPP) MODES                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 104<br>106<br>106<br>106<br>107<br>107<br>107<br>108<br>109                                           |
| 4.0 | <b>Para</b> 4.1 4.2 | EXAMPLE INTRODU 4.1.1 1 4.1.2 [ STANDAI 4.2.1 5 4.2.2 5 4.2.3 [ 4.2.4 5 4.2.5 ( ENHANC 4.3.1 E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | E OF A FOUR-DRIVE CIRCUIT USING THE PC87338/PC97338  JCTION The Chip Parallel Port Modes Device Configuration  RD PARALLEL PORT MODES Standard Parallel Port (SPP) Modes Register Set SPP Mode Parallel Port Register Bitmaps Data Register (DTR), Offset 0 Status Register (STR), Offset 1 Control Register (CTR), Offset 2  ED PARALLEL PORT (EPP) MODES Enhanced Parallel Port (EPP) Modes Register Set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 104<br>106<br>106<br>106<br>107<br>107<br>107<br>108<br>109<br>110                                    |
| 4.0 | <b>Para</b> 4.1 4.2 | EXAMPLE  Allel Port  INTRODU  4.1.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | JCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 104<br>106<br>106<br>106<br>107<br>107<br>107<br>108<br>109<br>110<br>111                             |
| 4.0 | <b>Para</b> 4.1 4.2 | EXAMPLE INTRODUCE 4.1.1 1 4.1.2 E STANDAL 4.2.1 S 4.2.2 S 4.2.3 E 4.2.5 C ENHANC 4.3.1 E 4.3.2 E 4.3.3 S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | JCTION  The Chip Parallel Port Modes  Device Configuration  RD PARALLEL PORT MODES  Standard Parallel Port (SPP) Modes Register Set  SPP Mode Parallel Port Register Bitmaps  Data Register (DTR), Offset 0  Status Register (STR), Offset 1  Control Register (CTR), Offset 2  ED PARALLEL PORT (EPP) MODES  Enhanced Parallel Port (EPP) Modes Register Set  EPP Modes Parallel Port Register Bitmaps  SPP or EPP Data Register (DTR), Offset 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 104<br>106<br>106<br>106<br>107<br>107<br>107<br>108<br>109<br>110<br>111<br>111                      |
| 4.0 | <b>Para</b> 4.1 4.2 | EXAMPLE INTRODUCT   4.1.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | UCTION  The Chip Parallel Port Modes  Device Configuration  RD PARALLEL PORT MODES  Standard Parallel Port Register Bitmaps  Data Register (DTR), Offset 0  Status Register (STR), Offset 1  Control Register (CTR), Offset 2  ED PARALLEL PORT (EPP) Modes Register Set  ED PARALLEL PORT (EPP) Modes Segister Set  Set Description of the process of the proc | 104<br>106<br>106<br>106<br>107<br>107<br>107<br>108<br>109<br>110<br>111<br>111<br>112<br>112        |
| 4.0 | <b>Para</b> 4.1 4.2 | EXAMPLE INTRODUCT INTODUCT INTRODUCT INTRODUCT INTRODUCT INTRODUCT INTRODUCT INTODUCT | JCTION  The Chip Parallel Port Modes  Device Configuration  RD PARALLEL PORT MODES  Standard Parallel Port (SPP) Modes Register Set  SPP Mode Parallel Port Register Bitmaps  Data Register (DTR), Offset 0  Status Register (STR), Offset 1  Control Register (CTR), Offset 2  ED PARALLEL PORT (EPP) Modes Register Set  EPP Modes Parallel Port (EPP) Modes Register Set  SPP or EPP Data Register (DTR), Offset 0  SPP or EPP Status Register (DTR), Offset 1  SPP or EPP Status Register (DTR), Offset 1  SPP or EPP Status Register (STR), Offset 1  SPP or EPP Control Register (CTR), Offset 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 104<br>106<br>106<br>106<br>107<br>107<br>108<br>109<br>110<br>111<br>112<br>112<br>112               |
| 4.0 | <b>Para</b> 4.1 4.2 | EXAMPLE INTRODUCT INTODUCT INTRODUCT INTRODUCT INTRODUCT INTRODUCT INTRODUCT INTODUCT | JCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 104<br>106<br>106<br>106<br>107<br>107<br>107<br>108<br>109<br>110<br>111<br>112<br>112<br>112        |
| 4.0 | <b>Para</b> 4.1 4.2 | EXAMPLE  INTRODU  4.1.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | JCTION  The Chip Parallel Port Modes Device Configuration  RD PARALLEL PORT MODES Standard Parallel Port Register Bitmaps Data Register (DTR), Offset 0 Status Register (CTR), Offset 2 ED PARALLEL PORT (EPP) Modes Register Set EPP Modes Parallel Port (EPP) Modes Register Set  ED PARALLEL PORT (EPP) MODES Enhanced Parallel Port (EPP) Modes Register Set EPP Modes Parallel Port (EPP) Modes Register Set EPP Modes Parallel Port (EPP) Modes Register Set EPP Modes Parallel Port Register Bitmaps SPP or EPP Data Register (DTR), Offset 0 SPP or EPP Status Register (STR), Offset 1 SPP or EPP Control Register (CTR), Offset 2 EPP Address Register, Offset 3 EPP Data Port 0, Offset 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 104<br>106<br>106<br>106<br>107<br>107<br>107<br>108<br>109<br>110<br>111<br>112<br>112<br>113<br>113 |
| 4.0 | <b>Para</b> 4.1 4.2 | EXAMPLE  INTRODU  4.1.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | JCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 104<br>106<br>106<br>106<br>107<br>107<br>107<br>108<br>109<br>110<br>111<br>112<br>112<br>113<br>113 |

|     |     | 4.3.10 EPP Data Port 3, Offset 7                                                                                                                       |     |
|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
|     |     | 4.3.11 EPP Mode Transfer Operations                                                                                                                    | 114 |
|     | 4.4 | EXTENDED CAPABILITIES PARALLEL PORT (ECP) MODES                                                                                                        |     |
|     |     | 4.4.1 Accessing the ECP Registers                                                                                                                      |     |
|     |     | 4.4.2 Software Operation in ECP Modes                                                                                                                  |     |
|     |     | 4.4.3 Hardware Operation in ECP Modes                                                                                                                  |     |
|     |     | <ul> <li>4.4.4 ECP Modes Parallel Port Register Bitmaps</li> <li>4.4.5 ECP Data Register (DATAR), Bits 7-5 of ECR = 000 or 001, Offset 000h</li> </ul> |     |
|     |     | 4.4.6 ECP Address FIFO (AFIFO) Register, Bits 7-5 of ECR = 011, Offset 000h                                                                            |     |
|     |     | 4.4.7 ECP Status Register (DSR), Offset 001h                                                                                                           |     |
|     |     | 4.4.8 ECP Control Register (DCR), Offset 002h                                                                                                          |     |
|     |     | 4.4.9 Parallel Port Data FIFO (CFIFO) Register, Bits 7-5 of ECR = 010, Offset 400h.                                                                    |     |
|     |     | 4.4.10 ECP Data FIFO (DFIFO) Register, Bits 7-5 of ECR = 011, Offset 400h                                                                              | 121 |
|     |     | 4.4.11 Test FIFO (TFIFO) Register, Bits 7-5 of ECR = 110, Offset 400h                                                                                  | 122 |
|     |     | 4.4.12 Configuration Register A (CNFGA), Bits 7-5 of ECR = 111, Offset 400h                                                                            |     |
|     |     | 4.4.13 Configuration Register B (CNFGB), Bits 7-5 of ECR = 111, Offset 401h                                                                            |     |
|     |     | 4.4.14 Extended Control Register (ECR), Offset 402h                                                                                                    |     |
|     | 4.5 | ECP MODE DESCRIPTIONS                                                                                                                                  |     |
|     |     | 4.5.1 Software Controlled Data Transfer (Modes 000 and 001)                                                                                            |     |
|     |     | 4.5.2 Automatic Data Transfer (Modes 010 and 011)                                                                                                      |     |
|     |     | 4.5.3 FIFO Test Access (Mode 110)                                                                                                                      |     |
|     |     | 4.5.5 Interrupt Generation                                                                                                                             |     |
|     | 4.0 | ·                                                                                                                                                      |     |
|     | 4.6 | THE PARALLEL PORT MULTIPLEXER (PPM)                                                                                                                    |     |
|     | 4.7 | PARALLEL PORT PIN/SIGNAL LIST                                                                                                                          | 127 |
| 5.0 |     | T with Fast IR                                                                                                                                         |     |
|     | 5.1 | FEATURES                                                                                                                                               | 129 |
|     | 5.2 | FUNCTIONAL MODES OVERVIEW                                                                                                                              | 129 |
|     |     | 5.2.1 UART Modes: 16450 or 16550, and Extended                                                                                                         |     |
|     |     | 5.2.2 Sharp-IR and SIR Infrared Modes                                                                                                                  |     |
|     |     | 5.2.3 High Speed Infrared Modes: MIR and FIR                                                                                                           |     |
|     | 5.3 | 5.2.4 Consumer IR Mode  REGISTER BANK OVERVIEW                                                                                                         |     |
|     | 5.4 | UART MODES – DETAILED DESCRIPTION                                                                                                                      |     |
|     | 5.4 | 5.4.1 16450 or 16550 UART Mode                                                                                                                         |     |
|     |     | 5.4.2 Extended UART Mode                                                                                                                               | _   |
|     | 5.5 | SHARP-IR MODE – DETAILED DESCRIPTION                                                                                                                   |     |
|     | 5.6 | SIR MODE – DETAILED DESCRIPTION                                                                                                                        |     |
|     | 5.7 | MIR AND FIR MODES – DETAILED DESCRIPTION                                                                                                               | 133 |
|     | J., | 5.7.1 High-Speed Infrared Transmission                                                                                                                 |     |
|     |     | 5.7.2 High Speed Infrared Reception                                                                                                                    |     |
|     | 5.8 | CONSUMER-IR MODE – DETAILED DESCRIPTION                                                                                                                |     |
|     | 5.5 | 5.8.1 Consumer-IR Transmission                                                                                                                         |     |
|     |     | 5.8.1 Consumer-IK Transmission                                                                                                                         | 13  |

|      | 5.8.2   | Consumer-IR Reception                                                                                                         | . 135 |
|------|---------|-------------------------------------------------------------------------------------------------------------------------------|-------|
| 5.9  | FIFO TI | ME-OUTS                                                                                                                       | . 136 |
|      | 5.9.1   | MIR or FIR Mode Time-Out Conditions                                                                                           |       |
|      | 5.9.2   | UART, SIR or Sharp-IR Mode Time-Out Conditions                                                                                | . 136 |
|      | 5.9.3   | Consumer-IR Mode Time-out Conditions                                                                                          | . 137 |
|      | 5.9.4   | Transmission Deferral                                                                                                         | . 137 |
| 5.10 | AUTOM.  | ATIC FALLBACK TO A NON-EXTENDED UART MODE                                                                                     | . 137 |
| 5.11 | PIPELIN | IING                                                                                                                          | . 138 |
| 5.12 | OPTICA  | L TRANSCEIVER INTERFACE                                                                                                       | . 138 |
| 5.13 | BANK 0  | - GLOBAL CONTROL AND STATUS REGISTERS                                                                                         | . 138 |
|      | 5.13.1  | Receiver Data Port (RXD) or the Transmitter Data Port (TXD), Bank 0, Offset 00h                                               | . 139 |
|      | 5.13.2  | Interrupt Enable Register (IER), Bank 0, Offset 01h                                                                           | . 139 |
|      | 5.13.3  | Event Identification Register (EIR), Bank 0, Offset 02h                                                                       | . 143 |
|      | 5.13.4  | FIFO Control Register (FCR), Bank 0, Offset 02h                                                                               |       |
|      | 5.13.5  | Link Control Register (LCR), Bank 0, Offset 03h, and Bank Selection Register (BSF All Banks, Offset 03h                       |       |
|      | 5.13.6  | Modem/Mode Control Register (MCR), Bank 0, Offset 04h                                                                         | . 148 |
|      | 5.13.7  | Link Status Register (LSR), Non-Extended Modes, Bank 0, Offset 05h                                                            | . 150 |
|      | 5.13.8  | Modem Status Register (MSR), Bank 0, Offset 06h                                                                               | . 151 |
|      | 5.13.9  | Scratchpad Register (SPR), Bank 0, Offset 07h                                                                                 | . 152 |
|      | 5.13.10 | Auxiliary Status and Control Register (ASCR), Bank 0, Offset 07h                                                              | . 152 |
| 5.14 | BANK 1  | - THE LEGACY BAUD RATE GENERATOR DIVISOR PORTS                                                                                | . 154 |
|      | 5.14.1  | Legacy Baud Rate Generator Divisor Ports (LBGD(L) and LBGD(H)),  Bank 1, Offsets 00h and 01h                                  | . 154 |
|      | 5.14.2  | Link Control Register (LCR) and Bank Select Register (BSR), Bank 1, Offset 03h                                                | . 156 |
| 5.15 | BANK 2  | - EXTENDED CONTROL AND STATUS REGISTERS                                                                                       | . 156 |
|      | 5.15.1  | Baud Generator Divisor Ports, LSB (BGD(L)) and MSB (BGD(H)), Bank 2, Offsets 00h and 01h                                      | . 156 |
|      | 5.15.2  | Extended Control Register 1 (EXCR1), Bank 2, Offset 02h                                                                       |       |
|      | 5.15.3  | Link Control Register (LCR) and Bank Select Register (BSR), Bank 2, Offset 03h                                                | . 158 |
|      | 5.15.4  | Extended Control and Status Register 2 (EXCR2), Bank 2, Offset 04h                                                            | . 158 |
|      | 5.15.5  | Reserved Register, Bank 2, Offset 05h                                                                                         | . 159 |
|      | 5.15.6  | TX_FIFO Current Level Register (TXFLV), Bank 2, Offset 06h                                                                    | . 159 |
|      | 5.15.7  | RX_FIFO Current Level Register (RXFLV), IrDA or Consumer-IR Modes, Bank 2, Offset 07h                                         | . 159 |
| 5.16 | BANK 3  | - MODULE REVISION ID AND SHADOW REGISTERS                                                                                     | . 160 |
|      | 5.16.1  | Module Revision ID Register (MRID), Bank 3, Offset 00h                                                                        | .160  |
|      | 5.16.2  | Shadow of Link Control Register (SH_LCR), Bank 3, Offset 01h                                                                  | . 160 |
|      | 5.16.3  | Shadow of FIFO Control Register (SH_FCR), Bank 3, Offset 02h                                                                  | . 160 |
|      | 5.16.4  | Link Control Register (LCR) and Bank Select Register (BSR), Bank 3, Offset 03h                                                | . 161 |
| 5.17 | BANK 4  | - TIMER AND FRAME BYTE COUNTERS                                                                                               | . 161 |
|      | 5.17.1  | Interval Timer (TMR(L) and TMR(H)), Bank 4, Offsets 00h and 01h                                                               | . 161 |
|      | 5.17.2  | Infrared Control Register 1 (IRCR1), Bank 4, Offset 02h                                                                       | . 161 |
|      | 5.17.3  | Link Control Register (LCR) and Bank Select Register (BSR), Bank 4, Offset 03h                                                |       |
|      | 5.17.4  | Transmission Frame Length Register (TFRL) or Transmission Frame Current Cour<br>Register (TFRCC), Bank 4, Offsets 04h and 05h |       |
|      |         |                                                                                                                               |       |

|     |      | 5.17.5 Reception Frame Maximum Length (RFRML) or Reception Frame Current Count (RFRCC) Registers, Bank 4, Offsets 06h and 07h |        |
|-----|------|-------------------------------------------------------------------------------------------------------------------------------|--------|
|     | 5.18 | BANK 5 – INFRARED CONTROL AND ST_FIFO REGISTERS                                                                               | 164    |
|     |      | 5.18.1 Pipelined Baud Generator Divisor Registers, (P_BGD(L) and P_BGD(H)),  Bank 5, Offsets 00h and 01h                      | 164    |
|     |      | 5.18.2 Pipeline Mode Register (P_MDR), Bank 5, Offset 02h                                                                     | 164    |
|     |      | 5.18.3 (LCR/BSR) Register, Bank 5, Offset 03h                                                                                 | 165    |
|     |      | 5.18.4 Infrared Control Register 2 (IRCR2), Bank 5, Offset 04h                                                                | 165    |
|     |      | 5.18.5 The ST_FIFO                                                                                                            |        |
|     |      | 5.18.6 Frame Status at FIFO Bottom Register (FRM_ST), Bank 5, Offset 05h                                                      |        |
|     |      | 5.18.7 Received Frame Length LSB (RFRL(L)) or Lost Frame Count at ST_FIFO Botton (LSTFRC), Bank 5, Offset 06h                 | 167    |
|     |      | 5.18.8 Received Frame Length (MSB) at ST_FIFO Bottom (RFRL(H)), Bank 5, Offset 07                                             | 'n 167 |
|     | 5.19 | BANK 6 – INFRARED PHYSICAL LAYER CONFIGURATION REGISTERS                                                                      | 167    |
|     |      | 5.19.1 Infrared Control Register 3 (IRCR3), Bank 6, Offset 00h                                                                | 167    |
|     |      | 5.19.2 MIR Pulse Width Register (MIR_PW), Bank 6, Offset 01h                                                                  | 168    |
|     |      | 5.19.3 SIR Pulse Width Register (SIR_PW), Bank 6, Offset 02h                                                                  |        |
|     |      | 5.19.4 Link Control Register (LCR) and Bank Select Register (BSR), Bank 6, Offset 03h                                         |        |
|     |      | 5.19.5 Beginning Flags and Preamble Length Register (BFPL), Bank 6, Offset 04h                                                | 169    |
|     | 5.20 | BANK 7 – CONSUMER-IR AND OPTICAL TRANSCEIVER CONFIGURATION REGISTER                                                           | RS 170 |
|     |      | 5.20.1 Infrared Receiver Demodulator Control Register (IRRXDC), Bank 7, Offset 0                                              | 171    |
|     |      | 5.20.2 Infrared Transmitter Modulator Control Register (IRTXMC), Bank 7, Offset 01h                                           |        |
|     |      | 5.20.3 Consumer-IR Configuration Register (RCCFG), Bank 7, Offset 02h                                                         |        |
|     |      | 5.20.4 Link Control/Bank Select Registers (LCR/BSR), Bank 7, Offset 03h                                                       |        |
|     |      | 5.20.5 Infrared Interface Configuration Register 1 (IRCFG1), Bank 7, Offset 04h                                               |        |
|     |      | 5.20.6 Infrared Interface Configuration Register 2 (IRCFG2), Bank 7, Offset 05h                                               |        |
|     |      | 5.20.7 Infrared Interface Configuration 3 Register (IRCFG3), Bank 7, Offset 06h                                               |        |
|     |      | 5.20.8 Infrared Interface Configuration Register 4 (IRCFG4), Bank 7, Offset 07h                                               |        |
|     | 5.21 | UART WITH FAST IR REGISTER BITMAPS                                                                                            | 178    |
| 6.0 | DMA  | A and Interrupt Mapping                                                                                                       |        |
|     | 6.1  | DMA SUPPORT                                                                                                                   | 185    |
|     |      | 6.1.1 Legacy Mode                                                                                                             | 185    |
|     |      | 6.1.2 Plug and Play Mode                                                                                                      | 185    |
|     | 6.2  | INTERRUPT SUPPORT                                                                                                             | 186    |
|     |      | 6.2.1 Legacy Mode                                                                                                             | 186    |
|     |      | 6.2.2 Plug and Play Mode                                                                                                      | 187    |
| 7.0 | Pow  | er Management                                                                                                                 |        |
|     | 7.1  | POWER-DOWN STATE                                                                                                              | 189    |
|     |      | 7.1.1 Recommended Power-Down Methods - Group 1                                                                                | 189    |
|     |      | 7.1.2 Recommended Power-Down Methods - Group 2                                                                                | 190    |
|     |      | 7.1.3 Special Power-Down Cases                                                                                                | 190    |
|     | 7.2  | POWER-UP                                                                                                                      | 190    |
|     |      | 7.2.1 The Clock Multiplier                                                                                                    | 190    |
|     |      | 7.2.2 Chip Power-Up Procedure                                                                                                 | 190    |
|     |      |                                                                                                                               |        |

|     |                      | 7.2.3          | UART Power-Up                                                                         | 191 |  |
|-----|----------------------|----------------|---------------------------------------------------------------------------------------|-----|--|
|     |                      | 7.2.4          | FDC Power-Up                                                                          |     |  |
| 8.0 | 0 Device Description |                |                                                                                       |     |  |
| 0.0 |                      |                | •                                                                                     |     |  |
|     | 8.1                  |                | RAL DC ELECTRICAL CHARACTERISTICS                                                     |     |  |
|     |                      | 8.1.1          | Recommended Operating Conditions                                                      |     |  |
|     |                      | 8.1.2<br>8.1.3 | Absolute Maximum Ratings  Capacitance                                                 |     |  |
|     |                      | 8.1.4          | Power Consumption Under Recommended Operating Conditions                              |     |  |
|     | 0.0                  |                | ·                                                                                     |     |  |
|     | 8.2                  | 8.2.1          | ARACTERISTICS OF PINS, BY GROUPGroup 1                                                |     |  |
|     |                      | 8.2.2          | Group 2                                                                               |     |  |
|     |                      | 8.2.3          | Group 3                                                                               |     |  |
|     |                      | 8.2.4          | Group 4                                                                               |     |  |
|     |                      | 8.2.5          | Group 5                                                                               |     |  |
|     |                      | 8.2.6          | Group 6                                                                               |     |  |
|     |                      | 8.2.7          | Group 7                                                                               | 195 |  |
|     |                      | 8.2.8          | Group 8                                                                               | 196 |  |
|     |                      | 8.2.9          | Group 9                                                                               | 196 |  |
|     |                      | 8.2.10         | Group 10                                                                              | 196 |  |
|     |                      | 8.2.11         | Group 11                                                                              |     |  |
|     |                      | 8.2.12         | Group 12                                                                              |     |  |
|     |                      | 8.2.13         | Group 13                                                                              |     |  |
|     | 8.3                  | AC ELE         | ECTRICAL CHARACTERISTICS                                                              |     |  |
|     |                      | 8.3.1          | AC Test Conditions $T_A$ = 0° C to 70° C, $V_{DD}$ = 5.0 V $\pm$ 10%, 3.3 V $\pm$ 10% | 198 |  |
|     |                      | 8.3.2          | Clock Timing                                                                          |     |  |
|     |                      | 8.3.3          | Microprocessor Interface Timing                                                       |     |  |
|     |                      | 8.3.4          | Baud Output Timing                                                                    |     |  |
|     |                      | 8.3.5          | SIR Transmitter Timing                                                                |     |  |
|     |                      | 8.3.6          | Receiver Timing                                                                       |     |  |
|     |                      | 8.3.7<br>8.3.8 | UART, Sharp-IR and Consumer Remote Control Timing                                     |     |  |
|     |                      | 8.3.9          | IRSLn Write Timing                                                                    |     |  |
|     |                      | 8.3.10         | Modem Control Timing                                                                  |     |  |
|     |                      | 8.3.11         | DMA Timing                                                                            |     |  |
|     |                      | 8.3.12         | Reset Timing                                                                          |     |  |
|     |                      | 8.3.13         | Write Data Timing                                                                     |     |  |
|     |                      | 8.3.14         | Floppy Disk Drive Control Timing                                                      | 211 |  |
|     |                      | 8.3.15         | Read Data Timing                                                                      | 212 |  |
|     |                      | 8.3.16         | Standard Parallel Port Timing                                                         | 212 |  |
|     |                      | 8.3.17         | Enhanced Parallel Port 1.7 Timing                                                     | 215 |  |
|     |                      | 8.3.18         | Enhanced Parallel Port 1.9 Timing                                                     | 216 |  |
|     |                      | 8.3.19         | Extended Capabilities Port Timing                                                     | 218 |  |
|     |                      | 8.3.20         | Chip Selection Timing                                                                 | 219 |  |
|     |                      | APPEN          | IDIX A                                                                                |     |  |
|     |                      |                | Comparison of PC87338 and PC97338                                                     | 220 |  |
|     |                      |                | Glossary                                                                              |     |  |
|     |                      |                |                                                                                       |     |  |

#### **List of Figures** FIGURE 2-1. FIGURE 2-2. FIGURE 2-3. FIGURE 2-4. FIGURE 2-5. PTR Register Bitmap .......31 FIGURE 2-6. FCR Register Bitmap .......31 FIGURE 2-7. FIGURE 2-8. FIGURE 2-9. FIGURE 2-10. SID Register Bitmap .......35 FIGURE 2-11. FIGURE 2-12. CS0LA Register Bitmap .......36 FIGURE 2-13. CS0CF Register Bitmap .......36 FIGURE 2-14. CS1LA Register Bitmap .......37 FIGURE 2-17. CS1HA Register Bitmap .......38 FIGURE 2-20. PNP0 Register Bitmap ......40 FIGURE 2-21. PNP1 Register Bitmap ......41 FIGURE 2-22. SCF2 Register Bitmap ......41 FIGURE 2-23. PNP2 Register Bitmap 42 FIGURE 2-24. FIGURE 2-25. FIGURE 2-26. U1BAL Register Bitmap .......44 FIGURE 2-27. U1BAH Register Bitmap .......44 FIGURE 2-28. U2BAL Register Bitmap .......44 FIGURE 2-29. U2BAH Register Bitmap .......45 FIGURE 2-30. FBAL Register Bitmap .......45 FIGURE 2-31. FBAH Register Bitmap .......45 FIGURE 2-32. FIGURE 2-33. FIGURE 2-34. FIGURE 2-35. FIGURE 2-36. SIRQ3 Register Bitmap .......48 FIGURE 2-37. FIGURE 2-38. SCF3 Register Bitmap .......50 FIGURE 2-39. CLK Register Bitmap .......51 FIGURE 3-1. FDC Functional Block Diagram .......52 FIGURE 3-2. PC87338/PC97338 Dynamic Window Margin Performance ......53 FIGURE 3-3. Perpendicular Recording Drive Read/Write Head and Pre-Erase Head ......55 FIGURE 3-4. FIGURE 3-5. FIGURE 3-6. FIGURE 3-7. DOR Register Bitmap .......61 FIGURE 3-8. FIGURE 3-9. MSR Register Bitmap ......64 DSR Register Bitmap ......65 FIGURE 3-10.

| FIGURE 0.44                  | EDO Data Danistan Bitanan                                             | 00  |
|------------------------------|-----------------------------------------------------------------------|-----|
| FIGURE 3-11.                 | <b>5</b> 1                                                            |     |
| FIGURE 3-12.                 | DIR Register Bitmap                                                   |     |
| FIGURE 3-13.                 | CCR Register Bitmap                                                   |     |
| FIGURE 3-14.                 | 5                                                                     |     |
|                              | ST1 Result Phase Register Bitmap                                      |     |
| FIGURE 3-16.                 | ST2 Result Phase Register Bitmap                                      |     |
| FIGURE 3-17.                 | ST3 Result Phase Register                                             |     |
| FIGURE 3-18.                 | IBM, Perpendicular, and ISO Formats Supported by FORMAT TRACK Command |     |
| FIGURE 3-19.                 | PC87338/PC97338 Four Floppy Disk Drive Circuit                        |     |
| FIGURE 4-1.                  | DTR Register Bitmap (SPP Mode)                                        |     |
| FIGURE 4-2.                  | STR Register Bitmap (SPP Mode)                                        |     |
| FIGURE 4-3.                  | CTR Register Bitmap (SPP Mode) in PC87338                             |     |
| FIGURE 4-4.                  | CTR Register Bitmap (SPP Mode) in PC97338                             |     |
| FIGURE 4-5.                  | DTR Register Bitmap (EPP Mode)                                        |     |
| FIGURE 4-6.                  | STR Register Bitmap (EPP Mode)                                        |     |
| FIGURE 4-7.                  | CTR Register Bitmap (EPP Mode)                                        |     |
| FIGURE 4-8.                  | DTR Register Bitmap (EPP Mode)                                        |     |
| FIGURE 4-9.                  | DTR Register Bitmap (EPP Mode)                                        |     |
| FIGURE 4-10.                 | DTR Register Bitmap (EPP Mode)                                        |     |
| FIGURE 4-11.                 | EPP Data Port 2 Bitmap                                                |     |
|                              | EPP Data Port 3 Bitmap                                                |     |
| FIGURE 4-13.                 | EPP 1.7 Address Write                                                 |     |
| FIGURE 4-14.                 | EPP 1.7 Address Read                                                  |     |
| FIGURE 4-15.<br>FIGURE 4-16. | EPP Write with Zero Wait States                                       |     |
|                              |                                                                       |     |
| FIGURE 4-17.                 | DATAR Register Bitmap                                                 |     |
| FIGURE 4-18.                 | ·                                                                     |     |
|                              | AFIFO Register Bitmap  ECP DSR Register Bitmap                        |     |
| FIGURE 4-21.                 | DCR Register Bitmap                                                   |     |
| FIGURE 4-21.                 | ·                                                                     |     |
| FIGURE 4-23.                 |                                                                       |     |
| FIGURE 4-23.                 | · · · · · · · · · · · · · · · · · · ·                                 |     |
| FIGURE 4-24.                 |                                                                       |     |
| FIGURE 4-25.                 | CNFGA Register Bitmap  CNFGB Register Bitmap                          |     |
| FIGURE 4-27.                 |                                                                       |     |
| FIGURE 4-27.                 | •                                                                     |     |
| FIGURE 4-29.                 | ECP (Backward) Read Cycle                                             |     |
| FIGURE 5-1.                  | Register Bank Architecture                                            |     |
| FIGURE 5-2.                  | Composite Serial Data                                                 |     |
| FIGURE 5-3.                  | RXD Register Bitmap                                                   |     |
| FIGURE 5-4.                  | TXD Register Bitmap                                                   |     |
| FIGURE 5-5.                  | IER Register Bitmap, Non-Extended Mode                                |     |
| FIGURE 5-6.                  | IER Register Bitmap, Extended Modes of UART and Sharp-IR              |     |
| FIGURE 5-7.                  | IER Register Bitmap, Extended Mode of SIR                             |     |
| FIGURE 5-8.                  | IER Register Bitmap, MIR and FIR Modes                                |     |
| FIGURE 5-9.                  | IER Register Bitmap, Consumer-IR Mode                                 |     |
| FIGURE 5-10.                 | EIR Register Bitmap, Non-Extended Modes                               |     |
| FIGURE 5-11.                 | EIR Register Bitmap, Extended Mode                                    |     |
| FIGURE 5-12.                 | · · · · · · · · · · · · · · · · · · ·                                 |     |
| FIGURE 5-13.                 | ·                                                                     |     |
| . 100112 0 10.               | 2008.00. Ditiriup                                                     | 177 |

| EIGUDE 5 14                  | BSR Register Bitmap                                      | 1/10  |
|------------------------------|----------------------------------------------------------|-------|
| FIGURE 5-15.                 | MCR Register Bitmap, Non-Extended Mode                   |       |
| FIGURE 5-16.                 | MCR Register Bitmap, Extended Modes                      |       |
|                              | LSR Register Bitmap                                      |       |
|                              | MSR Register Bitmap                                      |       |
| FIGURE 5-18.                 | ·                                                        |       |
| FIGURE 5-19.                 | ASCR Register Bitmap                                     |       |
| FIGURE 5-20.                 | ·                                                        |       |
|                              | LBGD(L) Register Bitmap                                  |       |
| FIGURE 5-22.                 | BGD(L) Register Bitmap                                   |       |
| FIGURE 5-23.                 | BGD(H) Register Bitmap                                   |       |
| FIGURE 5-24.                 | EXCR1 Register Bitmap                                    |       |
|                              | · · · · · · · · · · · · · · · · · · ·                    |       |
| FIGURE 5-26.<br>FIGURE 5-27. | DMA Control Signals Routing  EXCR2 Register Bitmap       |       |
| FIGURE 5-27.                 | TXFLV Register Bitmap                                    |       |
| FIGURE 5-26.                 | RXFLV Register Bitmap                                    |       |
| FIGURE 5-29.                 |                                                          |       |
| FIGURE 5-30.                 | MRID Register Bitmap                                     |       |
|                              | SH_LCR Register Bitmap                                   |       |
| FIGURE 5-32.                 | SH_LCR Register Bitmap                                   |       |
| FIGURE 5-33.                 | TMR(L) Register Bitmap                                   |       |
| FIGURE 5-34.                 | TMR(H) Register Bitmap                                   |       |
| FIGURE 5-35.                 | IRCR1 Register Bitmap                                    |       |
| FIGURE 5-36.                 | TFRL(L) or TFRCC(L) Register Bitmap                      |       |
| FIGURE 5-37.                 | TFRL(H) or TFRCC(H) Register Bitmap                      |       |
| FIGURE 5-38.                 | RFRML(L) or RFRCC(L) Register Bitmap                     |       |
| FIGURE 5-39.<br>FIGURE 5-40. | RFRML(H) or RFRCC(H) Register Bitmap                     |       |
| FIGURE 5-41.                 | Pipelined Baud Rate Generator Divisor Register Bitmap    |       |
|                              |                                                          |       |
| FIGURE 5-42.                 | IRCR2 Register Bitmap                                    |       |
| FIGURE 5-43.                 | FRM_ST Register Bitmap                                   |       |
| FIGURE 5-44.                 | RFRL(L) or LSTFRC Register BitmapRFRL(H) Register Bitmap |       |
|                              | IRCR3 Register Bitmap                                    |       |
| FIGURE 5-46.                 | MIR PW Register Bitmap                                   |       |
| FIGURE 5-47.                 |                                                          |       |
| FIGURE 5-49.                 | SIR_PW Register Bitmap BFPL Register Bitmap              |       |
| FIGURE 5-49.                 | IRRXDC Register Bitmap                                   |       |
| FIGURE 5-51.                 | IRTXMC Register Bitmap                                   |       |
| FIGURE 5-51.                 | RCCFG Register Bitmap                                    |       |
| FIGURE 5-52.                 | IRCFG1 Register Bitmap                                   |       |
| FIGURE 5-53.                 | IRCFG2 Register Bitmap                                   |       |
| FIGURE 5-54.                 | IRCFG3 Register Bitmap                                   |       |
| FIGURE 5-56.                 | IRCFG4 Register Bitmap                                   |       |
| FIGURE 8-1.                  | Load Circuit                                             |       |
| FIGURE 8-1.                  | A.C. Test Input, Output Waveform                         |       |
| FIGURE 8-2.                  | Clock Timing                                             |       |
| FIGURE 8-3.                  | Microprocessor Read Timing                               |       |
| FIGURE 8-4.                  | Microprocessor Write Timing                              |       |
| FIGURE 8-6.                  | System Interrupts                                        |       |
| FIGURE 8-7.                  | Baud Output Timing                                       |       |
| FIGURE 8-8.                  | SIR Transmitter Timing                                   |       |
| 1 10011L 0-0.                | One transmitter finning                                  | . 200 |

| FIGURE 8-9.  | IRSLx Timing                                      | 203 |
|--------------|---------------------------------------------------|-----|
| FIGURE 8-10. | SIR Receiver Timing                               | 204 |
| FIGURE 8-11. | FIFO Mode Receiver Timing                         | 205 |
| FIGURE 8-12. | Time-Out Receiver Timing                          | 205 |
| FIGURE 8-13. | UART, Sharp-IR and Consumer Remote Control Timing | 206 |
| FIGURE 8-14. | SIR, MIR and FIR Timing                           |     |
| FIGURE 8-15. | IRSLn Write Timing                                |     |
| FIGURE 8-16. | Modem Control Timing                              |     |
| FIGURE 8-17. | DMA Timing                                        | 209 |
| FIGURE 8-18. | Reset Timing                                      | 210 |
| FIGURE 8-19. | Write Data Timing of the Floppy Disk Drive        | 211 |
| FIGURE 8-20. | Floppy Disk Drive Control Timing                  | 211 |
| FIGURE 8-21. | Read Data Timing of the Floppy Disk Drive         | 212 |
| FIGURE 8-22. | Parallel Port Interrupt Timing (Compatible Mode)  | 212 |
| FIGURE 8-23. | Parallel Port Interrupt Timing (Extended Mode)    |     |
| FIGURE 8-24. | Typical Parallel Port Data                        | 213 |
| FIGURE 8-25. | Compatibility Mode Timing Parameters Diagram      | 214 |
| FIGURE 8-26. | Enhanced Parallel Port 1.7 Timing                 | 215 |
| FIGURE 8-27. | Enhanced Parallel Port 1.9 Timing                 | 217 |
| FIGURE 8-28. | ECP Parallel Port Forward Timing                  | 218 |
| FIGURE 8-29. | ECP Parallel Port Backward Timing                 | 218 |
| FIGURE 8-30. | Chip Select Timing                                |     |
|              |                                                   |     |

|             | List of Tables                                                                   |     |
|-------------|----------------------------------------------------------------------------------|-----|
| TABLE 1-1.  | Signal/Pin Description Table                                                     | 5   |
| TABLE 1-2.  | Multi-Function Pins (Excluding Strap Pins)                                       |     |
| TABLE 1-3.  | IRQ12, A15-11 / UART2 / Infrared Pin Allocation                                  |     |
| TABLE 1-4.  | UART2 Mode Configurations 1                                                      |     |
| TABLE 1-5.  | UART2 Mode Configurations 2                                                      | 18  |
| TABLE 2-1.  | Default Configurations Controlled by Hardware                                    |     |
| TABLE 2-2.  | Configuration Registers                                                          |     |
| TABLE 2-3.  | INDEX and DATA Register Address Options and Configuration Register Accessibility | 21  |
| TABLE 2-4.  | Primary and Secondary Drive Address Selection                                    |     |
| TABLE 2-5.  | Encoded Drive and Motor Pin Information (Bit 4 of FER = 1)                       |     |
| TABLE 2-6.  | Parallel Port Addresses                                                          |     |
| TABLE 2-7.  | COM Port Selection for UART1                                                     | 30  |
| TABLE 2-8.  | COM Port Selection for UART2                                                     | 30  |
| TABLE 2-9.  | Address Selection for COM3 and COM4                                              | 30  |
| TABLE 2-10. | Parallel Port Mode                                                               | 32  |
| TABLE 2-11. | Bit Settings to Enable MRT1, IDLE or IRSL2                                       | 34  |
| TABLE 2-12. | Bit Settings to Enable DR1 or PD                                                 | 34  |
| TABLE 2-13. | ECP DMA Option Selection                                                         | 39  |
| TABLE 2-14. | Parallel Port Plug and Play DMA Settings                                         | 39  |
| TABLE 2-15. | Parallel Port Plug and Play Interrupt Assignment                                 | 40  |
| TABLE 2-16. | Parallel Port Plug and Play Interrupt Mapping                                    | 40  |
| TABLE 2-17. | TDR Bit 5 Values                                                                 | 41  |
| TABLE 2-18. | FDC Plug and Play Interrupt Mapping                                              | 42  |
| TABLE 2-19. | FDC Plug and Play DMA Settings                                                   | 43  |
| TABLE 2-20. | SBAL Reset Values                                                                | 46  |
| TABLE 2-21. | SBAH Reset Values                                                                | 46  |
| TABLE 2-22. | SIRQI1 Plug and Play Interrupt Mapping                                           | 47  |
| TABLE 2-23. | SIRQ1 Interrupt Settings                                                         |     |
| TABLE 2-24. | SIRQI2 Plug and Play Interrupt Mapping                                           | 48  |
| TABLE 2-25. | Selecting MSEN1, DRATE1, CSO or SIRQI2                                           | 48  |
| TABLE 2-26. | SIRQI3 Plug and Play Interrupt Mapping                                           | 49  |
| TABLE 2-27. | Selecting DRV2, DR23, PNF or SIRQI3                                              |     |
| TABLE 2-28. | UART2 Plug and Play DMA Settings for Reception                                   | 50  |
| TABLE 2-29. | UART2 Plug and Play DMA Settings for Transmission                                | 50  |
| TABLE 3-1.  | The FDC Registers and Their Addresses                                            |     |
| TABLE 3-2.  | Drive and Motor Pin Encoding When FER 4 = 1                                      |     |
| TABLE 3-3.  | Drive Enable Hexadecimal Values                                                  |     |
| TABLE 3-4.  | TDR Bit Utilization and Reset Values in Different Drive Modes                    |     |
| TABLE 3-5.  | Media Type Bit Settings                                                          |     |
| TABLE 3-6.  | Data Transfer Rate Encoding                                                      |     |
| TABLE 3-7.  | Write Precompensation Delays                                                     | 65  |
| TABLE 3-8.  | Default Precompensation Delays                                                   |     |
| TABLE 3-9.  | FDC Command Set Summary                                                          |     |
| TABLE 3-10. | Bytes per Sector Codes                                                           |     |
| TABLE 3-11. | Typical Values for PC Compatible Diskette Media                                  |     |
| TABLE 3-12. | Typical Gap Values                                                               |     |
| TABLE 3-13. | Multipliers and Head Settle Time Ranges for Different Data Transfer Rates        |     |
| TABLE 3-14. | DENSEL Encoding                                                                  |     |
| TABLE 3-15. | Effect of Drive Mode and Data Rate on FORMAT TRACK and WRITE DATA Command        | s87 |

| TABLE 3-16. | Effect of GDC Bits on FORMAT TRACK and WRITE DATA Commands               |     |
|-------------|--------------------------------------------------------------------------|-----|
| TABLE 3-17. | Skip Control Effect on READ DATA Command                                 |     |
| TABLE 3-18. | Result Phase Termination Values with No Error                            |     |
| TABLE 3-19. | SK Effect on READ DELETED DATA Command                                   |     |
| TABLE 3-20. | Maximum RECALIBRATE Step Pulses for Values of R255 and ETR               |     |
| TABLE 3-21. | The Effect of Scan Commands on the ST2 Register                          |     |
| TABLE 3-22. | Interrupt Causes Reported by SENSE INTERRUPT                             |     |
| TABLE 3-23. | Defining Bytes to Read or Write Using SET TRACK                          |     |
| TABLE 3-24. | Constant Multipliers for Delay After Processing Factor and Delay Ranges  |     |
| TABLE 3-25. | Constant Multipliers for Delay Before Processing Factor and Delay Ranges |     |
| TABLE 3-26. | STEP Time Interval Calculation                                           |     |
| TABLE 3-27. | VERIFY Command Termination Conditions                                    |     |
| TABLE 4-1.  | Parallel Port Reset States                                               |     |
| TABLE 4-2.  | Standard Parallel Port Registers                                         |     |
| TABLE 4-3.  | SPP Data Register Read and Write Modes                                   |     |
| TABLE 4-4.  | EPP Revision Selection                                                   |     |
| TABLE 4-5.  | Parallel Port Registers in EPP Modes                                     |     |
| TABLE 4-6.  | ECP Modes Encoding                                                       |     |
| TABLE 4-7.  | Parallel Port Registers in ECP Modes                                     |     |
| TABLE 4-8.  | ECP Mode DMA Selection                                                   |     |
| TABLE 4-9.  | ECP Mode Interrupt Selection                                             |     |
| TABLE 4-10. | ECP Modes                                                                |     |
| TABLE 4-11. | Parallel Port Pin Out                                                    |     |
| TABLE 5-1.  | Register Bank Summary                                                    |     |
| TABLE 5-2.  | Bank 0 Serial Controller Base Registers                                  |     |
| TABLE 5-3.  | Non-Extended Mode Interrupt Priorities                                   |     |
| TABLE 5-4.  | Modem Status Event Detection Enable                                      |     |
| TABLE 5-5.  | TX_FIFO Level Selection                                                  |     |
| TABLE 5-6.  | RX_FIFO Level Selection                                                  |     |
| TABLE 5-7.  | Word Length Select Encoding                                              |     |
| TABLE 5-8.  | Bit Settings for Parity Control                                          |     |
| TABLE 5-9.  | Bank Selection Encoding                                                  |     |
| TABLE 5-10. | The Module Operation Modes                                               |     |
| TABLE 5-11. | Bank 1 Register Set                                                      |     |
| TABLE 5-12. | Baud Generator Divisor Settings                                          |     |
| TABLE 5-13. | Bits Cleared On Fallback                                                 |     |
| TABLE 5-14. | Bank 2 Register Set                                                      |     |
| TABLE 5-15. | DMA Threshold Levels                                                     |     |
| TABLE 5-16. | TX_FIFO Size Encoding                                                    |     |
| TABLE 5-17. | RX_FIFO Size Encoding                                                    |     |
| TABLE 5-18. | Prescaler Select                                                         |     |
| TABLE 5-19. | Bank 3 Register Set                                                      |     |
| TABLE 5-20. | Bank 4 Register Set                                                      |     |
| TABLE 5-21. | Sharp-IR or SIR Mode Selection                                           |     |
| TABLE 5-22. | Bank 5 Registers                                                         |     |
| TABLE 5-23. | ST_FIFO Interrupt Threshold Levels                                       |     |
| TABLE 5-24. | Bank 6 Register Set                                                      |     |
| TABLE 5-25. | MIR Pulse Width Settings                                                 |     |
| TABLE 5-26. | FIR Preamble Length                                                      |     |
| TABLE 5-27. | MIR Beginning Flags                                                      |     |
| TABLE 5-28. | Bank 7 Register Set                                                      | 170 |

| TABLE 5.00  |                                                                           | 474 |
|-------------|---------------------------------------------------------------------------|-----|
| TABLE 5-29. | Consumer-IR Carrier Frequency Encoding                                    |     |
| TABLE 5-30. | Carrier Clock Pulse Width Options                                         |     |
| TABLE 5-31. | Consumer-IR, Low Speed Demodulator (RXHSC = 0) (Frequency Ranges in kHz)  |     |
| TABLE 5-32. | Consumer IR, High Speed Demodulator (RXHSC = 1) (Frequency Ranges in kHz) |     |
| TABLE 5-33. | Sharp-IR Demodulator (Frequency Ranges in kHz)                            |     |
| TABLE 5-34. | Transmitter Modulation Mode Selection                                     |     |
| TABLE 5-35. | Infrared Receiver Input Selection                                         |     |
| TABLE 6-1.  | DMA Support in Legacy Mode                                                |     |
| TABLE 6-2.  | DMA Support in Plug and Play Mode                                         |     |
| TABLE 6-3.  | Interrupt Support in Legacy Mode for IRQ3, 4, 6, 7, 9 10 and 11           |     |
| TABLE 6-4.  | Interrupt Support in Legacy Mode for IRQ 5, 12 and 15                     |     |
| TABLE 6-5.  | TRI-STATE Condition for Interrupts in Legacy Mode                         |     |
| TABLE 6-6.  | Interrupt Support in Plug and Play Mode for IRQ3, 4, 6, 7, 9, 10 or 11    |     |
| TABLE 6-7.  | Interrupt Support in Plug and Play Mode for IRQ 5, 12 or 15               |     |
| TABLE 6-8.  | TRI-STATE Conditions for Interrupts in Plug and Play Mode                 |     |
| TABLE 7-1.  | Group 1 Power-Down                                                        |     |
| TABLE 7-2.  | Clock Multiplier Encoding Options                                         |     |
| TABLE 8-1.  | Recommended Operating Conditions at 5 V ± 10%                             |     |
| TABLE 8-2.  | Recommended Operating Conditions at 3.3 V ± 10%                           |     |
| TABLE 8-3.  | Absolute Maximum Ratings                                                  |     |
| TABLE 8-4.  | Capacitance: T <sub>A</sub> = 25° C, f = 1 MHz                            |     |
| TABLE 8-5.  | Power Consumption                                                         |     |
| TABLE 8-6.  | DC Characteristics of Group 1 Pins                                        |     |
| TABLE 8-7.  | DC Characteristics of Group 2 Pins                                        |     |
| TABLE 8-8.  | DC Characteristics of Group 3 Pins                                        |     |
| TABLE 8-9.  | DC Characteristics of Group 4 Pins                                        |     |
| TABLE 8-10. | DC Characteristics of Group 5 Pins                                        |     |
| TABLE 8-11. | DC Characteristics of Group 6 Input Pins                                  |     |
| TABLE 8-12. | DC Characteristics of Group 6 Output Pins                                 |     |
| TABLE 8-13. | DC Characteristics of Group 7 Pins                                        |     |
| TABLE 8-14. | DC Characteristics of Group 8 Pins                                        |     |
| TABLE 8-15. | DC Characteristics of Group 9 Pins                                        |     |
| TABLE 8-16. | DC Characteristics of Group 10 Pins                                       |     |
| TABLE 8-17. | DC Characteristics of Group 11 Pins                                       |     |
| TABLE 8-18. | DC Characteristics of Group 12 Pins                                       |     |
| TABLE 8-19. | DC Characteristics Group 13 Pins                                          |     |
| TABLE 8-20. | Clock Timing Parameters                                                   |     |
| TABLE 8-21. | Nominal t <sub>ICP</sub> and t <sub>DRP</sub> Values                      |     |
| TABLE 8-22. | Microprocessor Interface Timing Parameters                                |     |
| TABLE 8-23. | Baud Output Timing Parameters                                             |     |
| TABLE 8-24. | SIR Transmitter Timing Parameters                                         |     |
| TABLE 8-25. | SIR Receiver Timing Parameters                                            |     |
| TABLE 8-26. | UART, Sharp-IR and Consumer Remote Control Timing                         |     |
| TABLE 8-27. | SIR, MIR and FIR Timing                                                   |     |
| TABLE 8-28. | IRSLn Write Timing                                                        |     |
| TABLE 8-29. | Modem Control Timing Parameters                                           |     |
| TABLE 8-30. | DMA Timing Parameters                                                     |     |
| TABLE 8-31. | Reset Timing Parameters                                                   |     |
| TABLE 8-32. | Write Data Timing Parameters                                              |     |
| TABLE 8-33. | Minimum t <sub>WDW</sub> Values                                           |     |
| TABLE 8-34. | Floppy Disk Drive Control Timing Parameters                               | 211 |

| TABLE 8-35. | Read Data Timing Parameters212                  |
|-------------|-------------------------------------------------|
| TABLE 8-36. | Standard Parallel Port Timing Parameters        |
| TABLE 8-37. | · · · · · · · · · · · · · · · · · · ·           |
|             | Compatibility Mode Timing Parameters            |
| TABLE 8-38. | Enhanced Parallel Port 1.7 Timing Parameters215 |
| TABLE 8-39. | Enhanced Parallel Port 1.9 Timing Parameters216 |
|             |                                                 |
| TABLE 8-40. | Extended Capabilities Port Timing Parameters    |
| TABLE 8-41. | Chip Selection Timing Parameters219             |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
|             |                                                 |
| I           |                                                 |









#### 1.2 SIGNAL/PIN DESCRIPTIONS

Table 1-1 lists the signals of the Chip in alphabetical order. It also shows the pin associated with each signal for the Plastic Quad Flatpack, (PQFP) and Thin Quad Flatpack (TQFP) options. The I/O column describes whether the pin is an input, output, or bidirectional pin (marked as I, O or I/O, respectively). This column also specifies which group in Section 8.2 describes the pin's DC characteristics.

Refer to the glossary for an explanation of abbreviations and terms used in this table and throughout this document. Use the Table of Contents to find more information about each register.

TABLE 1-1. Signal/Pin Description Table

| Symbol                                                                                             | PQFP<br>Pin                                                                                  | TQFP<br>Pin                                                                                  | I/O and<br>Group # | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A0<br>A1<br>A2<br>A3<br>A4<br>A5<br>A6<br>A7<br>A8<br>A9<br>A10<br>A11<br>A12<br>A13<br>A14<br>A15 | 30<br>29<br>28<br>27<br>26<br>25<br>24<br>23<br>22<br>21<br>31<br>62<br>63<br>64<br>66<br>69 | 28<br>27<br>26<br>25<br>24<br>23<br>22<br>21<br>20<br>19<br>29<br>60<br>61<br>62<br>64<br>67 | I<br>Group 1       | Address. These address lines from the microprocessor determine which internal register is accessed. The values of A15-0 have no effect during DMA transfers.  If CFG0 = 0 during reset, A15-0 are used for address decoding.  If CFG0 = 1 during reset, only A10-0 are used for address decoding, and A15-11 are ignored (masked to 0).  In Legacy mode, A10 is used only for ECP decoding.  A15-11 are multiplexed with UART2's signals.                                                         |
| ĀCK                                                                                                | 85                                                                                           | 83                                                                                           | I<br>Group 3       | <b>Acknowledge.</b> This parallel port input signal is pulsed low by an external printer to indicate it received data from the parallel port. This pin is internally connected to a nominal 25 KΩ pull-up resistor. $\overline{\text{ACK}}$ is multiplexed with $\overline{\text{DR1}}$ . (See Table 4-11 for more information).                                                                                                                                                                  |
| ADRATE0<br>ADRATE1                                                                                 | 98<br>48                                                                                     | 96<br>46                                                                                     | O<br>Group 10      | Additional Data Rate signals 0 and 1. These FDC output signals are provided in addition to DRATE1,0 and have a similar function. They reflect the currently selected FDC data rate, (bits 0 and 1 in the Configuration Control Register (CCR) or the Data Rate Select Register (DSR), whichever was written to last).  ADRATE0 is configured when bit 0 of ASC is 1. ADRATE1 is configured when bit 4 of ASC is 1.  ADRATE0 is multiplexed with IRQ5 and ADRATE1 is multiplexed with DENSEL.      |
| AEN                                                                                                | 20                                                                                           | 18                                                                                           | l<br>Group 1       | Address Enable. When set to 1, this pin enables DMA addressing and disables the microprocessor Address. The address lines disabled will be A15-0 or A10-0, depending on whether CFG0 was set to 0 or 1 during reset (respectively).  Access during DMA transfer is NOT affected by this pin.                                                                                                                                                                                                      |
| ĀFD                                                                                                | 78                                                                                           | 76                                                                                           | O<br>Group 11      | <b>Automatic Feed XT.</b> When low this parallel port signal indicates to the external printer that it should automatically line feed after each Carriage Return byte. This signal enters a TRI-STATE <sup>®</sup> condition within 10 nsec after a 0 is loaded into the Control Register bit. An external 4.7 K $\Omega$ pull-up resistor should be attached to this pin. $\overline{\text{AFD}}$ is multiplexed with $\overline{\text{DSTRB}}$ and DENSEL. See Table 4-11 for more information. |

| Symbol            | PQFP<br>Pin                      | TQFP<br>Pin                      | I/O and<br>Group # | Function                                                                                                                                                                                                                                                                     |
|-------------------|----------------------------------|----------------------------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ASTRB             | 81                               | 79                               | O<br>Group 11      | Address Strobe. This active-low signal is used in EPP mode as an address strobe.  ASTRB is multiplexed with SLIN and STEP. See Table 4-11 for more information.                                                                                                              |
| BADDR0<br>BADDR1  | 74<br>73                         | 72<br>71                         |                    | SIO Base Address Straps 0 and 1. These bits must be externally strapped to determine which one of four base address options for the INDEX and DATA registers will be used by the system after reset. See Table 2-3.                                                          |
|                   |                                  |                                  |                    | If BADDR1 = 0 and BADDR0 = 1 during reset, the chip "wakes up" without a base address and the Plug and Play protocol should be applied. For more details see Chapter 2.                                                                                                      |
|                   |                                  |                                  |                    | These pins are internally grounded by a 30 K $\Omega$ pull-down resistor. To strap these pins high, pull them up to $V_{cc}$ with a 10 K $\Omega$ resistor. BADDR0 is multiplexed with $\overline{RTS1}$ , and BADDR1 is multiplexed with SOUT1 (and BOUT1 in PC87338 only). |
| BOUT1<br>BOUT2    | 73 <i>(71)</i><br>65 <i>(63)</i> | 71 <i>(69)</i><br>63 <i>(61)</i> | O<br>Group 7       | <b>UART Baud Output signals 1 and 2.</b> These multi-function pins provide the associated serial channel Baud Rate generator output signal for UART 1 or UART2, if test mode is selected in the Power and Test Configuration Register (PTR) and the DLAB bit (LCR7) is set.  |
|                   |                                  |                                  |                    | BOUT1 is multiplexed with SOUT1 and BADDR1. BOUT2 is multiplexed with SOUT2, IRTX and CFG0 (in PC87338 only).  BOUT1 is multiplexed with DTR1. BOUT2 is multiplexed with DTR2 and A12 (in PC97338 only).                                                                     |
| BUSY              | 84                               | 82                               | I<br>Group 2       | <b>Busy.</b> This parallel port signal is set high by the external printer when it cannot accept another character. This pin is internally grounded by a nominal 25 K $\Omega$ pull-down resistor.                                                                           |
|                   |                                  |                                  |                    | BUSY is multiplexed with $\overline{\text{MTR1}}$ and $\overline{\text{WAIT}}$ . (See Table 4-11 for more information).                                                                                                                                                      |
| CFG0              | 65                               | 63                               | I<br>Group 9       | <b>Con guration.</b> This CMOS input signal is externally strapped to select one of two default configurations in which the Chip powers up (see Table 2-1).                                                                                                                  |
|                   |                                  |                                  |                    | This pin is internally grounded by a 30 K $\Omega$ pull-down resistor. To strap this pin high, pull it up to $V_{CC}$ with a 10 K $\Omega$ resistor. CFG0 is multiplexed with SOUT2 and IRTX.                                                                                |
| <u>CS0</u><br>CS1 | 51<br>3                          | 49<br>1                          |                    | Programmable Chip Select signals 0 and 1. $\overline{\text{CS1,0}}$ are programmable chip select and/or latch enable and/or output enable signals that can be used as game port, I/O expander, etc.                                                                          |
|                   |                                  |                                  |                    | The decoded address and the assertion conditions are configured via the Chip configuration registers, indexed by 0Ah-0Dh, 10h-11h, 03h and 4Dh.                                                                                                                              |
|                   |                                  |                                  |                    | CS1,0 are push-pull output signals.  CS0 is multiplexed with DRATE1, MSEN1, SIRQI2 and DACK3.  CS1 is multiplexed with ZWS.                                                                                                                                                  |

| Symbol                                       | PQFP<br>Pin                            | TQFP<br>Pin                           | I/O and<br>Group # | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------------------------------------|----------------------------------------|---------------------------------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CTS1<br>CTS2                                 | 72<br>64                               | 70<br>62                              | I<br>Group 1       | UART Clear to Send signals 1 and 2. When low, this signal indicates that the modem or data transfer device is ready to exchange data.  The CTS signal is a modem status input signal whose condition can be tested by reading bit 4 (CTS) of the Modem Status Register (MSR) for the appropriate serial channel. Bit 4 is the complement of the CTS signal. Bit 0 (DCTS) of the MSR indicates whether the CTS input has changed state since the previous reading of the MSR. CTS has no effect on the transmitter.  If modem status interrupts are enabled, an interrupt is generated whenever the DCTS bit of the MSR is set.  CTS2 is multiplexed with A13. When CTS2 is not selected, it is masked to 0. |
| D0<br>D1<br>D2<br>D3<br>D4<br>D5<br>D6<br>D7 | 17<br>16<br>15<br>14<br>13<br>12<br>11 | 15<br>14<br>13<br>12<br>11<br>10<br>9 | I/O<br>Group 6     | <b>Data.</b> These signals are bi-directional data lines to the microprocessor. D0 is the LSB and D7 is the MSB.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| DACK0                                        | 55                                     | 53                                    | I<br>Group 1       | DMA Acknowledge 0. An active low input signal used to acknowledge DMA request 0 (DRQ0), and to enable the RD and WR input signals during a DMA transfer. It can be used by either the FDC, or the UART2 or the parallel port. If none of them uses this input signal, it is ignored. If the device which uses this signal is disabled or configured with no DMA, the signal is also ignored. Upon reset, it is ignored.                                                                                                                                                                                                                                                                                     |
| DACK1                                        | 54                                     | 52                                    | I<br>Group 1       | DMA Acknowledge 1. An active low input signal used to acknowledge DMA request 1 (DRQ1), and enable the RD and WR input signals during a DMA transfer. It can be used by one of the following: FDC, UART2 or parallel port. If none of them uses this input signal, it is ignored. If the device which uses this signal is disabled or configured with no DMA, the signal is also ignored. Upon reset, it is ignored.                                                                                                                                                                                                                                                                                        |
| DACK2                                        | 5                                      | 3                                     | I<br>Group 1       | DMA Acknowledge 2. An active low input signal used to acknowledge DMA request 2 (DRQ2), and enable the RD and WR input signals during a DMA transfer. It can be used by one of the following: FDC, UART2 or parallel port. If none of them uses this input signal, it is ignored. If the device which uses this signal is disabled or configured with no DMA, the signal is also ignored. Upon reset, it is used by the FDC.                                                                                                                                                                                                                                                                                |
| DACK3                                        | 51                                     | 49                                    | I<br>Group 1       | DMA Acknowledge 3. An active low input signal used to acknowledge DMA request 3 (DRQ3), and enable the RD and WR inputs during a DMA transfer. It can be used by one of the following: FDC, UART2 or parallel port. If none of them uses this input signal, it is ignored. If the device which uses this signal is disabled or configured with no DMA, the signal is also ignored. Upon reset, it is used by the FDC. DACK3 is multiplexed with DRATE1, MSEN1, CSO and SIRQI2.                                                                                                                                                                                                                              |

| Symbol                     | PQFP<br>Pin | TQFP<br>Pin | I/O and<br>Group # | Function                                                                                                                                                                                                                                                                                                                                                              |
|----------------------------|-------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DCD1<br>DCD2               | 77<br>69    | 75<br>67    | I<br>Group 1       | <b>UART Data Carrier Detect signals 1 and 2.</b> When low, this signal indicates that the modem or data transfer device has detected the data carrier.                                                                                                                                                                                                                |
|                            |             |             |                    | The DCD2,1 signals are modem status input signals whose condition can be tested by reading bit 7 (DCD) of the Modem Status Register (MSR) for the appropriate serial channel. Bit 7 is the complement of the DCD signal. Bit 3 (DDCD) of the MSR indicates whether the DCD input signal has changed state since the previous reading of the MSR.                      |
|                            |             |             |                    | If modem status interrupts are enabled, an interrupt is generated whenever the DDCD bit of the MSR is set to 1.  DCD2 is multiplexed with A15. When DCD2 is not selected, it is masked to 1.                                                                                                                                                                          |
| DENSEL<br>(Normal<br>Mode) | 48          | 46          | O<br>Group 10      | <b>Density Select.</b> Indicates that a high density FDC data rate (500 Kbps, 1 Mbps or 2 Mbps) or a low density data rate (250 Kbps or 300 Kbps) is selected. The polarity of DENSEL is controlled via bit 6 of the ASC register. The default is active high for high density. DENSEL is also programmable via the MODE command. DENSEL is multiplexed with ADRATE1. |
| (PPM<br>Mode)              | 78          | 76          | O<br>Group 10      | <b>Density Select.</b> This pin provides an additional Density Select signal in PPM mode when PNF = $0$ . DENSEL is multiplexed with $\overline{AFD}$ , $\overline{DSTRB}$ . See Table 4-11 for more information.                                                                                                                                                     |
| DIR<br>(Normal<br>Mode)    | 41          | 39          | O<br>Group 10      | <b>Direction.</b> This FDC output signal determines the direction of the Floppy Disk Drive (FDD) head movement (active = step in, inactive = step out) during a seek operation. During read or write operations, DIR is inactive.                                                                                                                                     |
| (PPM<br>Mode)              | 80          | 78          | O<br>Group 10      | <b>Direction.</b> This FDC pin provides an additional direction signal in PPM Mode when PNF = $0$ . $\overline{DIR}$ is multiplexed with $\overline{INIT}$ . See Table 4-11 for more information.                                                                                                                                                                     |
| DR0<br>DR1<br>(Normal      | 44<br>45    | 42<br>43    | O<br>Group 10      | <b>FDC Drive Select signals 0 and 1.</b> These FDC signals are decoded drive select output signals controlled by Digital Output Register bits D0 and D1.                                                                                                                                                                                                              |
| Mode)                      |             |             |                    | These signals are gated with DOR bits 7 through 4. These are active low output signals. They are encoded with information to control four FDDs when bit 4 of the Function Enable Register (FER) is set. DR0,1 are exchanged only via the TDR register. (Bit 4 of the FCR register is reserved.)  DR1 is multiplexed with PD.                                          |
| DR1<br>(PPM<br>Mode)       | 85          | 83          | O<br>Group 10      | <b>FDC Drive Select 1.</b> This signal provides an additional drive select signal in PPM mode when PNF = 0. It is drive select 1 when bit 4 of FCR is 0. It is drive select 0 when bit 4 of FCR is 1. This signal is active low. $\overline{DR1}$ is multiplexed with $\overline{ACK}$ . See Table 4-11 for more information.                                         |
| DR23                       | 49          | 47          | O<br>Group 10      | Drive 2 or 3. This FDC signal is asserted when either drive 2 or drive 3 is accessed (except during logical drive exchange, see bit 3 of TDR). This pin is configured when bits 7, 6 of SIRQ3 are 01.  DR23 is multiplexed with IRSL0, DRV2, SIRQI3 and PNF.                                                                                                          |

| Symbol                               | PQFP<br>Pin         | TQFP<br>Pin         | I/O and<br>Group # | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------------------------------|---------------------|---------------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DRATE0<br>DRATE1<br>(Normal<br>Mode) | 52<br>51            | 50<br>49            | O<br>Group 8       | Data Rates 0 and 1. These FDC output signals reflect the currently selected FDC data rate, (bits 1 and 0 in the Configuration Control Register (CCR) or the Data Rate Select Register (DSR), whichever was written to last). The pins are totem-pole buffered output signals (6 mA sink, 6 mA source).  DRATE0 is multiplexed with MSEN0. DRATE1 is multiplexed with MSEN1, SIRQI2, CSO and DACK3.                                                                                                                           |
| DRATE0<br>(PPM<br>Mode)              | 87                  | 85                  | O<br>Group 8       | Data Rate 0. This pin provides an additional FDC data rate signal, in PPM mode, when PNF = 0.  DRATE0 is multiplexed with PD6. See Table 4-11 for more information.                                                                                                                                                                                                                                                                                                                                                          |
| DRQ0<br>DRQ1<br>DRQ2<br>DRQ3         | 56<br>33<br>4<br>60 | 54<br>31<br>2<br>58 | O<br>Group 6       | DMA Requests 0, 1, 2 and 3. These active high outputs signal the DMA controller that a data transfer is required.  This DMA request can be sourced by one of the following: FDC, UART2 or parallel port. When not sourced by any of them, it is in TRI-STATE. In Plug and Play mode, when the sourced device is disabled or when the sourced device is configured with no DMA, it is also in TRI-STATE. Upon reset, DRQ2 is used by the FDC; and DRQ0,1 and 3 are in TRI-STATE.  DRQ3 is multiplexed with IRQ15, and SIRQI1. |
| DRV2                                 | 49                  | 47                  | I<br>Group 4       | Drive2. This FDC input signal indicates (low) when a second disk drive has been installed. The state of this signal is available from Status Register A in PS/2 mode. This pin is configured when bits 7 and 6 of SIRQ3 are 00.  DRV2 is multiplexed with DR23, PNF, SIRQI3 and IRSL2.                                                                                                                                                                                                                                       |
| DSKCHG<br>(Normal<br>Mode)           | 32                  | 30                  | I<br>Group 4       | <b>Disk Change.</b> This FDC input signal indicates if the drive door is open. The state of this signal is available from the Digital Input Register (DIR). This signal can also be configured as the RGATE data separator diagnostic input signal via the MODE command (see "The MODE Command" on page -84)                                                                                                                                                                                                                 |
| (PPM<br>Mode)                        | 89                  | 87                  | I<br>Group 4       | <b>Disk Change.</b> This signal provides an additional FDC Disk Change signal in PPM Mode when PNF = 0.DSKCHG is multiplexed with PD4. See Table 3-2 for more information.                                                                                                                                                                                                                                                                                                                                                   |
| DSR1<br>DSR2                         | 76<br>68            | 74<br>66            | I<br>Group 1       | Data Set Ready signals 1 and 2. When low, these UART signals indicates that the appropriate data transfer device or modem is ready to establish a communications link. The DSR signal is a modem status input whose condition can be tested by reading bit 5 (DSR) of the Modem Status Register (MSR) for the appropriate channel. Bit 5 is the complement of the DSR signal. Bit 1 (DDSR) of the MSR indicates whether the DSR input signal has changed state since the previous reading of the MSR.                        |
|                                      |                     |                     |                    | If modem status interrupts are enabled an interrupt is generated whenever the DDSR bit of the MSR is set.  When DSR2 is not selected, it is masked to 0.  DSR2 is multiplexed with IRRX2, IRQ12 and IRSL0.                                                                                                                                                                                                                                                                                                                   |
| DSTRB                                | 78                  | 76                  | O<br>Group 11      | Data Strobe. This signal is used in EPP mode as a data strobe. It is active low.  DSTRB is multiplexed with AFD, DENSEL. See Table 4-11 for more information.                                                                                                                                                                                                                                                                                                                                                                |

| Symbol                    | PQFP<br>Pin | TQFP<br>Pin | I/O and<br>Group # | Function                                                                                                                                                                                                                                                                                                                                                        |
|---------------------------|-------------|-------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DTR1<br>DTR2              | 71<br>63    | 69<br>61    | O<br>Group 7       | Data Terminal Ready signals 1 and 2. When low, these UART output signals indicate to the appropriate modem or data transfer device that the UART is ready to establish a communications link.                                                                                                                                                                   |
|                           |             |             |                    | The DTR signal can be set to active low by programming bit 0 (DTR) of the Modem Control Register (MCR) to a high level. A Master Reset (MR) operation sets this signal to its inactive (high) state. Loop mode operation holds this signal to its inactive state.  DTR2 is multiplexed with A12 (and BOUT2 in PC97338 only).                                    |
| ERR                       | 79          | 77          | I<br>Group 3       | <b>Error.</b> This parallel port input signal is set low by the external printer when it has detected an error. This pin is internally connected to a nominal 25 K $\Omega$ pull-up resistor.<br>$\overline{\text{ERR}}$ is multiplexed with $\overline{\text{HDSEL}}$ . See Table 4-11 for more information.                                                   |
| HDSEL<br>(Normal<br>Mode) | 34          | 32          | O<br>Group 10      | <b>Head Select.</b> This FDC output signal determines which side of the FDD is accessed. Active (low) selects side 1, inactive (high) selects side 0.                                                                                                                                                                                                           |
| (PPM<br>Mode)             | 79          | 77          | O<br>Group 10      | <b>Head Select.</b> This signal provides an additional head select signal in PPM mode when PNF = $0$ . HDSEL is multiplexed with ERR. See Table 4-11 for more information.                                                                                                                                                                                      |
| ID2                       | 43 or<br>49 | 41 or<br>47 | I<br>Group 1       | Identi cation – These ID signals identify the infrared transceiver for Plug and Play support. These pins are read after reset. These pins are available only in PC97338.                                                                                                                                                                                        |
| ID1                       | 8           | 6           |                    | ID2 is multiplexed with MTR1, IDLE and IRSL2 or with DRV2, PNF, DR23, SIRQI3 and IRSL2.                                                                                                                                                                                                                                                                         |
| ID0                       | 68          | 66          |                    | ID1 is multiplexed with IRSL1. ID0 is multiplexed with $\overline{DSR2}$ , IRQ12, IRRX2 and IRSL0.                                                                                                                                                                                                                                                              |
| IDLE                      | 43          | 41          | Group 10           | Idle. This FDC output pin is used for an IDLE output signal when bit 4 of PMC is 1. It is used for MTR1 when bit 4 of PMC is 0. IDLE indicates that the FDC is in the Idle state and can be powered down. Whenever the FDC is in the Idle state, or whenever the FDC is in a power-down state, the pin is active high. IDLE is multiplexed with MTR1 and IRSL2. |
| INDEX<br>(Normal<br>Mode) | 47          | 45          | I<br>Group 4       | Index. This input signal indicates the beginning of an FDD track.                                                                                                                                                                                                                                                                                               |
| (PPM<br>Mode)             | 94          | 92          |                    | <b>FDC Index.</b> This signal provides an additional index signal in PPM mode when PNF = 0.INDEX is multiplexed with PD0. See Table 4-11 for more information.                                                                                                                                                                                                  |
| INIT                      | 80          | 78          | O<br>Group 11      | Parallel Port Initialize. When this signal is low, it causes the printer to be initialized. This signal is in a TRI-STATE condition 10 nsec after a 1 is loaded into the corresponding Control Register bit. The system should pull this pin high using a 4.7 KΩ resistor. $\overline{\text{INIT}}$ is multiplexed with $\overline{\text{DIR}}$ .               |
| IOCHRDY                   | 53          | 51          | Group 13           | I/O Channel Ready. This is the I/O Channel Ready open-drain output signal. When IOCHRDY is driven low, the EPP extends the host cycle.                                                                                                                                                                                                                          |

| Symbol                           | PQFP<br>Pin          | TQFP<br>Pin          | I/O and<br>Group # | Function                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                            |
|----------------------------------|----------------------|----------------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IRQ3<br>IRQ4<br>IRQ5<br>IRQ6     | 1<br>100<br>98<br>97 | 99<br>98<br>96<br>95 | I/O<br>Group 6     | Interrupts Requests 3, 4, 5, 6, 7, 9, 10, 11, 12 and 15. These signals are used to request an interrupt from the host processor, when appropriate. These output pins can be configured as totempole or open-drain outputs (see below).                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                            |
| IRQ7<br>IRQ9<br>IRQ10<br>IRQ11   | 96<br>57<br>58<br>59 | 94<br>55<br>56<br>57 |                    | Any of these interrupt request lines may be assigned to any one of the following: UART1, UART2, parallel port, FDC, SIRQI1 signal, SIRQI2 signal, or SIRQI3 signal. For more details, refer to Chapters 2 and 6.                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                            |
| IRQ12<br>IRQ15<br>(Plug and      | 68<br>60             | 66<br>58             |                    | When the parallel port's interrupt is routed to one of these pins, bit 6 of the PCR determines whether the output signal is totem pole or open drain. Otherwise, they are totem-pole outputs.                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                            |
| Play mode)                       |                      |                      |                    | This pin is I/O only when the parallel port's interrupt is routed to this pin, ECP is enabled and bit 6 of PCR is 1. The Plug and Play mode is determined by bit 3 of PNP0.                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                            |
|                                  |                      |                      |                    | IRQ5 is multiplexed with ADRATE0.                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                            |
|                                  |                      |                      |                    | IRQ12 is multiplexed with DSR2, IRRX2 and IRSL0.                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                            |
|                                  |                      |                      |                    | IRQ15 is multiplexed with SIRQI1 and DRQ3.                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                            |
| IRQ3<br>IRQ4<br>(Legacy<br>mode) | 1<br>100             | 99<br>98             | O<br>Group 6       | Interrupts 3 and 4. These are active high interrupts associated with the serial ports. IRQ3 presents the device interrupt request if the serial channel has been designated as COM2 or COM4. IRQ4 presents the device interrupt request if the serial port is designated as COM1 or COM3.                                                                                                                          |                                                                                                                                                                                                                                                                                                                            |
|                                  |                      |                      |                    |                                                                                                                                                                                                                                                                                                                                                                                                                    | The appropriate interrupt is enabled via IER, the associated Interrupt Enable bit (Modem Control Register (MCR) bit 3), and the interrupt request is actually triggered when one of the following events occur: Receiver Error, Receive Data available, Transmitter Holding Register Empty, or a Modem Status Flag is set. |
|                                  |                      |                      |                    | The interrupt request signal becomes inactive (low) after the appropriate interrupt service routine is executed, after being disabled via the IER, or after a Master Reset. Either interrupt can be disabled and put in TRI-STATE by setting bit 3 of the MCR low                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                            |
| IRQ5<br>(Legacy<br>mode)         | 98                   | 96                   | I/O<br>Group 6     | Interrupt 5. This active high output signal indicates a parallel port interrupt request. When enabled, this signal follows the ACK signal input. When bit 4 in the parallel port Control Register is set and the parallel port address is designated as shown in Table 2-6, this interrupt is enabled. When not enabled this signal is TRI-STATE. This pin is I/O only when ECP is enabled, and IRQ5 is configured |                                                                                                                                                                                                                                                                                                                            |
| IRQ6<br>(Legacy<br>mode)         | 97                   | 95                   | O<br>Group 6       | Interrupt 6. This active high output signal indicates an interrupt request upon completion of the execution phase for certain FDC commands. It also signals when a data transfer is ready during a non-DMA operation. In PC-AT or Model 30 mode, this signal is enabled by bit D3 of the DOR. In PS/2 mode, IRQ6 is always enabled, and bit D3 of the DOR is reserved.                                             |                                                                                                                                                                                                                                                                                                                            |
| IRQ7<br>(Legacy<br>mode)         | 96                   | 94                   | I/O<br>Group 6     | Interrupt 7. This active high output signal indicates a parallel port interrupt request. When enabled, this signal follows the ACK signal input. When bit 4 in the parallel port Control Register is set and the parallel port address is designated as shown in Table 2-6, this interrupt is enabled. When not enabled, this signal is in TRI-STATE.                                                              |                                                                                                                                                                                                                                                                                                                            |
|                                  |                      |                      |                    | This pin is I/O only when ECP is enabled, and IRQ7 is configured. For ECP operation, refer to the interrupt ECP in Section 4.5.5.                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                            |

| Symbol                             | PQFP<br>Pin         | TQFP<br>Pin         | I/O and<br>Group # | Function                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------------------------------|---------------------|---------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IRRX1<br>IRRX2                     | 67<br>68            | 65<br>66            | I<br>Group 1       | Infrared Received data signals 1 and 2. Infrared serial data input signals. The infrared Analog Front End (AFE) is expected to send 1 to IRRX if there is no transmission. If it sends 0, the input signal should be inverted by RXINV (bit 4 of register 7, in bank 7 of UART2 - See Section 5.20.8).                                                                                                                |
|                                    |                     |                     |                    | IRRX1 is multiplexed with SIN2. IRRX2 is multiplexed with DSR2, IRQ12 and IRSL0.                                                                                                                                                                                                                                                                                                                                      |
| IRSL0<br>IRSL1<br>IRSL2            | 68<br>8<br>43 or 49 | 66<br>6<br>41 or 47 | Group 12           | Infrared Control signals 0, 1 and 2. These signals control the infrared Analog Front End (AFE).  IRSL0 is multiplexed with DSR2, IRQ12, IRRX2 (and ID0 in PC97338).                                                                                                                                                                                                                                                   |
|                                    |                     |                     |                    | IRSL1 is multiplexed with ID1 in PC97338.                                                                                                                                                                                                                                                                                                                                                                             |
|                                    |                     |                     |                    | IRSL2 is multiplexed with either DRV2, PNF, DR23, SIRQI3 (and ID2 in PC97338), or with MTR1, IDLE (and ID2 in PC97338).                                                                                                                                                                                                                                                                                               |
| IRTX                               | 65                  | 63                  | 0                  | Infrared Transmitted data. Infrared serial data output.                                                                                                                                                                                                                                                                                                                                                               |
|                                    |                     |                     | Group 12           | IRTX is multiplexed with SOUT2, CFG0 (and BOUT2 in PC87338)                                                                                                                                                                                                                                                                                                                                                           |
| MR                                 | 2                   | 100                 | I<br>Group 1       | <b>Master Reset.</b> Active high input signal that resets the controller to the idle state. The configuration registers are set to their selected default values. See the reset status for each functional unit.                                                                                                                                                                                                      |
| MSEN0<br>MSEN1<br>(Normal<br>Mode) | 52<br>51            | 50<br>49            | I<br>Group 4       | Media Sense signals 0 and 1. MSEN0 is selected as a media sense input signal when bit 1 of the FCR register is 0. MSEN1 is selected as a media sense input signal when bits 7 and 6 of the SIRQ2 register are 00.                                                                                                                                                                                                     |
|                                    |                     |                     |                    | Each pin is internally connected to a 10 K $\Omega$ pull-up resistor. When bit 1 of FCR is 1, pin 52 is used as a Data Rate 0 output pin, and the pull-up resistor is disabled. When $\overline{DACK3}$ , DRATE1, $\overline{CS0}$ or SIRQI2 is selected on the pin, MSEN1 is masked to 1. MSEN0 is multiplexed with DRATE0. MSEN1 is multiplexed with $\overline{DACK3}$ , $\overline{CS0}$ , SIRQI2 and DRATE1.     |
| MSEN0<br>MSEN1<br>(PPM             | 88<br>86            | 86<br>84            | I<br>Group 4       | Media Sense signals 0 and 1. These signals provide additional media sense signals in PPM mode when PNF = 0.  MSEN0 and MSEN1 are multiplexed with PD5 and PD7,                                                                                                                                                                                                                                                        |
| Mode)                              |                     |                     |                    | respectively. See Table 4-11 for more information.                                                                                                                                                                                                                                                                                                                                                                    |
| MTR0<br>MTR1<br>(Normal<br>Mode)   | 46<br>43            | 44<br>41            | O<br>Group 10      | FDC Motor Select signals 0 and 1. These motor enable lines for drives 0 and 1 are controlled by bits 7 through 4 of the Digital Output register. They are active low output signals. They are encoded with information to control four FDDs (MTR0 exchanges logical motor values with MTR1) according to the TDR register settings.  Bit 4 of the FCR register is reserved.  MTR1 is multiplexed with IDLE and IRSL2. |
| MTR1<br>(PPM<br>Mode)              | 84                  | 82                  | O<br>Group 10      | register. Bit 4 of the FCR register is reserved.                                                                                                                                                                                                                                                                                                                                                                      |
|                                    |                     |                     |                    | MTR1 is multiplexed with BUSY and WAIT. See Table 4-11 for more information.                                                                                                                                                                                                                                                                                                                                          |

| Symbol                                               | PQFP<br>Pin                                  | TQFP<br>Pin                                  | I/O and<br>Group #                | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------------------------------------------------|----------------------------------------------|----------------------------------------------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PD                                                   | 45                                           | 43                                           | O<br>Group 10                     | Power Down. This pin is used for the FDC Power-Down (PD) output signal when bit 4 of PMC is 1. It is used for DR1 when bit 4 of PMC is 0. PD is active high whenever the FDC is put into a power-down state by bit 6 of DSR (or bit 3 of FER, or bit 0 of PTR), or by the MODE command.  PD is multiplexed with DR1.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| PD0<br>PD1<br>PD2<br>PD3<br>PD4<br>PD5<br>PD6<br>PD7 | 94<br>93<br>92<br>91<br>89<br>88<br>87<br>86 | 92<br>91<br>90<br>89<br>87<br>86<br>85<br>84 | I/O<br>Group 1<br>and<br>Group 11 | Parallel- Port Data signals 0 through 7. These bidirectional pins transfer data to and from the peripheral data bus and the parallel port Data Register. These pins have high current drive capability. See "Device Description" on page 8-192.  PD7-0 are multiplexed with INDEX, TRK0, WP, RDATA, DSKCHG, MSEN0, DRATE0 and MSEN1, respectively. See Table 4-11 for more information.                                                                                                                                                                                                                                                                                                                                                                                            |
| PE                                                   | 83                                           | 81                                           | I<br>Group 2                      | <b>Paper End.</b> This parallel port input signal is set high by the external printer when it is out of paper. This pin is internally grounded by a nominal 25 K $\Omega$ pull-down resistor. PE is multiplexed with $\overline{\text{WDATA}}$ . See Table 4-11 for more information.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| PNF                                                  | 49                                           | 47                                           | I<br>Group 1                      | Printer Not Floppy. PNF is the Printer Not Floppy signal. It selects the device which is connected to the PPM pins.  When a parallel printer is connected, PNF must be set to 1, and when a floppy disk drive is connected, PNF must be set to 0. This pin is configured as PNF when bits 7 and 6 of SIRQ3 are 10.  PNF is multiplexed with DRV2, DR23, SIRQI3 and IRSL2.                                                                                                                                                                                                                                                                                                                                                                                                          |
| RD                                                   | 19                                           | 17                                           | I<br>Group 1                      | Read. Active low input signal to indicate a data read by the microprocessor.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| RDATA<br>(Normal<br>Mode)                            | 35                                           | 33                                           | I<br>Group 4                      | <b>Read Data.</b> This input signal is the raw serial data read from the floppy disk drive.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| (PPM<br>Mode)                                        | 91                                           | 89                                           | I<br>Group 4                      | Read Data. This pin provides an additional read data signal in PPM mode when PNF = 0.  RDATA is multiplexed with PD3. See Table 4-11 for more information.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| RI1<br>RI2                                           | 70<br>62                                     | 68<br>60                                     | I<br>Group 1                      | Ring Indicators 1 and 2. When low, these UART signals indicates that a telephone ring signal has been received by the appropriate modem. The $\overline{\text{RI}}$ signal is a modem status input signal whose condition can be tested by reading bit 6 (RI) of the Modem Status Register (MSR) for the appropriate serial channel. Bit 6 is the complement of the $\overline{\text{RI}}$ signal. Bit 2 (TERI) of the MSR indicates whether the $\overline{\text{RI}}$ input signal has changed from low to high since the previous reading of the MSR. When the TERI bit of MSR is set to 1, an interrupt is generated if modem status interrupts are enabled. $\overline{\text{RI2}}$ is multiplexed with A11. When $\overline{\text{RI2}}$ is not selected, it is masked to 1. |

| Symbol                     | PQFP<br>Pin    | TQFP<br>Pin    | I/O and<br>Group # | Function                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------------------|----------------|----------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RTS1<br>RTS2               | 74<br>66       | 72<br>64       | O<br>Group 7       | Requests to Send 1 and 2. When low, this output signal indicates to the modem or data transfer device that the appropriate UART is ready to exchange data.                                                                                                                                                                                                                                                           |
|                            |                |                |                    | The RTS signal can be set to active low by programming bit 1 (RTS) of the Modem Control Register (MCR) to a high level. A Master Reset operation sets this signal to its inactive (high) state. Loop mode operation holds this signal to its inactive state.  RTS1 is multiplexed with BADDR0.  RTS2 is multiplexed with A14.                                                                                        |
| SIN1<br>SIN2               | 75<br>67       | 73<br>65       | I<br>Group 1       | Serial Input data 1 and 2. These UART input signals receive composite serial data from the communications link (peripheral device, modem, or data transfer device).  SIN2 is multiplexed with IRRX1.                                                                                                                                                                                                                 |
| SIRQI1<br>SIRQI2<br>SIRQI3 | 60<br>51<br>49 | 58<br>49<br>47 | I<br>Group 1       | System IRQ Input signals 1, 2 and 3. These input signals can be routed to one of the following output pins: IRQ7-3 or IRQ12-9. SIRQI2 and SIRQI3 can also be routed to IRQ15. Software configuration determines to which output pin the input signal is routed.  SIRQI1 is multiplexed with IRQ15 and DRQ3.                                                                                                          |
|                            |                |                |                    | SIRQI2 is multiplexed with DRATE1, MSEN1, CS0 and DACK3. SIRQI3 is multiplexed with $\overline{DRV2}$ , PNF, $\overline{DR23}$ and IRSL2.                                                                                                                                                                                                                                                                            |
| SLCT                       | 82             | 80             | I<br>Group 2       | Select. This parallel port input signal is set high by the printer when it is selected. This pin is grounded by an internal nominal 25 K $\Omega$ pull-down resistor. SLCT is multiplexed with $\overline{\text{WGATE}}$ .                                                                                                                                                                                           |
| SLIN                       | 81             | 79             | I/O<br>Group 11    | Select Input. When this parallel port signal is low, it selects the external printer. This signal enters TRI-STATE within 10 nsec after a 0 is loaded into the corresponding Control Register bit. An external 4.7 K $\Omega$ pull-up resistor to V <sub>CC</sub> must be connected to this pin. SLIN is multiplexed with $\overline{\text{ASTRB}}$ , $\overline{\text{STEP}}$ . See Table 4-11 for more             |
| SOUT1<br>SOUT2             | 73<br>65       | 71<br>63       | O<br>Group 7       | information.  Serial Output signals 1 and 2 These UART output signals send composite serial data to the communications link (peripheral device, modem, or data transfer device). The SOUT signal is set to a marking state (logic 1) after a Master Reset operation.  SOUT1 is multiplexed with BADDR1 (and BOUT1 in PC87338).  SOUT2 is multiplexed with IRTX, CFG0 (and BOUT2 in PC87338).                         |
| STB                        | 95             | 93             | I/O<br>Group 11    | Strobe. This output signal indicates to the printer that valid data is available at the parallel port. This pin enters TRI-STATE within 10 nsec after a 0 is loaded into the corresponding Control Register bit. An external 4.7 K $\Omega$ pull-up resistor to $V_{CC}$ must be connected to this pin. $\overline{STB} \text{ is multiplexed with } \overline{WRITE}. \text{ See Table 4-11 for more information.}$ |

| Symbol                    | PQFP<br>Pin         | TQFP<br>Pin         | I/O and<br>Group # | Function                                                                                                                                                                                                                                                                                                                                                                  |
|---------------------------|---------------------|---------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| STEP<br>(Normal<br>Mode)  | 40                  | 38                  | O<br>Group 10      | <b>Step.</b> This FDC output signal issues pulses to the disk drive at a software programmable rate to move the head during a seek operation.                                                                                                                                                                                                                             |
| (PPM<br>Mode)             | 81                  | 79                  | O<br>Group 10      | <b>Step.</b> This pin provides an additional step signal in PPM mode when PNF = 0. STEP is multiplexed with SLIN and ASTRB. See Table 4-11 for more information.                                                                                                                                                                                                          |
| TC                        | 6                   | 4                   | I<br>Group 1       | Terminal Count. This control signal from the DMA controller indicates the termination of a DMA block transfer. TC is accepted by the module (FDC, parallel port or UART2) only when the corresponding DMA acknowledge signal (DACK0, DACK1, DACK2 or DACK3, according to software configuration) is active. TC is active high in PC-AT mode, and active low in PS/2 mode. |
| TRK0<br>(Normal<br>Mode)  | 37                  | 35                  | I<br>Group 4       | <b>Track 0.</b> This FDC input indicates to the controller that the head of the selected floppy disk drive is at track zero.                                                                                                                                                                                                                                              |
| (PPM<br>Mode)             | 93                  | 91                  | I<br>Group 4       | Track 0. This pin provides an additional Track 0 signal in PPM Mode when PNF = 0.  TRK0 is multiplexed with PD1 (See Table 4-11 for more information).                                                                                                                                                                                                                    |
| VDD                       | 50<br>99            | 48,<br>97           | I                  | <b>Power Supply signals.</b> These pins input the 3.3 V or 5 V supply voltage to the ChipVLJ and ChipVJG device.  See "Recommended Operating Conditions" on page 8-192.                                                                                                                                                                                                   |
| VSS                       | 42<br>9<br>90<br>61 | 40<br>7<br>88<br>59 | 0                  | Ground signals. These pins ground the ChipVLJ and ChipVJG circuitry.  See "Recommended Operating Conditions" on page 8-192.                                                                                                                                                                                                                                               |
| WAIT                      | 84                  | 82                  | I<br>Group 1       | Wait. This signal is used in EPP mode, by the parallel port device, to extend its access cycle. It is active low.  WAIT is multiplexed with BUSY and MTR1. See Table 4-11 for more information.                                                                                                                                                                           |
| WDATA<br>(Normal<br>Mode) | 39                  | 37                  | O<br>Group 10      | FDC Write Data. This FDC output signal is the write precompensated serial data that is written to the selected floppy disk drive. Precompensation is software selectable.                                                                                                                                                                                                 |
| (PPM<br>Mode)             | 83                  | 81                  | O<br>Group 10      | FDC Write Data. This pin provides an additional WDATA signal in PPM mode when PNF = 0.  WDATA is multiplexed with PE. See Table 4-11 for more information.                                                                                                                                                                                                                |
| WGATE<br>(Normal<br>Mode) | 38                  | 36                  | O<br>Group 10      | <b>FDC Write Gate.</b> This FDC <u>output</u> signal enables the write circuitry of the selected disk drive. WGATE is designed to prevent glitches during power up and power down. This prevents writing to the disk when power is cycled.                                                                                                                                |
| (PPM<br>Mode)             | 82                  | 80                  | O<br>Group 10      | FDC Write Gate. This pin provides an additional $\overline{WGATE}$ signal in PPM mode, when PNF = 0. $\overline{WGATE}$ is multiplexed with SLCT. See Table 4-11 for more information.                                                                                                                                                                                    |

### Winbond Electronics Corp. Advanced PC Product Center

| Symbol                 | PQFP<br>Pin | TQFP<br>Pin | I/O and<br>Group # | Function                                                                                                                                                                                                                                                                                                               |
|------------------------|-------------|-------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WP<br>(Normal<br>Mode) | 36          | 34          | I<br>Group 4       | Write Protect. This FDC input indicates that the disk in the selected drive is write protected.                                                                                                                                                                                                                        |
| (PPM<br>Mode)          | 92          | 90          | I<br>Group 4       | Write Protect. This pin provides an additional $\overline{WP}$ signal in PPM mode, when PNF = 0.<br>$\overline{WP}$ is multiplexed with PD2. See Table 4-11 for more information.                                                                                                                                      |
| WR                     | 18          | 16          | I<br>Group 1       | Write. This active low input signal indicates a write from the microprocessor to the Chip.                                                                                                                                                                                                                             |
| WRITE                  | 95          | 93          | O<br>Group 11      | <b>Write Strobe.</b> This signal is used in EPP mode as write strobe. It is active low. WRITE is multiplexed with STB. See Table 4-11 for more information.                                                                                                                                                            |
| X1                     | 7           | 5           | I<br>Group 5       | Clock. Active clock input signal of 14.318 MHz, 24 MHz or 48 MHz.                                                                                                                                                                                                                                                      |
| ZWS                    | 3           | 1           | O<br>Group 13      | Zero Wait State. This pin is used for the Zero Wait State opendrain output signal, when bit 6 of FCR is 0. ZWS is driven low when the EPP or ECP is written to, and the access time can be shortened. This pin is $\overline{CS1}$ when bit 6 of FCR is 1. $\overline{ZWS}$ is multiplexed with the $\overline{CS1}$ . |

**TABLE 1-2.** Multi-Function Pins (Excluding Strap Pins)

| PQFP Pin | TQFP Pin | Symbols                                         |  |  |  |  |
|----------|----------|-------------------------------------------------|--|--|--|--|
| 3        | 1        | CS1/ZWS                                         |  |  |  |  |
| 8        | 6        | IRSL1/ID1 (in PC97338)                          |  |  |  |  |
| 43       | 41       | MTR1/IDLE/IRSL2 (and ID2 in PC97338)            |  |  |  |  |
| 45       | 43       | DR1/PD                                          |  |  |  |  |
| 48       | 46       | DENSEL/ADRATE1                                  |  |  |  |  |
| 49       | 47       | DRV2/PNF/DR23/SIRQI3/IRSL2 (and ID2 in PC97338) |  |  |  |  |
| 51       | 49       | DRATE1/MSEN1/CS0/SIRQI2/DACK3                   |  |  |  |  |
| 52       | 50       | DRATE0/MSEN0                                    |  |  |  |  |
| 60       | 58       | IRQ15/SIRQI1/DRQ3                               |  |  |  |  |
| 62       | 60       | RI2/A11                                         |  |  |  |  |
| 63       | 61       | DTR2/A12 (and BOUT2 in PC97338)                 |  |  |  |  |
| 64       | 62       | CTS2/A13                                        |  |  |  |  |
| 65       | 63       | SOUT2/IRTX                                      |  |  |  |  |
| 66       | 64       | RTS2/A14                                        |  |  |  |  |
| 67       | 65       | SIN2/IRRX1                                      |  |  |  |  |
| 68       | 66       | DSR2/IRQ12/IRRX2/IRSL0 (and ID0 in PC97338)     |  |  |  |  |
| 69       | 67       | DCD2/A15                                        |  |  |  |  |
| 71       | 69       | DTR1/BOUT1 (Only in PC97338)                    |  |  |  |  |
| 73       | 71       | SOUT1/BOUT1 (Only in PC87338)                   |  |  |  |  |
| 78       | 76       | AFD/DSTRB/DENSEL(PPM)                           |  |  |  |  |
| 79       | 77       | ERR/HDSEL(PPM)                                  |  |  |  |  |
| 80       | 78       | INIT/DIR(PPM)                                   |  |  |  |  |
| 81       | 79       | SLIN/STEP(PPM)/ASTRB                            |  |  |  |  |
| 82       | 80       | SLCT/WGATE(PPM)                                 |  |  |  |  |
| 83       | 81       | PE/WDATA(PPM)                                   |  |  |  |  |
| 84       | 82       | BUSY/WAIT/MTR1(PPM)                             |  |  |  |  |
| 85       | 83       | ACK/DR1(PPM)                                    |  |  |  |  |
| 86       | 84       | PD7/MSEN1(PPM)                                  |  |  |  |  |
| 87       | 85       | PD6/DRATE0(PPM)                                 |  |  |  |  |
| 88       | 86       | PD5/MSEN0(PPM)                                  |  |  |  |  |
| 89       | 87       | PD4/DSKCHG(PPM)                                 |  |  |  |  |
| 91       | 89       | PD3/RDATA(PPM)                                  |  |  |  |  |
| 92       | 90       | PD2/WP(PPM)                                     |  |  |  |  |
| 93       | 91       | PD1/TRK0(PPM)                                   |  |  |  |  |
| 94       | 92       | PD0/INDEX(PPM)                                  |  |  |  |  |
| 95       | 93       | STB/WRITE                                       |  |  |  |  |
| 98       | 96       | IRQ5/ADRATE0                                    |  |  |  |  |

TABLE 1-3. IRQ12, A15-11 / UART2 / Infrared Pin Allocation

| PQFP Pin | TQFP Pin      | Reset Value of CFG0 is 0       | Reset Value of CFG0 is 1                               |
|----------|---------------|--------------------------------|--------------------------------------------------------|
| 62       | 60            |                                | Function: RI2 Others: A11 = 0                          |
| 63       | Function: A12 |                                | Function: $\overline{DTR2}/BOUT2^a$<br>Others: A12 = 0 |
| 64       | 62            | Function: A13 Others: CTS2 = 0 | Function: CTS2 Others: A13 = 0                         |
| 66       | 64            | Function: A14                  | Function: RTS2 Others: A14 = 0                         |
| 69       | 67            | Function: A15 Others: DCD2 = 1 | Function: DCD2 Others: A15 = 0                         |

a. DTR2 or BOUT2 is selected on the pin via the UART2 registers in PC97338 only. See Chapter 5.

TABLE 1-4. UART2 Mode Con gurations 1

| Pin  |      | Wak                         | е Up                                  | Run-Time Selection <sup>a</sup> |                                       |  |
|------|------|-----------------------------|---------------------------------------|---------------------------------|---------------------------------------|--|
| PQFP | TQFP | Reset Value of<br>CFG0 is 0 | Reset Value of<br>CFG0 is 1           | InfraRed Mode<br>Selected       | UART Mode<br>Selected                 |  |
| 65   | 63   | Function: IRTX              | Function:<br>SOUT2/BOUT2 <sup>b</sup> | Function: IRTX                  | Function:<br>SOUT2/BOUT2 <sup>b</sup> |  |
| 67   | 65   | Function: IRRX1             | Function: SIN2                        | Function: IRRX1                 | Function: SIN2                        |  |

a. Run time selection is via the UART2 registers (see Chapter 5). If the reset value of CFG0 is 0, run time selection is disabled after reset. To enable run time selection, configure the UART2 to any infrared mode. Once this is done, run time selection is enabled. If the reset value of CFG0 is 1, run time selection is enabled immediately after reset.

TABLE 1-5. UART2 Mode Con gurations 2

| P    | Pin  | Wak                                          | e Up              | Run-Time Selection                        |                                                         |                                                         |                       |  |
|------|------|----------------------------------------------|-------------------|-------------------------------------------|---------------------------------------------------------|---------------------------------------------------------|-----------------------|--|
|      |      | Reset Reset                                  |                   | Reset Valu                                | e of CFG0 is 0                                          | Reset Value of CFG0 is 1                                |                       |  |
| PQFP | TQFP |                                              | Value of CFG0 = 1 | Bit 3 of<br>SCF3 = 0                      | Bit 3 of SCF3 = 1                                       | InfraRed Mode<br>Selected                               | UART Mode<br>Selected |  |
| 68   |      | Function:<br>IRQ12<br>Others:<br>DSR2 =<br>0 | Function:<br>DSR2 | Function:<br>IRQ12<br>Others:<br>DSR2 = 0 | Function: IRRX2/IRSL0/ID0 <sup>a</sup> Others: DSR2 = 0 | Function: IRRX2/IRSL0/ID0 <sup>a</sup> Others: DSR2 = 0 | Function:<br>DSR2     |  |

a. IRRX2 or IRSL0/ID0 is selected on the pin via the UART2 registers. ID0 is available only in PC97338. See Chapter 5.

b. SOUT2 or BOUT2 is selected on the pin via UART2 registers in PC87338 only. See Chapter 5.

### 2.0 Con guration

### 2.1 OVERVIEW

The configuration register set consists of 37 registers, which control the Chip set-up. Setup values stored in these registers enable or disable major functions, such as FDC, UARTs and the parallel port, and set functional parameters such as functional mode selection, pin functionality, interrupt configuration, hardware-controlled power down options and I/O address assignment.

Table 2-2 lists these registers, their mnemonic abbreviations and index number (which serves as an address offset). Bitmaps of these registers, in order of increasing index numbers, appear in Section 2.3.1 on page 24.

### 2.2 CONFIGURATION REGISTER SETUP

Certain configuration registers are setup by hardware pin strapping schemes. All others are setup by software. The hardware-configured registers may be updated by software after power-up.

### 2.2.1 Hardware Device Configuration

Three configuration registers in the Chip are setup by hardware pin strapping options. The FER, FAR and PTR register default contents are setup by CFG0 during reset.

CFG0 is set to 0 level by default, and may be changed to logical 1 by attaching an external pull-up resistor. The values set by this method are loaded into the device registers during reset. The setting of this pin selects one of two sets of default values for loading. This enables automatic configuration without software intervention.

Table 2-1 shows the hardware-controlled default configurations.

CFG0 controls selection of 11 address bits with fully standard interface of UART2, or 16 address bits and UART2 with SIN and SOUT signals only.

- 11-bit address mode The chip is in this mode, if during reset CFG0 = 1. UART2 wakes up with the full standard interface.
- 16-bit address mode The chip is in this mode, if during reset CFG0 = 0. UART2 wakes up in 16550 UART/SIR mode.

The default configuration can be modified by software at any time after reset by using the access procedure described in the Section 2.2.

| IABLE 2-1. Default Con | gurations Controlled by | y Hardware |
|------------------------|-------------------------|------------|
|------------------------|-------------------------|------------|

| CFG0       | Reset Value of FAR, FER, PTR                 | Reset Con guration                                                                |
|------------|----------------------------------------------|-----------------------------------------------------------------------------------|
|            |                                              | All modules disabled (power down)                                                 |
| 0(Default) |                                              | • 16 address bits.                                                                |
|            | $FER = xx000000_{B}$<br>$PTR = 00x000x0_{B}$ | <ul> <li>UART2 in Legacy SIR mode, with SIN and SOUT signals<br/>only.</li> </ul> |
|            | $FAR = 00010000_B$                           | All modules disabled (power down).                                                |
| 1          |                                              | • 11 address bits.                                                                |
|            |                                              | UART2 in Legacy mode, with the full standard interface.                           |

**TABLE 2-2.** Con guration Registers

| Cumbal | Description                                | Index | HW  | Modules Affected |    |    |    |    |    |     |
|--------|--------------------------------------------|-------|-----|------------------|----|----|----|----|----|-----|
| Symbol | Description                                | inaex | Cfg | FDC              | PP | U1 | U2 | IR | cs | CFG |
| ASC    | Advanced SuperI/O Chip Configuration       | 09h   |     | х                | Х  |    |    |    |    |     |
| CLK    | Clock Control                              | 51h   |     |                  |    |    |    |    |    | х   |
| CS0CF  | Chip Select 0 Configuration                | 0Ch   |     |                  |    |    |    |    | х  |     |
| CS0HA  | Chip Select 0 Base Address, High           | 0Bh   |     |                  |    |    |    |    | х  |     |
| CS0LA  | Chip Select 0 Base Address, Low            | 0Ah   |     |                  |    |    |    |    | х  |     |
| CS1CF  | Chip Select 1 Configuration                | 10h   |     |                  |    |    |    |    | х  |     |
| CS1HA  | Chip Select 1 Base Address, High           | 0Eh   |     |                  |    |    |    |    | х  |     |
| CS1LA  | Chip Select 1 Base Address, Low            | 0Dh   |     |                  |    |    |    |    | х  |     |
| FAR    | Function Address Register                  | 01h   | Х   |                  | Х  | х  | х  |    |    |     |
| FBAH   | FDC Base Address, High                     | 49h   |     | х                |    |    |    |    |    |     |
| FBAL   | FDC Base Address, Low                      | 48h   |     | х                |    |    |    |    |    |     |
| FCR    | Function Control Register                  | 03h   |     | х                | Х  |    |    |    | х  | х   |
| FER    | Function Enable Register                   | 00h   | Х   | х                | Х  | х  | х  |    |    |     |
| PBAH   | Parallel port Base Address, High           | 43h   |     |                  | Х  |    |    |    |    |     |
| PBAL   | Parallel port Base Address, Low            | 42h   |     |                  | Х  |    |    |    |    |     |
| PCR    | Parallel port Control Register             | 04h   |     |                  | Х  |    |    |    |    |     |
| PMC    | Power Management Control                   | 06h   |     | х                | Х  | х  |    |    |    | х   |
| PNP0   | Plug and Play Configuration 0              | 1Bh   |     | х                | Х  | х  | Х  |    |    | х   |
| PNP1   | Plug and Play Configuration 1              | 1Ch   |     |                  |    | х  | Х  |    |    |     |
| PNP2   | Plug and Play Configuration 2              | 41h   |     | х                |    |    |    |    |    |     |
| PNP3   | Plug and Play Configuration 3              | 4Fh   |     |                  |    |    | х  | Х  |    |     |
| PTR    | Power and Test Register                    | 02h   | Х   |                  | Х  | х  | Х  |    |    |     |
| SBAH   | SuperI/O chip Base Address, High           | 4Bh   |     |                  |    |    |    |    |    | х   |
| SBAL   | SuperI/O chip Base Address, Low            | 4Ah   |     |                  |    |    |    |    |    | х   |
| SCF0   | SuperI/O chip Configuration 0              | 12h   |     |                  |    |    | Х  |    |    |     |
| SCF1   | SuperI/O chip Configuration 1              | 18h   |     |                  | Х  |    |    |    |    |     |
| SCF2   | SuperI/O chip Configuration 2              | 40h   |     | х                |    |    | х  | Х  |    |     |
| SCF3   | SuperI/O chip Configuration 3              | 50h   |     | х                | Х  |    | х  | Х  |    | х   |
| SID    | SuperI/O chip Identification               | 08h   |     |                  |    |    |    |    |    | х   |
| SIRQ1  | System IRQ Input 1 Configuration           | 4Ch   |     |                  |    |    |    |    |    | х   |
| SIRQ2  | System IRQ Input 2 Configuration           | 4Dh   |     | х                |    |    |    |    | Х  | х   |
| SIRQ3  | System IRQ input 3 configuration           | 4Eh   |     | х                | Х  |    |    |    |    | х   |
| TUP    | Tape, UART and Parallel Port Configuration | 07h   |     | х                | Х  | х  |    |    |    | х   |
| U1BAH  | <u>'</u>                                   | 45h   |     |                  |    | х  |    |    |    |     |
| U1BAL  | UART1 Base Address, Low                    | 44h   |     |                  |    | х  |    |    |    |     |
| U2BAH  |                                            | 47h   |     |                  |    |    | х  |    |    |     |
| U2BAL  | UART2 Base Address, Low                    | 46h   |     |                  |    |    | х  |    |    |     |

### 2.2.2 Software Device Configuration

Besides the three hardware-configured registers, all Legacy-mode access to the configuration registers is achieved by the use of an INDEX and DATA register pair. Each configuration register is indicated by the value loaded into the INDEX register. The data to be written into or read from the indicated configuration register is transferred via the DATA register.

Accessing the configuration registers in this way requires only two system I/O addresses. These two addresses are configured by strapping the values of pins BADDR0 and BADDR1 during reset, as described in Table 2-3. Since that I/O space is shared by other devices the INDEX and DATA registers may conflict with other system devices constrained to use this I/O address space. Such conflicts may be resolved by changing the INDEX and DATA register address assignments after reset, as described in Section 2.2.5.

TABLE 2-3. INDEX and DATA Register Address Options and Con guration Register Accessibility

| BADI | OR Pin | INDEX               | DATA                | Accessible      |  |
|------|--------|---------------------|---------------------|-----------------|--|
| 1    | 0      | Register<br>Address | Register<br>Address | after Reset     |  |
| 0    | 0      | 398h                | 399h                | Yes             |  |
| 0    | 1      | undefined           | undefined           | No <sup>a</sup> |  |
| 1    | 0      | 15Ch                | 15Dh                | Yes             |  |
| 1    | 1      | 2Eh                 | 2Fh                 | Yes             |  |

a. Apply Plug and Play protocol.

### 2.2.3 Updating Configuration Registers

The settings of the configuration registers are accessible via the INDEX and DATA registers. The location of these registers is set by hardware during reset, and the software is not informed of the chosen hardware setting. The first step required to change configuration registers settings is, to locate the addresses of the INDEX and DATA registers.

To access the configuration registers after reset, use the following procedure.

1. Determine the location of the INDEX register.

Check the possible locations (see Table 2-3) by reading them twice. At the correct location only, the first byte to return will be 88h, and the second will be 00h. This double read must be conducted before any writes have been made to the addresses being checked since the ID byte is only issued from the Index register during the first read after a reset. (The register is reset by read. Subsequent reads return the value loaded into the Index register (except bits 6-4 which are reserved and always read 0), or 00h if no write has been made).

- 2. Load the configuration registers.
  - A. Disable CPU interrupts (only for the PC87338).
  - B. Write the index of the configuration register (00h-0Eh) to the INDEX register.
  - C. Write the correct data for the configuration register to the DATA register (*one write access in the PC97338* and two consecutive write accesses in the PC87338).
  - D. Enable CPU interrupts (only for the PC87338).
- Load the configuration registers (read-modifywrite).
  - A. Disable CPU interrupts (only for the PC87338).
  - B. Write the index of the configuration register (00h-0Eh) to the INDEX register.
  - C. Read the configuration data in that register via the DATA register.
  - D. Modify the configuration data.
  - E. Write the changed data for the configuration register to the DATA register (*one write access in the PC97338* and two consecutive write accesses in the PC87338).
  - F. Enable CPU interrupts (only for the PC87338).

A single read access to the INDEX and DATA registers can be done at any time without disabling CPU interrupts. Reading the INDEX register returns the last value loaded into the INDEX register. Reading the DATA register returns the configuration register data pointed to by the INDEX register.

If during reset BADDR1 = 0 and BADDR0 = 1, the IN-DEX and DATA register addresses are determined after reset via the Plug and Play protocol. As long as these addresses are undefined, the configuration registers are not accessible. See Table 2-3.

## 2.2.4 Reserved Bits in Configuration Registers

To maintain compatibility with future Superl/O chips, do not modify reserved bits when the register is written, i.e., use read-modify-write to preserve the value of reserved bits.

### 2.2.5 INDEX and DATA Register Locations

During reset, the INDEX and DATA register pair can be located at one of three locations by a hardware strapping option on two pins (BADDR0 and BADDR1) (see Table 2-3). This enables resolution of conflicts with other devices in the I/O address space.

For all reset values of BADDR0,1, the INDEX and DATA register pair can always be relocated via configuration registers SBAL and SBAH. See "Relocating the INDEX and DATA Register Pair" on page 23.

The INDEX register address is always even. The DATA register is always at the next consecutive address. Bit 7 of the INDEX register is reserved, and is always read 0.

### 2.2.6 Plug and Play Protocol

The following protocol is based on the Plug and Play ISA Specification 1.0a. It should be applied on power-up, if during reset BADDR1 = 0 and BADDR0 = 1. It is not applicable otherwise. For any other reset values of BADDR0.1, the hardware does not respond.

This protocol is used to determine the addresses of the INDEX and DATA registers. When the protocol is applied, the CPU interrupts should be disabled.

Upon power up, an initiation key must be written to one of the following I/O ports: 279h, 3BDh or 3F0h. The initiation key consists of a predefined series of write operations. All of the write operations in the series must be to the same port. These ports are write only. The ports are chosen so as to avoid conflicts in the installed base of ISA functions. (These ports serve as read-only registers in legacy devices.) The write sequence is decoded by the Chip.

If the proper series of I/O writes is detected, the configuration of the Chip base address (address of the Index register) follows. The base address of the Chip is configured by two additional I/O writes to the chosen I/O port (the same I/O port to which the initiation key was written). The data in the first write holds the eight high address bits of the Chip base address. The data in the second write holds the eight low address bits of the Chip base address. Once these two I/O writes are accomplished, the INDEX and DATA registers are accessible and the Chip is configurable.

Since this protocol is based on the Plug and Play ISA Specification 1.0a, software should conclude this protocol with a sequence of two write cycles of 0x00 to the chosen I/O port. Once the Plug and Play protocol is concluded, it can not be applied again until a hardware reset is asserted. CPU interrupts can be enabled at this point. The addresses of the INDEX and DATA registers are still reconfigurable, via the SBAL and SBAH configuration registers, as explained in the Section "Relocating the INDEX and DATA Register Pair" on page 23.

The hardware check of the initiation key is implemented as a linear feedback shift register (LFSR). See "The Linear Feedback Shift Register (LFSR)" on page 23. Software generates the LFSR sequence and writes it to one of the three I/O ports defined above as a sequence of 8-bit write cycles (all writes are to the same I/O port). Hardware compares the byte of write data with the value in the shift register at each write. When the data does not match, the hardware resets to the initial value of the LFSR. Software should reset the LFSR to its initial value using a sequence of two write cycles of 0x00 to the chosen port (one of the three I/O ports) before the initiation key is sent.

Figure 2-1 shows the flowchart of the Plug and Play protocol.



FIGURE 2-1. Plug and Play Protocol Flowchart

## The Linear Feedback Shift Register (LFSR)

The LFSR is an 8-bit shift register that resets to the value of 0x6A. (See Figure 2-2.) The feedback taps for this shift register are taken from register bits 1 and 0 of LFSR.

The initiation key should be sent to the Chip upon power on. The software should ensure that the LFSR is in its initial state. Then 32 writes are performed. The first 30 writes must be exactly equal to the 30 values the LFSR will generate starting from 0x6A. The last two writes are of 0x00.

The exact sequence for the initiation key in hexadecimal notation is (reading left to right, top to bottom):

6A, B5, DA, ED, F6, FB, 7D, BE, DF, 6F, 37, 1B, 0D, 86, C3, 61, B0, 58, 2C, 16, 8B, 45, A2, D1, E8, 74, 3A, 9D, CE, E7, 00, 00



#### FIGURE 2-2. LFSR Circuit

### Relocating the INDEX and DATA Register Pair

The INDEX and DATA registers are relocated via configuration registers SBAL and SBAH, as follows:

1. Write to the SBAH register.

A temporary register (TEMP\_SBAH) is updated with the written data (as in all configuration registers). SBAH register is not updated yet with the written data, i.e., a read from SBAH register will return the data prior to the write.

The addresses of the INDEX and DATA registers are not modified.

2. Write to the SBAL register.

The second consecutive write updates the SBAL register with the written data and updates the SBAH register with the data stored in the temporary register (TEMP SBAH).

The addresses of the INDEX and DATA registers are modified according to the data of SBAL and SBAH.

3. Return to (1) if addresses of the INDEX and DATA registers need to be changed again.

Upon reset, TEMP\_SBAH is initialized to the initialization value of the SBAH register. When the SBAH register is updated by the Plug and Play protocol, TEMP SBAH is updated too, with the same value.

This scheme maintains the coherence of the INDEX and DATA register addresses.

### 2.3 THE CONFIGURATION REGISTERS

The next section presents the bitmaps of the configuration registers in address order. The sections that follow describe the bits and fields of each register in detail, in the same order.

"Reset" specifies the value of a bit after reset. "Required" indicates that the bit must always have that value.

To maintain compatibility with other SuperI/O chips, the value of reserved bits may not be altered. Use read-modify-write to preserve their values.













### 2.3.2 Function Enable Register (FER), Index 00h

This register enables and disables major chip functions. Disabled functions have their clocks automatically powered down, but the data in their registers remains intact. It also selects whether the FDC controller is located at the primary or secondary address.



FIGURE 2-3. FER Register Bitmap

#### Bit 0 - Parallel Port Enable

- 0 The parallel port is disabled.
- 1 The parallel port can be accessed at the address specified by: In Legacy mode: the FAR bits 1,0. In Plug and Play mode: by PBAL and PBAH registers.

#### Bit 1- UART1 Enable

This bit enables or disables UART1.

Any UART1 interrupt that is enabled and active, or becomes active after UART1 is disabled, asserts the associated IRQ pin when UART1 is disabled. If disabling UART1 via software, clear ISEN bit (see sec. 5.13.6 on page 148) to 0 before clearing FER bit 1. This is not an issue after reset because ISEN is 0 until it is written.

0 - Access to UART1 is blocked and it is in power down mode. The UART1 registers retain all data in power down mode.

1 - In Legacy mode, UART1 can be accessed at the address specified by bits 3,2 of the FAR. In Plug and Play mode, the address is specified the by U1BAL and U1BAH registers.

### Bit 2 - UART2 Enable

This bit enables UART2. Any UART2 interrupt that is enabled and active or becomes active after UART2 is disabled asserts the associated IRQ pin when UART2 is disabled. If disabling UART2 via software, clear ISEN bit (see sec. 5.13.6 on page 148) to 0 before clearing FER bit 2. This is not an issue after reset because ISEN is 0 until it is written.

- O Access to UART2 is blocked and it is in power down mode. The UART2 registers retain all data in power down mode.
- 1 In Legacy mode, UART2 can be accessed at the address specified by bits 5,4 of the FAR. In Plug and Play mode, the address is specified by the U2BAL and U2BAH registers.

#### Bit 3 - FDC Enable

This bit enables the FDC

- O Access to the FDC is blocked and it is in power down mode. The FDC registers retain all data in power down mode.
- 1 FDC can be accessed at the address specified by bit 5 of FER in Legacy mode, and by the FBAL and FBAH registers in Plug and Play mode.

### Bit 4 - FDC Four-Drive Encoding

- 0 The Chip can control two floppy disk drives directly without an external decoder.
- The two drive select signals and two motor enable signals from the FDC are encoded so that four floppy disk drives can be controlled. See Table 2-5.

Controlling four FDDs requires an external decoder. The pin states shown in Table 2-5 are a direct result of the bit patterns shown. All other bit patterns produce pin states that should not be decoded to enable any drive or motor.

### Bit 5 - Primary or Secondary FDC Address

In Legacy mode, this bit selects the primary or secondary FDC address. See Table 2-4.

In Plug and Play mode, this bit is ignored.

TABLE 2-4. Primary and Secondary Drive Address Selection

| Bit 5 of FER | PC-AT Mode        |
|--------------|-------------------|
| 0            | Primary: 3F0-7h   |
| 1            | Secondary: 370-7h |

#### Bits 7.6 - Reserved

These bits are reserved.

TABLE 2-5. Encoded Drive and Motor Pin Information (Bit 4 of FER = 1)

|   | Digi | ital ( | Outp | out | Reg | iste | r | D    | rive Co | ntrol Pi | ns  | Decoded Functions                       |
|---|------|--------|------|-----|-----|------|---|------|---------|----------|-----|-----------------------------------------|
| 7 | 6    | 5      | 4    | 3   | 2   | 1    | 0 | MTR1 | MTR0    | DR1      | DR0 | Decoded Functions                       |
| Х | Х    | Х      | 1    | Х   | Х   | 0    | 0 | Note | 0       | 0        | 0   | Activate drive 0 and motor 0            |
| Х | х    | 1      | х    | Х   | х   | 0    | 1 | Note | 0       | 0        | 1   | Activate drive 1 and motor 1            |
| х | 1    | х      | х    | Х   | х   | 1    | 0 | Note | 0       | 1        | 0   | Activate drive 2 and motor 2            |
| 1 | х    | х      | х    | х   | х   | 1    | 1 | Note | 0       | 1        | 1   | Activate drive 3 and motor 3            |
| Х | х    | х      | 0    | Х   | х   | 0    | 0 | Note | 1       | 0        | 0   | Activate drive 0 and deactivate motor 0 |
| Х | х    | 0      | х    | Х   | х   | 0    | 1 | Note | 1       | 0        | 1   | Activate drive 1 and deactivate motor 1 |
| Х | 0    | х      | х    | Х   | х   | 1    | 0 | Note | 1       | 1        | 0   | Activate drive 2 and deactivate motor 2 |
| 0 | х    | х      | х    | Х   | х   | 1    | 1 | Note | 1       | 1        | 1   | Activate drive 3 and deactivate motor 3 |

#### Note:

When bit 4 of the FER register = 1,  $\overline{\text{MTR1}}$  presents a pulse that is the inverted image of the IOW strobe. This inverted pulse is active whenever an I/O write to address 3F2h or 372h takes place. This pulse is delayed by 25 - 80 nsec after the leading edge of IOW and its leading edge can be used to clock data into an external

latch (e.g., 74LS175). Address 3F2h is used if the FDC is located at the primary address (bit 5 of FER = 0) and address 372h is used if the FDC is located at the secondary address (bit 5 of FER = 1).

### 2.3.3 Function Address Register (FAR), Index 01h

In Plug and Play mode, this register is ignored.

In Legacy mode, this register selects the ISA I/O address range to which each peripheral function responds.



FIGURE 2-4. FAR Register Bitmap

### Bits 1,0 - Parallel Port Address

These bits select the parallel port address as shown in Table 2-6.

**TABLE 2-6. Parallel Port Addresses** 

| FA    | <b>AR</b> | Parallel Port  | AT                    |
|-------|-----------|----------------|-----------------------|
| Bit 1 | Bit 0     | Address        | Interrupt             |
| 0     | 0         | LPT2 (378-37F) | IRQ5 <sup>a</sup>     |
| 0     | 1         | LPT1 (3BC-3BE) | IRQ7                  |
| 1     | 0         | LPT3 (278-27F) | IRQ5                  |
| 1     | 1         | Reserved       | TRI-STATE<br>(CTR4=0) |

 a. The interrupt assigned to this address can be changed to IRQ7 by setting bit 3 of the Power and Test Register (PTR)

### Bits 3,2 - UART1 Address

These bits determine which ISA I/O address range is associated with UART1 as shown in Table 2-8.

TABLE 2-7. COM Port Selection for UART1

| FA         | .R         | UART1      |                  |  |
|------------|------------|------------|------------------|--|
| Bit 3      | Bit 2      | COM Port # |                  |  |
| 0(default) | 0(default) | COM1       | (3F8-F)          |  |
| 0          | 1          | COM2       | (2F8-F)          |  |
| 1          | 0          | СОМЗ       | (See Table 2-9.) |  |
| 1          | 1          | COM4       | (See Table 2-9.) |  |

### Bits 5,4 - UART2 Address

These bits determine which ISA I/O address range is associated with UART2 as shown in Table 2-7.

**TABLE 2-8. COM Port Selection for UART2** 

| FA         | .R         |      | UART2            |
|------------|------------|------|------------------|
| Bit 5      | Bit 4      |      | COM#             |
| 0          | 0          | COM1 | (3F8-F)          |
| 0(default) | 1(default) | COM2 | (2F8-F)          |
| 1          | 0          | СОМЗ | (See Table 2-9.) |
| 1          | 1          | COM4 | (See Table 2-9.) |

### Bits 7,6 - Select COM3 or COM4

These bits select the addresses that are used for COM3 and COM4 as shown in Table 2-9.

TABLE 2-9. Address Selection for COM3 and COM4

| Bit 7 | Bit 6 | COM3 IRQ4 | COM4 IRQ3 |
|-------|-------|-----------|-----------|
| 0     | 0     | 3E8-Fh    | 2E8-Fh    |
| 0     | 1     | 338-Fh    | 238-Fh    |
| 1     | 0     | 2E8-Fh    | 2E0-7h    |
| 1     | 1     | 220-7h    | 228-Fh    |

### 2.3.4 Power and Test Register (PTR), Index 02h

This register determines the power-down method used and whether hardware power-down is enabled, and provides a bit for software power down of all enabled functions. It selects whether IRQ7 or IRQ5 is associated with LPT2. It puts the enabled UARTs into their test mode. Independent of this register the floppy disk controller can enter low power mode via the MODE command or the Data Rate Select (DSR) register.



### FIGURE 2-5. PTR Register Bitmap

#### Bit 0 - Power Down

Setting this bit causes all enabled functions to be powered down.

Bits 3 and 2 of PCR can affect this function.

- 0 Functions not powered down.
- 1 Setting this bit causes all enabled functions to be powered down. All register data is retained when the clocks are stopped. The FDC, UARTs and parallel port are affected by this bit when the relevant PMC register bits and SCF0 register bits are set.

### Bit 1 - Reserved

This bit is reserved.

### Bit 2 - Reserved

This bit is reserved and must be set to 0.

#### Bit 3 - Select IRQ5 or IRQ7

In Plug and Play mode, this bit is ignored.

In Legacy mode, setting this bit associates the parallel port with IRQ7 when the address for the parallel port is 378 - 37Fh (LPT2). This bit is ignored when the parallel port address is 3BC - 3BEh (LPT1) or 278 - 27Fh (LPT3).

- 0 LPT2 not associated with IRQ7
- 1 LPT2 associated with IRQ7

#### Bit 4 - UART1 Test Mode

Setting this bit puts UART1 into a test mode, which causes its BAUDOUT clock to be present on its SOUT1 pin if the bit 7 of the Line Control Register (LCR) is set to 1.

- 0 No test mode
- 1 Test mode.

### Bit 5 - Reserved

This bit is reserved.

### Bit 6 - Lock Con guration

Setting this bit to 1 prevents all further write accesses to the Configuration Registers. Once it is set by software it can only be cleared by a hardware reset. After the initial hardware reset it is 0.

- 0 Configuration Registers accessible. (Default)
- 1 Configuration Registers locked.

### Bit 7 - Select Extended or Compatible Parallel Port

When not in EPP or ECP modes, this bit controls SPP (Standard Parallel Port) mode (Compatible or Extended mode), thus controlling Pulse/Level interrupt:

In EPP mode this bit should be 0. In ECP mode, this bit is ignored.

- 0 Compatible mode, pulse interrupt.
- 1 Extended mode, level interrupt.

### 2.3.5 Function Control Register (FCR), Index 03h

This register determines several pin options. It selects Data Rate output or automatic media sense input signals.

For Enhanced Parallel Port it enables the  $\overline{\text{ZWS}}$  options and pin.

On reset, bits 7-1 of FCR are cleared to 0.



FIGURE 2-6. FCR Register Bitmap

### Bit 0 - TDR Mode Select

This bit selects TDR mode when bit 2 of ASC is zero

This bit is ignored when bit 2 of ASC is 1 (see bit 2 of ASC for complete TDR mode selection). This bit is initialized to 1 during reset, thus selecting AT Compatible TDR.

- 0 TDR is in Automatic Media Sense Mode. Bits 7-5 of TDR are valid.
- 1 TDR is in AT Compatible Mode. Bits 7-2 of TDR are in TRI-STATE during read. (Default)

### Bit 1 - Select MSEN0 or DRATE0

This bit is initialized to 0 during reset, thus selecting MSEN0.

- 0 MSEN0 is selected on the pin. (Default)
- 1 DRATE0 is selected on the pin.

#### Bit 2 - Reserved

This bit is reserved.

### Bit 3 - Parallel Port Multiplexor (PPM) Float Control

When this bit is zero, the PPM pins are driven. Otherwise, they are in TRI-STATE. Bit 3 is also functional when the PPM is not configured. (The PPM is configured when bits 7,6 of SIRQ3 are 10, and bit 1 of SCF3 is 0.)

When this bit is set the PPM output signals are in TRI-STATE and the input signals are blocked to reduce their leakage current. The values of the blocked input signals are: BUSY=1, PE=0, SLCT=0, ACK=1 and ERR=1.

To avoid undefined FDC input signals, the PPM can be disabled before this bit is set.

- 0 The PPM pins are driven.
- 1 The PPM pins are in TRI-STATE and the pullup resistors are disconnected.

#### Bit 4 - Reserved

This bit is reserved and is always 0.

### Bit 5 - Zero Wait State Enable

- $0 No \overline{ZWS}$  enabled.
- 1 If pin 3 is configured as ZWS (see bit 6), ZWS is driven low when the Enhanced Parallel Port (EPP) or the ECP can accept a short host read/write-cycle; otherwise the ZWS open drain output signal is not driven. EPP ZWS operation should be configured when the system's device is fast enough to support it.

### Bit 6 - Select ZWS or CS1 on pin 3

- 0 ZWS function is selected on pin 3.
- 1 CS1 function is selected on pin 3

#### Bit 7 - Reserved

Reserved bit. Write 0.

### 2.3.6 Printer Control Register (PCR), Index 04h

This register enables the EPP, ECP, version modes, and interrupt options. See Table 2-10.

**TABLE 2-10.** Parallel Port Mode

| Operation<br>Mode | Bit 0 of<br>FER | Bit 7 of<br>PTR | Bit 0 of<br>PCR | Bit 2 of<br>PCR |
|-------------------|-----------------|-----------------|-----------------|-----------------|
| None              | 0               | Х               | Χ               | Х               |
| Compatible        | 1               | 0               | 0               | 0               |
| Extended          | 1               | 1               | 0               | 0               |
| EPP               | 1               | 0               | 1               | 0               |
| ECP               | 1               | Х               | 0               | 1               |

On reset all the bits of PCR are cleared to 0.



FIGURE 2-7. PCR Register Bitmap

### Bit 0 - EPP Enable

- 0 The EPP is disabled, and the EPP registers are not accessible (access ignored).
- 1 If bit 2 of PCR is 0, the EPP is enabled. The EPP should not be configured with base address 3BCh.

### Bit 1 - EPP Version Select

- 0 Version 1.7 is supported.
- 1 Version 1.9 is supported (IEEE 1284).

### Bit 2 - ECP Enable

Enables or disables ECP mode. In Plug and Play mode, IRQ7-3, IRQ12-9 or IRQ15 are selected via the PNP0 register.

0 - The ECP is disabled and in power-down mode. The ECP registers are not accessible (access ignored), the ECP interrupt is inactive and DMA request pin is in TRI-STATE. The IRQ5,7 input signals are blocked to reduce their leakage currents. 1 - The ECP is enabled. The software should change this bit to 1 only when bits 2-0 of the existing CTR are 100.

#### Bit 3 - ECP Clock Freeze Control

When either this bit or the ECP enable bit is 0, there is no change in the Chip clock stopping mechanism.

- 0 The ECP does not affect the stopping of the clock multiplier (power-down mode 3) and does not change the function of bit 0 of PTR.
- 1 If the ECP is enabled (bit 2 of PCR is 1), the clock multiplier is not stopped (power mode 3 is not entered) and the ECP clock is not stopped (power down mode 2 excludes the ECP).

### Bit 4 - Reserved

This bit is reserved and must be set to 0.

### Bit 5 - Parallel Port Interrupt Polarity Control

This bit controls the polarity of the interrupt line allocated for the parallel port.

- The interrupt polarity is as defined in the existing Chip, and the ECP interrupt event is level high or negative pulse.
- 1 The interrupt event polarity is inverted.

### Bit 6 - Parallel Port Open-Drain Control

Parallel port interrupt (the parallel port-allocated interrupt line) open-drain control bit.

- The configured interrupt line (IRQ5 or IRQ7) has a totem-pole output with TRI-STATE ability.
- 1 The configured interrupt line has an open drain output signal (drive low or TRI-STATE).

### Bit 7 - Reserved

This bit is reserved. To maintain compatibility with future Super I/O chips, do not modify this bit when this register is written, i.e., use read-modify-write to preserve the value of this bit.

## 2.3.7 Power Management Control Register (PMC), Index 06h

This register controls the TRI-STATE and input signals. The PMC Register is accessed at index 06h. The PMC Register is cleared to 0 on reset.



FIGURE 2-8. PMC Register Bitmap

#### Bit 0 - Reserved

This bit is reserved.

### Bit 1 - FDC TRI-STATE Control

- 0 No TRI-STATE enabled.
- 1 If the FDC is powered down, the FDC output signals are in TRI-STATE, except the FDC-allocated interrupt line, PD, IDLE and the PPM output signals, even if the PPM is used for FDC pins, i.e., this bit does not control the IRQ6 and PPM pins.

In addition, if the FDC is powered down, the FDC input signals (except DSKCHG) are blocked to reduce their leakage current.

#### Bit 2 - UART1 TRI-STATE Control

This bit controls the TRI-STATE status of the UART1 output pins and blocked the input pins, to avoid leakage current. This bit does not control the TRI-STATE status of the UART1 interrupt.

- 0 TRI-STATE disabled on UART1 signals.
- If UART1 is disabled or the Chip is in powerdown mode, UART1 output signals are in TRI-STATE and the input signals are blocked to reduce their leakage current.

The values of the blocked input signals are: SIN1=1, CTS1=1, DSR1=1, DCD1=1 and RI1=1.

### Bit 3 - Reserved

This bit is reserved.

### Bit 4 - PD and IDLE or IRSL2/ID2 Enable

This is the PD and IDLE (FDC power management output signals) or IRSL2/*ID2* enable bit. When bit 2 of the SCF3 register is 1, IRSL2 controls pin 43 (PQFP) or 41 (TQFP) instead of MTR1 or IDLE. See Tables 2-11 and 2-12. *ID2* is available only in *PC97338*.

- 0 MTR1 or IRSL2/ID2 controls pin 43 (PQFP) or 41 (TQFP), and DR1 controls pin 45 (PQFP) or 43 (TQFP).
- 1 IDLE or IRSL2/*ID2* controls pin 43 (PQFP) or 41 (TQFP), and PD controls pin 45 (PQFP) or 43 (TQFP).

TABLE 2-11. Bit Settings to Enable MRT1, IDLE or IRSL2

| Bit 2 of<br>SCF3 | Bit 4 of<br>PMC | Function Selected on Pin #43<br>(PQFP) or Pin #41 (TQFP) |
|------------------|-----------------|----------------------------------------------------------|
| 0                | 0               | MTR1                                                     |
| 0                | 1               | IDLE                                                     |
| 1                | х               | IRSL2                                                    |

TABLE 2-12. Bit Settings to Enable DR1 or PD

| Bit 4 of PMC | Function Selected on Pin #45 (PQFP) or Pin #43 (TQFP) |
|--------------|-------------------------------------------------------|
| 0            | DR1                                                   |
| 1            | PD                                                    |

#### Bit 5 - Selective Lock

This bit enables locking of the following configuration bits: bit 5 of PMC (this bit), bit 4 of FER, bits 7 through 0 of FAR, bit 3 of PTR and bit 6 of FCR. Unlike bit 6 of PTR, it does not lock all the configuration bits.

Once this bit is set by software it can only be cleared by a hardware reset. This bit should be used instead of bit 6 of PTR if a configuration bit should be dynamically modified by software (like PMC bits).

- 0 No lock, except via bit 6 of PTR.
- 1 Any write to the above configuration bits is ignored, until a Master Reset clears this bit.

### Bit 6 - Parallel Port (PPM) TRI-STATE Enable

This bit enables reduction in power consumption, when the Superl/O chip is in power-down mode, or the parallel port is disabled, by placing the PPM output signals in TRI-STATE, and blocking the PPM input signals.

0 - The parallel port pins are enabled.

1 - If the parallel port is disabled, or the Super I/O chip is in power-down mode, the output signals of the parallel port, pins (except the Parallel Port-allocated interrupt line]) are in TRI-STATE, and the input signals are blocked to reduce their leakage currents.

The values of the blocked input signals are: BUSY=1, PE=0, SLCT=0, ACK=1 and ERR=1.

### Bit 7 - Reserved

This bit is reserved. To maintain compatibility with future SIO chips, do not modify this bit when this register is written, i.e., use read-modify-write to preserve the value of this bit.

# 2.3.8 Tape, UARTs and Parallel Port Configuration Register (TUP), Index 07h

The TUP Register is cleared to 0XX00000 on reset.



FIGURE 2-9. TUP Register Bitmap

### Bit 0 - Reserved

This bit is reserved.

#### Bit 1 - FDC 2 Mbps Enable

Upon reset, this bit is cleared to 0.

- 0 2 Mbps is not supported by the FDC, and the FDC clock is 24 MHz. (Default)
- 1 2 Mbps is supported by the FDC, and the FDC clock is 48 MHz The operating voltage should be 5 V. See Section 3.1.

### Bit 2 - EPP Time-Out Interrupt Enable

- 0 The EPP time-out interrupt is masked.
- The EPP time-out interrupt is generated on the selected IRQ line (the Parallel Port-allocated interrupt line), according to bit 6 of PCR.

### Bit 3 - MIDI/Reserved

In the PC87338 version this is the MIDI baud rate configuration bit which function as follow:

- 0 The UART1 baud rate generator is fed by the master clock of the Chip, divided by 13.
- 1 The UART1 baud rate generator is fed by the master clock of the Chip divided by 12. This bit should be set to support a MIDI port.

This bit is reserved in the PC97338 version.

#### Bit 4 - Reserved

This bit is reserved.

#### Bit 5 - PD Status

This bit holds the FDC power-down state, as defined for the PD pin, even when pin 45 (or 43 for VJG package) is not configured as PD. This bit is read only.

#### Bit 6 - IDLE Status

This bit holds the FDC idle state, as defined for the IDLE pin, even when pin 43 (or pin 41 in the VJG package) is not configured as IDLE, and when IDLE is masked by bit 7 of TUP. This bit is read only.

### Bit 7 - IDLE Pin Mask

This bit masks the IDLE output pin (but not the IDLE status bit). This bit is ignored when pin 43 is not configured as IDLE.

- 0 The IDLE output pin is unmasked The IDLE pin drives the value of the FDC idle state.
- 1 The IDLE output pin is masked. The IDLE pin is driven low.

## 2.3.9 SuperI/O Chip Identification Register (SID), Index 08h

The SID register is accessed, like the other configuration registers, through the INDEX register.

This read-only register identifies the chip. Bits 2-0 contain the revision code. SID holds the value B0h.



SuperI/O Chip Identification Register (SID) Index 08h

FIGURE 2-10. SID Register Bitmap

### 2.3.10 Advanced SuperI/O Chip Configuration Register (ASC), Index 09h

During reset, bits 2-0 and bits 5,4 are initialized to 0, and bits 7,6 are initialized to 1 (1100X000).



FIGURE 2-11. ASC Register Bitmap

#### Bit 0 - Select IRQ5 or ADRATE0

In Plug and Play mode, this bit does not affect the interrupt mapping of the parallel port (even when ADRATE0 is selected).

In Legacy mode, selection of parallel port interrupt pin (IRQ5 or IRQ7) via bits 1 and 0 of FAR, and via bit 3 of PTR, is ignored and IRQ7 is used as parallel port interrupt.

0 - Pin 98 (PQFP) or pin 96 (TQFP) is IRQ5. IRQ5 is controlled by bits 6 and 5 of PCR.

1 - Pin 98 (PQFP) or pin 96 (TQFP) is ADRATE0 open drain output. ADRATE0 has the same value as DRATE0.

#### Bit 1 - Reserved

This bit is reserved.

### Bit 2 - Enhanced TDR Support

- 0 TDR read is a function of bit 0 of the FCR configuration register.
- 1 The Chip provides enhanced TDR support.

#### Bit 3 - PNF Status

This bit reflects the value of the PNF pin. It is a read only bit; data written to this bit is ignored. It is undefined when the pin is configured as DRV2 or DR23.

This bit is undefined when the pin is configured as DRV2, DR23, SIRQI3 or IRSL2/ID2.

#### Bit 4 - Select DENSEL or ADRATE1

Controls the behavior of pin 48 in the PQFP package or of pin 46 in the TQFP package.

- 0 The pin is used for DENSEL.
- 1 The pin is used for ADRATE1.

#### Bit 5 - ECP CNFGA Bit

The value of this pin is reflected on bit 3 of CNFGA ECP register.

### Bit 6 - DENSEL Polarity

This bit controls the polarity of the DENSEL signal. Upon reset this bit is initialized to 1, thus selecting active high DENSEL for 500 Kbps, 1 Mbps and 2 Mbps data rates

- DENSEL is active low for data transmission rates of 500 Kbps, 1 Mbps and 2 Mbps data rates and active high for rates 250 Kbps and 300 Kbps.
- DENSEL is active low for data transmission rates of 250 Kbps, 300 Kbps data rates and active high for rates of 500 Kbps, 1 Mbps and 2 Mbps. (Default)

### Bit 7 - System Operation Mode

The Chip can be configured to either AT or PS/2 mode.

Upon reset this bit is initialized to 1, thus selecting AT mode.

- 0 PS/2 mode.
- 1 AT mode. (Default)

### 2.3.11 Chip Select 0 Low Address Register (CS0LA), Index 0Ah

This register holds the low address bits of the monitored I/O address. See CS0HA and CS0CF for complementary description. Bit 0 holds A0



FIGURE 2-12. CS0LA Register Bitmap

## 2.3.12 Chip Select 0 Configuration Register (CS0CF), Index 0Bh

This register controls the behavior of the  $\overline{\text{CS0}}$  pin.  $\overline{\text{CS0}}$  is asserted on non-DMA PIO cycles, when  $\overline{\text{RD}}$  or  $\overline{\text{WR}}$  is asserted.  $\overline{\text{CS0}}$  can be asserted only on reads, or on writes or on all cycles. The register is initialized to 0 during reset.



FIGURE 2-13. CS0CF Register Bitmap

#### Bits 2-0 - Reserved

These bits are reserved.

#### Bit 3 - Number of Decoded Address Bits

0 - During reset, if CFG0 = 0, decode 16 address bits (A15-A0) and compare them to CS0HA and CS0LA bits.

During reset, if CFG0 = 1, decode 11 address bits (A10-A0) and compare them to bits 2-0 of CS0HA and bits 7-0 of CS0LA. Bits 7-3 of CS0HA are ignored.

1 - During reset, if CFG0 = 0, decode four address bits (A15-A12) and compare them to bits 7-4 of CS0HA. Bits 3-0 of CS0HA and bits 7-0 of CS0LA are ignored.

During reset, if CFG0 = 1, it is illegal to set this bit to 1.

### Bit 4 - CSO Assert Enable (Write)

- 0 Do not enable CS0 assertion on write cycles.
- 1 Enable  $\overline{\text{CS0}}$  assertion on write cycles.

### Bit 5 - CSO Assert Enable (Read)

- 0 Do not enable  $\overline{\text{CS0}}$  assertion on read cycles.
- 1 Enable  $\overline{\text{CS0}}$  assertion on read cycles.

### Bits 7,6 - Reserved

These bits are reserved.

### 2.3.13 Chip Select 1 Low Address Register (CS1LA), Index 0Ch

This register holds the low address bits of the monitored I/O address. See CS1HA and CS1CF for complementary description. Bit 0 holds A0.



FIGURE 2-14. CS1LA Register Bitmap

## 2.3.14 Chip Select 1 Configuration Register (CS1CF), Index 0Dh

This register controls the behavior of the  $\overline{CS1}$  pin.  $\overline{CS1}$  is asserted on non-DMA PIO cycles, when  $\overline{RD}$  or  $\overline{WR}$  is asserted.  $\overline{CS1}$  can be asserted only on reads or writes or on all cycles. The register is initialized to 0 during reset.



FIGURE 2-15. CS1CF Register Bitmap

#### Bits 2-0 - Reserved

These bits are reserved.

#### Bit 3 - Number of Decoded Address Bits

0 - If during reset CFG0 = 0, decode 16 address bits (A15-A0) and compare them to CS1HA and CS1LA bits.

If during reset CFG0 = 1, decode 11 address bits (A10-A0) and compare them to bits 2-0 of CS1HA and bits 7-0 of CS1LA. Bits 7-3 of CS1HA are ignored.

1 - If during reset CFG[0]=0, decode 14 address bits (A15-A2) and compare them to bits 7-0 of CS1HA and bits 7-2 of CS1LA. Bits 1,0 of CS1LA are ignored.

If during reset CFG0 = 1. decode nine address bits (A10-A2) and compare them to bits 2-0 of CS1HA and bits 7-2 of CS1LA. Bits 7-3 of CS1HA and bits 1-0 of CS1LA are ignored.

### Bit 4 - CS1 Assert Enable (Write)

- 0 Do not enable CS1 assertion on write cycles.
- 1 Enable CS1 assertion on write cycles.

### Bit 5 - CS1 Assert Enable (Read)

- 0 Do not enable CS1 assertion on read cycles.
- 1 Enable CS1 assertion on read cycles.

### Bits 7,6 - Reserved

These bits are reserved.

### 2.3.15 Chip Select 0 High Address Register (CS0HA), Index 10h

This register holds the high address bits of the monitored I/O address. See CS0LA and CS0CF for complementary description. Bit 0 holds A8. If during reset CFG0 is1, A15-11 are not input signals of the chip. Therefore, bits 7-3 are reserved.



FIGURE 2-16. CS0HA Register Bitmap

### 2.3.16 Chip Select 1 High Address Register (CS1HA), Index 11h

This register holds the high address bits of the monitored I/O address. See CS1LA and CS1CF for complementary description. Bit 0 holds A8. If during reset CFG0 is 1, A15-11 are not input pins of the chip. Therefore, bits 7-3 are reserved.



FIGURE 2-17. CS1HA Register Bitmap

## 2.3.17 SuperI/O Chip Configuration Register 0 (SCF0), Index 12h

Upon reset. SCF0 is initialized to xxxx0xxx.



FIGURE 2-18. SCF0 Register Bitmap

### Bits 2-0 - Reserved

These bits are reserved.

#### Bit 3 - UART2 TRI-STATE Control

This bit controls the TRI-STATE status of the UART2 output pins and blocked the input pins, to avoid leakage current. This bit does not control the TRI-STATE status of the UART2 interrupt.

- 0 No TRI-STATE enabled in UART2 pins.
- 1 If UART2 is disabled or the Chip is in powerdown mode, UART2 and IR output signals are in TRI-STATE and the input signals are blocked to reduce their leakage current.

The values of the blocked input signals are: IRRX1=1, IRRX2=1, SIN2=1, CTS2=1, DSR2=1, DCD2=1, ID0=1, ID1=1, ID2=1 and RI2=1.

When IRSL2-0 control their respective pins they are all 0, under these conditions.

### Bits 7-4 - Reserved

Reserved.

## 2.3.18 SuperI/O Chip Configuration Register 1 (SCF1), Index 18h

Upon reset, SCF1 is initialized to xx00000x.



FIGURE 2-19. SCF1 Register Bitmap

#### Bit 0 - Reserved

This bit is reserved.

### Bits 2,1 - ECP DMA Number

Reported ECP DMA number, as reflected on bits 1,0 of the CNFGB ECP register. Bit 2 of SCF1 is reflected on bit 1 of CNFGB and bit 1 of SCF1 on bit 0 of CNFGB.

Microsoft's ECP Protocol and ISA Interface Standard defines these bits as shown in Table 2-13.

TABLE 2-13. ECP DMA Option Selection

| Bit 2 | Bit 1 | Selected DMA Option          |
|-------|-------|------------------------------|
| 0     | 0     | Jumpered 8-bit DMA (Default) |
| 0     | 1     | DMA Channel 1 selected       |
| 1     | 0     | DMA Channel 2 selected       |
| 1     | 1     | DMA Channel 3 selected       |

### Bits 5-3 - Parallel Port DMA Plug and Play Support

Upon reset these bits are initialized to 000.

When a DMA request signal, i.e., DRQ0, DRQ1, DRQ2 or DRQ3, is not configured as an FDC DMA request signal, a parallel port DMA request signal or a UART2 DMA request signal, it is in TRI-STATE.

When a DMA acknowledge signal, i.e., DACKO, DACK1, DACK2 or DACK3, is not configured as an FDC DMA acknowledge signal, a parallel port DMA acknowledge signal or a UART2 DMA acknowledge signal, it is ignored.

TABLE 2-14. Parallel Port Plug and Play DMA Settings

| Bit 5 | Bit 4 | Bit 3 | Parallel Port DMA Plug and Play Setting                                                                                                                                                                                           |
|-------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | 0     | 0     | Disabled. Parallel port's DMA is not connected to any ISA DMA channel, i.e., it is not connected to any of the chip's DMA pins. It is the software's responsibility to route all DMA sources onto the ISA DMA channels correctly. |
| 0     | 0     | 1     | Parallel port's DMA request and acknowledge signals are connected to DRQ0 and DACK0 pins.                                                                                                                                         |
| 0     | 1     | 0     | Parallel port's DMA request and acknowledge signals are connected to DRQ1 and DACK1 pins.                                                                                                                                         |
| 0     | 1     | 1     | Parallel port's DMA request and acknowledge signals are connected to DRQ2 and DACK2 pins.                                                                                                                                         |
| 1     | 0     | 0     | Parallel port's DMA request and acknowledge signals are connected to DRQ3 and DACK3 pins.                                                                                                                                         |
| 1     | 0     | 1     | Reserved                                                                                                                                                                                                                          |
| 1     | 1     | 0     | Reserved                                                                                                                                                                                                                          |
| 1     | 1     | 1     | Reserved                                                                                                                                                                                                                          |

#### Bits 7-6 - Reserved

These bits are reserved.

## 2.3.19 Plug and Play Configuration 0 Register (PNP0), Index 1Bh

This register allows configurable mapping of the parallel port's interrupt onto the ISA interrupts. Upon reset, PNP0 is initialized to 00000xxx.



FIGURE 2-20. PNP0 Register Bitmap

### Bits 2-0 - Parallel Port IRQ Select

These bits are reflected on bits 5-3 of the CNFGB ECP register. Bit 0 of PNP0 is reflected on bit 3 of CNFGB.

Upon reset, these bits are undefined.

Microsoft's ECP Protocol and ISA Interface Standard defines these bits as shown in Table 2-15.

TABLE 2-15. Parallel Port Plug and Play Interrupt Assignment

| Bit 2 | Bit 1 | Bit 0 | Interrupt Assignment                             |
|-------|-------|-------|--------------------------------------------------|
| 0     | 0     | 0     | Parallel port's interrupt is selected by jumpers |
| 0     | 0     | 1     | IRQ7 is parallel port's interrupt                |
| 0     | 1     | 0     | IRQ9 is parallel port's interrupt                |
| 0     | 1     | 1     | IRQ10 is parallel port's interrupt               |
| 1     | 0     | 0     | IRQ11 is parallel port's interrupt               |
| 1     | 0     | 1     | IRQ14 is parallel port's interrupt               |
| 1     | 1     | 0     | IRQ15 is parallel port's interrupt               |
| 1     | 1     | 1     | IRQ5 is parallel port's interrupt                |

### Bit 3 - Select Legacy or Plug and Play Mode

Upon reset this bit is initialized to 0. This bit may be modified only when all modules are disabled. In both modes, the Chip can decode 11-bit addresses or 16-bit addresses, according to the strap pin CFG0. Decoding of 10-bit addresses is not supported.

### 0 - Legacy mode. (Default)

The interrupts and the base addresses of the FDC, UART1, UART2 and the parallel port are configured as in legacy devices, i.e., as in previous Superl/O chips. DMA channels are configurable under this mode.

### 1 - Plug and Play mode.

The interrupts, the DMA channels and the base addresses of the FDC, UART1, UART2 and the parallel port are fully Plug and Play.

### Bits 7-4 - Parallel Port Interrupt Mapping

Parallel port interrupt mapping in Plug and Play mode. Upon reset these bits are initialized to 0000. When enabled it can be routed onto one of the following ISA interrupts: IRQ7-3, IRQ12-9 and IRQ15, as shown in Table 2-16.

TABLE 2-16. Parallel Port Plug and Play Interrupt Mapping

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Interrupt |
|-------|-------|-------|-------|-----------|
| 0     | 0     | 0     | 0     | Disable   |
| 0     | 0     | 0     | 1     | Invalid   |
| 0     | 0     | 1     | 0     | Invalid   |
| 0     | 0     | 1     | 1     | IRQ3      |
| 0     | 1     | 0     | 0     | IRQ4      |
| 0     | 1     | 0     | 1     | IRQ5      |
| 0     | 1     | 1     | 0     | IRQ6      |
| 0     | 1     | 1     | 1     | IRQ7      |
| 1     | 0     | 0     | 0     | Invalid   |
| 1     | 0     | 0     | 1     | IRQ9      |
| 1     | 0     | 1     | 0     | IRQ10     |
| 1     | 0     | 1     | 1     | IRQ11     |
| 1     | 1     | 0     | 0     | IRQ12     |
| 1     | 1     | 0     | 1     | Invalid   |
| 1     | 1     | 1     | 0     | Invalid   |
| 1     | 1     | 1     | 1     | IRQ15     |

Disable means the interrupt of the parallel port is not routed to any ISA interrupt. Unpredictable results when invalid values are written. IRQ5, IRQ12 and IRQ15 can not always be configured. For more details, see Chapter 6 on page 185.

It is the software's responsibility to route all interrupt sources onto the ISA interrupts correctly. These bits work with bits 2-0, to select the interrupt destination for the parallel port. However, the ac-

tual hardware selection is determined by bits 7-4 and it is software's responsibility to keep bits 2-0 and 7-4 in synchronization (if desired).

In Legacy mode, these bits are ignored and parallel port interrupt mapping is controlled by bits 1,0 of the FAR register, bit 3 of the PTR register and bit 0 of the ASC register.

### 2.3.20 Plug and Play Configuration 1 Register (PNP1), Index 1Ch

This register allows configurable mapping of the UART's interrupt onto the ISA interrupts. Upon reset, PNP1 is initialized to 00000000.

In Legacy mode, this register is ignored and the UART interrupt mapping is controlled via bits 7-2 of the FAR register.



FIGURE 2-21. PNP1 Register Bitmap

### Bits 3-0 - UART1 Interrupt Mapping

UART1 interrupt mapping in Plug and Play mode. Upon reset these bits are initialized to 0000.

These bits are defined and handled identically to bits 4,5,6 and 7 of the parallel port in the Plug and Play Configuration 0 Register (PNP0), Index 1Bh.

### Bits 7-4 - UART2 Interrupt Mapping

UART2 interrupt mapping in Plug and Play mode. Upon reset these bits are initialized to 0000.

These bits are defined and handled identically to bits 4,5,6 and 7 of the parallel port in the Plug and Play Configuration 0 Register (PNP0), Index 1Bh.

## 2.3.21 SuperI/O Chip Configuration Register 2 (SCF2), Index 40h

Undefined value when out of reset. This register controls the following.



FIGURE 2-22. SCF2 Register Bitmap

### Bits 1,0 - VLD0,1

These bits determine the state of bit 5 in the FDC Tape Drive Register (TDR), when either Automatic Media Sense TDR or Enhanced TDR is configured (bit 0 of FCR = 0 or bit 2 of ASC = 1).

Bit 5 of TDR holds VLD0 bit value when two floppy disk drives mode is configured (bit 4 of FER is 0) and drive 0 is accessed. Bit 5 of TDR holds VLD1 bit value when two floppy disk drives mode is configured (bit 4 of FER is 0) and drive 1 is accessed. Otherwise, bit 5 of TDR holds 1.

Upon reset, these bits are undefined.

TABLE 2-17. TDR Bit 5 Values

| Drive Accessed | sc    | TDR   |       |
|----------------|-------|-------|-------|
| Drive Accessed | Bit 1 | Bit 0 | Bit 5 |
| 0              | х     | 0     | 0     |
| 0              | х     | 1     | 1     |
| 1              | 0     | х     | 0     |
| 1              | 1     | х     | 1     |
| None           | х     | х     | 1     |

#### Bits 3-2 - Reserved

These bits are reserved.

### Bit 4 - UART1 Bank Select Enable

Enables bank switching. Upon reset, this bit is initialized to 0.

- O All attempts to access the extended registers of UART1 are ignored. (Default)
- 1 UART1 extended registers accessible.

#### Bits 5 - UART2 Normal Power Mode

Upon reset, this bit is initialized to 1.

- 0 Low power mode. UART2's clock is disabled. IRSL2, 1 and 0 output signals are set to 0. The RI2 input signal can be programmed to generate an interrupt. Registers are maintained.
- Normal power mode UART2's clock is enabled. UART2 is functional, when bit 2 of the FER register is set to 1.

### Bit 6 - UART2 is Busy

Read only. This bit can be used by power management software to decide when to power down UART2.

Upon reset, this bit is initialized to 0.

- 0 No transfer is in progress. (Default)
- 1 A transfer is in progress.

#### Bit 7 - UART2 Bank Select Enable

Enables bank switching. Upon reset, this bit is initialized to 0.

- O All attempts to access the extended registers of UART2 are ignored. (Default)
- 1 UART2 extended registers accessible.

## 2.3.22 Plug and Play Configuration 2 Register (PNP2), Index 41h

This register allows configurable mapping of the FDC's interrupt and DMA signals onto the ISA interrupts and DMA channels. It allows also configurable mapping of the parallel port's DMA signals onto the ISA DMA channels. Upon reset, PNP2 is initialized to 00110000.



FIGURE 2-23. PNP2 Register Bitmap

### Bits 3-0 - FDC Interrupt Mapping

FDC interrupt mapping in Plug and Play mode. Upon reset these bits are initialized to 0000.

When enabled it can be routed onto one of the following ISA interrupts: IRQ3-IRQ7, IRQ9-IRQ12 and IRQ15. See Table 2-18.

Disable means FDC's interrupt is not routed to any ISA interrupt. Unpredictable results when invalid values are written. IRQ5, IRQ12 and IRQ15 can not always be configured. For more details, refer to Chapter 6 on page 185.

It is the software's responsibility to route all interrupt sources onto the ISA interrupts correctly.

In Legacy mode, these bits are ignored and the interrupt of the FDC is connected to IRQ6.

TABLE 2-18. FDC Plug and Play Interrupt
Mapping

| Bit 3 | Bit 2 | Bit 1 | Bit 0 | Interrupt |
|-------|-------|-------|-------|-----------|
| 0     | 0     | 0     | 0     | Disable   |
| 0     | 0     | 0     | 1     | Invalid   |
| 0     | 0     | 1     | 0     | Invalid   |
| 0     | 0     | 1     | 1     | IRQ3      |
| 0     | 1     | 0     | 0     | IRQ4      |
| 0     | 1     | 0     | 1     | IRQ5      |
| 0     | 1     | 1     | 0     | IRQ6      |
| 0     | 1     | 1     | 1     | IRQ7      |
| 1     | 0     | 0     | 0     | Invalid   |
| 1     | 0     | 0     | 1     | IRQ9      |
| 1     | 0     | 1     | 0     | IRQ10     |
| 1     | 0     | 1     | 1     | IRQ11     |
| 1     | 1     | 0     | 0     | IRQ12     |

| Bit 3 | Bit 2 | Bit 1 | Bit 0 | Interrupt |
|-------|-------|-------|-------|-----------|
| 1     | 1     | 0     | 1     | Invalid   |
| 1     | 1     | 1     | 0     | Invalid   |
| 1     | 1     | 1     | 1     | IRQ15     |

### Bits 6-4 - FDC DMA Plug and Play Support

Upon reset these bits are initialized to 011. It is the software's responsibility to route all DMA sources onto the ISA DMA channels correctly. See Table 2-19.

When a DMA request pin, i.e., DRQ0, DRQ1, DRQ2 or DRQ3 is not configured as an FDC DMA request signal or a Parallel Port DMA request signal, it is in TRI-STATE.

When a DMA acknowledge pin, i.e., DACK0, DACK1, DACK0 or DACK3 is not configured as an FDC DMA acknowledge signal or a parallel port DMA acknowledge signal, it is ignored.

TABLE 2-19. FDC Plug and Play DMA Settings

| Bit 5 | Bit 4 | Bit 3 | FDC DMA Plug and Play Setting                                                                                       |
|-------|-------|-------|---------------------------------------------------------------------------------------------------------------------|
| 0     | 0     | 0     | Disabled. FDC DMA is not connected to any ISA DMA channel, i.e., it is not connected to any of the chip's DMA pins. |
| 0     | 0     | 1     | FDC DMA request and acknowledge signals are connected to DRQ0 and DACK0 pins.                                       |
| 0     | 1     | 0     | FDC DMA request and acknowledge signals are connected to DRQ1 and DACK1 pins.                                       |
| 0     | 1     | 1     | FDC DMA request and acknowledge signals are connected to DRQ2 and DACK2 pins.                                       |
| 1     | 0     | 0     | FDC DMA request and acknowledge signals are connected to DRQ3 and DACK3 pins.                                       |
| 1     | 0     | 1     | Reserved                                                                                                            |
| 1     | 1     | 0     | Reserved                                                                                                            |
| 1     | 1     | 1     | Reserved                                                                                                            |

### Bit 7 - Reserved

This bit is reserved.

## 2.3.23 Parallel Port Base Address Low Byte Register (PBAL), Index 42h

This register holds the low address bits of the parallel port's base address.

In Legacy mode, this register is ignored and the base address of the parallel port is determined by bits 1 and 0 of the FAR register.

In Plug and Play mode when EPP is enabled, bit 0 (A2) must be 0.

This register may be modified only when the parallel port is disabled. Undefined value when out of reset.

It is the software's responsibility to configure all devices so there will be no conflicts.



FIGURE 2-24. PBAL Register Bitmap

### 2.3.24 Parallel Port Base Address High Byte Register (PBAH), Index 43h

This register holds the high address bits of the parallel port's base address.

In Plug and Play mode, when ECP is enabled, bit 2 (A10) must be 0.

In Legacy mode, this register is ignored and the base address of the Parallel Port is determined by bits 1 and 0 of the FAR register.

This register may be modified only when the parallel port is disabled. Undefined value when out of reset.

It is the software's responsibility to configure all devices so there will be no conflicts.



FIGURE 2-25. PBAH Register Bitmap

## 2.3.25 UART1 Base Address Low Byte Register (U1BAL), Index 44h

This register holds the low address bits of UART1's base address.

In Legacy mode, this register is ignored and the base address of UART1 is determined by bits 3 and 2, and bits 7 and 6 of the FAR register.

This register may be modified only when UART1 is disabled. Undefined value when out of reset.

It is the software's responsibility to configure all devices so there will be no conflicts.



FIGURE 2-26. U1BAL Register Bitmap

## 2.3.26 UART1 Base Address High Byte Register (U1BAH), Index 45h

This register holds the high address bits of UART1's base address.

In Legacy mode, this register is ignored and the base address of UART1 is determined by bits 3 and 2, and bits 7 and 6 of the FAR register.

This register may be modified only when UART1 is disabled. Undefined value when out of reset.

It is the software's responsibility to configure all devices so as to avoid conflicts.



FIGURE 2-27. U1BAH Register Bitmap

## 2.3.27 UART2 Base Address Low Byte Register (U2BAL), Index 46h

This register holds the low address bits of UART2's base address.

In Legacy mode, this register is ignored and the base address of UART2 is determined by bits 7 through 4 of the FAR register.

This register may be modified only when UART2 is disabled. Undefined value when out of reset.

It is the software's responsibility to configure all devices so as to avoid conflicts.



FIGURE 2-28. U2BAL Register Bitmap

## 2.3.28 UART2 Base Address High Byte Register (U2BAH), Index 47h

This register holds the high address bits of UART2's base address.

In Legacy mode, this register is ignored and the base address of UART2 is determined by bits 4-7 of FAR register.

This register may be modified only when UART2 is disabled. Undefined value when out of reset.

It is the software's responsibility to configure all devices so as to avoid conflicts.



FIGURE 2-29. U2BAH Register Bitmap

## 2.3.29 FDC Base Address Low Byte Register (FBAL), Index 48h

This register holds the low address bits of the FDC's base address.

In Legacy mode, this register is ignored and the base address of the FDC is determined by bit 5 of the FER register.

This register may be modified only when the FDC is disabled. Undefined value when out of reset.

It is the software's responsibility to configure all devices so as to avoid conflicts.



FIGURE 2-30. FBAL Register Bitmap

## 2.3.30 FDC Base Address High Byte Register (FBAH,) Index 49h

This register holds the high address bits of the FDC's base address.

In Legacy mode, this register is ignored and the base address of the FDC is determined by bit 5 of the FER register.

This register may be modified only when the FDC is disabled. Undefined value when out of reset.

It is the software's responsibility to configure all devices so as to avoid conflicts.



FIGURE 2-31. FBAH Register Bitmap

## 2.3.31 SIO Base Address Low Byte Register (SBAL), Index 4Ah

This register holds the low address bits of the base address of the SuperI/O chip, i.e., the Chip. These bits are also the low address bits of the INDEX register.

The address of the DATA register is the next consecutive address after the address of the INDEX register.

The reset value of SBAL depends on the values of BADDR0 and BADDR1 during reset. See Table 2-20.

For more details about programming the Chip's base address, see Section 2.2.5 on page 21.

It is the software's responsibility to configure all devices so as to avoid conflicts.

**TABLE 2-20. SBAL Reset Values** 

| BADDR1 | BADDR0 | SBAL Reset Value |
|--------|--------|------------------|
| 0      | 0      | 98h              |
| 0      | 1      | Undefined        |
| 1      | 0      | 5Ch              |
| 1      | 1      | 2Eh              |



FIGURE 2-32. SBAL Register Bitmap

## 2.3.32 SIO Base Address High Byte Register (SBAH), Index 4Bh

This register holds the high address bits of the base address of the SuperI/O chip, i.e., the Chip. These bits are also the high address bits of the INDEX register.

The address of the DATA register is the next consecutive address after the address of the INDEX register.

The reset value of SBAH depends on the values of BADDR0 and BADDR1 during reset. See Table 2-21.

For more details about programming the Chip's base address see Section 2.2.5 on page 21.

It is the software's responsibility to configure all devices so as to avoid conflicts.

TABLE 2-21. SBAH Reset Values

| BADDR1 | BADDR0 | SBAH Reset Values |
|--------|--------|-------------------|
| 0      | 0      | 03h               |
| 0      | 1      | Undefined         |
| 1      | 0      | 01h               |
| 1      | 1      | 00h               |



FIGURE 2-33. SBAH Register Bitmap

## 2.3.33 System IRQ Input 1 Configuration Register (SIRQ1), Index 4Ch

This register allows configuration of the SIRQI1 signal. It is initialized to x0x00000 during reset.



FIGURE 2-34. SIRQ1 Register Bitmap

### Bits 3-0 - SIRQI1 Mapping

When it controls its pin, SIRQI1 can be routed onto one of the following ISA interrupts: IRQ7-3, IRQ12-9. See Table 2-22.

Unpredictable results when invalid values are written. IRQ5 and IRQ12 can not always be configured. For more details, refer to Chapter 6.

It is the software's responsibility to route all interrupt sources onto the ISA interrupts correctly.

TABLE 2-22. SIRQI1 Plug and Play Interrupt Mapping

| Bit 3 | Bit 2 | Bit 1 | Bit 0 | Interrupt |
|-------|-------|-------|-------|-----------|
| 0     | 0     | 0     | 0     | Disable   |
| 0     | 0     | 0     | 1     | Invalid   |
| 0     | 0     | 1     | 0     | Invalid   |
| 0     | 0     | 1     | 1     | IRQ3      |
| 0     | 1     | 0     | 0     | IRQ4      |
| 0     | 1     | 0     | 1     | IRQ5      |
| 0     | 1     | 1     | 0     | IRQ6      |
| 0     | 1     | 1     | 1     | IRQ7      |
| 1     | 0     | 0     | 0     | Invalid   |
| 1     | 0     | 0     | 1     | IRQ9      |
| 1     | 0     | 1     | 0     | IRQ10     |
| 1     | 0     | 1     | 1     | IRQ11     |
| 1     | 1     | 0     | 0     | IRQ12     |
| 1     | 1     | 0     | 1     | Invalid   |
| 1     | 1     | 1     | 0     | Invalid   |
| 1     | 1     | 1     | 1     | Invalid   |

#### Bit 4 - Invert SIRQI1

This bit inverts the interrupt selected by bits 3-0.

- 0 SIRQI1 not inverted. IRQx = SIRQI1.
- 1 SIRQI1 inverted, IRQx = SIRQI1.

#### Bit 5 - SIRQI1 Status

This bit is read-only. It holds the value of SIRQI1, when SIRQI1 controls its pin.

### Bits 7, 6 - Select IRQ15, SIRQI1 or DRQ3

Upon reset, these bits are initialized to 00.

TABLE 2-23. SIRQ1 Interrupt Settings

| Bit 7 | Bit 6 | Selected Interrupt<br>Connected to Pin |
|-------|-------|----------------------------------------|
| 0     | 0     | IRQ15                                  |
| 0     | 1     | SIRQI1                                 |
| 1     | 0     | DRQ3                                   |
| 1     | 1     | Reserved                               |

## 2.3.34 System IRQ Input 2 Configuration Register (SIRQ2), Index 4Dh

This register allows configuration of the SIRQI2 signal. See Table 2-25. It is initialized to 00x00000 during reset.



FIGURE 2-35. SIRQ2 Register Bitmap

### Bits 3-0 - SIRQI2 Mapping

When it controls its pin, SIRQI2 can be routed onto one of the following ISA interrupts: IRQ7-3, IRQ12-9 and IRQ15. See Table 2-24.

Unpredictable results when invalid values are written. IRQ5, IRQ12 and IRQ15 can not always be configured. For more details, refer to Chapter 6.

It is the software's responsibility to route all interrupt sources onto the ISA interrupts correctly.

TABLE 2-24. SIRQI2 Plug and Play Interrupt
Mapping

| Bit 3 | Bit 2 | Bit 1 | Bit 0 | Interrupt |
|-------|-------|-------|-------|-----------|
| 0     | 0     | 0     | 0     | Disable   |
| 0     | 0     | 0     | 1     | Invalid   |
| 0     | 0     | 1     | 0     | Invalid   |
| 0     | 0     | 1     | 1     | IRQ3      |
| 0     | 1     | 0     | 0     | IRQ4      |
| 0     | 1     | 0     | 1     | IRQ5      |
| 0     | 1     | 1     | 0     | IRQ6      |
| 0     | 1     | 1     | 1     | IRQ7      |
| 1     | 0     | 0     | 0     | Invalid   |
| 1     | 0     | 0     | 1     | IRQ9      |
| 1     | 0     | 1     | 0     | IRQ10     |
| 1     | 0     | 1     | 1     | IRQ11     |
| 1     | 1     | 0     | 0     | IRQ12     |
| 1     | 1     | 0     | 1     | Invalid   |
| 1     | 1     | 1     | 0     | Invalid   |
| 1     | 1     | 1     | 1     | IRQ15     |

### Bit 4 - Invert SIRQI2

In the following, x may equal 3, 4, 5, 6, 7, 9, 10, 11, 12 or 15, according to bits 3-0 of this register.

- 0 SIRQI2 is not inverted. IRQx = SIRQI2.
- 1 SIRQI2 is inverted. IRQx = inverted SIRQI2.

### Bit 5 - SIRQI2 Status

This bit is read-only. It holds the value of SIRQI2, when SIRQI2 controls its pin.

### Bits 7,6 - Select MSEN1, DRATE1, CSO or SIRQI2

These bits are ignored when bit 0 of the SCF3 register is 1. Setting bit 0 of the SCF3 register to 1 gives DACK3 control of the pin it shares with MSEN1, DRATE1, CSO and SIRQI2.

Table 2-25 shows how the values of these bits control which signal uses the pin they share.

TABLE 2-25. Selecting MSEN1, DRATE1, CS0 or SIRQI2

| Bit 0 of<br>SCF3 | Bit 7 of<br>SIRQ2 | Bit 6 of<br>SIRQ2 | Signal that<br>Uses the Pin |
|------------------|-------------------|-------------------|-----------------------------|
| 0                | 0                 | 0                 | MSEN1                       |
| 0                | 0                 | 1                 | DRATE1                      |
| 0                | 1                 | 0                 | CS0                         |
| 0                | 1                 | 1                 | SIRQI2                      |
| 1                | х                 | х                 | DACK3                       |

## 2.3.35 System IRQ Input 3 Configuration Register (SIRQ3), Index 4Eh

This register allows configuration of the SIRQI3 signal. See Table 2-27.

SIRQ3 is initialized to 00x00000 during reset.



FIGURE 2-36. SIRQ3 Register Bitmap

### Bits 3-0 - SIRQI3 Mapping

When SIRQI3 controls its pin, it can be routed onto one of the following ISA interrupts: IRQ3-IRQ7, IRQ9-IRQ12 and IRQ15. See Table 2-26.

Unpredictable results when invalid values are written. IRQ5, IRQ12 and IRQ15 can not always be configured. For more details, refer to Chapter 6.

It is the software's responsibility to route all interrupt sources onto the ISA interrupts correctly.

TABLE 2-26. SIRQI3 Plug and Play Interrupt
Mapping

| Bit 3 | Bit 2 | Bit 1 | Bit 0 | Interrupt |
|-------|-------|-------|-------|-----------|
| 0     | 0     | 0     | 0     | Disable   |
| 0     | 0     | 0     | 1     | Invalid   |
| 0     | 0     | 1     | 0     | Invalid   |
| 0     | 0     | 1     | 1     | IRQ3      |
| 0     | 1     | 0     | 0     | IRQ4      |
| 0     | 1     | 0     | 1     | IRQ5      |
| 0     | 1     | 1     | 0     | IRQ6      |
| 0     | 1     | 1     | 1     | IRQ7      |
| 1     | 0     | 0     | 0     | Invalid   |
| 1     | 0     | 0     | 1     | IRQ9      |
| 1     | 0     | 1     | 0     | IRQ10     |
| 1     | 0     | 1     | 1     | IRQ11     |
| 1     | 1     | 0     | 0     | IRQ12     |
| 1     | 1     | 0     | 1     | Invalid   |
| 1     | 1     | 1     | 0     | Invalid   |
| 1     | 1     | 1     | 1     | IRQ15     |

### Bit 4 - Invert SIRQI3

In the following, x = 3, 4, 5, 6, 7, 9, 10, 11, 12 or 15, according to bits 0-3 of this register.

- 0 SIRQI3 not inverted. IRQx = SIRQI3.
- 1 SIRQI3 inverted, IRQx = SIRQI3.

### Bit 5 - SIRQI3 Status

This bit is read-only. It holds the value of SIRQI3, when selected on the pin.

### Bits 7,6 - Select DRV2, DR23, PNF or SIRQI3

When  $\overline{DR23}$  controls the pin, it is asserted when either drive 2 or drive 3 is accessed (except during logical drive exchange - see bit 3 of TDR). Its value is undefined in four drive encoded mode, i.e., when bit 4 of the FER register is 1.

DRV2 is masked to 1, when DR23 controls the pin on the pin. When DRV2, PNF or SIRQI3 control the pin, the pin is read via the DRV2 bit (in the FDC registers).

When PNF does not control the pin, it is masked to

These bits are ignored when bit 1 of the SCF3 register is 1. Bit 1 of the SCF3 register allows selection of IRSL2/*ID0* (*ID0 in PC97338 only*) to control the pin.

Table 2-27 shows how the values of these bits control which signal uses the pin they share.

TABLE 2-27. Selecting DRV2, DR23, PNF or SIRQI3

| Bit 1 of<br>SCF3 | Bit 7 of<br>SIRQ3 | Bit 6 of<br>SIRQ3 | Signal that Uses the Pin |
|------------------|-------------------|-------------------|--------------------------|
| 0                | 0                 | 0                 | DRV2                     |
| 0                | 0                 | 1                 | DR23                     |
| 0                | 1                 | 0                 | PNF                      |
| 0                | 1                 | 1                 | SIRQI3                   |
| 1                | х                 | х                 | IRSL2                    |

## 2.3.36 Plug-and-Play Configuration 3 Register (PNP3), Index 4Fh

This register allows configurable mapping of the UART2 DMA signals onto the ISA DMA channels, as shown in Tables 2-28 and 2-29, for reception and transmission, respectively.

When a DMA request pin, i.e., DRQ0, DRQ1, DRQ2 or DRQ3, is not configured as an FDC DMA request signal, a parallel port DMA request signal or a UART2 DMA request signal, it is in TRI-STATE.

When a DMA acknowledge pin, i.e., DACKO, DACK1, DACK2 or DACK3, is not configured as an FDC DMA acknowledge signal, a parallel port DMA acknowledge signal or a UART2 DMA acknowledge signal, it is ignored.



FIGURE 2-37. PNP3 Register Bitmap

### Bits 2-0 - UART2 DMA Plug and Play Support for Reception

Upon reset these bits are initialized to 000. It is the software's responsibility to route all DMA sources onto the ISA DMA channels correctly. Table 2-28 shows the encoding options for these bits.

TABLE 2-28. UART2 Plug and Play DMA Settings for Reception

| Bit 2 | Bit 1 | Bit 0 | UART2 DMA Plug and Play<br>Reception Settings                                                                         |  |
|-------|-------|-------|-----------------------------------------------------------------------------------------------------------------------|--|
| 0     | 0     | 0     | Disabled. UART2 DMA is not connected to any ISA DMA channel, i.e., it is not connected to any of the chip's DMA pins. |  |
| 0     | 0     | 1     | UART2 reception DMA request and acknowledge signals are connected to DRQ0 and DACK0 pins.                             |  |
| 0     | 1     | 0     | UART2 reception DMA request and acknowledge signals are connected to DRQ1 and DACK1 pins.                             |  |
| 0     | 1     | 1     | UART2 reception DMA request and acknowledge signals are connected to DRQ2 and DACK2 pins.                             |  |
| 1     | 0     | 0     | UART2 reception DMA request and acknowledge signals are connected to DRQ3 and DACK3 pins.                             |  |
| 1     | 0     | 1     | Reserved                                                                                                              |  |
| 1     | 1     | 0     | Reserved                                                                                                              |  |
| 1     | 1     | 1     | Reserved                                                                                                              |  |

### Bits 5-3 - UART2 DMA Plug and Play Support for Transmission.

Upon reset these bits are initialized to 000. It is the software's responsibility to route all DMA sources onto the ISA DMA channels correctly. Table 2-29 shows the encoding options for these bits.

TABLE 2-29. UART2 Plug and Play DMA Settings for Transmission

| Bit 5 | Bit 4 | Bit 3 | UART2 DMA Plug and Play<br>Transmission Setting                                                                       |
|-------|-------|-------|-----------------------------------------------------------------------------------------------------------------------|
| 0     | 0     | 0     | Disabled. UART2 DMA is not connected to any ISA DMA channel, i.e., it is not connected to any of the chip's DMA pins. |
| 0     | 0     | 1     | UART2 transmission DMA request and acknowledge signals are connected to DRQ0 and DACK0 pins.                          |
| 0     | 1     | 0     | UART2 transmission DMA request and acknowledge signals are connected to DRQ1 and DACK1 pins.                          |
| 0     | 1     | 1     | UART2 transmission DMA request and acknowledge signals are connected to DRQ2 and DACK2 pins.                          |
| 1     | 0     | 0     | UART2 transmission DMA request and acknowledge signals are connected to DRQ3 and DACK3 pins.                          |
| 1     | 0     | 1     | Reserved                                                                                                              |
| 1     | 1     | 0     | Reserved                                                                                                              |
| 1     | 1     | 1     | Reserved                                                                                                              |

## 2.3.37 SuperI/O Configuration 3 Register (SCF3), Index 50h

This register controls the following. Upon reset, all implemented bits are initialized to 0.



FIGURE 2-38. SCF3 Register Bitmap

### Bit 0 - Select DRATE1, MSEN1, CS0, SIRQI2 or DACK3

When the pin is assigned for DACK3, MSEN1 is masked to 1.

- DRATE1, MSEN1, CSO or SIRQI2 may use the pin, according to bits 7 and 6 of the SIRQ2 register. (Default)
- 1 DACK3 may use the pin.

### Bit 1 - Select DRV2, PNF, DR23, SIRQI3 or IRSL2/ID2

DRV2 and PNF are masked to 1, when the pin is assigned for IRSL2.

- 0 DRV2, PNF, DR23 or SIRQI3 may use the pin, according to bits 7 and 6 of SIRQ3 register.
- 1 IRSL2/ID2 may use the pin (ID2 is only in PC97338).

### Bit 2 - Select MTR1, IDLE or IRSL2/ID2

- 0 MTR1 or IDLE may use the pin, according to bit 4 of PMC register.
- 1 IRSL2/ID2 uses the pin (ID2 is only in PC97338).

### Bit 3 - Select IRQ12, IRRX2, IRSL0/ID0

This bit is ignored in 11-bit address mode.

- 0 IRQ12 may use the pin.
- 1 IRRX2 or IRSL0/ID0 may use the pin, according to UART2 extended registers (ID0 is only in PC97338).

### Bit 7-4 - Reserved

These bits are reserved.

## 2.3.38 Clock Control Register (CLK), Index 51h

Upon power on (when  $V_{DD}$  is applied), all bits of this register are initialized to 0.

This register is not reset by the MR pin.



FIGURE 2-39. CLK Register Bitmap

### Bits 1,0 - SuperI/O Chip Clock Source

These bits define the clock source for the SuperI/O chip that is fed via the X1 pin.

Upon power on, these bits are read or write. Once they are written, they become read-only bits.

- 00 The clock source is the on-chip clock multiplier fed by 14.318 MHz.
- 01 The clock source is the on-chip clock multiplier fed by 24 MHz.
- 10 The clock source is 48 MHz.
- 11 Reserved.

### Bit 2 - Clock Multiplier Enable

Bits 2 and 3 of the PCR register may affect this bit.

- 0 On chip clock multiplier is disabled.
- 1 On chip clock multiplier is enabled.

### Bit 3 - Valid Multiplier Clock Status

Read only.

- 0 On-chip clock (clock multiplier output) is frozen
- 1 On-chip clock (clock multiplier output) is stable and toggling.

#### Bits 7-4 - Reserved

These bits are reserved.

### 2.3.39 Manufacturing Test Register (MTEST), Index 52h

This register controls manufacturing tests. It exist only in the PC97338 version.

# 3.0 The Digital Floppy Disk Controller (FDC)

The Floppy Disk Controller (FDC) is suitable for all PC-AT, EISA, PS/2, and general purpose applications. DP8473 and N82077 software compatibility is provided. Key features include a 16-byte FIFO, PS/2 diagnostic register support, perpendicular recording mode, CMOS disk input and output logic, and a high performance Digital Data Separator (DDS).

Figure 3-1shows a functional block diagram of the FDC. The rest of this chapter describes the FDC functions, data transfer, the FDC registers, the phases of FDC commands, the result phase status registers and the FDC commands, in that order.

#### 3.1 FDC FUNCTIONS

The Chip is software compatible with the DP8473 and 82077 Floppy Disk Controllers (FDCs). Upon a power-on reset, the 16-byte FIFO is disabled. Also, the disk interface output signals are configured as active push-pull output signals, which are compatible with both CMOS input signals and open-collector resistor

terminated disk drive input signals. The FIFO can be enabled with the CONFIGURE command. The FIFO can be very useful at high data rates, with systems that have a long DMA bus latency, or with multi-tasking systems such as the EISA or MCA bus structures.

The FDC supports all the DP8473 MODE command features as well as some additional features. These include control over the enabling of the FIFO for read and write operations, disabling burst mode for the FIFO, a bit that will configure the disk interface outputs as open-drain output signals, and programmability of the DENSEL output signal.

## 3.1.1 Microprocessor Interface

The FDC interface to the microprocessor consists of the A9-3, AEN, RD, and WR signals, which access the chip for read and write operations; the data signals D7-0; the address lines A2-0, which select the appropriate register (see Table 3-1); the IRQ6 signal, and the DMA interface signals DRQ, DACK, and TC. It is through this microprocessor interface that the Floppy Disk Controller (FDC) receives commands, transfers data, and returns status information.



FIGURE 3-1. FDC Functional Block Diagram

## 3.1.2 System Operation Modes

The FDC operates in PC-AT mode or PS/2 mode. The active mode is determined by bit 7 of the ASC register.

## **PC-AT Mode**

The PC-AT register set is enabled. The DMA enable bit in the Digital Output Register (DOR) becomes valid (IRQ6 and DRQ can be put in TRI-STATE). TC and DENSEL become active high signals (defaults to a 5.25" floppy disk drive).

## PS/2 Mode

This mode supports the PS/2 models 50/60/80 configuration and register set. The value of the DMA enable bit in the Digital Output Register (DOR) becomes unimportant (IRQ6 and DRQ signals are always valid). TC and DENSEL become active low signals (default to 3.5" floppy drive).

## 3.2 DATA TRANSFER

#### 3.2.1 Data Rates

The FDC supports the standard PC data rates of 250, 300 and 500 Kbps, as well as1 Mbps and 2 Mbps. High performance tape and floppy disk drives that are currently emerging in the PC world, transfer data at 1 Mbps. Very high performance tape drives transfer data at 2 Mbps. The FDC also supports the perpendicular recording mode, a new format used for some high capacity disk drives at 1 Mbps.

The internal digital data separator needs no external components. It improves the window margin performance standards of the DP8473, and is compatible with the strict data separator requirements of floppy disk drives and tape drives.

The FDC contains write precompensation circuitry that defaults to 125 nsec for 250, 300, and 500 Kbps (41.67 nsec at 1 Mbps). These values can be overridden in software to disable write precompensation or to provide levels of precompensation up to 250 nsec.

The FDC has internal 24 mA data bus buffers which allow direct connection to the system bus. The internal 40 mA totem-pole disk interface buffers are compatible with both CMOS drive input signals and 150 resistor terminated disk drive input signals.

## 3.2.2 The Data Separator

The internal data separator is a fully digital PLL. The fully digital PLL synchronizes the raw data signal read from the disk drive. The synchronized signal is used to separate the encoded clock and data pulses. The data pulses are broken down into bytes, and then sent to the microprocessor by the controller.

The FDC supports five data transfer rates: 250, 300, 500 Kbps and 1, 2 Mbps in Modified Frequency Modulation (MFM) format. *In the PC97338 the FDC supports also the FM encoded data mode.* 

The FDC has a dynamic window margin and lock range performance capable of handling a wide range of floppy disk drives. In addition, the data separator operates under a variety of conditions, including high fluctuations in the motor speed of tape drives that are compatible with floppy disk drives.

The dynamic window margin is the primary indicator of the quality and performance level of the data separator. It indicates the toleration of the data separator for Motor Speed Variation (MSV) of the drive spindle motor and bit jitter (or window margin).

Figure 3-2 shows the dynamic window margin in the performance of the FDC at different data rates, generated using a FlexStar FS-540 floppy disk simulator and a proprietary dynamic window margin test program written by National Semiconductor.





Motor Speed Variation (% of Nominal)

Typical Performance at 500 Kbps,  $V_{DD} = 5.0 \text{ V}, 25^{\circ} \text{ C}$ 

## FIGURE 3-2. PC87338/PC97338 Dynamic Window Margin Performance

The x axis measures MSV. MSV is translated directly to the actual rate at which the data separator reads data from the disk. In other words, a faster than nominal motor results in a higher data rate.

The dynamic window margin performance curve also indicates how much bit jitter (or window margin) can be tolerated by the data separator. This parameter is shown on the y-axis of the graph. Bit jitter is caused by the magnetic interaction of adjacent data pulses on the disk, which effectively shifts the bits away from their nominal positions in the middle of the bit window. Window margin is commonly measured as a percentage. This percentage indicates how far a data bit can be shifted early or late with respect to its nominal bit position, and still be read correctly by the data separator. If the data separator cannot correctly decode a shifted bit, then the data is misread and a CRC error results.

The dynamic window margin performance curve supplies two pieces of information:

- The maximum range of MSV (also called "lock range") that the data separator can handle with no read errors.
- The maximum percentage of window margin (or bit jitter) that the data separator can handle with no read errors.

Thus, the area under the dynamic window margin curves in Figure 3-2 is the range of MSV and bit jitter that the FDC can handle with no read errors. The internal digital data separator of the FDC performs much better than comparable digital data separator designs, and does not require any external components.

The controller maximizes the internal digital data separator by implementing a read algorithm that enhances the lock characteristics of the fully digital Phase-Locked Loop (PLL). The algorithm minimizes the effect of bad data on the synchronization between the PLL and the data.

It does this by forcing the fully digital PLL to re-lock to the clock reference frequency any time the data separator attempts to lock to a non-preamble pattern. See the state diagram of this read algorithm in Figure 3-3.



FIGURE 3-3. Read Algorithm State Diagram

## 3.2.3 Perpendicular Recording Mode Support

The FDC is fully compatible with perpendicular recording mode disk drives at all data transfer rates. These perpendicular drives are also called 4 Mbyte (unformatted) or 2.88 Mbyte (formatted) drives. This refers to their maximum storage capacity.

Perpendicular recording orients the magnetic flux changes (which represent bits) vertically on the disk surface, allowing for a higher recording density than conventional longitudinal recording methods. This increased recording density increases data rate by up to 1 Mbps, thereby doubling the storage capacity. In addition, the perpendicular 2.88 MB drive is read/write compatible with 1.44 MB and 720 KB diskettes (500 Kbps and 250 Kbps respectively).

The 2.88 MB drive has unique format and write data timing requirements due to its read/write head and pre-erase head design. This is illustrated in Figure 3-4.



FIGURE 3-4. Perpendicular Recording Drive Read/Write Head and Pre-Erase Head

Unlike conventional disk drives which have only a read/write head, the 2.88 MB drive has both a preerase head and read/write head. With conventional disk drives, the read/write head, itself, can rewrite the disk without problems. 2.88 MB drives need a preerase head to erase the magnetic flux on the disk surface before the read/write head can write to the disk surface. The pre-erase head is activated during disk write operations only, i.e. FORMAT and WRITE DATA commands.

In 2.88 MB drives, the pre-erase head leads the read/write head by 200  $\mu$ m, which translates to 38 bytes at 1 Mbps (19 bytes at 500 Kbps).

For both conventional and perpendicular drives, WGATE is asserted with respect to the position of the read/write head. With conventional drives, this means that WGATE is asserted when the read/write head is located at the beginning of the preamble to the data field

With 2.88 MB drives, since the preamble must be erased before it is rewritten, WGATE should be asserted when the pre-erase head is located at the beginning of the preamble to the data field. This means that WGATE should be asserted when the read/write head is at least 38 bytes (at 1 Mbps) before the preamble. Tables 3-15 and 3-16 on page 87 show how the perpendicular format affects gap 2 and, consequently, WGATE timing, for different data rates.

Because of the 38-byte spacing between the read/write head and the pre-erase head at 1 Mbps, the gap 2 length of 22 bytes used in the standard IBM disk format is not long enough. The format standard for 2.88 MB drives at 1 Mbps called the Perpendicular Format, increases the length of gap 2 to 41 bytes. See Figure 3-18 on page 82.

The PERPENDICULAR MODE command puts the Floppy Disk Controller (FDC) into perpendicular recording mode, which allows it to read and write perpendicular media. Once this command is invoked, the read, write and format commands can be executed in

the normal manner. The perpendicular mode of the FDC will work at all data rates, adjusting the format and write data parameters accordingly. See "The PERPENDICULAR MODE Command" on page 87 for more details.

## 3.2.4 Data Rate Selection

The FDC sets the data rate in two ways. For PC compatible software, the Configuration Control Register (CCR) at address 3F7h programs the data rate for the FDC. The lower bits D1 and D0 in the CCR set the data rate. The other bits should be set to zero. See Table 3-6 on page 65 to see how to encode the desired data rate.

The lower two bits of the Data rate Select Register (DSR) at address 4 can also set the data rate. These bits are encoded like the corresponding bits in the CCR. The remainder of the bits in the DSR have other functions. See the description of the DSR in Section 3.3.7 on page 65 for more details.

The data rate is determined by the last value written to either the CCR or the DSR. Either the CCR or the DSR can override the data rate selection of the other register. When the data rate is selected, the micro-engine and data separator clocks are scaled appropriately. Also, the DRATE0 and DRATE1 output signals will reflect the state of the data selection bits that were last written to either the CCR or the DSR.

## 3.2.5 Write Precompensation

Write precompensation is a way of preconditioning the WDATA output signal to adjust for the effects of bit shift on the data as it is written to the disk surface. Data that is subject to bit shift is much harder to read by a data separator, and can cause soft read errors.

Bit shift is caused by the magnetic interaction of data bits as they are written to the disk surface. It shifts these data bits away from their nominal position in the serial MFM (*MFM or FM in the PC98338*) data pattern.

Write precompensation predicts where bit shift could occur within a data pattern. It then shifts the individual data bits early, late, or not at all so that when they are written to the disk, the shifted data bits will be back in their nominal position.

The FDC supports software programmable write precompensation. Upon power up, the default write precompensation values shown in Table 3-8 on page 65, will be used. In addition, the default starting track number for write precompensation is track zero

You can use the DSR to change the write precompensation using any of the values in Table 3-7 on page 65. Also, the starting track number for write precompensation can be changed with the CONFIGURE command.

## 3.2.6 FDC Low-Power Mode Logic

The FDC of the Chip supports two low-power modes, manual and automatic. Other low-power modes (also referred to as power down) of the Chip are described in Section 7.1.

In low-power mode, the microcode is driven from the clock, so it will be disabled while the clock is off. If bit 1 of the Power and Test configuration Register (PTR) is 1, the FDC clock is disabled upon entering this mode. Upon entering the power-down state, bit 7, the RQM (Request For Master) bit, in the Main Status Register (MSR) of the FDC will be cleared to 0.

For details concerning entering and exiting low-power mode by setting bit 6 of the Data rate Select Register (DSR) or by executing the LOW PWR option of the FDC MODE command, see "Recovery from Low-Power Mode" later in this section, the "Data Rate Select Register (DSR), Offset 100" on page 65 and Section "The MODE Command" on page 84.

The Data rate Select Register (DSR), Digital Output Register (DOR), and the Configuration Control Register (CCR) are unaffected and remain active in power-down mode. Therefore, you should make sure that the motor and drive select signals are turned off.

If the power to an external clock driving the Chip will be independently removed while the FDC is in powerdown mode, it must not be done until 2 msec after the LOW PWR option of the FDC MODE command is issued.

## **Manual Low-Power Mode**

Manual low power is enabled by writing a 1 to bit 6 of the DSR. The chip will power down immediately. This bit will be cleared to 0 after power up.

Manual low power can also be triggered by the MODE command. Manual low power mode functions as a logical OR function between the DSR low power bit and the LOW PWR option of the MODE command.

## **Automatic Low-Power Mode**

Automatic low power mode switches the controller into low power 500 msec (at the 500 Kbps MFM data rate) after it has entered the Idle state. Once automatic low-power mode is set, it does not have to be set again, and the controller automatically goes into low power mode after entering the Idle state.

Automatic low-power mode can only be set with the LOW PWR option of the MODE command.

## **Recovery from Low-Power Mode**

There are two ways the FDC section can recover from the power-down state.

Power up is triggered by a software reset via the DOR or DSR. Since a software reset requires initialization of the controller, this method might be undesirable.

Power up is also triggered by a read or write to either the Data Register (FIFO) or Main Status Register (MSR). This is the preferred way to power up since all internal register values are retained. It may take a few milliseconds for the clock to stabilize, and the microprocessor will be prevented from issuing commands during this time through the normal MSR protocol. That means that bit 7, the Request for Master (RQM) bit, in the MSR will be a 0 until the clock has stabilized. When the controller has completely stabilized after power up, the RQM bit in the MSR is set to 1 and the controller can continue where it left off.

#### 3.2.7 Reset

The FDC can be reset by hardware or software. A hardware reset consists of pulsing the Master Reset (MR) input signal. A hardware reset sets all of the user addressable registers and internal registers to their default values. The SPECIFY command values are unaffected by reset, so they must be initialized again.

The major default conditions affected by reset are:

- FIFO disabled
- DMA disabled
- · Implied seeks disabled
- Drive polling enabled

A software reset can be triggered by bit 2 of the Digital Output Register (DOR) or bit 7 of the Data rate Select Register (DSR). Bit 7 of DSR clears itself, while bit 2 of DOR does not clear itself.

If the LOCK bit in the LOCK command was set to 1 before the software reset, the FIFO, THRESH, and PRETRK parameters in the CONFIGURE command will be retained. In addition, the FWR, FRD, and BST parameters in the MODE command will be retained if LOCK is set to 1. This function eliminates the need for total initialization of the controller after a software reset

After a hardware (assuming the FDC is enabled in the FER) or software reset, the Main Status Register (MSR) is immediately available for read access by the microprocessor. It will return a 00h value until all the internal registers have been updated and the data separator is stabilized.

When the controller is ready to receive a command byte, the MSR returns a value of 80h (Request for Master (RQM, bit 7) bit is set). The MSR is guaranteed to return the 80h value within 2.5  $\mu sec$  after a hardware or software reset. All other user addressable registers other than the Main Status Register (MSR) and Data Register (FIFO) can be accessed at any time, even during software reset.

#### 3.3 THE REGISTERS OF THE FDC

## **Legacy Mode**

In Legacy mode, the FDC registers are mapped to the offset address shown in Table 3-1, with the base address range provided by the on-chip address decoder. For PC-AT or PS/2 applications, the primary address range of the diskette controller is 3F0 to 3F7h, and the secondary address range is 370 to 377h.

TABLE 3-1. The FDC Registers and Their Addresses

| Cymbol | Description                           | C         | R/W        |            |        |
|--------|---------------------------------------|-----------|------------|------------|--------|
| Symbol | Description                           | <b>A2</b> | <b>A</b> 1 | <b>A</b> 0 | IT/ VV |
| SRA    | Status Register A                     | 0         | 0          | 0          | R      |
| SRB    | Status Register B                     | 0         | 0          | 1          | R      |
| DOR    | Digital Output Register               | 0         | 1          | 0          | R/W    |
| TDR    | Tape Drive Register                   | 0         | 1          | 1          | R/W    |
| MSR    | Main Status Register                  | 1         | 0          | 0          | R      |
| DSR    | Data Rate Select<br>Register          | 1         | 0          | 0          | W      |
| FIFO   | Data Register (FIFO)                  | 1         | 0          | 1          | R/W    |
| -      | (Bus in TRI-STATE)                    | 1         | 1          | 0          | Х      |
| DIR    | Digital Input Register                | 1         | 1          | 1          | R      |
| CCR    | CCR Configuration<br>Control Register | 1         | 1          | 1          | W      |

The FDC supports two system operation modes: PC-AT mode and PS/2 mode (micro-channel systems). Section 3.1.2 on page 53 describes each mode and "Bit 7 - System Operation Mode" on page 36 describes how each is enabled.

Unless specifically indicated otherwise, all fields in all registers are valid in both modes.

#### Plug and Play Mode

In Plug and Play mode, the FDC has plug and play support, as follows:

- The FDC interrupt can be routed on one of the following ISA interrupts: IRQ3-IRQ7, IRQ9-IRQ12 and IRQ15 (see PNP2 register).
- The FDC DMA signals can be routed to one of three 8-bit ISA DMA channels (see PNP2 register); and its base address is software configurable (see FBAL and FBAH registers).
- Upon reset, the DMA of the FDC is routed to the DRQ2 and DACK2 pins.

## 3.3.1 FDC Register Bitmaps











- 0 WP is active, i.e., the FDD in the selected drive is write protected.
- 1 WP is not active, i.e., the FDD in the selected drive is not write protected.

## Bit 2 - Beginning of Track (INDEX)

This bit indicates the beginning of a track. Its value reflects the status of the INDEX disk interface input signal.

- 0 INDEX is active, i.e., it is the beginning of a track.
- 1 INDEX is not active, i.e., it is not the beginning of a track.

#### Bit 3 - Head Select

This bit indicates which side of the Floppy Disk Drive (FDD) is selected by the head. Its value is the inverse of the HDSEL disk interface output signal.

- 0 HDSEL is not active, i.e., the head of the FDD selects side 0. (Default)
- 1 HDSEL is active, i.e., the head of the FDD selects side 1.

## Bit 4 - At Track 0 (TRK0)

This bit indicates whether or not the head of the Floppy Disk Drive (FDD) is at track 0. Its value reflects the status of the TRK0 disk interface input signal.

- 0 TRKO is active, i.e., the head of the FDD is at track 0.
- 1 TRK0 is not active, i.e., the head of the FDD is not at track 0.

#### Bit 5 - Step

This bit indicates whether or not the head of the Floppy Disk Drive (FDD) should move during a seek operation. Its value is the inverse of the STEP disk interface output signal.

- STEP is not active, i.e., the head of the FDD moves. (Default)
- 1 STEP is active (low), i.e., the head of the FDD does not move.

## Bit 6 - Second Drive Installed (DRV2)

This bit indicates whether or not a second Floppy Disk Drive (FDD) has been installed. Its value reflects the status of the TRK0 disk interface input signal.

- 0 DRV2 is active, i.e., a second FDD has been installed.
- 1 DRV2 is not active, i.e., a second FDD has not been installed.

#### Bit 7 - IRQ6 Pending

This bit signals the completion of the execution phase of certain FDC commands. Its value reflects the status of the IRQ6 pin.

- 0 IRQ6 is not active.
- 1 IRQ6 is active, i.e., the FDD has completed execution of certain FDC commands.

## 3.3.3 Status Register B (SRB), Offset 001

Status Register B (SRB) is a read-only diagnostic register that is valid only in PS/2 mode.

SRB can be read at any time while PS/2 mode is active. In PC-AT mode, all bits are in TRI-STATE during a microprocessor read.



FIGURE 3-6. SRB Register Bitmap

#### Bit 0 - Motor 0 Status (MTRO)

This bit indicates whether  $\underline{mot}$  or 0 is on or off. It reflects the status of the  $\overline{MTR0}$  disk interface output signal.

This bit is cleared to 0 by a hardware reset and unaffected by a software reset.

- 0 MTR0 is not active. Motor 0 is off.
- 1 MTR0 is active. Motor 0 is on. (Default)

## Bit 1 - Motor 1 Status (MTR1)

This bit indicates whether motor 1 is on or off. It reflects the status of the MTR1 disk interface output signal.

This bit is cleared to 0 by a hardware reset and unaffected by a software reset.

- 0 MTR0 is not active. Motor 1 is off.
- 1 MTR0 is active. Motor 1 is on. (Default)

#### Bit 2 - Write Circuitry Status (WGATE)

This bit indicates whether the write circuitry of the selected Floppy Disk Drive (FDD) is enabled or not. It reflects the status of the WGATE disk interface output signal.

- 0 WGATE is not active. The write circuitry of the selected FDD is disabled.
- 1 WGATE is active. The write circuitry of the selected FDD is enabled. (Default)

#### Bit 3 - Read Data Status (RDATA)

If read data was sent, this bit indicates whether an odd or even number of bits was sent.

Every inactive edge transition of the RDATA disk interface output signal causes this bit to change state

- 0 Either no read data was sent or an even number of bits of read data was sent. (Default)
- 1 An odd number of bits of read data was sent.

#### Bit 4 - Write Data (WDATA)

If write data was sent, this bit indicates whether an odd or even number of bits was sent.

Every inactive edge transition of the  $\overline{\text{WDATA}}$  disk interface output signal causes this bit to change state.

- 0 Either no write data was sent or an even number of bits of write data was sent. (Default)
- 1 An odd number of bits of write data was sent.

#### Bit 5 - Drive Select 0 Status

This bit reflects the status of drive select bit 0 in the Digital Output Register (DOR). See Section 3.3.4. It is cleared after a hardware reset and unaffected by a software reset.

- 0 Either drive 0 or 2 is selected. (Default)
- 1 Either drive 1 or 3 is selected.

#### Bits 7,6 - Reserved

These bits are reserved and are always 1.

## 3.3.4 Digital Output Register (DOR), Offset 010

DOR is a read/write register that can be written at any time. It controls the drive select and motor enable disk interface output signals, enables the DMA logic and contains a software reset bit.

The contents of the DOR is set to 00h after a hardware reset, and is unaffected by a software reset.

Table 3-2 shows how the bits of DOR select a drive and enable a motor when bit 4 of the Function Enable Register (FER) is 1. Bit patterns not shown produce states that should not be decoded to enable any drive or motor.

When bit 4 of the Function Enable Register (FER) is 1, MTR1 presents a pulse that is the inverse of WR. This pulse is active whenever an I/O write to address 3F2h or 372h occurs. This pulse is delayed for between 25 and 80 nsec after the leading edge of WR. The leading edge of this pulse can be used to clock data into an external latch (e.g., 74LS175).

Address 3F2h is used if the FDC is located at the primary address (bit 5 of FER is 0) and address 372h is used if the FDC is located at the secondary address (bit 5 of FER is 1). See Table 2-4 on page 29.

TABLE 3-2. Drive and Motor Pin Encoding When FER 4 = 1

| Digital Output<br>Register Bits |   |     |     |    |     |    |   | ` | Control<br>Signals |   |   | Decoded                                       |  |  |
|---------------------------------|---|-----|-----|----|-----|----|---|---|--------------------|---|---|-----------------------------------------------|--|--|
|                                 | • | icy | 131 | Ci | ווט | .3 |   | M | MTR DR             |   | R | Functions                                     |  |  |
| 7                               | 6 | 5   | 4   | 3  | 2   | 1  | 0 | 1 | 0                  | 1 | 0 |                                               |  |  |
| х                               | х | х   | 1   | х  | х   | 0  | 0 | - | 0                  | 0 | 0 | Activate Drive 0 and Motor 0                  |  |  |
| х                               | х | 1   | х   | х  | х   | 0  | 1 | - | 0                  | 0 | 1 | Activate Drive 1 and Motor 1                  |  |  |
| Х                               | 1 | х   | х   | х  | х   | 1  | 0 | - | 0                  | 1 | 0 | Activate Drive 2 and Motor 2                  |  |  |
| 1                               | х | х   | х   | х  | х   | 1  | 1 | - | 0                  | 1 | 1 | Activate Drive 3 and Motor 3                  |  |  |
| x                               | х | х   | 0   | х  | х   | 0  | 0 | - | 1                  | 0 | 0 | Activate Drive 0<br>and Deactivate<br>Motor 0 |  |  |
| х                               | х | 0   | х   | х  | х   | 0  | 1 | - | 1                  | 0 | 1 | Activate Drive 1<br>and deactivate<br>Motor 1 |  |  |
| х                               | 0 | х   | х   | х  | х   | 1  | 0 | - | 1                  | 1 | 0 | Activate Drive 2<br>and Deactivate<br>Motor 2 |  |  |
| 0                               | х | х   | х   | х  | х   | 1  | 1 | - | 1                  | 1 | 1 | Activate Drive 3<br>and Deactivate<br>Motor 3 |  |  |

Usually, the motor enable and drive select output signals for a particular drive are enabled together. Table 3-3 shows the DOR hexadecimal values that enable each of the four drives.

**TABLE 3-3.** Drive Enable Hexadecimal Values

| Drive | DOR Hexadecimal Value |
|-------|-----------------------|
| 0     | 1C                    |
| 1     | 2D                    |
| 2     | 4E                    |
| 3     | 8F                    |

The motor enable and drive select signals for drives 2 and 3 are only available when four drives are supported, i.e., when bit 4 of FER is 1, or when drives 2 and 0 are exchanged. These signals require external logic.



FIGURE 3-7. DOR Register Bitmap

#### Bits 1.0 - Drive Select

These bits select a drive, so that only one drive select output signal is active at a time.

See four-drive encoding bit 4 of FER on page 29 and logical drive exchange bits 3,2 of TDR on page 63 for more information.

- 00 Drive 0 is selected. (Default)
- 01 Drive 1 is selected.
- 10 If four drives are supported, or drives 2 and 0 are exchanged, drive 2 is selected.
- 11 If four drives are supported, drive 3 is selected

#### Bit 2 - Reset Controller

This bit can cause a software reset. The controller remains in a reset state until this bit is set to 1.

A software reset affects the CONFIGURE and MODE commands. See Section 3.6.2 on page 77 and 3.6.7 on page 84, respectively. A software reset does not affect the Data rate Select Register (DSR), Configuration Control Register (CCR) and other bits of this register (DOR).

This bit must be low for at least 100 nsec. There is enough time during consecutive writes to the DOR to reset software by toggling this bit.

- 0 Reset controller. (Default)
- 1 No reset.

#### Bit 3 - DMA Enable (DMAEN)

In PC-AT mode, this bit enables DMA operations by controlling the DRQ, DACK, TC and IRQ6 DMA signals. In PC-AT mode, this bit is set to 0 after reset.

In PS/2 mode, this bit is reserved, and DRQ, DACK, TC and IRQ6 are enabled. During reset, DRQ, DACK, TC, and IRQ6 remain enabled.

- 0 In PC-AT mode, DMA operations are disabled. DACK and TC are disabled, and DRQ and IRQ6 are put in TRI-STATE. (Default)
- In PC-AT mode, DMA operations are enabled, i.e., DRQ, DACK, TC and IRQ6 signals are enabled.

#### Bit 4- Motor Enable 0

If four drives are supported (bit 4 of the Function Enable Register (FER) is 1), this bit may control the motor output signal for drive 0, depending on the remaining bits of this register. See Table 3-2.

If two drives are supported (bit 4 of the Function Enable Register (FER) is 0), this bit controls the motor output signal for drive 0.

- 0 The motor signal for drive 0 is not active.
- 1 The motor signal for drive 0 is active.

#### Bit 5 - Motor Enable 1

If four drives are supported (bit 4 of the Function Enable Register (FER) is 1), this bit may control the motor output signal for drive 0, depending on the remaining bits of this register. See Table 3-2.

If two drives are supported (bit 4 of the Function Enable Register (FER) is 0), this bit controls the motor output signal for drive 1.

- 0 The motor signal for drive 1 is not active.
- 1 The motor signal for drive 1 is active.

#### Bit 6 - Motor Enable 2

If drives 2 and 0 are exchanged (see logical drive exchange bits 3,2 of TDR on page 63), or if four drives are supported (bit 4 of the Function Enable Register (FER) is 1), this bit controls the motor output signal for drive 2. See Table 3-2.

- 0 The motor signal for drive 2 is not active.
- 1 The motor signal for drive 2 is active.

#### Bit 7 - Motor Enable 3

If four drives are supported (bit 4 of the Function Enable Register (FER) is 1), this bit may control the motor output signal for drive 3, depending on the remaining bits of this register. See Table 3-2.

- 0 The motor signal for drive 3 is not active.
- 1 The motor signal for drive 3 is active.

## 3.3.5 Tape Drive Register (TDR), Offset 011

The TDR register is a read/write register that acts as the Floppy Disk Controller's (FDC) media and drive type register.

The bits of the TDR register function differently, depending on the drive mode configured by bit 0 of the Function Control configuration Register (FCR) (page 31), bit 2 of the Advanced SuperI/O Chip (ASC) configuration register (page 35) and bits 1 and 0 of SuperI/O Chip configuration register 2 (SCF2) (page 41). See Table 3-4.

The TDR drive modes are:

- PC-AT Compatible
- Automatic Media Sense
- Enhanced

## **PC-AT Compatible TDR Drive Mode**

When bit 0 of FCR is 1, and bit 2 of ASC is 0, the TDR assigns a drive number to the tape drive support mode of the data separator. All other logical drives can be assigned as floppy drive support. Bits 7-2 are in TRI-STATE during read operations.

#### **Automatic Media Sense TDR Drive Mode**

When bit 0 of FCR is 0, and bit 2 of ASC is 0, bits 7-5 of TDR are implemented, in addition to the bits that support Compatible AT TDR mode. Bits 4-2 are reserved.

#### **Enhanced TDR Drive Mode**

When bit 0 of FCR is 0, and bit 2 of ASC is 0, the TDR uses all its bits for operation with PS/2 floppy disk drives, except for bit 4 which is reserved.



FIGURE 3-8. TDR Register Bitmap

### Bits 1,0 - Tape Drive Select 1,0

These bits assign a logical drive number to a tape drive. Drive 0 is not available as a tape drive and is reserved as the floppy disk boot drive.

00 - No drive selected.

01 - Drive 1 selected.

10 - Drive 2 selected.

11 - Drive 3 selected.

TABLE 3-4. TDR Bit Utilization and Reset Values in Different Drive Modes

|                          |                    |       |                  |                 |               | Bits of TE   | R       |                   |              |   |
|--------------------------|--------------------|-------|------------------|-----------------|---------------|--------------|---------|-------------------|--------------|---|
| TDR Drive Mode           | Bit 0<br>of<br>FCR | of of | Extra<br>Density | High<br>Density | Valid<br>Data | Reserved     | _       | al Drive<br>ntrol | Drive Select |   |
|                          |                    |       | 7                | 6               | 5             | 4            | 3       | 2                 | 1            | 0 |
| PC-AT Compatible         | 1                  | 0     | Not ι            | ısed. In T      | RI-STATE      | during read  | operati | ons.              | 0            | 0 |
| Automatic Media<br>Sense | 0                  | 0     | Not<br>Reset     | Not<br>Reset    | Not<br>Reset  | Reserved 0 0 |         |                   | 0            |   |
| Enhanced                 | 0 or 1             | 1     | Not<br>Reset     | Not<br>Reset    | Not<br>Reset  | 1 0 0 0      |         | 0                 |              |   |

## Bits 3,2 - Logical Drive Control 1,0 (Enhanced Mode Only)

These read/write bits control logical drive exchange between drives 0 and 2. Drive 3 is never exchanged for drive 2.

When four drives are configured, i.e., bit 4 of FER is 1, logical drives are not exchanged.

- 00 No logical drive exchange.
- 01 Logical drives 0 and 1 are exchanged.
- 10 Logical drives 0 and 2 are exchanged.

Software exchanges the physical floppy disk control signals assigned to drives 0 and 2, i.e., DR0, DR23 and MTR0, as follows:

The internal signal that selects drive 2 uses DR0; the internal signal that selects the motor of drive 2 uses MTR0; and the DR0 internal signal uses DR23.

11 - Reserved. Unpredictable results when 11 is configured.

#### Bit 4 - Reserved

This bit is reserved.

## Bit 5 - Valid Data (Automatic Media Sense and Enhanced Modes)

This bit, together with bits 7,6, indicate what type of media is currently in the active floppy disk drive, as shown in Table 3-5.

**TABLE 3-5.** Media Type Bit Settings

| Bit 7 | Bit 6 | Bit 5 | Media Type     |
|-------|-------|-------|----------------|
| Х     | Х     | 1     | Invalid Data   |
| 0     | 0     | 0     | 1.2 MB (5.25") |
| 0     | 1     | 0     | 2.88 MB        |
| 1     | 0     | 0     | 1.44 MB        |
| 1     | 1     | 0     | 720 KB         |

The state of this bit reflects the value of either bit 1 or bit 0 of SCF2, i.e., the VLD1,0 bits. See bits 1,0 of SCF2 on page 41.

When two floppy disk drives are configured (bit 4 of FER is 0), this bit is the inverse of VLD0 (bit 0 of SCF2) when drive 0 is accessed, and the inverse of VLD1 (bit 1 of SCF2) when drive 1 is accessed. Otherwise, bit 5 of TDR is 1.

- O Automatic media sensing is enabled and there is valid media ID sense data in bits 7 and 6 of this register.
- 1 Automatic media sensing is disabled.

## **Bit 6 - High Density** (Automatic Media Sense and Enhanced Modes)

When bit 5 is 0, this bit is used with bit 7 to indicate the type of media currently in the active floppy disk drive. If bit 5 is 1, it is invalid. See Table 3-5.

This bit reflects the value of the MSEN0 signal.

- 0 If this bit is valid (bit 5 is 0), the floppy disk is 5.25 inch or 1.44 MB, depending on bit 7.
- 1 If this bit is valid (bit 5 is 0), the floppy disk is 2.88 MB or 720 MB, depending on bit 7.

## Bit 7 - Extra Density (Automatic Media Sense and Enhanced Modes)

When bit 5 is 0, this bit is used with bit 6 to indicate the type of media currently in the active floppy drive. If bit 5 is 1, it is invalid. See Table 3-5.

This bit reflects the value of the MSEN1 signal.

- 0 If this bit is valid (bit 5 is 0), the floppy disk is 5.25 inch or 2.88 MB, depending on bit 6.
- 1 If this bit is valid (bit 5 is 0), the floppy disk is 1.44 MB or 720 MB, depending on bit 6.

## 3.3.6 Main Status Register (MSR), Offset 100

This read-only register indicates the current status of the Floppy Disk Controller (FDC), indicates when the disk controller is ready to send or receive data through the Data Register (FIFO) and controls the flow of data to and from the Data Register (FIFO).

The MSR can be read at any time. It should be read before each byte is transferred to or from the Data Register (FIFO) except during a DMA transfer. No delay is required when reading this register after a data transfer.

The microprocessor can read the MSR immediately after a hardware or software reset, or recovery from a power down. The MSR contains a value of 00h, until the FDC clock has stabilized and the internal registers have been initialized.

When the FDC is ready to receive a new command, it reports a value of 80h for the MSR to the microprocessor. System software can poll the MSR until the MSR is ready. The MSR must report an 80h value (RQM set to 1) within 2.5 msec after reset or power up.



FIGURE 3-9. MSR Register Bitmap

## Bit 0 - Drive 0 Busy

This bit indicates whether or not drive 0 is busy.

It is set to 1 after the last byte of the command phase of a SEEK or RECALIBRATE command is issued for drive 0.

This bit is cleared to 0 after the first byte in the result phase of the SENSE INTERRUPT command is read for drive 0.

- 0 Not busy.
- 1 Busy.

## Bit 1 - Drive 1 Busy

This bit indicates whether or not drive 1 is busy.

It is set to 1 after the last byte of the command phase of a SEEK or RECALIBRATE command is issued for drive 1.

This bit is cleared to 0 after the first byte in the result phase of the SENSE INTERRUPT command is read for drive 1.

- 0 Not busy.
- 1 Busy.

#### Bit 2 - Drive 2 Busy

This bit indicates whether or not drive 2 is busy.

It is set to 1 after the last byte of the command phase of a SEEK or RECALIBRATE command is issued for drive 2.

This bit is cleared to 0 after the first byte in the result phase of the SENSE INTERRUPT command is read for drive 2.

- 0 Not busy.
- 1 Busy.

#### Bit 3 - Drive 3 Busy

This bit indicates whether or not drive 3 is busy.

It is set to 1 after the last byte of the command phase of a SEEK or RECALIBRATE command is issued for drive 3.

This bit is cleared to 0 after the first byte in the result phase of the SENSE INTERRUPT command is read for drive 3.

- 0 Not busy.
- 1 Busy.

## Bit 4 - Command in Progress

This bit indicates whether or not a command is in progress. It is set after the first byte of the command phase is written. This bit is cleared after the last byte of the result phase is read.

If there is no result phase in a command, the bit is cleared after the last byte of the command phase is written.

- 0 No command is in progress.
- 1 A command is in progress.

## Bit 5 - Non-DMA Execution

This bit indicates whether or not the controller is in the execution phase of a byte transfer operation in non-DMA mode.

This bit is used for multiple byte transfers by the microprocessor in the execution phase through interrupts or software polling.

- 0 The FDC is not in the execution phase.
- 1 The FDC is in the execution phase.

#### Bit 6 - Data I/O (Direction)

Indicates whether the controller is expecting a byte to be written or read, to or from the Data Register (FIFO).

- 0 Data will be written to the FIFO.
- 1 Data will be read from the FIFO.

#### Bit 7 - Request for Master (RQM)

This bit indicates whether or not the controller is ready to send or receive data from the microprocessor through the Data Register (FIFO). It is cleared to 0 immediately after a byte transfer and is set to 1 again as soon as the disk controller is ready for the next byte.

During a Non-DMA execution phase, this bit indicates the status of the interrupt.

- 0 Not ready. (Default)
- 1 Ready to transfer data.

## 3.3.7 Data Rate Select Register (DSR), Offset 100

This write-only register is used to program the data transfer rate, amount of write precompensation, power down mode, and software reset.

The data transfer rate is programmed via the CCR, not the DSR, for PC-AT, PS/2 and Micro Channel applications. Other applications can set the data transfer rate in the DSR.

The data rate of the floppy controller is determined by the most recent write to either the DSR or CCR.

The DSR is unaffected by a software reset. A hard-ware reset sets the DSR to 02h, which corresponds to the default precompensation setting and a data transfer rate of 250 Kbps.



FIGURE 3-10. DSR Register Bitmap

## Bits 1,0 - Data Transfer Rate Select 1,0 (DRATE 1,0)

These bits determine the data transfer rate for the Floppy Disk Controller (FDC), depending on the supported speeds. See "Tape, UARTs and Parallel Port Configuration Register (TUP), Index 07h" on page 34. Table 3-6 shows the data transfer rate selected by each value of this field.

These bits are unaffected by a software reset, and are set to 10 (250 Kbps) after a hardware reset.

**TABLE 3-6.** Data Transfer Rate Encoding

|   | Bits<br>ATE) | Value of Bit 1 of TUP |                     |  |  |  |
|---|--------------|-----------------------|---------------------|--|--|--|
| 1 | 0            | 0 (24 MHz)            | 1 (48 MHz)          |  |  |  |
| 0 | 0            | 500 Kbps              | Invalid             |  |  |  |
| 0 | 1            | 300 Kbps              | Invalid             |  |  |  |
| 1 | 0            | 250 Kbps              | Invalid             |  |  |  |
| 1 | 1            | 1 Mbps                | 2 Mbps <sup>a</sup> |  |  |  |

a. Not 100% tested.

## Bits 4-2 - Precompensation Delay Select

This field sets the write precompensation delay that the Floppy Disk Controller (FDC) imposes on the WDATA disk interface output signal, depending on the supported speeds. See "Tape, UARTs and Parallel Port Configuration Register (TUP), Index 07h" on page 34. Table 3-6 shows the delay for each value of this field.

In most cases, the default delays shown in Table 3-8 are adequate. However, alternate values may be used for specific drive and media types.

Track 0 is the default starting track number for precompensation. The starting track number can be changed using the CONFIGURE command.

**TABLE 3-7.** Write Precompensation Delays

| DS | RE | Bits | Value of Bit 1 of TUP |                     |  |  |  |  |
|----|----|------|-----------------------|---------------------|--|--|--|--|
| 4  | 3  | 2    | 0 (24 MHz)            | 1 (48 MHz)          |  |  |  |  |
| 0  | 0  | 0    | Default (Table 3-8)   | Default (Table 3-8) |  |  |  |  |
| 0  | 0  | 1    | 41.7 nsec             | 20.8 nsec           |  |  |  |  |
| 0  | 1  | 0    | 83.3 nsec             | 41.7 nsec           |  |  |  |  |
| 0  | 1  | 1    | 125.0 nsec            | 62.5 nsec           |  |  |  |  |
| 1  | 0  | 0    | 166.7 nsec            | 83.3 nsec           |  |  |  |  |
| 1  | 0  | 1    | 208.3 nsec            | 104.2 nsec          |  |  |  |  |
| 1  | 1  | 0    | 250.0 nsec            | 125.0 nsec          |  |  |  |  |
| 1  | 1  | 1    | 0.0 nsec              | 0.0 nsec            |  |  |  |  |

**TABLE 3-8.** Default Precompensation Delays

| Data Rate | Precompensation Delay |
|-----------|-----------------------|
| 2 Mbps    | 20.8 nsec             |
| 1 Mbps    | 41.7 nsec             |
| 500 Kbps  | 125.0 nsec            |
| 300 Kbps  | 125.0 nsec            |
| 250 Kbps  | 125.0 nsec            |

### Bit 5 - Unde ned

Should be set to 0.

#### Bit 6 - Low Power

This bit triggers a manual power down of the FDC in which the clock and data separator circuits are turned off. A manual power down can also be triggered by the MODE command.

After a manual power down, the FDC returns to normal power after a software reset, or an access to the Data Register (FIFO) or the Main Status Register (MSR).

- 0 Normal power.
- 1 Trigger power down.

#### Bit 7 - Software Reset

This bit controls the same kind of software reset of the FDC as bit 2 of the Digital Output Register (DOR). The difference is that this bit is automatically cleared to 0 (no reset) 100 nsec after it was set to 1.

See also "Bit 2 - Reset Controller" on page 61.

- 0 No reset. (Default)
- 1 Reset.

## 3.3.8 Data Register (FIFO), Offset 101

The Data Register of the FDC is a read/write register that is used to transfer all commands, data and status information between the microprocessor and the FDC.

During the command phase, the microprocessor writes command bytes into the Data Register after polling the RQM (bit 7) and DIO (bit 6) bits in the MSR. During the result phase, the microprocessor reads result bytes from the Data Register after polling the RQM and DIO bits in the MSR.

Use of the FIFO buffer lengthens the interrupt latency period and, thereby, reduces the chance of a disk overrun or underrun error occurring. Typically, the FIFO buffer is used at a 1 Mbps data transfer rate or with multi-tasking operating systems.

## **Enabling and Disabling the FIFO Buffer**

The 16-byte FIFO buffer can be used for DMA, interrupt, or software polling type transfers during the execution of a read, write, format or scan command.

The FIFO buffer is enabled and its threshold is set by the CONFIGURE command.

When the FIFO buffer is enabled, only execution phase byte transfers use it. If the FIFO buffer is enabled, it is not disabled after a software reset if the LOCK bit is set in the LOCK command.

The FIFO buffer is always disabled during the command and result phases of a controller operation. A hardware reset disables the FIFO buffer and sets its threshold to zero. The MODE command can also disable the FIFO for read or write operations separately.

After a hardware reset, the FIFO buffer is disabled to maintain compatibility with PC-AT systems.

## **Burst Mode Enabled and Disabled**

The FIFO buffer can be used with burst mode enabled or disabled by the MODE command.

In burst mode, DRQ or IRQ6 remains active until all of the bytes have been transferred to or from the FIFO buffer. When burst mode is disabled, DRQ or IRQ6 is deactivated for 350 nsec to allow higher priority transfer requests to be processed.

## **FIFO Buffer Response Time**

During the execution phase of a command involving data transfer to or from the FIFO buffer, the maximum time the system has to respond to a data transfer service request is calculated by the following formula:

 $Max\_Time = (THRESH + 1) \times 8 \times t_{DRP} - (16 \times t_{ICP})$ 

This formula applies for all data transfer rates, whether the FIFO buffer is enabled or disabled. THRESH is a 4-bit value programmed by the CONFIGURE command, which sets the threshold of the FIFO buffer. If the FIFO buffer is disabled, THRESH is zero in the above formula. The last term in the formula, (16 x  $t_{\rm ICP}$ ) is an inherent delay due to the microcode overhead required by the FDC. This delay is also data rate dependent. Table 8-20 on page 198 specifies minimum and maximum values for  $t_{\rm DRP}$  and  $t_{\rm ICP}$ .

The programmable FIFO threshold (THRESH) is useful in adjusting the FDC to the speed of the system. A slow system with a sluggish DMA transfer capability requires a high value for THRESH. this gives the system more time to respond to a data transfer service request (DRQ for DMA mode or IRQ6 for interrupt mode). Conversely, a fast system with quick response to a data transfer service request can use a low value for THRESH.



FIGURE 3-11. FDC Data Register Bitmap

## 3.3.9 Digital Input Register (DIR), Offset 111

This read-only diagnostic register is used to detect the state of the DSKCHG disk interface input signal and some diagnostic signals. DIR is unaffected by a software reset.

The bits of the DIR register function differently depending on whether the FDC is operating in PC-AT mode or in PS/2 mode.

Section 3.1.2 on page 53 describes each mode and "Bit 7 - System Operation Mode" on page 36 describes how each is enabled.

In PC-AT mode, bits 6 through 0 are in TRI-STATE to prevent conflict with the status register of the hard disk at the same address as the DIR.



FIGURE 3-12. DIR Register Bitmap

## Bit 0 - High Density (PS/2 Mode Only)

In PC-AT mode, this bit is reserved, in TRI-STATE and used by the status register of the hard disk.

In PS/2 mode, this bit indicates whether the data transfer rate is high or low.

- 0 The data transfer rate is high, i.e., 1 Mbps, 2 Mbps or 500 Kbps.
- 1 The data transfer rate is low, i.e., 300 Kbps or 250 Kbps.

## Bits 2,1 - Data Rata Select 1,0 (DRATE1,0) (PS/2 Mode Only)

In PC-AT mode, these bits are reserved, in TRI-STATE and used by the status register of the hard disk.

In PS/2 mode, these bits indicate the status of the DRATE1,0 bits programmed in DSR or CCR, whichever is written last.

The significance of each value for these bits depends on the supported speeds. See "Tape, UARTs and Parallel Port Configuration Register (TUP), Index 07h" on page 34. See also Table 3-6.

- 00 Data transfer rate is 500 Kbps or invalid.
- 01 Data transfer rate is 300 Kbps or invalid.
- 10 Data transfer rate is 250 Kbps or invalid.
- 11 Data transfer rate is 1 or 2 Mbps.

#### Bits 6-3 - Reserved

These bits are reserved and are always 1. In PC-AT mode these bits are reserved and in TRI-STATE. They are used by the status register of the fixed hard disk.

## Bit 7 - Disk Changed (DSKCHG)

This bit reflects the status of the  $\overline{\text{DSKCHG}}$  disk interface input signal.

During power down this bit is invalid, if it is read by the software.

- 0 DSKCHG is not active.
- 1 DSKCHG is active.

## 3.3.10 Configuration Control Register (CCR), Offset 111

This write-only register can be used to set the data transfer rate.

The data transfer rate is programmed via the CCR, not the DSR, for PC-AT, PS/2 and Micro Channel applications. Other applications can set the data transfer rate in the DSR. See Section 3.3.7.

This register is not affected by a software reset.

The data rate of the floppy controller is determined by the last write to either the CCR register or to the DSR register.



FIGURE 3-13. CCR Register Bitmap

## Bits 1,0 - Data Transfer Rate Select 1,0 (DRATE 1,0)

These bits determine the data transfer rate for the Floppy Disk Controller (FDC), depending on the supported speeds. See "Tape, UARTs and Parallel Port Configuration Register (TUP), Index 07h" on page 34. Table 3-6 shows the data transfer rate selected by each value of this field.

These bits are unaffected by a software reset, and are set to 10 (250 Kbps) after a hardware reset.

#### Bits 7-2 - Reserved

These bits are reserved and should be set to 0.

## 3.4 THE PHASES OF FDC COMMANDS

FDC commands may be in the command phase, the execution phase or the result phase. The active phase determines how data is transferred between the Floppy Disk Controller (FDC) and the host microprocessor. When no command is in progress, the FDC may be either idle or polling a drive.

## 3.4.1 Command Phase

During the command phase, the microprocessor writes a series of bytes to the Data Register (FIFO). The first command byte contains the opcode for the command, which the controller can interpret to determine how many more command bytes to expect. The remaining command bytes contain the parameters required for the command.

The number of command bytes varies for each command. All command bytes must be written in the order specified in the Command Description Table in Section 3.6 on page 74. The execution phase starts immediately after the last byte in the command phase is written. Prior to performing the command phase, the Digital Output Register (DOR) should be set and the data rate should be set with the Data rate Select Register (DSR) or the Configuration Control Register (CCR).

The Main Status Register (MSR) controls the flow of command bytes, and must be polled by the software before writing each command phase byte to the Data Register (FIFO). Prior to writing a command byte, bit 7 of MSR (RQM, Request for Master) must be set and bit 6 of MSR (DIO, Data I/O direction) must be cleared.

After the first command byte is written to the Data Register (FIFO), bit 4 of MSR (CMD PROG, Command in Progress) is also set and remains set until the last result phase byte is read. If there is no result phase, the CMD PROG bit is cleared after the last command byte is written.

A new command may be initiated after reading all the result bytes from the previous command. If the next command requires selection of a different drive or a change in the data rate, the DOR and DSR or CCR should be updated, accordingly. If the command is the last command, the software should deselect the drive.

Normally, command processing by the controller core and updating of the DOR, DSR, and CCR registers by the microprocessor are operations that can occur independently of one another. Software must ensure that the these registers are not updated while the controller is processing a command.

#### 3.4.2 Execution Phase

During the execution phase, the Floppy Disk Controller (FDC) performs the desired command.

Commands that involve data transfers (e.g., read, write and format operations) require the microprocessor to write or read data to or from the Data Register (FIFO) at this time. Some commands, such as SEEK or RECALIBRATE, control the read/write head movement on the disk drive during the execution phase via the disk interface signals. Execution of other commands does not involve any action by the microprocessor or disk drive, and consists of an internal operation by the controller.

Data can be transferred between the microprocessor and the controller during execution in DMA mode, interrupt transfer mode or software polling mode. The last two modes are non-DMA modes. All data transfer modes work with the FIFO enabled or disabled.

DMA mode is used if the system has a DMA controller. This allows the microprocessor to do other tasks while data transfer takes place during the execution phase.

If a non-DMA mode is used, an interrupt is issued for each byte transferred during the execution phase. Also, instead of using the interrupt during a non-DMA mode transfer, the Main Status Register (MSR) can be polled by software to indicate when a byte transfer is required.

#### **DMA Mode - FIFO Disabled**

DMA mode is selected by writing a 0 to the DMA bit in the SPECIFY command and by setting bit 3 of the DOR (DMA enabled) to 1.

In the execution phase when the FIFO is disabled, each time a byte is ready to be transferred, a DMA request (DRQ) is generated in the execution phase. The DMA controller should respond to the DRQ with a DMA acknowledge (DACK) and a read or write pulse. The DRQ is cleared by the leading edge of the active low DACK input signal. After the last byte is transferred, an interrupt is generated, indicating the beginning of the result phase.

During DMA operations, FDC address signals are ignored since AEN input signal is 1. The DACK signal acts as the chip select signal for the FIFO, in this case, and the state of the address lines A2-0 is ignored. The Terminal Count (TC) signal can be asserted by the DMA controller to terminate the data transfer at any time. Due to internal gating, TC is only recognized when DACK is low.

#### **PC-AT Mode**

In PC-AT interface mode when the FIFO is disabled, the controller is in single byte transfer mode. That is, the system has the time it takes to transfer one byte, to service a DMA request (DRQ) from the controller. DRQ is deactivated between bytes.

#### PS/2 Mode

In PS/2 mode, for DMA transfers with the FIFO disabled, instead of single byte transfer mode, the FIFO is enabled with THRESH = 0Fh. Thus, DRQ is asserted when one byte enters the FIFO during a read, and when one byte can be written to the FIFO during a write. DRQ is deactivated by the leading edge of the DACK input signal, and is asserted again when DACK becomes inactive high. This operation is very similar to burst mode transfer with the FIFO enabled except that DRQ is deactivated between bytes.

#### DMA Mode - FIFO Enabled

#### **Read Data Transfers**

Whenever the number of bytes in the FIFO is greater than or equal to (16 – THRESH), a DRQ is generated. This is the trigger condition for the FIFO read data transfers from the floppy controller to the microprocessor.

When the last byte in the FIFO has been read, DRQ becomes inactive. DRQ is asserted again when the FIFO trigger condition is satisfied. After the last byte of a sector is read from the disk, DRQ is again generated even if the FIFO has not yet reached its threshold trigger condition. This guarantees that all current sector bytes are read from the FIFO before the next sector byte transfer begins.

**Burst Mode Enabled -** DRQ remains active until enough bytes have been read from the controller to empty the FIFO.

**Burst Mode Disabled -** DRQ is deactivated after each read transfer. If the FIFO is not completely empty, DRQ is asserted again after a 350 nsec delay. This allows other higher priority DMA transfers to take place between floppy disk transfers.

In addition, this mode allows the controller to work correctly in systems where the DMA controller is put into a read verify mode, where only DACK signals are sent to the FDC, with no RD pulses. This read verify mode of the DMA controller is used in some PC software. When burst mode is disabled, a pulse from the DACK input signal may be issued by the DMA controller, to correctly clocks data from the FIFO.

#### **Write Data Transfers**

Whenever the number of bytes in the FIFO is less than or equal to THRESH, a DRQ is generated. This is the trigger condition for the FIFO write data transfers from the microprocessor to the FDC.

**Burst Mode Enabled -** DRQ remains active until enough bytes have been written to the controller to completely fill the FIFO.

**Burst Mode Disabled -** DRQ is deactivated after each write transfer. If the FIFO is not full, DRQ is asserted again after a 350 nsec delay. Deactivation of DRQ allows other higher priority DMA transfers to take place between floppy disk transfers.

The FIFO has a byte counter which monitors the number of bytes being transferred to the FIFO during write operations whether burst mode is enabled or disabled. When the last byte of a sector is transferred to the FIFO, DRQ is deactivated even if the FIFO has not been completely filled. Thus, the FIFO is cleared after each sector is written. Only after the FDC has determined that another sector is to be written, is DRQ asserted again. Also, since DRQ is deactivated immediately after the last byte of a sector is written to the FIFO, the system will not be delayed by deactivation of DRQ and is free to do other operations.

#### **Read and Write Data Transfers**

The DACK input signal from the DMA controller may be held active during an entire burst, or a pulse may be issued for each byte transferred during a read or write operation. In burst mode, the FDC deactivates DRQ as soon as it recognizes that the last byte of a burst was transferred.

If a DACK pulse is issued for each byte, the leading edge of this pulse is used to deactivate DRQ. If a DACK pulse is issued, RD or WR is not required. This is the case during the read-verify mode of the DMA controller.

If  $\overline{DACK}$  is held active during the entire burst, the trailing edge of the  $\overline{RD}$  or  $\overline{WR}$  pulse is used to deactivate DRQ. DRQ is deactivated within 50 nsec of the leading edge of  $\overline{DACK}$ ,  $\overline{RD}$ , or  $\overline{WR}$ . This quick response should prevent the DMA controller from transferring extra bytes in most applications.

## **Overrun Errors**

An overrun or underrun error terminates the execution of a command, if the system does not transfer data within the allotted data transfer time. (See Section 3.3.8 on page 66), This puts the controller in the result phase.

During a read overrun, the microprocessor is required to read the remaining bytes of the sector before the controller asserts IRQ6, signifying the end of execution.

During a write operation, an underrun error terminates the execution phase after the controller has written the remaining bytes of the sector with the last correctly written byte to the FIFO. Whether there is an error or not, an interrupt is generated at the end of the execution phase, and is cleared by reading the first result phase byte.

DACK asserted alone, without a RD or WR pulse, is also counted as a transfer. If pulses of RD or WR are not being issued for each byte, a DACK pulse must be issued for each byte so that the Floppy Disk Controller(FDC) can count the number of bytes correctly.

The VERIFY command, allows easy verification of data written to the disk without actually transferring the data on the data bus.

## Interrupt Transfer Mode - FIFO Disabled

If interrupt transfer (non-DMA) mode is selected, IRQ6 is asserted instead of DRQ, when each byte is ready to be transferred.

The Main Status Register (MSR) should be read to verify that the interrupt is for a data transfer. The RQM and NON DMA bits (bits 7 and 5, respectively) in the MSR are set to 1. The interrupt is cleared when the byte is transferred to or from the Data Register (FIFO). To transfer the data in or out of the Data register, you must use the address bits of the FDC together and RD or WR must be active, i.e., A2-0 must be valid. It is not enough to just assert the address bits of the FDC. RD or WR must also be active for a read or write transfer to be recognized.

The microprocessor should transfer the byte within the data transfer service time (see Section 3.3.8 on page 66). If the byte is not transferred within the time allotted, an overrun error is indicated in the result phase when the command terminates at the end of the current sector.

An interrupt is also generated after the last byte is transferred. This indicates the beginning of the result phase. The RQM and DIO bits (bits 7 and 6, respectively) in the MSR are set to 1, and the NON DMA bit (bit 5) is cleared to 0. This interrupt is cleared by reading the first result byte.

## Interrupt Transfer Mode - FIFO Enabled

Interrupt transfer (non-DMA) mode with the FIFO enabled is very similar to interrupt transfer mode with the FIFO disabled. In this case, IRQ6 is asserted instead of DRQ, under the same FIFO threshold trigger conditions. The MSR should be read to verify that the interrupt is for a data transfer. The RQM and non-DMA bits (bits 7 and 5, respectively) in the MSR are set. To transfer the data in or out of the Data register, you

must use the address bits of the FDC together and RD or WR must be active, i.e., A2-0 must be valid. It is not enough to just assert the address bits of the FDC. RD or WR must also be active for a read or write transfer to be recognized.

Burst mode may be used to hold the IRQ6 pin active during a burst, or burst mode may be disabled to toggle the IRQ6 pin for each byte of a burst. The Main Status Register (MSR) is always valid to the microprocessor. For example, during a read command, after the last byte of data has been read from the disk and placed in the FIFO, the MSR still indicates that the execution phase is active, and that data needs to be read from the Data Register (FIFO). Only after the last byte of data has been read by the microprocessor from the FIFO does the result phase begin.

The overrun and underrun error procedures for non-DMA mode are the same as for DMA mode. Also, whether there is an error or not, an interrupt is generated at the end of the execution phase, and is cleared by reading the first result phase byte.

## Software Polling

If non-DMA mode is selected and interrupts are not suitable, the microprocessor can poll the MSR during the execution phase to determine when a byte is ready to be transferred. The RQM bit (bit 7) in the MSR reflects the state of the IRQ6 signal. Otherwise, the data transfer is similar to the interrupt mode described above, whether the FIFO is enabled or disabled.

## 3.4.3 Result Phase

During the result phase, the microprocessor reads a series of result bytes from the Data Register (FIFO). These bytes indicate the status of the command. They may indicate whether the command executed properly, or may contain some control information.

See the specific commands in "The FDC Command Set" on page 74 or "Data Register (FIFO), Offset 101" on page 66 for details.

These result bytes are read in the order specified for that particular command. Some commands do not have a result phase. Also, the number of result bytes varies with each command. All result bytes must be read from the Data Register (FIFO) before the next command can be issued.

As it does for command bytes, the Main Status Register (MSR) controls the flow of result bytes, and must be polled by the software before reading each result byte from the Data Register (FIFO). The RQM bit (bit 7) and DIO bit (bit 6) of the MSR must both be set before each result byte can be read.

After the last result byte is read, the Command in Progress bit (bit 4) of the MSR is cleared, and the controller is ready for the next command.

For more information, see "The Result Phase Status Registers" on page 71.

## 3.4.4 Idle Phase

After a hardware or software reset, after the chip has recovered from power-down mode or when there are no commands in progress the controller is in the idle phase. The controller waits for a command byte to be written to the Data Register (FIFO). The RQM bit is set, and the DIO bit is cleared in the MSR.

After receiving the first command (opcode) byte, the controller enters the command phase. When the command is completed the controller again enters the idle phase. The Digital Data Separator (DDS) remains synchronized to the reference frequency while the controller is idle. While in the idle phase, the controller periodically enters the drive polling phase.

## 3.4.5 Drive Polling Phase

National Semiconductor's FDC supports the polling mode of old 8-inch drives, as a means of monitoring any change in status for each disk drive present in the system. This support provides backward compatibility with software that expects it.

In the idle phase, the controller enters a drive polling phase every 1 msec, based on a 500 Kbps data transfer rate. In the drive polling phase, the controller checks the status of each of the logical drives (bits 0 through 3 of the MSR). The internal ready line for each drive is toggled only after a hardware or software reset, and an interrupt is generated for drive 0.

At this point, the software must issue four SENSE INTERRUPT commands to clear the status bit for each drive, unless drive polling is disabled via the POLL bit in the CONFIGURE command. See "Bit 4 - Disable Drive Polling (POLL)" on page 77. The CONFIGURE command must be issued within 500  $\mu sec$  (worst case) of the hardware or software reset to disable drive polling.

Even if drive polling is disabled, drive stepping and delayed power-down occur in the drive polling phase. The controller checks the status of <u>each</u> drive and, if necessary, it issues a pulse on the STEP output signal with the DIR signal at the appropriate logic level.

The controller also uses the drive polling phase to automatically trigger power down. When the specified time that the motor may be off has expired, the controller waits 512 msec, based on data transfer rates of 500 Kbps and 1 Mbps, before powering down, if this function is enabled via the MODE command.

If a new command is issued while the FDC is in the drive polling phase, the MSR does not indicate a ready status for the next parameter byte until the polling sequence completes the loop. This can cause a delay between the first and second bytes of up to 500  $\mu sec$  at 250 Kbps.

## 3.5 THE RESULT PHASE STATUS REGISTERS

In the result phase of a command, result bytes that hold status information are read from the Data Register (FIFO). These bytes are the result phase status registers.

The result phase status registers may only be read from the Data Register (FIFO) during the result phase of certain commands, unlike the Main Status Register (MSR), which is a read only register that is always valid

## 3.5.1 Result Phase Status Register 0 (ST0)



FIGURE 3-14. ST0 Result Phase Register Bitmap

#### Bits 1,0 - Logical Drive Selected

These two binary encoded bits indicate the logical drive selected at the end of the execution phase.

The value of these bits is reflected in bits 1,0 of the SR3 register, described on page 74.

- 00 Drive 0 selected.
- 01 Drive 1 selected.
- 10 If four drives are supported, or drives 2 and 0 are exchanged, drive 2 is selected.
- 11 If four drives are supported, drive 3 is selected.

#### Bit 2 - Head Selected

This bit indicates which side of the Floppy Disk Drive (FDD) is selected. It reflects the status of the HDSEL signal at the end of the execution phase.

The value of this bit is reflected in bit 2 of the SR3 register, described on page 74.

- 0 Side 0 is selected.
- 1 Side 1 is selected.

#### Bit 3 - Not used.

This bit is not used and is always 0.

## Bit 4 - Equipment Check

After a RECALIBRATE command, this bit indicates whether the head of the <u>selected</u> drive was at track 0, i.e., whether or not TRKO was active. This information is used during the SENSE INTERRUPT command.

- 0 Head was at track 0, i.e., a  $\overline{\text{TRK0}}$  pulse occurred after a RECALIBRATE command.
- 1 Head was not at track 0, i.e., no TRK0 pulse occurred after a RECALIBRATE command.

#### Bit 5 - SEEK End

This bit indicates whether or not a SEEK, RELA-TIVE SEEK, or RECALIBRATE command was completed by the controller. Used during a SENSE INTERRUPT command.

- 0 SEEK, RELATIVE SEEK, or RECALIBRATE command not completed by the controller.
- SEEK, RELATIVE SEEK, or RECALIBRATE command was completed by the controller.

## Bits 7,6 - Interrupt Code (IC)

These bits indicate the reason for an interrupt.

- 00 Normal termination of command.
- 01 Abnormal termination of command. Execution of command was started, but was not successfully completed.
- 10 Invalid command issued. Command issued was not recognized as a valid command.
- 11 Internal drive ready status changed state during the drive polling mode. This only occurs after a hardware or software reset.

## 3.5.2 Result Phase Status Register 1 (ST1)



FIGURE 3-15. ST1 Result Phase Register Bitmap

#### Bit 0 - Missing Address Mark

This bit indicates whether or not the Floppy Disk Controller (FDC) failed to find an address mark in a data field during a read, scan, or verify command.

- 0 No missing address mark.
- 1 Address mark missing.

Bit 0 of the result phase Status register 2 (ST2) indicates the when and where the failure occurred. See Section 3.5.3 on page 73.

#### Bit 1 - Drive Write Protected

When a write or format command is issued, this bit indicates whether or not the selected drive is write protected, i.e., the  $\overline{\text{WP}}$  signal is active.

- 0 Selected drive is not write protected, i.e., WP is not active.
- 1 Selected drive is write protected, i.e.,  $\overline{WP}$  is active.

## Bit 2 - Missing Data

This bit indicates whether or not data is missing for one of the following reasons:

- Controller cannot find the sector specified in the command phase during the execution of a read, write, scan, or VERIFY command. An Address Mark (AM) was found however, so it is not a blank disk.
- Controller cannot read any address fields without a CRC error during a READ ID command.
- Controller cannot find starting sector during execution of READ A TRACK command.
- 0 Data is not missing for one of these reasons.
- 1 Data is missing for one of these reasons.

#### Bit 3 - Not Used

This bit is not used and is always 0.

#### Bit 4 - Overrun or Underrun

This bit indicates whether or not the FDC was serviced by the microprocessor soon enough during a data transfer in the execution phase. For read operations, this bit indicates a data overrun. For write operations, it indicates a data underrun.

- 0 FDC was serviced in time.
- 1 FDC was not serviced fast enough. Overrun or underrun occurred.

#### Bit 5 - CRC Error

This bit indicates whether or not the FDC detected a Cyclic Redundancy Check (CRC) error.

- 0 No CRC error detected.
- 1 CRC error detected.

Bit 5 of the result phase Status register 2 (ST2) indicates when and where the error occurred. See Section 3.5.3.

#### Bit 6 - Not Used

This bit is not used and is always 0.

#### Bit 7 - End of Track

This bit is set to 1 when the FDC transfers the last byte of the last sector without the TC signal becoming active. The last sector is the End of Track sector number programmed in the command phase.

- The FDC did not transfer the last byte of the last sector without the TC signal becoming active.
- 1 The FDC transferred the last byte of the last sector without the TC signal becoming active.

## 3.5.3 Result Phase Status Register 2 (ST2)



FIGURE 3-16. ST2 Result Phase Register Bitmap

## Bit 0 - Missing Address Mark Location

If the FDC cannot find the address mark of a data field or of an address field during a read, scan, or verify command, i.e., bit 0 of ST1 is 1, this bit indicates when and where the failure occurred.

- The FDC failed to detect an address mark for the address field after two disk revolutions.
- The FDC failed to detect an address mark for the data field after it found the correct address field.

## Bit 1 - Bad Track

This bit indicates whether or not the FDC detected a bad track

- 0 No bad track detected.
- 1 Bad track detected.

The desired sector is not found. If the track number recorded on any sector on the track is FFh and this number is different from the track address specified in the command phase, then there is a hard error in IBM format.

#### Bit 2 - Scan Not Satis ed

This bit indicates whether or not the value of the data byte from the microprocessor meets any of the conditions specified by the scan command used.

"The SCAN EQUAL, the SCAN LOW OR EQUAL and the SCAN HIGH OR EQUAL Commands" on page 95 and Table 3-21 describes the conditions.

- 0 The data byte from the microprocessor meets at least one of the conditions specified.
- 1 The data byte from the microprocessor does not meet any of the conditions specified.

#### Bit 3 - Scan Satis ed

This bit indicates whether or not the value of the data byte from the microprocessor was equal to a byte on the floppy disk during any scan command.

- 0 No equal byte was found.
- A byte whose value whose values is equal to the byte from the microprocessor was found on the floppy disk.

## Bit 4 - Wrong Track

This bit indicates whether or not there was a problem finding the sector because of the track number.

- 0 Sector found.
- 1 Desired sector not found.

The desired sector is not found. The track number recorded on any sector on the track is different from the track address specified in the command phase.

## Bit 5 - CRC Error in Data Field

When the FDC detected a CRC error in the correct sector (bit 5 of the result phase Status register 1 (ST1) is 1), this bit indicates whether it occurred in the address field or in the data field.

- 0 The CRC error occurred in the address field.
- 1 The CRC error occurred in the data field.

#### Bit 6 - Control Mark

When the controller tried to read a sector, this bit indicates whether or not it detected a deleted data address mark during execution of a READ DATA or scan commands, or a regular address mark during execution of a READ DELETED DATA command.

0 - No control mark detected.

1 - Control mark detected.

#### Bit 7 - Not Used

This bit is not used and is always 0.

## 3.5.4 Result Phase Status Register 3 (ST3)



FIGURE 3-17. ST3 Result Phase Register

## Bits 1,0 - Logical Drive Selected

These two binary encoded bits indicate the logical drive selected at the end of the command phase.

The value of these bits is the same as bits 1,0 of the SR0 register, described on page 71.

- 00 Drive 0 selected.
- 01 Drive 1 selected.
- 10 If four drives are supported, or drives 2 and 0 are exchanged, drive 2 is selected.
- 11 If four drives are supported, drive 3 is selected.

#### Bit 2 - Head Selected

This bit indicates which side of the Floppy Disk Drive (FDD) is selected. It reflects the status of the HDSEL signal at the end of the command phase.

The value of this bit is the same as bit 2 of the SR0 register, described on page 71.

- 0 Side 0 is selected.
- 1 Side 1 is selected.

#### Bit 3 - Not Used

This bit is not used and is always 1.

#### Bit 4 - Track 0

This bit Indicates whether or not the head of the selected drive is at track 0.

- 0 The head of the selected drive is not at track 0, i.e., TRK0 is not active.
- 1 The head of the selected drive is at track 0, i.e., TRK0 is active.

#### Bit 5 - Not Used

This bit is not used and is always 1.

#### Bit 6 - Drive Write Protected

This bit indicates whether or not the selected drive is write protected, i.e., the  $\overline{\text{WP}}$  signal is active (low).

- 0 Selected drive is not write protected, i.e., WP is not active.
- 1 Selected drive is write protected, i.e., WP is active.

#### Bit 7 - Not Used

This bit is not used and is always 0.

## 3.6 THE FDC COMMAND SET

The first command byte for each command in the FDC command set is the opcode byte. The FDC uses this byte to determine how many command bytes to expect.

If an invalid command byte is issued to the controller, it immediately enters the result phase and the status is 80 (hex), signifying an invalid command.

Table 3-9 shows the FDC commands in alphabetical order with the opcode, i.e., the first command byte, for each.

In this table:

- MT is a multi-track enable bit (See "Bit 7 Multi-Track (MT)" on page 89.)
- MFM is a modified frequency modulation parameter (See "Bit 6 Modified Frequency Modulation (MFM)" on page 79.)
- SK is a skip control bit. (See "Bit 5 Skip Control (SK)" on page 88.)

Section 3.6.1 explains some symbols and abbreviations you will encounter in the descriptions of the commands.

All phases of each command are described in detail, starting with Section 3.6.2, with bitmaps of each byte in each phase.

Only named bits and fields are described in detail. When a bitmap shows a value (0 or 1) for a bit, that bit must have that value and is not described.

**TABLE 3-9. FDC Command Set Summary** 

| Commond               | Opcode |     |        |     |     |   |   |   |  |
|-----------------------|--------|-----|--------|-----|-----|---|---|---|--|
| Command               | 7      | 6   | 5      | 4   | 3   | 2 | 1 | 0 |  |
| CONFIGURE             | 0      | 0   | 0      | 1   | 0   | 0 | 1 | 1 |  |
| DUMPREG               | 0      | 0   | 0      | 0   | 1   | 1 | 1 | 0 |  |
| FORMAT TRACK          | 0      | MFM | 0      | 0   | 1   | 1 | 0 | 1 |  |
| INVALID               |        | Inv | alid O | рсс | ode |   |   |   |  |
| LOCK                  |        | 0   | 0      | 1   | 0   | 1 | 0 | 0 |  |
| MODE                  | 0      | 0   | 0      | 0   | 0   | 0 | 0 | 1 |  |
| NSC                   | 0      | 0   | 0      | 1   | 1   | 0 | 0 | 0 |  |
| PERPENDICULAR<br>MODE | 0      | 0   | 0      | 1   | 0   | 0 | 1 | 0 |  |
| READ DATA             | МТ     | MFM | SK     | 0   | 0   | 1 | 1 | 0 |  |
| READ DELETED<br>DATA  | MT     | MFM | SK     | 0   | 1   | 1 | 0 | 0 |  |
| READ ID               | 0      | MFM | 0      | 0   | 1   | 0 | 1 | 0 |  |
| READ TRACK            | 0      | MFM | 0      | 0   | 0   | 0 | 1 | 0 |  |
| RECALIBRATE           | 0      | 0   | 0      | 0   | 0   | 1 | 1 | 1 |  |
| RELATIVE SEEK         | 1      | MFM | 0      | 0   | 1   | 1 | 1 | 1 |  |
| SCAN EQUAL            | МТ     | MFM | SK     | 1   | 0   | 0 | 0 | 1 |  |
| SCAN HIGH OR<br>EQUAL | MT     | MFM | SK     | 1   | 1   | 1 | 0 | 1 |  |
| SCAN LOW OR<br>EQUAL  | MT     | MFM | SK     | 1   | 1   | 0 | 0 | 1 |  |
| SEEK                  | 0      | 0   | 0      | 0   | 1   | 1 | 1 | 1 |  |
| SENSE DRIVE<br>STATUS | 0      | 0   | 0      | 0   | 0   | 1 | 0 | 0 |  |
| SENSE<br>INTERRUPT    | 0      | 0   | 0      | 0   | 1   | 0 | 0 | 0 |  |
| SET TRACK             | 0      |     | 1      | 0   | 0   | 0 | 0 | 1 |  |
| SPECIFY               | 0      | 0   | 0      | 0   | 0   | 0 | 1 | 1 |  |
| VERIFY                | МТ     | MFM | SK     | 1   | 0   | 1 | 1 | 0 |  |
| VERSION               | 0      | 0   | 0      | 1   | 0   | 0 | 0 | 0 |  |
| WRITE DATA            | МТ     | MFM | 0      | 0   | 0   | 1 | 0 | 1 |  |
| WRITE DELETED<br>DATA | МТ     | MFM | 0      | 0   | 1   | 0 | 0 | 1 |  |

## 3.6.1 Abbreviations Used in FDC Commands

- **BFR** Buffer enable bit set in the MODE command. Enabled open-collector output buffers.
- BST Burst mode disable control bit set in MODE command. Disables burst mode for the FIFO, if the FIFO is enabled.
- **DC3-0** Drive Configuration for drives 3-0. Used to configure a logical drive to conventional or perpendicular mode. Used in the PERPENDICULAR MODE command.

#### **DENSEL**

Density Select control bits set in the MODE command.

- **DIR** Direction control bit used in RELATIVE SEEK command to indicate step in or out.
- **DMA** DMA mode enable bit set in the SPECIFY command.
- **DS1-0** Drive Select for bits 1,0 used in most commands. Selects the logical drive.
- EC Enable Count control bit set in the VERIFY command. When this bit is 1, SC (Sectors to read Count) command byte is required.
- **EIS** Enable Implied Seeks. Set in the CONFIG-URE command.
- **EOT** End of Track parameter set in read, write, scan, and VERIFY commands.
- **ETR** Extended Track Range set in the MODE command.
- FIFO First-In First-Out buffer. Also a control bit set in the CONFIGURE command to enable or disable the FIFO.
- FRD FIFO Read Disable control bit set in the MODE command
- **FWR** FIFO Write disable control bit set in the MODE command.
- Gap 2 The length of gap 2 in the FORMAT TRACK command and the portion of it that is rewritten in the WRITE DATA command depend on the drive mode, i.e., perpendicular or conventional. Figure 3-18 on page 82 illustrates gap 2 graphically. For more details, see "Bits 1,0 Group Drive Mode Configuration (GDC)" on page 88.
- **Gap 3** Gap 3 is the space between sectors, excluding the synchronization field. It is defined in the FORMAT TRACK command. See Figure 3-18 on page 82.

- **GDC** Group Drive Configuration for all drives. Configures all logical drives as conventional or perpendicular. Used in the PERPENDICULAR MODE command. Formerly, GAP2 and WG.
- **HD** Head Select control bit used in most commands. Selects Head 0 or 1 of the disk.
- IAF Index Address Field control bit set in the MODE command. Enables the ISO Format during the FORMAT command.
- **IPS** Implied Seek enable bit set in the MODE, read, write, and scan commands.
- **LOCK** Lock enable bit in the LOCK command. Used to prevent certain parameters from being affected by a software reset.

#### **LOW PWR**

Low Power control bits set in the MODE command.

- **MFM** Modified Frequency Modulation parameter used in FORMAT TRACK, read, VERIFY and write commands.
- **MFT** Motor Off Time. Now called Delay After Processing time. This delay is set by the SPECI-FY command.
- MNT Motor On Time. Now called Delay Before Processing time. This delay is set by the SPECI-FY command.
- **MSB** Most Significant Byte controls which whether the most or least significant byte is read or written in the SET TRACK command.
- **MT** Multi-Track enable bit used in read, write, scan and VERIFY commands.
- **OW** Overwrite control bit set in the PERPENDICU-LAR MODE command.
- **POLL** Enable Drive Polling bit set in the CONFIG-URE command.

#### **PRETRK**

Precompensation Track Number set in the CONFIGURE command

- PTR Present Track number. Contains the internal 8-bit track number or the least significant byte of the 12-bit track number of one of the four logical disk drives. PTR is set in the SET TRACK command.
- **R255** Recalibration control bit set in MODE command. Sets maximum number of STEP pulses during RECALIBRATE command to 255.
- **RTN** Relative Track Number used in the RELATIVE SEEK command.

- SC Sector Count control bit used in the VERIFY command.
- **SK** Skip control bit set in read and scan and VER-IFY operations.
- SRT Step Rate Time set in the SPECIFY command. Determines the time between STEP pulses for SEEK and RECALIBRATE operations.

#### ST0-3

Result phase Status registers 3-0 that contain status information about the execution of a command. See Sections 3.5.1 through 3.5.4.

#### **THRESH**

FIFO threshold parameter set in the CONFIG-URE command

- **TMR** Timer control bit set in the MODE command. Affects the timers set in the SPECIFY command.
- WG Formerly, the Write Gate control bit. Now included in the Group Drive mode Configuration (GDC) bits in the PERPENDICULAR MODE command.
- **WLD** Wildcard bit in the MODE command used to enable or disable the wildcard byte (FF) during scan commands.
- **WNR** Write Number controls whether to read an existing track number or to write a new one in the SET TRACK command.

## 3.6.2 The CONFIGURE Command

The CONFIGURE command controls some operation modes of the controller. It should be issued during the initialization of the FDC after power up.

The bits in the CONFIGURE registers are set to their default values after a hardware reset.

### **Command Phase**

| 7                                     | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|---------------------------------------|---|---|---|---|---|---|---|--|--|
| 0                                     | 0 | 0 | 1 | 0 | 0 | 1 | 1 |  |  |
| 0                                     | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |
| 0 EIS FIFO POLL Threshold (THRESH)    |   |   |   |   |   |   |   |  |  |
| Precompensation Track Number (PRETRK) |   |   |   |   |   |   |   |  |  |

## **Third Command Phase Byte**

#### Bits 3-0 - The FIFO Threshold (THRESH)

These bits specify the threshold of the FIFO during the execution phase of read and write data transfers.

This value is programmable from 00 to 0F hex. A software reset sets this value to 00 if the LOCK bit (bit 7 of the opcode of the LOCK command) is 0. If the LOCK bit is 1, THRESH retains its value.

Use a high value of THRESH for systems that respond slowly and a low value for fast systems.

#### Bit 4 - Disable Drive Polling (POLL)

This bit enables and disabled drive polling. A software reset clears this bit to 0.

When drive polling is enabled, an interrupt is generated after a reset.

When drive polling is disabled, if the CONFIGURE command is issued within 500 msec of a hardware or software reset, then an interrupt is not generated. In addition, the four SENSE INTERRUPT commands to clear the Ready Changed State of the four logical drives is not required.

- 0 Enable drive polling. (Default)
- 1 Disable drive polling.

#### Bit 5 - Enable FIFO (FIFO)

This bit enables and disables the FIFO for execution phase data transfers.

If the LOCK bit (bit 7 of the opcode of the LOCK command) is 0, a software reset disables the FIFO, i.e., sets this bit to 1.

If the LOCK bit is 1, this bit retains its previous value after a software reset.

- 0 FIFO enabled for read and write operations.
- 1 FIFO disabled. (Default)

#### Bit 6 - Enable Implied Seeks (EIS)

This bit enables or disables implied seek operations. A software reset disables implied seeks, i.e., clears this bit to 0.

Bit 5 of the MODE command (Implied Seek (IPS) can override the setting of this bit and enable implied seeks even if they are disabled by this bit.

When implied seeks are enabled, a seek or sense interrupt operation is performed before execution of the read, write, scan, or verify operation.

- 0 Implied seeks disabled. The MODE command can still enable implied seek operations. (Default)
- Implied seeks enabled for read, write, scan and VERIFY operations, regardless of the value of the IPS bit in the MODE command.

## Fourth Command Phase Byte, Bits 7-0, Precompensation Track Number (PRETRK)

This byte identifies the starting track number for write precompensation. The value of this byte is programmable from track 0 (00 hex) to track 255 (FF hex).

If the LOCK bit (bit 7 of the opcode of the LOCK command) is 0, after a software reset this byte indicates track 0 (00 hex).

If the LOCK bit is 1, PRETRK retains its previous value after a software reset.

## **Execution Phase**

Internal registers are written.

#### **Result Phase**

None.

## 3.6.3 The DUMPREG Command

The DUMPREG command supports system run-time diagnostics, and application software development and debugging.

DUMPREG has a one-byte command phase (the opcode) and a 10-byte result phase, which returns the values of parameters set in other commands. See the commands that set each parameter for a detailed description of the parameter.

## **Command Phase**

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---|---|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 |

#### **Execution Phase**

Internal registers read.

## **Result Phase**

After a hardware or software reset, parameters in this phase are reset to their default values. Some of these parameters are unaffected by a software reset, depending on the state of the LOCK bit.

See the command that determines the setting for the bit or field for details.

| 7                                          | 6                                           | 5       | 4      | 3           | 2       | 1       | 0      |  |
|--------------------------------------------|---------------------------------------------|---------|--------|-------------|---------|---------|--------|--|
| Ву                                         | te of F                                     | resent  | Track  | Numbe       | er (PTF | R) Driv | e 0    |  |
| Ву                                         | te of F                                     | resent  | Track  | Numbe       | er (PTF | R) Driv | e 1    |  |
| Byte of Present Track Number (PTR) Drive 2 |                                             |         |        |             |         |         |        |  |
| Byte of Present Track Number (PTR) Drive 3 |                                             |         |        |             |         |         |        |  |
| Step                                       | Step Rate Time (SRT) Delay After Processing |         |        |             |         |         |        |  |
|                                            | De                                          | elay Be | fore P | rocess      | ing     |         | DMA    |  |
| Secto                                      | rs per                                      | Track   | or End | d of Tra    | ack (EC | DT) Se  | ctor # |  |
| LOCK                                       | 0                                           | DC3     | DC2    | DC1 DC0 GDC |         |         |        |  |
| 0                                          | EIS                                         | FIFO    | POLL   | THRESH      |         |         |        |  |
| Precompensation Track Number (PRETRK)      |                                             |         |        |             |         |         |        |  |

## First through Fourth Result Phase Bytes, Bits 7-0, Present Track Number (PTR) Drives 3-0

Each of these bytes contains either the internal 8bit track number or the least significant byte of the 12-bit track number of the corresponding logical disk drive.

# Fifth and Sixth Result Phase Bytes, Bits 7-0, Step Rate Time, Motor Off Time, Motor On Time and DMA

These fields are all set by the SPECIFY command. See Section 3.6.21 on page 99.

## Seventh Result Phase Byte -Sectors Per Track or End of Track (EOT)

This byte varies depending on what commands have been previously executed.

If the last command issued was a FORMAT TRACK command, and no read or write commands have been issued since then, this byte contains the sectors per track value.

If a read or a write command was executed more recently than a FORMAT TRACK command, this byte specifies the number of the sector at the End of the Track (EOT).

## **Eighth Result Phase Byte**

#### Bit 7 - LOCK

This bit controls how the other bits in this command respond to a software reset. See page 83.

The value of this is determined by bit 7 of the opcode of the LOCK command.

- 0 -Bits in this command are set to their default values after a software reset. (Default)
- Bits in this command are unaffected by a software reset.

## Bits 5-0 - DC3-0, GDC

Bits 5-0 of the second command phase byte of the PERPENDICULAR MODE command set bits 5-0 of this byte. See page 88.

## Ninth and Tenth Result Phase Bytes

These bytes reflect the values in the third and fourth command phase bytes of the CONFIGURE command. See page 77.

## 3.6.4 The FORMAT TRACK Command

This command formats one track on the disk in IBM, ISO, or Toshiba perpendicular format.

After a pulse from the INDEX signal is detected, data patterns are written on the disk including all gaps, Address Marks (AMs), address fields and data fields. See Figure 3-18.

The format of the track is determined by the following parameters:

- The MFM bit in the opcode (first command) byte, which indicates the type of the disk drive and the data transfer rate and determines the format of the address marks and the encoding scheme.
- The Index Address Format (IAF) bit (bit 6 in the second command phase byte) in the MODE command, which selects IBM or ISO format.
- The Group Drive Configuration (GDC) bits in the PERPENDICULAR MODE command, which select either conventional or Toshiba perpendicular format.
- A bytes-per-sector code, which determines the sector size. See Table 3-10 on page 80.
- A sectors per track parameter, which specifies how many sectors are formatted on the track.
- The data pattern byte, which is used to fill the data field of each sector.

Table 3-11 shows typical values for these parameters for specific PC compatible diskettes.

To allow flexible formatting, the microprocessor must supply the four address field bytes (track number, head number, sector number, bytes-per-sector code) for each sector formatted during the execution phase. This allows non-sequential sector interleaving.

This transfer of bytes from the microprocessor to the controller can be done in DMA or non-DMA mode (See Section 3.4.2 on page 68), with the FIFO enabled or disabled.

The FORMAT TRACK command terminates when a pulse from the INDEX signal is detected a second time, at which point an interrupt is generated.

#### **Command Phase**

| 7 | 6                     | 5  | 4      | 3       | 2   | 1   | 0   |  |  |
|---|-----------------------|----|--------|---------|-----|-----|-----|--|--|
| 0 | MFM                   | 0  | 0      | 1       | 1   | 0   | 1   |  |  |
| Х | Х                     | Х  | Х      | Х       | HD  | DS1 | DS0 |  |  |
|   | Bytes-Per-Sector Code |    |        |         |     |     |     |  |  |
|   |                       | Se | ectors | per Tra | ack |     |     |  |  |
|   | Bytes in Gap 3        |    |        |         |     |     |     |  |  |
|   | Data Pattern          |    |        |         |     |     |     |  |  |

## First Command Phase Byte, Opcode

#### Bit 6 - Modi ed Frequency Modulation (MFM)

This bit indicates the type of the disk drive and the data transfer rate, and determines the format of the address marks and the encoding scheme.

- 0 FM mode, i.e., single density.
- 1 MFM mode, i.e., double density.

## **Second Command Phase Byte**

## Bits 1,0 - Logical Drive Select (DS1,0)

These bits indicate which logical drive is active. They reflect the values of bits 1,0 of the Digital Output Register (DOR) described on page 71 and of result phase status registers 0 and 3 (ST0 and ST3) described on pages 71 and 74, respectively.

- 00 Drive 0 is selected. (Default)
- 01 Drive 1 is selected.
- 10 If four drives are supported, or drives 2 and 0 are exchanged, drive 2 is selected.
- 11 If four drives are supported, drive 3 is selected.

### Bit 2 - Head Select (HD)

This bit indicates which side of the Floppy Disk Drive (FDD) is selected by the head. Its value is the inverse of the HDSEL disk interface output signal.

This bit reflects the value of bit 3 of Status Register A (SRA) described on page 59 and bit 2 of result phase status registers 0 and 3 (ST0 and ST3) described on pages 71 and 74, respectively.

- 0 HDSEL is not active, i.e., the head of the FDD selects side 0. (Default)
- 1 HDSEL is active, i.e., the head of the FDD selects side 1.

## Third Command Phase Byte - Bytes-Per-Sector Code

This byte contains a code in hexadecimal format that indicates the number of bytes in a data field.

Table 3-10 shows the number of bytes in a data field for each code.

TABLE 3-10. Bytes per Sector Codes

| Bytes-Per-Sector Code (hex) | Bytes in Data Field |
|-----------------------------|---------------------|
| 00                          | 128                 |
| 01                          | 256                 |
| 02                          | 512                 |
| 03                          | 1024                |
| 04                          | 2048                |
| 05                          | 4096                |
| 06                          | 8192                |
| 07                          | 16384               |

#### Fourth Command Phase Byte - Sectors Per Track

The value in this byte specifies how many sectors there are in the track.

## Fifth Command Phase Byte - Bytes in Gap 3

The number of bytes in gap 3 is programmable. The number to program for Gap 3 depends on the data transfer rate and the type of the disk drive. Table 3-12 shows some typical values to use for Gap 3.

Figure 3-18 illustrates the track format for each of the formats recognized by the FORMAT TRACK command.

## Sixth Command Phase Byte - Data Pattern

This byte contains the contents of the data field.

#### **Execution Phase**

The system transfers four ID bytes (track number, head number, sector number and bytes-per-sector code) per sector to the Floppy Disk Controller (FDC) in either a DMA or a non-DMA mode. Section 3.4.2 on page 68 describes these modes.

The entire track is formatted. The data block in the data field of each sector is filled with the data pattern byte.

Only the first three status bytes in this phase are significant.

TABLE 3-11. Typical Values for PC Compatible Diskette Media

| Media Type           | Bytes in Data<br>Field (decimal) | Bytes-Per-Sector<br>Code (hex) | End of Track (EOT)<br>Sector # (hex) | Bytes in Gap 2 <sup>a</sup><br>(hex) | Bytes in Gap 3 <sup>b</sup> (hex) |
|----------------------|----------------------------------|--------------------------------|--------------------------------------|--------------------------------------|-----------------------------------|
| 360 KB               | 512                              | 02                             | 09                                   | 2A                                   | 50                                |
| 1.2 MB               | 512                              | 02                             | 0F                                   | 1B                                   | 54                                |
| 720 KB               | 512                              | 02                             | 09                                   | 1B                                   | 50                                |
| 1.44 MB              | 512                              | 02                             | 12                                   | 1B                                   | 6C                                |
| 2.88 MB <sup>c</sup> | 512                              | 02                             | 24                                   | 1B                                   | 53                                |

a. Gap 2 is specified in the command phase of read, write, scan, and verify commands. Although this is the recommended value, the FDC ignores this byte in read, write, scan and verify commands.

b. Gap 3 is the suggested value for the programmable GAP3 that is used in the FORMAT TRACK command and is illustrated in Figure 3-18.

c. The 2.88 MB diskette media is a barium ferrite media intended for use in perpendicular recording drives at the data rate of up to 1 Mbps.

**TABLE 3-12. Typical Gap Values** 

| Drive Type<br>and Data<br>Transfer<br>Rate | Bytes in Data<br>Field (decimal) | Bytes-Per-Sector<br>Code (hex) | End of Track (EOT)<br>Sector # (hex) | Bytes in Gap 2 <sup>a</sup><br>(hex) | Bytes in Gap 3 <sup>b</sup> (hex) |
|--------------------------------------------|----------------------------------|--------------------------------|--------------------------------------|--------------------------------------|-----------------------------------|
|                                            | 128                              | 00                             | 12                                   | 07                                   | 09                                |
|                                            | 128                              | 00                             | 10                                   | 10                                   | 19                                |
| 125 Kbps                                   | 256                              | 01                             | 08                                   | 18                                   | 30                                |
| FM                                         | 512                              | 02                             | 04                                   | 46                                   | 87                                |
|                                            | 1024                             | 03                             | 02                                   | C8                                   | FF                                |
|                                            | 2048                             | 04                             | 01                                   | C8                                   | FF                                |
|                                            | 256                              | 01                             | 12                                   | 0A                                   | 0C                                |
|                                            | 256                              | 01                             | 10                                   | 20                                   | 32                                |
| 250 Kbps                                   | 512                              | 02                             | 08                                   | 2A                                   | 50                                |
| MFM                                        | 512                              | 02                             | 09                                   | 2A                                   | 50                                |
|                                            | 1024                             | 03                             | 04                                   | 80                                   | F0                                |
|                                            | 2048                             | 04                             | 02                                   | C8                                   | FF                                |
|                                            | 4096                             | 05                             | 01                                   | C8                                   | FF                                |
|                                            | 128                              | 00                             | 1A                                   | 07                                   | 1B                                |
|                                            | 256                              | 01                             | 0F                                   | 0E                                   | 2A                                |
| 250 Kbps                                   | 512                              | 02                             | 08                                   | 1B                                   | 3A                                |
| FM                                         | 1024                             | 03                             | 04                                   | 47                                   | 8A                                |
|                                            | 2048                             | 04                             | 02                                   | C8                                   | FF                                |
|                                            | 4096                             | 05                             | 01                                   | C8                                   | FF                                |
|                                            | 256                              | 01                             | 1A                                   | 0E                                   | 36                                |
|                                            | 512                              | 02                             | 0F                                   | 1B                                   | 54                                |
| 500.14                                     | 512                              | 02                             | 12                                   | 1B                                   | 6C                                |
| 500 Kbps<br>MFM                            | 1024                             | 03                             | 08                                   | 35                                   | 74                                |
| IVIFIVI                                    | 2048                             | 04                             | 04                                   | 99                                   | FF                                |
|                                            | 4096                             | 05                             | 02                                   | C8                                   | FF                                |
|                                            | 8192                             | 06                             | 01                                   | C8                                   | FF                                |

a. Gap 2 is specified in the command phase of read, write, scan, and verify commands. Although this is the recommended value, the FDC ignores this byte in read, write, scan and verify commands.

b. Gap 3 is the suggested value for use in the FORMAT TRACK command. This is the programmable Gap 3 illustrated in Figure 3-18.



A1\* = Data Pattern of A1, Clock Pattern of OA. All other data rates use gap 2 = 22 bytes.

FIGURE 3-18. IBM, Perpendicular, and ISO Formats Supported by FORMAT TRACK Command

## **Result Phase**

| 7 | 6      | 5     | 4       | 3    | 2      | 1     | U |
|---|--------|-------|---------|------|--------|-------|---|
|   | Result | Phase | Status  | Regi | ster 0 | (ST0) |   |
|   | Result | Phase | Status  | Regi | ster 1 | (ST1) |   |
|   | Result | Phase | Status  | Regi | ster 2 | (ST2) |   |
|   |        |       | Undefir | ned  |        |       |   |
|   |        |       | Undefir | ned  |        |       |   |
|   |        |       | Undefir | ned  |        |       |   |
|   |        |       | Undefir | ned  |        |       |   |
|   |        |       |         |      |        |       |   |

C2\* = Data Pattern of C2, Clock Pattern of 14

## 3.6.5 The INVALID Command

If an invalid command (illegal opcode byte in the command phase) is received by the Floppy Disk Controller (FDC), the controller responds with the result phase Status register 0 (ST0) in the result phase. See "Result Phase Status Register 0 (ST0)" on page 71

The controller does not generate an interrupt during this condition. Bits 7 and 6 in the MSR (see Section 3.3.6 page 63) are both set to 1, indicating to the microprocessor that the controller is in the result phase and the contents of ST0 must be read.

## **Command Phase**

| 7 | 6 | 5  | 4       | 3      | 2  | 1 | 0 |
|---|---|----|---------|--------|----|---|---|
|   |   | lr | valid ( | Opcode | es |   |   |

## **Execution Phase**

None.

## **Result Phase**

| 7 6 5 4 3 2 1 | 0 |
|---------------|---|
|---------------|---|

Result Phase Status Register 0 (STO) (80 hex)

The system reads 80 (hex) from ST0 indicating that an invalid command was received.

## 3.6.6 The LOCK Command

The LOCK command can be used to keep the FIFO enabled and to retain the values of some parameters after a software reset.

After the command byte of the LOCK command is written, its result byte must be read before the opcode of the next command can be read. The LOCK command is not executed until its result byte is read by the microprocessor.

If the part is reset after the command byte of the LOCK command is written but before its result byte is read, then the LOCK command is not executed. This prevents accidental execution of the LOCK command.

## **Command Phase**

| 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|---|---|---|---|---|---|---|
| LOCK | 0 | 0 | 1 | 0 | 1 | 0 | 0 |

## Bit 7 - Control Reset Effect (LOCK)

This bit determines how the FIFO, THRESH, and PRETRK bits in the CONFIGURE command and, the FWR, FRD, and BST bits in the MODE command are affected by a software reset.

- Set default values after a software reset. (Default)
- 1 Values are unaffected by a software reset.

## **Execution Phase**

Internal register is written.

## **Result Phase**

| 7 | 6 | 5 | 4    | 3 | 2 | 1 | 0 |
|---|---|---|------|---|---|---|---|
| 0 | 0 | 0 | LOCK | 0 | 0 | 0 | 0 |

#### Bit 4 - Control Reset Effect (LOCK)

Same as bit 7 of opcode in command phase.

## 3.6.7 The MODE Command

This command selects the special features of the controller. The bits in the command bytes of the MODE command are set to their default values after a hardware reset.

#### **Command Phase**

| 7   | 6    | 5   | 4    | 3         | 2   | 1        | 0    |
|-----|------|-----|------|-----------|-----|----------|------|
| 0   | 0    | 0   | 0    | 0         | 0   | 0        | 1    |
| TMR | IAF  | IPS | 0    | LOW       | PWR | 0        | ETR  |
| FWR | FRD  | BST | R255 | 0         | 0   | 0        | 0    |
| DEN | ISEL | BFR | WLD  | Head Sett |     | ttle Fac | ctor |
| 0   | 0    | 0   | 0    | 0         | 0   | 0        | 0    |

#### **Second Command Phase Byte**

## Bit 0 - Extended Track Range (ETR)

This bit determines how the track number is stored. It is cleared to 0 after a software reset.

 Track number is stored as a standard 8-bit value compatible with the IBM, ISO, and Toshiba Perpendicular formats.

This allows access of up to 256 tracks during a seek operation. (Default)

1 - Track number is stored as a 12-bit value.

The upper four bits of the track value are stored in the upper four bits of the head number in the sector address field.

This allows access of up to 4096 tracks during a seek operation. With this bit set, an extra byte is required in the SEEK command phase and SENSE INTERRUPT result phase.

## Bits 3,2 - Low-Power Mode (LOW PWR)

These bits determine whether or not the FDC powers down and, if it does, they specific how long it will take.

These bits disable power down, i.e., are cleared to 0, after a software reset.

- 00 Disables power down. (Default)
- 01 Automatic power down.

At a 500 Kbps data transfer rate, the FDC will go into low-power mode 512 msec after it becomes idle.

At a 250 Kbps data transfer rate, the FDC will go into low-power mode 1 second after it becomes idle.

10 - Manual power down.

The FDC powers down mode immediately.

11 - Not used.

#### Bit 5 - Implied Seek (IPS)

This bit determines whether the Implied Seek (IPS) bit in a command phase byte of a read, write, scan, or verify command is ignored or READ.

A software reset clears this bit to its default value of 0.

- 0 The IPS bit in the command byte of a read, write, scan, or verify is ignored. (Default)
  - Implied seeks can still be enabled by the Enable Implied Seeks (EIS) bit (bit 6 of the third command phase byte) in the CONFIGURE command.
- 1 The IPS bit in the command byte of a read, write, scan, or verify is read.

If it is set to 1, the controller performs seek and sense interrupt operations before executing the command.

#### Bit 6 - Index Address Format (IAF)

This bit determines whether the controller formats tracks with or without an index address field.

A software reset clears this bit to its default value of 0.

- 0 The controller formats tracks with an index address field. (IBM and Toshiba Perpendicular format).
- 1 The controller formats tracks without an index address field. (ISO format).

#### Bit 7 - Motor Timer Values (TMR)

This bit determines which group of values to use to calculate the Delay Before Processing and Delay After Processing times. The value of each is programmed using the SPECIFY command, which is described on page 99 and in Tables 3-24 and 3-25.

A software reset clears this bit to its default value of 0.

- 0 Use the TMR = 0 group of values. (Default)
- 1 Use the TMR = 1 group of values.

#### **Third Command Phase Byte**

## Bit 4 - RECALIBRATE Step Pulses (R255)

This bit determines the maximum number of RECALIBRATE step pulses the controller issues before terminating with an error, depending on the value of the Extended Track Range (ETR) bit, i.e., bit 0 of the second command phase byte in the MODE command.

A software reset clears this bit to its default value of 0.

0 - If ETR (bit 0) = 0, the controller issues a maximum of 85 recalibration step pulses.

If ETR (bit 0) = 1, the controller issues a maximum of 3925 recalibration step pulses. (Default)

1 - If ETR (bit 0) = 0, the controller issues a maximum of 255 recalibration step pulses.

If ETR (bit 0) = 1, the controller issues a maximum of 4095 recalibration step pulses.

#### Bit 5 - Burst Mode Disable (BST)

This bit enables or disables burst mode, if the FIFO is enabled (bit 5 in the CONFIGURE command is 0). If the FIFO is not enabled in the CONFIGURE command, then the value of this bit is ignored.

A software reset enables burst mode, i.e., clears this bit to its default value of 0, if the LOCK bit (bit 7 of the opcode of the LOCK command) is 0. If it is 1, BST retains its value after a software reset.

- 0 Burst mode enabled for FIFO execution phase data transfers. (Default)
- 1 Burst mode disabled.

The FDC issues one DRQ or IRQ6 pulse for each byte to be transferred while the FIFO is enabled.

#### Bit 6 - FIFO Read Disable (FRD)

This bit enables or disables the FIFO for microprocessor read transfers from the controller, if the FIFO is enabled (bit 5 in the CONFIGURE command is 0). If the FIFO is not enabled in the CONFIGURE command, then the value of this bit is ignored.

A software reset enables the FIFO for reads, i.e., clears this bit to its default value of 0, if the LOCK bit (bit 7 of the opcode of the LOCK command) is 0. If it is 1, FRD retains its value after a software reset.

- Enable FIFO. Execution phase of microprocessor read transfers use the internal FIFO. (Default)
- 1 Disable FIFO. All read data transfers take place without the FIFO.

#### Bit 7 - FIFO Write Enable or Disable (FWR)

This bit enables or disables write transfers to the controller, if the FIFO is enabled (bit 5 in the CONFIGURE command is 0). If the FIFO is not enabled in the CONFIGURE command, then the value of this bit is ignored.

A software reset enables the FIFO for writes, i.e., clears this bit to its default value of 0, if the LOCK bit (bit 7 of the opcode of the LOCK command) is 0. If it is 1, FWR retains its value after a software reset.

- Enable FIFO. Execution phase microprocessor write transfers use the internal FIFO. (Default)
- 1 Disable FIFO. All write data transfers take place without the FIFO.

#### **Fourth Command Phase Byte**

#### Bits 3-0 - Head Settle Factor

This field is used to specify the maximum time allowed for the read/write head to settle after a seek during an implied seek operation.

The value specified by these bits (the head settle factor) is multiplied by the multiplier for selected data rate to specify a head settle time that is within the range for that data rate.

Use the following formula to determine the head settle factor that these bits should specify:

Head Settle Factor x Multiplier = Head Settle Time Table 3-13 shows the multipliers and head settle time ranges for each data transfer rate.

The default head settle factor, i.e., value for these bits, is 8.

TABLE 3-13. Multipliers and Head Settle Time Ranges for Different Data Transfer Rates

| Data Transfer<br>Rate (Kbps) | Multiplier | Head Settle<br>Time Range (msec) |
|------------------------------|------------|----------------------------------|
| 250                          | 8          | 0 - 120                          |
| 300                          | 6.666      | 0 - 100                          |
| 500                          | 4          | 0 - 60                           |
| 1000                         | 2          | 0 - 30                           |

## Bit 4 - Scan Wild Card (WLD)

This bit determines whether or not FF (hex) from either the microprocessor or the disk will be recognized during a scan command as a wildcard character.

- O An FF (hex) from either the microprocessor or the disk during a scan command is interpreted as a wildcard character that always matches. (Default)
- The scan commands do not recognize FF (Hex) as a wildcard character.

#### Bit 5 - CMOS Disk Interface Buffer Enable (BFR)

This bit configures drive output signals.

- 0 Drive output signals are configured as standard 4 mA push-pull output signals (40 mA sink, 4 mA source). (Default)
- 1 Drive output signals are configured as 40 mA open-drain output signals.

## **Bits 7,6 - Density Select Pin Con guration** (DENSEL)

This field can configure the polarity of the Density Select output signal (DENSEL) as always low or always high, as shown in Table 4-3. This allows the user more flexibility with new drive types.

This field overrides the DENSEL polarity defined by the DENSEL polarity bit of the Advanced Superl/O Chip (ASC) configuration register described on page 36.

- 00 The DENSEL signal is always low.
- 01 The DENSEL signal is always high.
- 10 The DENSEL signal is undefined.
- 11 The polarity of the DENSEL signal is defined by the DENSEL Polarity bit (bit 6) of the ASC register. See page 36. (Default)

**TABLE 3-14. DENSEL Encoding** 

| Bit 7 | Bit 6 | DENSEL Pin De nition |
|-------|-------|----------------------|
| 0     | 0     | DENSEL low           |
| 0     | 1     | DENSEL high          |
| 1     | 0     | undefined            |
| 1     | 1     | Set by ASC register. |

## 3.6.8 The NSC Command

The NSC command can be used to distinguish between the FDC versions and the 82077.

## **Command Phase**

|   | 6 |   |   |   |   |   |   |  |
|---|---|---|---|---|---|---|---|--|
| 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 |  |

## **Execution Phase**

## **Result Phase**

The result phase byte of the NSC command identifies the floppy disk controller (FDC) as a PC87338/PC97338 by returning a value of 73h.

The 82077 and DP8473 return the value 80 hex, signifying an invalid command.

Bits 3-0 of this result byte are subject to change by NSC, and specify the version of the Floppy Disk Controller (FDC).

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---|---|---|---|---|---|---|
| 0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 |

## **Execution Phase**

Internal registers are written.

### **Result Phase**

None.

## 3.6.9 The PERPENDICULAR MODE Command

The PERPENDICULAR MODE command configures each of the four logical disk drives for perpendicular or conventional mode via the logical drive configuration bits 1,0 or 5-2, depending on the value of bit 7. The default mode is conventional. Therefore, if the drives in the system are conventional, it is not necessary to issue a PERPENDICULAR MODE command.

This command supports the unique FORMAT TRACK and WRITE DATA requirements of perpendicular (vertical) recording disk drives with a 4 MB unformatted capacity.

Perpendicular recording drives operate in extra high density mode at 1 or 2 Mbps, and are downward compatible with 1.44 MB and 720 KB drives at 500 kbps (high density) and 250 kbps (double density), respectively.

If the system includes perpendicular drives, this command should be issued during initialization of the FDC. Then, when a drive is accessed for a FORMAT TRACK or WRITE DATA command, the FDC adjusts the command parameters based on the data rate. See Table 3-15.

Precompensation is set to zero for perpendicular drives at any data rate.

Perpendicular recording type disk drives have a preerase head that leads the read or write head by 200  $\mu$ m, which translates to 38 bytes at a 1 Mbps data transfer rate (19 bytes at 500 Kbps).

The increased space between the two heads requires a larger gap 2 between the address field and data field of a sector at 1 or 2 Mbps. See Perpendicular Format in Figure 3-18. A gap 2 length of 41 bytes (at 1 or 2 Mbps) ensures that the preamble in the data field is completely pre-erased by the pre-erase head.

Also, during WRITE DATA operations to a perpendicular drive, a portion of gap 2 must be rewritten by the controller to guarantee that the data field preamble has been pre-erased. See Table 3-15.

## **Command Phase**

| 7  | 6 | 5   | 4   | 3   | 2   | 1  | 0  |
|----|---|-----|-----|-----|-----|----|----|
| 0  | 0 | 0   | 1   | 0   | 0   | 1  | 0  |
| OW | 0 | DC3 | DC2 | DC1 | DC0 | GI | DC |

TABLE 3-15. Effect of Drive Mode and Data Rate on FORMAT TRACK and WRITE DATA Commands

| Data Rates           | Drive Mode                    | Length of Gap 2 in FORMAT TRACK Command | Portion of Gap 2 Rewritten in WRITE DATA Command |  |
|----------------------|-------------------------------|-----------------------------------------|--------------------------------------------------|--|
| 250, 300 or 500 Kbps | Conventional<br>Perpendicular | 22 bytes<br>22 bytes                    | 0 bytes<br>19 bytes                              |  |
| 1 or 2 Mbps          | Conventional                  | 22 bytes                                | 0 bytes                                          |  |
| '                    | Perpendicular                 | 41 bytes                                | 38 bytes                                         |  |

TABLE 3-16. Effect of GDC Bits on FORMAT TRACK and WRITE DATA Commands

| GDC Bits |                               | Drive Mode                | Length of Gap 2 in   | Portion of Gap 2 Rewritten in |  |
|----------|-------------------------------|---------------------------|----------------------|-------------------------------|--|
| 1        | 0                             | Drive Mode                | FORMAT TRACK Command | WRITE DATA Command            |  |
| 0        | 0                             | Conventional              | 22 bytes             | 0 bytes                       |  |
| 0        | 1                             | Perpendicular (≤500 Kbps) | 22 bytes             | 19 bytes                      |  |
| 1        | 0                             | Conventional              | 22 bytes             | 0 bytes                       |  |
| 1        | 1 Perpendicular (1 or 2 Mbps) |                           | 41 bytes             | 38 bytes                      |  |

#### **Second Command Phase Byte**

A hardware reset clears all the bits to zero (conventional mode for all drives). PERPENDICULAR MODE command bits may be written at any time.

The settings of bits 1 and 0 in this byte override the logical drive configuration set by bits 5 through 2. If bits 1 and 0 are both 0, bits 5 through 2 configure the logical disk drives as conventional or perpendicular. Otherwise, bits 2 and 0 configure them. See Table 3-16.

#### Bits 1,0 - Group Drive Mode Con guration (GDC)

These bits configure all the logical disk drives as conventional or perpendicular. If the Overwrite bit (OW, bit 7) is 0, this setting may be overridden by bits 5-2.

It is not necessary to issue the FORMAT TRACK command if all drives are conventional.

These bits are cleared to 0 by a software reset.

- 00 Conventional. (Default)
- 01 Perpendicular. (500 Kbps)
- 10 Conventional.
- 11 Perpendicular. (1 or 2 Mbps)

#### Bits 5-2 -Drive 3-0 Mode Con guration (DC3-0)

If bits 1,0 are both 0, and bit 7 is 1, these bits configure logical drives 3-0 as conventional or perpendicular. Bits 5-2 (DC3–0) correspond to logical drives 3-0, respectively.

These bits are not affected by a software reset.

- 0 Conventional drive. (Default)
  - It is not necessary to issue the FORMAT TRACK command for conventional drives.
- 1 Perpendicular drive.

#### Bit 7 - Overwrite (OW)

This bit enables or disables changes in the mode of the logical drives by bits 5-2.

- 0 Changes in mode of logical drives via bits 5-2 are ignored. (Default)
- 1 Changes enabled.

#### **Execution Phase**

Internal registers are written.

#### **Result Phase**

None.

#### 3.6.10 The READ DATA Command

The READ DATA command reads logical sectors that contain a normal data address mark from the selected drive and makes the data available to the host microprocessor.

#### **Command Phase**

The READ DATA command phase bytes must specify the following ID information for the desired sector:

- Track number
- Head number
- Sector number
- Bytes-per-sector code (See Table 3-10.)
- End of Track (EOT) sector number. This allows the controller to read multiple sectors.
- The value of the data length byte is ignored and must be set to FF (hex).

After the last command phase byte is written, the controller waits the Delay Before Processing time (see Table 3-25 on page 100) for the selected drive. During this time, the drive motor must be turned on by enabling the appropriate drive and motor select disk interface output signals via the bits of the Digital Output Register (DOR). See "Digital Output Register (DOR), Offset 010" on page 60.

| 7                    | 6                                | 5    | 4       | 3      | 2    | 1 | 0 |  |  |  |
|----------------------|----------------------------------|------|---------|--------|------|---|---|--|--|--|
| MT                   | MFM                              | SK   | 0       | 0      | 1    | 1 | 0 |  |  |  |
| IPS X X X X HD DS1 D |                                  |      |         |        |      |   |   |  |  |  |
| Track Number         |                                  |      |         |        |      |   |   |  |  |  |
| Head Number          |                                  |      |         |        |      |   |   |  |  |  |
|                      |                                  | 5    | Sector  | Numbe  | er   |   |   |  |  |  |
|                      |                                  | Byte | s-Per-S | Sector | Code |   |   |  |  |  |
|                      | End of Track (EOT) Sector Number |      |         |        |      |   |   |  |  |  |
|                      | Bytes Between Sectors - Gap 3    |      |         |        |      |   |   |  |  |  |
|                      | Data Length (Obsolete)           |      |         |        |      |   |   |  |  |  |

#### **First Command Phase Byte**

#### Bit 5 - Skip Control (SK)

This controls whether or not sectors containing a deleted address mark will be skipped during execution of the READ DATA command. See Table 3-17.

- 0 Do not skip sector with deleted address mark.
- 1 Skip sector with deleted address mark.

#### Bit 6 - Modi ed Frequency Modulation (MFM)

This bit indicates the type of the disk drive and the data transfer rate, and determines the format of the address marks and the encoding scheme.

- 0 FM mode, i.e., single density.
- 1 MFM mode, i.e., double density.

#### Bit 7 - Multi-Track (MT)

This bit controls whether or not the controller continues to side 1 of the disk after reaching the last sector of side 0.

- 0 Single track. The controller stops at the last sector of side 0.
- 1 Multiple tracks. the controller continues to side1 after reaching the last sector of side 0.

#### **Second Command Phase Byte**

#### Bits 1,0 - Logical Drive Select (DS1,0)

These bits indicate which logical drive is active. See "Bits 1,0 - Logical Drive Select (DS1,0)" on page 79.

- 00 Drive 0 is selected. (Default)
- 01 Drive 1 is selected.
- 10 If four drives are supported, or drives 2 and 0 are exchanged, drive 2 is selected.
- 11 If four drives are supported, drive 3 is selected.

#### Bit 2 - Head (HD)

This bit indicates which side of the Floppy Disk Drive (FDD) is selected by the head. Its value is the inverse of the HDSEL disk interface output signal. See "Bit 2 - Head Select (HD)" on page 79.

- 0 HDSEL is not active, i.e., the head of the FDD selects side 0. (Default)
- 1 HDSEL is active, i.e., the head of the FDD selects side 1.

#### Bit 7 - Implied Seek (IPS)

This bit indicates whether or not an implied seek should be performed. See also, "Bit 5 - Implied Seek (IPS)" on page 84.

A software reset clears this bit to its default value of 0.

- 0 No implied seek operations. (Default)
- 1 The controller performs seek and sense interrupt operations before executing the command.

#### **Third Command Phase Byte - Track Number**

The value in this byte specifies the number of the track to read.

#### Fourth Command Phase Byte - Head Number

The value in this byte specifies head to use.

#### Fifth Command Phase Byte - Sector Number

The value in this byte specifies the sector to read.

### Sixth Command Phase Byte - Bytes-Per-Sector Code

This byte contains a code in hexadecimal format that indicates the number of bytes in a data field. Table 3-10 on page 80 indicates the number of bytes that corresponds to each code.

### **Seventh Command Phase Byte - Bytes Between Sectors - Gap 3**

The value in this byte specifies how many bytes there are between sectors. See "Fifth Command Phase Byte - Bytes in Gap 3" on page 80.

### Eighth Command Phase Byte - Data Length (Obsolete)

The value in this byte is ignored and must be set to FF (hex).

#### **Execution Phase**

In this phase, data read from the disk drive is transferred to the system via DMA or non-DMA modes. See 3.4.2 on page 68.

The controller looks for the track number specified in the third command phase byte. If implied seeks are enabled, the controller also performs all operations of a SENSE INTERRUPT command and of a SEEK command (without issuing these commands). Then, the controller waits the head settle time. See bits 3-0 of the fourth command phase byte of the MODE command on page 85.

The controller then starts the data separator and waits for the data separator to find the address field of the next sector. The controller compares the ID information (track number, head number, sector number, bytes-per-sector code) in that address field with the corresponding information in the command phase bytes of the READ DATA command.

If the contents of the bytes do not match, then the controller waits for the data separator to find the address field of the next sector. The process is repeated until a match or an error occurs.

Possible errors, the conditions that may have caused them and the actions that result are:

The microprocessor aborted the command by writing to the FIFO.

If there is no disk in the drive, the controller gets stuck. The microprocessor must then write a byte to the FIFO to advance the controller to the result phase.  Two pulses of the INDEX signal were detected since the search began, and no valid ID was found.

If the track address differs, either the Wrong Track bit (bit 4) or the Bad Track bit (bit 1) (if the track address is FF hex) is set in result phase Status register 2 (ST2). See Section 3.5.3 on page 73.

If the head number, sector number or bytes-persector code did not match, the Missing Data bit (bit 2) is set in result phase Status register 1 (ST1).

If the Address Mark (AM) was not found, the Missing Address Mark bit (bit 0) is set in ST1.

Section 3.5.2 on page 72 describes the bits of ST1.

 A CRC error was detected in the address field. In this case the CRC Error bit (bit 5) is set in ST1.

Once the address field of the desired sector is found, the controller waits for the data separator to find the data field for that sector.

If the data field (normal or deleted) is not found within the expected time, the controller terminates the operation, enters the result phase and sets bit 0 (Missing Address Mark) in ST1.

If a deleted data mark is found, and Skip (SK) control is set to 1 in the opcode command phase byte, the controller skips this sector and searches for the next sector address field as described above. The effect of Skip Control (SK) on the READ DATA command is summarized in Table 3-17.

TABLE 3-17. Skip Control Effect on READ DATA Command

| Skip<br>Control<br>(SK) | Data<br>Type | Sector<br>Read? | Control<br>Mark Bit 6<br>of ST2 | Result                  |
|-------------------------|--------------|-----------------|---------------------------------|-------------------------|
| 0                       | Normal       | Υ               | 0                               | Normal<br>Termination   |
| 0                       | Deleted      | Y               | 1                               | No More<br>Sectors Read |
| 1                       | Normal       | Y               | 0                               | Normal<br>Termination   |
| 1                       | Deleted      | N               | 1                               | Sector<br>Skipped       |

After finding the data field, the controller transfers data bytes from the disk drive to the host until the bytes-per-sector count has been reached, or until the host terminates the operation by issuing the Terminal Count (TC) signal, reaching the end of the track or reporting an overrun.

See also, Section "The Phases of FDC Commands" on page 68.

The controller then generates a Cyclic Redundancy Check (CRC) value for the sector and compares the result with the CRC value at the end of the data field.

After reading the sector, the controller reads the next logical sector unless one or more of the following termination conditions occurs:

- The DMA controller asserted the Terminal Count (TC) signal to indicate that the operation terminated. The Interrupt Code (IC) bits (bits 7,6) in ST0 are set to normal termination (00). See page 72.
- The last sector address (of side 1, if the Multi-Track enable bit (MT) was set to 1) was equal to the End of Track sector number. The End of Track bit (bit 7) in ST1 is set. The IC bits in ST0 are set to abnormal termination (01). This is the expected condition during non-DMA transfers.
- Overrun error. The Overrun bit (bit 4) in ST1 is set.
  The Interrupt Code (IC) bits (bits 7,6) in ST0 are
  set to abnormal termination (01). If the microprocessor cannot service a transfer request in time,
  the last correctly read byte is transferred.
- CRC error. CRC Error bit (bit 5) in ST1 and CRC Error in Data Field bit (bit 5) in ST2, are set. The Interrupt Code (IC) bits (bits 7,6) in ST0 are set to abnormal termination (01).

If the Multi-Track (MT) bit was set in the opcode command byte, and the last sector of side 0 has been transferred, the controller continues with side 1.

#### **Result Phase**

Upon terminating the execution phase of the READ DATA command, the controller asserts IRQ6, indicating the beginning of the result phase. The microprocessor must then read the result bytes from the FIFO.

| 7 | 6                                    | 5      | 4       | 3      | 2       | 1     | 0 |  |  |
|---|--------------------------------------|--------|---------|--------|---------|-------|---|--|--|
|   | Resul                                | t Phas | e Statu | ıs Reg | ister 0 | (ST0) |   |  |  |
|   | Resul                                | t Phas | e Statu | ıs Reg | ister 1 | (ST1) |   |  |  |
|   | Result Phase Status Register 2 (ST2) |        |         |        |         |       |   |  |  |
|   | Track Number                         |        |         |        |         |       |   |  |  |
|   |                                      | ı      | Head N  | Numbe  | r       |       |   |  |  |
|   | Sector Number                        |        |         |        |         |       |   |  |  |
|   |                                      | Bytes  | s-Per-S | Sector | Code    |       |   |  |  |

The values that are read back in the result bytes are shown in Table 3-18. If an error occurs, the result bytes indicate the sector read when the error occurred.

TABLE 3-18. Result Phase Termination Values with No Error

| Multi Tuesta        | Used #         | End of Track                | ID Information in Result Phase |                |                           |                          |  |  |  |
|---------------------|----------------|-----------------------------|--------------------------------|----------------|---------------------------|--------------------------|--|--|--|
| Multi-Track<br>(MT) | Head #<br>(HD) | (EOT) Sector<br>Number      | Track<br>Number                | Head<br>Number | Sector<br>Number          | Bytes-per-Sector<br>Code |  |  |  |
| 0                   | 0              | < EOT <sup>a</sup> Sector # | No Change                      | No Change      | Sector <sup>b</sup> # + 1 | No Change                |  |  |  |
| 0                   | 0              | = EOT <sup>a</sup> Sector # | Track <sup>c</sup> # + 1       | No Change      | 1                         | No Change                |  |  |  |
| 0                   | 1              | < EOT <sup>a</sup> Sector # | No Change                      | No Change      | Sector <sup>b</sup> # + 1 | No Change                |  |  |  |
| 0                   | 1              | = EOT <sup>a</sup> Sector # | Track <sup>c</sup> # + 1       | No Change      | 1                         | No Change                |  |  |  |
| 1                   | 0              | < EOT <sup>a</sup> Sector # | No Change                      | No Change      | Sector <sup>b</sup> # + 1 | No Change                |  |  |  |
| 1                   | 0              | = EOT <sup>a</sup> Sector # | No Change                      | 1              | 1                         | No Change                |  |  |  |
| 1                   | 1              | < EOT <sup>a</sup> Sector # | No Change                      | No Change      | Sector <sup>b</sup> # + 1 | No Change                |  |  |  |
| 1                   | 1              | = EOT <sup>a</sup> Sector # | Track <sup>c</sup> # + 1       | 0 1            |                           | No Change                |  |  |  |

- a. End of Track sector number from the command phase.
- b. The number of the sector last operated on by controller.
- c. Track number programmed in the command phase

## 3.6.11 The READ DELETED DATA Command

The READ DELETED DATA command reads logical sectors containing a Address Mark (AM) for deleted data from the selected drive and makes the data available to the host microprocessor.

This command is like the READ DATA command, except for the setting of the Control Mark bit (bit 6) in ST2 and the skipping of sectors. See description of execution phase.

#### **Command Phase**

| 7            | 6                                | 5    | 4       | 3      | 2    | 1   | 0   |  |  |  |
|--------------|----------------------------------|------|---------|--------|------|-----|-----|--|--|--|
| MT           | MFM                              | SK   | 0       | 1      | 1    | 0   | 0   |  |  |  |
| IPS          | Х                                | Х    | Х       | Х      | HD   | DS1 | DS0 |  |  |  |
| Track Number |                                  |      |         |        |      |     |     |  |  |  |
| Head Number  |                                  |      |         |        |      |     |     |  |  |  |
|              | Sector Number                    |      |         |        |      |     |     |  |  |  |
|              |                                  | Byte | s-Per-S | Sector | Code |     |     |  |  |  |
|              | End of Track (EOT) Sector Number |      |         |        |      |     |     |  |  |  |
|              | Bytes Between Sectors - Gap 3    |      |         |        |      |     |     |  |  |  |
|              | Data Length (Obsolete)           |      |         |        |      |     |     |  |  |  |

See READ DATA command for a description of the command bytes.

#### **Execution Phase**

Data read from disk drive is transferred to the system in DMA or non-DMA modes. See Section 3.4.2 on page 68.

The effect of Skip Control (SK) on the READ DELET-ED DATA command is summarized in Table 3-19.

TABLE 3-19. SK Effect on READ DELETED DATA Command

| Skip<br>Control<br>(SK) | Data<br>Type | Sector<br>Read? | Control<br>Mark Bit 6<br>of ST2 | Result                  |
|-------------------------|--------------|-----------------|---------------------------------|-------------------------|
| 0                       | Normal       | Υ               | 1                               | No More<br>Sectors Read |
| 0                       | Deleted      | Υ               | 0                               | Normal<br>Termination   |
| 1                       | Normal       | N               | 1                               | Sector<br>Skipped       |
| 1                       | Deleted      | Υ               | 0                               | Normal<br>Termination   |

#### **Result Phase**

| 7 | 6                                    | 5    | 4       | 3     | 2       | 1     | 0 |  |  |  |
|---|--------------------------------------|------|---------|-------|---------|-------|---|--|--|--|
|   | Result                               | Phas | e Statu | s Reg | ister 0 | (ST0) |   |  |  |  |
|   | Result Phase Status Register 1 (ST1) |      |         |       |         |       |   |  |  |  |
|   | Result Phase Status Register 2 (ST2) |      |         |       |         |       |   |  |  |  |
|   | Track Number                         |      |         |       |         |       |   |  |  |  |
|   |                                      | I    | Head N  | lumbe | r       |       |   |  |  |  |
|   | Sector Number                        |      |         |       |         |       |   |  |  |  |
|   | Bytes-Per-Sector Code                |      |         |       |         |       |   |  |  |  |

See Table 3-18 for the state of the result bytes when the command terminates normally.

#### 3.6.12 The READ ID Command

The READ ID command finds the next available address field and returns the ID bytes (track number, head number, sector number, bytes-per-sector code) to the microprocessor in the result phase.

The controller reads the first ID Field header bytes it can find and reports these bytes to the system in the result bytes.

#### **Command Phase**

| 7 | 6   | 5 | 4 | 3 | 2  | 1   | 0   |
|---|-----|---|---|---|----|-----|-----|
| 0 | MFM | 0 | 0 | 1 | 0  | 1   | 0   |
| Χ | Х   | Х | Х | Х | HD | DS1 | DS0 |

After the last command phase byte is written, the controller waits the Delay Before Processing time (see Table 3-25 on page 100) for the selected drive. During this time, the drive motor must be turned on by enabling the appropriate drive and motor select disk interface output signals via the bits of the Digital Output Register (DOR). See "Digital Output Register (DOR), Offset 010" on page 60.

#### First Command Phase Byte, Opcode

See "Bit 6 - Modified Frequency Modulation (MFM)" on page 79.

#### **Second Command Phase Byte**

See "Second Command Phase Byte" on page 79 for a description of the Drive Select (DS1,0) and Head Select (HD) bits.

#### **Execution Phase**

There is no data transfer during the execution phase of this command. An interrupt is generated when the execution phase is completed.

The READ ID command does not perform an implied seek.

After waiting the Delay Before Processing time, the controller starts the data separator and waits for the data separator to find the address field of the next sector. If an error condition occurs, the Interrupt Code (IC) bits in ST0 are set to abnormal termination (01), and the controller enters the result phase.

Possible errors are:

- The microprocessor aborted the command by writing to the FIFO.
  - If there is no disk in the drive, the controller gets stuck. The microprocessor must then write a byte to the FIFO to advance the controller to the result phase.
- Two pulses of the INDEX signal were detected since the search began, and no Address Mark (AM) was found.

When the Address Mark (AM) is not found, the Missing Address Mark bit (bit 0) is set in ST1. Section 3.5.2 on page 72 describes the bits of ST1.

#### **Result Phase**

| 7                     | 6             | 5      | 4       | 3      | 2       | 1     | 0 |  |  |
|-----------------------|---------------|--------|---------|--------|---------|-------|---|--|--|
|                       | Resul         | t Phas | e Statı | ıs Reg | ister 0 | (ST0) |   |  |  |
|                       | Resul         | t Phas | e Statı | ıs Reg | ister 1 | (ST1) |   |  |  |
|                       | Resul         | t Phas | e Statı | ıs Reg | ister 2 | (ST2) |   |  |  |
|                       | Track Number  |        |         |        |         |       |   |  |  |
|                       | Head Number   |        |         |        |         |       |   |  |  |
|                       | Sector Number |        |         |        |         |       |   |  |  |
| Bytes-Per-Sector Code |               |        |         |        |         |       |   |  |  |
|                       |               |        |         |        |         |       |   |  |  |

#### 3.6.13 The READ A TRACK Command

The READ A TRACK command reads sectors from the selected drive, in physical order, and makes the data available to the host.

#### **Command Phase**

| 7                     | 6                                | 5    | 4       | 3      | 2      | 1 | 0 |  |  |
|-----------------------|----------------------------------|------|---------|--------|--------|---|---|--|--|
| 0                     | MFM                              | 0    | 0       | 0      | 0      | 1 | 0 |  |  |
| IPS X X X X HD DS1 DS |                                  |      |         |        |        |   |   |  |  |
| Track Number          |                                  |      |         |        |        |   |   |  |  |
| Head Number           |                                  |      |         |        |        |   |   |  |  |
|                       |                                  | 5    | Sector  | Numbe  | er     |   |   |  |  |
|                       |                                  | Byte | s-Per-S | Sector | Code   |   |   |  |  |
|                       | End of Track (EOT) Sector Number |      |         |        |        |   |   |  |  |
|                       | Bytes Between Sectors - Gap 3    |      |         |        |        |   |   |  |  |
|                       |                                  | Data | Lengtl  | n (Obs | olete) |   |   |  |  |

The command phase bytes of the READ A TRACK command are like those of the READ DATA command, except for the MT and SK bits. Multi-track and skip operations are not allowed in the READ A TRACK command. Therefore, bits 7 and 5 of the opcode command phase byte (MT and SK, respectively) must be 0.

#### First Command Phase Byte, Opcode

See "Bit 6 - Modified Frequency Modulation (MFM)" on page 79.

#### **Second Command Phase Byte**

See "Second Command Phase Byte" on page 79 for a description of the Drive Select (DS1,0) and Head Select (HD) bits.

See "Bit 5 - Implied Seek (IPS)" on page 84 for a description of the Implied Seek (IPS) bit.

#### **Third through Ninth Command Phase Bytes**

See "The READ DATA Command" on page 88.

#### **Execution Phase**

Data read from the disk drive is transferred to the system in DMA or non-DMA modes. See Section 3.4.2.

Execution of this command is like execution of the READ DATA command except for the following differences:

 The controller waits for a pulse from the INDEX signal before it searches for the address field of a sector. If the microprocessor writes to the FIFO before the INDEX pulse is detected, the command enters the result phase with the Interrupt Code (IC) bits (bits 7,6) in ST0 set to abnormal termination (01).

- All the ID bytes of the sector address are compared, except the sector number. Instead, the sector number is set to 1, and then incremented for each successive sector read.
- If no match occurs when the ID bytes of the sector address are compared, the controller sets the Missing Data bit (bit 2) in ST1, but continues to read the sector. If there is a CRC error in the address field being read, the controller sets CRC Error (bit 5) in ST1, but continues to read the sector.
- If there is a CRC error in the data field, the controller sets the CRC Error bit (bit 5) in ST1 and CRC Error in Data Field bit (bit 5) in ST2, but continues reading sectors.
- The controller reads a maximum of End of Track (EOT) physical sectors. There is no support for multi-track reads.

n

#### **Result Phase**

6

| U                     | 3      | 7                                   | 3                                                                              | 2                                                                                                  | •                                                                                                                                   | U                                                                                                                                                     |  |  |
|-----------------------|--------|-------------------------------------|--------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Resul                 | t Phas | e Statu                             | ıs Reg                                                                         | jister 0                                                                                           | (ST0)                                                                                                                               |                                                                                                                                                       |  |  |
| Resul                 | t Phas | e Statu                             | ıs Reg                                                                         | jister 1                                                                                           | (ST1)                                                                                                                               |                                                                                                                                                       |  |  |
| Resul                 | t Phas | e Statu                             | ıs Reg                                                                         | jister 2                                                                                           | (ST2)                                                                                                                               |                                                                                                                                                       |  |  |
| Track Number          |        |                                     |                                                                                |                                                                                                    |                                                                                                                                     |                                                                                                                                                       |  |  |
| Head Number           |        |                                     |                                                                                |                                                                                                    |                                                                                                                                     |                                                                                                                                                       |  |  |
| Sector Number         |        |                                     |                                                                                |                                                                                                    |                                                                                                                                     |                                                                                                                                                       |  |  |
| Bytes-Per-Sector Code |        |                                     |                                                                                |                                                                                                    |                                                                                                                                     |                                                                                                                                                       |  |  |
|                       | Resul  | Result Phas Result Phas Result Phas | Result Phase Statu Result Phase Statu Result Phase Statu Track N Head N Sector | Result Phase Status Reg<br>Result Phase Status Reg<br>Track Number<br>Head Number<br>Sector Number | Result Phase Status Register 0 Result Phase Status Register 1 Result Phase Status Register 2 Track Number Head Number Sector Number | Result Phase Status Register 0 (ST0) Result Phase Status Register 1 (ST1) Result Phase Status Register 2 (ST2) Track Number Head Number Sector Number |  |  |

1

#### 3.6.14 The RECALIBRATE Command

The RECALIBRATE command issues pulses that make the head of the selected drive step out until it reaches track 0.

#### **Command Phase**

| 7 | 6 | 5 | 4 | 3 | 2  | 1   | 0   |
|---|---|---|---|---|----|-----|-----|
| 0 | 0 | 0 | 0 | 0 | 1  | 1   | 1   |
| Χ | Х | Х | Х | Х | HD | DS1 | DS0 |

#### **Second Command Phase Byte**

See "Second Command Phase Byte" on page 79 for a description of the Drive Select (DS1,0) and Head Select (HD) bits.

#### **Execution Phase**

After the last command byte is issued, the Drive Busy bit for the selected drive is set in the Main Status Register (MSR). See bits 3-0 in "Main Status Register (MSR), Offset 100" on page 63.

The controller waits the Delay Before Processing time (see Table 3-25 on page 100) for the selected drive., and then becomes idle. See "Idle Phase" on page 71.

Then, the controller issues pulses until the TRK0 disk interface input signal becomes active or until the maximum number of RECALIBRATE step pulses have been issued.

Table 3-20 shows the maximum number of RECALli-BRATE step pulses that may be issued, depending on the RECALIBRATE Step Pulses (R255) bit, bit 0 in the second command phase byte of the MODE command (page 84), and the Extended Track Range (ETR) bit, bit 4 of the third command byte of the MODE command (page 84).

If the number of tracks on the disk drive exceeds the maximum number of RECALIBRATE step pulses, it may be necessary to issue another RECALIBRATE command.

TABLE 3-20. Maximum RECALIBRATE Step Pulses for Values of R255 and ETR

| R255 | ETR | Maximum Number of<br>RECALIBRATE Step Pulses |
|------|-----|----------------------------------------------|
| 0    | 0   | 85 (default)                                 |
| 1 0  |     | 255                                          |
| 0    | 1   | 3925                                         |
| 1    | 1   | 4095                                         |

The pulses actually occur while the controller is in the drive polling phase. See "Drive Polling Phase" on page 71.

An interrupt is generated after the TRKO signal is asserted, or after the maximum number of RECALI-BRATE step pulses is issued.

Software should ensure that the RECALIBRATE command is issued for only one drive at a time. This is because the drives are actually selected via the Digital Output Register (DOR), which can only select one drive at a time.

No command, except a SENSE INTERRUPT command, should be issued while a RECALIBRATE command is in progress.

#### **Result Phase**

None.

#### 3.6.15 The RELATIVE SEEK Command

The RELATIVE SEEK command issues STEP pulses that make the head of the selected drive step in or out a programmable number of tracks.

#### **Command Phase**

| 7                           | 6   | 5 | 4 | 3 | 2  | 1   | 0   |  |
|-----------------------------|-----|---|---|---|----|-----|-----|--|
| 0                           | DIR | 0 | 0 | 1 | 1  | 1   | 1   |  |
| Χ                           | Х   | Х | Х | Х | HD | DS1 | DS0 |  |
| Relative Track Number (RTN) |     |   |   |   |    |     |     |  |

### First Command Phase Byte, Opcode, Bit - 6 Step Direction DIR

This bit defines the step direction.

- 0 Step head out.
- 1 Step head in.

#### **Second Command Phase Byte**

See "Second Command Phase Byte" on page 79 for a description of the Drive Select (DS1,0) and Head Select (HD) bits.

### Third Command Phase Byte - Relative Track Number (RTN)

This value specifies how many tracks the head should step in or out from the current track.

#### **Execution Phase**

After the last command byte is issued, the Drive Busy bit for the selected drive is set in the Main Status Register (MSR). See bits 3-0 in Section 3.3.6 on page 63.

The controller waits the Delay Before Processing time (see Table 3-25 on page 100) for the selected drive., and then becomes idle. See "Idle Phase" on page 71.

Then, the controller enters the idle phase and issues RTN STEP pulses until the TRKO disk interface input signal becomes active or until the specified number (RTN) of STEP pulses have been issued. After the RELATIVE SEEK operation is complete, the controller generates an interrupt.

Software should ensure that the RELATIVE SEEK command is issued for only one drive at a time. This is because the drives are actually selected via the Digital Output Register (DOR), which can only select one drive at a time.

No command, except the SENSE INTERRUPT command, should be issued while a RELATIVE SEEK command is in progress.

#### **Result Phase**

None.

#### 3.6.16 The SCAN EQUAL, the SCAN LOW OR EQUAL and the SCAN HIGH OR EQUAL Commands

The scan commands compare data read from the disk with data sent from the microprocessor. This comparison produces a match for each scan command, as follows, and as shown in Table 3-21:

- SCAN EQUAL Disk data equals microprocessor data.
- SCAN LOW OR EQUAL Disk data is less than or equal to microprocessor data.
- SCAN HIGH OR EQUAL Disk data is greater than or equal to microprocessor data.

#### **Command Phase**

#### **SCAN EQUAL**

| 7            | 6                                | 5    | 4       | 3       | 2    | 1   | 0   |  |  |
|--------------|----------------------------------|------|---------|---------|------|-----|-----|--|--|
| MT           | MFM                              | SK   | 1       | 0       | 0    | 0   | 1   |  |  |
| IPS          | Х                                | Х    | Х       | Х       | HD   | DS1 | DS0 |  |  |
| Track Number |                                  |      |         |         |      |     |     |  |  |
| Head Number  |                                  |      |         |         |      |     |     |  |  |
|              | Sector Number                    |      |         |         |      |     |     |  |  |
|              |                                  | Byte | s-Per-S | Sector  | Code |     |     |  |  |
|              | End of Track (EOT) Sector Number |      |         |         |      |     |     |  |  |
|              | Bytes Between Sectors - Gap 3    |      |         |         |      |     |     |  |  |
|              |                                  | S    | ector S | Step Si | ze   |     |     |  |  |

#### **SCAN LOW OR EQUAL**

| 7   | 6                                | 5    | 4       | 3      | 2    | 1   | 0   |  |  |
|-----|----------------------------------|------|---------|--------|------|-----|-----|--|--|
| MT  | MFM                              | SK   | 1       | 1      | 0    | 0   | 1   |  |  |
| IPS | Х                                | Χ    | Х       | Х      | HD   | DS1 | DS0 |  |  |
|     | Track Number                     |      |         |        |      |     |     |  |  |
|     | Head Number                      |      |         |        |      |     |     |  |  |
|     | Sector Number                    |      |         |        |      |     |     |  |  |
|     |                                  | Byte | s-Per-S | Sector | Code |     |     |  |  |
|     | End of Track (EOT) Sector Number |      |         |        |      |     |     |  |  |
|     | Bytes Between Sectors - Gap 3    |      |         |        |      |     |     |  |  |
|     | Sector Step Size                 |      |         |        |      |     |     |  |  |
|     |                                  |      |         |        |      |     |     |  |  |

#### **SCAN HIGH OR EQUAL**

| 6                                | 5     | 4                                           | 3                                                                                      | 2                                                                                                                                  | 1                                                                                                                                                     | 0                                                                                                                                                                |  |  |  |
|----------------------------------|-------|---------------------------------------------|----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| MFM                              | SK    | 1                                           | 1                                                                                      | 1                                                                                                                                  | 0                                                                                                                                                     | 1                                                                                                                                                                |  |  |  |
| X                                | Χ     | Х                                           | Х                                                                                      | HD                                                                                                                                 | DS1                                                                                                                                                   | DS0                                                                                                                                                              |  |  |  |
| Track Number                     |       |                                             |                                                                                        |                                                                                                                                    |                                                                                                                                                       |                                                                                                                                                                  |  |  |  |
| Head Number                      |       |                                             |                                                                                        |                                                                                                                                    |                                                                                                                                                       |                                                                                                                                                                  |  |  |  |
| Sector Number                    |       |                                             |                                                                                        |                                                                                                                                    |                                                                                                                                                       |                                                                                                                                                                  |  |  |  |
|                                  | Byte  | s-Per-S                                     | Sector                                                                                 | Code                                                                                                                               |                                                                                                                                                       |                                                                                                                                                                  |  |  |  |
| End of Track (EOT) Sector Number |       |                                             |                                                                                        |                                                                                                                                    |                                                                                                                                                       |                                                                                                                                                                  |  |  |  |
| Bytes Between Sectors - Gap 3    |       |                                             |                                                                                        |                                                                                                                                    |                                                                                                                                                       |                                                                                                                                                                  |  |  |  |
| Sector Step Size                 |       |                                             |                                                                                        |                                                                                                                                    |                                                                                                                                                       |                                                                                                                                                                  |  |  |  |
|                                  | MFM X | MFM SK X X  S  Bytes  End of Trac  Bytes Be | MFM SK 1  X X X  Track N  Head N  Sector  Bytes-Per-S  End of Track (EO  Bytes Between | MFM SK 1 1  X X X X X  Track Number  Head Number  Sector Number  Bytes-Per-Sector  End of Track (EOT) Sector  Bytes Between Sector | MFM SK 1 1 1  X X X X X HD  Track Number  Head Number  Sector Number  Bytes-Per-Sector Code  End of Track (EOT) Sector Nu  Bytes Between Sectors - Ga | MFM SK 1 1 1 0  X X X X HD DS1  Track Number  Head Number  Sector Number  Bytes-Per-Sector Code  End of Track (EOT) Sector Number  Bytes Between Sectors - Gap 3 |  |  |  |

### First through Eighth Command Phase Bytes - All Scan Commands

See READ DATA command for a description of the first eight command phase bytes.

#### Ninth Command Phase Byte, Sector Step Size

During execution, the value of this byte is added to the current sector number to determine the next sector to read.

#### **Execution Phase**

The most significant bytes of each sector are compared first. If wildcard mode is enabled in bit 4 of the fourth command phase byte in the MODE command (page 85), an FF (hex) from either the disk or the microprocessor always causes a match.

After each sector is read, if there is no match, the next sector is read. The next sector is the current sector number plus the Sector Step Size specified in the ninth command phase byte.

The scan operation continues until the condition is met, the End of Track (EOT) is reached or the Terminal Count (TC) signal becomes active.

Read error conditions during scan commands are the same as read error conditions during the execution phase of the READ DATA command. See page 89.

If the Skip Control (SK) bit is set to 1, sectors with deleted data marks are ignored.

If all sectors read are skipped, the command terminates with bit 3 of ST2 set to 1, i.e., disk data equals microprocessor data.

#### **Result Phase**

| 7 | 6                                    | 5       | 4       | 3      | 2       | 1     | 0 |  |  |
|---|--------------------------------------|---------|---------|--------|---------|-------|---|--|--|
|   | Resu                                 | lt Phas | e Statu | ıs Reg | ister 0 | (ST0) |   |  |  |
|   | Result Phase Status Register 1 (ST1) |         |         |        |         |       |   |  |  |
|   | Result Phase Status Register 2 (ST2) |         |         |        |         |       |   |  |  |
|   | Track Number                         |         |         |        |         |       |   |  |  |
|   |                                      |         | Head N  | Numbe  | r       |       |   |  |  |
|   | Sector Number                        |         |         |        |         |       |   |  |  |
|   | Bytes-Per-Sector Code                |         |         |        |         |       |   |  |  |

Table 3-21 shows how all the scan commands affect bits 3,2 of the Status 2 (ST2) result phase register. See "Result Phase Status Register 2 (ST2)" on page 73.

TABLE 3-21. The Effect of Scan Commands on the ST2 Register

| Command                  | Result Ph<br>Registe     | Condition                    |                                                                                                  |
|--------------------------|--------------------------|------------------------------|--------------------------------------------------------------------------------------------------|
| Command                  | Bit 3 - Scan<br>Satis ed | Bit 2 - Scan<br>Not Satis ed | Condition                                                                                        |
| SCAN<br>EQUAL            | 1<br>0                   | 0<br>1                       | Disk = μP<br>Disk ≠ μP                                                                           |
| SCAN LOW<br>OR EQUAL     | 1<br>0<br>0              | 0<br>0<br>1                  | $\begin{array}{l} \text{Disk} = \mu P \\ \text{Disk} < \mu P \\ \text{Disk} > \mu P \end{array}$ |
| SCAN<br>HIGH<br>OR EQUAL | 1<br>0<br>0              | 0<br>0<br>1                  | $\begin{array}{l} \text{Disk} = \mu P \\ \text{Disk} > \mu P \\ \text{Disk} < \mu P \end{array}$ |

#### 3.6.17 The SEEK Command

The SEEK command issues pulses of the STEP signal to the selected drive, to move it in or out until the desired track number is reached.

Software should ensure that the SEEK command is issued for only one drive at a time. This is because the drives are actually selected via the Digital Output Register (DOR), which can only select one drive at a time. See "Digital Output Register (DOR), Offset 010" on page 60.

No command, except a SENSE INTERRUPT command, should be issued while a SEEK command is in progress.

#### **Command Phase**

When bit 2 of the second command phase byte (ETR) in the MODE command is set to 1, the track number is stored as a 12-bit value. See "Bit 0 - Extended Track Range (ETR)" on page 84.

In this case, a fourth command byte should be written in the command phase to hold the Most Significant Nibble (MSN), i.e., the four most significant bits, of the number of the track to seek. Otherwise (ETR bit in MODE is 0), this command phase byte is not required. and, only three command bytes should be written.

After the last command byte is issued, the Drive Busy bit for the selected drive is set in the Main Status Register (MSR). See bits 3-0 in Section 3.3.6 on page 63.

The controller waits the Delay Before Processing time (see Table 3-25 on page 100) for the selected drive, before issuing the first STEP pulse. After waiting the Delay Before Processing time, the controller becomes idle. See "Idle Phase" on page 71.

| 7   | 6                       | 5       | 4    | 3 | 2  | 1   | 0   |  |
|-----|-------------------------|---------|------|---|----|-----|-----|--|
| 0   | 0                       | 0       | 0    | 1 | 1  | 1   | 1   |  |
| Х   | Х                       | Х       | Х    | Х | HD | DS1 | DS0 |  |
|     | Number of Track to Seek |         |      |   |    |     |     |  |
| MSN | of Tra                  | ck # to | Seek |   |    |     |     |  |

#### **Second Command Phase Byte**

See READ DATA command for a description of these bits.

#### Third Command Phase Byte, Number of Track to Seek

The value in this byte is the number of the track to seek.

#### Fourth Command Phase Byte, Bits 7-4 - MSN of Track Number

If the track number is stored as a 12-bit value, these bits contain the Most Significant Nibble (MSN), i.e., the four most significant bits, of the number of the track to seek. Otherwise (the ETR bit in the MODE command is 0), this command phase byte is not required.

#### **Execution Phase**

During the execution phase of the SEEK command, the track number to seek to is compared with the present track number. The controller determines how many STEP pulses to issue and the DIR disk interface output signal indicates which direction the head should move.

The SEEK command issues step pulses while the controller is in the drive polling phase. The step pulse rate is determined by the value programmed in the second command phase byte of the SPECIFY command.

An interrupt is generated one step pulse period after the last step pulse is issued. A SENSE INTERRUPT command should be issued to determine the cause of the interrupt.

#### **Result Phase**

None.

### 3.6.18 The SENSE DRIVE STATUS Command

The SENSE DRIVE STATUS command indicates which drive and which head are selected, whether or not the head is at track 0 and whether or not the track is write protected in result phase Status register 3 (ST3). See "Result Phase Status Register 3 (ST3)" on page 74. This command does not generate an interrupt.

#### **Command Phase**

| 7 | 6 | 5 | 4 | 3 | 2  | 1   | 0   |
|---|---|---|---|---|----|-----|-----|
| 0 | 0 | 0 | 0 | 0 | 1  | 0   | 0   |
| Х | Х | Х | Х | Х | HD | DS1 | DS0 |

See READ DATA command for a description of these bits.

#### **Execution Phase**

Disk drive status information is detected and reported.

#### **Result Phase**

| 7 | 6     | 5       | 4      | 3   | 2        | 1     | 0 |
|---|-------|---------|--------|-----|----------|-------|---|
|   | Resul | t Phase | Status | Reg | gister 3 | (ST3) |   |

See "Result Phase Status Register 3 (ST3)" on page 74.

### 3.6.19 The SENSE INTERRUPT Command

The SENSE INTERRUPT command returns the cause of an interrupt that is caused by the change in status of any disk drive.

If a SENSE INTERRUPT command is issued when no interrupt is pending it is treated as an invalid command.

#### When to Issue SENSE INTERRUPT

The SENSE INTERRUPT command is issued to detect either of the following causes of an interrupt:

- The FDC became ready during the drive polling phase for an internally selected drive. See "Drive Polling Phase" on page 71. This can occur only after a hardware or software reset.
- A SEEK, RELATIVE SEEK or RECALIBRATE command terminated.

Interrupts caused by these conditions are cleared after the first result byte has been read. Use the Interrupt Code (IC) (bits 7,6) and SEEK End bits (bit 5) of result phase Status register 0 (ST0) to identify the cause of these interrupts. See page 72 and Table 3-22.

TABLE 3-22. Interrupt Causes Reported by SENSE INTERRUPT

| _ | Bits of<br>ST0 |   | Interrupt Cause                                            |
|---|----------------|---|------------------------------------------------------------|
| 7 | 6              | 5 |                                                            |
| 1 | 1              | 0 | FDC became ready during drive polling mode.                |
|   |                |   | SEEK, RELATIVE SEEK or RECALIBRATE not completed.          |
| 0 | 0              | 1 | SEEK, RELATIVE SEEK or RECALIBRATE terminated normally.    |
| 0 |                |   | SEEK, RELATIVE SEEK or RELCALIBRATE terminated abnormally. |

# When SENSE INTERRUPT is not Necessary

Interrupts that occur during most command operations do not need to be identified by the SENSE INTERRUPT. The microprocessor can identify them by checking the Request for Master (RQM) bit (bit 7) of the Main Status Register (MSR). See page "Bit 7 - Request for Master (RQM)" on page 64.

It is not necessary to issue a SENSE INTERRUPT command to detect the following causes of Interrupts:

- The result phase of any of the following commands started:
  - READ DATA, READ DELETED DATA, READ A TRACK, READ ID
  - WRITE DATA, WRITE DELETED
  - FORMAT TRACK
  - SCAN EQUAL, SCAN EQUAL OR LOW, SCAN EQUAL OR HIGH
  - VERIFY
- Data is being transferred in non-DMA mode, during the execution phase of some command.

Interrupts caused by these conditions are cleared automatically, or by reading or writing information from or to the Data Register (FIFO).

#### **Command Phase**

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---|---|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |

#### **Execution Phase**

Status of interrupt is reported.

#### **Result Phase**

When bit 2 of the second command phase byte (ETR) in the MODE command is set to 1, the track number is stored as a 12-bit value. See "Bit 0 - Extended Track Range (ETR)" on page 84.

In this case, a third result byte should be read to hold the Most Significant Nibble (MSN), i.e., the four most significant bits, of the number of the current track.

Otherwise (ETR bit in MODE is 0), this command phase byte is not required. and, only two result phase bytes should be read.

| ,                                    | 0     | 5      | 4 | 3 | 2 |  | U |
|--------------------------------------|-------|--------|---|---|---|--|---|
| Result Phase Status Register 0 (ST0) |       |        |   |   |   |  |   |
| Byte of Present Track Number (PTR)   |       |        |   |   |   |  |   |
|                                      | MSN c | of PTR |   |   |   |  |   |

#### First Command Phase Byte, Result Phase Status Register 0

See "Result Phase Status Register 0 (ST0)" on page 71.

#### Second Command Phase Byte, Present Track Number (PTR)

The value in this byte is the number of the current track.

#### Fourth Command Phase Byte, Bits 7-4 - MSN of Track Number

If the track number is stored as a 12-bit value, these bits contain the Most Significant Nibble (MSN), i.e., the four most significant bits, of the number of the track to seek.

Otherwise (the ETR bit in the MODE command is 0), this result phase byte is not required.

#### 3.6.20 The SET TRACK Command

This command is used to verify (read) or change (write) the number of the present track.

This command could be useful for recovery from disk tracking errors, where the true track number could be read from the disk using the READ ID command, and used as input to the SET TRACK command to correct the Present Track number (PTR) stored internally.

Termination of this command does not generate an interrupt

#### **Command Phase**

When bit 2 of the second command phase byte (ETR) in the MODE command is set to 1, the track number is stored as a 12-bit value. See "Bit 0 - Extended Track Range (ETR)" on page 84.

In this case, issue SET TRACK twice - once for the Most Significant Byte (MSB) of the number of the current track and once for the Least Significant Byte (LSB).

Otherwise (ETR bit in MODE is 0), issue SET TRACK only once, with bit 2 (MSB) of the second command phase byte set to 0.

|                      | 7                                  | 6   | 5 | 4 | 3 | 2 | 1 | 0   |
|----------------------|------------------------------------|-----|---|---|---|---|---|-----|
|                      | 0                                  | WNR | 1 | 0 | 0 | 0 | 0 | 1   |
| 0 0 1 1 0 MSB DS1 DS |                                    |     |   |   |   |   |   | DS0 |
|                      | Byte of Present Track Number (PTR) |     |   |   |   |   |   |     |

#### First Command Phase Byte, Bit 6 - Write Track Number (WNR)

0 - Read the existing track number.

The result phase byte already contains the track number, and the third byte in the command phase is a dummy byte.

1 - Change the track number by writing a new value to the result phase byte.

#### **Second Command Phase Byte**

#### Bits 1,0 - Logical Drive Select (DS1,0)

These bits indicate which logical drive is active. See "Bits 1,0 - Logical Drive Select (DS1,0)" on page 79.

- 00 Drive 0 is selected.
- 01 Drive 1 is selected.
- 10 If four drives are supported, or drives 2 and 0 are exchanged, drive 2 is selected.
- 11 If four drives are supported, drive 3 is selected.

#### Bit 2 - Most Signi cant Byte (MSB)

This bit, together with bits 1,0, determines the byte to read or write. See also Table 3-23.

- 0 Least significant byte of the track number.
- 1 Most significant byte of the track number.

TABLE 3-23. De ning Bytes to Read or W rite Using SET TRACK

| MSB | DS1 | DS0 | Duta to Dood on White |  |  |
|-----|-----|-----|-----------------------|--|--|
| 2   | 1   | 0   | Byte to Read or Write |  |  |
| 0   | 0   | 0   | Drive 0 (LSB)         |  |  |
| 1   | 0   | 0   | Drive 0 (MSB)         |  |  |
| 0   | 0   | 1   | Drive 1 (LSB)         |  |  |
| 1   | 0   | 1   | Drive 1 (MSB)         |  |  |
| 0   | 1   | 0   | Drive 2 (LSB)         |  |  |
| 1   | 1   | 0   | Drive 2 (MSB)         |  |  |
| 0   | 1   | 1   | Drive 3 (LSB)         |  |  |
| 1   | 1   | 1   | Drive 3 (MSB)         |  |  |

#### **Execution Phase**

Internal register is read or written.

#### **Result Phase**

7 6 5 4 3 2 1 0

Byte of Present Track Number(PTR)

This byte is one byte of the track number that was read or written, depending on the value of WNR in the first command byte.

#### 3.6.21 The SPECIFY Command

The SPECIFY command sets initial values for the following time periods:

- The delay before command processing starts, formerly called Motor On Time (MNT)
- The delay after command processing terminates, formerly called Motor Off Time (MFT)
- The interval step rate time.

The FDC uses the Digital Output Register (DOR) to enable the drive and motor select signals. See also, "Digital Output Register (DOR), Offset 010" on page 60.

The delays may be used to support the  $\mu PD765$ , i.e., to insert delays from selection of a drive motor until a read or write operation starts, and from termination of a command until the drive motor is no longer selected, respectively.

The parameters used by this command are undefined after power up, and are unaffected by any reset. Therefore, software should always issue a SPECIFY command as part of an initialization routine to initialize these parameters.

Termination of this command does not generate an interrupt.

#### **Command Phase.**

| 7    | 6                                       | 5 | 4 | 3 | 2 | 1 | 0 |  |
|------|-----------------------------------------|---|---|---|---|---|---|--|
| 0    | 0                                       | 0 | 0 | 0 | 0 | 1 | 1 |  |
| Step | Step Rate Time (SRT) Delay After Proces |   |   |   |   |   |   |  |
|      | Delay Before Processing                 |   |   |   |   |   |   |  |

#### **Second Command Phase Byte**

#### Bits 3-0 - Delay After Processing Factor

These bits specify a factor that is multiplied by a constant to determine the delay after command processing ends, i.e., from termination of a command until the drive motor is no longer selected.

The value of the Motor Timer Values (TMR) bit (bit 7) of the second command phase byte in the MODE command determines which group of constants and delay ranges to use. See "Bit 7 - Motor Timer Values (TMR)" on page 84.

The specific constant that will be multiplied by this factor to determine the actual delay after processing for each data transfer rate is shown in Table 3-24.

Use the smallest possible value for this factor, except 0, i.e., 1. If this factor is 0, the value 16 is used.

TABLE 3-24. Constant Multipliers for Delay After Processing Factor and Delay Ranges

| Data Transfer | Bit 7 of M          | ODE (TMR) = 0          | Bit 7 of MC         | Bit 7 of MODE (TMR) = 1 |  |  |
|---------------|---------------------|------------------------|---------------------|-------------------------|--|--|
| Rate (bps)    | Constant Multiplier | Permitted Range (msec) | Constant Multiplier | Permitted Range (msec)  |  |  |
| 1 M           | 8                   | 8 -128                 | 512                 | 512 - 8192              |  |  |
| 500 K         | 16                  | 16 - 256               | 512                 | 512 - 8192              |  |  |
| 300 K         | 80 / 3              | 26.7 - 427             | 2560 / 3            | 853 - 13653             |  |  |
| 250 K         | 32                  | 32 - 512               | 1024                | 1024 -16384             |  |  |

TABLE 3-25. Constant Multipliers for Delay Before Processing Factor and Delay Ranges

| Data Transfer | Bit 7 of M          | ODE (TMR) = 0          | Bit 7 of MO         | DE (TMR) = 1              |  |  |
|---------------|---------------------|------------------------|---------------------|---------------------------|--|--|
| Rate (bps)    | Constant Multiplier | Permitted Range (msec) | Constant Multiplier | Permitted Range<br>(msec) |  |  |
| 1 M           | 1                   | 1 -128                 | 32                  | 32 - 4096                 |  |  |
| 500 K         | 1                   | 1 -128                 | 32                  | 32 - 4096                 |  |  |
| 300 K         | 10 / 3              | 3.3 - 427              | 160 / 3             | 53 - 6827                 |  |  |
| 250 K         | 4                   | 4 - 512                | 64                  | 64 - 8192                 |  |  |

#### Bits 7-4 - STEP Time Interval Value (SRT)

These bits specify a value that is used to calculate the time interval between successive STEP signal pulses during a SEEK, IMPLIED SEEK, RECALIBRATE, or RELATIVE SEEK command.

Table 3-26 shows how this value is used to calculate the actual time interval.

TABLE 3-26. STEP Time Interval Calculation

| Data Transfer<br>Rate (bps) | Calculation of<br>Time Interval | Permitted<br>Range (msec) |
|-----------------------------|---------------------------------|---------------------------|
| 1 M                         | (16 – SRT) / 2                  | 0.5 - 8                   |
| 500 K                       | (16 – SRT)                      | 1 - 16                    |
| 300 K                       | (16 – SRT) x 1.67               | 1.67 - 26.7               |
| 250 K                       | (16 – SRT) x 2                  | 2 - 32                    |

#### **Third Command Phase Byte**

#### Bit 0 - DMA

This bit selects the data transfer mode in the execution phase of a read, write, or scan operation.

Data can be transferred between the microprocessor and the controller during execution in DMA mode or in non-DMA mode, i.e., interrupt transfer mode or software polling mode.

See "Execution Phase" on page 68 for a description of these modes.

- 0 DMA mode is selected.
- 1 Non-DMA mode is selected.

#### Bits 3-0 - Delay Before Processing Factor

These bits specify a factor that is multiplied by a constant to determine the delay before command processing starts, i.e., from selection of a drive motor until a read or write operation starts.

The value of the Motor Timer Values (TMR) bit (bit 7) of the second command phase byte in the MODE command determines which group of constants and delay ranges to use. See "Bit 7 - Motor Timer Values (TMR)" on page 84.

The specific constant that will be multiplied by this factor to determine the actual delay before processing for each data transfer rate is shown in Table 3-25.

Use the smallest possible value for this factor, except 0, i.e., 1. If this factor is 0, the value128 is used.

#### **Execution Phase**

Internal registers are written.

#### **Result Phase**

None.

#### 3.6.22 The VERIFY Command

The VERIFY command verifies the contents of data and/or address fields after they have been formatted or written.

VERIFY reads logical sectors containing a normal data Address Mark (AM) from the selected drive, without transferring the data to the host.

The TC signal cannot terminate this command since no data is transferred. Instead, VERIFY simulates a TC signal by setting the Enable Count (EC) bit to1. In this case, VERIFY terminates when the number of sectors read equals the number of sectors to read, i.e., Sectors to read Count (SC). If SC = 0 then 256 sectors will be verified.

When EC is 0, VERIFY ends when the End of the Track (EOT) sector number equals the number of the sector checked. In this case, the ninth command phase byte is not needed and should be set to FF (hex).

Table 3-27 shows how different values for the VERI-FY parameters affect termination.

#### **Command Phase**

| 7  | 6                                | 5       | 4        | 3      | 2       | 1   | 0   |  |  |
|----|----------------------------------|---------|----------|--------|---------|-----|-----|--|--|
| MT | MFM                              | SK      | 1        | 0      | 1       | 1   | 0   |  |  |
| EC | Х                                | Χ       | X        | Х      | HD      | DS1 | DS0 |  |  |
|    | Track Number                     |         |          |        |         |     |     |  |  |
|    | Head Number                      |         |          |        |         |     |     |  |  |
|    |                                  | 5       | Sector   | Numbe  | er      |     |     |  |  |
|    |                                  | Byte    | s-Per-S  | Sector | Code    |     |     |  |  |
|    | End of Track (EOT) Sector Number |         |          |        |         |     |     |  |  |
|    | Bytes Between Sectors - Gap 3    |         |          |        |         |     |     |  |  |
|    | ;                                | Sectors | s to rea | ad Cou | int (SC | )   |     |  |  |

#### **First Command Phase Byte**

See READ DATA command for a description of these bits starting on page 88.

#### **Second Command Phase Byte**

### Bits 2-0 - Drive Select (DS1,0) and Head (HD) Select

See the description of the Drive Select bits (DS1,0) and the Head (HD) select bit in the READ DATA command, starting on page 89.

#### Bit 7 - Enable Count Control (EC)

This bit controls whether the End of Track sector number or the Sectors to read Count (SC) triggers termination of the VERIFY command. See also. Table 3-27.

 Terminate VERIFY when the number of the last sector read equals the End of Track (EOT) sector number.

The ninth command phase byte, i.e., Sectors to read Count (SC), is not needed and should be set to FF (hex).

 1 - Terminate VERIFY when number of sectors read equals the number of sectors to read, i.e., Sectors to read Count (SC).

#### **Third through Eighth Command Phase Bytes**

See "The READ DATA Command" on page 88.

Always set the End of Track (EOT) sector number to the number of the last sector to be checked on each side of the disk. If EOT is greater than the number of sectors per side, the command terminates with an error and no useful Address Mark (AM) or CRC data is returned.

#### Ninth Command Phase Byte, Sectors to Read Count (SC)

This byte specifies the number of sectors to read. If the Enable Count (EC) control bit (bit 7) of the second command byte is 0, this byte is not needed and should be set to the value FF (hex).

#### **Execution Phase**

Data is read from the disk, as the controller checks for valid address marks in the address and data fields.

This command is identical to the READ DATA command, except that it does not transfer data during the execution phase. See "The READ DATA Command" on page 88.

If the Multi-Track (MT) parameter is 1 and SC is greater than the number of remaining formatted sectors on side 0, verification continues on side 1 of the disk.

#### Result Phase

|   | 1                                    | ь      | 5      | 4       | 3      | 2       | 1     | U |
|---|--------------------------------------|--------|--------|---------|--------|---------|-------|---|
|   |                                      | Result | t Phas | e Statu | ıs Reg | ister 0 | (ST0) |   |
|   |                                      | Result | t Phas | e Statu | ıs Reg | ister 1 | (ST1) |   |
|   | Result Phase Status Register 2 (ST2) |        |        |         |        |         |       |   |
|   | Track Number                         |        |        |         |        |         |       |   |
|   |                                      |        |        | Head N  | Numbe  | r       |       |   |
|   | Sector Number                        |        |        |         |        |         |       |   |
|   | Bytes-Per-Sector Code                |        |        |         |        |         |       |   |
| _ |                                      |        |        |         |        |         |       |   |

Table 3-27 shows how different conditions affect the termination status.

### **TABLE 3-27. VERIFY Command Termination Conditions**

| МТ | EC | Sector Count (SC) or<br>End of Track (EOT) Value                  | Termination<br>Status   |
|----|----|-------------------------------------------------------------------|-------------------------|
| 0  | 0  | SC should be FF (hex)<br>EOT $\leq$ Sectors per Side <sup>a</sup> | No Errors               |
|    |    | SC should be FF (hex)<br>EOT > Sectors per Side                   | Abnormal<br>Termination |
| 0  | 1  | $SC \le Sectors per Side$<br>and<br>$SC \le EOT$                  | No Errors               |
|    |    | SC > Sectors Remaining <sup>b</sup> or SC > EOT                   | Abnormal<br>Termination |
| 1  | 0  | SC should be FF (hex)<br>EOT ≤ Sectors per Side                   | No Errors               |
|    |    | SC should be FF (hex)<br>EOT > Sectors per Side                   | Abnormal<br>Termination |
| 1  | 1  | $SC \le Sectors per Side$<br>and<br>$SC \le EOT$                  | No Errors               |
|    |    | SC ≤ (EOT x 2)<br>and<br>EOT ≤ Sectors per Side                   | No Errors               |
|    |    | SC > (EOT x 2)                                                    | Abnormal<br>Termination |

- a. The number of formatted sectors per side of the disk.
- b. The number of formatted sectors left, which can be read, including side 1 of the disk if MT is 1.

#### 3.6.23 The VERSION Command

The VERSION command returns the version number of the current Floppy Disk Controller (FDC).

#### **Command Phase**

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---|---|---|---|---|---|---|
| 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |

#### **Execution Phase**

None.

#### **Result Phase**

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---|---|---|---|---|---|---|
| 1 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |

The result phase byte returns a value of 90 (hex) for an FDC that is compatible with the 82077.

Other controllers, i.e., the DP8473 and other NEC765 compatible controllers, return a value of 80 hex (invalid command).

#### 3.6.24 The WRITE DATA Command

The WRITE DATA command receives data from the host and writes logical sectors containing a normal data Address Mark (AM) to the selected drive.

This command is like the READ DATA command, except that the data is transferred from the microprocessor to the controller instead of the other way around.

#### **Command Phase**

| 7   | 7 6 5 4 3 2 1 0                  |      |         |        |        |  |  |  |
|-----|----------------------------------|------|---------|--------|--------|--|--|--|
| MT  | MT MFM 0 0 0 1 0 1               |      |         |        |        |  |  |  |
| IPS | IPS X X X X HD DS1 DS0           |      |         |        |        |  |  |  |
|     | Track Number                     |      |         |        |        |  |  |  |
|     |                                  |      | Head N  | Numbe  | r      |  |  |  |
|     | Sector Number                    |      |         |        |        |  |  |  |
|     |                                  | Byte | s-Per-S | Sector | Code   |  |  |  |
|     | End of Track (EOT) Sector Number |      |         |        |        |  |  |  |
|     | Bytes Between Sectors - Gap 3    |      |         |        |        |  |  |  |
|     |                                  | Data | Lengtl  | n (Obs | olete) |  |  |  |

See the READ DATA command starting on page 88 for a description of these bytes.

The controller waits the Delay Before Processing time before starting execution.

If implied seeks are enabled, i.e., IPS in the second command phase byte is 1, the operations performed by SEEK and SENSE INTERRUPT commands are performed (without these commands being issued).

#### **Execution Phase**

Data is transferred from the system to the controller via DMA or non-DMA modes and written to the disk. See "Execution Phase" starting on page 68 for a description of these data transfer modes.

The controller starts the data separator and waits for it to find the address field of the next sector. The controller compares the address ID (track number, head number, sector number, bytes-per-sector code) with the ID specified in the command phase.

If there is no match, the controller waits to find the next sector address field. This process continues until the desired sector is found. If an error condition occurs, the Interrupt Control (IC) bits (bits 7,6) in STO are set to abnormal termination, and the controller enters the result phase. See "Bits 7,6 - Interrupt Code (IC)" on page 72

Possible errors are:

The microprocessor aborted the command by writing to the FIFO.

If there is no disk in the drive, the controller gets stuck. The microprocessor must then write a byte to the FIFO to advance the controller to the result phase.

 Two pulses of the INDEX signal were detected since the search began, and no valid ID was found.

If the track address differs, either the Wrong Track bit (bit 4) or the Bad Track bit (bit 1) (if the track address is FF hex) is set in result phase Status register 2 (ST2). See Section 3.5.3 on page 73.

If the head number, sector number or bytes-persector code did not match, the Missing Data bit (bit 2) is set in result phase Status register 1 (ST1).

If the Address Mark (AM) is not found, the Missing Address Mark bit (bit 0) is set in ST1.

Section 3.5.2 on page 72 describes the bits of ST1.

- A CRC error was detected in the address field. In this case the CRC Error bit (bit 5) is set in ST1.
- The controller detected an active the Write Protect (WP) disk interface input signal, and set bit 1 of ST1 to 1.

If the correct address field is found, the controller waits for all (conventional drive mode) or part (perpendicular drive mode) of gap 2 to pass. See Figure 3-18 on page 82. The controller then writes the preamble field, Address Marks (AM) and data bytes to the data field. The microprocessor transfers the data bytes to the controller.

After writing the sector, the controller reads the next logical sector, unless one or more of the following termination conditions occurs:

- The DMA controller asserted the Terminal Count (TC) signal to indicate that the operation terminated. The Interrupt Code (IC) bits (bits 7,6) in ST0 are set to normal termination (00). See page 72.
- The last sector address (of side 1, if the Multi-Track enable bit (MT) was set to 1) was equal to the End of Track sector number. The End of Track bit (bit 7) in ST1 is set. The IC bits in ST0 are set to abnormal termination (01). This is the expected condition during non-DMA transfers.
- Overrun error. The Overrun bit (bit 4) in ST1 is set.
  The Interrupt Code (IC) bits (bits 7,6) in ST0 are
  set to abnormal termination (01). If the microprocessor cannot service a transfer request in time,
  the last correctly written byte is written to the disk.

If the Multi-Track (MT) bit was set in the opcode command byte, and the last sector of side 0 has been transferred, the controller continues with side 1.

#### **Result Phase**

Upon terminating the execution phase of the WRITE DATA command, the controller asserts IRQ6, indicating the beginning of the result phase. The microprocessor must then read the result bytes from the FIFO.

| <br>0 | Э      | 4       | 3      | 2       | ı     | U |
|-------|--------|---------|--------|---------|-------|---|
| Resul | t Phas | e Statı | us Reg | ister 0 | (ST0) |   |
| Resul | t Phas | e Statı | us Reg | ister 1 | (ST1) |   |
| Resul | t Phas | e Statı | us Reg | ister 2 | (ST2) |   |
|       | -      | Track I | Numbe  | r       |       |   |
|       | l      | Head I  | Numbe  | r       |       |   |
|       | S      | Sector  | Numbe  | er      |       |   |
|       | Bytes  | s-Per-S | Sector | Code    |       |   |

The values that are read back in the result bytes are shown in Table 3-18 on page 91. If an error occurs, the result bytes indicate the sector read when the error occurred.

### 3.6.25 The WRITE DELETED DATA Command

The WRITE DELETED DATA command receives data from the host and writes logical sectors containing a deleted data Address Mark (AM) to the selected drive.

This command is identical to the WRITE DATA command, except that a deleted data AM, instead of a normal data AM, is written to the data field.

#### **Command Phase**

| 7   | 7 6 5 4 3 2 1                    |      |        |        |        |     |     |
|-----|----------------------------------|------|--------|--------|--------|-----|-----|
| MT  | MT MFM 0 0 1 0 0                 |      |        |        |        |     |     |
| IPS | X                                | Х    | Х      | Х      | HD     | DS1 | DS0 |
|     | Track Number                     |      |        |        |        |     |     |
|     | Head Number                      |      |        |        |        |     |     |
|     | Sector Number                    |      |        |        |        |     |     |
|     | Bytes-Per-Sector Code            |      |        |        |        |     |     |
|     | End of Track (EOT) Sector Number |      |        |        |        |     |     |
|     | Bytes Between Sectors - Gap 3    |      |        |        |        |     |     |
|     |                                  | Data | Length | n (Obs | olete) |     |     |

See the READ DATA command starting on page 88 and WRITE DATA on page 103 for a description of these bytes.

#### **Execution Phase**

Data is transferred from the system to the controller in DMA or non-DMA modes, and written to the disk. See "Execution Phase" starting on page 68 for a description of these data transfer modes.

#### **Result Phase**

Upon terminating the execution phase of the WRITE DATA command, the controller asserts IRQ6, indicating the beginning of the result phase. The microprocessor must then read the result bytes from the FIFO.

| 1 | 6     | 5      | 4       | 3      | 2       | 1     | U |
|---|-------|--------|---------|--------|---------|-------|---|
|   | Resul | t Phas | e Statu | ıs Reg | ister 0 | (ST0) |   |
|   | Resul | t Phas | e Statu | ıs Reg | ister 1 | (ST1) |   |
|   | Resul | t Phas | e Statu | ıs Reg | ister 2 | (ST2) |   |
|   |       |        | Track N | Numbe  | r       |       |   |
|   |       |        | Head N  | Numbe  | r       |       |   |
|   |       | 9      | Sector  | Numbe  | er      |       |   |
|   |       | Byte   | s-Per-S | Sector | Code    |       |   |
|   |       |        |         |        |         |       |   |

The values that are read back in the result bytes are shown in Table 3-18 on page 91. If an error occurs, the result bytes indicate the sector read when the error occurred.

# 3.7 EXAMPLE OF A FOUR-DRIVE CIRCUIT USING THE PC87338/PC97338

Figure 3-19 shows one implementation of a four-drive circuit. Refer to Table 3-2 on page 60 to see how to encode the drive and motor bits for this configuration.



FIGURE 3-19. PC87338/PC97338 Four Floppy Disk Drive Circuit

#### 4.0 Parallel Port

#### 4.1 INTRODUCTION

The Parallel Port is a communications device that enables transfer of parallel data bytes between the system and an external device. Originally designed to output data to an external printer, the use of this port has grown to include additional capabilities such as bidirectional communications, increased data rates and additional applications (such as network adaptors). Despite additional parallel port capability, backward compatability is maintained to support existing hardware and software.

#### 4.1.1 The Chip Parallel Port Modes

This parallel interface fully supports the IEEE 1284 standard and EPP 1.7 modes of parallel communications, in both Legacy or Plug and Play configurations. It supports two Standard Parallel Port (SPP) modes of operation for parallel printer ports (as found in the IBM PC-AT, PS/2 and Centronics systems), two Enhanced Parallel Port (EPP) modes of operation, and one Extended Capabilities Port (ECP) mode.

The parallel port output pins are protected against potential damage from connecting an unpowered port to a powered-up printer.

The functional modes supported by the Chip parallel port are as follows:

- The Standard Parallel Port (SPP) configuration supports two operation modes:
  - In Compatible SPP mode the port is write-only (for data). Data transfers are software-controlled, accompanied by status and control handshake lines.
  - In Extended SPP mode, the parallel port becomes a read/write port, transferring a full data byte in both directions.

In these modes, low data rates are achieved (several hundred bytes per second).

- The Enhanced Parallel Port (EPP) configuration supports two modes that offer higher bi-directional throughput and more efficient hardware-based handling.
  - The EPP revision 1.7 mode has the above advantages but lacks a comprehensive handshaking scheme to ensure data transfer integrity between communicating devices with dissimilar data rates.

The IEEE 1284 standard establishes a widely accepted handshake and transfer protocol that ensures transfer data integrity. This standard is met by all modes in this module except the EPP revision 1.7 mode.

- EPP revision 1.9 mode offers data transfer enhancement, while meeting the IEEE 1284 standard.
- The Extended Capabilities Port (ECP) mode extends the port capabilities beyond EPP modes by adding a bi-directional 16-level FIFO with threshold interrupts, for PIO and DMA operation. In this mode, the device becomes a hardware state-machine with highly efficient hardware real-time data transfer control.

#### 4.1.2 Device Configuration

The functional mode of the parallel port is determined by setting the appropriate bits in the system configuration registers:

All parallel port functions are enabled by setting bit 0 of the system Function Enable Register (FER) to 1.

SPP is the default mode. In this mode, bit 7 of the PTR register selects Compatible SPP mode when it is 0 and Extended SPP mode when it is 1.

If bit 0 of the Parallel Port Control Register (PCR) is set to 1, the device enters EPP mode. Bit 1 of this registers dictates whether mode 1.7 or 1.9 is active, unless the Zero Wait State Enable bit 5 of the Function Control configuration register (FCR) is set to 1. In this case, the device is in revision 1.7 mode, regardless of the value of bit 1 of the PCR register.

When bit 2 of the PCR is set to 1, ECP mode is enabled.

The parallel port supports plug and play operation; its interrupt can be routed on one of the following ISA interrupts: IRQ7-IRQ3, IRQ12-IRQ9 or IRQ15 (see PNP0 register); its DMA signals can be routed to one of three 8-bit ISA DMA channels (see PNP2 register); and its base address is software configurable (see PBAL and PBAH registers)

### 4.2 STANDARD PARALLEL PORT MODES

The two Standard Parallel Port (SPP) modes Compatible SPP and Extended SPP modes.

Compatible SPP mode is a data write-only mode that outputs data to a parallel printer, using handshake bits, under software control.

In Extended SPP mode, parallel data transfer is bi-directional.

The list of output signals for the standard 25-pin, D-type connector appears in Table 4-11 on page 128.

The reset states for handshake output pins in this mode are listed below in Table 4-1.

A single Data Register DTR is used for data input and output (see Section 4.2.3). The direction of data flow is determined by the system setting in bit 5 of the Control Register CTR.

**TABLE 4-1. Parallel Port Reset States** 

| Signal | Reset Control | State After Reset |
|--------|---------------|-------------------|
| SLIN   | MR            | TRI-STATE         |
| INIT   | MR            | Zero              |
| AFD    | MR            | TRI-STATE         |
| STB    | MR            | TRI-STATE         |
| IRQ5,7 | MR            | TRI-STATE         |

# 4.2.1 Standard Parallel Port (SPP) Modes Register Set

All SPP mode port operation is controlled by three registers. Table 4-2 shows the registers of the parallel port in the Standard Parallel Port (SPP) modes.

The register bits assignments are compatible with the assignments in existing SPP devices.

**TABLE 4-2. Standard Parallel Port Registers** 

| Offset | <b>A</b> 1 | <b>A</b> 0 | Symbol | Description | R/W       |
|--------|------------|------------|--------|-------------|-----------|
| 0      | 0          | 0          | DTR    | Data        | R/W       |
| 1      | 0          | 1          | STR    | Status      | R         |
| 2      | 1          | 0          | CTR    | Control     | R/W       |
| 3      | 1          | 1          |        | -           | TRI-STATE |

# 4.2.2 SPP Mode Parallel Port Register Bitmaps







#### 4.2.3 Data Register (DTR), Offset 0

This bidirectional data port transfers 8-bit data in the direction determined by bit 7 of configuration Register PTR and bit 5 of SPP register CTR.

Bit 7 of the PTR selects the port mode - compatible mode, with no data input capability, or extended mode, having data input capability.

Bit 5 of the CTR determines the direction of the data flow - whether from the Data register DTR to the system, or from DTR to the external pins PD7-0.

The actual read or write to the data register is activated by the system  $\overline{RD}$  and  $\overline{WR}$  strobes.

Table 4-3 tabulates DTR register operation.

TABLE 4-3. SPP Data Register Read and Write Modes

| Bit 7 of<br>PTR | Bit 5 of<br>CTR | RD | WR | Result                          |
|-----------------|-----------------|----|----|---------------------------------|
| 0               | Х               | 1  | 0  | Data written to PD7-0.          |
| 0               | Х               | 0  | 1  | Data read from the output latch |
| 1               | 0               | 1  | 0  | Data written to PD7-0.          |
| 1               | 1               | 1  | 0  | Data written is latched         |
| 1               | 0               | 0  | 1  | Data read from output latch.    |
| 1               | 1               | 0  | 1  | Data read from PD7-0.           |

When bit 7 of the PTR is zero, the device is in SPP compatible mode, and does not write data to the output pins. Bit 5 of the CTR register has no effect in this state. If data is written ( $\overline{WR}$  goes low), the data will be sent to the output pins PD7-0. If a Read cycle is initiated ( $\overline{RD}$  goes low), the system will read the contents of the output latch, and not data from the output pins PD7-0.

When bit 7 of the PTR is 1, the device is in the Extended SPP mode and can read and write external data via PD7-0. In this mode, bit 5 sets the direction for data in or data out, while read or write cycles are possible in both settings of bit 5.

If CTR bit 5 is cleared to 0, data is written to the output pins PD7-0 when a write cycle occurs. (if a read cycle occurs in this setting, the system will read the output latch, not data from PD7-0).

If CTR bit 5 is set to 1, data is read from the output pins PD7-0 when a read cycle occurs. A write cycle in this setting will only write to the output latch, not to the output pins PD7-0.

The reset value of this register is 0.



FIGURE 4-1. DTR Register Bitmap (SPP Mode)

#### 4.2.4 Status Register (STR), Offset 1

This read-only register holds status information. A system write operation to STR is an invalid operation that has no effect on the parallel port.



FIGURE 4-2. STR Register Bitmap (SPP Mode)

#### Bit 0 - Time-Out Status

In EPP mode only, this is the time-out status bit. In all other modes this bit has no function and has the constant value 1.

This bit is cleared when EPP mode is enabled, i.e., when bit 0 of PCR is changed from 0 to 1. Thereafter, this bit is set to 1 when a time-out occurs in an EPP cycle and is cleared when STR is read.

In EPP mode:

- EPP mode set. No time-out occurred since STR was last read.
- 1 Time-out occurred on EPP cycle (minimum of 10 μsec). (Default)

#### Bit 1 - Reserved

This bit is reserved and is always 1.

#### Bit 2 - IRQ Status

In all modes except Extended SPP, this bit is always 1.

In Extended SPP mode (bit 7 of PTR is 1) this bit is the IRQ status bit. It remains high unless the interrupt request is enabled (bit 4 of CTR set high). This bit is high except when latched low when the ACK signal makes a low to high transition, indicating a character is now being transferred to the printer.

Reading this bit resets it to 1.

- 0 Interrupt requested in Extended SPP mode.
- 1 No interrupt requested. (Default)

#### Bit 3 - ERR Status

This bit reflects the current state of the printer error signal, ERR. The printer sets this bit low when there is a printer error.

- 0 Printer error.
- 1 No printer error.

#### Bit 4 - SLCT Status

This bit reflects the current state of the printer select signal, SLCT. The printer sets this bit high when it is online and selected.

- 0 No printer selected.
- 1 Printer selected and online.

#### Bit 5 - PE Status

This bit reflects the current state of the printer paper end signal (PE). The printer sets this bit high when it detects the end of the paper.

- 0 Printer has paper.
- 1 End of paper in printer.

#### Bit 6 - ACK Status

This bit reflects the <u>current</u> state of the printer acknowledge signal, ACK. The printer pulses this signal low after it has received a character and is ready to receive another one. This bit follows the state of the ACK pin.

- 0 Character reception complete.
- 1 No character received .

#### Bit 7 - Printer Status

This bit reflects the current state of the printer BUSY signal. The printer sets this bit low when it is busy and cannot accept another character.

This bit is the inverse of the (BUSY/WAIT) pin.

- 0 Printer busy.
- 1 Printer not busy.

#### 4.2.5 Control Register (CTR), Offset 2

The control register provides all the output signals that control the printer. Except for bit 5, it is a read and write register.

Normally when the Control Register is read, the bit values are provided by the internal output data latch. These bit values can be superseded by the logic level of the STB, AFD, INIT, and SLIN pins, if these pins are forced high or low by an external voltage. To force these signals high or low the corresponding bits should be set to their inactive state (e.g., AFD, STB and SLIN should all be 0, INIT should be 1).

Section 4.3.11 describes the transfer operations that are possible in EPP mode.



FIGURE 4-3. CTR Register Bitmap (SPP Mode) in PC87338



FIGURE 4-4. CTR Register Bitmap (SPP Mode) in PC97338

#### Bit 0 - Data Strobe Control

Bit 0 directly controls the data strobe signal to the printer via the STB pin.

This bit is the inverse of the STB pin.

#### Bit 1 - Automatic Line Feed Control

This bit directly controls the automatic line feed signal to the printer via the AFD pin. Setting this bit high causes the printer to automatically feed after each line is printed.

This bit is the inverse of the AFD pin.

- 0 No automatic line feed. (Default)
- 1 Automatic line feed

#### Bit 2 - Printer Initialization Control (INIT)

This bit directly controls the signal to initialize the printer via the INIT pin. Setting this bit to low initializes the printer.

The value of the  $\overline{\text{INIT}}$  signal reflects the value of this bit. In the PC87338 this bit is 0 after reset (activate  $\overline{\text{INIT}}$  signal to initialized the printer).

In the PC97338 this bit is 1 after reset, so the printer can stay in ECP mode if it was programmed to this mode, and not initialized to SPP mode.

- 0 Initialize Printer (Default in PC87338).
- 1 No action (Default in PC97338).

#### Bit 3 - Select Input Signal Control

This bit directly controls the select in signal to the printer via the SLIN pin. Setting this bit high selects the printer.

It is the inverse of the SLIN pin.

This bit must be set to 1 before enabling the EPP or ECP modes via bits 0 or 2 of the PCR register.

- 0 Printer not selected. (Default)
- 1 Printer selected and online.

#### Bit 4 - Interrupt Enable

Bit 4 controls the interrupt generated by the ACK signal. Its function changes slightly depending on the parallel port mode selected.

In ECP mode, this bit should be set to 0.

In the following description, IRQx indicates an interrupt line allocated for the parallel port.

- In Compatible SPP, Extended SPP and EPP modes, IRQx is floated. (Default)
- 1 In Compatible SPP mode, IRQx follows ACK transitions.

In Extended SPP mode, IRQx is set active on the trailing edge of ACK.

In EPP mode, IRQx follows  $\overline{ACK}$  transitions, or is set when an EPP time-out occurs.

#### **Bit 5 - Direction Control**

This bit determines the direction of the parallel port in Extended SPP mode (when bit 7 of PTR is 1). In the (default) Compatible SPP mode, this pin has no effect, since the port functions for output only.

This is a read/write bit in EPP modes. In SPP modes it is a write only bit. A read from it returns 1. In Compatible SPP mode and in EPP modes it does not control the direction. See Table 4-3.

- 0 Data output to PD7-0 in Extended SPP mode during write cycles (Default)
- 1- Data input from PD7-0 in Extended SPP mode during read cycles.

#### Bits 7,6 - Reserved

These bits are reserved and are always 1.

### 4.3 ENHANCED PARALLEL PORT (EPP) MODES

EPP modes allow greater throughput than Compatible SPP and Extended SPP modes by supporting faster transfer times (8, 16 or 32 bit data transfers in a single read/write operation) and a mechanism that allows the system to address peripheral device registers directly. Faster transfers are achieved by automatically generating the address and data strobes.

The connector pin assignments for these modes are listed in "Parallel Port Pin Out" on page 128.

EPP modes support revision 1.7 and revision 1.9 of the IEEE 1284 standard, as shown in Table 4-4. When bit 5 of FCR is 1 (configured for zero wait states), the EPP revision is always 1.7, i.e., it is not affected by bit 1 of PCR.

**TABLE 4-4. EPP Revision Selection** 

| EPP Mode                        | Bit 5 of the FCR<br>Con guration<br>register | Bit 1 of<br>PCR | Bit 0 of<br>PCR |
|---------------------------------|----------------------------------------------|-----------------|-----------------|
| EPP Revision                    | 1                                            | х               | 1               |
| 1.7                             | 0                                            | 0               | 1               |
| EPP Revision<br>1.9 (IEEE 1284) | 0                                            | 1               | 1               |

In Legacy mode, EPP modes are supported for a parallel port whose base address is 278h or 378h, but not for a parallel port whose base address is 3BCh. (There are no EPP registers at 3BFh.)

SPP-type data transactions may be conducted in either EPP mode. The appropriate registers are available for this type of transaction. (See Table 4-5.) As in the SPP modes, software must generate the control signals required to send or receive data.

The output of the control signals in PC87338 are in level 2 (pushpull) when in EPP1.9 mode

The output of the control signals in PC97338 are in level 2 (pushpull) always when in EPP mode.

## 4.3.1 Enhanced Parallel Port (EPP) Modes Register Set

Table 4-5 lists the EPP mode registers. All are singlebyte registers.

Bits 0, 1 and 3 of the CTR register must be 0 before the EPP registers can be accessed, since the pins controlled by these bits are controlled by hardware during EPP accesses. Once these bits are set to 0 by the software driver, multiple EPP access cycles may be invoked. Bit 7 of the PTR register must be set to 0, when EPP mode is enabled.

Bit 7 of STR (BUSY status) must be set to 1 before writing to DTR in EPP mode to ensure data output to PD7-0.

The EPP monitors the IOCHRDY pin during EPP cycles. If IOCHRDY is driven low for more then 10  $\mu sec$ , an EPP time-out event occurs, which aborts the cycle by asserting IOCHRDY, thus releasing the system from a stuck EPP peripheral device. When the cycle is aborted,  $\overline{ASTRB}$  or  $\overline{DSTRB}$  becomes inactive, and the time-out event is signaled by asserting bit 0 of the STR. If bit 4 of the CTR is 1, the time-out event also pulses the IRQ5 or IRQ7 lines.

EPP cycles to the external device are activated by invoking read or write cycles to the EPP.

TABLE 4-5. Parallel Port Registers in EPP Modes

| Offset | Symbol | Description | Mode       | R/W |
|--------|--------|-------------|------------|-----|
| 0      | DTR    | SPP Data    | SPP or EPP | R/W |
| 1      | STR    | SPP Status  | SPP or EPP | R   |
| 2      | CTR    | SPP Control | SPP or EPP | R/W |
| 3      | EPP    | Address     | EPP        | R/W |
| 4      | EPP [  | Data Port 0 | EPP        | R/W |
| 5      | EPP [  | Data Port 1 | EPP        | R/W |
| 6      | EPP [  | Data Port 2 | EPP        | R/W |
| 7      | EPP [  | Data Port 3 | EPP        | R/W |

# 4.3.2 EPP Modes Parallel Port Register Bitmaps











D25

**EPP Device** 

Bits 31-24

Read or Write

D26

D27

D28

D29

D30

D31

### 4.3.3 SPP or EPP Data Register (DTR), Offset 0

The DTR register is the SPP Compatible or SPP Extended data register. A write to DTR sets the state of the eight data pins on the 25-pin D-shell connector.



FIGURE 4-5. DTR Register Bitmap (EPP Mode)

# 4.3.4 SPP or EPP Status Register (STR), Offset 1

This status port is read only. A read presents the current status of the five pins on the 25-pin D-shell connector, and the IRQ as shown in Figure 4-6.



#### FIGURE 4-6. STR Register Bitmap (EPP Mode)

The bits of this register have the identical function in EPP mode as in SPP mode. See Section 4.2.4 for a detailed description of each bit.

# 4.3.5 SPP or EPP Control Register (CTR), Offset 2

This control port is read or write. A write operation to it sets the state of four pins on the 25-pin D-shell connector, and controls both the parallel port interrupt enable and direction.



#### FIGURE 4-7. CTR Register Bitmap (EPP Mode)

The bits of this register have the identical function in EPP modes as in SPP modes. See Section 4.2.5 for a detailed description of each bit.

#### 4.3.6 EPP Address Register, Offset 3

This port is added in EPP mode to enhance system throughput by enabling registers in the remote device to be directly addressed by hardware.

This port can be read or written. Writing to it initiates an EPP device or register selection operation.



FIGURE 4-8. DTR Register Bitmap (EPP Mode)

#### 4.3.7 EPP Data Port 0, Offset 4

This is a read/write port. Accessing it initiates device read or write operations of bits 7-0.



FIGURE 4-9. DTR Register Bitmap (EPP Mode)

#### 4.3.8 EPP Data Port 1, Offset 5

This is the second EPP data port. It is only accessed to transfer bits 15 through 8 of a 16-bit read or write to data port 0.



FIGURE 4-10. DTR Register Bitmap (EPP Mode)

#### 4.3.9 EPP Data Port 2, Offset 6

This is the third EPP data port. It is only accessed to transfer bits 16 to 23 of a 32-bit read or write to data port 0.



FIGURE 4-11. EPP Data Port 2 Bitmap

#### 4.3.10 EPP Data Port 3, Offset 7

This is the fourth EPP data port. It is only accessed to transfer bits 24 to 31 of a 32-bit read or write to data port 0.



FIGURE 4-12. EPP Data Port 3 Bitmap

#### 4.3.11 EPP Mode Transfer Operations

The EPP transfer operations are: address read or write, and data read or write. An EPP transfer operation is composed of a system read or write cycle (from or to an EPP register) and an EPP read or write cycle (from a peripheral device to an EPP register, or from an EPP register to a peripheral device).

#### **EPP 1.7 Address Write**

The following procedure selects a peripheral device or register as illustrated in Figure 4-13.

- The system writes a byte to the EPP address register
  - WR becomes low to latch D7-0 into the address register. The latch drives the address register onto PD7-0 and the EPP pulls WRITE low.
- 2. The EPP pulls ASTRB low to indicate that data was sent.
- If WAIT was low during the system write cycle, IO-CHRDY becomes low. When WAIT becomes high, the EPP pulls IOCHRDY high.
- 4. When IOCHRDY becomes high, it causes WR to become high. If WAIT is high during the system write cycle, then the EPP does not pull IOCHRDY to low.
- 5. When WR becomes high, it causes the EPP to pull ASTRB to high, and then to pull WRITE to high. The EPP can change PD7-0 only when WRITE and ASTRB are both high.



FIGURE 4-13. EPP 1.7 Address Write

#### **EPP 1.7 Address Read**

The following procedure reads from the address register as shown in Figure 4-14.

- 1. The system reads a byte from the EPP address register. RD goes low to gate PD7-0 into D7-0.
- 2. The EPP pulls ASTRB low to signal the peripheral to start sending data.
- If WAIT is low during the system read cycle. Then the EPP pulls IOCHRDY low. When WAIT becomes high, the EPP stops pulling IOCHRDY to low.
- When IOCHRDY becomes high, it causes RD to become high. If WAIT is high during the system read cycle then the EPP does not pull IOCHRDY to low.
- 5. When RD becomes high, it causes the EPP to pull ASTRB high. The EPP can change PD7-0 only when ASTRB is high. After ASTRB becomes high, the EPP puts D7-0 in TRI-STATE.



FIGURE 4-14. EPP 1.7 Address Read

#### **EPP 1.7 Data Write and Read**

This procedure writes to the selected peripheral device or register.

An EPP 1.7 data read or write operations are similar to the EPP 1.7 address read or write operations, except that the data strobe (DSTRB signal), and a data register, replace the address strobe (ASTRB signal) and the address register respectively.

#### EPP Revision 1.7 Zero Wait State (ZWS) Address and Data Write and Read Operations

To configure the device for zero wait states, set bit 5 of FCR to 1 and clear bit 6 of FCR to 0. When bit 5 of FCR is 1, the EPP revision is always 1.7, i.e., it is not affected by bit 1 of PCR.

The following procedure performs a short write to the selected peripheral device or register. See also Figure 4-15.

- 1. The system writes a byte to the EPP address register.
  - WR becomes low to latch D7-0 into the data register. The latch drives the data register to PD7-0.
- 2. The EPP first pulls WRITE low, and then pulls ASTRB low to indicate that data has been sent.
- 3. If WAIT was high during the system write cycle, ZWS goes low and IOCHRDY stays high.
- 4. When the system pulls WR high, the EPP pulls ASTRB, ZWS and then WRITE to high. The EPP can change PD7-0 only when WRITE and ASTRB are high.
- If the peripheral is fast enough to pull WAIT low before the system terminates the write cycle, the EPP pulls IOCHRDY to low, but does not pull ZWS to low, thus carrying out a normal (non-ZWS EPP

1.7) write operation.



#### FIGURE 4-15. EPP Write with Zero Wait States

A read operation is similar, except for the data direction, activation of  $\overline{RD}$  instead of  $\overline{WR}$ , and  $\overline{WRITE}$  stays high.

EPP 1.7 zero wait state data write and read operations are similar to EPP zero wait state address write and read operations, with the exception that the data strobe (DSTRB signal), and a data register, replace the address strobe (ASTRB signal) and the address register, respectively.

#### **EPP 1.9 Address Write**

The following procedure selects a peripheral or register as shown in Figure 4-16.

- 1. The system writes a byte to the EPP address register.
- 2. The EPP pulls IOCHRDY low, and waits for WAIT to become low.
- When WAIT becomes low, the EPP pulls WRITE to low and drives the latched byte onto PD7-0. If WAIT was already low, steps 2 and 3 occur concurrently.
- 4. The EPP pulls ASTRB low and waits for WAIT to become high.
- 5. When WAIT becomes high, the EPP stops pulling IOCHRDY low, and waits for WR to become high.
- 6. When WR becomes high, the EPP pulls ASTRB high, and waits for WAIT to become low.
- 7. If no EPP write is pending when WAIT becomes low, the EPP pulls WRITE to high. Otherwise, WRITE remains low, and the EPP may change PD7-0.



FIGURE 4-16. EPP 1.9 Address Write

#### **EPP 1.9 Address Read**

The following procedure reads from the address register.

- 1. The system reads a byte from the EPP address register. When RD becomes low, the EPP pulls IOCHRDY low, and waits for WAIT to become low.
- 2. When WAIT becomes low, the EPP pulls ASTRB low and waits for WAIT to become high. If WAIT was already low, steps 2 and 3 occur concurrently.
- 3. When WAIT becomes high, the EPP stops pulling IOCHRDY low, and waits for RD to become high.
- 4. When  $\overline{\text{RD}}$  becomes high, the EPP latches PD7-0 (to provide sufficient hold time), pulls  $\overline{\text{ASTRB}}$  high, and puts D7-0 in TRI-STATE.



FIGURE 4-17. EPP 1.9 Address Read

#### **EPP 1.9 Data Write and Read**

This procedure writes to the selected peripheral drive or register.

EPP 1.9 data read and write operations are similar to EPP 1.9 address read and write operations, respectively, except that the data strobe (DSTRB signal) and a data register replace the address strobe (ASTRB signal) and the address register, respectively.

### 4.4 EXTENDED CAPABILITIES PARALLEL PORT (ECP) MODES

In the Extended Capabilities Port (ECP) modes, the device is a state machine that supports a 16-byte FIFO that can be configured for either direction, command and data FIFO tags (one per byte), a FIFO threshold interrupt for both directions, FIFO empty and full status bits, automatic generation of strobes (by hardware) to fill or empty the FIFO, transfer of commands and data, and Run Length Encoding (RLE) expanding (decompression) as explained below. The FIFO can be accessed by PIO or system DMA cycles.

The ECP modes are enabled when bit 2 of PCR is 1. Once enabled, the mode is controlled via the mode field of ECR, i.e., bits 7-5 of the ECR register as shown in Table 4-10 on page 124 and described in detail in "ECP Mode Descriptions" on page 125.

The ECP modes and their code designations are listed in Table 4-6.

TABLE 4-6. ECP Modes Encoding

| ECR   | Bit Enco | oding | Mode Name          |
|-------|----------|-------|--------------------|
| Bit 7 | Bit 6    | Bit 5 | Mode Name          |
| 0     | 0        | 0     | Standard           |
| 0     | 0        | 1     | PS/2               |
| 0     | 1        | 0     | Parallel port FIFO |
| 0     | 1        | 1     | ECP FIFO           |
| 1     | 1        | 0     | FIFO test          |
| 1     | 1        | 1     | Configuration      |

The output of the control signals in PC87338 are in level 2 (pushpull) when:

- in ECP mode 011
- in ECP mode 010 and PCR[1]=1

The output of the control signals in PC97338 are in level 2 (pushpull) in all ECP modes besides 000.

TABLE 4-7. Parallel Port Registers in ECP Modes

| Offset | Symbol | Description                    | Modes<br>(ECR Bits)<br>7 6 5 | R/W |
|--------|--------|--------------------------------|------------------------------|-----|
| 000h   | DATAR  | Parallel Port<br>Data Register | 0 0 0<br>0 0 1               | R/W |
| 000h   | AFIFO  | ECP Address<br>FIFO            | 0 1 1                        | W   |
| 001h   | DSR    | Status Register                | All Modes                    | R   |
| 002h   | DCR    | Control Register               | All Modes                    | R/W |
| 400h   | CFIFO  | Parallel Port<br>Data FIFO     | 0 1 0                        | W   |
| 400h   | DFIFO  | ECP Data FIFO                  | 0 1 1                        | R/W |
| 400h   | TFIFO  | Test FIFO                      | 1 1 0                        | R/W |
| 400h   | CNFGA  | Configuration<br>Register A    | 1 1 1                        | R   |
| 401h   | CNFGB  | Configuration<br>Register B    | 111                          | R   |
| 402h   | ECR    | Extended Control<br>Register   | All Modes                    | R/W |

#### 4.4.1 Accessing the ECP Registers

The AFIFO, CFIFO, DFIFO and TFIFO registers access the same ECP FIFO. The FIFO is accessed at Base + 000h, or Base + 400h, depending on the mode field of ECR and the register.

The FIFO can be accessed by system DMA cycles, as well as system PIO cycles.

When the DMA is configured and enabled (bit 3 of ECR is 1 and bit 2 of ECR is 0) the ECP automatically (by hardware) issues DMA requests to fill the FIFO (in the forward direction when bit 5 of DCR is 0) or to empty the FIFO (in the backward direction when bit 5 of DCR is 1). All DMA transfers are to or from these registers. The ECP does not assert DMA requests for more than 32 consecutive DMA cycles. The ECP stops requesting the DMA when TC is detected during an ECP DMA cycle.

Writing into a full FIFO, and reading from an empty FIFO, are ignored. The written data is lost, and the read data is undefined. The FIFO empty and full status bits are not affected by such accesses.

Some registers are not accessible in all modes of operation, or may be accessed in one direction only. Accessing a non accessible register has no effect. Data read is undefined; data written is ignored; and the FIFO does not update. The Chip SPP registers (DTR, STR and CTR) are not accessible when the ECP is enabled.

To improve noise immunity in ECP cycles, the state machine does not examine the control handshake response lines until the data has had time to switch.

#### In ECP modes:

- DATAR replaces DTR of SPP/EPP
- DSR replaces STR of SPP/EPP
- DCR replaces CTR of SPP/EPP

The base address is 278h, 378h or 3BCh, as specified in the FAR register in Legacy mode.

#### 4.4.2 Software Operation in ECP Modes

Software should operate as described in "Extended Capabilities Port Protocol and ISA Interface Standard".

Some of these operations are:

- Software should enable ECP (bit 2 of PCR is 1) after bits 3-0 of the parallel port Control Register (CTR) are set to 0100.
- When ECP is enabled, software should switch modes only through modes 000 or 001.
- When ECP is enabled, the software should change direction only in mode 001.
- Software should not switch from mode 010 or 011, to mode 000 or 001, unless the FIFO is empty.
- Software should switch to mode 011 when bits 0 and 1 of DCR are 0.
- Software should switch to mode 010 when bit 0 of DCR is 0.
- Software should disable ECP (bit 2 of PCR is 0) only in mode 000 or 001.

Software may switch from mode 011 backward to modes 000 or 001, when there is an on-going ECP read cycle. In this case, the read cycle is aborted by deasserting AFD. The FIFO is reset (empty) and a potential byte expansion (RLE) is automatically terminated since the new mode is 000 or 001.

### 4.4.3 Hardware Operation in ECP Modes

The  $\overline{\text{ZWS}}$  signal is asserted by the ECP when ECP modes are enabled, and an ECP register is accessed by system PIO instructions, thus using a system zero wait states cycle (except during read cycles from ECR).

The ECP uses an internal clock, which can be frozen to reduce power consumption during power down. In this power-down state the DMA is disabled, all interrupts (except ACK) are masked, and the FIFO registers are not accessible (access is ignored). The other ECP registers are unaffected by power-down and are always accessible when the ECP is enabled. During power-down the FIFO status and contents become inaccessible, and the system reads bit 2 of ECR as 0, bit 1 of ECR as 1 and bit 0 of ECR as 1, regardless of the actual values of these bits. The FIFO status and contents are not lost, however, and when the clock activity resumes, the values of these bits resume their designated functions.

When the clock is frozen, an on-going ECP cycle may be corrupted, but the next ECP cycle will not start even if the FIFO is not empty in the forward direction, or not full in the backward direction. If the ECP clock starts or stops toggling during a system cycle that accesses the FIFO, the cycle may yield wrong data.

ECP output signals are inactive when the ECP is disabled.

Only the FIFO, DMA and RLE do not function when the clock is frozen. All other registers are accessible and functional. The FIFO, DMA and RLE are affected by ECR modifications, i.e., they are reset when exits from modes 010 or 011 are carried out even while the clock is frozen.

# 4.4.4 ECP Modes Parallel Port Register Bitmaps



Bits 7-5 of ECR = 011







#### All ECP Modes





# 4.4.6 ECP Address FIFO (AFIFO) Register, Bits 7-5 of ECR = 011, Offset 000h

The ECP Address FIFO Register (AFIFO) is write only. In the forward direction (bit 5 of DCR is 0) a byte written into this register is pushed into the FIFO and tagged as a command.

Reading this register returns undefined contents. Writing to this register in a backward direction (bit 5 of DCR is 1) has no effect and the data is ignored.

#### Bits 7-5 of ECR = 011



FIGURE 4-19. AFIFO Register Bitmap

### 4.4.7 ECP Status Register (DSR), Offset 001h

This read-only register displays device status. Writes to this DSR have no effect and the data is ignored.

This register should not be confused with the DSR register of the Floppy Disk Controller (FDC).

#### **All ECP Modes**



FIGURE 4-20. ECP DSR Register Bitmap

#### Bits 0 - 2 - Reserved

These bits are reserved and are always 1.

#### Bit 3 - ERR Status

This bit reflects the status of the ERR signal.

- 0 Printer error
- 1 No printer error

#### Bit 4 - SLCT Status

This bit reflects the status of the Select signal. The printer sets this signal high when it is online and selected

- 0 Printer not selected (default)
- 1 Printer selected and online

#### Bit 5 - PE Status

This bit reflects the status of the Paper End (PE) signal.

- 0 Paper not ended
- 1 NO paper in printer.

#### Bit 6 - ACK Status

This bit reflects the status of the ACK signal. This signal is pulsed low after a character is received.

- 0 Character received.
- 1 No character received (Default)

#### Bit 7 - Printer Status

This bit reflects the inverse of the state of the BUSY signal.

- 0 Printer is busy (cannot accept another character now)
- 1 Printer not busy ready for another character.

#### 4.4.8 ECP Control Register (DCR), Offset 002h

Reading this register returns the register content (not the pin values, as in SPP mode).

All ECP Modes



FIGURE 4-21. DCR Register Bitmap

#### Bit 0 - Data Strobe Control

Bit 0 directly controls the data strobe signal to the printer via the STB signal. This bit is the inverse of the STB signal.

- 0 The STB signal is inactive in all modes except 010 and 011. In these modes, it may be active or inactive as set by the software.
- 1 In all modes, STB is active.

#### Bit 1 - Automatic Line Feed Control

This bit directly controls the automatic feed XT signal to the printer via the AFD signal. Setting this bit high causes the printer to automatically feed after each line is printed. This bit is the inverse of the AFD signal.

In mode 011,  $\overline{\text{AFD}}$  is activated by both ECP hardware and by software using this bit.

- 0 No automatic line feed. (Default)
- 1 Automatic line feed.

#### Bit 2 - Printer Initialization Control

Bit 2 directly controls the signal to initialize the printer via the INIT signal. Setting this bit to low initializes the printer. The INIT signal follows this bit.

- 0 Initialize printer (Default)
- 1 No action.

#### Bit 3 - Parallel Port Input Control

This bit directly controls the select input device signal to the printer via the SLIN signal. It is the inverse of the SLIN signal.

This bit must be set to 1 before enabling the EPP or ECP modes via bits 0 or 2 of the PCR register.

- 0 The printer is not selected.
- 1 The printer is selected.

#### Bit 4 - Interrupt Enable

Bit 4 enables the interrupt generated by the  $\overline{ACK}$  signal. In ECP mode, this bit should be set to 0. This bit does not float the IRQ pin.

- 0 Masked. (Default)
- 1 Enabled.

#### **Bit 5 - Direction Control**

This bit determines the direction of the parallel port when bit 7 of PTR is 1. The default condition is parallel port in output mode.

In the PC87338, this bit is a read only bit (return 0) in ECP modes 000 and 010. In all other ECP modes, it is a read/write bit.

In the PC97338, this bit is a read/write bit in all ECP modes.

This bit is a read/write bit in EPP mode. In SPP mode it is a write only bit. A read from it returns 1. In SPP Compatible mode and in EPP mode it does not control the direction. See Table 4-3.

- 0 The ECP is in forward direction.
- 1 The ECP is in backward direction.

The ECP drives the PD7-0 pins in the forward direction, but does not drive them in the backward direction.

The direction bit, bit 5, is readable and writable. In modes 000 and 010 the direction bit is forced to 0, internally, regardless of the data written into this bit

- 0 ECP drives forward in output mode. (Default)
- 1 ECP direction is backward.

#### Bits 7,6 - Reserved

These bits are reserved and are always 1.

# 4.4.9 Parallel Port Data FIFO (CFIFO) Register, Bits 7-5 of ECR = 010, Offset 400h

The Parallel Port FIFO (CFIFO) register is write only. A byte written to this register by PIO or DMA is pushed into the FIFO and tagged as data.

Reading this register has no effect and the data read is undefined.



FIGURE 4-22. CFIFO Register Bitmap

#### 4.4.10 ECP Data FIFO (DFIFO) Register, Bits 7-5 of ECR = 011, Offset 400h

This bi-directional FIFO functions as either a writeonly device (when DCR bit 5 is 0) or a read-only device (DCR bit 5 is 1).

In the forward direction (bit 5 of DCR is 0), a byte written to the ECP Data FIFO (DFIFO) register by PIO or DMA is pushed into the FIFO and tagged as data. Reading this register when set for write-only has no effect and the data read is undefined.

In the backward direction (bit 5 of DCR is 1), the ECP automatically issues ECP read cycles to fill the FIFO.

Reading from this register pops a byte from the FIFO. Writing to this register when it is set for read-only has no effect, and the data written is ignored.



FIGURE 4-23. DFIFO Register Bitmap

#### 4.4.11 Test FIFO (TFIFO) Register, Bits 7-5 of ECR = 110, Offset 400h

A byte written into the Test FIFO (TFIFO) register is pushed into the FIFO. A byte read from this register is popped from the FIFO. The ECP does not issue an ECP cycle to transfer the data to or from the peripheral device.

The TFIFO is readable and writable in both directions. In the forward direction (bit 5 of DCR is 0) PD7-0 are driven, but the data is undefined.

The FIFO does not stall when overwritten or underrun (access is ignored). Bytes are always read from the top of the FIFO, regardless of the direction bit setting (bit 5 of DCR). For example if 44h, 33h, 22h, 11h is written into the FIFO, reading the FIFO returns 44h, 33h, 22h, 11h (in the same order it was written).

### Bits 7-5 of ECR = 110



FIGURE 4-24. TFIFO Register Bitmap

# 4.4.12 Configuration Register A (CNFGA), Bits 7-5 of ECR = 111, Offset 400h

This register is read only. Reading CNFGA always returns 100 on bits 2 to 0 and 0001 on bits 7 to 4; bit 3 is a reflection of bit 5 of ASC. Writing this register has no effect and the data is ignored.

#### Bits 7-5 of ECR = 111



FIGURE 4-25. CNFGA Register Bitmap

#### Bits 2-0 - Reserved

These bits are reserved and are always 100.

#### Bit 3 - Bit 5 of ASC

This bit reflects the value of bit 5 of the ASC configuration register, which has no specific function. Bit 5 of ASC may be used at the discretion of system programmers, for any purpose. Whatever value is put in bit 5 of the ASC register will appear in bit 3 of the CNFGA register.

The CNFGA register bit reflects a specific system configuration parameter, as opposed to other devices, e.g., 8-bit data word length.

#### Bit 7-4 - Reserved

These bits are reserved and are always 0001.

# 4.4.13 Configuration Register B (CNFGB), Bits 7-5 of ECR = 111, Offset 401h

Configuration register B (CNFGB) is read only. Reading this register returns the configured parallel port interrupt line and DMA channel, and the state of the interrupt line.

Writing to this register has no effect and the data is ignored.

#### Bits 7-5 of ECR = 111 0 Configuration Register B (ČNFGB) 0 Χ 0 0 Reset Χ Χ Offset 401h Required DMA Channel Select Reserved Interrupt Select IRQ Signal Value Reserved

FIGURE 4-26. CNFGB Register Bitmap

#### Bits 1,0 - DMA Select Bits

These bits reflect the value of bits 2 and 1 of the SCF1 configuration register. Microsoft's ECP Protocol and ISA Interface Standard defines these bits shown in Table 4-8.

Note that bits 2-1 of SCF1 are read/write bits but CNFGB bits are read only.

Upon reset, these bits are initialized to 00.

**TABLE 4-8. ECP Mode DMA Selection** 

| Bit 1 | Bit 0 | DMA Con guration                            |  |  |
|-------|-------|---------------------------------------------|--|--|
| 0     | 0     | 8-bit DMA selected by jumpers.<br>(Default) |  |  |
| 0     | 1     | DMA channel 1 selected.                     |  |  |
| 1     | 0     | DMA channel 2 selected.                     |  |  |
| 1     | 1     | DMA channel 3 selected.                     |  |  |

#### Bit 2 - Reserved

This bit is reserved and is always 0.

#### Bits 5-3 - Interrupt Select Bits

These bits reflect the value of bits 2-0 of the PNP0 configuration register. Microsoft's ECP Protocol and ISA Interface Standard defines these bits as shown in Table 4-9.

Bits 2-0 of PNP0 are normal read/write bits but CNFGB bits are read only.

Upon reset, these bits have an undefined value.

**TABLE 4-9. ECP Mode Interrupt Selection** 

| Bit 5 | Bit 4 | Bit 3 | Interrupt Selection |
|-------|-------|-------|---------------------|
| 0     | 0     | 0     | Jumper selection.   |
| 0     | 0     | 1     | IRQ7 selected.      |
| 0     | 1     | 0     | IRQ9 selected.      |
| 0     | 1     | 1     | IRQ10 selected.     |
| 1     | 0     | 0     | IRQ11 selected.     |
| 1     | 0     | 1     | IRQ14 selected.     |
| 1     | 1     | 0     | IRQ15 selected.     |
| 1     | 1     | 1     | IRQ5 selected.      |

#### Bit 6 - IRQ Signal Value

This bit holds the value of the configured IRQ signal. The value of this bit will be undetermined if the interrupt is not correctly configured on configuration register PNP0, bits 1 and bits 7-4.

#### Bit 7 - Reserved

This bit is reserved and is always 0.

#### 4.4.14 Extended Control Register (ECR), Offset 402h

This register controls the ECP and parallel port functions. On reset this register is initialized to 00010101. IOCHRDY is driven low on ECR read when the ECR status bits do not hold updated data.

#### **All ECP Modes**



FIGURE 4-27. ECR Register Bitmap

#### Bit 0 - FIFO Empty

This bit continuously reflects the FIFO state, and therefore can only be read. Data written to this bit is ignored.

When the ECP clock is frozen this bit is read as 1, regardless of the actual FIFO state.

0 - The FIFO has at least one byte of data.

1 - The FIFO is empty or ECP clock is frozen.

#### Bit 1 - FIFO Full

This bit continuously reflects the FIFO state, and therefore can only be read. Data written to this bit is ignored.

When the ECP clock is frozen this bit is read as 1, regardless of the actual FIFO state.

- 0 The FIFO has at least one free byte.
- 1 The FIFO is full or ECP clock frozen.

#### Bit 2 - ECP Service

This bit enables servicing of interrupt requests. It is set to 1 upon reset, and by the occurrence of interrupt events.

While set to 1, neither DMA nor the interrupt events listed below will generate an interrupt. It is set to 0 by software.

When set to 0, the interrupt setup is "armed" and an interrupt will be generated on occurrence of an interrupt event.

While the ECP clock is frozen, it will always return a 0 value, although it retains its proper value and may be modified while the clock is frozen.

When one of the following interrupt events occurs while this bit is 0, an interrupt is generated and this bit is set to 1 by hardware.

- DMA is enabled (Bit 3 of ECR is 1) and terminal count is reached.
- FIFO write threshold reached (no DMA -Bit 3 of ECR is 0; forward direction - bit 5 of DCR is 0, and there are eight or more bytes free in the FIFO).
- FIFO read threshold reached (no DMA bit 3 of ECR is 0; read direction set - bit 5 of DCR is 1, and there are eight or more bytes to be read from the FIFO).
- The DMA and the above three interrupts are not disabled.
- The DMA and the above three interrupts are disabled.

#### Bit 3 - ECP DMA Enable

- 0 Depending on the value of bits 7 and 6 of the PNP2 register, the selected pin DRQ0, DRQ1 or DRQ2 is in TRI-STATE, and the appropriate signal DACK0, DACK1 or DACK2 is assumed inactive.
- 1 The DMA is enabled and the DMA starts when bit 2 of ECR is 0.

#### Bit 4 - ECP Interrupt Mask

 O - An interrupt is generated on ERR assertion (the high-to-low edge of ERR). An interrupt is also generated while ERR is asserted when this bit is changed from 1 to 0; this prevents the loss of an interrupt between ECR read and ECR write.

1 - No interrupt is generated.

#### Bits 7-5 - ECP Mode Control

These bits set the mode for the ECP device. See Section 4.5 for a more detailed description of operation in each of these ECP modes. The ECP modes are listed in Table 4-10.

TABLE 4-10. ECP Modes

| Mode<br>Code |          |          | Mode Name                  | Operation Description                                                                                                                                                                               |  |  |
|--------------|----------|----------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit<br>7     | Bit<br>6 | Bit<br>5 |                            | Operation Description                                                                                                                                                                               |  |  |
| 0            | 0        | 0        | Standard<br>mode           | Write cycles are under software control.  Bit 5 of DCR is forced to 0 (forward direction) and PD7-0 are driven.  The FIFO is reset (empty).  Reading DATAR returns the last value written to DATAR. |  |  |
| 0            | 0        | 1        | PS/2 mode                  | Read and write cycles are under software control. The FIFO is reset (empty).                                                                                                                        |  |  |
| 0            | 1        | 0        | Parallel port<br>FIFO mode | Write cycles are automatic, i.e., under hardware control (STB is controlled by hardware).  Bit 5 of DCR is forced to 0 internally (forward direction) and PD7-0 are driven.                         |  |  |
| 0            | 1        | 1        | ECP FIFO<br>mode           | The FIFO direction is automatic, i.e., controlled by bit 5 of DCR.  Read and write cycles to the device are controlled by hardware (STB and AFD are controlled by hardware).                        |  |  |
| 1            | 0        | 0        | Reserved                   |                                                                                                                                                                                                     |  |  |
| 1            | 0        | 1        | Reserved                   |                                                                                                                                                                                                     |  |  |
| 1            | 1        | 0        | FIFO test<br>mode          | The FIFO is accessible via<br>the TFIFO register.<br>The ECP does not issue<br>ECP cycles to fill or empty<br>the FIFO.                                                                             |  |  |
| 1            | 1        | 1        | Configuration mode         | CNFGA and CNFGB registers are accessible.                                                                                                                                                           |  |  |

#### 4.5 ECP MODE DESCRIPTIONS

# 4.5.1 Software Controlled Data Transfer (Modes 000 and 001)

Software controlled data transfer is supported in modes 000 and 001. The software generates peripheral-device cycles by modifying the DATAR and DCR registers and reading the DSR, DCR and DATAR registers. The negotiation phase and nibble mode transfer, as defined in the IEEE 1284 standard, are performed in these modes.

In these modes the FIFO is reset (empty) and is not functional, the DMA and RLE are idle.

Mode 000 is for the forward direction only; the direction bit (DCR Bit 5) is forced to 0 and PD7-0 are driven. Mode 001 is for both the forward and backward directions. The direction bit controls whether or not pins PD7-0 are driven.

# 4.5.2 Automatic Data Transfer (Modes 010 and 011)

Automatic data transfer (ECP cycles generated by hardware) is supported only in modes 010 and 011 (Parallel Port and ECP FIFO modes). Automatic DMA access to fill or empty the FIFO is supported in modes 010, 011 and 110. Mode 010 is for the forward direction only; the direction bit is forced to 0 and PD7-0 are driven. Mode 011 is for both the forward and backward directions. The direction bit controls whether PD7-0 are driven.

Automatic Run Length Expanding (RLE) is supported in the backward direction.

### Forward Direction (bit 5 of DCR=0)

When the ECP is in forward direction and the FIFO is not full (bit 1 of ECR is 0) the FIFO can be filled by software writes to the FIFO registers (AFIFO and DFIFO in mode 011, and CFIFO in mode 010).

When DMA is enabled (bit 3 of ECR is 1 and bit 2 of ECR is 0) the ECP automatically issues DMA requests to fill the FIFO with data bytes (not including command bytes).

When the ECP is in forward direction and the FIFO is not empty (bit 0 of ECR is 0) the ECP pops a byte from the FIFO and issues a write signal to the peripheral device. The ECP drives AFD according to the operation mode (bits 7-5 of ECR) and according to the tag of the popped byte as follows: In Parallel Port FIFO mode (mode 010) AFD is controlled by bit 1 of DCR. In ECP mode (mode 011) AFD is controlled by the popped tag. AFD is driven high for normal data bytes and driven low for command bytes.

### **ECP (Forward) Write Cycle**

An ECP write cycle starts when the ECP drives the popped tag onto  $\overline{AFD}$  and the popped byte onto PD7-0. When BUSY is low the  $\overline{ECP}$  asserts  $\overline{STB}$ . In 010 mode the ECP deasserts  $\overline{STB}$  to terminate the write cycle. In 011 mode the ECP waits for BUSY to be high.

When BUSY is high, the ECP deasserts STB, and changes AFD and PD7-0 only after BUSY is low.



FIGURE 4-28. ECP Forward Write Cycle

### **Backward Direction (Bit 5 of DCR is 1)**

When the ECP is in the backward direction, and the FIFO is not full (bit 1 of ECR is 0), the ECP issues a read cycle to the peripheral device and monitors the BUSY signal. If BUSY is high the byte is a data byte and it is pushed into the FIFO. If BUSY is low the byte is a command byte. The ECP checks bit 7 of the command byte, if it is high the byte is ignored, if it is low the byte is tagged as an RLC byte (not pushed into the FIFO but used as a Run Length Count to expand the next byte read). Following an RLC read the ECP issues a read cycle from the peripheral device to read the data byte to be expanded. This byte is considered a data byte, regardless of its BUSY state (even if it is low). This byte is pushed into the FIFO (RLC+1) times (e.g. for RLC=0, push the byte once. For RLC=127 push the byte 128 times).

When the ECP is in the backward direction, and the FIFO is not empty (bit 0 of ECR is 0), the FIFO can be emptied by software reads from the FIFO register (true only for the TFIFO in mode 011, not for AFIFO or CFIFO reads).

When DMA is enabled (bit 3 of ECR is 1 and bit 2 of ECR is 0) the ECP automatically issues DMA requests to empty the FIFO (only in mode 011).

### **ECP (Backward) Read Cycle**

An ECP read cycle starts when the ECP drives  $\overline{\text{AFD}}$  low.

The peripheral device drives BUSY high for a normal data read cycle, or drives BUSY low for a command read cycle, and drives the byte to be read onto PD7-0.

When  $\overline{ACK}$  is asserted the ECP drives  $\overline{AFD}$  high. When  $\overline{AFD}$  is high the peripheral device deasserts  $\overline{ACK}$ . The ECP reads the PD7-0 byte, then drives  $\overline{AFD}$  low. When  $\overline{AFD}$  is low the peripheral device may change BUSY and PD7-0 states in preparation for the next cycle



FIGURE 4-29. ECP (Backward) Read Cycle

#### Notes:

- 1. FIFO-full condition is checked before every expanded byte push.
- Switching from modes 010 or 011 to other modes removes pending DMA requests and aborts pending RLE expansion.
- 3. FIFO pushes and pops are neither synchronized nor linked at the hardware level. The FIFO will not delay these operations, even if performed concurrently. Care must be taken by the programmer to utilize the empty and full FIFO status bits to avoid corrupting PD7-0 or D7-0 while a previous FIFO port access not complete.
- 4. In the forward direction, the empty bit is updated when the ECP cycle is completed, not when the last byte is popped from the FIFO (valid cleared on cycle end).
- 5. ZWS is not asserted for DMA cycles.
- 6. The one-bit command/data tag is used only in the forward direction.

### 4.5.3 FIFO Test Access (Mode 110)

Mode 110 is for testing the FIFO in PIO and DMA cycles. Both read and write operations (pop and push) are supported, regardless of the direction bit.

In the forward direction PD7-0 are driven, but the data is undefined. This mode can be used to measure the system-ECP cycle throughput, usually with DMA cycles. This mode can also be used to check the FIFO depth and its interrupt threshold, usually with PIO cycles.

# 4.5.4 Configuration Registers Access (Mode 111)

The two configuration registers, CNFGA and CNFGB, are accessible only in this mode.

### 4.5.5 Interrupt Generation

An interrupt is generated according to bit 5 and 6 setting in the PCR, when any of the events described in this section occurs. Interrupt events 2, 3 and 4 are level events. They are shaped as interrupt pulses, and are masked (inactive) when the ECP clock is frozen.

#### **Event 1**

Bit 2 of ECR is 0, bit 3 of ECR is 1 and TC is asserted during ECP DMA cycle. Interrupt event 1 is a pulse event.

#### **Event 2**

Bit 2 of ECR is 0, bit 3 of ECR is 0, bit 5 of DCR is 0 and there are eight or more bytes free in the FIFO

This event includes the case when bit 2 of ECR is cleared to 0 and there are already eight or more bytes free in the FIFO (modes 010, 011 and 110 only).

#### **Event 3**

Bit 2 of ECR is 0, bit 3 of ECR is 0, bit 5 of DCR is 1 and there are eight or more bytes to be read from the FIFO.

This event includes the case when bit 2 of ECR is cleared to 0 and there are already eight or more bytes to be read from the FIFO (modes 011 and 110 only).

#### **Event 4**

Bit 4 of ECR is 0 and  $\overline{\text{ERR}}$  is asserted (high to low edge) or  $\overline{\text{ERR}}$  is asserted when bit 4 of ECR is modified from 1 to 0.

This event may be lost when the ECP clock is frozen.

#### **Event 5**

When bit 4 of DCR is 1 and  $\overline{\text{ACK}}$  is deasserted (low-to-high edge).

This event behaves as in the normal SPP mode, i.e., the IRQ signal follows the ACK signal transition (when bit 5 of PCR is 0 and bit 6 of PCR is 0).

# 4.6 THE PARALLEL PORT MULTIPLEXER (PPM)

A PPM is used for a PC, which may have an internal Floppy Disk Drive (FDD) connected via regular FDC pins, to interface with either a printer or an external FDD, via a 25-pin DIN connector.

The printer and external FDD may be exchanged, without turning the PC off, and without updating the DOS device tables. The software may assign A to the FDD connected to the regular FDC pins and B to the FDD connected to the PPM pins (the default assignment), or vice versa.

The FDC output signals are always connected to the regular FDC output pins.

The FDC output signals are connected to the PPM output pins when the PPM is enabled (bits 7 and 6 of SIRQ3 are 1 and 0, respectively) and a floppy drive is connected to it (PNF = 0). See Table 4-11.

The FDC input signals are connected to the regular FDC pins when either bits 7 and 6 of SIRQ3 are not equal to 1 and 0, respectively, or when the PNF signal is active (high).

The FDC input pins are internally multiplexed between the regular FDC pins and the PPM pins when bits 7 and 6 of SIRQ3 are 1 and 0, respectively, and PNF = 0 as follows:

- The PPM pins are connected to the FDC input signals when DR1=0.
- The regular pins are connected to the FDC input signals when DR1=1.

To support true floating pins, the pins are back-drive protected.

When bit 3 of FCR is 1, the PPM pins are floated.

When the PPM is not enabled, the parallel port signals are connected to the PPM pins. (The PPM is configured when bits 7,6 of SIRQ3 are 10, and bit 1 of SCF3 is 0.)

When bits 7,6 of SIRQ3 are 10, and PNF=1, the parallel port signals are connected to the PPM pins.

When bits 7,6 of SIRQ3 are 10, and PNF=0, the FDC output signals are connected to the PPM pins.

Reading back the DTR or CTR returns their written values.

Input signals assume their default values (STR register):  $\overline{BUSY} = 0$ ,  $\overline{PE} = 0$ ,  $\overline{SLCT} = 0$ ,  $\overline{ACK} = 1$  and thus the parallel port module sees cable not connected.

#### 4.7 PARALLEL PORT PIN/SIGNAL LIST

Table 4-11 on the following page shows the standard 25-pin, D-type connector definition for various parallel port operations

### Winbond Electronics Corp. Advanced PC Product Center

**TABLE 4-11.** Parallel Port Pin Out

| Connector Pin | PQFP Pin | TQFP Pin | SPP, ECP<br>Mode | I/O | EPP Mode | I/O | PPM Mode<br>and PNF=0 | I/O |
|---------------|----------|----------|------------------|-----|----------|-----|-----------------------|-----|
| 1             | 95       | 93       | STB              | I/O | WRITE    | I/O | -                     | I   |
| 2             | 94       | 92       | PD0              | I/O | PD0      | I/O | INDEX                 | ı   |
| 3             | 93       | 91       | PD1              | I/O | PD1      | I/O | TRK0                  | ı   |
| 4             | 92       | 90       | PD2              | I/O | PD2      | I/O | WP                    | I   |
| 5             | 91       | 89       | PD3              | I/O | PD3      | I/O | RDATA                 | ı   |
| 6             | 89       | 87       | PD4              | I/O | PD4      | I/O | DSKCHG                | ı   |
| 7             | 88       | 86       | PD5              | I/O | PD5      | I/O | MSEN0                 | ı   |
| 8             | 87       | 85       | PD6              | I/O | PD6      | I/O | DRATE0                | 0   |
| 9             | 86       | 84       | PD7              | I/O | PD7      | I/O | MSEN1                 | ı   |
| 10            | 85       | 83       | ACK              | I   | ACK      | I   | DR1                   | 0   |
| 11            | 84       | 82       | BUSY             | I   | WAIT     | I   | MTR1                  | 0   |
| 12            | 83       | 81       | PE               | I   | PE       | I   | WDATA                 | 0   |
| 13            | 82       | 80       | SLCT             | I   | SLCT     | ı   | WGATE                 | 0   |
| 14            | 78       | 76       | ĀFD              | I/O | DSTRB    | I/O | DENSEL                | 0   |
| 15            | 79       | 77       | ERR              | I   | ERR      | I   | HDSEL                 | 0   |
| 16            | 80       | 78       | ĪNIT             | I/O | ĪNIT     | I/O | DIR                   | 0   |
| 17            | 81       | 79       | SLIN             | I/O | ASTRB    | I/O | STEP                  | 0   |
| 18 - 23       |          |          | GND              |     | GND      |     | GND                   |     |
| 24            | 49       | 47       | PNF = 1          | I   | PNF = 1  | ı   | PNF = 0               | I   |
| 25            |          |          | GND              |     | GND      |     | GND                   |     |

### 5.0 UART with Fast IR

This section describes the functionality of the Legacy UART (16450/16550), Enhanced UART and IR modes.

UART1 supports standard 16450/16550 mode. (In the PC97338 it supports Enhanced mode as well.)

UART2 supports standard 16450/16550, Enhanced UART and IR modes.

UART1 is a subset of UART2 functionality. It supports UART mode hard-wired communications, but does not support IR communication. Therefore, all explanations of IR communication in this section do not apply to UART1.

The UART module provides advanced, versatile serial communications features with infrared capabilities. It supports six modes of operation: UART, Sharp-IR, IrDA 1.0 SIR, IrDA 1.1 MIR, IrDA 1.1 FIR, and Consumer-IR (also called TV-Remote or Consumer remote-control). In this section, the IrDA modes are referred to by their abbreviated names. e.g. SIR, MIR and FIR. In UART mode, the module can function as a standard 16450 or 16550, or as an Extended UART.

Existing 16550-based legacy software is completely and transparently supported. Module organization and specific fallback mechanisms switch the module to 16550 compatibility mode upon reset or when initialized by 16550 software.

The module includes two DMA channels that can support all operational modes. The device can use either one or two DMA channels. One channel is required for infrared based applications since infrared communications work in half duplex fashion. Two channels would normally be needed to handle high-speed full duplex UART based applications.

The module includes a 12-bit 125  $\mu$ sec resolution timer that simplifies driver design and infrared communications protocol implementation.

Note that UART2's wake up mode depends on CFG0 strap pin, as follows:

- If during reset CFG0=0, UART2 wakes up in SIR mode.
- If during reset CFG0=1, UART2 wakes up in UART mode.

#### 5.1 FEATURES

- Fully compatible with 16550A and 16450 devices
- Automatic fallback to 16550A compatibility mode
- Extended UART mode
- UART baud rates up to 1.5 Mbps
- Sharp-IR with selectable internal or external modulation/demodulation
- SIR with data rates up to 115.2 Kbps

- MIR and FIR with data rates of 0.576, 1.152 and 4.0 Mbps
- Consumer-IR (TV-Remote) mode
- Back-to-back infrared frame transmission and reception
- Full duplex infrared capability for diagnostics
- Transmission deferral (in fast IR modes)
- IrDA modes pipelining
- Selectable 16 or 32-level transmission and reception FIFOs (RX\_FIFO & TX\_FIFO respectively)
- 8-level ST FIFO (ST FIFO)
- Multiple optical transceiver support
- Automatic or manual transceiver configuration
- 12-bit timer for infrared protocol support

#### 5.2 FUNCTIONAL MODES OVERVIEW

This multi-mode module can be configured to act as any one of several different functions. Although each mode is unique, certain system resources and features are common to some or to all modes.

# 5.2.1 UART Modes: 16450 or 16550, and Extended

UART modes support serial data communications with a remote peripheral device or modem using a wired interface. The device transmits and receives data concurrently in full-duplex operation, performing parallel-to-serial and serial-to-parallel conversion and other functions required to exchange parallel data with the system. It also interfaces with external devices using a programmable serial communications format.

The UART modes supported are:

- 16450 or 16550 mode (Non-Extended modes)
- Extended mode

The 16450 or 16550 mode is functionally and software-compatible with the standard 16450 or 16550 UARTs. This is the default mode of operation after power up, after reset or when initialized by software written for the 16450 or 16550 UART (Special mechanisms switch the module automatically to 16550 UART mode when standard 16550 software is run).

The 16550 UART mode has all the features of the 16450 mode, with the addition of 16-byte data FIFOs for more efficient data I/O.

In Extended mode, additional features become available that enhance the UART performance, such as timer access, additional interrupts and DMA ability (See "Extended UART Mode" on page 132)

The UART supports baud rates of up to 115.2 Kbps in 16450 or 16550 mode, and up to 1.5 Mbps in Extended mode.

### 5.2.2 Sharp-IR and SIR Infrared Modes

The Sharp-IR mode provides bidirectional communication by transmitting and receiving infrared radiation. In this mode, infrared I/O circuits was added to the UART, which operates at 38.4 Kbps in half-duplex, using normal UART serial data formats with Digital Amplitude Shift Keying (DASK) modulation. The modulation/demodulation can be operated internally or externally.

In SIR mode, the system functions similarly to the Sharp-IR mode, but at 115.2 Kbps.

# 5.2.3 High Speed Infrared Modes: MIR and FIR

The infrared support of this module includes both MIR and FIR modes, with data rates of 567 Kbps, 1.152 Mbps and 4.0 Mbps. The data format differs from the previous infrared modes. Those modes relay word-oriented data formats produced by the UART via infrared I/O circuits. In the fast infrared modes, a frame-oriented serial format is employed instead of word-oriented. These changes enable more efficient channel data bandwidth utilization and more effective error detection/correction.

#### 5.2.4 Consumer IR Mode

Consumer-IR mode supports all the protocols presently used in remote-controlled home entertainment equipment: RC-5, RC-6, RECS 80, NEC and RCA. Like the high-speed IR modes, the serial format is not compatible with UART operation, and specific circuitry performs all the hardware tasks required for signal conditioning and formatting. The software is responsible for the generation of the infrared code to be transmitted, and for the interpretation of the received code.

#### 5.3 REGISTER BANK OVERVIEW

Eight register banks, each containing eight registers, control UART operation. All registers use the same 8-byte address space to indicate offsets 00h through 07h, and the active bank must be selected by the software.

The register bank organization enables access to the banks as required for activation of all module modes, while maintaining transparent compatibility with 16450 or 16550 software, which activates only the registers and specific bits used in those devices. For details, See Section 5.4.

The Bank Selection Register (BSR) selects the active bank and is common to all banks. See Figure 5-1. Therefore, each bank defines seven new registers.



FIGURE 5-1. Register Bank Architecture

The default bank selection after system reset is 0, which places the module in the UART 16550 mode. Additionally, setting the baud rate in bank 1 (as required to initialize the 16550 UART) switches the module to a Non-Extended UART mode. This ensures that running existing 16550 software will switch the system to the 16550 configuration without software modification.

Table 5-1 shows the main functions of the registers in each bank. Banks 0-3 control both UART and infrared modes of operation; banks 4-7 control and configure the infrared modes only.

**TABLE 5-1. Register Bank Summary** 

| Bank | UART | IR<br>Mode | Main Functions                                         |
|------|------|------------|--------------------------------------------------------|
| 0    | ✓    | ✓          | Global Control and Status                              |
| 1    | ✓    | ✓          | Legacy Bank                                            |
| 2    | ✓    | ✓          | Baud Generator Divisor,<br>Extended Control and Status |
| 3    | ✓    | ✓          | Module Revision ID and Shadow Registers                |
| 4    |      | 1          | Timer and Counters                                     |

| Bank | UART | IR<br>Mode | Main Functions                                    |
|------|------|------------|---------------------------------------------------|
| 5    |      | ✓          | Infrared Control and ST_FIFO                      |
| 6    |      | ✓          | Infrared Physical Layer<br>Configuration          |
| 7    |      | ✓          | Consumer-IR and Optical Transceiver Configuration |

Banks 0 and 1 are the 16550 register banks. The registers in these banks are equivalent to the registers contained in the 16550 UARTs and are accessed by 16550 software drivers as if the module was a 16550. Bank 1 contains the baud rate divisor ports. Bank 0 registers control all other aspects of the UART function, including data transfers, format setup parameters, interrupt setup and status monitoring.

Bank 2 registers contain the non-legacy Baud Generator Divisor ports, and control the extended features special to this UART, that are not included in the 16550 repertoire. These include DMA and timer usage. See "Extended UART Mode" on page 132.

Bank 3 contains the Module Revision ID and shadow registers. The Module Revision ID (MRID) register contains a code that identifies the revision of the module when read by software. The shadow registers contain the identical content as reset-whenread registers within bank 0. Reading their contents from the shadow registers lets the system read the register content without resetting them.

Bank 4 contains counter and timer access registers. The 12-bit timer may be used by the UART in Extended mode, or by the infrared modes. The counters are used by the fast infrared modes which communicate in frame-oriented formats and need to count frame lengths for control.

**Bank 5** registers control infrared parameters related to the logical system I/O parameters, and the ST FIFO used in fast infrared communications.

**Bank 6** registers control physical characteristics involved in infrared communications (e.g. pulse width selection).

**Bank 7** registers are dedicated to Consumer-IR configuration and control.

# 5.4 UART MODES – DETAILED DESCRIPTION

The UART modes support serial data communications with a remote peripheral device or modem using a wired interface. The module provides receive and transmit channels that can operate concurrently in full-duplex mode. This module performs all functions required to conduct parallel data interchange with the system and composite serial data exchange with the external data channel, including:

- Format conversion between the internal parallel data format and the external programmable composite serial format. See Figure 5-2.
- Serial data timing generation and recognition
- Parallel data interchange with the system using a choice of bi-directional data transfer mechanisms
- Status monitoring for all phases of the communications activity

The module supplies modem control registers, and a prioritized interrupt system for efficient interrupt handling.

### 5.4.1 16450 or 16550 UART Mode

The module defaults to 16450 mode after power up or reset. UART 16550 mode is equivalent to 16450 mode, with the addition of a 16-byte data FIFO for more efficient data I/O. Transparent compatibility is preserved with this UART mode in this module.

Despite the many additions to the basic UART hardware and organization, the UART responds correctly to existing software drivers with no software modification required. When 16450 software initializes and addresses this module, it will in always perform as a 16450 device.

Data transfer takes place by use of data buffers that interface internally in parallel and with the external data channel in a serial format. 16-byte data FIFOs may reduce host overhead by enabling multiple-byte data transfers within a single interrupt. With FIFOs disabled, this module is equivalent to the standard 16450 UART. With FIFOs enabled, the hardware functions as a standard 16550 UART.

The composite serial data stream interfaces with the data channel through signal conditioning circuitry such as TTL/RS232 converters, modem tone generators, etc.

Data transfer is accompanied by software-generated control signals, which may be utilized to activate the communications channel and "handshake" with the remote device. These may be supplied directly by the UART, or generated by control interface circuits such as telephone dialing and answering circuits, etc.



FIGURE 5-2. Composite Serial Data

The composite serial data stream produced by the UART is illustrated in Figure 5-2. A data word containing five to eight bits is preceded by start bits and followed by an optional parity bit and a stop bit. The data is clocked out, LSB first, at a predetermined rate (the baud rate).

The data word length, parity bit option, number of start bits and baud rate are programmable parameters.

The UART includes a programmable baud rate generator that produces the baud rate clocks and associated timing signals for serial communication.

The system can monitor this module status at any time. Status information includes the type and condition of the transfer operation in process, as well as any error conditions (e.g., parity, over-run, framing, or break interrupt).

The module resources include modem control capability and a prioritized interrupt system. Interrupts can be programmed to match system requirements, minimizing the CPU overhead required to handle the communications link.

#### **Programmable Baud Rate Generator**

This module contains a programmable baud rate generator that generates the clock rates for serial data communication (both transmit and receive channels). It divides its input clock by any divisor value from 1 to 2<sup>16</sup> - 1. The output clock frequency of the baud generator must be programmed to be sixteen times the baud rate value. A 24 MHz input frequency is divided by a prescale value (PRESL field of EXCR2 - see page 158. Its default value is 13) and by a 16-bit programmable divisor value contained in the Baud Generator Divisor High and Low registers (BGD(H) and BGD(L) - see page 156). Each divisor value vields a clock signal (BOUT) and a further division by 16 produces the baud rate clock for the serial data stream. It may also be output as a test signal when enabled (see bit 7 of EXCR1 on page 157.)

These user-selectable parameters enable the user to generate a large choice of serial data rates, including all standard baud rates. A list of baud rates and their settings appears in Table 5-12 on page 155.

#### **Module Operation**

Before module operation can begin, both the communications format and baud rate must be programmed by the software. The communications format is programmed by loading a control byte into the LCR register, while the baud rate is selected by loading an appropriate value into the baud generator divisor registers and the divisor preselect values (PRESL) into EXCR2 (see page 158).

The software can read the status of the module at any time during operation. The status information includes full or empty state for both transmission and reception channels, and any other condition detected on the received data stream, like parity error, framing error, data over-run, or break event.

#### 5.4.2 Extended UART Mode

In Extended UART mode of operation, the module configuration changes and additional features become available which enhance UART capabilities.

- The interrupt sources are no longer prioritized; they are presented bit-by-bit in the EIR (see page 143).
- An auxiliary status and control register replaces the scratchpad register. It contains additional status and control flag bits ("Auxiliary Status and Control Register (ASCR), Bank 0, Offset 07h" on page 152).
- The TX\_FIFO can generate interrupts when the number of outgoing bytes in the TX\_FIFO drops below a programmable threshold. In the Non-Extended UART modes, only reception FIFOs have the thresholding feature.
- DMA capability is available.
- Interrupts occur when the transmitter becomes empty or a DMA event occurs.

# 5.5 SHARP-IR MODE – DETAILED DESCRIPTION

This mode supports bidirectional data communication with a remote device using infrared radiation as the transmission medium. Sharp-IR uses Digital Amplitude Shift Keying (DASK) and allows serial communication at baud rates up to 38.4 Kbaud. The format of the serial data is similar to the UART data format. Each data word is sent serially beginning with a zero value start bit, followed by up to eight data bits (LSB first), an optional parity bit, and ending with at least one stop bit with a binary value of one. A logical zero is signalled by sending a 500 KHz continuous pulse train of infrared radiation. A logical 1 is signalled by the absence of any infrared signal. This module can perform the modulation and demodulation operations internally, or can rely on the external optical module to perform them.

Sharp-IR device operation is similar to the operation in UART modes, the main difference being that data transfer operations are normally performed in half duplex fashion, and the modem control and status signals are not used. Selection of the Sharp-IR mode is controlled by the Mode Select (MDSL) bits in the

MCR register when the module is in Extended mode, or by the IR\_SL bits in the IRCR1 register when the module is not in extended mode. This prevents legacy software, running in non-extended mode, from spuriously switching the module to UART mode, when the software writes to the MCR register.

# 5.6 SIR MODE – DETAILED DESCRIPTION

This operational mode supports bidirectional data communication with a remote device using infrared radiation as the transmission medium.

SIR allows serial communication at baud rates up to 115.2 Kbuad. The serial data format is similar to the UART data format. Each data word is sent serially beginning with a 0 value start bit, followed by eight data bits (LSB first), an optional parity bit, and ending with at least one stop bit with a binary value of 1.

A zero value is signalled by sending a single infrared pulse. A one value is signalled by not sending any pulse. The width of each pulse can be either 1.6  $\mu$ sec or 3/16 of the time required to transmit a single bit. (1.6  $\mu$ sec equals 3/16 of the time required to transmit a single bit at 115.2 Kbps). This way, each word begins with a pulse for the start bit.

The module operation in SIR is similar to the operation in UART modes, the main difference being that data transfer operations are normally performed in half duplex fashion. Selection of the SIR mode is controlled by the MDSL bits in the MCR register when the UART is in Extended mode, or by the IR\_SL bits in the IRCR1 register when the UART is not in Extended mode. This prevents legacy software, running in Non-Extended mode, from spuriously switching the module to UART mode, when the software writes to the MCR register.

# 5.7 MIR AND FIR MODES – DETAILED DESCRIPTION

This module supports both MIR and FIR modes, with data rates of 576 Kbps, 1.152 Mbps and 4.0 Mbps.

These high-speed modes differ from the previous communications modes in that the communication is now frame-oriented rather than word-oriented. Details on the frame format, encoding schemes, CRC sequences, etc. are provided in the appropriate IrDA documents. These modes do not use the same serial word formats as the UART modes; they generate complete frames of data which can be transferred faster, more efficiently and with more sophisticated error detection or correction than word-oriented transmission.

The MIR transmitter's front end performs bit stuffing on the outbound data stream and places start and stop flags at the beginning and end of MIR frames. The MIR receiver's front-end removes flags and "destuffs" the inbound bit stream, and checks for abort conditions.

The FIR transmitter's front end adds a preamble as well as start and stop flags to each frame, and encodes the transmission data into a 4 ppm (Pulse Position Modulation) data stream. The FIR receiver's front end strips the preamble and flags from the inbound data stream and decodes the 4 ppm data, while also checking for coding violations.

Both MIR and FIR front ends also automatically append CRC sequences to transmitted frames and check for CRC errors on received frames.

# 5.7.1 High-Speed Infrared Transmission

Transmission of a frame begins when the CPU or the DMA controller writes data into the TX\_FIFO while it is empty.

Frame transmission can be completed normally by using one of the following methods:

 S\_EOT bit (Set End of Transmission), bit 2 in ASCR Register, in Bank 0 Offset 07h.

This method is used when data transfers are performed in Programmed I/O (PIO) mode. When the CPU sets the S\_EOT bit before writing the last byte into the TX\_FIFO, the byte is tagged with an End-Of-Frame (EOF) indication. When this byte reaches the TX\_FIFO bottom, and is read by the transmitter front end, a CRC is appended to the transmitted data and the frame is normally terminated.

DMA TC signal (DMA Terminal Count)

This method is used when data transfers are performed in DMA mode. It works similarly to the previous method except that the tagging of the last byte of a frame occurs when the DMA controller asserts the TC signal during a write of the last byte to the TX FIFO.

Frame Length Counter

This method can be used when data transfers are performed in either PIO or DMA mode. The value of the FEND\_MD bit in the IRCR2 register determines whether the Frame Length Counter is effective in the PIO or DMA mode.

The counter is loaded from the frame length register (TFRL) at the beginning of each frame, and is decremented as each byte is transmitted. An EOF is generated when the counter reaches zero. When used in DMA mode with an 8237 type DMA controller, if the block size is not an exact multiple of the frame size, this method allows a large data

block to be automatically split into equal-size back-to-back frames, plus a shorter frame that is terminated by the DMA TC signal if the block size is not an exact multiple of the frame size.

An option is also provided to stop transmission at the end of each frame. This happens when the transmitter frame-end stop mode is selected (TX\_MS bit in IRCR2 register set to 1).

By using this option, the software can send frames of different sizes without re-initializing the DMA controller for each frame. After transmission of each frame, the transmitter stops and generates an interrupt. The software loads the length of the next frame into the TFRL register and restarts the transmitter by clearing the TXHFE bit in the ASCR register.

Note: PIO or DMA mode is controlled by setting the DMA\_EN bit in the extended-mode MCR register. DMA cycles always access the Transmission or RX\_FIFO, regardless of the selected bank. In PIO mode, Bank 0 must be selected to enable CPU access to the FIFOs. When DMA\_EN is set to 1 (DMA enabled) the CPU may access the RX\_FIFO and the TX\_FIFO, but these accesses will be treated as DMA accesses as far as the function of the FEND\_MD bit in the IRCR2 (see page 165) is concerned.

#### **Under-Run Event Description**

While a frame is being transmitted, data must be written to the TX\_FIFO at a rate dictated by the transmission speed. If the CPU or DMA controller fails to meet this requirement, a transmitter under-run occurs, an inverted CRC is appended to the frame being transmitted, and the frame is terminated with a stop flag. Data transmission then stops. Transmission of the inverted CRC ensures that the remote receiving device will receive the frame with a CRC error and will discard it.

Following an under-run condition, data transmission always stops at the next frame boundary. The frame bytes from the point where the under-run occurred to the end of the frame are not sent out to the external infrared interface. Nonetheless, they are removed from the TX\_FIFO by the transmitter and discarded. The under-run indication is reported only when the transmitter detects the end of frame via one of the methods described above.

The software can do various things to recover from an under-run condition. For example, the software can simply clear the under-run condition by writing a 1 into bit 6 of ASCR and retransmit the under-run frame later, or it can retransmit the under-run frame immediately, before transmitting other frames.

If the software chooses to retransmit the frame immediately, it must perform the following steps:

1. Disable DMA, if DMA mode was selected.

- Read the TXFLV register to determine the number of bytes in the TX\_FIFO.(This is needed to determine the exact point where the under-run occurred, and whether or not the first byte of a new frame is in the TX\_FIFO).
- 3. Reset the TX\_FIFO.
- 4. Backup DMA controller registers.
- 5. Clear the transmission under-run bit.
- 6. Re-enable DMA controller.

### 5.7.2 High Speed Infrared Reception

When the receiver's front end detects an incoming frame, it starts de-serializing the infrared bit stream and loads the resulting data bytes into the RX\_FIFO. When the EOF is detected, two or four CRC bytes are appended to the received data, and an EOF flag is written into the tag section of the RX\_FIFO along with the last byte. In the present implementation, the CRC bytes are always transferred to the RX\_FIFO following the data.

Additional status information, related to the received frame, is also written into the RX\_FIFO tag section along with the last byte. The status information will be loaded into the LSR register when the last frame byte reaches the bottom of the RX\_FIFO. The receiver counts received bytes from the beginning of the current frame, and will only transfer to the RX\_FIFO a number of bytes not exceeding the max frame length value (programmed via the RFRML register in bank 4). If any additional frame bytes are present they are discarded and the MAX\_LEN error flag is set.

Although data can be transferred from the RX\_FIFO to memory in either PIO or DMA mode, DMA mode should be used due to the high data rates.

An eight-level **ST\_FIFO** is provided to handle backto-back incoming frames, when DMA mode is selected and an 8237 type DMA controller is used.

When an End-Of-Frame (EOF) mark is detected in 8237 DMA mode, the status and byte count information for the frame is written into the ST\_FIFO. An interrupt is also generated when the ST\_FIFO level reaches a programmed threshold or a ST\_FIFO timeout occurs.

The CPU uses this information to locate the frame boundaries in the memory buffer where data belonging to several received frames has been transferred by the 8237 type DMA controller.

The ST\_FIFO and the received frame length can be used to determine the validity and the position of the received frames inside the reception buffer.

If the RX\_FIFO and/or the ST\_FIFO fills up during multiple frames reception due to the DMA controller or CPU not serving them in time, data frames might be crushed and lost. This means that no bytes belonging to these frames were written to the RX\_FIFO. In fact, a frame will be lost in 8237 DMA mode when

the ST\_FIFO is full for the entire time during which the frame is being received, even though there were empty locations in the RX\_FIFO. This is because no data bytes can be loaded into the RX\_FIFO, and then transferred to memory by the DMA controller, unless there is at least one available entry in the ST\_FIFO to store the number of received bytes. This information, as mentioned before, is needed by the software to locate the frame boundaries in the DMA memory buffer.

In the event that a number of frames are lost, for any of the reasons mentioned above, one or more lost-frame indications including the number of lost frames, are loaded into the ST FIFO.

Frames can also be lost in PIO mode, but only when the RX\_FIFO is full. The reason for that, in these cases, is that the ST\_FIFO stores only lost-frame indications, not frame status or byte counts.

# 5.8 CONSUMER-IR MODE – DETAILED DESCRIPTION

The Consumer-IR circuitry in this module is designed to optimally support all the major protocols presently used in remote-controlled home entertainment equipment: RC-5, RC-6, RECS 80, NEC and RCA.

This module, in conjunction with an external optical device, provides the physical layer functions necessary to support these protocols. These functions include: modulation, demodulation, serialization, deserialization, data buffering, status reporting, interrupt generation, etc.

The software is responsible for the generation of the infrared code to be transmitted, and for the interpretation of the received code.

#### 5.8.1 Consumer-IR Transmission

The code to be transmitted consists of a sequence of bytes that represent either a bit string or a set of runlength codes. The number of bits or run-length codes usually needed to represent each infrared code bit depends on the infrared protocol to be used. The RC-5 protocol, for example, needs two bits or between one and two run-length codes to represent each infrared code bit.

Transmission is initiated when the CPU or DMA module writes code bytes into the empty TX\_FIFO. Transmission is normally completed when the CPU sets the S\_EOT bit in the ASCR register (See Section 5.13.9 on page 152), before writing the last byte, or when the DMA controller activates the TC (terminal count) signal. Transmission will also terminate if the CPU simply stops transferring data and the transmitter becomes empty. In this case, however, a transmitter-under-run condition will be generated, which must be cleared in order to begin the next transmission.

The transmission bytes are either de-serialized or run-length encoded, and the resulting bit string modulates a carrier signal and is sent to the transmitter LED. The transfer rate of this bit string, like in the UART modes, is determined by the value programmed in the baud generator divisor registers. Unlike a UART transmission, start, stop and parity bits are not included in the transmitted data stream. A logic 1 in the bit string keeps the LED off, so no infrared signal is transmitted. A logic 0, generates a sequence of modulating pulses which will turn on the transmitter LED. Frequency and pulse width of the modulating pulses are programmed by the MCFR and MCPW fields in the IRTXMC register as well as the TXHSC bit in the RCCFG register. Sections 5.20.2 and 5.20.3 describe these registers in detail.

The RC\_MMD field selects the transmitter modulation mode. If C\_PLS mode is selected, modulating pulses are generated continuously for the entire logic 0 bit time. If 6\_PLS or 8\_PLS mode is selected, six or eight pulses are generated each time a logic 0 bit is transmitted following a logic 1 bit. The total transmission time for the logic 0 bits must be equal-to or greater-than 6 or 8 times the period of the modulation subcarrier, otherwise, fewer pulses will be transmitted.

C\_PLS modulation mode is used for RC-5, RC-6, NEC and RCA protocols. 8\_PLS or 6\_PLS modulation mode is used for the RECS 80 protocol. The 8\_PLS or 6\_PLS mode allows minimization of the number of bits needed to represent the RECS 80 infrared code sequence. The current transmitter implementation supports only the modulated modes of the RECS 80 protocol. It does not support Flash mode.

### 5.8.2 Consumer-IR Reception

The Consumer-IR receiver is significantly different from a UART receiver in two ways. Firstly, the incoming infrared signals are DASK modulated. Therefore, demodulation may be necessary. Secondly, there are no start bits in the incoming data stream.

Whenever an infrared signal is detected, receiver operations depend on whether or not receiver demodulation is enabled. If demodulation is disabled, the receiver immediately becomes active. If demodulation is enabled, the receiver checks the carrier frequency of the incoming signal, and becomes active only if the frequency is within the programmed range. Otherwise, the signal is ignored and no other action is taken.

When the receiver enters the active state, the RXACT bit in the ASCR register is set to 1. Once in the active state, the receiver keeps sampling the infrared input signal and generates a bit string where a logic 1 indicates an idle condition and a logic 0 indicates the presence of infrared energy. The infrared input is sampled regardless of the presence of infrared puls-

es at a rate determined by the value loaded into the baud generator divisor registers. The received bit string is either de-serialized and assembled into 8-bit characters, or it is converted to run-length encoded values. The resulting data bytes are then transferred into the RX FIFO.

The receiver also sets the RXWDG bit in the ASCR register each time an infrared pulse signal is detected. This bit is automatically cleared when the ASCR register is read, and it is intended to assist the software in determining when the infrared link has been idle for a certain time. The software can then stop the data reception by writing a 1 into the RXACT bit to clear it and return the receiver to the inactive state.

The frequency bandwidth for the incoming modulated infrared signal is selected by the DFR and DBW fields in the IRRXDC register.

There are two Consumer-IR reception data modes: "Oversampled" and "Programmed T Period" mode. For either mode the sampling rate is determined by the setting of the baud generator divisor registers.

The "Over-sampled" mode can be used with the receiver demodulator either enabled or disabled. It should be used with the demodulator disabled when a detailed snapshot of the incoming signal is needed, for example to determine the period of the carrier signal. If the demodulator is enabled, the stream of samples can be used to reconstruct the incoming bit string. To obtain good resolution, a fairly high sampling rate should be selected.

The "Programmed-T-Period" mode should be used with the receiver demodulator enabled. The T Period represents one half bit time for protocols using biphase encoding, or the basic unit of pulse distance for protocols using pulse distance encoding. The baud rate is usually programmed to match the T Period. For long periods of logic low or high, the receiver samples the demodulated signal at the programmed sampling rate.

Whenever a new infrared energy pulse is detected, the receiver synchronizes the sampling process to the incoming signal timing. This reduces timing related errors and eliminates the possibility of missing short infrared pulse sequences, especially with the RECS 80 protocol.

In addition, the "Programmed-T-Period" sampling minimizes the amount of data used to represent the incoming infrared signal, therefore reducing the processing overhead in the host CPU.

#### 5.9 FIFO TIME-OUTS

Time-out mechanisms prevent received data from remaining in the RX\_FIFO and/or the ST\_FIFO indefinitely, if the programmed interrupt or DMA thresholds are not reached.

An RX\_FIFO time-out generates a Receiver Data Ready interrupt and/or a receiver DMA request if bit 0 of IER and/or bit 2 of MCR (in Extended mode) are set to 1 respectively. An RX\_FIFO time-out also sets bit 0 of ASCR to 1 if the RX\_FIFO is below the threshold. When a Receiver Data Ready interrupt occurs, this bit is tested by the software to determine whether a number of bytes indicated by the RX\_FIFO threshold can be read without checking bit 0 of the LSR register.

A ST\_FIFO time-out is enabled only in MIR and FIR modes, and generates an interrupt if bit 6 of IER is set to 1

The conditions that must exist for a time-out to occur in the various modes of operation are described below.

When a time-out has occurred, it can only be reset when the FIFO is read by the CPU or DMA controller.

# 5.9.1 MIR or FIR Mode Time-Out Conditions

**An RX\_FIFO time-out** occurs when all of the following are true:

· At least one byte is in the RX FIFO

and

 More than 64 µsec have elapsed since the last byte was loaded into the RX\_FIFO from the receiver logic

and

 More than 64 µsec have elapsed since the last byte was read from the RX\_FIFO by the CPU or DMA controller.

A ST\_FIFO time-out occurs when all of the following are true:

At least one entry is in the ST\_FIFO

and

 More than 1 msec has elapsed since the last entry was loaded into the RX\_FIFO by the receiver logic

and

 More than 1 msec has elapsed since the last entry was read from the ST\_FIFO by the CPU.

# 5.9.2 UART, SIR or Sharp-IR Mode Time-Out Conditions

Two timers (timer1 and timer 2) are used to generate two different time-out events (A and B, respectively). Timer 1 times out after 64  $\mu sec$ . Timer 2 times out after four character times.

Time-out event A generates an interrupt and sets the RXF\_TOUT bit (bit 0 of ASCR) when all of the following are true:

· At least one byte is in the RX FIFO, and

- More than 64 µsec or four character times, whichever is greater, have elapsed since the last byte was loaded into the RX\_FIFO from the receiver logic, and
- More than 64 µsec or four character times, whichever is greater, have elapsed since the last byte was read from the RX\_FIFO by the CPU or DMA controller.

Time-out event B activates the receiver DMA request and is invisible to the software. It occurs when all of the following are true:

- At least one byte is in the RX FIFO, and
- More than 64 µsec or four character times, whichever is smaller, have elapsed since the last byte was loaded into the RX\_FIFO from the receiver logic, and
- More than 64 µsec or four character times, whichever is smaller, have elapsed since the last byte was read from the RX\_FIFO by the CPU or DMA controller.

# 5.9.3 Consumer-IR Mode Time-out Conditions

The RX\_FIFO time-out, in Consumer-IR mode, is disabled while the receiver is active. It occurs when all of the following are true:

- At least one byte has been in the RX\_FIFO for 64 μsec or more, and
- The receiver has been inactive (RXACT = 0) for 64 μsec or more, and
- More than 64 µsec have elapsed since the last byte was read from the RX\_FIFO by the CPU or DMA controller.

#### 5.9.4 Transmission Deferral

This feature allows software to send short high-speed data frames in Programmed Input/Output (PIO) mode without the risk of generating a transmitter under-run.

Although this feature is available and works identically in all the Extended modes, its use will most likely be confined to MIR and FIR modes to support high-speed negotiation. (In other modes, either the relatively slow transmission data rate lets the CPU keep up without letting an under-run occur, as in the case of the Consumer-IR mode, or else transmission under-runs are allowed and are not considered to be error conditions.

Transmission deferral is available only in Extended mode and when the TX\_FIFO is enabled. When transmission deferral is enabled (TX\_DFR bit in the MCR register set to 1) and the transmitter becomes empty, an internal flag is set that locks the transmitter. If the CPU now writes data into the TX\_FIFO, the

transmitter does not start sending the data until the TX\_FIFO level reaches either 14 for a 16-level TX\_FIFO, or 30 for a 32-level TX\_FIFO, at which time the internal flag is cleared. The internal flag is also cleared and the transmitter starts transmitting when a time-out condition is reached. This prevents some bytes from being in the TX\_FIFO indefinitely if the threshold is not reached.

The time-out mechanism is implemented by a timer that is enabled when the internal flag is set and there is at least one byte in the TX\_FIFO. Whenever a byte is loaded into the TX\_FIFO the timer gets reloaded with the initial value. If no bytes are loaded for a 64-usec time, the timer times out and the internal flag is cleared, thus enabling the transmitter.

# 5.10 AUTOMATIC FALLBACK TO A NON-EXTENDED UART MODE

The automatic fallback feature supports existing legacy software packages that use the 16550 UART by automatically turning off any Extended mode features and switches the UART to Non-Extended mode when either of the LBGD(L) or LBGD(H) ports in bank 1 is read from or written to by the CPU.

This eliminates the need for user intervention prior to running a legacy program.

In order to avoid spurious fallbacks, alternate baud rate registers are provided in bank 2. Any program designed to take advantage of the UART's extended features, should not use LBGD(L) and LBGD(H) to change the baud rate. It should use the BGD(L) and BGD(H) registers instead. Access to these ports will not cause fallback.

Fallback can occur in any mode. In Extended UART mode, fallback is always enabled. In this case, when a fallback occurs, the following happens:

- Transmission and Reception FIFOs switch to 16 levels
- A value of 13 is selected for the baud generator prescaler
- The BTEST and ETDLBK bits in the EXCR1 register are cleared.
- UART mode is selected.
- A switch to a Non-Extended UART mode occurs.

When a fallback occurs in a Non-Extended UART mode, the last two of the above actions do not take place.

No switch to UART modes occurs if either SIR or Sharp-IR modes was selected. This prevents spurious switching to UART modes when a legacy program running in infrared mode accesses the baud generator divisor registers from bank 1.

Fallback from a Non-Extended mode can be disabled by setting the LOCK bit in register EXCR2. When LOCK is set to 1 and the UART is in a Non-Extended mode, two scratch registers overlaid with LBGD(L) and LBGD(H) are enabled. Any attempted CPU access of LBGD(L) and LBGD(H) accesses the scratch registers, and the baud rate setting is not affected. This feature allows existing legacy programs to run faster than 115.2 Kbps.

### 5.11 PIPELINING

When successive Infrared serial data streams must be communicated using the UART, the system can be pre-programmed to switch between different serial formats and different infrared modes by hardware, without software intervention during the process. This saves time and reduces system overhead. This automatic switching process between communication modes is called pipelining.

Pipelining minimizes the delay from the end of a negotiation phase to the subsequent data transfer phase in the IrDA infrared operation modes (SIR, MIR and FIR). The module does this by automatically selecting a new infrared operation mode and/or loading new values into the baud rate generator divisor registers as soon as the current data transmission completes and the transmitter becomes empty. The new operation mode and baud rate generator divisor values are programmed into special pipeline registers.

Pipelining is automatically disabled after a pipeline operation takes place. Software should enable pipelining again after the special pipeline registers are reloaded.

The only restriction on the pipelined operation modes is that they must be IrDA modes. Nevertheless, SIR mode will most likely be the first operation mode in a pipeline, since SIR is the operation mode used by the negotiation procedures in the presently defined IrDA protocols.

Following a pipeline operation, the transmitter will be halted for 250  $\mu$ sec to allow the newly selected receiver filter in the remote optical transceiver to stabilize.

If a switch from either MIR or FIR to SIR operation mode occurs as a result of pipelining, and the transmitter sent an infrared interaction pulse just before the mode switch, assertion of the transmitter DMA request signal is delayed by a character time (at the newly selected baud rate) or for 250  $\mu$ sec, whichever is greater. This prevents transmission of the next SIR operation mode data from starting before completion of reception at the remote station of the character triggered by the interaction pulse.

Since pipelining occurs without software intervention, automatic transceiver configuration must be enabled.

# 5.12 OPTICAL TRANSCEIVER INTERFACE

This module implements a flexible interface for the external infrared transceiver. Several signals are provided for this purpose. A transceiver module with one or two reception signals, or two transceiver modules can interface directly with this module without any additional logic.

Since various operational modes are supported by this module, the transmitter power as well as the receiver filter in the transceiver module must be configured according to the selected mode.

This module provides three output pins, IRSL(2-0), to control the infrared transceiver. *In PC97338 this three interface pins are I/O pins, ID/IRSL(2-0). When in input mode, they can be used to read the identification data of Plug-n-Play infrared adapters.* 

When in output mode, the logic levels of IRSL(2-0) can be either controlled directly by the software by setting bits 2-0 of the IRCFG1 register, or they can be automatically selected by this module whenever the operation mode changes.

The automatic transceiver configuration is enabled by setting the AMCFG bit (bit 7) in the IRCFG4 register to 1. It allows the low-level functional details of the transceiver module being used to be hidden from the software drivers. It also speeds up the transceiver mode selection and must be enabled if the pipelining feature is to be used.

The operation mode settings for the automatic configuration are determined by various bit fields in the Infrared Interface Configuration registers (IRCFG[4-1]) that must be programmed when the UART is initialized.

The ID0/IRSL0/IRRX2 pin can also be used as an input to support an additional infrared reception signal. In this case, however, only two configuration pins are available.

The IRSL0\_DS and IRSL21\_DS bits in the IRCFG4 register determines the direction of IRSL(2-0).

# 5.13 BANK 0 – GLOBAL CONTROL AND STATUS REGISTERS

In the Non-Extended modes of operation, bank 0 is compatible with both the 16450 and the 16550. Upon reset, this module defaults to the 16450 mode. In the Extended mode, all the Registers (except RXD/ TXD) offer additional features.

TABLE 5-2. Bank 0 Serial Controller Base Registers

| Offset | Registe r Name | Description                                                   |  |
|--------|----------------|---------------------------------------------------------------|--|
| 00h    | RXD/<br>TXD    | Receiver Data Port/<br>Transmitter Data Port                  |  |
| 01h    | IER            | Interrupt Enable Register                                     |  |
| 02h    | EIR/<br>FCR    | Event Identification Register/<br>FIFO Control Register       |  |
| 03h    | LCR/<br>BSR    | Link Control Register/<br>Bank Select Register                |  |
| 04h    | MCR            | Modem Control Register                                        |  |
| 05h    | LSR            | Link Status Register                                          |  |
| 06h    | MSR            | Modem Status Register                                         |  |
| 07h    | SCR/<br>ASCR   | Scratch Register/<br>Auxiliary Status and Control<br>Register |  |

# 5.13.1 Receiver Data Port (RXD) or the Transmitter Data Port (TXD), Bank 0, Offset 00h

These ports share the same address.

RXD is accessed during CPU read cycles. It is used to read data from the Receiver Holding Register when the FIFOs are disabled, or from the bottom of the RX\_FIFO when the FIFOs are enabled. See Figure 5-3.

TXD is accessed during CPU write cycles. It is used to write data to the Transmitter Holding Register when the FIFOs are disabled, or to the TX\_FIFO when the FIFOs are enabled. See Figure 5-4.

DMA cycles always access the TXD and RXD ports, regardless of the selected bank.

# Receiver Data Port (RXD), Bank 0, Offset 00h



Receiver Data Port (RXD) Bank 0, Offset 00h

FIGURE 5-3. RXD Register Bitmap

#### Bits 7-0 - Received Data

Used to access the Receiver Holding Register when the FIFOs are disabled, or the bottom of the RX FIFO when the FIFOs are enabled.

# Transmitter Data Port (TXD), Bank 0, Offset 00h



FIGURE 5-4. TXD Register Bitmap

#### Bits 7-0 - Transmitted Data

Used to access the Transmitter Holding Register when the FIFOs are disabled or the top of TX\_FIFO when the FIFOs are enabled.

### 5.13.2 Interrupt Enable Register (IER), Bank 0, Offset 01h

This register controls the enabling of various interrupts. Some interrupts are common to all operating modes of the module, while others are mode specific. Bits 4 to 7 can be set in Extended mode only. They are cleared in Non-Extended mode. The bits of the Interrupt Enable Register (IER) are defined differently, depending on the operating mode of the module.

The different modes can be divided into the following five groups:

- Non-Extended (which includes UART, Sharp-IR and SIR).
- UART and Sharp-IR in Extended mode.
- SIR in Extended mode.
- Fast Infrared (MIR & FIR).
- Consumer-IR.

The following five sections describe the bits in this register for each of these modes.

The reset mode for the IER is the Non-Extended UART mode.

When edge-sensitive interrupt triggers are employed, user is advised to clear all IER bits immediately upon entering the interrupt service routine and to re-enable them prior to exiting (or alternatively, to disable CPU interrupts and re-enable prior to exiting). This will guarantee proper interrupt triggering in the interrupt controller in case one or more interrupt events occur during execution of the interrupt routine.

If the LSR, MSR or EIR registers are to be polled, interrupt sources which are identified by self-clearing bits should have their corresponding IER bits set to 0, to prevent spurious pulses on the interrupt output pin.

If an interrupt source must be disabled, the CPU can do so by clearing the corresponding bit in the IER register. However, if an interrupt event occurs just before the corresponding enable bit in the IER register is cleared, a spurious interrupt may be generated. To avoid this problem, the clearing of any IER bit should be done during execution of the interrupt service routine. If the interrupt controller is programmed for level-sensitive interrupts, the clearing of IER bits can also be performed outside the interrupt service routine, but with the CPU interrupt disabled.

# Interrupt Enable Register (IER), in the Non-Extended Modes (UART, SIR and Sharp-IR)

Upon reset, the IER supports UART, SIR and Sharp-IR in the Non-Extended modes. Figure 5-5 shows the bitmap of the Interrupt Enable Register in these modes.

#### **IER in Non-Extended Modes**



FIGURE 5-5. IER Register Bitmap, Non-Extended Mode

### Bit 0 - Receiver High-Data-Level Interrupt Enable (RXHDL IE)

Setting this bit enables interrupts on Receiver High-Data-Level, or RX\_FIFO Time-Out events (EIR Bits 3-0 are 0100 or 1100. See "Non-Extended Mode Interrupt Priorities" on page 144).

- 0 Disable Receiver High-Data-Level and RX\_FIFO Time-Out interrupts (Default).
- Enable Receiver High-Data-Level and RX\_FIFO Time-Out interrupts.

# Bit 1 - Transmitter Low-Data-Level Interrupt Enable (TXLDL IE)

Setting this bit enables interrupts on Transmitter Low Data-Level-events (EIR Bits 3-0 are 0010. See "Non-Extended Mode Interrupt Priorities" on page 144.

- 0 Disable Transmitter Low-Data-Level Interrupts (Default).
- 1 Enable Transmitter Low-Data-Level Interrupts.

#### Bit 2 - Link Status Interrupt Enable (LS\_IE)

Setting this bit enables interrupts on Link Status events. (EIR Bits 3-0 are 0110. See "Non-Extended Mode Interrupt Priorities" on page 144).

- 0 Disable Link Status Interrupts (LS\_EV) (Default).
- 1 Enable Link Status Interrupts (LS\_EV).

#### Bit 3 - Modem Status Interrupt Enable (MS IE)

Setting this bit enables the interrupts on Modem Status events. (EIR Bits 3-0 are 0000. See "Non-Extended Mode Interrupt Priorities" on page 144).

- 0 Disable Modem Status Interrupts (MS\_EV) (Default).
- 1 Enable Modern Status Interrupts (MS EV).

#### Bit 7-4- Reserved

These bits are reserved.

# Interrupt Enable Register (IER), in the Extended Modes of UART and Sharp-IR

Figure 5-6 shows the bitmap of the Interrupt Enable Register in these modes.

#### **Extended Mode of UART and Sharp-IR**



# FIGURE 5-6. IER Register Bitmap, Extended Modes of UART and Sharp-IR

# Bit 0 - Receiver High-Data-Level Interrupt Enable (RXHDL\_IE)

Setting this bit enables interrupts when the RX\_FIFO is equal to or above the RX\_FIFO threshold level, or an RX\_FIFO time out occurs.

- 0 Disable Receiver Data Ready interrupt. (Default)
- Enable Receiver Data Ready interrupt.

# Bit 1 - Transmitter Low-Data-Level Interrupt Enable (TXLDL\_IE)

Setting this bit enables interrupts when the TX\_FIFO is below the threshold level or the Transmitter Holding Register is empty.

- 0 Disable Transmitter Low-Data-Level Interrupts (Default).
- 1 Enable Transmitter Low-Data-Level Interrupts.

#### Bit 2 - Link Status Interrupt Enable (LS\_IE)

Setting this bit enables interrupts on Link Status events.

- 0 Disable Link Status Interrupts (LS\_EV) (Default)
- 1 Enable Link Status Interrupts (LS\_EV).

#### Bit 3 - Modem Status Interrupt Enable (MS\_IE)

Setting this bit enables the interrupts on Modem Status events.

- 0 Disable Modem Status Interrupts (MS\_EV) (Default)
- 1 Enable Modem Status Interrupts (MS\_EV).

#### Bit 4 - DMA Interrupt Enable (DMA IE)

Setting this bit enables the interrupt on terminal count when the DMA is enabled.

- 0 Disable DMA terminal count interrupt (Default)
- 1 Enable DMA terminal count interrupt.

# Bit 5 - Transmitter Empty Interrupt Enable (TXEMP IE)

Setting this bit enables interrupt generation if the transmitter and TX FIFO become empty.

- 0 Disable Transmitter Empty interrupts (Default)
- 1 Enable Transmitter Empty interrupts.

#### Bit 6 - Reserved

This bit is reserved.

#### Bit 7 - Timer Interrupt Enable (TMR\_IE)

Setting this bit enables the timer interrupt.

- 0 Disable Timer Interrupt (Default)
- 1 Enable Timer Interrupt.

# Interrupt Enable Register (IER), in the Extended Mode of SIR

Figure 5-7 shows the bitmap of the Interrupt Enable Register (IER) in this mode.



FIGURE 5-7. IER Register Bitmap, Extended Mode of SIR

#### Bits 4-0

Same as in the Extended Modes of UART and Sharp-IR (see page 141).

# Bit 5 - Transmitter Empty Interrupt Enable (TXEMP\_IE) and Pipeline Load Interrupt Enable (PLD IE)

Enables interrupt generation if the transmitter becomes empty.

When pipeline mode is enabled, the transition from one mode to another is made upon the transmitter becoming empty.

- 0 Disable Transmitter Empty and Pipeline Load interrupts (Default)
- 1 Enable Transmitter Empty and Pipeline Load interrupts.

#### **Bits 7-6**

Same as in the Extended Modes of UART and Sharp-IR (see page 141).

### Interrupt Enable Register (IER), Fast IR (MIR and FIR) Modes, Bank 0, Offset 01h

Figure 5-8 shows the bitmap of the Interrupt Enable Register in these modes.

#### Fast IR (MIR and FIR) Modes Interrupt Enable Register (IER) 0 0 0 0 0 0 0 0 Reset Bank 0, Offset 01h Required RXHDL IE TXLDL IE LS IE/TXUR IE MS IE DMA\_IE TXEMP IE / PLD IE - SFIF\_IE

FIGURE 5-8. IER Register Bitmap, MIR and FIR Modes

#### **Bits 1-0**

TMR IE

Same as in the Extended Modes of UART and Sharp-IR (see page 141).

# Bit 2 - Link Status Interrupt Enable (LS\_IE) or TX\_FIFO Under-run Interrupt Enable (TXUR\_IE)

On reception, Setting this bit enables Link Status Interrupts.

On transmission, Setting this bit enables TX\_FIFO under-run interrupts.

- 0 Disable Link Status and TX\_FIFO Under-run interrupts (Default)
- 1 Enable Link Status and TX\_FIFO Under-run interrupts.

#### Bit 3 - Modem Status Interrupt Enable (MS IE)

Setting this bit, when the IRMSSL bit in the IRCR2 register is cleared to 0, enables the modem status interrupts. Note that by default IRMSSL is set to 1 (See bit 2 of "Infrared Control Register 2 (IRCR2), Bank 5, Offset 04h" on page 165).

- 0 Disable Modem Status Interrupts (MS\_EV) (Default)
- 1 Enable Modem Status Interrupts (MS\_EV).

#### **Bits 5-4**

Same as in the Extended Modes of SIR.

# Bit 6 - ST\_FIFO Threshold Interrupt Enable (SFIF\_IE)

Setting this bit, enables interrupts when the ST\_FIFO level is equal to or above the threshold. This interrupt is cleared when the ST\_FIFO is read and its level drops below the threshold. (It is recomended to use this interrupt to service the ST\_FIFO during back-to-back frame reception).

- 0 Disable ST\_FIFO Threshold Interrupts (Default)
- Enable ST\_FIFO Threshold Interrupts (MS\_EV).

#### Bit 7

Same as in the Extended Modes of SIR (see page 142).

### Interrupt Enable Register (IER), Consumer-IR Mode, Bank 0, Offset 01h

Figure 5-9 shows the bitmap of the Interrupt Enable Register (IER) in this mode.

#### Consumer-IR Mode



FIGURE 5-9. IER Register Bitmap, Consumer-IR Mode

#### **Bits 4-0**

Same as in the Fast IR (see page 142).

#### **Bits 7-5**

Same as in the Extended Modes of UART and Sharp-IR (see page 141).

# 5.13.3 Event Identification Register (EIR), Bank 0, Offset 02h

The Event Identification Register (EIR) and the FIFO Control Register (FCR) (see next register description) share the same address. The EIR is accessed during CPU read cycles while the FCR is accessed during CPU write cycles.

The Event Identification Register (EIR) indicates the interrupt source. The function of this register changes according to the selected mode of operation.

### Event Identi cation Register (EIR), Non-Extended Mode

When Extended mode is not selected (EXT\_SL bit in EXCR1 register is set to 0), this register is the same as in the 16550.

In a Non-Extended UART mode, this module prioritizes interrupts into four levels. The EIR indicates the highest level of the interrupt that is pending. The encoding of these interrupts is shown in Table 5-3.

While the EIR is read, the display of the highest priority pending interrupt is frozen; new interrupt requests are recorded, but the indication is not updated until the access is complete.

#### Non-Extended Modes, Read Cycles



#### FIGURE 5-10. EIR Register Bitmap, Non-Extended Modes

#### Bit 0 - Interrupt Pending Flag (IPF)

- 0 There is an interrupt pending.
- 1 No interrupt pending. (Default)

#### Bits 2,1 - Interrupt Priority 1,0 (IPR1,0)

When bit 0 (IPF) is 0, these bits indicate the pending interrupt with the highest priority. See Table 5-3.

Default value is 00.

#### Bit 3 - RX FIFO Time-Out (RXFT)

In the 16450 mode, this bit is always 0. In the 16550 mode (FIFOs enabled), this bit is set to 1 when an RX\_FIFO read time-out occurred and the associated interrupt is currently the highest priority pending interrupt.

#### Bits 5,4 - Reserved

Read/Write 0.

### Bit 7,6 - FIFOs Enabled (FEN1,0)

- 0 No FIFO enabled. (Default)
- 1 FIFOs are enabled (bit 0 of FCR is set to 1).

# **Event Identi cation Register (EIR), Extended Mode**

In Extended mode, each of the previously prioritized and encoded interrupt sources is broken down into individual bits. Each bit in this register acts as an interrupt pending flag, and is set to 1 when the corresponding event occurred or is pending, regardless of the IER register bit setting.

When this register is read the DMA event bit (bit 4) is cleared if an 8237 type DMA is used. All other bits are cleared when the corresponding interrupts are acknowledged by reading the relevant register (e.g. reading MSR clears MS EV bit).



FIGURE 5-11. EIR Register Bitmap, Extended Mode

### Bit 0 - Receiver High-Data-Level Event (RXHDL EV)

When FIFOs are disabled, this bit is set to 1 when a character is in the Receiver Holding Register.

When FIFOs are enabled, this bit is set to 1 when the RX\_FIFO is above threshold or an RX\_FIFO time-out has occurred.

| <b>TABLE 5-3.</b> | Non-Extended Mode | <b>Interrupt Priorities</b> |
|-------------------|-------------------|-----------------------------|
|-------------------|-------------------|-----------------------------|

| EIR             | Interrupt Set and Reset Functions |                                        |                                                                                                                                                        |                                                                                                                               |  |
|-----------------|-----------------------------------|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|--|
| Bits<br>3 2 1 0 | Priority<br>Level                 | Interrupt Type                         | Interrupt Source                                                                                                                                       | Interrupt Reset Control                                                                                                       |  |
| 0 0 0 1         | -                                 | None                                   | None                                                                                                                                                   | -                                                                                                                             |  |
| 0 1 1 0         | Highest                           | Link Status                            | Parity error, framing error, data over-<br>run or break event                                                                                          | Read Link Status Register (LSR).                                                                                              |  |
| 0 1 0 0         | Second                            | Receiver High<br>Data Level<br>Event   | Receiver Holding Register (RXD) full, or RX_FIFO level equal to or above threshold.                                                                    | Reading the RXD or, RX_FIFO level drops below threshold.                                                                      |  |
| 1 1 0 0         | Second                            | RX_FIFO<br>Time-Out                    | At least one character is in the RX_FIFO, and no character has been input to or read from the RX_FIFO for 4 character times.                           | Reading the RXD port.                                                                                                         |  |
| 0 0 1 0         | Third                             | Transmitter<br>Low Data<br>Level Event | Transmitter Holding Register or TX_FIFO empty.                                                                                                         | Reading the EIR Register if this interrupt is currently the highest priority pending interrupt, or writing into the TXD port. |  |
| 0000            | Fourth                            | Modem Status                           | Any transition on $\overline{\text{CTS}}$ , $\overline{\text{DSR}}$ or $\overline{\text{DCD}}$ or a low to high transition on $\overline{\text{RI}}$ . | Reading the Modem Status Register (MSR).                                                                                      |  |

### Bit 1 - Transmitter Low-Data-Level Event (TXLDL EV)

When FIFOs are disabled, this bit is set to 1 when the Transmitter Holding Register is empty.

When FIFOs are enabled, this bit is set to 1 when the TX FIFO is below the threshold level.

# Bit 2 - Link Status Event (LS\_EV) or Transmitter Halted Event (TXHLT\_EV)

In the **UART, Sharp-IR** and **SIR** modes, this bit is set to 1 when a receiver error or break condition is reported.

When FIFOs are enabled, the Parity Error(PE), Frame Error(FE) and Break(BRK) conditions are only reported when the associated character reaches the bottom of the RX\_FIFO. An Over-run Error (OE) is reported as soon as it occurs.

In the **MIR** and **FIR** modes, this bit indicates that a Link Status Event (LS\_EV) or a Transmitter Halted Event (TXHLT\_EV) occurred. It is set to 1 when any of the following conditions occurs:

- Last byte of receiver frame reaches the bottom of the RX\_FIFO.
- A receiver over-run.
- A transmitter under-run.
- Transmitter halted on frame end.

In the **Consumer-IR** mode, this bit indicates that a Link Status Event (LS\_EV) or a Transmitter Halted Event (TXHLT\_EV) occurred. It is set to 1 when any of the following conditions occurs:

- A receiver over-run.
- A transmitter under-run.

Note: A high speed CPU can service the interrupt generated by the last frame byte reaching the RX\_FIFO bottom before that byte is transferred to memory by the DMA controller. This can happen when the CPU interrupt latency is shorter than the FIFO Time-out event B (see sec. 5.9.2 on page 136). A DMA request is generated only when the RX\_FIFO level reaches the DMA threshold or when Timeout Event B occurs, in order to minimize the performance degradation due to DMA signal handshake sequences.

If the DMA controller must be set up before receiving each frame, the software in the interrupt routine should make sure that the last byte of the frame just received has been transferred to memory before re-initializing the DMA controller, otherwise that byte could appear as the first byte of the next received frame.

#### Bit 3 - Modem Status Event (MS\_EV)

In UART mode this bit is set to 1 when any of the 0 to 3 bits in the MSR register is set to 1.

In any **IR** mode, the function of this bit depends on the setting of the IRMSSL bit in the IRCR2 register (see Table 5-4 and also "Bit 1 - MSR Register Function Select in Infrared Mode (IRMSSL)" on page 165).

TABLE 5-4. Modem Status Event Detection Enable

| IRMSSL<br>Value | Bit Function               |
|-----------------|----------------------------|
| 0               | Modem Status Event (MS_EV) |
| 1               | Forced to 0.               |

#### Bit 4 - DMA Event Occurred (DMA\_EV)

When an 8237 type DMA controller is used, this bit is set to 1 when a DMA terminal count (TC) is signalled. It is cleared upon read.

# Bit 5 - Transmitter Empty (TXEMP\_EV) or Pipeline Load Event (PLD EV)

In **UART, Sharp-IR** and **Consumer-IR** modes, this bit is the same as bit 6 of the LSR register. It is set to 1 when the transmitter is empty.

In the **MIR**, **FIR** and **SIR** modes, this bit is set to 1 when the transmitter is empty or a pipeline operation occurs.

#### Bit 6 - ST\_FIFO Event (SFIF\_EV)

In **MIR** and **FIR** modes, this bit is set to 1 when the ST\_FIFO level is equal to or above the threshold, or a ST\_FIFO time-out occurs. This bit is cleared when the CPU reads the ST\_FIFO and its level drops below the threshold.

#### Bit 7 - Timer Event (TMR EV)

Set to 1 when the timer reaches 0.

Cleared by writing 1 into bit 7 of the ASCR register

### 5.13.4 FIFO Control Register (FCR), Bank 0, Offset 02h

The FIFO Control Register (FCR) is write only. It is used to enable the FIFOs, clear the FIFOs and set the interrupt thresholds levels for the reception and transmission FIFOs.



FIGURE 5-12. FCR Register Bitmap

#### Bit 0 - FIFO Enable (FIFO EN)

When set to 1 enables both the Transmision and Reception FIFOs. Resetting this bit clears both FIFOs.

In **MIR**, **FIR** and **Consumer-IR** modes the FIFOs are always enabled and the setting of this bit is ignored.

#### Bit 1 - Receiver Soft Reset (RXSR)

Writing a 1 to this bit generates a receiver soft reset, which clears the RX\_FIFO and the receiver logic. This bit is automatically cleared by the hardware.

#### Bit 2 - Transmitter Soft Reset (TXSR)

Writing a 1 to this bit generates a transmitter soft reset, which clears the TX\_FIFO and the transmitter logic. This bit is automatically cleared by the hardware.

#### Bit 3 - Reserved

Read/Write 0.

Writing to this bit has no effect on the UART operation.

#### Bits 5,4 - TX FIFO Threshold Level (TXFTH1,0)

In **Non-Extended** modes, these bits have no effect.

In **Extended** modes, these bits select the TX\_FIFO interrupt threshold level. An interrupt is generated when the level of the data in the TX\_FIFO drops below the encoded threshold.

TABLE 5-5. TX FIFO Level Selection

| TXFTH (Bits 5,4) | TX_FIF0 Tresh.<br>(16 Levels) | TX_FIF0<br>Tresh. (32<br>Levels) |  |
|------------------|-------------------------------|----------------------------------|--|
| 00(Default)      | 1                             | 1                                |  |
| 01               | 3                             | 7                                |  |
| 10               | 9                             | 17                               |  |
| 11               | 13                            | 25                               |  |

### Bits 7,6 - RX\_FIFO Threshold Level (RXFTH1,0)

In **Non-Extended** modes, these bits have no effect.

In **Extended** modes, these bits select the RX\_FIFO interrupt threshold level. An interrupt is generated when the level of the data in the RX\_FIFO is equal to or above the encoded threshold.

TABLE 5-6. RX FIFO Level Selection

| RXFTH<br>(Bits 5,4) | RX_FIF0<br>Tresh. (16<br>Levels) | RX_FIF0 Tresh.<br>(32 Levels) |
|---------------------|----------------------------------|-------------------------------|
| 00(Default)         | 1                                | 1                             |
| 01                  | 4                                | 8                             |
| 10                  | 8                                | 16                            |
| 11                  | 14                               | 26                            |

### 5.13.5 Link Control Register (LCR), Bank 0, Offset 03h, and Bank Selection Register (BSR), All Banks, Offset 03h

The Link Control Register (LCR) and the Bank Select Register (BSR) (see the next register) share the same address.

The **Link Control Register (LCR)** selects the communications format for data transfers in UART, SIR and Sharp-IR modes.

Upon reset, all bits are set to 0.

Reading the register at this address location returns the content of the BSR. The content of LCR may be read from the Shadow of Link Control Register (SH\_LCR) register in bank 3 (See Section 5.16.2 on page 160). During a write operation to this register at this address location, the setting of bit 7 (Bank Select Enable, BKSE) determines whether LCR or BSR is to be accessed, as follows:

If bit 7 is 0, the write affects both LCR and BSR.

If bit 7 is 1, and it is not one of the codes that selects bank 1 (see Table 5-9, "Bank Selection Encoding" on page 148), the write affects only BSR, and LCR remains unchanged. This prevents the communications format from being spuriously affected when a bank other than 0 or 1 is accessed.

Upon reset, all bits are set to 0.

### Link Control Register (LCR), All Banks, Offset 03h

Bits 6-0 are only effective in **UART, Sharp-IR** and **SIR** modes. They are ignored in **MIR, FIR** and **Consumer-IR** modes.



### FIGURE 5-13. LCR Register Bitmap

#### Bits 1,0 - Character Length Select (WLS1,0)

These bits specify the number of data bits in each transmitted or received serial character. Table 5-7 shows how to encode these bits.

TABLE 5-7. Word Length Select Encoding

| WLS1 | WLS0 | Character Length |
|------|------|------------------|
| 0    | 0    | 5 (Default)      |
| 0    | 1    | 6                |
| 1    | 0    | 7                |
| 1    | 1    | 8                |

### Bits 2 - Number of Stop Bits (STB)

This bit specifies the number of stop bits transmitted with each serial character.

- 0 One stop bit is generated. (Default)
- 1 If the data length is set to 5-bits via bits 1,0 (WLS1,0), 1.5 stop bits are generated. For 6,
  7 or 8 bit word lengths, two stop bits are transmitted. The receiver checks for one stop bit only, regardless of the number of stop bits selected.

#### Bit 3 - Parity Enable (PEN)

This bit enable the parity bit See Table 5-8 on page 147.

The parity enable bit is used to produce an even or odd number of 1s when the data bits and parity bit are summed, as an error detection device.

- 0 No parity bit is used. (Default)
- 1 A parity bit is generated by the transmitter and checked by the receiver.

#### Bit 4 - Even Parity Select (EPS)

When Parity is enabled (PEN is 1), this bit, together with bit 5 (STKP), controls the parity bit as shown in Table 5-8.

- 0 If parity is enabled, an odd number of logic 1s are transmitted or checked in the data word bits and parity bit. (Default)
- 1 If parity is enabled, an even number of logic1s are transmitted or checked.

#### Bit 5 - Stick Parity (STKP)

When Parity is enabled (PEN is 1), this bit, together with bit 4 (EPS), controls the parity bit as show in Table 5-8.

**TABLE 5-8. Bit Settings for Parity Control** 

| PEN | EPS | STKP | Selected Parity Bit |
|-----|-----|------|---------------------|
| 0   | Х   | Х    | None                |
| 1   | 0   | 0    | Odd                 |
| 1   | 1   | 0    | Even                |
| 1   | 0   | 1    | Logic 1             |
| 1   | 1   | 1    | Logic 0             |

#### Bit 6 - Set Break (SBRK)

This bit enables or disables a break. During the break, the transmitter can be used as a character timer to accurately establish the break duration.

This bit acts only on the transmitter front-end and has no effect on the rest of the transmitter logic.

When set to 1 the following occurs:

- If a UART mode is selected, the SOUT pin is forced to a logic 0 state.
- If SIR mode is selected, pulses are issued continuously on the IRTX pin.
- If Sharp-IR mode is selected and internal modulation is enabled, pulses are issued continuously on the IRTX pin.
- If Sharp-IR mode is selected and internal modulation is disabled, the IRTX pin is forced to a logic 1 state.

To avoid transmission of erroneous characters as a result of the break, use the following procedure to set SBRK:

- 1. Wait for the transmitter to be empty. (TXEMP = 1).
- 2. Set SBRK to 1.
- Wait for the transmitter to be empty, and clear SBRK when normal transmission must be restored.

#### Bit 7 - Bank Select Enable (BKSE)

- 0 This register functions as the Link Control Register (LCR).
- This register functions as the Bank Select Register (BSR).

### Bank Selection Register (BSR), All Banks, Offset 03h



Bank Selection Register (BSR) All Banks, Offset 03h

FIGURE 5-14. BSR Register Bitmap

The Bank Selection Register (BSR) selects which register bank is to be accessed next.

About accessing this register see the description of bit 7 of the LCR Register.

#### Bits 6-0 - Bank Selection

When bit 7 is set to 1, bits 6-0 of BSR select the bank, as shown in Table 5-9.

#### Bit 7 - Bank Selection Enable (BKSE)

- 0 Bank 0 is selected.
- 1 Bits 6-0 specify the selected bank.

TABLE 5-9. Bank Selection Encoding

|   | BSR Bits |   |   |   |   | Bank | LCR |          |            |
|---|----------|---|---|---|---|------|-----|----------|------------|
| 7 | 6        | 5 | 4 | 3 | 2 | 1    | 0   | Selected | LON        |
| 0 | Х        | Х | Х | Х | Х | Х    | Х   | 0        | LCR is     |
| 1 | 0        | Х | Х | Х | Х | Х    | Х   | 1        | written    |
| 1 | 1        | Х | Х | Х | Х | 1    | Х   | 1        |            |
| 1 | 1        | Х | Х | Х | Х | Х    | 1   | 1        |            |
| 1 | 1        | 1 | 0 | 0 | 0 | 0    | 0   | 2        | LCR is not |
| 1 | 1        | 1 | 0 | 0 | 1 | 0    | 0   | 3        | written    |
| 1 | 1        | 1 | 0 | 1 | 0 | 0    | 0   | 4        |            |
| 1 | 1        | 1 | 0 | 1 | 1 | 0    | 0   | 5        |            |
| 1 | 1        | 1 | 1 | 0 | 0 | 0    | 0   | 6        |            |
| 1 | 1        | 1 | 1 | 0 | 1 | 0    | 0   | 7        |            |
| 1 | 1        | 1 | 1 | 1 | Х | 0    | 0   | Reserved |            |
| 1 | 1        | 0 | Х | Х | х | 0    | 0   | Reserved |            |

# 5.13.6 Modem/Mode Control Register (MCR), Bank 0, Offset 04h

This register controls the interface with the modem or data communications set, and the device operational mode when the device is in the **Extended** mode. The register function differs for Extended and Non-Extended modes.

### Modem/Mode Control Register (MCR), Non-Extended Mode, Bank 0, Offset 04h

#### **Non-Extended UART Modes**



FIGURE 5-15. MCR Register Bitmap, Non-Extended Mode

#### Bit 0 - Data Terminal Ready (DTR)

This bit controls the  $\overline{\rm DTR}$  signal output. When set to 1,  $\overline{\rm DTR}$  is driven low. When loopback is enabled (LOOP is set to 1), this bit internally drives  $\overline{\rm DSR}$ .

#### Bit 1 - Request To Send (RTS)

This bit controls the  $\overline{RTS}$  signal output. When set to 1, drives  $\overline{RTS}$  low. When loopback is enabled (LOOP is set), this bit drives  $\overline{CTS}$ , internally.

#### Bit 2 - Loopback Interrupt Request (RILP)

 $\underline{W}$ hen loopback is enabled, this bit internally drives  $\overline{RI}$ . Otherwise it is unused.

# Bit 3 - Interrupt Signal Enable (ISEN) or Loopback DCD (DCDLP)

In normal operation (standard 16450 or 16550) mode, this bit controls the interrupt signal and must be set to 1 in order to enable the interrupt request signal.

When loopback is enabled, the interrupt output signal is always enabled, and this bit internally drives  $\overline{DCD}$ .

New programs should always keep this bit set to 1 during normal operation. The interrupt signal should be controlled through the Plug-n-Play logic.

#### Bit 4 - Loopback Enable (LOOP)

When this bit is set to 1, it enables loopback. This bit accesses the same internal register as bit 4 of the EXCR1 register. (see "Extended Control Register 1 (EXCR1), Bank 2, Offset 02h" on page 157 for more information on the Loopback mode).

- 0 Loopback disabled. (Default)
- 1 Loopback enabled.

#### Bits 7-5 - Reserved

Read/Write 0.

# Modem/Mode Control Register (MCR), Extended Mode, Bank 0, Offset 04h

In Extended mode, this register is used to select the operation mode (IrDA, Sharp, etc.) of the device and to enable the DMA interface. In these modes, the interrupt output signal is always enabled, and loopback can be enabled by setting bit 4 of the EXCR1 register.



FIGURE 5-16. MCR Register Bitmap, Extended Modes

#### Bit 0 - Data Terminal Ready (DTR)

This bit controls the  $\overline{\text{DTR}}$  signal output. When set to 1,  $\overline{\text{DTR}}$  is driven low. When loopback is enabled (LOOP is set), this bit internally drives both  $\overline{\text{DSR}}$  and  $\overline{\text{RI}}$ .

#### Bit 1 - Request To Send (RTS)

This bit controls the RTS signal output. When set to1, RTS is driven low. When loopback is enabled (LOOP is set), this bit internally drives both CTS and DCD.

#### Bit 2 - DMA Enable (DMA\_EN)

When set to1, DMA mode of operation is enabled. When DMA is selected, transmit and/or receive interrupts should be disabled to avoid spurious interrupts.

DMA cycles always address the Data Holding Registers or FIFOs, regardless of the selected bank.

#### Bit 3 - Transmission Deferral (TX DFR)

For a detailed description of the Transmission Deferral see "Transmission Deferral" on page 137.

- 0 No transmission deferral enabled. (Default)
- 1 Transmission deferral enabled.

This bit is effective only if the Transmission FIFOs is enabled.

#### Bit 4 - Send Interaction Pulse (IR PLS)

This bit is effective only in MIR or FIR modes.

When set to 1, a  $2\mu$ sec infrared interaction pulse is transmitted at the end of the frame and it is automatically cleared after the pulse is sent. This interaction pulse indicates to low speed devices that high speed transfers are taking place.

This bit is automatically cleared after the pulse is sent or if the mode changes or after "soft reset".

Writing 0 into it has no effect.

#### Bits 7-5 - Mode Select (MDSL2-0)

These bits select the operational mode of the module when in **Extended** mode, as shown in Table 5-10.

When the mode is changed, the transmission and reception FIFOs are flushed, Link Status and Modern Status Interrupts are cleared, and all of the bits in the auxiliary status and control register are cleared.

**TABLE 5-10.** The Module Operation Modes

| MDSL2<br>(Bit 7) | MDSL1<br>(Bit 6) | MDSL0<br>(Bit 5) | Operational Mode        |
|------------------|------------------|------------------|-------------------------|
| 0                | 0                | 0                | UART Modes<br>(Default) |
| 0                | 0                | 1                | Reserved                |
| 0                | 1                | 0                | Sharp-IR                |
| 0                | 1                | 1                | SIR                     |
| 1                | 0                | 0                | MIR                     |
| 1                | 0                | 1                | FIR                     |
| 1                | 1                | 0                | Consumer-IR             |
| 1                | 1                | 1                | Reserved                |

### 5.13.7 Link Status Register (LSR), Non-Extended Modes, Bank 0, Offset 05h

This register provides status information concerning the data transfer. The bits indicating the error conditions are sticky (they accumulate the occurrence of error conditions since the last time they were read). They are cleared when one of the following events occurs:

- A hardware reset occurs.
- The receiver is soft-reset.
- The LSR register is read.

Upon reset this register assumes the value of 0x60h.

The bit definitions change depending upon the operation mode of the module.

Bits 4 through 1 of the LSR are the error conditions that generate a Receiver Link Status interrupt whenever any of the corresponding conditions are detected and that interrupt is enabled.

The LSR is intended for read operations only. Writing to the LSR is not permitted



FIGURE 5-17. LSR Register Bitmap

#### Bit 0 - Receiver Data Available (RXDA)

Set to 1 when the Receiver Holding Register is full.

If the FIFOs are enabled, this bit is set when at least one character is in the RX FIFO.

Cleared when the CPU reads all the data in the Holding Register or in the RX FIFO.

#### Bit 1 - Over-run Error (OE)

This bit is set to 1 as soon as an overrun condition is detected by the receiver.

Cleared upon read.

In **UART, Sharp-IR**, **SIR** and **Consumer-IR** modes when-

#### FIFOs Disabled:

An overrun occurs when a new character is completely received into the receiver front-end section and the CPU has not yet read the previous character in the receiver holding register. The new character is discarded, and the receiver holding register is not affected.

#### FIFOs Disabled:

An overrun occurs when a new character is completely received into the receiver front-end section and the RX\_FIFO is full. The new character is discarded, and the RX\_FIFO is not affected.

In the **MIR** and **FIR** modes, an overrun occurs when a new character is completely received into the receiver front-end section and the RX\_FIFO or the ST\_FIFO is full. The new character is discarded, and the RX\_FIFO is not affected.

#### Bit 2 - Parity Error or CRC Error (PE or BAD CRC)

In **UART, Sharp-IR** and **SIR** modes, this bit is set to 1 if the received data character does not have the correct parity, even or odd as selected by the parity control bits of the LCR register.

If the FIFOs are enabled, this error is associated with the particular character in the FIFO that it applies to. This error is revealed to the CPU when its associated character is at the bottom of the RX FIFO.

In **MIR** and **FIR** modes, this bit is the **BAD\_CRC** bit. It set to 1 when the received CRC and the receiver-generated CRC do not match, and the last byte has reached the bottom of the RX FIFO.

This bit is cleared upon read.

# Bit 3 - Framing Error or Physical Layer Error (FE or PHY ERR)

In **UART, Sharp-IR** and **SIR** modes, this bit is set to 1 when the received data character does not have a valid stop bit (i.e., the stop bit following the last data bit or parity bit is a 0).

If the FIFOs are enabled, this Framing Error is associated with the particular character in the FIFO that it applies to. This error is revealed to the CPU when its associated character is at the bottom of the RX FIFO.

After a framing error is detected, the receiver will try to resynchronize.

If the bit following the erroneous stop bit is 0, the receiver assumes it to be a valid start bit and shifts in the new character. If that bit is a 1, the receiver enters the idle state and awaits the next start bit.

In **MIR** mode this bit is the **PHY\_ERR** (Physical Layer Error) bit. It is set to 1 when an abort condition is detected during the reception of a frame, and the last byte of the frame has reached the bottom of the RX FIFO.

In **FIR** mode this bit is the **PHY\_ERR** (Physical Layer Error) bit. It is set to 1 when an encoding error or the sequence BOF-data-BOF is detected (missing EOF) during the reception of a frame, and the last byte of the frame has reached the bottom of the RX FIFO.

This bit is cleared upon read.

# Bit 4 - Break Event Detected or Maximum Length Exceeded (BRK or MAX\_LEN)

In **UART, Sharp-IR** and **SIR** modes this bit is set to 1 when a break event is detected (i.e. when a sequence of logic 0 bits, equal or longer than a full character transmission, is received). If the FIFOs are enabled, the break condition is associated with the particular character in the RX\_FIFO to which it applies. In this case, the BRK bit is set when the character reaches the bottom of the RX\_FIFO.

When a break event occurs, only one zero character is transferred to the Receiver Holding Register or to the RX FIFO.

The next character transfer takes place after at least one logic 1 bit is received followed by a valid start bit.

In **MIR** and **FIR** modes, this is the **MAX\_LEN** (Maximum Length exceeded) bit. It is set to 1 when a frame exceeding the maximum length has been received, and the last byte of the frame has reached the bottom of the RX FIFO.

This bit is cleared upon read.

#### Bit 5 - Transmitter Ready (TXRDY)

This bit is set to 1 when the Transmitter Holding Register or the TX FIFO is empty.

It is cleared when a data character is written to the TXD register.

#### **Bit 6 - Transmitter Empty (TXEMP)**

This bit is set to 1 when the Transmitter Holding Register or the TX\_FIFO is empty, and the transmitter front-end is idle.

# Bit 7 - Error in RX\_FIFO (ER\_INF) or Frame End (FR END)

In **UART, Sharp-IR** and **SIR** modes, this bit is set to a 1 if there is at least 1 framing error, parity error or break indication in the RX FIFO.

This bit is always 0 in the 16450 mode.

In the **MIR** and **FIR** modes, this is the Frame End (FR\_END) bit. It is set to 1 when the last byte of a received frame reaches the bottom of the RX\_FIFO.

This bit is cleared upon read.

### 5.13.8 Modem Status Register (MSR), Bank 0, Offset 06h

The function of this register depends on the selected operational mode. When a **UART** mode is selected, this register provides the current-state as well as state-change information of the status lines from the modem or data transmission module.

When any of the infrared modes is selected, the register function is controlled by the setting of the **IRMSSL** bit in the IRCR2 (see page 165). If IRMSSL is 0, the MSR register works as in UART mode. If IRMSSL is 1, the MSR register returns the value 30 hex, regardless of the state of the modem input lines.

When loopback is enabled, the MSR register works similarly except that its status input signals are internally driven by appropriate bits in the MCR register since the modem input lines are internally disconnected. Refer to the DTR & RTS bits at the MCR (see page 148) and to the LOOP & ETDLBK bits at the EXCR1 (see page 157) for more information.

A description of the various bits of the MSR register, with Loopback disabled and UART Mode selected, is provided below.

When bits 0, 1, 2 or 3 is set to 1, a Modem Status Event (MS\_EV) is generated if the MS\_IE bit is enabled in the IER

Bits 0 to 3 are set to 0 as a result of any of the following events:

- A hardware reset occurs.
- The operational mode is changed and the IRMSSL bit is 0.
- The MSR register is read.

In the reset state, bits 4 through 7 are indeterminate as they reflect their corresponding input signals.

Note: The modem status lines can be used as general purpose inputs. They have no effect on the transmitter or receiver operation.



FIGURE 5-18. MSR Register Bitmap

#### Bit 0 - Delta Clear to Send (DCTS)

Set to 1, when the  $\overline{\text{CTS}}$  input signal changes state. This bit is cleared upon read.

### Bit 1 - Delta Data Set Ready (DDSR)

Set to 1, when the DSR input signal changes state.

This bit is cleared upon read

### Bit 2 - Trailing Edge Ring Indicate (TERI)

Set to 1, when the  $\overline{\text{RI}}$  input signal changes state from low to high.

This bit is cleared upon read

#### Bit 3 - Delta Data Carrier Detect (DDCD)

Set to 1, when the DCD input signal changes state.

1 - DCD signal state changed.

### Bit 4 - Clear To Send (CTS)

This bit returns the inverse of the CTS input signal.

#### Bit 5 - Data Set Ready (DSR)

This bit returns the inverse of the  $\overline{\text{DSR}}$  input signal

#### Bit 6 - Ring Indicate (RI)

This bit returns the inverse of the RI input signal.

#### Bit 7 - Data Carrier Detect (DCD)

This bit returns the inverse of the  $\overline{\text{DCD}}$  input signal.

### 5.13.9 Scratchpad Register (SPR), Bank 0, Offset 07h

This register shares a common address with the following one (ASCR).

In the **Non-Extended** mode this is a scratch register (as in the 16550) for temporary data storage.

#### **Non-Extended Modes**



FIGURE 5-19. SPR Register Bitmap

### 5.13.10Auxiliary Status and Control Register (ASCR), Bank 0, Offset 07h

This register shares a common address with the previous one (SCR).

This register is accessed when the **Extended** mode of operation is selected. The definition of the bits in this case is dependent upon the mode selected in the MCR register, bits 7 through 5. This register is cleared upon hardware reset or when the operational mode changes. Bits 2 and 6 are cleared when the transmitter is "soft reset". Bits 0,1,4 and 5 are cleared when the receiver is "soft reset".



FIGURE 5-20. ASCR Register Bitmap

#### Bit 0 - RX\_FIFO Time-Out (RXF\_TOUT)

This bit is read only and set to 1 when an RX\_FIFO timeout occurs. It is cleared when a character is read from the RX\_FIFO.

Note: In **MIR** or **FIR** mode, this bit can be used in conjunction with bit 1 (EOT\_INF) to determine whether a number of bytes (as determined by the RX\_FIFO threshold), can be read without checking the RXDA bit in the LSR register for each byte.

### Bit 1 - Frame End In FIFO (EOF\_INF)

In **MIR** or **FIR** mode, this bit is read only and set to 1 when one or more EOF bytes are in the RX\_FIFO. It is cleared when no EOF byte is in the RX\_FIFO.

#### Bit 2 - Set End of Transmission (S EOT)

In **MIR** or **FIR** modes, this is the Set End of Transmission bit. When a 1 is written into this bit position before writing the last character into the TX\_FIFO, frame transmission is completed and a CRC + EOF is sent.

This bit can be used as an alternative to the TFRL/TFRCC counter (see page 162). If this method is to be used, the FEND\_MD bit in the IRCR2 (see page 165) should be set to 1 or the Transmission Frame Length Register should be set to maximum count. This bit is automatically cleared by hardware when a character is written to the TX FIFO.

In **Consumer-IR** mode this is the Set End of Transmission bit. When a 1 is written into this bit position before writing the last character into the TX\_FIFO, data transmission is gracefully completed.

In this mode, if the CPU simply stops writing data into the TX\_FIFO at the end of the data stream, a transmitter under-run is generated and the transmitter stops. In this case this is not an error, but

the software must clear the under-run before the next transmission can occur. This bit is automatically cleared by hardware when a character is written to the TX FIFO.

#### Bit 3 - Transmitter Halted on Frame End (TXHFE)

This bit is used only in **MIR** or **FIR** modes, when the Transmitter Frame End Stop mode is selected (TX\_MS bit in IRCR2 on page 165 is set to 1). It is set to 1 by the hardware when transmission of a frame is completed and an End Of Frame condition is generated by the TRFCC (see page 162) counter reaches 0.

This bit must be cleared, by writing 1 into it, to reenable transmission.

### Bit 4 - Lost Frame Flag (LOST\_FR) or Reception Watchdog (RXWDG)

In the **MIR** or **FIR** modes, this is the Lost Frame Flag. This read-only bit reflects the setting of the lost-frame indicator flag at the bottom of the ST FIFO.

In **Consumer-IR** mode, this is the Reception Watchdog (RXWDG) bit. It is set to 1 each time a pulse or pulse-train (modulated pulse) is detected by the receiver. It can be used by the software to detect a receiver idle condition. It is cleared upon read.

# Bit 5 - Receiver Busy (RXBSY) or Receiver Active (RXACT)

In the **MIR** or **FIR** modes, this is the Receiver Busy (RXBSY) bit. It is a read only bit and is set to 1 when reception of a frame is in progress.

In **Consumer-IR** Mode this is the Receiver Active (RXACT) bit. It is set to 1 when an infrared pulse or pulse-train is received. If a 1 is written into this bit position, the bit is cleared and the receiver is deactivated. When this bit is set, the receiver samples the infrared input continuously at the programmed baud rate and transfers the data to the RX\_FIFO. See "Consumer-IR Reception" on page 135.

#### Bit 6 - Infrared Transmitter Under-run (TXUR)

In the MIR, FIR and Consumer-IR modes, this is the Transmitter Under-run flag. This bit is set to 1 when a transmitter under-run occurs. It is always cleared when a mode other than MIR, FIR or Consumer-IR is selected. This bit must be cleared, by writing 1 into it, to re-enable transmission.

# Bit 7 - Pipeline Status (PLD) or Clear Timer Event (CTE)

In **MIR**, **FIR** or **SIR** modes, on a read operation, this is the Pipeline Load Status (PLD) bit. Reading this bit returns the pipeline load status. This bit is set to 1 when a pipeline load operation occurs, and is cleared upon read.

In all the other Extended Modes, writing 1 into this bit position clears the TMR\_EV bit in the EIR register. Writing 0 into this bit has no effect.

The write operation has no effect on the Pipeline Load Status bit.

### 5.14 BANK 1 – THE LEGACY BAUD RATE GENERATOR DIVISOR PORTS

This register bank contains two baud rate generator divisor ports, and a bank select register.

The Legacy Baud-rate Generator Divisor (LBGD) port provides an alternate path to the Baud Divisor Generator register. This bank is implemented to maintain compatibility with 16550 standard and to support existing legacy software packages. In case of using legacy software, the addresses 0 and 1 are shared with the data ports RXD/TXD (see page 139). The selection between them is controlled by the value of the BKSE bit (LCR bit 7 page 146).

TABLE 5-11. Bank 1 Register Set

| Offset    | Register<br>Name | Description                                       |  |
|-----------|------------------|---------------------------------------------------|--|
| 00h       | LBGD(L)          | Legacy Baud Generator<br>Divisor Port (Low Byte)  |  |
| 01h       | LBGD(H)          | Legacy Baud Generator<br>Divisor Port (High Byte) |  |
| 02h       |                  | Reserved                                          |  |
| 03h       | LCR/<br>BSR      | Link Control /<br>Bank Select Register            |  |
| 04h - 07h |                  | Reserved                                          |  |

In addition, a fallback mechanism maintains this compatibility by forcing the UART to revert to 16550 mode if 16550 software addresses the module after a different mode was set. Since setting the baud rate divisor values is a necessary initialization of the 16550, setting the divisor values in bank 1 forces the UART to enter 16550 mode. (This is called fallback).

To enable other modes to program their desired baud rates without activating this fallback mechanism, the baud rate divisor register in bank 2 should be used.

In PC87338, the baud rate generator is not initialized. *In PC97338*, *MR resets the baud rate generator register on power-up.* 

### 5.14.1 Legacy Baud Rate Generator Divisor Ports (LBGD(L) and LBGD(H)), Bank 1, Offsets 00h and 01h

The programmable baud rates in the Non-Extended mode are achieved by dividing a 24 MHz clock by a prescale value of 13, 1.625 or 1. This prescale value is selected by the PRESL field of EXCR2 (see page 158). This clock is then subdivided by the two baud generator divisor buffers, which output a clock at 16 times the desired baud rate (this clock is the BAUD-OUT clock). This clock is used by I/O circuitry, and after a last division by 16 produces the output baud rate.

Divisor values between 1 and 2<sup>16</sup>-1 can be used. (Zero is forbidden). The baud generator divisor must be loaded during initialization to ensure proper operation of the baud generator. Upon loading either part of it, the baud generator counter is immediately loaded. Table 5-12 on page 155 shows typical baud rate divisors.

After reset the divisor register contents are indeterminate.

Any access to the **LBGD(L)** or **LBGD(H)** ports causes a reset to the default Non-Extended mode, i.e., 16550 mode (See "Automatic Fallback to A Non-Extended UART Mode" on page 137).

To access a Baud Generator Devisor when in the **Extended** mode, use the port pair in bank 2 (BGD on page 156).

Table 5-13 shows the bits which are cleared when Fallback occurs during **Extended** or **Non-Extended** modes.

If the UART is in **Non-Extended** mode and the LOCK bit is 1, the content of the divisor (BGD) ports will not be affected and no other action is taken.

When programming the baud rate, the new divisor is loaded upon writing into LBGD(L) and LBGD(H). After reset, the contents of these registers are indeterminate.

Divisor values between 1 and 2<sup>16</sup>-1 can be used. (Zero is forbidden.) Table 5-12 shows typical baud rate divisors.

**TABLE 5-12.** Baud Generator Divisor Settings

| Baud<br>Rate | Divisor | % Error | Divisor | % Error | Divisor | % Error |
|--------------|---------|---------|---------|---------|---------|---------|
| 50           | 2304    | 0.16%   | 18461   | 0.00%   | 30000   | 0.00%   |
| 75           | 1536    | 0.16%   | 12307   | 0.01%   | 20000   | 0.00%   |
| 110          | 1047    | 0.19%   | 8391    | 0.01%   | 13636   | 0.00%   |
| 134.5        | 857     | 0.10%   | 6863    | 0.00%   | 11150   | 0.02%   |
| 150          | 768     | 0.16%   | 6153    | 0.01%   | 10000   | 0.00%   |
| 300          | 384     | 0.16%   | 3076    | 0.03%   | 5000    | 0.00%   |
| 600          | 192     | 0.16%   | 1538    | 0.03%   | 2500    | 0.00%   |
| 1200         | 96      | 0.16%   | 769     | 0.03%   | 1250    | 0.00%   |
| 1800         | 64      | 0.16%   | 512     | 0.16%   | 833     | 0.04%   |
| 2000         | 58      | 0.53%   | 461     | 0.12%   | 750     | 0.00%   |
| 2400         | 48      | 0.16%   | 384     | 0.16%   | 625     | 0.00%   |
| 3600         | 32      | 0.16%   | 256     | 0.16%   | 416     | 0.16%   |
| 4800         | 24      | 0.16%   | 192     | 0.16%   | 312     | 0.16%   |
| 7200         | 16      | 0.16%   | 128     | 0.16%   | 208     | 0.16%   |
| 9600         | 12      | 0.16%   | 96      | 0.16%   | 156     | 0.16%   |
| 14400        | 8       | 0.16%   | 64      | 0.16%   | 104     | 0.16%   |
| 19200        | 6       | 0.16%   | 48      | 0.16%   | 78      | 0.16%   |
| 28800        | 4       | 0.16%   | 32      | 0.16%   | 52      | 0.16%   |
| 38400        | 3       | 0.16%   | 24      | 0.16%   | 39      | 0.16%   |
| 57600        | 2       | 0.16%   | 16      | 0.16%   | 26      | 0.16%   |
| 115200       | 1       | 0.16%   | 8       | 0.16%   | 13      | 0.16%   |
| 230400       |         |         | 4       | 0.16%   |         |         |
| 460800       |         |         | 2       | 0.16%   |         |         |
| 750000       |         |         |         |         | 2       | 0.00%   |
| 921600       |         |         | 1       | 0.16%   |         |         |
| 1500000      |         |         |         |         | 1       | 0.00%   |

TABLE 5-13. Bits Cleared On Fallback

|          | UART Mode & LOCK bit before Fallback |          |                      |  |  |
|----------|--------------------------------------|----------|----------------------|--|--|
| Register | Mode                                 | Mode     | Non-Extended<br>Mode |  |  |
|          | LOCK = x                             | LOCK = 0 | LOCK = 1             |  |  |
| MCR      | 2 to 7                               | none     | none                 |  |  |
| EXCR1    | 0, 5 and 7                           | 5 and 7  | none                 |  |  |
| EXCR2    | 0 to 5                               | 0 to 5   | none                 |  |  |
| IRCR1    | 2 and 3                              | none     | none                 |  |  |



FIGURE 5-21. LBGD(L) Register Bitmap



FIGURE 5-22. LBGD(H) Register Bitmap

### 5.14.2 Link Control Register (LCR) and Bank Select Register (BSR), Bank 1, Offset 03h

These registers are the same as the registers at offset 03h in bank 0.

# 5.15 BANK 2 – EXTENDED CONTROL AND STATUS REGISTERS

Bank 2 contains two alternate Baud rate Generator Divisor ports and the Extended Control Registers (EXCR1 and EXCR2).

TABLE 5-14. Bank 2 Register Set

| Offset | Register<br>Name | Description                             |  |
|--------|------------------|-----------------------------------------|--|
| 00h    | BGD(L)           | Baud Generator Divisor Port (Low byte)  |  |
| 01h    | BGD(H)           | Baud Generator Divisor Port (High byte) |  |
| 02h    | EXCR1            | Extended Control Register 1             |  |
| 03h    | LCR/BSR          | Link Control/<br>Bank Select Register   |  |
| 04h    | EXCR2            | Extended Control Register 2             |  |
| 05h    |                  | Reserved                                |  |
| 06h    | TXFLV            | TX_FIFO Level                           |  |
| 07h    | RXFLV            | RX_FIFO Level                           |  |

### 5.15.1 Baud Generator Divisor Ports, LSB (BGD(L)) and MSB (BGD(H)), Bank 2, Offsets 00h and 01h

These ports perform the same function as the Legacy Baud Divisor Ports in Bank 1 and are accessed identically to them, but do not change the operation mode of the module when accessed. Refer to Section 5.14.1 on page 154 for more detail.

These ports should be used to set the baud rate when operating in Extended mode to avoid fallback to a Non-Extended operation mode, i.e., 16550 compatible.

When programming the baud rate, writing to BGDH causes the baud rate to change immediately.



FIGURE 5-23. BGD(L) Register Bitmap



FIGURE 5-24. BGD(H) Register Bitmap

# 5.15.2 Extended Control Register 1 (EXCR1), Bank 2, Offset 02h

Use this register to control module operation in the Extended mode. Upon reset all bits are set to 0.



FIGURE 5-25. EXCR1 Register Bitmap

#### Bit 0 - Extended Mode Select (EXT SL)

When set to 1, the Extended mode is selected.

### Bit 1 - DMA Fairness Control (DMANF)

This bit controls the maximum duration of DMA burst transfers.

- 0 DMA requests are forced inactive after approximately 10.5 μsec of continuous transmitter and/or receiver DMA operation. (Default)
- A transmission DMA request is deactivated when the TX\_FIFO is full. A reception DMA request is deactivated when the RX\_FIFO is empty.

#### Bit 2 - DMA FIFO Threshold (DMATH)

This bit selects the TX\_FIFO and RX\_FIFO threshold levels used by the DMA request logic to support demand transfer mode.

A transmission DMA request is generated when the TX FIFO level is below the threshold.

A reception DMA request is generated when the RX\_FIFO level reaches the threshold or when a DMA timeout occurs.

Table 5-15 lists the threshold levels for each FIFO.

TABLE 5-15. DMA Threshold Levels

| Bit   | DMA Threshold for FIFO Type |                        |                        |  |  |
|-------|-----------------------------|------------------------|------------------------|--|--|
| Value | RX_FIFO                     | Tx_FIFO<br>(16 Levels) | Tx_FIFO<br>(32 Levels) |  |  |
| 0     | 4                           | 13                     | 29                     |  |  |
| 1     | 10                          | 7                      | 23                     |  |  |

#### Bit 3 - DMA Swap (DMASWP)

This bit selects the routing of the DMA control signals between the internal DMA logic and the configuration module of the chip. When this bit is 0, the transmitter and receiver DMA control signals are not swapped. When it is 1, they are swapped. A block diagram illustrating the control signals routing is given in Fig. 5-26.

The swap feature is particularly useful when only one 8237 DMA channel is used to serve both transmitter and receiver. In this case only one external DRQ/DACK signal pair will be interconnected to the swap logic by the configuration module. Routing the external DMA channel to either the transmitter or the receiver DMA logic is then simply controlled by the DMASWP bit. This way, the infrared device drivers do not need to know the details of the configuration module.



FIGURE 5-26. DMA Control Signals Routing

### Bit 4 - Loopback Enable (LOOP)

During loopback, the transmitter output is connected internally to the receiver input, to enable system self-test of serial communications. In addition to the data signal, all additional signals within the UART are interconnected to enable real transmission and reception using the UART mechanisms.

When this bit is set to 1, loopback is selected. This bit accesses the same internal register as bit 4 in the MCR register, when the UART is in a Non-Extended mode.

Loopback behaves similarly in both Non-Extended and Extended modes.

When Extended mode is selected, the DTR bit in the MCR register internally drives both DSR and RI, and the RTS bit drives CTS and DCD.

During loopback, the following actions occur:

- The transmitter and receiver interrupts are fully operational. The Modem Status Interrupts are also fully operational, but the interrupt sources are now the lower bits of the MCR register. Modem interrupts in infrared modes are disabled unless the IRMSSL bit in the IRCR2 register is 0. Individual interrupts are still controlled by the IER register bits.
- 2. The DMA control signals are fully operational.
- UART and infrared receiver serial input signals are disconnected. The internal receiver input signals are connected to the corresponding internal transmitter output signals.
- 4. The UART transmitter serial output is forced high and the infrared transmitter serial output is forced low, unless the ETDLBK bit is set to 1. In which case they function normally.
- The modem status input pins (DSR, CTS, RI and DCD) are disconnected. The internal modem status signals, are driven by the lower bits of the MCR register.

### Bit 5 - Enable Transmitter During Loopback (ETDLBK)

When this bit is set to 1, the transmitter serial output is enabled and functions normally when loopback is enabled.

#### Bit 6 - Reserved

Write 1.

#### Bit 7 - Baud Rate Generator Test (BTEST)

When <u>set</u>, this bit routes the baud rate generator to the DTR pin for testing purposes.

### 5.15.3 Link Control Register (LCR) and Bank Select Register (BSR), Bank 2, Offset 03h

These registers are the same as the registers at offset 03h in bank 0.

### 5.15.4 Extended Control and Status Register 2 (EXCR2), Bank 2, Offset 04h

This register configures the transmitter and receiver FIFOs, and the baud generator prescaler.

Upon reset all bits are set to 0.



FIGURE 5-27. EXCR2 Register Bitmap

#### Bits 1,0 - TX FIFO Size (TF SIZ1,0)

These bits select the number of levels for the TX\_FIFO. They are effective only when the FIFOs are enabled. (See Table 5-16.)

TABLE 5-16. TX FIFO Size Encoding

| TF_SIZ1 | TF_SIZ0 | FIFO Depth |
|---------|---------|------------|
| 0       | 0       | 16         |
| 0       | 1       | 32         |
| 1       | х       | Reserved   |

#### Bits 3,2 - RX\_FIFO Size (RF\_SIZ1,0)

These bits select the number of levels for the RX\_FIFO. They are effective only when the FIFOs are enabled. (See Table 5-17.)

TABLE 5-17. RX FIFO Size Encoding

| RF_SIZ1 | RF_SIZ0 | FIFO Depth |
|---------|---------|------------|
| 0       | 0       | 16         |
| 0       | 1       | 32         |
| 1       | х       | reserved   |

#### Bits 5.4 - Prescaler Select

The prescaler divides the 24 MHz input clock frequency to provide the clock for the baud generator. (See Table 5-18.)

**TABLE 5-18. Prescaler Select** 

| Bit 5 | Bit 4 | Prescaler<br>Value |
|-------|-------|--------------------|
| 0     | 0     | 13                 |
| 0     | 1     | 1.625              |
| 1     | 0     | Reserved           |
| 1     | 1     | 1.0                |

#### Bit 6 - Reserved

Read/write 0.

### Bit 7 - Baud Rate Divisor Register Lock (LOCK)

When set to 1, accesses to the baud generator divisor register through LBGD(L) and LBGD(H) as well as fallback are disabled from non-extended mode.

In this case two scratchpad registers overlaid with LBGD(L) and LBGD(H) are enabled, and any attempted CPU access of the baud generator divisor register through LBGD(L) and LBGD(H) will access the scratchpad registers instead. This bit must be set to 0 when extended mode is selected.

### 5.15.5 Reserved Register, Bank 2, Offset 05h

Upon reset, all bits are set to 0.

#### Bits 7-0 - Reserved

Read/write 0's.

# 5.15.6 TX\_FIFO Current Level Register (TXFLV), Bank 2, Offset 06h

This read-only register returns the number of bytes in the TX\_FIFO. It can be used to facilitate programmed I/O modes during recovery from transmitter under-run in one of the fast infrared modes.

#### **Extended Modes**



FIGURE 5-28. TXFLV Register Bitmap

#### Bits 5-0 - Number of Bytes in TX FIFO (TFL(5-0))

These bits specify the number of bytes in the TX FIFO.

#### Bits 7,6 - Reserved

Read/Write 0's.

# 5.15.7 RX\_FIFO Current Level Register (RXFLV), IrDA or Consumer-IR Modes, Bank 2, Offset 07h

This read-only register returns the number of bytes in the RX\_FIFO. It can be used for software debugging.

#### **Extended Modes**



#### FIGURE 5-29. RXFLV Register Bitmap

#### Bits 5-0 - Number of Bytes in RX FIFO (RFL(5-0))

These bits specify the number of bytes in the RX FIFO.

#### Bits 7,6 - Reserved

Read/Write 0's.

Note: The contents of TXFLV and RXFLV are not frozen during CPU reads. Therefore, invalid data could be returned if the CPU reads these registers during normal transmitter and receiver operation. To obain correct data, the software should perform three consecutive reads and then take the data from the second read, if first and second read yield the same result, or from the third read, if first and second read yield different results.

## 5.16 BANK 3 – MODULE REVISION ID AND SHADOW REGISTERS

Bank 3 contains the Module Revision ID register which identifies the revision of the module, shadow registers for monitoring various registers whose contents are modified by being read, and status and control registers for handling the flow control.

TABLE 5-19. Bank 3 Register Set

| Offset  | Register<br>Name | Description                                    |
|---------|------------------|------------------------------------------------|
| 00h     | MRID             | Module Revision ID Register                    |
| 01h     | SH_LCR           | Shadow of LCR Register (Read Only)             |
| 02h     | SH_FCR           | Shadow of FIFO Control<br>Register (Read Only) |
| 03h     | LCR/<br>BSR      | Link Control Register/<br>Bank Select Register |
| 04h-07h | Reserved         |                                                |

## 5.16.1 Module Revision ID Register (MRID), Bank 3, Offset 00h

This read-only register identifies the revision of the module. When read, it returns the module ID and revision level. This module returns the code 2xh, where x indicates the revision number.



FIGURE 5-30. MRID Register Bitmap

#### Bits 3-0 - Revision ID (MID3-0)

The value in these bits identifies the revision level.

#### Bits 7-4 - Module ID (MID7-4)

The value in these bits identifies the module type.

## 5.16.2 Shadow of Link Control Register (SH\_LCR), Bank 3, Offset 01h

This register returns the value of the LCR register. The LCR register is written into when a byte value according to Table 5-9 on page 148, is written to the LCR/BSR registers location (at offset 03h) from any bank.



FIGURE 5-31. SH\_LCR Register Bitmap

See "Link Control Register (LCR), All Banks, Offset 03h" on page 147 for bit descriptions.

## 5.16.3 Shadow of FIFO Control Register (SH\_FCR), Bank 3, Offset 02h

This read-only register returns the contents of the FCR register in bank 0.



FIGURE 5-32. SH\_LCR Register Bitmap

See "FIFO Control Register (FCR), Bank 0, Offset 02h" on page 145 for bit descriptions.

#### 5.16.4 Link Control Register (LCR) and Bank Select Register (BSR), Bank 3, Offset 03h

These registers are the same as the registers at offset 03h in bank 0.

#### 5.17 BANK 4 – TIMER AND FRAME BYTE COUNTERS

Bank 4 contains the Timer Reload Registers, as well as Frame Size Lengths and frame counters.

TABLE 5-20. Bank 4 Register Set

| Offset | Register<br>Name      | Description                                                   |
|--------|-----------------------|---------------------------------------------------------------|
| 00h    | TMR(L)                | Timer Register (Low Byte)                                     |
| 01h    | TMR(H)                | Timer Register (High Byte)                                    |
| 02h    | IRCR1                 | Infrared Control Register 1                                   |
| 03h    | LCR/<br>BSR           | Link Control/<br>Bank Select Registers                        |
| 04h    | TFRL(L)/<br>TFRCC(L)  | Transmit Frame Length/<br>Current Count (Low Byte)            |
| 05h    | TFRL(H)/<br>TFRCC(H)  | Transmit Frame Length/<br>Current Count (High Byte)           |
| 06h    | RFRML(L)/<br>RFRCC(L) | Receive Frame<br>Maximum Length/<br>Current Count (Low Byte)  |
| 07h    | RFRML(H)/<br>RFRCC(H) | Receive Frame<br>Maximum Length/<br>Current Count (High Byte) |

## 5.17.1 Interval Timer (TMR(L) and TMR(H)), Bank 4, Offsets 00h and 01h

This register is used to program the reload value for the internal down-counter as well as to read the current counter value. TMR is 12 bits wide and is split into two independently accessible parts occupying consecutive address locations.

TMR(L) is located at the lower address and accesses the least significant 8 bits, whereas TMR(H) is located at the higher address and accesses the most significant 4 bits. Values from 1 to  $2^{12}$ - 1 can be used. The zero value is reserved and must not be used. The upper 4 bits of TMR(H) are reserved and must be written with 0's. The timer resolution is  $125\mu s$ , providing a maximum timeout interval of approximately 0.5 seconds. To properly program the timer, the CPU must

always write the lower value into TMR(L) first, and then the upper value into TMR(H). Writing into TMR(H) causes the counter to be loaded. A read of TMR returns the current counter value if the CTEST bit is 0, or the programmed reload value if CTEST is

In order for a read access to return an accurate value, the CPU should always read TMR(L) first, and then TMR(H). This is because a read of TMR(H) returns the content of an internal latch that is loaded with the 4 most significant bits of the current counter value when TMR(L) is read.

After reset, the content of this register is indeterminate.



FIGURE 5-33. TMR(L) Register Bitmap



FIGURE 5-34. TMR(H) Register Bitmap

## 5.17.2 Infrared Control Register 1 (IRCR1), Bank 4, Offset 02h

Controls the timer and counters, and enables the Sharp-IR or SIR infrared mode in the Non-Extended mode of operation.

Upon reset, all bits are set to 0.



#### FIGURE 5-35. IRCR1 Register Bitmap

#### Bit 0 - Timer Enable (TMR\_EN)

Enables the timer.

- 0 Timer is frozen. (Default)
- 1 Timer is enabled.

#### Bit 1 - Counter Test (CTEST)

When this bit is set to 1, the TMR register reload value, as well as the TFRL and RFRML register contents are returned during CPU reads

## Bits 3,2 - Sharp-IR or SIR Mode Select (IR\_SL1,0), Non-Extended Mode Only

These bits enable Sharp-IR and SIR modes in Non-Extended mode. They allow selection of the appropriate infrared interface when Extended mode is not selected. These bits are ignored when Extended mode is selected.

Upon termination of the application these bits should be reset to 00 to switch back to a UART mode.

TABLE 5-21. Sharp-IR or SIR Mode Selection

| IR_SL1 | IR_SL0 | Selected Mode  |
|--------|--------|----------------|
| 0      | 0      | UART (Default) |
| 0      | 1      | Reserved       |
| 1      | 0      | Sharp-IR       |
| 1      | 1      | SIR            |

#### Bits 7-4 - Reserved

Read/Write 0.

#### 5.17.3 Link Control Register (LCR) and Bank Select Register (BSR), Bank 4, Offset 03h

These registers are the same as the registers at offset 03h in bank 0.

#### 5.17.4 Transmission Frame Length Register (TFRL) or Transmission Frame Current Count Register (TFRCC), Bank 4, Offsets 04h and 05h

These registers share the same addresses.

TFRL is always accessed during write cycles and is used to program the transmitted frame length (in bytes) for the frame to be transmitted. The frame length value does not include appended CRC bytes. TFRL is accessed during read cycles, if the CTEST bit is set to 1, and returns the previously programmed value. Values from 1 to 2<sup>13</sup> - 1 are valid. The zero value is reserved and must not be used.

TFRCC is loaded with the content of TFRL when transmission of a frame begins, and decrements after each byte is transmitted. It is read-only and is accessed when the CTEST bit is 0. It returns the number of currently remaining bytes of the frame being transmitted.

These registers are 13 bits wide and are split into two independently accessible parts occupying consecutive address locations. TFRL(L) and TFRCC(L) are located at the lower address and access the least significant eight bits, whereas TFRL(H) and TFRCC(H) are located at the higher address and access the most significant five bits. The upper three bits of TFRL(H) are reserved and 0's must be written to them.

In order for a read access of TFRCC to return an accurate value, the CPU should always read TFRCC(L) first, and than read TFRCC(H).

After reset, the content of the TFRL register is 800h.

To properly program TFRL, the CPU must always write the lower value into TFRL(L) first, and then the upper value into TFRL(H).



FIGURE 5-36. TFRL(L) or TFRCC(L) Register Bitmap

**Transmission Frame Length or Current Count Most Significant Bits** (TFRL(H) or TFRCC(H)) Registér 0 0 0 0 1 0 0 0 Reset Bank 4, 0 0 0 Offset 05h Required Most Significant Bits of Transmission Frame Length or Current Count Reserved

FIGURE 5-37. TFRL(H) or TFRCC(H) Register Bitmap

Note: TFRCC is for testing purposes only..

# 5.17.5 Reception Frame Maximum Length (RFRML) or Reception Frame Current Count (RFRCC) Registers, Bank 4, Offsets 06h and 07h

These registers share the same addresses.

RFRML is always accessed during write cycles and is used to program the maximum frame length (in bytes) for the frame to be received. The maximum frame length value includes the CRC bytes. RFRML is accessed during read cycles, if the CTEST bit is set to 1, and returns the previously programmed value. Values from 1 to  $2^{13} - 1$  can be used. The zero value is reserved and must not be used.

RFRCC is set to 0 when reception of a frame begins, and increments after each byte is received. It is readonly and is accessed during CPU read cycles when the CTEST bit is 0. It returns the current number of bytes of the frame being received. These registers are 13 bits wide and are split into two independently accessible parts at consecutive addresses.

RFRML(L) and RFRCC(L) are at the lower addresses and access the least significant eight bits, whereas RFRML(H) and RFRCC(H) are at the higher addresses and access the most significant five bits. The upper three bits of RFRML(H) are reserved and must be 0.

In order for a read access of RFRCC to return an accurate value, the CPU should always read RFRCC(L) following a read of RFRCC(H).

After reset, the content of the RFRML register is 800h.

To properly program RFRML, the CPU must always write the lower value into RFRML(L) first, and then the upper value into RFRML(H).



FIGURE 5-38. RFRML(L) or RFRCC(L) Register
Bitmap



FIGURE 5-39. RFRML(H) or RFRCC(H) Register Bitmap

Note: RFRCC is for testing purposes only.

## 5.18 BANK 5 – INFRARED CONTROL AND ST FIFO REGISTERS

The registers in this bank handle pipelining, infrared control and ST\_FIFO parameters. For information about the pipeline operation see "Pipelining" on page 138.

TABLE 5-22. Bank 5 Registers

| Offset | Register<br>Name   | Description                                                                   |
|--------|--------------------|-------------------------------------------------------------------------------|
| 00h    | P_BGD(L<br>)       | Pipelined Baud Generator<br>Divisor, Low Byte                                 |
| 01h    | P_BGD(H<br>)       | Pipelined Baud Generator<br>Divisor, High Byte                                |
| 02h    | P_MDR              | Pipeline Mode Register                                                        |
| 03h    | LCR/<br>BSR        | Link Control Register/<br>Bank Select Register                                |
| 04h    | IRCR2              | Infrared Control Register 2                                                   |
| 05h    | FRM_ST             | Frame Status                                                                  |
| 06h    | RFRL(L)/<br>LSTFRC | Received Frame Length at<br>Bottom of ST_FIFO (Low Byte)/<br>Lost Frame Count |
| 07h    | RFRL(H)            | Received Frame Length at Bottom of ST_FIFO (High Byte)                        |

#### 5.18.1 Pipelined Baud Generator Divisor Registers, (P\_BGD(L) and P\_BGD(H)), Bank 5, Offsets 00h and 01h

The Pipeline Baud Generator Divisor (P\_LBGD(L) and P\_BGD(H)) registers hold the 16-bit value that determines the new baud rate following a pipeline operation. These registers occupy consecutive address locations.

The value written into these registers is loaded into the least and most significant parts of the baud generator divisor register when the transmitter becomes empty and both the MD\_PEN and BR\_PEN bits in the P\_MDR register are set to 1.

Upon reset, the content of these registers is indeterminate.



FIGURE 5-40. Pipelined Baud Rate Generator Divisor Register Bitmap

#### 5.18.2 Pipeline Mode Register (P\_MDR), Bank 5, Offset 02h

The Pipeline Mode Register can be read or written in any mode. However, a pipeline operation will only take place if the current operation mode and next operation mode are both IrDA modes. Furthermore, SIR must be selected in extended mode and the TX\_FIFO must be enabled.

When a pipeline operation takes place, the following occurs:

- 1. If the target mode is MIR or FIR, the transmitter is halted for 250us.
- 2. If the target mode is SIR, the transmitter is halted for 250μs or for a character time (at the newly selected baud rate), whichever is greater.

Upon reset, all bits are set to 0.



FIGURE 5-41. P MDR Register Bitmap

#### Bit 0 - Mode Bits Pipeline Enable (MD PEN)

When set to 1, a pipeline load operation takes place when the transmitter becomes empty. Bits 7, 6, 5 and 2 are loaded into the corresponding bit positions in the MCR (see page 148), and bit 3 is loaded into bit position 3 of EXCR1 (see page 157).

This bit is automatically cleared after the load has occurred and the pipeline status bit in the ASCR (see page 152) is set, indicating that a pipeline event occurred. If pipeline interrupts are enabled, then an interrupt is generated.

#### Bit 1 - Baud Rate Pipeline Enable (BR PEN)

This bit is effective only when the MD\_PEN bit (bit 0) is set to 1. If the transmitter becomes empty while this bit set to 1, the P\_BGD register will be loaded into the baud generator divisor register.

#### Bit 2 - Pipelined DMA Enable (P DMA EN)

When pipelining is enabled, whenever the transmitter becomes empty this bit will be placed in the DMA Enable bit in the Modem Control Register (MCR), thereby enabling/disabling DMA as is appropriate for the next mode of operation.

#### Bit 3 - Pipelined DMA Swap (P\_DMASWP)

When pipelining is enabled, this bit Indicates a swap is pending on the DMA channel. Whenever the transmitter becomes empty, this bit is placed in the DMA swap bit in the Modem Control Register (MCR), thereby enabling or disabling DMA input and output switching on the same channel, when 8237 type DMA is used, as is appropriate for the next mode of operation.

#### Bit 4 - Reserved

Read/Write 0.

#### Bits 7-5 - Pipelined Mode Select Bits(PMDSL2-0)

When MD\_PEN is enabled and the transmitter becomes empty, these bits are copied into their respective bits in the Modem Control Register (MCR).

#### 5.18.3 (LCR/BSR) Register, Bank 5, Offset 03h

These registers are the same as the registers at offset 03h in bank 0.

## 5.18.4 Infrared Control Register 2 (IRCR2), Bank 5, Offset 04h

This register controls the basic settings of the infrared modes.

Upon reset, the content of this register is 02h.



FIGURE 5-42. IRCR2 Register Bitmap

## Bit 0 - Enable Infrared Full Duplex Mode (IR FDPLX)

When set to 1, the infrared receiver is not masked during transmission.

## Bit 1 - MSR Register Function Select in Infrared Mode (IRMSSL)

This bit selects the behavior of the Modem Status Register (MSR) and the Modem Status Interrupt (MS\_EV) when any infrared mode is selected. When a UART mode is selected, the Modem Status Register and the Modem Status Interrupt function normally, and this bit is ignored.

- 0 MSR register and modem status interrupt work in the IR modes as in the UART mode (Enables external circuitry to perform carrier detection and provide wake-up events).
- 1 The MSR returns 30h, and the Modem Status Interrupt is disabled. (Default)

#### Bit 2 - MIR Data Rate Select (MDRS)

This bit determines the data rate in MIR mode.

0 - 1.152 Mbps (default)

1 - 0.576 Mbps

#### Bit 3 - Transmitter Mode Select (TX MS)

This bit is used in MIR and FIR modes only.

When it is set to 1, transmitter frame-end stop mode is selected.

In this case the transmitter stops after transmission of a frame is complete, if the end-of-frame condition was generated by the TFRCC counter reaching 0.

The transmitter can be restarted by clearing the TXHFE bit in the ASCR (see page 152).

#### Bit 4 - Auxiliary Infrared Input Select (AUX IRRX)

When set to 1, the infrared signal is received from the auxiliary input (Separate input signals may be desired for different front-end circuits). See Table 5-35 on page 177.

#### Bit 5 - Frame End Mode Control (FEND MD)

This bit selects whether a Terminal-Count(TC) condition from the TFRCC register (see on page 162) will generate an EOF in PIO mode or in DMA mode.

- 0 TFRCC terminal count effective in PIO mode.
- 1 TFRCC terminal count effective in DMA mode.

For a complete discussion of back-to-back frame transmission refer to "High-Speed Infrared Transmission" on page 133.

#### Bit 6 - ST\_FIFO Threshold Select (SFTSL)

An interrupt request is generated when the ST\_FIFO level reaches the threshold or when an ST\_FIFO timeout occurs.

TABLE 5-23. ST\_FIFO Interrupt Threshold Levels

| SFTSL Bit Value | Threshold Level |
|-----------------|-----------------|
| 0               | 2               |
| 1               | 4               |

#### Bit 7 - Reserved

Read/Write 0.

#### 5.18.5 The ST\_FIFO

An 8-level ST\_FIFO is used in **MIR** and **FIR** modes to support back-to-back incoming frames when the DMA is enabled and an 8237-type DMA controller is used

Each ST\_FIFO entry contains either status information and frame length for a single frame, or the number of lost frames.

The bottom entry spans three address locations, and is accessed via the following three registers (FRM ST, RFRL(L)/LSTFRC and RFRL(H)).

The ST\_FIFO is flushed when a reset occurs or when the operational mode is changed.

Status and length data are loaded into the ST\_FIFO whenever the DMA\_EN bit in the extended-mode MCR register is set to 1 and an 8237-type DMA controller is used, regardless of whether the CPU or the DMA controller is transferring the data from the RX\_FIFO to memory. This implies that, during testing, if full duplex is enabled and a DMA channel is servicing the transmitter while the CPU is servicing the receiver, the CPU must still read the ST\_FIFO otherwise the ST\_FIFO can be filled up and incoming frames will be rejected.

#### 5.18.6 Frame Status at FIFO Bottom Register (FRM\_ST), Bank 5, Offset 05h

This read-only register returns the status byte at the bottom of the frame ST\_FIFO. The ST\_FIFO and the received frame length can be used to determine the validity and the position of the received frames inside the reception buffer.

If the LOST\_FR bit is 0, bits 0 to 4 indicate if any error condition occurred during reception of the corresponding frame. Error conditions also affect the error flags in the LSR register.



#### FIGURE 5-43. FRM ST Register Bitmap

#### Bit 0 - Over-run Error 2 (OVR2)

This bit is set to 1 when incoming characters or entire frames have been discarded due to the ST\_FIFO being full.

#### Bit 1 - Over-run 1 (OVR1)

This bit is set to 1 when incoming characters or entire frames have been discarded due to the RX\_FIFO being full.

#### Bit 2 - CRC Error (BAD CRC)

This bit is set to 1 when a mismatch between the received CRC and the receiver-generated CRC is detected.

#### Bit 3 - Physical Layer Error (PHY\_ERR)

This bit is set to 1 when an encoding error or the sequence BOF-data-BOF is detected in FIR mode, or an abort condition is detected in MIR mode.

#### Bit 4 - Maximum Length Exceeded (MAX LEN)

This bit is set to 1 when a frame exceeding the maximum length has been received. The extra bytes are discarded (they are not stored).

#### Bit 5 - Reserved

Returned data is indeterminate.

#### Bit 6 - Lost Frame Indicator Flag (LOST FR)

Indicates the type of information provided by this entry.

- 0 Entry provides status information and length for a received frame.
- Entry provides over-run indications and number of lost frames.

#### Bit 7 - ST\_FIFO Valid (VLD)

When set to 1, indicates that the bottom entry in the ST FIFO contains valid data.

# 5.18.7 Received Frame Length LSB (RFRL(L)) or Lost Frame Count at ST\_FIFO Bottom (LSTFRC), Bank 5, Offset 06h

This read-only register should only be read when the VLD bit (bit 7) in the Frame ST\_FIFO Bottom (FRM\_ST) register is 1 (See previous section). The information returned depends on the setting of the LOST FR bit (bit 6 in the FRM ST register).

When the LOST\_FR bit is 0, this register contains the eight least significant bits of the received frame length.

When the LOST\_FR bit is 1, the register contains the number of lost frames.

Upon reset, all bits are undefined.

Received Frame Length(LSB) (RFRL(L)) or **Lost Frame Count** Register (LSTFRC) at 6 Х Х Х Х Х Х Х Х ST FIFO Bottom Required Bank 5. Offset 06h Least Significant Bits of Received Frame Length FIFO Bottom or the Lost Frame Count

FIGURE 5-44. RFRL(L) or LSTFRC Register Bitmap

## 5.18.8 Received Frame Length (MSB) at ST\_FIFO Bottom (RFRL(H)), Bank 5. Offset 07h

This read-only register should only be read when the VLD bit in FRM\_ST is 1. The information returned depends on the setting of the LOST\_FR bit (bit 6 in the FRM\_ST register).

When the LOST\_FR bit is zero, the register contains the most significant 5 bits of the received frame length.

When the LOST\_FR bit is one, all bits are set to 0.

Reading this register removes the bottom ST\_FIFO entry.

Upon reset, all bits are set to 0.



FIGURE 5-45. RFRL(H) Register Bitmap

## 5.19 BANK 6 – INFRARED PHYSICAL LAYER CONFIGURATION REGISTERS

This Bank of registers controls aspects of the framing and timing of the infrared modes.

TABLE 5-24. Bank 6 Register Set

| Offset    | Register<br>Name | Description                                     |
|-----------|------------------|-------------------------------------------------|
| 00h       | IRCR3            | Infrared Control Register 3                     |
| 01h       | MIR_PW           | MIR Pulse Width Control<br>(1.152 Mbps)         |
| 02h       | SIR_PW           | SIR Pulse Width Control<br>(≤ 115 Kbps)         |
| 03h       | LCR/<br>BSR      | Link Control Register/<br>Bank Select Register  |
| 04h       | BFPL             | Beginning Flags and<br>Preamble Length Register |
| 05h - 07h |                  | Reserved                                        |

## 5.19.1 Infrared Control Register 3 (IRCR3), Bank 6, Offset 00h

This Register selects the operating mode of the infrared interface. It also designates the CRC used for that mode and enables/disables modulation in Sharp-IR mode. To facilitate custom modes of operation the CRC is selectable. Typically, MIR uses CRC-16, and FIR uses CRC-32.

Upon reset, the content of this register is 20h.



#### FIGURE 5-46. IRCR3 Register Bitmap

#### Bit 0 - Reserved

Read/Write 0.

#### Bit 1 - Disable Transmitter CRC (TXCRC\_DS)

- 0 Append CRC to frames in the **MIR** and **FIR** modes of operation. (Default).
- 1 CRC is not transmitted.

#### Bit 2 - Invert Transmitter CRC (TXCRC\_INV)

When set to 1, an inverted CRC is transmitted (This bit can be used to force a bad CRC to be sent to test the datalink).

- 0 Send CRC normally. (Default).
- 1 Invert CRC.

#### Bit 3 - Reserved

Read/Write 0.

#### Bit 4 - MIR Mode CRC Select (MIR CRC)

Selects the CRC length in 1.152 Mbps (MIR) mode.

- 0 16-bit CRC. (Default)
- 1 32-bit CRC.

#### Bit 5 - FIR Mode CRC Select (FIR\_CRC)

Selects the CRC length in 4.0 Mbps (FIR) mode.

- 0 16 Bit CRC.
- 1 32 Bit CRC. (Default)

#### Bit 6 - Sharp-IR Modulation Disable (SHMD\_DS)

- 0 Enables internal 500KHz transmitter modulation. (Default)
- 1 Disables internal modulation.

### Bit 7 - Sharp-IR Demodulation Disable (SHDM DS)

- 0 Enables internal 500 KHz receiver demodulation. (Default)
- 1 Disables internal demodulation.

## 5.19.2 MIR Pulse Width Register (MIR\_PW), Bank 6, Offset 01h

This register sets the pulse width for transmitted MIR operation mode infrared pulses in increments of 20.83 or 41.666 nsec, depending on the setting of the MDRS bit in the IRCR2 Register (see p.165). These setting do not affect the receiver.

Upon reset, this register is set to 0Ah.



FIGURE 5-47. MIR\_PW Register Bitmap

#### Bits 3-0 - MIR Pulse Width Register (MPW)

These bits specify the pulse width in nsec, for MIR mode (see Table 5-25). Each bit increments the pulse width by 20.83 nsec or 41.666 nsec according to the MDRS bit in IRCR2 (see page 165).

**TABLE 5-25. MIR Pulse Width Settings** 

| ENCODING<br>MPW Bits 3-0 | Pulse Width<br>MDRS = 0 | Pulse Width<br>MDRS = 1 |
|--------------------------|-------------------------|-------------------------|
| 00XX                     | Reserved                | Reserved                |
| 0100                     | 83.33ns                 | 166.66ns                |
| 0101                     | 104.16ns                | 208.33ns                |
| 0110                     | 125ns                   | 250ns                   |
| 0111                     | 145.83ns                | 291.66ns                |
| 1000                     | 166.66ns                | 333.33ns                |
| 1001                     | 187.50ns                | 374.99ns                |
| 1010                     | 208.33ns                | 416.66ns                |
| 1011                     | 229.16ns                | 458.33                  |
| 1100                     | 250ns                   | 500ns                   |

| ENCODING<br>MPW Bits 3-0 | Pulse Width<br>MDRS = 0 | Pulse Width<br>MDRS = 1 |
|--------------------------|-------------------------|-------------------------|
| 1101                     | 270.83ns                | 541.66ns                |
| 1110                     | 291.66ns                | 583.32ns                |
| 1111                     | 312.5ns                 | 625ns                   |

#### Bits 7-4 - Reserved

Read/Write 0's.

## 5.19.3 SIR Pulse Width Register (SIR PW), Bank 6, Offset 02h

This register sets the pulse width for transmitted pulses in SIR operation mode. These setting do not affect the receiver. Upon reset, the content of this register is 00h, which defaults to a pulse width of 3/16 of the baud rate.



#### FIGURE 5-48. SIR PW Register Bitmap

#### Bits 3-0 - SIR Pulse Width Register (SPW)

Two codes for setting the pulse width are available. All other values for this field are reserved.

0000 - Pulse width is 3/16 of the bit period. (Default)

1101 - Pulse width is 1.6  $\mu$ sec.

#### Bits 7-4 - Reserved

Read/Write 0's.

#### 5.19.4 Link Control Register (LCR) and Bank Select Register (BSR), Bank 6, Offset 03h

These registers are the same as the registers at offset 03h in Bank 0.

#### 5.19.5 Beginning Flags and Preamble Length Register (BFPL), Bank 6, Offset 04h

This register programs the number of beginning flags for **MIR** mode and the preamble bytes for the **FIR** mode.

This register defaults to 2Ah, selecting two beginning flags for MIR mode and 16 preamble symbols for FIR mode.



FIGURE 5-49. BFPL Register Bitmap

### Bits 3-0 - FIR Preamble Length (in bytes) (FPL(3-0))

Selects the number of preamble symbols for **FIR** frames.

Table 5-26 specify the number of preamble symbols for **FIR** frames.

TABLE 5-26. FIR Preamble Length

| ENCODING<br>FPL Bits (3-0) | Preamble Length (in Bytes) |
|----------------------------|----------------------------|
| 0000                       | Reserved                   |
| 0001                       | 1                          |
| 0010                       | 2                          |
| 0011                       | 3                          |
| 0100                       | 4                          |
| 0101                       | 5                          |
| 0110                       | 6                          |
| 0111                       | 8                          |
| 1000                       | 10                         |
| 1001                       | 12                         |
| 1010                       | 16 (Default)               |
| 1011                       | 20                         |
| 1100                       | 24                         |

| ENCODING<br>FPL Bits (3-0) | Preamble Length (in Bytes) |
|----------------------------|----------------------------|
| 1101                       | 28                         |
| 1110                       | 32                         |
| 1111                       | Reserved                   |

#### Bits 7-4 - MIR Beginning Flags (MBF(3-0))

Selects the number of beginning flags for **MIR** frames.

Table 5-27 specify the number of beginning of flags for **MIR** frames.

**TABLE 5-27. MIR Beginning Flags** 

| ENCODING<br>MBF Bits (3-0) | Beginning Flags |
|----------------------------|-----------------|
| 0000                       | Reserved        |
| 0001                       | 1               |
| 0010                       | 2 (Default)     |
| 0011                       | 3               |
| 0100                       | 4               |
| 0101                       | 5               |
| 0110                       | 6               |
| 0111                       | 8               |
| 1000                       | 10              |
| 1001                       | 12              |
| 1010                       | 16              |
| 1011                       | 20              |
| 1100                       | 24              |
| 1101                       | 28              |
| 1110                       | 32              |
| 1111                       | Reserved        |

## 5.20 BANK 7 – CONSUMER-IR AND OPTICAL TRANSCEIVER CONFIGURATION REGISTERS

Bank 7 contains the registers that configure Consumer-IR functions and infrared transceiver controls. See Table 5-28.

TABLE 5-28. Bank 7 Register Set

| Offse<br>t | Register<br>Name | Description                                          |
|------------|------------------|------------------------------------------------------|
| 00h        | IRRXDC           | Infrared Receiver<br>Demodulator Control<br>Register |
| 01h        | IRTXMC           | Infrared Transmitter<br>Modulator Control Register   |
| 02h        | RCCFG            | Consumer-IR Configuration<br>Register                |
| 03h        | LCR/BS<br>R      | Link Control Register/<br>Bank Select Register       |
| 04h        | IRCFG1           | Infrared Interface<br>Configuration Register 1       |
| 05h        | IRCFG2           | Infrared Interface<br>Configuration Register 2       |
| 06h        | IRCFG3           | Infrared Interface<br>Configuration Register 3       |
| 07h        | IRCFG4           | Infrared Interface<br>Configuration Register 4       |

The Consumer-IR utilizes two carrier frequency ranges (See also Table 5-29):

- Low range which spans from 30 KHz to 56 KHz, in 1 KHz increments, and
- High range which includes three frequencies: 400KHz, 450KHz or 480KHz.

High and low frequencies are specified independently to allow separate transmission and reception modulation settings. The transmitter uses the carrier frequency settings in Table 5-29.

The four registers at offsets 04h through 07h (the infrared transceiver configuration registers) are provided to configure the Infrared Interface (the transceiver). The transceiver mode is selected by up to three special output signals (IRSL2-0). When programmed as outputs these signals are forced to low when automatic configuration is enabled (AMCFG bit set to 1) and a UART mode is selected.

#### 5.20.1 Infrared Receiver Demodulator Control Register (IRRXDC), Bank 7, Offset 0

This register controls settings for Sharp-IR and Consumer IR reception. After reset, the content of this register is 29h. This setting selects a subcarrier frequency in a range between 34.61 KHz and 38.26 KHz for the Consumer-IR mode, and from 480.0 to 533.3 KHz for the Sharp-IR mode. The value of this register is ignored in both modes if the receiver demodulator is disabled. The available frequency ranges for Consumer-IR and Sharp-IR modes are given in Tables 5-31 through 5-33.



FIGURE 5-50. IRRXDC Register Bitmap

#### Bits 4-0 - Demodulator Frequency (DFR(4-0))

These bits select the subcarrier's center frequency for the Consumer-IR receiver demodulator. Table 5-31 shows the selection for low speed demodulation (bit 5 of RCCFG=0, see page 174), and Table 5-32 shows the selection for high speed demodulation (bit 5 of RCCFG=1).

#### Bits 7-5 - Demodulator Bandwidth (DBW(2-0))

These bits set the demodulator bandwidth for the selected frequency range. The subcarrier signal frequency must fall within the specified frequency range in order to be accepted. Used for both Sharp-IR and Consumer-IR modes.

See Tables 5-31 and 5-32 on page 173 and bit 5 (RXHSC) of the Consumer-IR Configuration (RC-CFG) Register on page 174.

#### 5.20.2 Infrared Transmitter Modulator Control Register (IRTXMC), Bank 7, Offset 01h

This register controls modulation subcarrier parameters for Consumer-IR and Sharp-IR mode transmission. For Sharp-IR, only the carrier pulse width is controlled by this register - the carrier frequency is fixed at 500 KHz.

After reset, the value of this register is 69h, selecting a carrier frequency of 36 KHZ and an IR pulse width of 7  $\mu$ sec for Consumer-IR, or a pulse width of 0.8  $\mu$ sec for Sharp-IR.



FIGURE 5-51. IRTXMC Register Bitmap

## Bits 4-0 - Modulation Subcarrier Frequency (MCFR)

These bits set the frequency for the Consumer-IR modulation subcarrier. The encoding are defined in Table 5-29. Bits 7-5 - Modulation Subcarrier Pulse Width (MCPW)

Specify the pulse width of the subcarrier clock as shown in Table 5-30.

TABLE 5-29. Consumer-IR Carrier Frequency Encoding

|                                | _                            |                               |  |  |  |
|--------------------------------|------------------------------|-------------------------------|--|--|--|
| Encoding<br>MCFR Bits<br>43210 | Low Frequency<br>(TXHSC = 0) | High Frequency<br>(TXHSC = 1) |  |  |  |
| 00000                          | Reserved                     | Reserved                      |  |  |  |
| 00001                          | Reserved                     | Reserved                      |  |  |  |
| 00010                          | Reserved                     | Reserved                      |  |  |  |
| 00011                          | 30 KHz                       | 400 KHz                       |  |  |  |
| 00100                          | 31 KHz                       | Reserved                      |  |  |  |
| 00101                          | 32 KHz                       | Reserved                      |  |  |  |
| 00110                          | 33 KHz                       | Reserved                      |  |  |  |
| 00111                          | 34 KHz                       | Reserved                      |  |  |  |
| 01000                          | 35 KHz                       | 450 KHz                       |  |  |  |
| 01001                          | 36 KHz                       | Reserved                      |  |  |  |
| 01010                          | 37 KHz                       | Reserved                      |  |  |  |
| 01011                          | 011 38 KHz 480 KH            |                               |  |  |  |
| 01100                          | 39 KHz                       | Reserved                      |  |  |  |
| 01101                          | 40 KHz                       | Reserved                      |  |  |  |

| Encoding<br>MCFR Bits<br>43210 | Low Frequency<br>(TXHSC = 0) | High Frequency<br>(TXHSC = 1) |
|--------------------------------|------------------------------|-------------------------------|
| 01110                          | 41 KHz                       | Reserved                      |
|                                |                              |                               |
| 11010                          | 53 KHz                       | Reserved                      |
| 11011                          | 54 KHz                       | Reserved                      |
| 11100                          | 55 KHz                       | Reserved                      |
| 11101                          | 56 KHz                       | Reserved                      |
| 11110                          | 56.9 KHz                     | Reserved                      |
| 11111                          | Reserved                     | Reserved                      |

**TABLE 5-30.** Carrier Clock Pulse Width Options

| Encoding<br>MCPW Bits<br>7 6 5 | Low Frequency<br>(TXHSC = 0) | High Frequency<br>(TXHSC = 1) |
|--------------------------------|------------------------------|-------------------------------|
| 0 0 0                          | Reserved                     | Reserved                      |
| 0 0 1                          | Reserved                     | Reserved                      |
| 0 1 0                          | 6 μsec                       | 0.7 μsec                      |
| 0 1 1                          | 7 μsec                       | 0.8 μsec                      |
| 1 0 0                          | 9 μsec                       | 0.9 µsec                      |
| 1 0 1                          | 10.6 µsec                    | Reserved                      |
| 1 1 0                          | Reserved                     | Reserved                      |
| 111                            | Reserved                     | Reserved                      |

TABLE 5-31. Consumer-IR, Low Speed Demodulator (RXHSC = 0) (Frequency Ranges in kHz)

| DFR Bits  | DBW2-0 (Bits 7, 6 and 5 of IRRXDC) |       |       |       |       |       |       |  |
|-----------|------------------------------------|-------|-------|-------|-------|-------|-------|--|
| 4 3 2 1 0 | min/max                            | 0 0 1 | 010   | 011   | 100   | 101   | 110   |  |
| 00010     | min                                | 26.66 | 25.45 | 24.34 | 23.33 | 22.40 | 21.53 |  |
| 00010     | max                                | 29.47 | 31.11 | 32.94 | 35.00 | 37.33 | 40.00 |  |
| 00011     | min                                | 28.57 | 27.27 | 26.08 | 25.00 | 24.00 | 23.07 |  |
| 00011     | max                                | 31.57 | 33.33 | 35.29 | 37.50 | 40.00 | 42.85 |  |
| 0.01.00   | min                                | 29.28 | 27.95 | 26.73 | 25.62 | 24.60 | 23.65 |  |
| 00100     | max                                | 32.37 | 34.16 | 36.17 | 38.43 | 41.00 | 43.92 |  |
| 00101     | min                                | 30.07 | 28.68 | 27.43 | 26.29 | 25.24 | 24.27 |  |
| 00101     | max                                | 33.24 | 35.05 | 37.11 | 39.43 | 42.06 | 45.07 |  |
| 0.0.1.1.0 | min                                | 31.74 | 30.30 | 28.98 | 27.77 | 26.66 | 25.63 |  |
| 00110     | max                                | 35.08 | 37.03 | 39.21 | 41.66 | 44.44 | 47.61 |  |
| 00111     | min                                | 32.60 | 31.13 | 29.78 | 28.54 | 27.40 | 26.34 |  |
| 00111     | max                                | 36.00 | 38.05 | 40.29 | 42.81 | 45.66 | 48.92 |  |
| 01000     | min                                | 33.57 | 32.04 | 30.65 | 29.37 | 28.20 | 27.11 |  |
| 01000     | max                                | 37.10 | 39.16 | 41.47 | 44.06 | 47.00 | 50.35 |  |
| 01001     | min                                | 34.61 | 33.04 | 31.60 | 30.29 | 29.08 | 27.96 |  |
| 01001     | max                                | 38.26 | 40.38 | 42.76 | 45.43 | 48.46 | 51.92 |  |
| 01010     | min                                | 35.71 | 34.09 | 32.60 | 31.25 | 30.00 | 28.84 |  |
| 01010     | max                                | 39.47 | 41.66 | 44.11 | 46.87 | 50.00 | 53.57 |  |
| 01011     | min                                | 36.85 | 35.18 | 33.65 | 32.25 | 30.96 | 29.76 |  |
| 01011     | max                                | 40.73 | 43.00 | 45.52 | 48.37 | 51.60 | 55.28 |  |
| 01100     | min                                | 38.10 | 36.36 | 34.78 | 33.33 | 32.00 | 30.77 |  |
| 01100     | max                                | 42.10 | 44.44 | 47.05 | 50.00 | 53.33 | 57.14 |  |
| 01101     | min                                | 39.40 | 37.59 | 36.00 | 34.45 | 33.08 | 31.80 |  |
| 01101     | max                                | 43.55 | 45.94 | 48.64 | 51.68 | 55.13 | 59.07 |  |

| DFR Bits  | DBW2-0 (Bits 7, 6 and 5 of IRRXDC) |       |       |       |       |       |       |  |
|-----------|------------------------------------|-------|-------|-------|-------|-------|-------|--|
| 43210     | min/max                            | 0 0 1 | 0 1 0 | 0 1 1 | 100   | 101   | 110   |  |
| 01110     | min                                | 40.81 | 38.95 | 37.26 | 35.70 | 34.28 | 32.96 |  |
| 01110     | max                                | 45.11 | 47.61 | 50.41 | 53.56 | 57.13 | 61.21 |  |
| 10010     | min                                | 42.32 | 40.40 | 38.64 | 37.03 | 35.55 | 34.18 |  |
| 10010     | max                                | 46.78 | 49.37 | 52.28 | 55.55 | 59.25 | 63.48 |  |
| 10011     | min                                | 43.95 | 41.95 | 40.13 | 38.45 | 36.92 | 35.50 |  |
| 10011     | max                                | 48.58 | 51.27 | 54.29 | 57.68 | 61.53 | 65.92 |  |
| 10101     | min                                | 45.71 | 43.63 | 41.74 | 40.00 | 38.40 | 36.92 |  |
| 10101     | max                                | 50.52 | 53.33 | 56.47 | 60.00 | 64.00 | 68.57 |  |
| 10111     | min                                | 47.62 | 45.45 | 43.47 | 41.66 | 40.00 | 38.46 |  |
| 10111     | max                                | 52.63 | 55.55 | 58.82 | 62.50 | 66.66 | 71.42 |  |
| 11010     | min                                | 49.66 | 47.40 | 45.34 | 43.45 | 41.72 | 40.11 |  |
| 11010     | max                                | 54.90 | 57.94 | 61.35 | 65.18 | 69.53 | 74.50 |  |
| 11011     | min                                | 51.90 | 49.54 | 47.39 | 45.41 | 43.60 | 41.92 |  |
| 1 1 0 1 1 | max                                | 57.36 | 60.55 | 64.11 | 68.12 | 72.66 | 77.85 |  |
| 11101     | min                                | 54.38 | 51.90 | 49.65 | 47.58 | 45.68 | 43.92 |  |
| 11101     | max                                | 60.10 | 63.44 | 67.17 | 71.37 | 76.13 | 81.57 |  |

TABLE 5-32. Consumer IR, High Speed Demodulator (RXHSC = 1) (Frequency Ranges in kHz)

| DFR Bits    |         | DBW2-0 (Bits 7, 6 and 5 of IRRXDC) |        |        |        |        |        |  |
|-------------|---------|------------------------------------|--------|--------|--------|--------|--------|--|
| 4 3 2 1 0 m | min/max | 0 0 1                              | 010    | 011    | 100    | 101    | 110    |  |
| 00011       | min     | 380.95                             | 363.63 | 347.82 | 333.33 | 320.00 | 307.69 |  |
| 00011       | max     | 421.05                             | 444.44 | 470.58 | 500.00 | 533.33 | 571.42 |  |
| 0 1 0 0 0   | min     | 436.36                             | 417.39 | 400.00 | 384.00 | 369.23 | 355.55 |  |
| 01000       | max     | 480.00                             | 505.26 | 533.33 | 564.70 | 600.00 | 640.00 |  |
| 01011       | min     | 457.71                             | 436.36 | 417.39 | 400.00 | 384.00 | 369.92 |  |
|             | max     | 502.26                             | 533.33 | 564.70 | 600.00 | 640.00 | 685.57 |  |

TABLE 5-33. Sharp-IR Demodulator (Frequency Ranges in kHz)

| DFR Bits      | DBW2-0 (Bits 7, 6 and 5 of IRRXDC) |       |       |       |       |       |       |
|---------------|------------------------------------|-------|-------|-------|-------|-------|-------|
| 4 3 2 1 0     | min/max                            | 001   | 010   | 011   | 100   | 101   | 110   |
| , , , , , , , | min                                | 480.0 | 457.1 | 436.4 | 417.4 | 400.0 | 384.0 |
| XXXXX         | max                                | 533.3 | 564.7 | 600.0 | 640.0 | 685.6 | 738.5 |

#### 5.20.3 Consumer-IR Configuration Register (RCCFG), Bank 7, Offset 02h

This register control the basic operation of the Consumer-IR mode. After reset, the content of this register is 00h.



FIGURE 5-52. RCCFG Register Bitmap

## Bits 1,0 - Transmitter Modulation Mode (RC MMD(1,0))

Determines how infrared pulses are generated from the transmitted bit string. (see Table 5-34).

TABLE 5-34. Transmitter Modulation Mode Selection

| RCCFG<br>Bits<br>1 0 | Modulation Mode                                                                                                                  |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 0 0                  | <b>C_PLS Modulation mode.</b> Pulses are generated continuously for the entire logic 0 bit time.                                 |
| 0 1                  | <b>8_PLS Modulation Mode.</b> 8 pulses are generated each time one or more logic 0 bits are transmitted following a logic 1 bit. |
| 1 0                  | <b>6_PLS Modulation Mode.</b> 6 pulses are generated each time one or more logic 0 bits are transmitted following a logic 1 bit. |
| 1 1                  | Reserved. Result is indeterminate.                                                                                               |

## **Bit 2 - Transmitter Subcarrier Frequency Select** (TXHSC)

This bit selects the frequency range for the modulation carrier.

0 - Low frequency: 30-56.9 KHz 1 - High frequency: 400-480 KHz

#### Bit 3 - Reserved

Read/Write 0.

## Bit 4 - Receiver Demodulation Disable (RCDM DS)

When this bit is 1, the internal demodulator is disabled. The internal demodulator, when enabled, performs carrier frequency checking and envelope detection.

This bit must be set to 1 (disabled), when the demodulation is performed externally, or when oversampling mode is selected to determine the carrier frequency.

- 0 Internal demodulation enabled.
- 1 Internal demodulation disabled.

#### Bit 5 - Receiver Carrier Frequency Select (RXHSC)

This bit selects the frequency range for the receiver demodulator.

0 - Low frequency: 30-56.9 KHz1 - High frequency: 400-480 KHz

#### Bit 6 - Receiver Sampling Mode Select(T\_OV)

- 0 Programmed-T-period sampling.
- 1 Oversampling mode.

#### Bit 7 - Run Length Control (R\_LEN)

Enables or disables run length encoding/decoding. The format of a run length code is:

YXXXXXX

where, Y is the bit value and XXXXXXX is the number of bits minus 1 (Selects from 1 to 128 bits).

- 0 Run Length Encoding/decoding is disabled.
- 1 Run Length Encoding/decoding is enabled.

#### 5.20.4 Link Control/Bank Select Registers (LCR/BSR), Bank 7, Offset 03h

These registers are the same as the registers at offset 03h in bank 0.

#### 5.20.5 Infrared Interface Configuration Register 1 (IRCFG1), Bank 7, Offset 04h

This register holds the transceiver configuration data for Sharp-IR and SIR modes. It is also used to directly control the transceiver operation mode when automatic configuration is not enabled. The four least significant bits are also used to read the identification data of a Plug and Play infrared interface adaptor.



#### FIGURE 5-53. IRCFG1 Register Bitmap

### Bit 0 - Transceiver Identi cation/Control Bit 0 (IRIC0)

The function of this bit depends on whether the ID0/IRSL0/IRRX2 pin is programmed as an input or an output.

If ID0/IRSL0/IRRX2 is programmed as an input (IRSL0 DS = 0) then:

- Upon read, this bit returns the logic level of the pin (allowing external devices to identify themselves).
- Data written to this bit position is ignored.

If ID0/IRSL0/IRXX2 is programmed as an output (IRSL0\_DS = 1), then:

- If AMCFG (bit 7 of IRCFG4) is set to 1, this bit drives the ID0/IRSL0/IRRX2 pin when Sharp-IR mode is selected.
- If AMCFG is 0, these bits will drive the ID0/IRSL0/IRRX2 pin, regardless of the selected mode.

Upon read, this bit returns the value previously written.

## Bits 2-1 - Transceiver Identi cation/Control Bits 2-1 (IRIC2-1)

The function of these bits depends on whether the ID/IRSL(2-1) pins are programmed as inputs or outputs.

If ID/IRSL(2-1) are programmed as input (IRSL21 DS = 0) then:

Upon read, these bits return the logic level of the pins (allowing external devices to identify themselves).

Data written to these bit positions will be ignored.

If ID/IRSL(2-1) are programmed as output (IRSL21\_DS = 1) then:

If AMCFG (bit 7 of IRCFG4) is set to 1, these bits drive the ID/IRSL(2-1) pins when Sharp-IR mode is selected.

If AMCFG is 0, these bits will drive the ID/IRSL(2-1)pins, regardless of the selected mode.

Upon read, these bits return the values previously written.

#### Bit 3 - Reserved

Read/Write 0.

### Bits 6-4 - SIR Mode Transceiver Con guration (SIRC2-0)

These bits will drive the ID/IRSL(2-0) pins when AMCFG (bit 7 of IRCFG4) is 1 and SIR mode is selected. They are unused when AMCFG is 0 or when the ID/IRSL (2-0) pins are programmed as inputs. SIRC0 is also unused when the IRSL0\_DS bit in IRCFG4 is 0.

Upon read, these bits return the values previously written.

## Bit 7 - Special Transceiver Mode Selection (STRV\_MS)

This bit supports programming of the high speed mode in some optical devices. When this bit is set to 1, the IRTX output signal is forced to active high and a timer is started.

The timer times out after 64  $\mu$ sec, at which time the bit is reset and the IRTX output signal becomes low again. The timer is restarted every time a 1 is written to this bit.

Although it is possible to extend the period during which IRTX remains high beyond 64  $\mu$ sec, this should be avoided to prevent damage to the transmitter LED.

Writing a zero to this bit has no effect.

#### 5.20.6 Infrared Interface Configuration Register 2 (IRCFG2), Bank 7, Offset 05h

IRCFG2 holds the transceiver configuration data for the **MIR** and **FIR** modes.

Upon reset, the content of this register is 00h.



FIGURE 5-54. IRCFG2 Register Bitmap

## Bits 2-0 - MIR Mode Transceiver Con guration (MIRC(2-0))

These bits drive the ID/IRSL(2-0) pins when AM-CFG (bit 7 of IRCFG4) is 1 and MIR mode is selected. They are unused when AMCFG is 0 or when the ID/IRSL(2-0) pins are programmed as inputs.

Upon read, these bits return the values previously written.

#### Bit 3 - Reserved

Read/Write 0.

## Bits 6-4 - FIR Mode Transceiver Con guration (FIRC(2-0))

These bits drive the IRSL(2-0) pins when AMCFG is 1 and FIR mode is selected. They are unused when AMCFG (bit 7 of IRCFG4) is 0 or when the ID/IRSL(2-0) pins are programmed as inputs. Upon read, these bits return the values previously written.

#### Bit 7 - Reserved

Read/Write 0.

## 5.20.7 Infrared Interface Configuration 3 Register (IRCFG3), Bank 7, Offset 06h

This register sets the external transceiver configuration for the low speed and high speed Consumer IR modes of operation. Upon reset, the content of this register is 00h.



FIGURE 5-55. IRCFG3 Register Bitmap

## Bits 2-0 - Consumer-IR Mode Transceiver Con guration, Low-Speed (RCLC)

These bits drive the ID/IRSL(2-0) pins when AM-CFG is 1 and Consumer-IR mode with 30-56 KHz receiver carrier frequency is selected. They are unused when AMCFG is 0 or when the ID/IRSL(2-0) pins are programmed as inputs. Upon read, these bits return the values previously written.

#### Bit 3 - Reserved

Read/Write 0.

## Bits 6-4 - Consumer-IR Mode Transceiver Con guration, High-Speed (RCHC)

These bits drive the IRSL(2-0) pins when AMCFG (bit 7 of IRCFG4) is 1 and Consumer-IR mode with 400-480 KHz receiver carrier frequency is selected. They are unused when AMCFG is 0 or when the ID/IRSL(2-0) pins are programmed as inputs.

Upon read, these bits return the values previously written.

#### Bit 7 - Reserved

Read/Write 0.

#### 5.20.8 Infrared Interface Configuration Register 4 (IRCFG4), Bank 7, Offset 07h

This register configures the receiver data path and enables the automatic selection of the configuration pins.

After reset, this register contains 00h.



FIGURE 5-56. IRCFG4 Register Bitmap

#### Bits 2-0 - Reserved

Read/write 0.

## Bit 3- ID/IRSL(2-1) Pins' Direction Select (IRSL21 DS)

This bit determines the direction of the ID/IRSL2 and ID/IRSL1 pins.

- 0 Pins' direction is input.
- 1 Pins' direction is output.

#### Bit 4 - IRRX Signal Invert (RXINV)

This bit supports optical transceivers with receive signals of opposite polarity (active high instead of active low).

When set to 1 an inverter is put on the path of the input signal of the receiver.

## Bit 5 - ID0/IRSL0/IRRX2 Pin Direction Select (IRSL0\_DS)

This bit determines the direction of the ID0/IRSL0/IRRX2 pin.

- 0 Pin's direction is input.
- 1 Pin's direction is output.

#### Bit 6 - Infrared Mode Selection (IRRX MD)

Determines whether one or two inputs are used for IrDA low speed and high speed input signals.

Table 5-35 shows the possible combinations of IRSL0\_DS, IRRX\_MD and AUX\_IRRX.

#### 0 - One input pin is used for both low and highspeed IR modes.

1 - Low-speed input is on IRRX1 and High-speed is on IRRX2.

#### Bit 7 - Automatic Module Con guration (AMCFG)

When set to 1, this bit enables automatic infrared configuration.

**TABLE 5-35.** Infrared Receiver Input Selection

| Bit 5 of<br>IRCFG4 <sup>a</sup><br>(IRSL0_DS) | Bit 6 of<br>IRCFG4 <sup>a</sup><br>(IRRX_MD) | Bit 4 of IRCR2<br>(AUX_IRRX) <sup>b</sup> | HIS_IR<br>(1 when MIR<br>or FIR<br>selected) | Selected IRRX |
|-----------------------------------------------|----------------------------------------------|-------------------------------------------|----------------------------------------------|---------------|
| 0                                             | 0                                            | 0                                         | х                                            | IRRX1         |
| 0                                             | 0                                            | 1                                         | Х                                            | IRRX2         |
| 0                                             | 1                                            | х                                         | 0                                            | IRRX1         |
| 0                                             | 1                                            | х                                         | 1                                            | IRRX2         |
| 1                                             | 0                                            | 0                                         | Х                                            | IRRX1         |
| 1                                             | 0                                            | 1                                         | Х                                            | 1             |
| 1                                             | 1                                            | х                                         | 0                                            | IRRX1         |
| 1                                             | 1                                            | х                                         | 1                                            | 1             |

a. IRCFG4 is in bank 7, offset 07h. It is described on page 176.

b. AUX\_IRRX (bit 4 of IRCR2) is described on page 165.















#### 6.0 DMA and Interrupt Mapping

The Chip provides Plug and Play support.

#### 6.1 DMA SUPPORT

#### 6.1.1 Legacy Mode

Table 6-1 shows the conditions under which DMA request signals are put in TRI-STATE, in legacy mode. For each DMA signal to be put in TRI-STATE, every column must have one true condition. If no condition is true in any one column, the signal is not put in TRI-STATE.

#### 6.1.2 Plug and Play Mode

The Chip allows the Floppy Disk Controller (FDC), the parallel port and UART2 to be connected to three 8-bit DMA channels.

It is illegal to configure a pair of DMA signals to more than one DMA source.

A pair of DMA signals may be configured to a specific device only when the device is disabled.

Upon reset, DRQ2 and  $\overline{DACK2}$  are used by the FDC. A DRQ line is in TRI-STATE<sup>®</sup> and the  $\overline{DACK}$  line input is blocked to 1, when any of the following conditions is true:

- When no device is mapped to the DMA channel.
- When the device mapped to the DMA channel is inactive.

In Plug and Play mode, this condition is true for all devices.

In Legacy mode, this condition is true only for UART2 and the parallel port, controlled by bit 2 of the FER register and bit 2 of the PCR register, respectively.

 When the device mapped to the DMA channel floats its DRQ line.

Table 6-2 shows the conditions that put DMA request signals in TRI-STATE, in Plug and Play mode. For each DMA signal to be put in TRI-STATE, every column must have one true condition. If no condition is true in any one column, the signal is not put in TRI-STATE.

| TABLE 6-1. | <b>DMA Support in</b> | <b>Legacy Mode</b> |
|------------|-----------------------|--------------------|
|------------|-----------------------|--------------------|

| DMA Signal        | I-STATE                                                                                    |                                                                                  |                                                           |
|-------------------|--------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|-----------------------------------------------------------|
| DMA Signal        | Parallel Port                                                                              | FDC                                                                              | UART2                                                     |
| DRQx <sup>a</sup> | DRQx <sup>a</sup> not selected or bit 2 of PCR = 0 or bit 2 of PCR = 1 and bit 3 of ECR =0 | DRQx <sup>a</sup> not selected<br>or<br>bit 3 of DOR = 0<br>and bit 7 of ASC = 1 | DRQx <sup>a</sup> not selected<br>or<br>bit 2 of FER. = 0 |

a. x = 0, 1 or 2

TABLE 6-2. DMA Support in Plug and Play Mode

| DMA Signal        | Conditions for DRQx <sup>a</sup> to be in TRI-STATE                                                                |                                                                                             |                                                          |  |  |  |
|-------------------|--------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|----------------------------------------------------------|--|--|--|
| DIMA Signal       | Parallel Port                                                                                                      | Parallel Port FDC                                                                           |                                                          |  |  |  |
| DRQx <sup>a</sup> | DRQx <sup>a</sup> not selected  or bit 0 of FER = 0  or bit 2 of PCR = 0  or bit 2 of PCR = 1 and bit 3 of ECR = 0 | DRQx <sup>a</sup> not selected or bit 3 of FER = 0 or bit 3 of DOR = 0 and bit 7 of ASC = 1 | DRQx <sup>a</sup> not selected<br>or<br>bit 2 of FER = 0 |  |  |  |

a. x = 0, 1 or 2

#### 6.2 INTERRUPT SUPPORT

#### 6.2.1 Legacy Mode

Tables 6-3 and 6-4 describe the possible interrupt source for each IRQ, in legacy mode. A plus sign (+) means this is a possible interrupt source and a minus sign (–) means it is not.

Table 6-4 also indicates the conditions that must be true to enable IRQ 5, 12 and 15. All conditions in the row (horizontally) must be true to enable the interrupt. An x indicates the value does not matter.

It is illegal to configure two or more devices to the same ISA interrupt, with the exception of UART1 and UART2 which can be configured to the same ISA interrupt. An ISA interrupt may be configured to a specific device only when the device is disabled.

Table 6-5 describes the conditions under which each interrupt is put in TRI-STATE, in Legacy mode.

For each interrupt to be put in TRI-STATE, every column must have one true condition. If no condition is true in any one column, the signal will not be put in TRI-STATE.

TABLE 6-3. Interrupt Support in Legacy Mode for IRQ3, 4, 6, 7, 9 10 and 11

|                   | Possible Interrupt Source |       |               |     |                     |  |  |  |  |  |
|-------------------|---------------------------|-------|---------------|-----|---------------------|--|--|--|--|--|
| Interrupt         | UART1                     | UART2 | Parallel Port | FDC | SIRQIn <sup>a</sup> |  |  |  |  |  |
| IRQ3,4            | +                         | +     | _             | _   | +                   |  |  |  |  |  |
| IRQ6              | _                         | _     | _             | +   | +                   |  |  |  |  |  |
| IRQ7              | _                         | _     | +             | _   | +                   |  |  |  |  |  |
| IRQx <sup>b</sup> | _                         | _     | _             | _   | +                   |  |  |  |  |  |

a. n = 1, 2 or 3b. x = 9, 10 or 11

TABLE 6-4. Interrupt Support in Legacy Mode for IRQ 5, 12 and 15

|           | Conditions      |                  |                          | Possible Interrupt Source |   |       |                  |     |        |        |        |
|-----------|-----------------|------------------|--------------------------|---------------------------|---|-------|------------------|-----|--------|--------|--------|
| Interrupt | Bit 0 of<br>ASC | Bit 3 of<br>SCF3 | Bits 7,6<br>of<br>SIRQI1 | Reset<br>Value<br>of CFG0 |   | UART2 | Parallel<br>Port | FDC | SIRQI1 | SIRQI2 | SIRQI3 |
| IRQ5      | 0               | х                | х                        | х                         | - | _     | +                | _   | +      | +      | +      |
| INQS      | 1               | х                | х                        | х                         | _ | _     | _                | -   | _      | _      | _      |
|           | Х               | 0                | х                        | 0                         | _ | _     | _                | -   | +      | +      | +      |
| IRQ12     | Х               | 1                | х                        | 0                         | _ | _     | _                | -   | _      | _      | _      |
|           | Х               | х                | х                        | 1                         | _ | _     | _                | -   | _      | _      | _      |
|           | Х               | х                | 0 0                      | х                         | _ | _     | _                | -   | _      | +      | +      |
| IRQ15     | х               | х                | 0 1                      | х                         | _ | _     | -                | -   | _      | _      | _      |
|           | Х               | х                | 1 x                      | х                         | - | -     | _                | -   | -      | _      | _      |

TABLE 6-5. TRI-STATE Condition for Interrupts in Legacy Mode

| 1                 | TRI-STATE Condition        |                            |                            |                            |                                |  |  |  |  |  |
|-------------------|----------------------------|----------------------------|----------------------------|----------------------------|--------------------------------|--|--|--|--|--|
| Interrupt         | UART1                      | UART2                      | Parallel Port              | FDC                        | SIRQIn <sup>a</sup>            |  |  |  |  |  |
| IRQ3,4            | As described in Chapter 5. | As described in Chapter 5. | NA                         | NA                         | IRQ3 or 4 not selected         |  |  |  |  |  |
| IRQ5,7            | NA                         | NA                         | As described in Chapter 4. | NA                         | IRQ5 or 7 not selected         |  |  |  |  |  |
| IRQ6              | NA                         | NA                         | NA                         | As described in Chapter 3. | IRQ6 not selected              |  |  |  |  |  |
| IRQx <sup>b</sup> | NA                         | NA                         | NA                         | NA                         | IRQx <sup>b</sup> not selected |  |  |  |  |  |

a. n = 1, 2 or 3

b. x = 9, 10, 11, 12 or 15

#### 6.2.2 Plug and Play Mode

In Plug and Play mode, software can configure the interrupts of the Chip on the ISA interrupts.

It is illegal to configure two or more devices to the same ISA interrupt, with the exception of UART1 and UART2 which can be configured to the same ISA interrupt.

An interrupt should be configured to a specific device only when the device is disabled.

Tables 6-6 and 6-7 describe the possible interrupt source for each IRQ. A plus sign (+) means this is a possible interrupt source and a minus sign (–) means it is not.

Table 6-7 also indicates the conditions that must be true to enable IRQ 5, 12 and 15. All conditions in the row (horizontally) must be true to enable the interrupt. An x indicates the value does not matter.

Table 6-8 describes the conditions under which each interrupt is put in TRI-STATE, in Plug and Play mode.

For each interrupt to be put in TRI-STATE, every column must have one true condition. If no condition is true in any one column, the signal will not be put in TRI-STATE.

An IRQ signal is in TRI-STATE when any of the following conditions is true:

- When no device is mapped to the IRQ line.
- When the device mapped to the IRQ line is inactive.
- When the device mapped to the IRQ line floats its IRQ line.

TABLE 6-6. Interrupt Support in Plug and Play Mode for IRQ3, 4, 6, 7, 9, 10 or 11

| Inda was and      | Source |       |               |     |                     |  |  |
|-------------------|--------|-------|---------------|-----|---------------------|--|--|
| Interrupt         | UART1  | UART2 | Parallel Port | FDC | SIRQIn <sup>a</sup> |  |  |
| IRQx <sup>b</sup> | +      | +     | +             | +   | +                   |  |  |

a. n = 1, 2 or 3 b. x = 3, 4, 6, 7, 9, 10 or 11

TABLE 6-7. Interrupt Support in Plug and Play Mode for IRQ 5, 12 or 15

|           |                 | Conditions       |                          |                           | Possible Interrupt Source |       |                  |     |        |        |        |
|-----------|-----------------|------------------|--------------------------|---------------------------|---------------------------|-------|------------------|-----|--------|--------|--------|
| Interrupt | Bit 0 of<br>ASC | Bit 3 of<br>SCF3 | Bits 7,6<br>of<br>SIRQI1 | Reset<br>Value<br>of CFG0 |                           | UART2 | Parallel<br>Port | FDC | SIRQI1 | SIRQI2 | SIRQI3 |
| IRQ5      | 0               | х                | х                        | х                         | +                         | +     | +                | +   | +      | +      | +      |
|           | 1               | х                | х                        | х                         | -                         | _     | _                | _   | _      | _      | _      |
| IRQ12     | х               | 0                | х                        | 0                         | +                         | +     | +                | +   | +      | +      | +      |
|           | х               | 1                | х                        | 0                         | -                         | _     | _                | _   | _      | _      | _      |
|           | х               | х                | х                        | 1                         | -                         | _     | _                | _   | _      | _      | _      |
| IRQ15     | х               | х                | 00                       | х                         | +                         | +     | +                | +   | _      | +      | +      |
|           | х               | х                | 01                       | х                         | _                         | _     | _                | _   | _      | _      | _      |
|           | Х               | Х                | 1x                       | Х                         | _                         | _     | _                | _   | _      | _      | _      |

TABLE 6-8. TRI-STATE Conditions for Interrupts in Plug and Play Mode

| IRQ               |                                | Conditions for IRQx <sup>b</sup> to be in TRI-STATE |                                |                                |                                |  |  |  |  |  |
|-------------------|--------------------------------|-----------------------------------------------------|--------------------------------|--------------------------------|--------------------------------|--|--|--|--|--|
| inu               | UART1                          | UART2                                               | PP                             | FDC                            | SIRQIn <sup>a</sup>            |  |  |  |  |  |
| IRQx <sup>b</sup> | IRQx <sup>b</sup> not selected | IRQx <sup>b</sup> not selected                      | IRQx <sup>b</sup> not selected | IRQx <sup>b</sup> not selected | IRQx <sup>b</sup> not selected |  |  |  |  |  |
|                   | or<br>bit 1 of FER = 0         | or<br>bit 2 of FER = 0                              | or<br>bit 0 of FER = 0         | or<br>bit 3 of FER = 0         |                                |  |  |  |  |  |
|                   | or<br>bit 3 of MCR1 = 0        | or<br>bit 3 of MCR2 = 0                             | or<br>bit 4 of CTR = 0         | or<br>bit 3 of DOR = 0         |                                |  |  |  |  |  |
|                   | or<br>bit 4 of MCR1 = 1        | or<br>bit 4 of MCR2 = 1                             | or<br>bit 2 of PCR = 0         | or<br>bit 7 of ASC = 1         |                                |  |  |  |  |  |

a. n = 1, 2 or 3b. x = 3, 4, 5, 6, 7, 9, 10, 11, 12 Or 15

#### 7.0 Power Management

The chip places special emphasis on power management. Power management is implemented in the two major states of the chip: Power-Down and Power-Up.

#### 7.1 POWER-DOWN STATE

Power-down can be divided into two major groups:

#### Group 1:

Full power-down - the entire chip is powered-down/disabled.

#### Group 2:

Specific function power-down - specific Superl/O modules (FDC, UART1, UART2, ECP, Parallel Port) are powered-down/disabled.

All power-down modes are enhanced by a new feature which allows TRI-STATE of the output pins associated with a specific function (FDC, UART1, UART2, Parallel Port), and reduces current leakage by blocking their inputs.

Four modules in the chip are operated by the internal clock - FDC, UART1, UART2 and ECP. These modules can be powered-down/disabled by stopping their associated internal clocks. In addition, all four modules can be powered-down/disabled by stopping the external crystal oscillator.

Modules which do not use a clock; e.g., Parallel Port (SPP/EPP), can be powered-down/disabled by simply blocking access to them.

All the above power-down modes can be achieved using the power-down methods from Group 1 or Group 2, as described below.

## 7.1.1 Recommended Power-Down Methods - Group 1

Use the power-down methods in Group 1 to place the chip in following modes:

#### Mode 1

The entire chip is powered-down, the oscillator is stopped, pins are TRI-STATE, and the inputs are blocked.

In this mode the maximum current saving can be achieved.

#### Mode 2

The entire chip is powered-down and the oscillator is stopped. Pins are driven.

There are five ways to reach the above two operating modes. See Table 7-1.

| <b>TABLE</b> | 7-1. | Group 1 | Power-Down |
|--------------|------|---------|------------|
|--------------|------|---------|------------|

| Method | PTR bit<br>0 | FER bits<br>3210 | PCR bit | PMC bits<br>621 | SCF0 bit | Mode | Typical Current<br>Consumption |
|--------|--------------|------------------|---------|-----------------|----------|------|--------------------------------|
| 1      | 1            | XXXX             | Х       | 111             | 1        | #1   | 10 μΑ                          |
| 2      | X            | 0000             | 0       | 111             | 1        |      |                                |
| 3      | 1            | XXXX             | Х       | 000             | 0        | #2   | 1.5 mA                         |
| 4      | X            | 0000             | 0       | 000             | 0        |      |                                |
| 5      | X            | 1xxx             | х       | 000             | 0        |      |                                |

#### Notes:

- 1. The chip can also be placed in Mode 2 by using method #5, and entering FDC Low Power by executing Mode Command or by setting bit 6 of DSR to high.
- 2. The Current Consumption values are measured under the following conditions:
  - No load on output signals
  - Input signals are stable
  - $V_{IL} = V_{SS}$ ,  $V_{IH} = V_{DD}$

- $-V_{DD} = 3.3V$
- FCR bit 0 of UART1 and UART2 are 1 (16550 mode FIFO enabled)
- When PCR bit 3 is 1, and the ECP is enabled (bit 2 of PCR is 1) the clock multiplier and the ECP clock are not stopped.

## 7.1.2 Recommended Power-Down Methods - Group 2

Use the power-down methods in Group 2 to place the chip in any desired combination of the following power-down modes:

Mode 1:Parallel Port (SPP/EPP/ECP) is powered-down, providing a possible saving of up to 5 mA.

Mode 2: UARTs are powered-down, providing a possible saving of up to 5 mA.

Mode 3:FDC is powered-down, providing a possible saving of up to 4 mA.

#### 7.1.3 Special Power-Down Cases

The FDC can be powered down by executing the MODE command or by setting bit 6 of DSR to high. This is equivalent to the Mode 2 described in the previous section. See Sections 3.3.7 and 3.6.7.

When the parallel port is enabled in Extended Capability Port (ECP) mode (bit 2 of the Printer Control configuration Register (PCR) is 1), powering down by setting bit 2 of the Power and Test configuration Register (PTR) will not stop the clock of the ECP. Bit 3 of PCR must also be 0 before the internal clock multiplier to the ECP can stop. See Sections 2.3.4 and 2.3.6.

#### 7.2 POWER-UP

The chip powers up with all modules disabled, as described in Mode 2, above.

#### 7.2.1 The Clock Multiplier

The source of all internal clocks in the chip can be either an external 48 MHz clock on the X1 pin, or the onchip clock multiplier.

The on-chip clock multiplier is fed by applying either a 14.31818 MHz or a 24 MHz clock on the same X1 pin. It generates two internal clocks: 24 MHz and 48 MHz. The 24 MHz clock is needed for UART1, the FDC and the Parallel Port. The 48 MHz clock is needed for UART2 and the FDC when it supports 2Mbps data rates, as set by bit 1 of the Tape, UARTS and Parallel Port (TUP) register. See Section 2.3.8.

After power-up or reset, the clock multiplier is disabled.

#### **Clock Multiplier Functionality**

The on-chip clock multiplier starts working, when it is enabled via the clock multiplier enable bit (bit 2 of the CLK register, at index 51), i.e., when it changes from 0 to 1. This bit can also disable the on-chip clock multiplier and its output clock after the multiplier is enabled.

Once enabled, the output clock is frozen to a steady logic level until the multiplier can provide a stable output clock that meets all requirements; then it starts toggling.

On power-on, when  $V_{DD}$  is applied, the chip wakes-up with the on-chip clock multiplier disabled. The input and output clocks of the on-chip clock multiplier may toggle regardless of the state of the Master Reset (MR) pin (they can toggle while MR is active). The on-chip clock multiplier must have a toggling input clock. If the input clock is not toggling, the on-chip clock multiplier waits until this input clock starts toggling.

Bit 3 of the CLK register is the Valid Clock Multiplier status bit. It is read only. While stabilizing, the output clock is frozen to a steady logic level, and the status bit is cleared to 0 to indicate a frozen clock. When the on-chip clock multiplier is stable, the output clock starts toggling and the status bit is set to 1. The status bit tells the software, when the clock multiplier is ready. The software should poll this status bit and activate (enable) the FDC, Parallel Port, UARTs and infrared interface only if it is 1.

When the multiplier is enabled for the first time after power-on, more time is required until this status bit is set to 1.

The on-chip clock multiplier and its output clock do not consume power, when they are disabled.

#### **Clock Multiplier Speci cations**

Wake-up time, from valid  $V_{DD}$  (2.1V minimum) toggling input clock and multiplier enabled, until clock is stable is 2.6 msec (maximum).

Tolerance (long term deviation) of the multiplier output clock, relative to input clock is  $\pm 110$  ppm.

Total tolerance is therefore  $\pm$  (input clock tolerance + 110 ppm).

Cycle by cycle variance is 0.4 nsec (maximum).

#### 7.2.2 Chip Power-Up Procedure

To ensure proper operation, do the following, after power-up:

1. Set bits 2,1 and 0 of the Clock Control configuration (CLK) register at index 51, according to the external clock source used. See Table 7-2.

Bits 2,1 and 0 may be written in a single write cycle.

**TABLE 7-2.** Clock Multiplier Encoding Options

|                                         | CLK Register (Index 51h)            |                               |                      |   |  |  |  |  |
|-----------------------------------------|-------------------------------------|-------------------------------|----------------------|---|--|--|--|--|
| External<br>Clock on<br>Pin X1<br>(MHz) | Valid Clock<br>Multiplier<br>Status | Clock<br>Multiplier<br>Enable | Chip Clock<br>Source |   |  |  |  |  |
| , ,                                     | 3                                   | 2                             | 1                    | 0 |  |  |  |  |
| 14.31818                                | 0 = Reset                           | 1                             | 0                    | 0 |  |  |  |  |
| 24                                      | 1 = Stable                          | 1                             | 0                    | 1 |  |  |  |  |
| 48                                      | Always 0                            | 0                             | 1                    | 0 |  |  |  |  |
| Reserved                                | х                                   | х                             | 1                    | 1 |  |  |  |  |

From this point on, bits 1 and 0 of the CLK register are read-only. The value of the clock source can not be changed, except by a total power-off and power-on cycle. However, the on-chip clock multiplier can be disabled at any time.

- If the external clock source is 14.31818 MHz or 24 MHz:
  - Enable the on-chip clock multiplier.
  - Poll bit 3 of the CLK register while the clock multiplier is stabilizing.
  - When bit 3 of CLK is set to 1, go to step 3.

If the external clock source is 48 MHz, do not enable the clock multiplier.

3. Enable any module of the chip.

#### 7.2.3 UART Power-Up

The clock signal to the UARTs is controlled by the FER and PTR configuration registers.

To restore the clock signal to one or both UARTs, the following must both be true:

- The appropriate enable bits, bits 2 and 1 of FER for UART2 and UART1, respectively must be set to 1.
- The power-down bit, bit 0 of PTR, must be 0.

If the on-chip clock multiplier stopped, allow time (maximum 2.4 msec) for multiplier stabilization before sending any data or signaling that the receiver channel is ready. The stabilization period can be sensed by reading the Main Status Register in the FDC, if the FDC is being powered up. (The Request for Master bit (RQM) is not set for approximately 2.4 msec). If the FDC is not powered up but, either one of the UARTs is being powered up, then, software must generate a delay of 2.4 msec. Stabilization of multiplier can also be sensed by putting any of the enabled UARTs into local loopback mode and sending bytes until they are received correctly.

#### 7.2.4 FDC Power-Up

The clock signal to the FDC is controlled by the configuration registers, the FDC MODE command and the Data Rate Select Register (DSR).

To restore the clock signal to the FDC, both of the following conditions must be true:

- Bit 3 of FER must be set to 1.
- The power-down bit, bit 0 of PTR, must be 0.

In addition to these conditions, do one of the following to initiate the recovery from power-down mode:

- Read the Main Status Register (MSR) until the RQM bit, bit 7, is set to 1.
- Set the software reset bit, bit 7 or the Data Rate Select Register (DSR), to 1.
- Write the following to the reset bit, bit 2 or the Digital Output Register (DOR):
  - Set it to 1.
  - Clear it to 0.
- Read the Data Register and the Main Status Register until the RQM bit is set to 1.

#### 8.0 Device Description

#### 8.1 GENERAL DC ELECTRICAL CHARACTERISTICS

#### 8.1.1 Recommended Operating Conditions

TABLE 8-1. Recommended Operating Conditions at 5 V  $\pm$  10%

| Parameter             | Symbol         | Conditions | Min | Typical | Max | Unit |
|-----------------------|----------------|------------|-----|---------|-----|------|
| Supply voltage        | $V_{DD}$       |            | 4.5 | 5.0     | 5.5 | V    |
| Operating temperature | T <sub>A</sub> |            | 0   |         | +70 | ° C  |

TABLE 8-2. Recommended Operating Conditions at 3.3 V  $\pm$  10%

| Parameter             | Symbol         | Conditions | Min | Typical | Max | Unit |
|-----------------------|----------------|------------|-----|---------|-----|------|
| Supply voltage        | $V_{DD}$       |            | 3.0 | 3.3     | 3.6 | V    |
| Operating temperature | T <sub>A</sub> |            | 0   |         | +70 | ° C  |

#### 8.1.2 Absolute Maximum Ratings

Absolute maximum ratings are values beyond which damage to the device may occur.

Unless otherwise specified, all voltages are relative to ground.

**TABLE 8-3.** Absolute Maximum Ratings

| Parameter                            | Symbol           | Conditions                                                   | Min  | Max                   | Unit |
|--------------------------------------|------------------|--------------------------------------------------------------|------|-----------------------|------|
| Supply voltage                       | $V_{DD}$         |                                                              | -0.5 | 7.0                   | V    |
| Input voltage                        | VI               | $V_{DD} = 5V - 5.5V$                                         | -0.5 | V <sub>DD</sub> + 0.5 | V    |
| Input voltage                        | VI               | $V_{DD} = 3V - 5V$                                           | -0.5 | 5.5                   | V    |
| Output voltage                       | V <sub>O</sub>   |                                                              | -0.5 | V <sub>DD</sub> + 0.5 | V    |
| Storage temperature                  | T <sub>STG</sub> |                                                              | -65  | +165                  | ° C  |
| Power dissipation                    | P <sub>D</sub>   |                                                              |      | 1                     | W    |
| Lead temperature soldering (10 sec.) | TL               |                                                              |      | +260                  | ° C  |
| ESD tolerance                        |                  | $C_{ZAP} = 100 \text{ pF}$ $R_{ZAP} = 1.5 \text{ K}\Omega^a$ | 2000 |                       | V    |

a. Value based on test complying with RAI-5-048-RA human body model ESD testing.

#### 8.1.3 Capacitance

TABLE 8-4. Capacitance:  $T_A = 25^{\circ}$  C, f = 1 MHz

| Parameter               | Symbol           | Min | Typical | Max | Unit |
|-------------------------|------------------|-----|---------|-----|------|
| Input pin capacitance   | C <sub>IN</sub>  |     | 5       | 7   | pF   |
| Clock input capacitance | C <sub>IN1</sub> |     | 8       | 10  | pF   |
| I/O pin capacitance     | C <sub>IO</sub>  |     | 10      | 12  | pF   |
| Output pin capacitance  | C <sub>O</sub>   |     | 6       | 8   | pF   |

#### 8.1.4 Power Consumption Under Recommended Operating Conditions

**TABLE 8-5.** Power Consumption

| Parameter                                                               | Cumbal            | Conditions                                                |     | 5V      |     | 3.3V |         |     | Unit  |
|-------------------------------------------------------------------------|-------------------|-----------------------------------------------------------|-----|---------|-----|------|---------|-----|-------|
| Parameter                                                               | Symbol            | Conditions                                                | Min | Typical | Max | Min  | Typical | Max | Offic |
| V <sub>DD</sub> average supply current                                  | I <sub>CC</sub>   | $V_{IL} = 0.5 \text{ V}$ $V_{IH} = 2.4 \text{ V}$ No Load |     | 25      | 55  |      | 12      | 35  | mA    |
| V <sub>DD</sub> quiescent supply current in low power mode <sup>a</sup> | I <sub>CCSB</sub> | $V_{IL} = V_{SS}$ $V_{IH} = V_{DD}$ No Load               |     | 20      |     |      | 10      |     | μА    |

a. I<sub>CCSB</sub> is not fully tested. It is measured only in one state when UART1 or UART2 bit of FCR is 1.

#### 8.2 DC CHARACTERISTICS OF PINS, BY GROUP

The following tables list the DC characteristics of all device pins described in Section 1.2 on page 5. The pin list preceding each table lists the device pins to which the table applies.

#### 8.2.1 Group 1

#### **PIN LIST:**

 $\underline{\text{A15-0}}, \text{ AEN, BADDR1,0}, \overline{\text{CTS2,1}}, \underline{\overline{\text{DACK3-1}}}, \overline{\overline{\text{DCD2,1}}}, \overline{\overline{\text{DSR2,1}}}, \overline{\text{ID2-0}}, \overline{\text{IRRX2,1}}, \overline{\text{MR, PD7-0}}, \overline{\text{RD}}, \overline{\text{RD}}, \overline{\text{RI2,1}}, \overline{\text{SIN2,1}}, \overline{\text{SIRQ31}}, \overline{\text{TC}}, \overline{\overline{\text{WAIT}}}, \overline{\overline{\text{WR}}}$ 

TABLE 8-6. DC Characteristics of Group 1 Pins

| Parameter             | Cymbal           | Conditions                             |      | 5V      |           |      | Unit    |           |                          |
|-----------------------|------------------|----------------------------------------|------|---------|-----------|------|---------|-----------|--------------------------|
| Parameter             | Symbol           | Conditions                             | Min  | Typical | Max       | Min  | Typical | Max       | Unit                     |
| Input high voltage    | V <sub>IH</sub>  |                                        | 2.0  |         | 5.5       | 2.0  |         | 5.5       | ٧                        |
| Input low voltage     | V <sub>IL</sub>  |                                        | -0.5 |         | 0.8       | -0.5 |         | 0.8       | ٧                        |
| Input leakage current | I <sub>LKG</sub> | $V_{IN} = V_{DD}$<br>$V_{IN} = V_{SS}$ |      |         | 10<br>–10 |      |         | 10<br>-10 | μ <b>Α</b><br>μ <b>Α</b> |
| Input hysteresis      | V <sub>H</sub>   | On PNF                                 |      | 250     |           |      | 200     |           | mV                       |
| Input Hysteresis      | V <sub>H</sub>   | On SIRQI3                              |      |         | 250       |      |         | 200       | mV                       |

#### 8.2.2 Group 2

PIN LIST:

BUSY, PE, SLCT

TABLE 8-7. DC Characteristics of Group 2 Pins

| Parameter             | Symbol           | Conditions                             | 5    | 5V          |      | 3.3V        |                          |  |
|-----------------------|------------------|----------------------------------------|------|-------------|------|-------------|--------------------------|--|
| Farameter             | Syllibol         | Conditions                             | Min  | Max         | Min  | Max         | Unit                     |  |
| Input high voltage    | V <sub>IH</sub>  |                                        | 2.0  | 5.5         | 2.0  | 5.5         | ٧                        |  |
| Input low voltage     | V <sub>IL</sub>  |                                        | -0.5 | 0.8         | -0.5 | 0.8         | ٧                        |  |
| Input leakage current | I <sub>LKG</sub> | $V_{IN} = V_{DD}$<br>$V_{IN} = V_{SS}$ |      | 100<br>–200 |      | 100<br>-140 | μ <b>Α</b><br>μ <b>Α</b> |  |

#### 8.2.3 Group 3

PIN LIST:

 $\overline{\mathsf{ACK}}, \overline{\mathsf{ERR}}$ 

TABLE 8-8. DC Characteristics of Group 3 Pins

| Parameter             | Symbol          | Conditions                             | 5    | V 3        |      | 3V         | Unit                     |
|-----------------------|-----------------|----------------------------------------|------|------------|------|------------|--------------------------|
| Parameter             | Symbol          | Conditions                             | Min  | Max        | Min  | Max        | Unit                     |
| Input high voltage    | V <sub>IH</sub> |                                        | 2.0  | 5.5        | 2.0  | 5.5        | ٧                        |
| Input low voltage     | V <sub>IL</sub> |                                        | -0.5 | 0.8        | -0.5 | 0.8        | ٧                        |
| Input leakage current | I <sub>IL</sub> | $V_{IN} = V_{DD}$<br>$V_{IN} = V_{SS}$ |      | 10<br>–200 |      | 10<br>-140 | μ <b>Α</b><br>μ <b>Α</b> |

#### 8.2.4 Group 4

PIN LIST:

 $\overline{\text{DRV2}}, \overline{\text{DSCKCHG}}, \overline{\text{INDEX}}, \overline{\text{MSEN1,0}}, \overline{\text{RDATA}}, \overline{\text{TRK0}}, \overline{\text{WP}}$ 

TABLE 8-9. DC Characteristics of Group 4 Pins

| Parameter             | Cymphal          | Conditions                          |      | 5V      |           |      | 3.3V    |           | l lmit                   |
|-----------------------|------------------|-------------------------------------|------|---------|-----------|------|---------|-----------|--------------------------|
| Parameter             | Symbol           | Conditions                          | Min  | Typical | Max       | Min  | Typical | Max       | Unit                     |
| Input high voltage    | V <sub>IH</sub>  |                                     | 2.0  |         | 5.5       | 2.0  |         | 5.5       | ٧                        |
| Input low voltage     | V <sub>IL</sub>  |                                     | -0.5 |         | 0.8       | -0.5 |         | 0.8       | V                        |
| Input leakage current | I <sub>LKG</sub> | $V_{IN} = V_{DD}$ $V_{IN} = V_{SS}$ |      |         | 10<br>–10 |      |         | 10<br>-10 | μ <b>Α</b><br>μ <b>Α</b> |
| Input hysteresis      | V <sub>H</sub>   | All pins (but DRV2)                 |      | 250     |           |      | 250     |           | mV                       |
| Input Hysteresis      | V <sub>H</sub>   | On DRV2                             |      | 250     |           |      | 200     |           | mV                       |

#### 8.2.5 Group 5

#### PIN LIST:

X1

TABLE 8-10. DC Characteristics of Group 5 Pins

| Parameter                | Symbol            | Conditions                             | Min | Max         | Unit |
|--------------------------|-------------------|----------------------------------------|-----|-------------|------|
| XTAL1 input high voltage | V <sub>IH</sub>   |                                        | 2.0 |             | ٧    |
| XTAL1 input low voltage  | V <sub>IL</sub>   |                                        |     | 0.4         | V    |
| XTAL1 leakage            | I <sub>XLKG</sub> | $V_{IN} = V_{DD}$<br>$V_{IN} = V_{SS}$ |     | 400<br>-400 | μΑ   |

#### 8.2.6 Group 6

#### **PIN LIST:**

D7-0, DRQ3-0, IRQ15, IRQ12-9, IRQ7-3

TABLE 8-11. DC Characteristics of Group 6 Input Pins

| Parameter          | Symbol          | Conditions | 5V 3.3V |     |      | 3V  | Hait |
|--------------------|-----------------|------------|---------|-----|------|-----|------|
|                    | Syllibol        | Conditions | Min     | Max | Min  | Max | Unit |
| Input high voltage | V <sub>IH</sub> |            | 2.0     | 5.5 | 2.0  | 5.5 | ٧    |
| Input low voltage  | V <sub>IL</sub> |            | -0.5    | 0.8 | -0.5 | 0.8 | ٧    |

TABLE 8-12. DC Characteristics of Group 6 Output Pins

| Parameter                       | Cymbol          | Cond                                | litions                             | Min    | Max       | Unit                     |
|---------------------------------|-----------------|-------------------------------------|-------------------------------------|--------|-----------|--------------------------|
| Parameter                       | Symbol          | 5V                                  | 3.3V                                | IVIIII | IVIAX     | Oilit                    |
| Output high voltage             | V <sub>OH</sub> | $I_{OH} = -15 \text{ mA}$           | $I_{OH} = -7.5 \text{ mA}$          | 2.4    |           | ٧                        |
| Output low voltage              | V <sub>OL</sub> | I <sub>OL</sub> = 24 mA             | I <sub>OL</sub> = 12 mA             |        | 0.4       | ٧                        |
| Input TRI-STATE leakage current | I <sub>OZ</sub> | $V_{IN} = V_{DD}$ $V_{IN} = V_{SS}$ | $V_{IN} = V_{DD}$ $V_{IN} = V_{SS}$ |        | 50<br>-50 | μ <b>Α</b><br>μ <b>Α</b> |

#### 8.2.7 Group 7

#### PIN LIST:

BOUT2,1,  $\overline{DTR2,1}$ ,  $\overline{RTS2,1}$ , SOUT2,1

TABLE 8-13. DC Characteristics of Group 7 Pins

| Parameter           | Symbol          | Cond                    | litions                 | Min | Mov   | Unit |
|---------------------|-----------------|-------------------------|-------------------------|-----|-------|------|
| Parameter           | Syllibol        | 5V                      | 3.3V                    |     | Ullit |      |
| Output high voltage | V <sub>OH</sub> | I <sub>OH</sub> = -6 mA | I <sub>OH</sub> = -3 mA | 2.4 |       | ٧    |
| Output low voltage  | V <sub>OL</sub> | I <sub>OL</sub> = 12 mA | I <sub>OL</sub> = 6 mA  |     | 0.4   | ٧    |

# 8.2.8 Group 8

## PIN LIST:

CS1,0, DRATE1,0

TABLE 8-14. DC Characteristics of Group 8 Pins

| Davamatar           | Cymbol          | Conditions              |                          | Min | May | l lmit |
|---------------------|-----------------|-------------------------|--------------------------|-----|-----|--------|
| Parameter           | Symbol          | 5V                      | 3.3V                     | Min | Max | Unit   |
| Output high voltage | V <sub>OH</sub> | I <sub>OH</sub> = -6 mA | $I_{OH} = -3 \text{ mA}$ | 2.4 |     | ٧      |
| Output low voltage  | V <sub>OL</sub> | I <sub>OL</sub> = 6 mA  | I <sub>OL</sub> = 3 mA   |     | 0.4 | ٧      |

## 8.2.9 Group 9

These parameters apply only during reset. After reset, the pins in parentheses apply. See Group 7.

## PIN LIST:

BADDR0 (RTS1), BADDR1 (SOUT1), CFG0 (SOUT2)

TABLE 8-15. DC Characteristics of Group 9 Pins

| Parameter                          | Symbol           | Symbol Conditions                      |      | 5V          |      | 3.3V        |                          |
|------------------------------------|------------------|----------------------------------------|------|-------------|------|-------------|--------------------------|
| Parameter                          | Syllibol         | Conditions                             | Min  | Max         | Min  | Max         | Unit                     |
| Input leakage current during reset | I <sub>LKG</sub> | $V_{IN} = V_{DD}$<br>$V_{IN} = V_{SS}$ |      | 150<br>-160 |      | 150<br>-110 | μ <b>Α</b><br>μ <b>Α</b> |
| Input high voltage                 | V <sub>IH</sub>  |                                        | 2.5  | 5.5         | 2.5  | 5.5         |                          |
| Input low voltage                  | V <sub>IL</sub>  |                                        | -0.5 | 0.8         | -0.5 | 0.8         |                          |

# 8.2.10 Group 10

## PIN LIST:

ADRATE1,0, DENSEL, DIR, DR1,0, DR23, HDSEL, IDLE, MRT1,0, PD, STEP, WDATA, WGATE

TABLE 8-16. DC Characteristics of Group 10 Pins

| Dozomotov                        | Symbol           |                                        | Conditions                          | Min | Max       | l lmit                   |
|----------------------------------|------------------|----------------------------------------|-------------------------------------|-----|-----------|--------------------------|
| Parameter                        | Symbol           | 5V                                     | 3.3V                                | Min | IVIAX     | Unit                     |
| High output voltage <sup>a</sup> | V <sub>OH</sub>  | $I_{OH} = -4 \text{ mA}$               | $I_{OH} = -2 \text{ mA}$            | 2.4 |           | V                        |
| Low output voltage               | V <sub>OL</sub>  | $I_{OL} = 40 \text{ mA}$               | $I_{OL} = 20mA$                     |     | 0.4       | ٧                        |
| High output leakage current a    | I <sub>LKG</sub> | $V_{IN} = V_{DD}$<br>$V_{IN} = V_{SS}$ | $V_{IN} = V_{DD}$ $V_{IN} = V_{SS}$ |     | 10<br>–10 | μ <b>Α</b><br>μ <b>Α</b> |

a. V<sub>OH</sub> for the floppy disk interface pins is valid for CMOS buffered output signals only.

# 8.2.11 Group 11

## PIN LIST:

AFD, ASTRB, DSTRB, INIT, PD7-0, SLIN, STB, WRITE

TABLE 8-17. DC Characteristics of Group 11 Pins

| Downwator                              | Cumbal          | Conditions                 | _   | SV. | 3.  | 3V  | Unit  |
|----------------------------------------|-----------------|----------------------------|-----|-----|-----|-----|-------|
| Parameter                              | Syllibol        | Conditions                 | Min | Max | Min | Max | Offic |
| High level output current <sup>a</sup> | Іон             | V <sub>OH</sub> = 2.4<br>V | -14 |     | -14 |     | mA    |
| Low level output current               | I <sub>OL</sub> | V <sub>OL</sub> = 0.4<br>V | 14  |     | 14  |     | mA    |

a. When the Compatible or Extended modes, or EPP 1.7, or ECP mode 0, or ECP mode 2 and bit 1 of PCR is 0 for the parallel port are selected, pins  $\overline{AFD}$ ,  $\overline{INIT}$ ,  $\overline{SLIN}$ , and  $\overline{STB}$  are open-drain support pins. 4.7 K $\Omega$  resistors should be used.

# 8.2.12 Group 12

## PIN LIST:

IRSL2-0, IRTX

TABLE 8-18. DC Characteristics of Group 12 Pins

| Parameter           | Symbol          | Conditions                | Min | Max  | Unit |
|---------------------|-----------------|---------------------------|-----|------|------|
| Output high voltage | V <sub>OH</sub> | $I_{OH} = -6 \text{ mA}$  | 2.4 |      | V    |
| Output low voltage  | V <sub>OL</sub> | I <sub>OL</sub> = 6 mA    |     | 0.4  | V    |
| Output high current | I <sub>OH</sub> | $V_{OH} = V_{CC} - 0.2 V$ |     | -100 | μΑ   |
| Output low current  | I <sub>OL</sub> | V <sub>OL</sub> = 0.2 V   |     | 100  | μΑ   |

## 8.2.13 Group 13

## PIN LIST:

IOCHRDY, ZWS

**TABLE 8-19. DC Characteristics Group 13 Pins** 

| Parameter                       | Symbol          |                                     | litions                             | Min | Max       | Unit                     |
|---------------------------------|-----------------|-------------------------------------|-------------------------------------|-----|-----------|--------------------------|
| Parameter                       | Syllibol        | 5V                                  | 3.3V                                |     | IVIAX     | Offic                    |
| Output high voltage             | V <sub>OH</sub> | Tri-State                           | Tri-State                           |     |           |                          |
| Output low voltage              | V <sub>OL</sub> | I <sub>OL</sub> = 24 mA             | I <sub>OL</sub> = 12 mA             |     | 0.4       | ٧                        |
| Input TRI-STATE leakage current | l <sub>OZ</sub> | $V_{IN} = V_{DD}$ $V_{IN} = V_{SS}$ | $V_{IN} = V_{DD}$ $V_{IN} = V_{SS}$ |     | 50<br>-50 | μ <b>Α</b><br>μ <b>Α</b> |

## 8.3 AC ELECTRICAL CHARACTERISTICS

# **8.3.1** AC Test Conditions $T_A = 0^{\circ}$ C to $70^{\circ}$ C, $V_{DD} = 5.0$ V $\pm$ 10%, 3.3 V $\pm$ 10%



- C<sub>I</sub> = 100 pF, includes jig and scope capacitance.
- S<sub>1</sub> = Open for push-pull output signals.
   S<sub>1</sub> = V<sub>DD</sub> for high impedance to active low and active low to high impedance measurements.
   S<sub>1</sub> = GND for high impedance to active high and active high to high impedance measurements.
   R<sub>1</sub> = 1.0 K for uP interface pins.
- For the FDC open drive interface pins,  $S_1 = V_{DD}$  and  $R_L = 150$ .
- For 3 V operation, it is recommended to connect all reset strap pins to CMOS input.

FIGURE 8-1. Load Circuit



FIGURE 8-2. A.C. Test Input, Output Waveform

## 8.3.2 Clock Timing

**TABLE 8-20.** Clock Timing Parameters

| Parameter                                 | Symbol                             | Min  | Max  | Unit |
|-------------------------------------------|------------------------------------|------|------|------|
| Clock pulse duty cycle                    | t <sub>CH</sub> or t <sub>CP</sub> | 40   | 60   | %    |
| Clock high pulse width for 24 MHz         | t <sub>CH</sub>                    | 16   |      | nsec |
| Clock low pulse width for 24 MHz          | t <sub>CL</sub>                    | 16   |      | nsec |
| Clock high pulse width for 48 MHz         | t <sub>CH</sub>                    | 8    |      | nsec |
| Clock low pulse width for 48 MHz          | t <sub>CL</sub>                    | 8    |      | nsec |
| Clock tolerance for 14.318 MHz and 24 MHz | t <sub>CP</sub>                    | -100 | +100 | ppm  |
| Clock tolerance for 48 MHz                | t <sub>CP</sub>                    | -200 | +200 | ppm  |
| Internal clock period (See Table 8-21.)   | t <sub>ICP</sub>                   |      |      |      |
| Data rate period (See Table 8-21.)        | t <sub>DRP</sub>                   |      |      |      |

TABLE 8-21. Nominal  $t_{\mbox{\scriptsize ICP}}$  and  $t_{\mbox{\scriptsize DRP}}$  Values

| MFM Data Rate | t <sub>DRP</sub> | t <sub>ICP</sub>    | Value | Unit |
|---------------|------------------|---------------------|-------|------|
| 1 Mbps        | 1000             | 3 x t <sub>CP</sub> | 125   | nsec |
| 500 Kbps      | 2000             | 3 x t <sub>CP</sub> | 125   | nsec |
| 300 Kbps      | 3333             | 5 x t <sub>CP</sub> | 208   | nsec |
| 250 Kbps      | 4000             | 6 x t <sub>CP</sub> | 250   | nsec |



FIGURE 8-3. Clock Timing

# 8.3.3 Microprocessor Interface Timing

**TABLE 8-22.** Microprocessor Interface Timing Parameters

| Parameter                                                         | Symbol           | Min | Max | Unit |
|-------------------------------------------------------------------|------------------|-----|-----|------|
| Valid address to read active                                      | t <sub>AR</sub>  | 18  |     | nsec |
| Valid address to write active                                     | t <sub>AW</sub>  | 18  |     | nsec |
| Data hold                                                         | t <sub>DH</sub>  | 0   |     | nsec |
| Data setup                                                        | t <sub>DS</sub>  | 18  |     | nsec |
| Read to floating data bus                                         | t <sub>HZ</sub>  | 13  | 25  | nsec |
| Port setup                                                        | t <sub>PS</sub>  | 10  |     | nsec |
| Address hold from inactive read                                   | t <sub>RA</sub>  | 0   |     | nsec |
| Read cycle update                                                 | t <sub>RCU</sub> | 45  |     | nsec |
| Read strobe width                                                 | t <sub>RD</sub>  | 60  |     | nsec |
| Read data hold                                                    | t <sub>RDH</sub> | 10  |     | nsec |
| Read strobe to clear IRQ6                                         | t <sub>RI</sub>  |     | 55  | nsec |
| Active read to valid data                                         | t <sub>RVD</sub> |     | 55  | nsec |
| Address hold from inactive write                                  | t <sub>WA</sub>  | 0   |     | nsec |
| Write cycle update                                                | t <sub>WCU</sub> | 45  |     | nsec |
| Write strobe to clear IRQ6                                        | t <sub>WI</sub>  |     | 55  | nsec |
| Write data to port update                                         | t <sub>WO</sub>  |     | 60  | nsec |
| Write strobe width                                                | t <sub>WR</sub>  | 60  |     | nsec |
| Read cycle = t <sub>AR</sub> + t <sub>RD</sub> + t <sub>RCV</sub> | RC               | 123 |     | nsec |
| Write cycle = $t_{AW} + t_{WR} + t_{WCV}$                         | WC               | 123 |     | nsec |
| Delay from SIRQI1,2,3 to IRQx                                     | t <sub>DSI</sub> |     | 25  | nsec |





FIGURE 8-6. System Interrupts

# 8.3.4 Baud Output Timing

**TABLE 8-23.** Baud Output Timing Parameters

| Parameter                       | Symbol             | Conditions                    | Min | Max   | Unit |
|---------------------------------|--------------------|-------------------------------|-----|-------|------|
| Baud divisor                    | n                  |                               | 1   | 65535 | nsec |
| Baud output positive edge delay | t <sub>BHD</sub> a | CLK = 24 MHz / 2, 100 pF Load |     | 56    | nsec |
| Baud output negative edge delay | t <sub>BLD</sub> a | CLK = 24 MHz / 2, 100 pF Load |     | 56    | nsec |

a. Delay values are not 100% tested, and are guaranteed by characterization.



FIGURE 8-7. Baud Output Timing

# 8.3.5 SIR Transmitter Timing

**TABLE 8-24.** SIR Transmitter Timing Parameters

| Parameter                                             | Symbol            | Min    | Max  | Unit        |
|-------------------------------------------------------|-------------------|--------|------|-------------|
| IRTX pulse width                                      | t <sub>IRTX</sub> | 1.6 μs | 3/16 | BOUT cycles |
| Delay from WR (WR THR) to reset IRQ                   | t <sub>HR</sub>   |        | 40   | nsec        |
| Delay from RD (RD IIR) to reset IRQ (THRE)            | t <sub>IR</sub>   |        | 55   | nsec        |
| Delay from initial IRQ reset to start of transmission | t <sub>IRS</sub>  | 8      | 24   | BOUT cycles |
| Delay from initial write to IRQ                       | t <sub>SI</sub>   | 16     | 24   | BOUT cycles |
| Delay from start bit to IRQ (THRE)                    | t <sub>STI</sub>  |        | 8    | BOUT cycles |
| Write strobe to valid IRSL0,1,2                       | t <sub>WRI</sub>  |        | 80   | nsec        |



FIGURE 8-8. SIR Transmitter Timing



FIGURE 8-9. IRSLx Timing

# 8.3.6 Receiver Timing

**TABLE 8-25. SIR Receiver Timing Parameters** 

| Parameter                                                                | Symbol            | Min      | Max              | Unit        |
|--------------------------------------------------------------------------|-------------------|----------|------------------|-------------|
| IRRX pulse width                                                         | t <sub>IRRX</sub> | 0.8 μsec | 6 <sub>/16</sub> | BOUT cycles |
| Delay from active edge of RD to reset IRQ                                | t <sub>RAI</sub>  |          | 78               | nsec        |
| Delay from inactive edge of $\overline{\text{RD}}$ (RD LSR) to reset IRQ | t <sub>RINT</sub> |          | 55               | nsec        |
| Delay from Stop bit to set interrupt                                     | t <sub>SINT</sub> |          | 2                | BOUT cycles |



FIGURE 8-10. SIR Receiver Timing



**Note:** If FCR0 = 1, then  $t_{SINT}$  = 3 x BOUT. For a Time-out interrupt,  $t_{SINT}$  = 8 x BOUT

FIGURE 8-11. FIFO Mode Receiver Timing



**Note:** If FCR0 = 1, then  $t_{SINT}$  = 3 x BOUT. For a Time-out interrupt,  $t_{SINT}$  = 8 x BOUT

FIGURE 8-12. Time-Out Receiver Timing

#### 8.3.7 UART, Sharp-IR and Consumer Remote Control Timing

TABLE 8-26. UART, Sharp-IR and Consumer Remote Control Timing

| Symbol           | Parameter                                                             | Conditions  | Min                                | Max                   | Unit |
|------------------|-----------------------------------------------------------------------|-------------|------------------------------------|-----------------------|------|
| t <sub>BT</sub>  | Single Bit Time in UART and Sharp-IR                                  | Transmitter | t <sub>BTN</sub> – 30 <sup>a</sup> | t <sub>BTN</sub> + 30 | nsec |
|                  |                                                                       | Receiver    | t <sub>BTN</sub> – 2%              | t <sub>BTN</sub> + 2% | nsec |
| t <sub>CMW</sub> | Modulation Signal Pulse Width in Sharp-IR and Consumer Remote Control | Transmitter | t <sub>CWN</sub> – 30 <sup>b</sup> | t <sub>CWN</sub> + 30 | nsec |
|                  | and Consumer Remote Control                                           |             | 500                                |                       | nsec |
| t <sub>CMP</sub> | Modulation Signal Period in Sharp-IR and Consumer Remote Control      | Transmitter | t <sub>CPN</sub> – 30 <sup>c</sup> | t <sub>CPN</sub> + 30 | nsec |
|                  | Consumer Remote Control                                               |             | t <sub>MMIN</sub> d                | t <sub>MMAX</sub> d   | nsec |

- a. t<sub>BTN</sub> is the nominal bit time in UART, Sharp-IR, SIR and Consumer Remote Control modes. It is determined by the setting of the Baud Rate Generator Divisor registers P\_BGDL and P\_BGDH at offsets 00h and 01h, respectively, in bank 5 of logical device 5.
- b. t<sub>CWN</sub> is the nominal pulse width of the modulation signal for Sharp-IR and Consumer Remote Control modes. It is determined by the MCPW field (bits 7-5) of the IRTXMC register at offset 01h and the TXHSC bit (bit 2) in the RCCFG register at offset 02h. Both registers are in bank 7 of logical device 5.
- c. t<sub>CPN</sub> is the nominal period of the modulation signal for Sharp-IR and Consumer Remote Control modes. It is determined by the MCFREQ field (bits 4-0) of the IRTXMC register at offset 01h and the TXHSC bit (bit 2) of the RCCFG register at offset 02h. Both registers are in bank 7 of logical device 5.
- d. t<sub>MMIN</sub> and t<sub>MMAX</sub> define the time range within which the period of the incoming carrier signal has to fall in order for the signal to be accepted by the receiver. These time values are determined by the content of register IRRXDC at offset 00h and the setting of the RXHSC bit (bit 5) in the RCCFG register at offset 02h. Both registers are in bank 7 of logical device 5.



FIGURE 8-13. UART, Sharp-IR and Consumer Remote Control Timing

## 8.3.8 SIR, MIR and FIR Timing

TABLE 8-27. SIR, MIR and FIR Timing

| Symbol            | Parameter                           | Conditions            | Min                                | Max                                | Unit |
|-------------------|-------------------------------------|-----------------------|------------------------------------|------------------------------------|------|
| t <sub>SPW</sub>  | SIR Signal Pulse Width              | Transmitter, Variable | $(^3/_{16})$ x $t_{BTN} - 25$ a    | $(^{3}/_{16}) \times t_{BTN} - 25$ | nsec |
|                   |                                     | Transmitter, Fixed    | 1.60                               | 1.65                               | μsec |
|                   |                                     | Receiver              | 1                                  |                                    | μsec |
| S <sub>DRT</sub>  | SIR Transmitter Data Rate Tolera    | ance                  |                                    | ± 0.87 %                           |      |
| t <sub>SJT</sub>  | SIR Receiver Edge Jitter, % of N    | Iominal Bit Duration  |                                    | ± 6.5 %                            |      |
| t <sub>MPW</sub>  | MIR Signal Pulse Width              | Transmitter           | t <sub>MWN</sub> – 25 <sup>b</sup> | t <sub>MWN</sub> + 25              | nsec |
|                   |                                     | Receiver              | 60                                 |                                    | nsec |
| M <sub>DRT</sub>  | MIR Transmitter Data Rate Toler     | ance                  |                                    | ± 0.1 %                            |      |
| t <sub>MJT</sub>  | MIR Receiver Edge Jitter, % of N    | Iominal Bit Duration  |                                    | ± 2.9 %                            |      |
| t <sub>FPW</sub>  | FIR Signal Pulse Width              | Transmitter           | 120                                | 130                                | nsec |
|                   |                                     | Receiver              | 90                                 | 160                                | nsec |
| t <sub>FDPW</sub> | FIR Signal Double Pulse Width       | Transmitter           | 245                                | 255                                | nsec |
|                   |                                     | Receiver              | 215                                | 285                                | nsec |
| F <sub>DRT</sub>  | FIR Transmitter Data Rate Tolerance |                       |                                    | ± 0.01 %                           |      |
| t <sub>FJT</sub>  | FIR Receiver Edge Jitter, % of N    | Iominal Bit Duration  |                                    | ± 4.0 %                            |      |

- a. t<sub>BTN</sub> is the nominal bit time in UART, Sharp-IR, SIR and Consumer Remote Control modes. It is determined by the settings of the Baud Rate Generator Divisor registers P\_BGDL and P\_BGDH at offsets 00h and 01h, respectively, in bank 5 of logical device 5.
- b. t<sub>MWN</sub> is the nominal pulse width for MIR mode. It is determined by the M\_PWID field (bits 4-0) in the MIR\_PW register at offset 01h in bank 6 of logical device 5.



FIGURE 8-14. SIR, MIR and FIR Timing

# 8.3.9 IRSLn Write Timing

**TABLE 8-28. IRSLn Write Timing** 

| Symbol           | Parameter                              | Conditions | Min | Max | Unit |
|------------------|----------------------------------------|------------|-----|-----|------|
| t <sub>WOD</sub> | IRSLn Output Delay from Write Inactive |            |     | 60  | nsec |



FIGURE 8-15. IRSLn Write Timing

# 8.3.10 Modem Control Timing

**TABLE 8-29. Modem Control Timing Parameters** 

| Parameter                             | Symbol           | Min | Max | Unit |
|---------------------------------------|------------------|-----|-----|------|
| Delay from WR (write MCR) to output   | t <sub>MDO</sub> |     | 40  | nsec |
| Delay to reset IRQ from RD (read MSR) | t <sub>RIM</sub> |     | 78  | nsec |
| Delay to set IRQ from modem input     | t <sub>SIM</sub> |     | 40  | nsec |



FIGURE 8-16. Modem Control Timing

# 8.3.11 DMA Timing

**TABLE 8-30. DMA Timing Parameters** 

| Parameter                                                                                  | Symbol          | Min                  | Max                                             | Unit |
|--------------------------------------------------------------------------------------------|-----------------|----------------------|-------------------------------------------------|------|
| DACK3-0 inactive pulse width                                                               | t <sub>KI</sub> | 25                   |                                                 | nsec |
| DACK3-0 active pulse width                                                                 | t <sub>KK</sub> | 65                   |                                                 | nsec |
| DACK active edge to DRQ inactive <sup>a</sup>                                              | t <sub>KQ</sub> |                      | 65                                              | nsec |
| DRQ to DACK active edge                                                                    | t <sub>QK</sub> | 10                   |                                                 | nsec |
| DRQ period for FDC (FDC-burst DMA)                                                         | t               | 8 x t <sub>DRP</sub> |                                                 |      |
| DRQ period for ECP                                                                         | t <sub>QP</sub> | 330                  |                                                 | nsec |
| DRQ inactive non-burst pulse width                                                         | t <sub>QQ</sub> | 300                  | 400 <sup>b</sup>                                | nsec |
| DRQ to RD, WR active                                                                       | t <sub>QR</sub> | 15                   |                                                 | nsec |
| DRQ of FDC to end of $\overline{RD}$ , $\overline{WR}$ (FDC DRQ service time) <sup>a</sup> | t <sub>QW</sub> |                      | (8 x t <sub>DRP</sub> - 16 x t <sub>ICP</sub> ) |      |
| DRQ of FDC to TC active (FDC DRQ service time) <sup>a</sup>                                | t <sub>QT</sub> |                      | (8 x t <sub>DRP</sub> - 16 x t <sub>ICP</sub> ) |      |
| RD, WR active edge to DRQ inactive <sup>c</sup>                                            | t <sub>RQ</sub> |                      | 65                                              | nsec |
| TC active edge to DRQ inactive                                                             | t <sub>TQ</sub> |                      | 75                                              | nsec |
| TC active pulse width                                                                      | t <sub>TT</sub> | 50                   |                                                 | nsec |

a. For FDC DMA, values shown are with the FIFO disabled, or with the FIFO enabled and THRESH = 0. For non-zero values of THRESH, add (THRESH x 8 x t<sub>DRP</sub>) to the values shown.

- b. Only in case of pending DRQ.
- c. The active edge of  $\overline{RD}$  or  $\overline{WR}$  and TC is recognized only when  $\overline{DACK}$  is active.



FIGURE 8-17. DMA Timing

For ECP DMA, value shown is with the FIFO disabled. When the FIFO is enabled, add  $(192 \times TCP)$  to the value shown (assuming IOCHRDY = 1).

# 8.3.12 Reset Timing

**TABLE 8-31. Reset Timing Parameters** 

| Parameter                                                           | Symbol          | Min | Max | Unit |
|---------------------------------------------------------------------|-----------------|-----|-----|------|
| Reset width (The software reset pulse of the FDC is 100 nsec wide.) | t <sub>RW</sub> | 22  |     | μsec |
| Reset to control inactive                                           | t <sub>RC</sub> |     | 300 | nsec |



(DRQ and IRQ6 will be in TRI-STATE after time  $t_{\mbox{\scriptsize RC}}$  in PC-AT or model 30 mode.)

FIGURE 8-18. Reset Timing

# 8.3.13 Write Data Timing

**TABLE 8-32.** Write Data Timing Parameters

| Parameter                      | Symbol           | Min            | Max | Unit |
|--------------------------------|------------------|----------------|-----|------|
| HDSEL hold from WGATE inactive | t <sub>HDH</sub> | 750            |     | μsec |
| HDSEL setup to WGATE active    | t <sub>HDS</sub> | 100            |     | μsec |
| Write data pulse width         | t <sub>WDW</sub> | See Table 8-33 |     | nsec |

TABLE 8-33. Minimum  $t_{WDW}$  Values

| Data Rate | t <sub>DRP</sub> | t <sub>WDW</sub>     | t <sub>WDW</sub> Value | Unit |
|-----------|------------------|----------------------|------------------------|------|
| 1 Mbps    | 1000             | 2 x t <sub>ICP</sub> | 250                    | nsec |
| 500 Kbps  | 2000             | 2 x t <sub>ICP</sub> | 250                    | nsec |
| 300 Kbps  | 3333             | 2 x t <sub>ICP</sub> | 375                    | nsec |
| 250 Kbps  | 4000             | 2 x t <sub>ICP</sub> | 500                    | nsec |



FIGURE 8-19. Write Data Timing of the Floppy Disk Drive

# 8.3.14 Floppy Disk Drive Control Timing

**TABLE 8-34.** Floppy Disk Drive Control Timing Parameters

| Parameter                                  | Symbol           | Min              | Max | Unit |
|--------------------------------------------|------------------|------------------|-----|------|
| DR3-0, MTR3-0 from end of WR               | t <sub>DRV</sub> |                  | 110 | nsec |
| DIR setup to STEP active                   | t <sub>DST</sub> | 6                |     | μsec |
| Index pulse width                          | t <sub>IW</sub>  | 100              |     | nsec |
| DIR hold from STEP inactive                | t <sub>STD</sub> | t <sub>STR</sub> |     | msec |
| STEP active-high pulse width               | t <sub>STP</sub> | 8                |     | μsec |
| STEP rate time (See Table 3-2 on page 60.) | t <sub>STR</sub> | 1                |     | msec |



FIGURE 8-20. Floppy Disk Drive Control Timing

# 8.3.15 Read Data Timing

**TABLE 8-35.** Read Data Timing Parameters

| Parameter             | Symbol           | Min | Max | Unit |
|-----------------------|------------------|-----|-----|------|
| Read data pulse width | t <sub>RDW</sub> | 50  |     | nsec |



FIGURE 8-21. Read Data Timing of the Floppy Disk Drive

# 8.3.16 Standard Parallel Port Timing

**TABLE 8-36. Standard Parallel Port Timing Parameters** 

| Parameter            | Symbol           | Conditions | Max | Typical | Unit |
|----------------------|------------------|------------|-----|---------|------|
| Port data hold       | t <sub>PDH</sub> | а          |     | 500     | nsec |
| Port data setup      | t <sub>PDS</sub> | а          |     | 500     | nsec |
| Port interrupt Begin | t <sub>PIB</sub> |            | 33  |         | nsec |
| Port interrupt End   | t <sub>PIE</sub> |            | 33  |         | nsec |
| Strobe width         | t <sub>SW</sub>  | а          |     | 500     | nsec |

a. These times are system dependent and are, therefore, not tested.



FIGURE 8-22. Parallel Port Interrupt Timing (Compatible Mode)



**TABLE 8-37.** Compatibility Mode Timing Parameters

| Parameter               | Symbol            | Minimum | Maximum | Unit |
|-------------------------|-------------------|---------|---------|------|
| BUSY low to STB low     | t <sub>BLSL</sub> | 0       |         | ns   |
| Data stable to STB low  | t <sub>DSSL</sub> | 750     |         | ns   |
| STB width               | t <sub>STBW</sub> | 750     | 500,000 | ns   |
| STB high to data change | t <sub>SHDC</sub> | 750     |         | ns   |
| STB low to BUSY high    | t <sub>SLBH</sub> |         | 500     | ns   |
| STB high to nACK low    | t <sub>SHNL</sub> | 0       |         | ns   |
| ACK width               | t <sub>ACKW</sub> | 500     | 10,000  | ns   |
| ACK high to BUSY low    | t <sub>AHBL</sub> | 0       |         | ns   |
| ACK high to STB low     | t <sub>AHSL</sub> | 0       |         | ns   |



FIGURE 8-25. Compatibility Mode Timing Parameters Diagram

# 8.3.17 Enhanced Parallel Port 1.7 Timing

TABLE 8-38. Enhanced Parallel Port 1.7 Timing Parameters

| Parameter                                                                       | Symbol            | Min | Max | Unit |
|---------------------------------------------------------------------------------|-------------------|-----|-----|------|
| WRITE active or inactive from WR active or inactive                             | t <sub>WW</sub>   |     | 45  | nsec |
| DSTRB or ASTRB active or inactive from WR or RD active or inactive <sup>a</sup> | t <sub>WST</sub>  |     | 45  | nsec |
| DSTRB or ASTRB active after WRITE active                                        | t <sub>WEST</sub> | 0   |     | nsec |
| PD7-0 hold after WRITE inactive                                                 | t <sub>WPDh</sub> | 50  |     | nsec |
| IOCHRDY active or inactive after WAIT active or inactive                        | t <sub>HRW</sub>  |     | 40  | nsec |
| PD7-0 valid after WRITE active <sup>b</sup>                                     | t <sub>WPDS</sub> |     | 15  | nsec |
| PD7-0 valid width                                                               | t <sub>EPDW</sub> | 80  |     | nsec |
| PD7-0 hold after DSTRB or ASTRB inactive                                        | t <sub>EPDh</sub> | 0   |     | nsec |
| ZWS valid after WR or RD active                                                 | t <sub>ZWSa</sub> |     | 45  | nsec |
| ZWS hold after WR or RD inactive                                                | t <sub>ZWSh</sub> | 0   |     | nsec |

a. The design of the Chip guarantees that  $\overline{\text{WRITE}}$  will not change from low to high before  $\overline{\text{DSTRB}}$  or  $\overline{\text{ASTRB}}$ , goes from low to high.

b. D7-0 are stable 15 nsec before  $\overline{\text{WR}}$  becomes active.



# 8.3.18 Enhanced Parallel Port 1.9 Timing

TABLE 8-39. Enhanced Parallel Port 1.9 Timing Parameters

| Parameter                                                                                    | Symbol             | Min | Max | Unit |
|----------------------------------------------------------------------------------------------|--------------------|-----|-----|------|
| WRITE active from WR active or WAIT low <sup>a</sup>                                         | t <sub>WWa</sub>   |     | 45  | nsec |
| WRITE inactive from WAIT low                                                                 | t <sub>WWia</sub>  |     | 45  | nsec |
| DSTRB or ASTRB active from WR or RD active or WAIT low ab                                    | t <sub>WSTa</sub>  |     | 65  | nsec |
| DSTRB or ASTRB inactive from WR or RD high                                                   | t <sub>WSTia</sub> |     | 45  | nsec |
| DSTRB or ASTRB active after WRITE active                                                     | t <sub>WEST</sub>  | 10  |     | nsec |
| PD7-0 hold after WRITE inactive                                                              | t <sub>WPDh</sub>  | 0   |     | nsec |
| IOCHRDY active after WR or RD active or inactive after WAIT high                             | t <sub>HRW</sub>   |     | 40  | nsec |
| PD7-0 valid after WRITE active <sup>c</sup>                                                  | t <sub>WPDS</sub>  |     | 15  | nsec |
| PD7-0 valid width                                                                            | t <sub>EPDW</sub>  | 80  |     | nsec |
| PD7-0 hold after DSTRB or ASTRB inactive                                                     | t <sub>EPDh</sub>  | 0   |     | nsec |
| ZWS valid after WR or RD active                                                              | t <sub>ZWSa</sub>  |     | 45  | nsec |
| $\overline{\text{ZWS}}$ hold after $\overline{\text{WR}}$ or $\overline{\text{RD}}$ inactive | t <sub>ZWSh</sub>  | 0   |     | nsec |

a. When  $\overline{\text{WAIT}}$  is low  $t_{\underline{\text{WSTa}}}$  and  $t_{\overline{\text{WWa}}}$  are measured after  $\overline{\text{WR}}$  or  $\overline{\text{RD}}$  becomes active; otherwise  $t_{\overline{\text{WSTa}}}$  and  $t_{\overline{\text{WWa}}}$  are measured after  $\overline{\text{WAIT}}$  becomes low.

b. The Chip design guarantees that WRITE will not change from low to high before DSTRB, or ASTRB, goes from low to high.

c. D7-0 is stable 15 nsec before  $\overline{\text{WR}}$  becomes active.



**Note:** When  $\overline{WAIT}$  is low,  $t_{WSTa}$  and  $t_{WWa}$  are measured after  $\overline{WR}$  or  $\overline{RD}$  becomes active. Otherwise,  $t_{WSTa}$  and  $t_{WWa}$  are measured after  $_{WAIT}$  becomes low.

FIGURE 8-27. Enhanced Parallel Port 1.9 Timing

# 8.3.19 Extended Capabilities Port Timing

**TABLE 8-40.** Extended Capabilities Port Timing Parameters

| Parameter                                           | Symbol            | Min | Max | Unit |
|-----------------------------------------------------|-------------------|-----|-----|------|
| Data and AFD or BUSY setup before STB or ACK active | t <sub>ECDS</sub> | 0   |     | nsec |
| Data and AFD or BUSY hold after BUSY or AFD         | t <sub>ECDH</sub> | 0   |     | nsec |
| BUSY or AFD setup after STB or ACK active           | t <sub>ECLH</sub> | 75  |     | nsec |
| STB or ACK active after BUSY or AFD                 | t <sub>ECHH</sub> | 0   | 1   | sec  |
| BUSY or AFD setup after STB or ACK inactive         | t <sub>ECHL</sub> | 0   | 35  | msec |
| STB or ACK active after BUSY or AFD                 | t <sub>ECLL</sub> | 0   |     | nsec |



FIGURE 8-28. ECP Parallel Port Forward Timing



FIGURE 8-29. ECP Parallel Port Backward Timing

# 8.3.20 Chip Selection Timing

**TABLE 8-41.** Chip Selection Timing Parameters

| Parameter                                         | Symbol          | Min | Max | Unit |
|---------------------------------------------------|-----------------|-----|-----|------|
| Delay from command to enabling of chip selection  | t <sub>CE</sub> | 0   | 25  | nsec |
| Delay from command to disabling of chip selection | t <sub>CD</sub> | 0   | 25  | nsec |



FIGURE 8-30. Chip Select Timing

# Appendix A Comparison of PC87338 and PC97338

| Module        | PC87338                                                                                                                                                                                   | PC97338                                                                                                                                                                                     |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Configuration | Updating a Configuration Register requires two consecutive write accesses to the Data Register, and the CPU interrupts must be disabled during the write cycle.                           | Updating a Configuration Register requires a single write to the Data Register, and the CPU interrupts do not need to be disabled.                                                          |
|               | The MIDI baud rate (pre-scale of 12 instead of 13) is configured by TUP3 as follows:  TUP3: 0 - Pre-scale divides the clock by 13  TUP3: 1 - Pre-scale divides the clock by 12 (for MIDI) | TUP3 is reserved. Programming the UART to MIDI baud rate is accomplished by programming the prescale to 1, and the baud rate divisor to a number that is 12 times its value in the PC87338. |
|               | SuperI/O Chip Configuration Register 2 (SCF2) bits 2 and 4 are reserved.                                                                                                                  | SuperI/O Chip Configuration Register 2 (SCF2) bits 2 and 4 values are: Bit 2: UART1 Normal Power Mode Bit 4: UART1 Bank Select Enable                                                       |
|               | No Manufacturing Test Register.                                                                                                                                                           | Includes a new register, the Manufacturing Test Register (MTEST), Index 52h.                                                                                                                |
| FDC           | No FM mode support.                                                                                                                                                                       | Supports FM mode.                                                                                                                                                                           |
| NPP           | The output of the control signals are at level 2 (push-pull) in: - EPP1.9 mode - ECP mode 011 - ECP mode 010 and PCR[1]=1                                                                 | The output of the control signal are at level 2 (push-pull) in: - EPP mode - All ECP modes except 000                                                                                       |
|               | DCR5 is a read only bit (return 0) in ECP modes 000 and 010. In all other ECP modes, DCR5 is a read/write bit.                                                                            | DCR5 is a read/write bit in all ECP modes.                                                                                                                                                  |
|               | CTR2 is 0 after reset (activate INIT signal to initialize the printer).                                                                                                                   | CTR2 is 1 after reset, so the printer remains in ECP mode if it was programmed to this mode and not initialized to SPP mode.                                                                |
| UART and IR   | The baud rate generator is not initialized on power-up.                                                                                                                                   | MR signal resets the baud rate generator register on power-up.                                                                                                                              |
|               | BOUT1,2 signal is multiplexed with SOUT1,2 signal.                                                                                                                                        | BOUT1,2 signal is multiplexed with DTR1,2 signal.                                                                                                                                           |
|               | In loopback mode, the data is not projected on SOUT1,2 pins.                                                                                                                              | In loopback mode, the data is projected on SOUT1,2 pins.                                                                                                                                    |
|               | No ID pin.                                                                                                                                                                                | IRSL0-2 is multiplexed with ID0-2                                                                                                                                                           |

Winbond Electronics Corp. Advanced PC Product Center

# **Glossary**

#### 11-bit address mode

In this mode, the Chip decodes address lines A0-A10, A11-A15 are masked to 1, and UART2 is a fully featured 16550 UART. The mode is configured during reset, via the CFG0 strap pin.

#### 16-bit address mode

In this mode, the Chip decodes address lines A0-A15 and UART2 is a 16550 UART with SIN2/SOUT2 interface signals only. The mode is configured during reset, via the CFG0 strap pin.

#### **AFIFO**

Address FIFO for the parallel port in Extended Capabilities Port mode.

#### **ASC**

The register that configures the Advanced Super I/O chip, i.e., the PC87338/VLJ or the PC87338VJG.

#### **ASK-IR**

Amplitude Shift Keying Infrared.

## BGD(H) and BGD(L)

Baud rate Generator Divisor buffer (High and Low bytes) for the UARTs.

#### **BSR**

Bank Selection Register for the UARTs.

#### **CCR**

Configuration Control Register of the Floppy Disk Controller (FDC).

#### **CFIFO**

Parallel port data FIFO in Extended Capabilities Port (ECP) mode.

#### **CNFGA and CNFGB**

Configuration registers A and B for the parallel port in Extended Capabilities Port mode.

#### Consumer-IR (TV Remote Control) Mode

This IR mode supports all four protocols currently used in remote-controlled home entertainment equipment. Also called TV-Remote mode.

## CS0HA

The Chip Select 0 High Address register.

#### **CSOLA**

The Chip Select 0 Low Address register.

#### CS1CF

The Chip Select 1 Configuration register.

## CS1HA

The Chip Select 1 High Address register.

#### CS1LA

The Chip Select 1 Low Address register.

#### **CTR**

Control Register of the parallel port.

#### **DASK-IR**

Digital Amplitude Shift Keying Infrared.

#### Data

The Data register contains the data in the register indicated by the corresponding Index register.

#### **DATAR**

Data Register for the parallel port in Extended Capability Port mode.

#### **DCR**

Data Control Register for the parallel port in Extended Capabilities Port mode.

#### **Device**

Any circuit that performs a specific function, such as a parallel port.

#### DIR

Digital Input Register of the Floppy Disk Controller (FDC).

#### DOR

Digital Output Register of the Floppy Disk Controller (FDC).

#### **DSR**

Data rate Select Register of the Floppy Disk Controller (FDC) and the data Status Register in Extended Capabilities Port mode.

#### **DTR**

Data Register of the parallel port.

#### **EAR**

Extended Auxiliary Register of the parallel port in Extended Capabilities Port (ECP) modes.

## **ECP**

Extended Capabilities Port.

#### **ECR**

Extended Control Register for the parallel port in Extended Capabilities Port mode.

#### **EDR**

Extended Data Register for the parallel port in extended Capabilities Port (ECP) modes.

## **EIR**

Two expressions:

Extended Index Register of the parallel port Extended Capabilities Port (ECP) modes.

Event Identification Register for UART1 and UART2 for read cycles.

## **EPP**

Enhanced Parallel Port.

**FAR** 

The Function Address configuration Register.

**FBAH** 

The register that holds the High byte of the Base Address of the Floppy Disc Controller (FDC).

**FBAL** 

The register that holds the Low byte of the Base Address of the Floppy Disk Controller (FDC).

**FCR** 

The Function Control configuration Register or the FIFO Control Register for UARTs.

**FDC** 

Floppy Disk Controller.

**FER** 

The Function Enable configuration Register.

**FIFO** 

Data register (FIFO queue) of the Floppy Disk Controller (FDC)

**IER** 

The Interrupt Enable Register for the UARTs.

Index

The Index register is a pointer that is used to address other registers.

IR

Infrared.

#### IRCFG1, IRCFG3 and IRCFG4

Infrared module Configuration registers for the UART2.

#### IRCR1, IRCR2 and IRCR3

Infrared Module Control Registers 1, 2 and 3 for the UART2.

**IrDA** 

Infrared Data Association.

IrDA mode

In this mode, the Chip provides the Infrared Data Association standard compliant interface.

**IRQ** 

Interrupt Request.

**IRRXDC** 

Infrared Receiver Demodulator Control register for the UART2.

**IRTXMC** 

Infrared Transmitter Modulator Control register for the UART2.

**ISA** 

Industry Standard Architecture.

LBGD(H) and LBGD(L)

Legacy Baud rate Generator Divisor port (High and Low bytes) for the UART2.

**LCR** 

Line Control Register for UARTs.

Legacy

A colloquial description usually referring to older devices or systems that are not Plug and Play compatible.

Legacy mode

In this mode, the interrupts and the base addresses of the FDC, UART1, UART2 and the parallel port of the Chip are configured as in earlier SuperI/O chips. This mode is configured via bit 3 of Plug and Play configuration register 0 (PNP0).

**LFSR** 

The Linear Feedback Shift Register. In Plug and Play mode, this register is used to prepare the chip for operation in Plug and Play (PnP) mode.

**LSR** 

Line Status Register for UARTs.

**MCR** 

Modem Control Register for UARTs.

**MRID** 

Module Revision ID register for the UART2.

**MSR** 

Main Status Register of the Floppy Disk Controller (FDC) or Modem Status Register for UARTs.

Non-Extended UART Operation Modes

These UART operation modes support only UART operations that are standard for 15450 or 16550A devices.

**PBAH** 

The register that holds the High byte of the Base Address of the Parallel port.

**PBAL** 

The register that holds the Low byte of the Base Address of the Parallel port.

**PCR** 

The Parallel port Control configuration Register.

Plug and Play (PnP)

A design philosophy and a set of specifications that describe hardware and software changes to the PC and its peripherals that automatically identify and arbitrate resource requirements among all devices and buses on the system.

**PMC** 

The Power Management Control configuration register.

PnP

Plug and Play.

## PnP mode

In this mode, the interrupts, the DMA channels and the base address of the FDC, UART1, UART2 and the Parallel Port of the Chip are fully plug and play. This mode is configured via bit 3 of Plug and Play configuration register 0 (PNP0).

#### PNP0. PNP1 and PNP2

Plug and Play configuration registers 0 through 2.

#### P MDR

Pipeline Mode Register for UARTs.

#### PIO

Programmable Input/Output.

#### ppm

Parts per million.

#### **PPM**

Parallel Port Multiplexor or Multiplexed.

#### **PPM** mode

In this mode, the Parallel Port pins of the chip serve as FDC pins.

#### **Precompensation**

Also called write precompensation, is a way of preconditioning the WDATA output signal to adjust for the effects of bit shift on the data as it is written to the disk surface.

#### **PTR**

The Power and Test configuration Register.

#### **RSR**

The Receiver Shift Register for UARTs. This register if for internal use only.

#### **SBAH**

The register that holds the High byte of the Base Address, of the Super I/O chip.

#### **SBAL**

The register that holds the Low byte of the Base Address, of the Super I/O chip.

## SCF0, SCF1 and SCF2

The Configuration registers that configure the Super I/O chip.

#### **SCR**

Scratch Register for UARTs.

## SH\_LCR

Shadow of the Line Control Register (LCR) for the UART2 for read operations.

#### **SHARP-IR**

SHARP Infrared.

## **SHARP-IR mode**

In this mode, the Chip provides SHARP Infrared interface. This mode is configured via the IRC register.

#### SID

Super I/O ID, the configuration register that holds the identity of the Super I/O chip.

#### SIO

Super I/O, sometimes used to refer to a chip that has Super I/O capabilities.

#### SIR

Serial Infrared.

#### SIR PW

SIR Pulse Width control for the UART2.

## SIRQ1, SIRQ2 and SIRQ3

These configuration registers describe the SIRQI1, SIRQI2 and SIRQI3 functions, which determine how Interrupt Requests are handled.

#### SPP

The Standard Parallel Port configuration of the Parallel Port device supports the Compatible SPP mode and the Extended PP mode.

#### **SRA and SRB**

Status Registers A and B of the Floppy Disk Controller (FDC).

#### ST0, ST1, ST2 and ST3

Status registers 0, 1, 2 and 3 of the Floppy Disk Controller (FDC).

#### **STR**

Status Register of the parallel port.

#### **TDR**

Tape Drive Register of the Floppy Disk Controller (FDC).

#### **TFIFO**

Test FIFO for the parallel port in Extended Capabilities Port mode.

## **TXDR**

The Transmitter Data Register for UARTs.

## **TUP**

The Tape drive, UART, Parallel port configuration register.

#### U1BAH

The configuration register that holds the High byte of the Base Address of UART 1.

#### **U1BAL**

The configuration register that holds the Low byte of the Base Address of UART 1.

#### U2BAH

The configuration register that holds the High byte of the Base Address of UART 2.

#### U2BAL

The configuration register that holds the Low byte of the Base Address of UART 2.

#### **UART**

Universal Asynchronous Receiver Transmitter.

Winbond Electronics Corp. Advanced PC Product Center



# **Physical Dimensions** millimeters



Thin Quad Flatpack (TQFP), JEDEC) Order Number PC87338/PC97338(VJG) NS Package Number VJG100A

#### LIFE SUPPORT POLICY

NATIONAL'S PRODUCTS ARE NOT AUTHORIZED FOR USE AS CRITICAL COMPONENTS IN LIFE SUPPORT DEVICES OR SYSTEMS WITHOUT THE EXPRESS WRITTEN APPROVAL OF THE PRESIDENT OF NATIONAL SEMICONDUCTOR CORPORATION. As used herein:

- Life support devices or systems are devices or systems which, (a) are intended for surgical implant into the body, or (b) support or sustain life, and whose failure to perform, when properly used in accordance with instructions for use provided in the labeling, can be reasonably expected to result in a significant injury to the user.
- A critical component is any component of a life support device or system whose failure to perform can be reasonably expected to cause the failure of the life support device or system, or to affect its safety or effectiveness.



National Semiconductor Corporation 2900 Semiconductor Dr. P.O. Box 58090 Santa Clara, CA 95052-8090 Tel: +1 (800) 272-9959 TWX: (910) 339-9240

National Semiconductor GmbH Livry-Gargan-Str. 10 D-82256 Furstenfeldbruck

Furstenfeldbruck, Germany Tel: (81 41) 35-0 Telex: 527649 Fax: (81 41) 35-1 National Semiconductor Japan Ltd. URD-KIBA Building 2-17-16, Kiba, Koutou-Ku Tokyo 135, Japan Tel: +81 3 5620-6170 Fax: +81 3 5620-6179

National Semiconductor Hong Kong Ltd. 13 Floor, Straight Block Ocean Centre, 5 Canton Rd. Tsimshatsui, Kowloon Hong Kong Tel: (852) 2737-1601 Telex: 51292 NSHKL Fax: (852) 2736-9960 National Semiconductores Do Brazil Ltda. Rue Deputado Lacorda Franco 120-3A Sao Paulo-SP Brazil 05418-000 Tel: (55-11) 212-5066 Telex: 391-1131931 NSBR BR Fax: (55-11) 212-1181

(Australia) Pty, Ltd. 16 Business Park Dr. Notting Hill, VIC 3168 Australia Tel: (3) 558-9999 Fax: (3) 558-9998

National Semiconductor