DISTINCTIVE CHARACTERISTICS

- Completely integrated system for cost-sensitive embedded applications requiring high performance.
- Full 32-bit RISC architecture offers faster instruction execution and higher performance.
  - 32-bit instruction/data bus
  - 22-bit address bus
  - 192 general-purpose registers
  - Fully pipelined, three-address instruction architecture
  - 104-Mbyte address space
  - 12-, 16-, and 20-MHz operating frequencies
  - 16 VAX MIPS sustained at 20 MHz
- Glueless system interfaces with on-chip wait state control lower total system cost.
  - ROM controller supports four banks of ROM, each separately programmable for 8-, 16-, or 32-bit-wide interface.
  - DRAM controller supports four banks of DRAM, each separately programmable for 16- or 32-bit-wide interface.
  - 2-port peripheral interface adapter (PIA)
- Two-channel DMA controller (one external) with queued reload for internal peripherals
- On-chip timer and interrupt controller

IEEE Std 1284-1994-compliant parallel port interface (peripheral-side only) supports fast bidirectional data transfers.
- Compatibility, Nibble, Byte, and ECP modes
- Supports Microsoft® Windows® Printing System
- Bidirectional bit serializer/deserializer for direct connection to raster input and output devices
- 12-line programmable I/O port (8 lines interruptible)
- DRAM page-mode support improves memory access time.
- On-chip DRAM mapping reduces memory requirements.
- Advanced debugging support
  - IEEE Std 1149.1-1990-compliant Standard Test Access Port and Boundary Scan Architecture (JTAG) for testing system hardware
  - Instruction tracing
  - UART serial port
- Software and hardware development tools widely available from AMD® and Fusion29K® partners
- Binary compatibility with all 29K Family of RISC microcontrollers and microprocessors
- 132-pin Plastic Quad Flat Pack (PQFP) package

GENERAL DESCRIPTION

The Am29202™ RISC microcontroller is a highly integrated, 32-bit embedded processor implemented in complementary metal-oxide semiconductor (CMOS) technology. Based on the 29K architecture, the Am29202 microcontroller is part of a growing family of RISC microcontrollers, which includes the Am29200™ and Am29205™ microcontrollers, along with the high-performance Am29240™, Am29245™, and Am29243™ RISC microcontrollers. A feature summary of the Am29200 RISC microcontroller family is included in Table 1.

With its 32-bit instruction and data bus, the Am29202 microcontroller is functionally very similar to an Am29200 microcontroller, operating with a reduced pin count and fewer peripherals. The low-cost Am29202 microcontroller is well-suited for cost-sensitive embedded applications requiring the enhanced performance of a 32-bit instruction/data bus and an IEEE-1284-compliant parallel port interface. The Am29202 microcontroller incorporates a complete set of system facilities commonly found in printing, imaging, graphics, and other embedded applications.

The Am29202 microcontroller meets the common requirements of embedded applications such as laser printers, imaging applications, graphics processing, industrial control, and general purpose applications requiring high performance in a compact design. Specific applications include products based on Microsoft’s Windows Printing System, such as personal and工作组 600-DPI laser printers and midrange inkjet printers, as well as scanners and multifunction peripherals, among others.
CUSTOMER SERVICE

AMD’s customer service network includes U.S. offices, international offices, and a customer training center. Expert technical assistance is available from AMD’s worldwide staff of field application engineers and factory support staff.

Hotline, E-mail, and Bulletin Board Support

For answers to technical questions, AMD provides a toll-free number for direct access to our engineering support staff. For overseas customers, the easiest way to reach the engineering support staff with your questions is via fax with a short description of your question. AMD 29K Family customers also receive technical support through electronic mail. This worldwide service is available to 29K Family product users via the international Internet e-mail service. Also available is the AMD bulletin board service, which provides the latest 29K Family product information, including technical information and data on upcoming product releases.

Engineering Support Staff

<table>
<thead>
<tr>
<th>Phone Number</th>
<th>Location</th>
<th>Access</th>
</tr>
</thead>
<tbody>
<tr>
<td>(800) 292-9263, ext. 2</td>
<td>toll-free for U.S.</td>
<td></td>
</tr>
<tr>
<td>0031-11-1163</td>
<td>toll-free for Japan</td>
<td></td>
</tr>
<tr>
<td>(512) 602-4118</td>
<td>direct dial worldwide</td>
<td></td>
</tr>
</tbody>
</table>

44-(0)256-811101 | U.K. and Europe hotline
(512) 602-5031 | fax
epd.support@amd.com | e-mail

Bulletin Board

(800) 292-9263, ext. 1 | toll-free for U.S.
(512) 602-7604 | direct dial worldwide

Documentation and Literature

A simple phone call gets you free 29K Family information, such as data books, user’s manuals, data sheets, application notes, the Fusion29K Partner Solutions Catalog and Newsletter, and other literature. Internationally, contact your local AMD sales office for complete 29K Family literature.

Literature Request

(800) 292-9263, ext. 3 | toll-free for U.S.
(512) 602-5651 | direct dial worldwide
(512) 602-7639 | fax for U.S.
(800) 222-9323, option 1 | AMD Facts-On-Demand™ fax information service
toll-free for U.S.
ORDERING INFORMATION

Standard Products

AMD standard products are available in several packages and operating ranges. Valid order numbers are formed by a combination of the elements below.

**Valid Combinations**

<table>
<thead>
<tr>
<th>Valid Combinations</th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>AM29202–12</td>
<td></td>
</tr>
<tr>
<td>AM29202–16</td>
<td>KC\W</td>
</tr>
<tr>
<td>AM29202–20</td>
<td></td>
</tr>
</tbody>
</table>

**SHIPPING OPTION**

\W = Trimmed and Formed

**TEMPERATURE RANGE**

\C = Commercial (\T_C = 0°C to +85°C)

**PACKAGE TYPE**

\K = 132-Lead Plastic Quad Flat Pack (PQB132)

**SPEED OPTION**

–12 = 12.5 MHz
–16 = 16.67 MHz
–20 = 20 MHz

**DEVICE NUMBER/DESCRIPTION**

Am29202 RISC Microcontroller

Valid Combinations list configurations planned to be supported in volume. Consult the local AMD sales office to confirm availability of specific valid combinations, and check on newly released combinations.
## Table 1. Product Comparison—Am29200 Microcontroller Family

<table>
<thead>
<tr>
<th>FEATURE</th>
<th>Am29205 Controller</th>
<th>Am29202 Controller</th>
<th>Am29200 Controller</th>
<th>Am29245 Controller</th>
<th>Am29240 Controller</th>
<th>Am29243 Controller</th>
</tr>
</thead>
<tbody>
<tr>
<td>Instruction Cache</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>2 Kbytes</td>
<td>2 Kbytes</td>
</tr>
<tr>
<td>Data Cache</td>
<td>—</td>
<td>—</td>
<td>4 Kbytes</td>
<td>4 Kbytes</td>
<td>4 Kbytes</td>
<td>4 Kbytes</td>
</tr>
<tr>
<td>Cache Associativity</td>
<td>—</td>
<td>Software</td>
<td>2-way</td>
<td>2-way</td>
<td>2-way</td>
<td>2-way</td>
</tr>
<tr>
<td>Integer Multiplier</td>
<td>Software</td>
<td>Software</td>
<td>Software</td>
<td>Software</td>
<td>32 x 32-bit</td>
<td>32 x 32-bit</td>
</tr>
<tr>
<td>Memory Management Unit (MMU)</td>
<td>—</td>
<td>—</td>
<td>1 TLB</td>
<td>1 TLB</td>
<td>2 TLBs</td>
<td>2 TLBs</td>
</tr>
<tr>
<td>Data Bus Width</td>
<td>32 bits</td>
<td>32 bits</td>
<td>32 bits</td>
<td>32 bits</td>
<td>32 bits</td>
<td>32 bits</td>
</tr>
<tr>
<td>ROM Interface</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
</tr>
<tr>
<td>ROM Size (Max/Bank)</td>
<td>8, 16 bits</td>
<td>8, 16, 32 bits</td>
<td>8, 16, 32 bits</td>
<td>8, 16, 32 bits</td>
<td>8, 16, 32 bits</td>
<td>8, 16, 32 bits</td>
</tr>
<tr>
<td>Boot-Up ROM Width</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
</tr>
<tr>
<td>Burst-Mode Access</td>
<td>Not Supported</td>
<td>Not Supported</td>
<td>Supported</td>
<td>Supported</td>
<td>Supported</td>
<td>Supported</td>
</tr>
<tr>
<td>Integer Multiplier</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>32 x 32-bit</td>
<td>32 x 32-bit</td>
<td>32 x 32-bit</td>
</tr>
<tr>
<td>Instruction Cache</td>
<td>—</td>
<td>4 Kbytes</td>
<td>4 Kbytes</td>
<td>4 Kbytes</td>
<td>4 Kbytes</td>
<td>4 Kbytes</td>
</tr>
<tr>
<td>Data Cache</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>2 Kbytes</td>
<td>2 Kbytes</td>
</tr>
<tr>
<td>Cache Associativity</td>
<td>—</td>
<td>2-way</td>
<td>2-way</td>
<td>2-way</td>
<td>2-way</td>
<td>2-way</td>
</tr>
<tr>
<td>Integer Multiplier</td>
<td>Software</td>
<td>Software</td>
<td>Software</td>
<td>Software</td>
<td>32 x 32-bit</td>
<td>32 x 32-bit</td>
</tr>
<tr>
<td>Memory Management Unit (MMU)</td>
<td>—</td>
<td>1 TLB</td>
<td>1 TLB</td>
<td>2 TLBs</td>
<td>2 TLBs</td>
<td>2 TLBs</td>
</tr>
<tr>
<td>Data Bus Width</td>
<td>32 bits</td>
<td>32 bits</td>
<td>32 bits</td>
<td>32 bits</td>
<td>32 bits</td>
<td>32 bits</td>
</tr>
<tr>
<td>ROM Interface</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
</tr>
<tr>
<td>ROM Size (Max/Bank)</td>
<td>8, 16 bits</td>
<td>8, 16, 32 bits</td>
<td>8, 16, 32 bits</td>
<td>8, 16, 32 bits</td>
<td>8, 16, 32 bits</td>
<td>8, 16, 32 bits</td>
</tr>
<tr>
<td>Boot-Up ROM Width</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
</tr>
<tr>
<td>Burst-Mode Access</td>
<td>Not Supported</td>
<td>Not Supported</td>
<td>Supported</td>
<td>Supported</td>
<td>Supported</td>
<td>Supported</td>
</tr>
<tr>
<td>Integer Multiplier</td>
<td>—</td>
<td>32 x 32-bit</td>
<td>32 x 32-bit</td>
<td>32 x 32-bit</td>
<td>32 x 32-bit</td>
<td>32 x 32-bit</td>
</tr>
<tr>
<td>Instruction Cache</td>
<td>—</td>
<td>4 Kbytes</td>
<td>4 Kbytes</td>
<td>4 Kbytes</td>
<td>4 Kbytes</td>
<td>4 Kbytes</td>
</tr>
<tr>
<td>Data Cache</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>2 Kbytes</td>
<td>2 Kbytes</td>
</tr>
<tr>
<td>Cache Associativity</td>
<td>—</td>
<td>2-way</td>
<td>2-way</td>
<td>2-way</td>
<td>2-way</td>
<td>2-way</td>
</tr>
<tr>
<td>Integer Multiplier</td>
<td>Software</td>
<td>Software</td>
<td>Software</td>
<td>Software</td>
<td>32 x 32-bit</td>
<td>32 x 32-bit</td>
</tr>
<tr>
<td>Memory Management Unit (MMU)</td>
<td>—</td>
<td>1 TLB</td>
<td>1 TLB</td>
<td>2 TLBs</td>
<td>2 TLBs</td>
<td>2 TLBs</td>
</tr>
<tr>
<td>Data Bus Width</td>
<td>32 bits</td>
<td>32 bits</td>
<td>32 bits</td>
<td>32 bits</td>
<td>32 bits</td>
<td>32 bits</td>
</tr>
<tr>
<td>ROM Interface</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
</tr>
<tr>
<td>ROM Size (Max/Bank)</td>
<td>8, 16 bits</td>
<td>8, 16, 32 bits</td>
<td>8, 16, 32 bits</td>
<td>8, 16, 32 bits</td>
<td>8, 16, 32 bits</td>
<td>8, 16, 32 bits</td>
</tr>
<tr>
<td>Boot-Up ROM Width</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
</tr>
<tr>
<td>Burst-Mode Access</td>
<td>Not Supported</td>
<td>Not Supported</td>
<td>Supported</td>
<td>Supported</td>
<td>Supported</td>
<td>Supported</td>
</tr>
<tr>
<td>Integer Multiplier</td>
<td>—</td>
<td>32 x 32-bit</td>
<td>32 x 32-bit</td>
<td>32 x 32-bit</td>
<td>32 x 32-bit</td>
<td>32 x 32-bit</td>
</tr>
<tr>
<td>Instruction Cache</td>
<td>—</td>
<td>4 Kbytes</td>
<td>4 Kbytes</td>
<td>4 Kbytes</td>
<td>4 Kbytes</td>
<td>4 Kbytes</td>
</tr>
<tr>
<td>Data Cache</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>—</td>
<td>2 Kbytes</td>
<td>2 Kbytes</td>
</tr>
<tr>
<td>Cache Associativity</td>
<td>—</td>
<td>2-way</td>
<td>2-way</td>
<td>2-way</td>
<td>2-way</td>
<td>2-way</td>
</tr>
<tr>
<td>Integer Multiplier</td>
<td>Software</td>
<td>Software</td>
<td>Software</td>
<td>Software</td>
<td>32 x 32-bit</td>
<td>32 x 32-bit</td>
</tr>
<tr>
<td>Memory Management Unit (MMU)</td>
<td>—</td>
<td>1 TLB</td>
<td>1 TLB</td>
<td>2 TLBs</td>
<td>2 TLBs</td>
<td>2 TLBs</td>
</tr>
<tr>
<td>Data Bus Width</td>
<td>32 bits</td>
<td>32 bits</td>
<td>32 bits</td>
<td>32 bits</td>
<td>32 bits</td>
<td>32 bits</td>
</tr>
<tr>
<td>ROM Interface</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
</tr>
<tr>
<td>ROM Size (Max/Bank)</td>
<td>8, 16 bits</td>
<td>8, 16, 32 bits</td>
<td>8, 16, 32 bits</td>
<td>8, 16, 32 bits</td>
<td>8, 16, 32 bits</td>
<td>8, 16, 32 bits</td>
</tr>
<tr>
<td>Boot-Up ROM Width</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
<td>16 bits</td>
</tr>
<tr>
<td>Burst-Mode Access</td>
<td>Not Supported</td>
<td>Not Supported</td>
<td>Supported</td>
<td>Supported</td>
<td>Supported</td>
<td>Supported</td>
</tr>
<tr>
<td>Integer Multiplier</td>
<td>—</td>
<td>32 x 32-bit</td>
<td>32 x 32-bit</td>
<td>32 x 32-bit</td>
<td>32 x 32-bit</td>
<td>32 x 32-bit</td>
</tr>
</tbody>
</table>
### RELATED AMD PRODUCTS

#### 29K Family Devices

<table>
<thead>
<tr>
<th>Part No.</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Am29000®</td>
<td>32-bit RISC microprocessor</td>
</tr>
<tr>
<td>Am29005™</td>
<td>Low-cost 32-bit RISC microprocessor with no MMU and no branch target cache</td>
</tr>
<tr>
<td>Am29030™</td>
<td>32-bit RISC microprocessor with 8-Kbyte instruction cache</td>
</tr>
<tr>
<td>Am29035™</td>
<td>32-bit RISC microprocessor with 4-Kbyte instruction cache</td>
</tr>
<tr>
<td>Am29040™</td>
<td>32-bit RISC microprocessor with 8-Kbyte instruction cache and 4-Kbyte data cache</td>
</tr>
<tr>
<td>Am29050™</td>
<td>32-bit RISC microprocessor with on-chip floating point unit</td>
</tr>
<tr>
<td>Am29200™</td>
<td>32-bit RISC microcontroller</td>
</tr>
<tr>
<td>Am29205™</td>
<td>Low-cost 32-bit RISC microcontroller</td>
</tr>
<tr>
<td>Am29240™</td>
<td>32-bit RISC microcontroller with 4-Kbyte instruction cache and 2-Kbyte data cache</td>
</tr>
<tr>
<td>Am29243™</td>
<td>32-bit data RISC microcontroller with instruction and data caches and DRAM parity</td>
</tr>
<tr>
<td>Am29245™</td>
<td>Low-cost 32-bit RISC microcontroller with 4-Kbyte instruction cache</td>
</tr>
</tbody>
</table>

#### 29K FAMILY DEVELOPMENT SUPPORT PRODUCTS

Contact your local AMD representative for information on the complete set of development support tools. The following software and hardware development products are available on several hosts:

- Optimizing compilers for common high-level languages
- Assembler and utility packages
- Source- and assembly-level software debuggers
- Target-resident development monitors
- Simulators
- Execution boards

#### THIRD-PARTY DEVELOPMENT SUPPORT PRODUCTS

The Fusion29K Program of Partnerships for Application Solutions provides the user with a vast array of products designed to meet critical time-to-market needs. Products and solutions available from the AMD Fusion29K Partners include:

- Silicon products
- Software generation and debug tools
- Hardware development tools
- Board level products
- Laser printer solutions
- Networking and communication solutions
- Multiuser, kernel, and real-time operating systems
- Graphics solutions
- Manufacturing support
- Custom software consulting, support, and training
TABLE OF CONTENTS

**DISTINCTIVE CHARACTERISTICS**
- GENERAL DESCRIPTION .......................................................... 1
  - Am29202 MICROCONTROLER BLOCK DIAGRAM ............................... 2

**CUSTOMER SERVICE** ................................................................ 2

**ORDERING INFORMATION** ....................................................... 3
- Am29200 MICROCONTROLER FAMILY COMPARISON .......................... 4
- RELATED AMD PRODUCTS ......................................................... 5
- 29K FAMILY DEVELOPMENT SUPPORT PRODUCTS .......................... 5
- THIRD-PARTY DEVELOPMENT SUPPORT PRODUCTS ........................ 5

**KEY FEATURES AND BENEFITS** ............................................... 10
- IEEE-1284-COMPLIANT ADVANCED PARALLEL INTERFACE ............ 10
- WINDOWS PRINTING SYSTEM COMPATIBILITY ............................... 10
- COMPLETE SET OF COMMON SYSTEM PERIPHERALS ...................... 10
- PERFORMANCE OVERVIEW ....................................................... 11
- DEBUGGING AND TESTING ....................................................... 12
- COMPLETE DEVELOPMENT AND SUPPORT ENVIRONMENT ............... 12

**PIN INFORMATION** ................................................................ 17
- CONNECTION DIAGRAM .......................................................... 13
- PQFP PIN DESIGNATIONS (Sorted by Pin Number) .......................... 14
- PQFP PIN DESIGNATIONS (Sorted by Pin Name) ............................ 15
- LOGIC SYMBOL ..................................................................... 16
- PIN DESCRIPTIONS .................................................................. 17

**FUNCTIONAL DIFFERENCES** .................................................... 20
- Advanced Parallel Interface ....................................................... 20
- Memory Map Changes ............................................................. 20
- Pin Changes for the Am29202 Microcontroller .............................. 20
- ROM CONTROLLER ................................................................. 22
  - ROM Control Register (RMCT, Address 80000000) ...................... 22
- DRAM CONTROLLER ............................................................... 23
  - DRAM Control Register (DRCT, Address 80000008) .................... 23
  - Refresh Control Changes ....................................................... 24
- PERIPHERAL INTERFACE ADAPTER (PIA) .................................. 25
  - PIA Control Register 0/1 (PICT0/1, Address 80000020/24) ............ 25
- DMA CONTROLLER ................................................................. 26
  - DMA0 Control Register (DMCT0, Address 80000030) .................. 26
  - DMA0 Address Register (DMAD0, Address 80000034) ................. 27
  - DMA1 Control Register (DMCT1, Address 80000040) .................. 27
- PROGRAMMABLE I/O PORT ....................................................... 29
  - PIO Control Register (POCT, Address 800000D0) ....................... 29
  - PIO Input Register (PIN, Address 800000D4) ............................. 30
  - PIO Output Register (POUT, Address 800000D8) ....................... 30
  - PIO Output Enable Register (POEN, Address 800000DC) .............. 30
IEEE-1284-COMPLIANT ADVANCED PARALLEL INTERFACE

INTERRUPTS AND TRAPS

EXTERNAL SIGNALS

OVERVIEW

REGISTERS

INITIALIZATION

CONTROLLING THE PARALLEL PORT INTERFACE

USING SOFTWARE IN IEEE-1284 MODES
LIST OF FIGURES
Figure 1. ROM Control Register ................................................................. 22
Figure 2. DRAM Control Register ............................................................... 23
Figure 3. PIA Control Register 0 ................................................................. 25
Figure 4. DMA0 Control Register ............................................................... 26
Figure 5. DMA0 Address Register ............................................................. 27
Figure 6. DMA1 Control Register ............................................................... 28
Figure 7. PIO Control Register ................................................................. 29
Figure 8. PIO Input Register ..................................................................... 30
Figure 9. PIO Output Register ................................................................... 30
Figure 10. PIO Output Enable Register ...................................................... 30
Figure 11. Serial Port Control Register ....................................................... 32
Figure 12. Serial Port Status Register ......................................................... 32
Figure 13. Current Processor Status Register ............................................. 33
Figure 14. Interrupt Control Register ......................................................... 34
Figure 15. Maximum External System Design ............................................. 41
Figure 16. Minimal System Design ............................................................. 42
Figure 17. Advanced Parallel Control Register ........................................... 47
Figure 18. Advanced Parallel Status Register ............................................. 50
Figure 19. Advanced Parallel Interrupt Mask Register ............................... 52
Figure 20. Advanced Parallel Interrupt Status Register .............................. 53
Figure 21. Advanced Parallel Data Register ................................................ 54
Figure 22. Example: Using A Control Status Condition to Generate an Interrupt in Compatibility Mode ............................................................ 56
Figure 23. Example: Using the Data Status Condition in Compatibility Mode ................................................................. 57
Figure 24. Advanced Parallel Port Buffer Read Cycle for Forward Transfers .............................................................................. 58
Figure 25. Advanced Parallel Port Buffer Write Cycle for Reverse Transfers .................................................................................. 58

LIST OF TABLES
Table 1. Product Comparison—Am29200 Microcontroller Family .................. 4
Table 2. Internal Peripheral Address Ranges ................................................ 16
Table 3. Internal Peripheral Address Assignments ........................................ 17
Table 4. Vector Number Assignments .......................................................... 32
Table 5. Interrupt and Trap Priority Table ..................................................... 34
Table 6. Main Data Scan Path ...................................................................... 35
Table 7. Feature Comparison of Supported IEEE-1284 Communication Modes ............................................................................. 39
Table 8. IEEE-1284 Parallel Interface Signal Names by Mode ....................... 41
Table 9. Parallel Port Register Summary ...................................................... 42
Table 10. APMODE Values ......................................................................... 45
Table 11. Using Control Status Conditions in IEEE-1284 Modes ................... 58
Table 12. PQFP Thermal Characteristics ....................................................... 71
KEY FEATURES AND BENEFITS

The Am29202 microcontroller offers the performance of the Am29200 microcontroller with the slightly reduced feature set required for a smaller package. As an upgrade to the Am29205 microcontroller, the low-cost Am29202 microcontroller offers the enhanced performance of a 32-bit instruction/data bus and an IEEE-1284-compliant parallel interface.

IEEE-1284-Compliant Advanced Parallel Interface

The Am29202 microcontroller includes a new parallel port interface, called the Advanced Parallel Interface (API), that is compliant with IEEE Std 1284-1994. The IEEE-1284 standard specifies the operation of an extendible, bidirectional, multimode parallel interface that provides access to a variety of peripheral devices, such as printers, scanners, multifunction peripherals, storage devices, network interfaces, and others. This standard bidirectional protocol enables the development of new peripherals that can return significant data, as well as basic status, to the host.

AMD’s implementation of this protocol on the Am29202 microcontroller supports a number of communications modes, allowing access to both high-speed and low-overhead communications. The supported modes include: Compatibility (standard Centronics) mode, Nibble (reverse) mode, Byte (reverse) mode, and ECP (bidirectional) mode.

The standard IEEE-1284 communications modes are supported using a mixture of hardware and software controls. Automatic hardware handshakes and hardware DMA support are provided in all modes except Nibble. Full software control provides easy access to input status information with a variety of software strategies, including polling, interrupt service, and DMA. The API supports peripheral-side designs only.

Windows Printing System Compatibility

Because of its high performance, full feature set, glueless interfaces, and low total system cost, the Am29202 microcontroller was chosen by Microsoft to be the reference hardware design for its Windows Printing System. The Windows Printing System provides substantial performance improvements for a new class of printers that are optimized for the Windows operating system.

These new printers utilize features of the IEEE-1284 parallel interface to provide a fast, bidirectional communication channel that improves the transfer of data between host and peripheral and also allows the printer to communicate status information back to the host PC. While not limited in functionality to a specific application, the Am29202 microcontroller has the performance and feature set ideally suited to meet the needs of these low-to mid-range laser printers.

Complete Set of Common System Peripherals

The Am29202 microcontroller minimizes system cost by incorporating a complete set of system facilities commonly found in embedded applications, eliminating the cost of additional components. The on-chip functions include: a ROM controller, a DRAM controller, a peripheral interface adapter, a DMA controller, a bidirectional serializer/deserializer, a programmable I/O port, an IEEE-1284-compliant parallel port interface, a serial port, an interrupt controller, and an IEEE-1149.1-compliant JTAG debug port.

The Am29202 microcontroller provides a glueless attachment to external ROMs, DRAMs, and other peripheral components. Processor outputs have edge-rate control that allows them to drive a wide range of load capacitances with low noise and ringing. This eliminates the cost of external logic and buffering.

The Am29202 microcontroller lets product designers capitalize on the very low system cost made possible by the integration of processor and peripherals. Many simple systems can be built using only the Am29202 microcontroller and external ROM and/or DRAM memory.

ROM Controller

The ROM controller supports four individual banks of ROM or other static memory. Each ROM bank has its own timing characteristics, and each bank may be of a different size: either 8, 16, or 32 bits wide. The ROM banks can appear as a contiguous memory area of up to 16 Mbytes in size. The ROM controller also supports writes to the ROM memory space for devices such as Flash EPROMs and SRAMs.

DRAM Controller

The DRAM controller supports four separate banks of dynamic memory, each of which can be a different size: either 16 or 32 bits wide. The DRAM banks can appear as a contiguous memory area of up to 64 Mbytes in size. To support system functions such as on-the-fly data compression and decompression, four 64-Kbyte regions of the DRAM can be mapped into a 16-Mbyte virtual address space.

Peripheral Interface Adapter (PIA)

The peripheral interface adapter allows for additional system features implemented by external peripheral chips. The PIA interface permits glueless interfacing from the Am29202 microcontroller to two external peripherals, each with a separate 4-Mbyte address space.
DMA Controller
The DMA controller in the Am29202 microcontroller provides two channels for transfer of data between the DRAM and internal peripherals and one channel for external transfers. One of the DMA channels is double buffered to relax the constraints on the reload time.

Interrupt Controller
The interrupt controller generates and reports the status of interrupts caused by on-chip peripherals.

Programmable I/O Port (PIO)
The Am29202 microcontroller’s I/O port permits direct access to 12 individually programmable external input/output signals. Eight of these signals can be configured to cause interrupts. Four of these signals are shared with the IEEE-1284-compliant parallel port interface.

Serial Port
The serial port implements a full-duplex UART.

Serializer/Deserializer
The bidirectional bit serializer/deserializer (video interface) permits direct connection to a number of laser marking engines, video displays, or raster input devices such as scanners.

Performance Overview
The Am29202 microcontroller offers a significant margin of performance over CISC microprocessors in existing embedded designs, since the majority of processor features were defined for the maximum achievable performance at a very low cost. This section describes the features of the Am29202 microcontroller from the point of view of system performance.

Instruction Timing
The Am29202 microcontroller uses an arithmetic/logic unit, a field shift unit, and a prioritizer to execute most instructions. Each of these is organized to operate on 32-bit operands and produce a 32-bit result. All operations are performed in a single cycle.

The performance degradation of load and store operations is minimized in the Am29202 microcontroller by overlapping them with instruction execution, by taking advantage of pipelining, and by organizing the flow of external data into the processor so that the impact of external accesses is minimized.

Pipelining
Instruction operations are overlapped with instruction fetch, instruction decode and operand fetch, instruction execution, and result write-back to the register file. Pipeline forwarding logic detects pipeline dependencies and routes data as required, avoiding delays that might arise from these dependencies.

Pipeline interlocks are implemented by processor hardware. Except for a few special cases, it is not necessary to rearrange instructions to avoid pipeline dependencies, although this is sometimes desirable for performance.

Instruction Set Overview
The Am29202 microcontroller employs a three-address instruction set architecture. The compiler or assembly-language programmer is given complete freedom to allocate register usage. There are 192 general-purpose registers, allowing the retention of intermediate calculations and avoiding needless memory accesses. Instruction operands may be contained in any of the general-purpose registers, and the results may be stored into any of the general-purpose registers.

The instruction set contains 117 instructions that are divided into nine classes. These classes are integer arithmetic, compare, logical, shift, data movement, constant, floating point, branch, and miscellaneous. The floating-point instructions are not executed directly, but are emulated by trap handlers.

All directly implemented instructions are capable of executing in one processor cycle, with the exception of interrupt returns, loads, and stores.

Data Formats
The Am29202 microcontroller defines a word as 32 bits of data, a half-word as 16 bits, and a byte as 8 bits. The hardware provides direct support for word-integer (signed and unsigned), word-logical, word-Boolean, half-word integer (signed and unsigned), and character data (signed and unsigned).

Word-Boolean data is based on the value contained in the most significant bit of the word. The values TRUE and FALSE are represented by the MSB values 1 and 0, respectively.

Other data formats, such as character strings, are supported by instruction sequences. Floating-point formats (single and double precision) are defined for the processor; however, there is no direct hardware support for these formats in the Am29202 microcontroller.

Protection
The Am29202 microcontroller offers two mutually exclusive modes of execution, the user and supervisor modes, that restrict or permit accesses to certain processor registers and external storage locations.

The register file may be configured to restrict accesses to supervisor-mode programs on a bank-by-bank basis.
Page-Mode Memories

The Am29202 microcontroller uses the page-mode capability of common DRAMs to improve the access time in cases where page-mode accesses can be used. This is particularly useful in very low-cost systems with 16-bit-wide DRAMs, where the DRAM must be accessed twice for each 32-bit operand.

DRAM Mapping

The Am29202 microcontroller provides a 16-Mbyte region of virtual memory that is mapped to one of four 64-Kbyte blocks in the physical DRAM memory. This supports system functions such as on-the-fly data compression and decompression, allowing a large data structure such as a frame buffer to be stored in a compressed format while the application software operates on a region of the structure that is decompressed. Using a mechanism that is analogous to demand paging, system software moves data between the compressed and decompressed formats in a way that is invisible to the application software. This feature can greatly reduce the amount of memory required for printing, imaging, and graphics applications.

Interrupts and Traps

When the microcontroller takes an interrupt or trap, it does not automatically save its current state information in memory. This lightweight interrupt and trap facility greatly improves the performance of temporary interruptions such as simple operating-system calls that require no saving of state information.

In cases where the processor state must be saved, the saving and restoring of state information is under the control of software. The methods and data structures used to handle interrupts—and the amount of state information saved—may be tailored to the needs of a particular system.

Interrupts and traps are dispatched through a 256-entry vector table which directs the processor to a routine that handles a given interrupt or trap. The vector table may be relocated in memory by the modification of a processor register. There may be multiple vector tables in the system, though only one is active at any given time.

The vector table is a table of pointers to the interrupt and trap handlers and requires only 1 Kbyte of memory. The processor performs a vector fetch every time an interrupt or trap is taken. The vector fetch requires at least three cycles, in addition to the number of cycles required for the basic memory access.

Debugging and Testing

Software debugging on the Am29202 microcontroller is facilitated by the instruction trace facility and instruction breakpoints. Instruction tracing is accomplished by forcing the processor to trap after each instruction has been executed. Instruction breakpoints are implemented by the HALT instruction or by a software trap.

A scan interface compliant with IEEE Std 1149.1-1990 (JTAG) Standard Test Access Port and Boundary-Scan Architecture is provided to test system hardware in a production environment. It contains extensions that allow a hardware-development system to control and observe the processor without interposing hardware between the processor and system.

Complete Development and Support Environment

A complete development and support environment is vital for reducing a product's time-to-market. Advanced Micro Devices has created a standard development environment for the 29K Family of processors. In addition, the Fusion29K third-party support organization provides the most comprehensive customer/partner program in the embedded processor market.

Advanced Micro Devices offers a complete set of hardware and software tools for design, integration, debugging, and benchmarking. These tools, which are available now for the 29K Family, include the following:

- High C® 29K optimizing C compiler with assembler, linker, ANSI library functions, and 29K architectural simulator
- XRAY29K™ source-level debugger
- MiniMON29K™ debug monitor
- A complete family of demonstration and development boards

In addition, Advanced Micro Devices has developed a standard host interface (HIF) specification for operating system services, the Universal Debug Interface (UDI) for seamless connection of debuggers to ICEs and target hardware, and extensions for the UNIX common object file format (COFF).

This support is augmented by an engineering hotline, an on-line bulletin board, and field application engineers.
Note:
Pin 1 is marked for orientation.
<table>
<thead>
<tr>
<th>Pin No.</th>
<th>Pin Name</th>
<th>Pin No.</th>
<th>Pin Name</th>
<th>Pin No.</th>
<th>Pin Name</th>
<th>Pin No.</th>
<th>Pin Name</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>VCC</td>
<td>34</td>
<td>ID7</td>
<td>67</td>
<td>PIAOE</td>
<td>100</td>
<td>POE</td>
</tr>
<tr>
<td>2</td>
<td>MEMCLK</td>
<td>35</td>
<td>ID6</td>
<td>68</td>
<td>DACK1</td>
<td>101</td>
<td>PACK</td>
</tr>
<tr>
<td>3</td>
<td>VCC</td>
<td>36</td>
<td>ID5</td>
<td>69</td>
<td>A21</td>
<td>102</td>
<td>PBUSY</td>
</tr>
<tr>
<td>4</td>
<td>GND</td>
<td>37</td>
<td>ID4</td>
<td>70</td>
<td>A20</td>
<td>103</td>
<td>PIO15</td>
</tr>
<tr>
<td>5</td>
<td>INCLK</td>
<td>38</td>
<td>ID3</td>
<td>71</td>
<td>A19</td>
<td>104</td>
<td>PIO14</td>
</tr>
<tr>
<td>6</td>
<td>GND</td>
<td>39</td>
<td>ID2</td>
<td>72</td>
<td>A18</td>
<td>105</td>
<td>PIO13</td>
</tr>
<tr>
<td>7</td>
<td>VCC</td>
<td>40</td>
<td>ID1</td>
<td>73</td>
<td>A17</td>
<td>106</td>
<td>GND</td>
</tr>
<tr>
<td>8</td>
<td>ID31</td>
<td>41</td>
<td>ID0</td>
<td>74</td>
<td>A16</td>
<td>107</td>
<td>VCC</td>
</tr>
<tr>
<td>9</td>
<td>ID30</td>
<td>42</td>
<td>GND</td>
<td>75</td>
<td>A15</td>
<td>108</td>
<td>PIO12</td>
</tr>
<tr>
<td>10</td>
<td>ID29</td>
<td>43</td>
<td>VCC</td>
<td>76</td>
<td>A14</td>
<td>109</td>
<td>PIO11</td>
</tr>
<tr>
<td>11</td>
<td>ID28</td>
<td>44</td>
<td>RXD</td>
<td>77</td>
<td>A13</td>
<td>110</td>
<td>PIO10</td>
</tr>
<tr>
<td>12</td>
<td>ID27</td>
<td>45</td>
<td>UCLK</td>
<td>78</td>
<td>A12</td>
<td>111</td>
<td>PIO9</td>
</tr>
<tr>
<td>13</td>
<td>ID26</td>
<td>46</td>
<td>TXD</td>
<td>79</td>
<td>A11</td>
<td>112</td>
<td>PIO8</td>
</tr>
<tr>
<td>14</td>
<td>ID25</td>
<td>47</td>
<td>ROMCS3</td>
<td>80</td>
<td>GND</td>
<td>113</td>
<td>PIO7/REVOE</td>
</tr>
<tr>
<td>15</td>
<td>ID24</td>
<td>48</td>
<td>ROMCS2</td>
<td>81</td>
<td>VCC</td>
<td>114</td>
<td>PIO6/DATASTROBE</td>
</tr>
<tr>
<td>16</td>
<td>ID23</td>
<td>49</td>
<td>ROMCS1</td>
<td>82</td>
<td>A10</td>
<td>115</td>
<td>PIO5/SELECTIN</td>
</tr>
<tr>
<td>17</td>
<td>ID22</td>
<td>50</td>
<td>ROMCS0</td>
<td>83</td>
<td>A9</td>
<td>116</td>
<td>PIO4/INIT</td>
</tr>
<tr>
<td>18</td>
<td>ID21</td>
<td>51</td>
<td>RSWE</td>
<td>84</td>
<td>A8</td>
<td>117</td>
<td>TDO</td>
</tr>
<tr>
<td>19</td>
<td>ID20</td>
<td>52</td>
<td>ROMOE</td>
<td>85</td>
<td>A7</td>
<td>118</td>
<td>VDAT</td>
</tr>
<tr>
<td>20</td>
<td>ID19</td>
<td>53</td>
<td>RAS3</td>
<td>86</td>
<td>A6</td>
<td>119</td>
<td>VCC</td>
</tr>
<tr>
<td>21</td>
<td>ID18</td>
<td>54</td>
<td>RAS2</td>
<td>87</td>
<td>A5</td>
<td>120</td>
<td>GND</td>
</tr>
<tr>
<td>22</td>
<td>ID17</td>
<td>55</td>
<td>RAS1</td>
<td>88</td>
<td>A4</td>
<td>121</td>
<td>PSYNC</td>
</tr>
<tr>
<td>23</td>
<td>ID16</td>
<td>56</td>
<td>RAS0</td>
<td>89</td>
<td>A3</td>
<td>122</td>
<td>DREQ1</td>
</tr>
<tr>
<td>24</td>
<td>VCC</td>
<td>57</td>
<td>CAS3</td>
<td>90</td>
<td>A2</td>
<td>123</td>
<td>INTR0</td>
</tr>
<tr>
<td>25</td>
<td>GND</td>
<td>58</td>
<td>CAS2</td>
<td>91</td>
<td>A1</td>
<td>124</td>
<td>INTR2</td>
</tr>
<tr>
<td>26</td>
<td>ID15</td>
<td>59</td>
<td>CAS1</td>
<td>92</td>
<td>A0</td>
<td>125</td>
<td>VCLK</td>
</tr>
<tr>
<td>27</td>
<td>ID14</td>
<td>60</td>
<td>CAS0</td>
<td>93</td>
<td>VCC</td>
<td>126</td>
<td>LSYNC</td>
</tr>
<tr>
<td>28</td>
<td>ID13</td>
<td>61</td>
<td>WE</td>
<td>94</td>
<td>GND</td>
<td>127</td>
<td>TMS</td>
</tr>
<tr>
<td>29</td>
<td>ID12</td>
<td>62</td>
<td>VCC</td>
<td>95</td>
<td>BOOTW</td>
<td>128</td>
<td>TRST</td>
</tr>
<tr>
<td>30</td>
<td>ID11</td>
<td>63</td>
<td>GND</td>
<td>96</td>
<td>WAIT/TRIST</td>
<td>129</td>
<td>TCK</td>
</tr>
<tr>
<td>31</td>
<td>ID10</td>
<td>64</td>
<td>PIACS1</td>
<td>97</td>
<td>PAUTOFD</td>
<td>130</td>
<td>TDI</td>
</tr>
<tr>
<td>32</td>
<td>ID9</td>
<td>65</td>
<td>PIACS0</td>
<td>98</td>
<td>PSTROBE</td>
<td>131</td>
<td>RESET</td>
</tr>
<tr>
<td>33</td>
<td>ID8</td>
<td>66</td>
<td>PIAWE</td>
<td>99</td>
<td>PWE</td>
<td>132</td>
<td>GND</td>
</tr>
</tbody>
</table>
## PQFP PIN DESIGNATIONS (Sorted by Pin Name)

<table>
<thead>
<tr>
<th>Pin Name</th>
<th>Pin No.</th>
<th>Pin Name</th>
<th>Pin No.</th>
<th>Pin Name</th>
<th>Pin No.</th>
<th>Pin Name</th>
<th>Pin No.</th>
</tr>
</thead>
<tbody>
<tr>
<td>A0</td>
<td>92</td>
<td>GND</td>
<td>63</td>
<td>ID27</td>
<td>12</td>
<td>RAS0</td>
<td>56</td>
</tr>
<tr>
<td>A1</td>
<td>91</td>
<td>GND</td>
<td>80</td>
<td>ID28</td>
<td>11</td>
<td>RAS1</td>
<td>55</td>
</tr>
<tr>
<td>A2</td>
<td>90</td>
<td>GND</td>
<td>94</td>
<td>ID29</td>
<td>10</td>
<td>RAS2</td>
<td>54</td>
</tr>
<tr>
<td>A3</td>
<td>89</td>
<td>GND</td>
<td>106</td>
<td>ID30</td>
<td>9</td>
<td>RAS3</td>
<td>53</td>
</tr>
<tr>
<td>A4</td>
<td>88</td>
<td>GND</td>
<td>120</td>
<td>ID31</td>
<td>8</td>
<td>RST</td>
<td>131</td>
</tr>
<tr>
<td>A5</td>
<td>87</td>
<td>GND</td>
<td>132</td>
<td>INCLK</td>
<td>5</td>
<td>ROMCS0</td>
<td>50</td>
</tr>
<tr>
<td>A6</td>
<td>86</td>
<td>ID0</td>
<td>41</td>
<td>INTR0</td>
<td>123</td>
<td>ROMCS1</td>
<td>49</td>
</tr>
<tr>
<td>A7</td>
<td>85</td>
<td>ID1</td>
<td>40</td>
<td>INTR2</td>
<td>124</td>
<td>ROMCS2</td>
<td>48</td>
</tr>
<tr>
<td>A8</td>
<td>84</td>
<td>ID2</td>
<td>39</td>
<td>LSYNC</td>
<td>126</td>
<td>ROMCS3</td>
<td>47</td>
</tr>
<tr>
<td>A9</td>
<td>83</td>
<td>ID3</td>
<td>38</td>
<td>MEMCLK</td>
<td>2</td>
<td>ROMOE</td>
<td>52</td>
</tr>
<tr>
<td>A10</td>
<td>82</td>
<td>ID4</td>
<td>37</td>
<td>PACK</td>
<td>101</td>
<td>RSWE</td>
<td>51</td>
</tr>
<tr>
<td>A11</td>
<td>79</td>
<td>ID5</td>
<td>36</td>
<td>PAUTOFD</td>
<td>97</td>
<td>RXD</td>
<td>44</td>
</tr>
<tr>
<td>A12</td>
<td>78</td>
<td>ID6</td>
<td>35</td>
<td>PBUSY</td>
<td>102</td>
<td>TCK</td>
<td>129</td>
</tr>
<tr>
<td>A13</td>
<td>77</td>
<td>ID7</td>
<td>34</td>
<td>PIACS0</td>
<td>65</td>
<td>TDI</td>
<td>130</td>
</tr>
<tr>
<td>A14</td>
<td>76</td>
<td>ID8</td>
<td>33</td>
<td>PIACS1</td>
<td>64</td>
<td>TDO</td>
<td>117</td>
</tr>
<tr>
<td>A15</td>
<td>75</td>
<td>ID9</td>
<td>32</td>
<td>PIACS2</td>
<td>32</td>
<td>TMS</td>
<td>127</td>
</tr>
<tr>
<td>A16</td>
<td>74</td>
<td>ID10</td>
<td>31</td>
<td>PIACS3</td>
<td>33</td>
<td>TRST</td>
<td>128</td>
</tr>
<tr>
<td>A17</td>
<td>73</td>
<td>ID11</td>
<td>30</td>
<td>PIACS4</td>
<td>34</td>
<td>TXD</td>
<td>46</td>
</tr>
<tr>
<td>A18</td>
<td>72</td>
<td>ID12</td>
<td>29</td>
<td>PIACS5</td>
<td>29</td>
<td>UCLK</td>
<td>45</td>
</tr>
<tr>
<td>A19</td>
<td>71</td>
<td>ID13</td>
<td>28</td>
<td>PIACS6</td>
<td>28</td>
<td>VCC</td>
<td>1</td>
</tr>
<tr>
<td>A20</td>
<td>70</td>
<td>ID14</td>
<td>27</td>
<td>PIACS7</td>
<td>27</td>
<td>VCC</td>
<td>3</td>
</tr>
<tr>
<td>A21</td>
<td>69</td>
<td>ID15</td>
<td>26</td>
<td>PIACS8</td>
<td>26</td>
<td>VCC</td>
<td>7</td>
</tr>
<tr>
<td>A22</td>
<td>68</td>
<td>ID16</td>
<td>25</td>
<td>PIACS9</td>
<td>25</td>
<td>VCC</td>
<td>24</td>
</tr>
<tr>
<td>BOOTW</td>
<td>67</td>
<td>ID17</td>
<td>24</td>
<td>PIACS10</td>
<td>24</td>
<td>VCC</td>
<td>43</td>
</tr>
<tr>
<td>CAS0</td>
<td>60</td>
<td>ID18</td>
<td>23</td>
<td>PIACS11</td>
<td>23</td>
<td>VCC</td>
<td>62</td>
</tr>
<tr>
<td>CAS1</td>
<td>59</td>
<td>ID19</td>
<td>22</td>
<td>PIACS12</td>
<td>22</td>
<td>VCC</td>
<td>81</td>
</tr>
<tr>
<td>CAS2</td>
<td>58</td>
<td>ID20</td>
<td>21</td>
<td>PIACS13</td>
<td>21</td>
<td>VCC</td>
<td>93</td>
</tr>
<tr>
<td>DACK1</td>
<td>57</td>
<td>ID21</td>
<td>20</td>
<td>PIACS14</td>
<td>20</td>
<td>VCC</td>
<td>107</td>
</tr>
<tr>
<td>DREQ1</td>
<td>56</td>
<td>ID22</td>
<td>19</td>
<td>PIACS15</td>
<td>19</td>
<td>VCC</td>
<td>119</td>
</tr>
<tr>
<td>GND</td>
<td>55</td>
<td>ID23</td>
<td>18</td>
<td>PIACS16</td>
<td>18</td>
<td>VCC</td>
<td>125</td>
</tr>
<tr>
<td>GND</td>
<td>54</td>
<td>ID24</td>
<td>17</td>
<td>PIACS17</td>
<td>17</td>
<td>VCC</td>
<td>118</td>
</tr>
<tr>
<td>GND</td>
<td>53</td>
<td>ID25</td>
<td>16</td>
<td>PIACS18</td>
<td>16</td>
<td>VCC</td>
<td>96</td>
</tr>
<tr>
<td>GND</td>
<td>52</td>
<td>ID26</td>
<td>15</td>
<td>PIACS19</td>
<td>15</td>
<td>WE</td>
<td>61</td>
</tr>
</tbody>
</table>
PIN DESCRIPTIONS

Note: The UCLK signal must be tied High if the serial port is not used.

Clocks

INCLK
Input Clock (input)
This is an oscillator input at twice the processor and system operating frequency. It can be driven at TTL levels.

MEMCLK
Memory Clock (output)
This is a clock output at one-half of the frequency of INCLK. Most processor outputs, and many inputs, are synchronous to MEMCLK. MEMCLK drives out with CMOS levels.

Processor Signals

A21–A0
Address Bus (output, synchronous)
The address bus supplies the byte address for all accesses, except for DRAM accesses. For DRAM accesses, multiplexed row and column addresses are provided on A14–A1. The signals A23–A22 and burst-mode devices are not supported on the Am29202 microcontroller.

ID31–ID0
Instruction/Data Bus (bidirectional, synchronous)
The instruction/data bus (ID bus) transfers instructions to, and data to and from the processor.

INTR2, INTR0
Interrupt Requests 2 and 0 (input, asynchronous, internal pull-up transistors)
These inputs generate prioritized interrupt requests. The interrupt caused by INTR0 has the highest priority, and the interrupt caused by INTR2 has the lower priority. The interrupt requests are masked in prioritized order by the Interrupt Mask field in the Current Processor Status Register and are disabled by the DA and DI bits of the Current Processor Status Register. These signals have special hardening against metastable states, allowing them to be driven with slow-transition-time signals. The INTR3 and INTR1 signals are not supported on the Am29202 microcontroller.

RESET
Reset (input, asynchronous)
This input places the processor in the Reset mode. This signal has special hardening against metastable states, allowing it to be driven with a slow-rise-time signal.

WAIT/TRIST
Add Wait States/Three-State Control (input, synchronous, weak internal pull-up)
The WAIT signal may be asserted during a PIA, ROM, or DMA access to extend the access indefinitely. The WAIT/TRIST pin is also used for three-state control during test. When asserted during a processor reset, all output pins go into a high impedance state. For normal operation, this pin must be pulled High during reset.

ROM Interface

BOOTW
Boot ROM Width (input, asynchronous)
This input configures the width of ROM Bank 0, so the ROM can be accessed before the ROM configuration has been set by the system initialization software. The BOOTW signal is sampled during and after a processor reset. If BOOTW is High before and after reset (tied High), the boot ROM is 32 bits wide. If BOOTW is Low before and after reset (tied Low), the boot ROM is 16 bits wide. If BOOTW is Low before reset and High after reset (tied to RESET), the boot ROM is 8 bits wide. This signal has special hardening against metastable states, allowing it to be driven with a slow-rise-time signal and permitting it to be tied to RESET.

ROMCS3–ROMCS0
ROM Chip Selects, Banks 3–0 (output, synchronous)
A Low level on one of these signals selects the memory devices in the corresponding ROM bank. ROMCS3 selects devices in ROM Bank 3, and so on. The timing and access parameters of each bank are individually programmable.

ROMOE
ROM Output Enable (output, synchronous)
This signal enables the selected ROM Bank to drive the ID bus. It is used to prevent bus contention when switching between different ROM banks or switching between a ROM bank and another device or DRAM bank.

RSWE
ROM Space Write Enable (output, synchronous)
This signal is used to write an alterable memory in a ROM bank (such as an SRAM or Flash EPROM). RSWE supports only writes of width equal to or greater than the width of the memory, and the memory must be at least 16 bits wide. The CAS3–CAS0 signals can serve as individual byte strobes for writes to the ROM space, if ROM byte writes are enabled.

DRAM Interface

CAS3–CAS0
Column Address Strobes, Byte 3–0 (output, synchronous)
A High-to-Low transition on these signals causes the DRAM bank selected by RAS3–RAS0 to latch the column address and complete the access. To support byte and half-word writes, column address strobes are provided for individual DRAM bytes. CAS3 is the column address strobe for the DRAMs, in all banks, attached to
ID31–ID24. CAS2 is for the DRAMs attached to ID23–ID16, and so on. These signals are also used in other special DRAM cycles.

The CAS3–CAS0 signals can be enabled to act as individual byte strobes for byte writes to the ROM space. In this configuration, ROM accesses do not conflict with DRAM accesses or refresh even though CAS3–CAS0 may be used by both the ROM and DRAM.

RAS3–RAS0
Row Address Strobe, Banks 3–0 (output, synchronous)
A High-to-Low transition on one of these signals causes a DRAM in the corresponding bank to latch the row address and begin an access. RAS3 starts an access in DRAM Bank 3, and so on. These signals are also used in other special DRAM cycles.

WE
Write Enable (output, synchronous)
This signal is used to write the selected DRAM bank. “Early write” cycles are used so the DRAM data inputs and outputs can be tied to the common ID bus.

Peripheral Interface Adapter (PIA)

PIACS1–PIACS0
Peripheral Chip Selects, Regions 1–0 (output, synchronous)
These signals are used to select individual peripheral devices. DMA Channel 1 may be programmed to use PIACS1. PIACS5–PIACS2 are not supported on the Am29202 microcontroller.

PIAOE
Peripheral Output Enable (output, synchronous)
This signal enables the selected peripheral device to drive the ID bus.

PIAWE
Peripheral Write Enable (output, synchronous)
This signal causes data on the ID bus to be written into the selected peripheral.

DMA Controller

DACK1
DMA Acknowledge, Channel 1 (output, synchronous)
This signal acknowledges an external transfer on DMA Channel 1. DMA transfers can occur to and from internal peripherals independent of these acknowledgments. DACK0 is not supported on the Am29202 microcontroller.

DREQ1
DMA Request, Channel 1 (input, asynchronous, internal pull-up)
This signal requests an external transfer on DMA Channel 1. This request is individually programmable to be either level- or edge-sensitive for either polarity of level or edge. DMA transfers can occur to and from internal peripherals independent of these requests. DREQ0 is not supported on the Am29202 microcontroller.

I/O Port

PIO15–PIO8, PIO7/REVOE, PIO6/DATASTROBE, PIO5/SELECTIN, PIO4/INIT
Programmable Input/Output (input/output, asynchronous)
The PIO signals are available for direct software control and inspection. PIO15–PIO8 may be individually programmed to cause processor interrupts. These signals have special hardening against metastable states, allowing them to be driven with slow-transition-time signals. PIO7–PIO4 are shared with the IEEE-1284-compliant parallel port interface. The I/O port has control of these lines when the parallel port is not enabled. The signals PIO3–PIO0 are not supported on the Am29202 microcontroller.

Advanced Parallel Interface (API)

Note: For more complete descriptions of these signals and their use, see the functional description of the IEEE-1284-compliant parallel interface beginning on page 41.

DATASTROBE/PIO6
(output, synchronous)
DATASTROBE causes incoming data from the host to be latched externally on the rising edge. It is generated by a number of different signals and edges in various IEEE-1284 modes.

INIT/PIO4
(input, asynchronous)
The INIT signal comes from the IEEE-1284 signal nInit/ nReverseRequest and can optionally cause control interrupts on either edge.

PACK
Parallel Port Acknowledge (output, synchronous)
This signal is used by the microcontroller to acknowledge a transfer from the host or to indicate to the host that data has been placed on the port.

PAUTOFD
Parallel Port Autofeed (input, asynchronous)
This signal is directly input from the IEEE-1284 signal nAutofd/HostBusy/HostAck. It is used by the host in reverse-channel modes to signal reverse data strobe. It is also used in other contexts in various modes. PAUTOFD can optionally cause control interrupts on either edge.

PBUSY
Parallel Port Busy (output, synchronous)
Output to the IEEE-1284 signal Busy/PtrBusy/PeriphAck, this signal comes from the API when it is enabled.
POE
Parallel Port Output Enable (output, synchronous)
This signal enables latched data on the data bus, to be read by the processor under interrupt or DMA control.

PSTROBE
Parallel Port Strobe (input, asynchronous)
Directly input from the IEEE-1284 signal nStrobe/HostClk, PSTROBE is used in some forward modes to generate data strobe assertions and to signal data presence. In other modes, PSTROBE signals something other than a data transfer. The PSTROBE signal can optionally cause control interrupts on either edge.

PWE
Parallel Port Write Enable (output, synchronous)
This signal is used to latch the data bus for outgoing (peripheral-to-host) transmission.

REVOE/PIO7
(output, synchronous)
REVOE is used to drive latched output data in the reverse direction, from peripheral to host.

SELECTIN/PIO5
(input, asynchronous)
SELECTIN comes from the IEEE-1284 signal nSelectIn/1284Active. It transitions (along with PAUTOFD) to signal the request to negotiate an IEEE-1284 mode and to signal the termination from an IEEE-1284 mode. SELECTIN can optionally cause control interrupts on either edge.

Serial Port

UCLK
UART Clock (input)
This is an oscillator input for generating the UART (serial port) clock. To generate the UART clock, the oscillator frequency may be divided by any amount up to 65,536. The UART clock operates at 16 times the serial port’s baud rate. As an option, UCLK may be driven with MEMCLK or INCLK. It can be driven with TTL levels. UCLK must be tied High if unused.

TXD
Transmit Data (output, asynchronous)
This output is used to transmit serial data.

RXD
Receive Data (input, asynchronous)
This input is used to receive serial data.

Video Interface

VCLK
Video Clock (input, asynchronous)
This clock is used to synchronize the transfer of video data. As an option, VCLK may be driven with MEMCLK or INCLK. It can be driven with TTL levels.

VDAT
Video Data (input/output, synchronous to VCLK)
This is serial data to or from the video device.

LSYNC
Line Synchronization (input, asynchronous)
This signal indicates the start of a raster line.

PSYNC
Page Synchronization (input/output, asynchronous)
This signal indicates the beginning of a raster page.

JTAG 1149.1 Boundary Scan Interface

TCK
Test Clock Input (asynchronous input, internal pull-up)
This input is used to operate the test access port. The state of the test access port must be held if this clock is held either High or Low. This clock is internally synchronized to MEMCLK for certain operations of the test access port controller, so signals internally driven and sampled by the test access port are synchronous to processor internal clocks.

TMS
Test Mode Select (input, synchronous to TCK, internal pull-up)
This input is used to control the test access port. If it is not driven, it appears High internally.

TDI
Test Data Input (input, synchronous to TCK, internal pull-up)
This input supplies data to the test logic from an external source. It is sampled on the rising edge of TCK. If it is not driven, it appears High internally.

TDO
Test Data Output (three-state output, synchronous to TCK)
This output supplies data from the test logic to an external destination. It changes on the falling edge of TCK. It is in the high-impedance state except when scanning is in progress.

TRST
Test Reset Input (asynchronous input, internal pull-up)
This input asynchronously resets the test access port. This input places the test logic in a state such that no output driver is enabled. The TRST input must be asserted in conjunction with the RESET input for correct processor initialization, whether or not the JTAG port is used.
FUNCTIONAL DIFFERENCES

The Am29202 microcontroller is functionally very similar to the Am29200 microcontroller, operating with a reduced pin count and fewer peripherals. The major differences include a new IEEE-1284-compliant bidirectional parallel port interface, a new refresh scheme, a smaller address bus (22 bits), only one external DMA channel, no direct DMA, no video DRAM support, fewer PIOs, fewer PIAs, no burst-mode ROM, no external traps, fewer interrupt request pins, and a new JTAG scan path.

This large section (through page 70) describes the technical differences between the Am29202 and Am29200 microcontrollers and omits much of the information common to both processors. For a complete description of the technical features, on-chip peripherals, programming interface, and instruction set, please refer to the Am29200 and Am29205 RISC Microcontrollers User’s Manual (order# 16362).

Note: All registers with bits designated as “reserved” should be programmed with 0s to ensure compatibility.

Advanced Parallel Interface

The parallel interface on the Am29202 microcontroller is completely different from the one included on the Am29200 and Am29205 microcontrollers. The new port is called the Advanced Parallel Interface (API) and is described in considerable detail in the section “IEEE-1284-Compliant Advanced Parallel Interface,” beginning on page 41.

Memory Map Changes

All addresses are in the microcontroller’s instruction/data memory address space. The address space is partitioned as shown in Table 2. Internal peripheral registers are selected by offsets from address 80000000h. The address assignment of the various internal peripherals and controllers is shown in Table 3.

The address assignments for the parallel port registers have changed from those assigned for the Am29200 and Am29205 microcontrollers. The following register addresses are not supported on the Am29202 microcontroller:

- Parallel Port Control Register 800000C0
- Parallel Port Data Register 800000C4
- Parallel Port Status Register 800000C8

Accesses to addresses that are not supported on the Am29202 microcontroller will generate an Unsupported Peripheral Address trap (see Table 4). The new address assignments for the Advanced Parallel Interface (API) registers are shown in Table 3.

Pin Changes for the Am29202 Microcontroller

The reduced pin count of the Am29202 microcontroller comes from having a smaller address bus and fewer ports on some of the peripherals. The following signals supported on the Am29200 microcontroller are not available on the Am29202 microcontroller.

- Processor signals: A23–A22, R/W, WARN, INTR1, INTR3, TRAP1–TRAP0, STAT2–STAT0
- ROM interface signals: BURST
- DRAM interface signals: TR/IOE
- PIA signals: PIACS5–PIACS2
- DMA signals: DREQ0, DACK0, TDMA, GREQ, GACK
- I/O port signals: PIO3–PIO0
- Serial port signals: DSR, DTR

<table>
<thead>
<tr>
<th>Address Range (hexadecimal)</th>
<th>Selection</th>
<th>Maximum Physical Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>000000000–03FFFFFFF</td>
<td>ROM Banks (all)</td>
<td>16 Mbyte</td>
</tr>
<tr>
<td>400000000–43FFFFFFF</td>
<td>DRAM Banks (all)</td>
<td>64 Mbyte</td>
</tr>
<tr>
<td>500000000–50FFFFFFF</td>
<td>Mapped DRAM Banks (all)</td>
<td>16 Mbyte</td>
</tr>
<tr>
<td>600000000–63FFFFFFF</td>
<td>VDRAM transfers</td>
<td>Not Supported</td>
</tr>
<tr>
<td>800000000–800000FC</td>
<td>Internal peripherals/controllers</td>
<td>—</td>
</tr>
<tr>
<td>900000000–90FFFFFFF</td>
<td>PIA Region 0 (PIACS0)</td>
<td>4 Mbyte</td>
</tr>
<tr>
<td>910000000–91FFFFFFF</td>
<td>PIA Region 1 (PIACS1)</td>
<td>4 Mbyte</td>
</tr>
<tr>
<td>920000000–92FFFFFFF</td>
<td>PIA Region 2 (PIACS2)</td>
<td>Not Supported</td>
</tr>
<tr>
<td>930000000–93FFFFFFF</td>
<td>PIA Region 3 (PIACS3)</td>
<td>Not Supported</td>
</tr>
<tr>
<td>940000000–94FFFFFFF</td>
<td>PIA Region 4 (PIACS4)</td>
<td>Not Supported</td>
</tr>
<tr>
<td>950000000–95FFFFFFF</td>
<td>PIA Region 5 (PIACS5)</td>
<td>Not Supported</td>
</tr>
<tr>
<td>—all others—</td>
<td>Reserved</td>
<td></td>
</tr>
</tbody>
</table>
### Table 3. Internal Peripheral Address Assignments

<table>
<thead>
<tr>
<th>Peripheral</th>
<th>Address (hexadecimal)</th>
<th>Register</th>
</tr>
</thead>
<tbody>
<tr>
<td>ROM Controller</td>
<td>80000000</td>
<td>ROM Control Register</td>
</tr>
<tr>
<td></td>
<td>80000004</td>
<td>ROM Configuration Register</td>
</tr>
<tr>
<td>DRAM Controller</td>
<td>80000008</td>
<td>DRAM Control Register</td>
</tr>
<tr>
<td></td>
<td>8000000C</td>
<td>DRAM Configuration Register</td>
</tr>
<tr>
<td>DRAM Mapping Unit</td>
<td>80000010</td>
<td>DRAM Mapping Register 0</td>
</tr>
<tr>
<td></td>
<td>80000014</td>
<td>DRAM Mapping Register 1</td>
</tr>
<tr>
<td></td>
<td>80000018</td>
<td>DRAM Mapping Register 2</td>
</tr>
<tr>
<td></td>
<td>8000001C</td>
<td>DRAM Mapping Register 3</td>
</tr>
<tr>
<td>Peripheral Interface Adapter</td>
<td>80000020</td>
<td>PIA Control Register 0</td>
</tr>
<tr>
<td></td>
<td>80000024</td>
<td>PIA Control Register 1 ♦</td>
</tr>
<tr>
<td>Interrupt Controller</td>
<td>80000028</td>
<td>Interrupt Control Register</td>
</tr>
<tr>
<td>DMA Channel 0</td>
<td>80000030</td>
<td>DMA0 Control Register</td>
</tr>
<tr>
<td></td>
<td>80000034</td>
<td>DMA0 Address Register</td>
</tr>
<tr>
<td></td>
<td>80000070</td>
<td>DMA0 Address Tail Register</td>
</tr>
<tr>
<td></td>
<td>80000038</td>
<td>DMA0 Count Register</td>
</tr>
<tr>
<td></td>
<td>8000003C</td>
<td>DMA0 Count Tail Register</td>
</tr>
<tr>
<td>DMA Channel 1</td>
<td>80000040</td>
<td>DMA1 Control Register</td>
</tr>
<tr>
<td></td>
<td>80000044</td>
<td>DMA1 Address Register</td>
</tr>
<tr>
<td></td>
<td>80000048</td>
<td>DMA1 Count Register</td>
</tr>
<tr>
<td>Serial Port</td>
<td>80000080</td>
<td>Serial Port Control Register</td>
</tr>
<tr>
<td></td>
<td>80000084</td>
<td>Serial Port Status Register</td>
</tr>
<tr>
<td></td>
<td>80000088</td>
<td>Serial Port Transmit Holding Register</td>
</tr>
<tr>
<td></td>
<td>8000008C</td>
<td>Serial Port Receive Buffer Register</td>
</tr>
<tr>
<td></td>
<td>80000090</td>
<td>Baud Rate Divisor Register</td>
</tr>
<tr>
<td>Advanced Parallel Interface</td>
<td>800000A0</td>
<td>Advanced Parallel Control Register</td>
</tr>
<tr>
<td></td>
<td>800000A4</td>
<td>Advanced Parallel Status Register</td>
</tr>
<tr>
<td></td>
<td>800000A8</td>
<td>Advanced Parallel Interrupt Mask Register</td>
</tr>
<tr>
<td></td>
<td>800000AC</td>
<td>Advanced Parallel Interrupt Status Register</td>
</tr>
<tr>
<td></td>
<td>800000B0</td>
<td>Advanced Parallel Data Register</td>
</tr>
<tr>
<td>Programmable I/O Port</td>
<td>800000D0</td>
<td>PIO Control Register</td>
</tr>
<tr>
<td></td>
<td>800000D4</td>
<td>PIO Input Register</td>
</tr>
<tr>
<td></td>
<td>800000D8</td>
<td>PIO Output Register</td>
</tr>
<tr>
<td></td>
<td>800000DC</td>
<td>PIO Output Enable Register</td>
</tr>
<tr>
<td>Video Interface</td>
<td>800000E0</td>
<td>Video Control Register</td>
</tr>
<tr>
<td></td>
<td>800000E4</td>
<td>Top Margin Register</td>
</tr>
<tr>
<td></td>
<td>800000E8</td>
<td>Side Margin Register</td>
</tr>
<tr>
<td></td>
<td>800000EC</td>
<td>Video Data Holding Register</td>
</tr>
<tr>
<td>—all others—</td>
<td>Reserved</td>
<td></td>
</tr>
</tbody>
</table>

**Note:**

♦ PIA Control Register 1 is reserved on the Am29202 microcontroller.
ROM CONTROLLER

The on-chip ROM controller provides a glueless interface to static memory devices such as ROM, EPROM, SRAM, Flash EPROM, and memory-mapped peripherals.

The ROM interface on the Am29202 microcontroller accommodates up to four banks of static memory space. These banks can be 8, 16, or 32 bits wide, with a maximum address space of 4 Mbytes per bank, instead of the 16 Mbytes supported by the Am29200 microcontroller.

Burst-mode ROM accesses are not supported on the Am29202 microcontroller, since the BURST pin is not present.

ROM Control Register (RMCT, Address 80000000)

The ROM Control Register (Figure 1) controls the access of ROM Banks 0 through 3. Bits controlling burst-mode on the Am29200 microcontroller are now reserved on the Am29202 microcontroller.

Bit 31: Reserved

Bits 30–29: Data Width, Bank 0 (DW0)—This field indicates the width of the ROM in Bank 0, as follows:

<table>
<thead>
<tr>
<th>DW0</th>
<th>ROM Width</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>32 bits</td>
</tr>
<tr>
<td>01</td>
<td>8 bits</td>
</tr>
<tr>
<td>10</td>
<td>16 bits</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

Bit 28: Large Memory (LM)—This bit controls the size of the ROM banks and the total size of the ROM address space. If the LM bit is 0, each ROM bank is up to 1 Mbyte in size, for placement within a 4 Mbyte total ROM address space. If the LM bit is 1, each ROM bank is up to 4 Mbytes in size, for placement within a 16-Mbyte total ROM address space.

Bit 27: Byte Write Enable (BWE)—This bit controls whether or not the CAS3–CAS0 signals are used as byte strobes during writes to the ROM address space. If BWE is 0, the CAS3–CAS0 signals are not active during ROM writes (unless there is a hidden refresh at the same time). If BWE is 1, the CAS3–CAS0 signals are used as byte strobes during a ROM write with hidden refresh prohibited during a ROM read or write.

Bit 26: Reserved

Bits 25–24: Wait States, Bank 0 (WS0)—This field specifies the number of wait states in a ROM access (i.e., the number of cycles in addition to one cycle required to access the ROM). Zero-wait-state cycles are supported for ROM reads. Writes to the ROM address space have a minimum of one wait state, even when wait states are programmed at zero.

Other bits of this register have a definition similar to DW0 and WS0 for ROM Banks 1 through 3.
DRAM CONTROLLER

The Am29202 microcontroller directly supports DRAM devices without any additional components, providing RAS and CAS generation, address multiplexing, and refresh generation. The on-chip DRAM controller utilizes page-mode accesses and CAS-before-RAS refresh to extract maximum performance from DRAM devices.

The DRAM interface accommodates up to four banks of DRAM that can be configured as a contiguous memory. Each bank is individually configurable in width. In addition, four 64-Kbyte regions of the DRAM can be mapped into a 16-Mbyte virtual address space.

For random accesses, the DRAM controller provides a fixed access time of 3 cycles plus 1 cycle of RAS precharge after each access. Sequential accesses use the DRAM page mode with 3 cycles for the first access, followed by 2 cycles for each additional access, followed by 1 cycle of precharge.

To support a lower pin count, several signals used by the Am29200 microcontroller for DRAM interfacing are not available on the Am29202 microcontroller. The TR/OE signal for normal DRAM output enable and video DRAM transfer is not available on the Am29202 microcontroller. Any DRAM with an OE line should have this line either tied to the appropriate CAS signal, or tied directly to ground (asserted) to always be enabled. This will not cause any circuit contention, since the DRAM’s internal logic gates the external OE signal with the device’s internal chip select from the processor’s RAS. Video DRAM transfers are not supported on the Am29202 microcontroller.

DRAM Control Register (DRCT, Address 80000008)

The DRAM Control Register (Figure 2) controls the access to and refresh of DRAM Banks 0 through 3.

Bit 31: Page-Mode DRAM, Bank 0 (PG0)—When this bit is 1, burst-mode accesses to DRAM Bank 0 are performed using page-mode accesses for all but the first access. When this bit is 0, page-mode accesses are not performed.

Bit 30: Data Width, Bank 0 (DW0)—This field indicates the width of the DRAM in Bank 0, as follows:

<table>
<thead>
<tr>
<th>DW Value</th>
<th>DRAM Width</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>32 bits</td>
</tr>
<tr>
<td>1</td>
<td>16 bits</td>
</tr>
</tbody>
</table>

Bit 29: Disable Bank Refresh, Bank 0 (DBR0)—When this bit is 1, DRAM refresh does not occur for DRAM Bank 0.

Bit 28: Large Memory (LM)—This bit controls the size of the DRAM banks and the total size of the DRAM address space. If the LM bit is 0, each DRAM bank is up to 4 Mbytes in size, for placement within a 16 Mbyte total DRAM address space.

If the LM bit is 1, each DRAM bank is up to 16 Mbytes in size, for placement within a 64-Mbyte total DRAM address space.

Other bits of this register have a definition similar to PG0, DBR0, DW0 for DRAM Banks 1 through 3.

Bit 15: Static-Column DRAM (SC)—When this bit is 1, page-mode accesses to the DRAM are performed using static-column accesses. Static column accesses differ from page-mode cycles only in that CAS3–CAS0 are held Low throughout a read access. The timing of the access is not affected, and write accesses are not affected. When this bit is 0, normal page-mode accesses are performed, if enabled.

Bits 14–9: Reserved

Bits 8–0: Refresh Rate (REFRATE)—This field indicates the number of MEMCLK cycles between DRAM refresh intervals. A DRAM refresh interval is the time required to refresh all enabled DRAM banks. CAS-before-RAS cycles are performed, overlapped in the background with other non-DRAM accesses when possible. If one or more banks have not been refreshed

---

Figure 2. DRAM Control Register
in the background when the REFRATE interval expires twice, the processor forces a panic-mode refresh of the unrefreshed banks.

The minimum REFRATE count for the Am29202 microcontroller is 16. A zero in the REFRATE field disables refresh. On reset, this field is initialized to the value 1FFh.

**Refresh Control Changes**

Two basic improvements have been made to the refresh control mechanism over that implemented on the Am29200 microcontroller.

- Panic refresh has been redefined.
- Selectable DRAM refresh by bank has been added.

**Panic Refresh**

A panic refresh will occur when the REFRATE field in the DRAM Control Register has decremented to 0 twice. Rather than immediately refreshing all unrefreshed banks at the first available opportunity, these banks are refreshed in sequence, with each 4-cycle CAS-before-RAS refresh separated by 12 cycles from the next refresh. Having gaps between the refreshes allows DMA transfers to occur in between. The maximum interval between refreshes on the same (enabled) bank is:

\[
((\text{number of rows/bank}) - 1) \times \text{REFRATE} + \\
(16 \times \text{MEMCLK cycles} \times \text{number of enabled banks})
\]

This assumes each DRAM bank can be refreshed within 16 cycles of the preceding bank’s refresh.

Hidden or non-panic refreshes are unchanged from the Am29200 microcontroller.

**Selectable DRAM Refresh**

Since unused DRAM banks need no refresh, the Am29202 microcontroller provides a selectable DRAM bank refresh option. This feature eliminates unnecessary refresh cycles, reducing the likelihood of a panic refresh and speeding up the refresh process. Four new bits have been added to the DRAM Control Register to support this feature. A single bit is present for each DRAM bank and, when set high, disables that DRAM bank from being refreshed. All DRAM banks are enabled for DRAM refresh at processor reset.
PERIPHERAL INTERFACE Adapter (PIA)

PIA space on the microcontroller is divided into regions, each of which can be directly attached to an off-chip peripheral device. The microcontroller’s dedicated PIA chip select signals will assert a peripheral device’s chip select pin when the associated PIA region on the microcontroller is read or written.

With two PIA chip select signals and a smaller address bus, the Am29202 microcontroller supports up to two peripheral devices, each with its own 22-bit memory space, for a maximum size of 4 Mbytes per PIA region. The PIACS5–PIACS2 signals are not supported on the Am29202 microcontroller.

PIA Control Register 0/1 (PICT0/1, Address 80000020/24)

The PIA Control Register 0 (Figure 3) controls the access to PIA Regions 0 and 1 on the Am29202 microcontroller. The PIA Control Register 1 is not available on the Am29202 microcontroller, since this product does not support PIA Regions 2, 3, 4, or 5.

Bit 31: Input/Output Extend, Region 0 (IOEXT0)—If this bit is one, the end of a PIA access is extended by one cycle after PIAOE is deasserted or by two cycles after PIAWE is deasserted. This provides one additional cycle of output disable time or data hold time for reads and writes, respectively.

Bits 30–29: Reserved

Bits 28–24: Input/Output Wait States, Region 0 (IOWAIT0)—This field specifies the number of wait states taken by an access to PIA Region 0. An I/O read cycle takes at least three cycles (two wait states), and an I/O write cycle takes at least four cycles (three wait states). If the IOWAIT0 field specifies an insufficient number of wait states for an access (for example, IOWAIT0 = 00010b for a write), the processor takes the required minimum number of wait states instead of the specified number.

Other bits perform similar functions to IOEXT0 and IOWAIT0 for PIA Region 1.

Bits 15–0: Reserved. These bits are reserved on the Am29202 microcontroller and should be written with 0s to ensure compatibility.
DMA CONTROLLER

The Am29202 microcontroller supports two types of DMA transfers: internal and external transfers. Direct DMA transfers between an external device and DRAM using an address supplied by the external device are not supported on the Am29202 microcontroller since the GREQ and GACK pins are not available on this device.

Internal DMA transfers can be requested by the parallel port, serial port, and video interface. Each of these internal peripherals has a field in its control register for specifying which of the two DMA channels is to be used for the transfer. The DMA-enable field for the IEEE-1284-compliant parallel port is DMAMODE in the Advanced Parallel Control (APCT) Register.

External DMA transfers are requested by off-chip peripherals using DREQ1.

DMA Channel 0 (DMA0) is available to internal peripherals only. DMA Channel 1 (DMA1) can be requested by either internal or external peripherals.

The Am29200 microcontroller signals DREQ0, DACK0, GREQ, GACK, and TDMA are not supported on the Am29202 microcontroller.

DMA0 Control Register (DMCT0, Address 80000030)

The DMA0 Control Register (Figure 4) controls DMA Channel 0 on the Am29202 microcontroller. DMA Channel 0 on the Am29202 microcontroller is available for transfers between internal peripherals and DRAM only; external transfers are not supported.

Bits 31–24: Reserved

Bits 23–22: Data Width (DW)—This field indicates the width of the data transferred by the DMA channel, as follows:

<table>
<thead>
<tr>
<th>DW Value</th>
<th>DMA Transfer Width</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>32 bits</td>
</tr>
<tr>
<td>01</td>
<td>8 bits</td>
</tr>
<tr>
<td>10</td>
<td>16 bits</td>
</tr>
<tr>
<td>11</td>
<td>32 bits, address unchanged</td>
</tr>
</tbody>
</table>

The value DW=11 is used to repeatedly transfer a fixed pattern from a single DRAM location to a peripheral. For example, it can be used with the video shifter to display a blank area of a printed page without requiring that a memory buffer be allocated for the blank area.

Bits 21–10: Reserved

Bit 9: Transfer Up/Down (UD)—This bit controls the addressing of memory for the series of DMA transfers. If the UD bit is 1, the DMA address (in the DMA0 Address Register) is incremented after each transfer. If the UD bit is 0, the DMA address is decremented after each transfer. The amount by which the address is incremented or decremented is determined by the width of the transfer.

<table>
<thead>
<tr>
<th>DW Value</th>
<th>Address Increment/Decrement</th>
</tr>
</thead>
<tbody>
<tr>
<td>00 (32 bits)</td>
<td>+/- 4</td>
</tr>
<tr>
<td>01 (8 bits)</td>
<td>+/- 1</td>
</tr>
<tr>
<td>10 (16 bits)</td>
<td>+/- 2</td>
</tr>
<tr>
<td>11 (32 bits)</td>
<td>+/- 0</td>
</tr>
</tbody>
</table>

Bit 8: Read/Write (RW)—This bit controls whether the DMA transfer is to or from the DRAM. If the RW bit is 1, the DMA channel transfers data from the DRAM to the peripheral. If the RW bit is 0, the DMA channel transfers data from the peripheral to the DRAM.

Bit 7: Enable (EN)—This bit enables the DMA channel to perform transfers. A 1 enables transfers, and a 0 disables transfers.

Bit 6: Reserved

Bit 5: Count Terminate Enable (CTE)—This bit, when 1, causes the DMA channel to terminate the transfer when the DMACNT field of the DMA Count Register decrements past zero. If this bit is 0, the DMA transfer does not terminate, though the DMA channel still decrements the count after every transfer.

Bit 4: Queue Enable (QEN)—This bit, when 1, enables the DMA queuing feature (which is implemented only on DMA Channel 0). DMA queuing allows the DMA0 Address Register and DMA0 Count Register to be reloaded automatically at the end of a DMA transfer from the DMA0 Address Tail Register and the DMA0

![Figure 4. DMA0 Control Register](image-url)
Count Tail Register, respectively. Queuing permits a second transfer to start immediately after a first transfer has terminated, greatly reducing the response-time requirement for software to set up and start the second transfer. When this bit is 0, DMA queuing is disabled, and the DMA0 Address Register and DMA0 Count Register are set directly to initiate a transfer.

**Bits 3–1: Reserved**

**Bit 0: Count Terminate Interrupt (CTI)**—The CTI bit is used to report that the DMA channel has generated an interrupt because of count termination. If the CTE bit is one and the DMACNT field decrements past zero, the CTI bit is set and a processor interrupt occurs.

**DMA0 Address Register (DMAD0, Address 80000034)**

The DMA0 Address Register (Figure 5) contains the addresses for a transfer by DMA Channel 0.

**Bits 31–24: Reserved**

**Bits 23–0: DRAM Address (DRAMADDR)**—This field contains the DRAM address for the next DMA transfer to or from the DRAM. The DRAMADDR field is incremented or decremented (based on the UD bit) by an amount determined by the width of the DMA transfer. The increment or decrement amount is 1 for a byte transfer, 2 for a halfword transfer, and 4 for a word transfer. To support repeated transfers from the same word, the address can be left unchanged.

The DRAMADDR field wraps from the value 000000h to FFFFFFFh when decremented and from FFFFFFFh to 000000h when incremented. Addresses must be aligned with the data width of the transfer.

**DMA1 Control Register (DMCT1, Address 80000040)**

DMA1 Control Register (Figure 6) controls DMA Channel 1. Queuing is not implemented on DMA Channel 1.

**Bit 31: DMA Extend (DMAEXT)**—The DMAEXT bit serves a function very similar to the IOEXTx bits in the PIA Control registers. This bit is set to provide an additional cycle of output disable time for a read or an additional cycle of data hold time for a write.

**Bits 30–29: Reserved**

**Bits 28–24: DMA Wait States (DMAWAIT)**—This field specifies the number of wait states taken by an external access by DMA Channel 1. An external DMA read cycle takes at least three cycles (two wait states) and an external DMA write cycle takes at least four cycles (three wait states). If the DMAWAIT field specifies an insufficient number of wait states for an access (for example, DMAWAIT = 00010b for a write), the processor takes the required minimum number of wait states instead of the specified number.

**Bits 23–22: Data Width (DW)**—This field indicates the width of the data transferred by the DMA channel, as follows:

<table>
<thead>
<tr>
<th>DW Value</th>
<th>DMA Transfer Width</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>32 bits</td>
</tr>
<tr>
<td>01</td>
<td>8 bits</td>
</tr>
<tr>
<td>10</td>
<td>16 bits</td>
</tr>
<tr>
<td>11</td>
<td>32 bits, address unchanged</td>
</tr>
</tbody>
</table>

The value DW=11 is used to repeatedly transfer a fixed pattern from a single DRAM location to a peripheral.

**Bits 21–20: DMA Request Mode (DRM)**—This field indicates how external DMA requests are signaled by DREQ1, as follows:

<table>
<thead>
<tr>
<th>DRM Value</th>
<th>DREQ1 Request</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>Active Low</td>
</tr>
<tr>
<td>01</td>
<td>Active High</td>
</tr>
<tr>
<td>10</td>
<td>High-to-Low transition</td>
</tr>
<tr>
<td>11</td>
<td>Low-to-High transition</td>
</tr>
</tbody>
</table>

The DRM field is set to 00 by a processor reset.
Bit 19: Assert Chip Select (ACS)—This bit controls whether DMA Channel 1 asserts PIACS1 during an external peripheral access. If the ACS bit is 1, the DMA channel asserts PIACS1; if the ACS bit is 0, the DMA channel does not assert PIACS1.

Bits 18–10: Reserved

Bit 9: Transfer Up/Down (UD)—This bit controls the addressing of memory for the series of DMA transfers. If the UD bit is 1, the DMA address (in the DMA1 Address Register) is incremented after each transfer. If the UD bit is 0, the DMA address is decremented after each transfer. The amount by which the address is incremented or decremented is determined by the width of the transfer, as follows:

<table>
<thead>
<tr>
<th>DW Value</th>
<th>Address Increment/Decrement</th>
</tr>
</thead>
<tbody>
<tr>
<td>00 (32 bits)</td>
<td>+/- 4</td>
</tr>
<tr>
<td>01 (8 bits)</td>
<td>+/- 1</td>
</tr>
<tr>
<td>10 (16 bits)</td>
<td>+/- 2</td>
</tr>
<tr>
<td>11 (32 bits)</td>
<td>+/- 0</td>
</tr>
</tbody>
</table>

Bit 8: Read/Write (RW)—This bit controls whether DMA transfer is to or from the DRAM. If the RW bit is 1, the DMA channel transfers data from the DRAM to the peripheral. If the RW bit is 0, the DMA channel transfers data from the peripheral to the DRAM.

Bit 7: Enable (EN)—This bit enables the DMA channel to perform transfers. A 1 enables transfers, and a 0 disables transfers.

Bit 6: Reserved

Bit 5: Count Terminate Enable (CTE)—This bit, when 1, causes the DMA channel to terminate the transfer when the DMACNT field of the DMA Count Register decrements past zero. If this bit is 0, the CTE field does not terminate the DMA transfer, though the DMA channel still decrements the count after every transfer.

Bits 4–1: Reserved

Bit 0: Count Terminate Interrupt (CTI)—The CTI bit is used to report that the DMA channel has generated an interrupt because of count termination. If the CTE bit is one and the DMACNT field decrements past zero, the CTI bit is set and a processor interrupt occurs.
PROGRAMMABLE I/O PORT

The I/O port permits direct programmable access of up to twelve external PIO signals, as either inputs, outputs, or open-drain outputs. When used as inputs, eight of these signals, PIO15–PIO8, can be programmed to cause edge- or level-sensitive interrupts. The Am29202 microcontroller supports PIO signals PIO15–PIO4.

Four PIO signals (PIO7–PIO4) are shared with the IEEE-1284-compliant parallel port interface. The access to these additional IEEE-1284-specific input and output signals is controlled by the parallel port. To use REVOE and DATASTROBE as outputs and SELECTIN and INIT as inputs, the POCT, PIN, POUT, and POEN registers must be configured before the parallel interface is enabled.

When the parallel port is enabled, it has control of the shared signals. The I/O port has control of the lines when the parallel port is not enabled or after a processor reset. The I/O port signals may be read at any time, irrespective of the parallel port ownership of those signals.

PIO Control Register (POCT, Address 800000D0)

The PIO Control Register (Figure 7) controls interrupt generation and determines the polarity of PIO15–PIO4. Note that IRM15, value 11 is now reserved; it cannot be used to signal a change in the parallel port configuration to the host.

Bits 31–30: Interrupt Request Mode, PIO15 (IRM15)—This field enables PIO15 to generate an interrupt and indicates whether PIO15 is level- or edge-sensitive in generating the interrupt. The IRM15 field controls PIO15 as follows:

<table>
<thead>
<tr>
<th>IRM15 Value</th>
<th>PIO15 Interrupt</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>Interrupt disabled</td>
</tr>
<tr>
<td>01</td>
<td>Level-sensitive</td>
</tr>
<tr>
<td>10</td>
<td>Edge-sensitive</td>
</tr>
<tr>
<td>11</td>
<td>Reserved</td>
</tr>
</tbody>
</table>

The INVERT field (see below) further conditions interrupt generation. If the INVERT bit for PIO15 is 0, an interrupt, if enabled, is generated by a High level on PIO15 (level-sensitive) or on a Low-to-High transition (edge-sensitive) of PIO15. If the INVERT bit for PIO15 is 1, an interrupt, if enabled, is generated by a Low level on PIO15 (level-sensitive) or on a High-to-Low transition (edge-sensitive) of PIO15.

Bits 29–16: IRM14 through IRM8—The IRM14–IRM8 fields enable interrupts and specify level- or edge-sensitivity for PIO14–PIO8, respectively. These fields are identical in definition to IRM15.

Bits 15–4: PIO Inversion (INVERT)—This field determines how the level on each PIO signal is reflected in the PIO Input and PIO Output Registers, and how interrupts are generated. The most significant bit of the INVERT field determines the sense of PIO15, the next bit determines the sense of PIO14, and so on. A 0 in this field causes the internal and external sense of the respective PIO signal to be noninverted; a High external level is reflected as a 1 internally, and a Low is reflected as a 0 internally. A 1 in this field causes the internal and external sense of the respective PIO signal to be inverted; a High external level is reflected as a 0 internally, and a Low is reflected as a 1 internally.

Bits 3–0: Reserved. These bits are reserved on the Am29202 microcontroller and should be written with 0s to ensure compatibility.

Figure 7. PIO Control Register
PIO Input Register  
(PIN, Address 800000D4)

The PIO Input Register (Figure 8) reflects the external levels of PIO15–PIO4.

**Bits 31–16: Reserved**

**Bits 15–4: PIO Input (PIN)—**This field reflects the levels on each PIO signal. The most significant bit of the PIN field reflects the level on PIO15, the next bit reflects the level on PIO14, and so on. The correspondence between levels and bits in this register is controlled by the INVERT field.

**Bits 3–0: Reserved.** These bits are reserved on the Am29202 microcontroller and will be read as 0s.

PIO Output Register  
(POUT, Address 800000D8)

The PIO Output Register (Figure 9) determines the levels driven on the PIO signals, for those signals enabled to be driven by the PIO Output Enable Register.

**Bits 31–16: Reserved**

**Bits 15–4: PIO Output (POUT)—**This field determines the levels on each PIO signal, if so enabled by the PIO Output Enable Register. The most significant bit of the POUT field determines the level on PIO15, the next bit determines the level on PIO14, and so on. The correspondence between levels and bits in this register is controlled by the INVERT field.

**Bits 3–0: Reserved.** These bits are reserved on the Am29202 microcontroller and should be written with 0s to ensure compatibility.

PIO Output Enable Register  
(POEN, Address 800000DC)

The PIO Output Enable Register (Figure 10) determines whether or not the PIO signals are driven as outputs.

**Bits 31–16: Reserved**

**Bits 15–4: PIO Output Enable (POEN)—**This field determines whether each PIO signal is driven as an output. The most significant bit of the POEN field determines whether PIO15 is driven, the next bit determines whether PIO14 is driven, and so on. A 1 in a bit position enables the respective signal to be driven according to the associated POUT and INVERT bits, and a 0 disables the signal as an output.

**Bits 3–0: Reserved.** These bits are reserved on the Am29202 microcontroller and should be written with 0s to ensure compatibility.
SERIAL PORT

The on-chip serial port is a UART that permits full-duplex, bidirectional data transfer using the RS-232 standard. Serial port registers provide a programmable baud rate generator, odd/even parity capability, choice of word length, a test mode, and DMA access.

The operations of the serial port are similar on the Am29200 and Am29202 microcontrollers, except that the DSR and DTR handshake signals are not available on the Am29202 microcontroller. These functions, if needed, can be recreated with available PIO signals.

Serial Port Control Register
(SPCT, Address 80000080)

The Serial Port Control Register (Figure 11) controls both the transmit and receive sections of the serial port.

**Bits 31–27: Reserved**

**Bit 26: Loopback (LOOP)—**Setting this bit places the serial port in the loopback mode. In this mode, the TXD output is set High and the Transmit Shift Register is connected to the Receive Shift Register. Data transmitted by the transmit section is immediately received by the receive section. The loopback mode is provided for testing the serial port.

**Bit 25: Send Break (BRK)—**Setting this bit causes the serial port to send a break, which is a continuous Low level on the TXD output for a duration of more than one frame transmission time. The transmitter can be used to time the frame by setting the BRK bit when the transmitter is empty (indicated by the TEMT bit of the Serial Port Status Register), writing the Serial Port Transmit Holding Register with data to be transmitted, and then waiting until the TEMT bit is set again before resetting the BRK bit.

**Bits 24–22: Reserved**

**Bits 21–19: Parity Mode (PMODE)—**This field specifies how parity generation and checking are performed during transmission and reception (the value “x” is a don’t care):

<table>
<thead>
<tr>
<th>PMODE Value</th>
<th>Parity Generation and Checking</th>
</tr>
</thead>
<tbody>
<tr>
<td>0xx</td>
<td>No parity bit in frame</td>
</tr>
<tr>
<td>100</td>
<td>Odd parity (odd number of 1s in frame)</td>
</tr>
<tr>
<td>101</td>
<td>Even parity (even number of 1s in frame)</td>
</tr>
<tr>
<td>110</td>
<td>Parity forced/checked as 1</td>
</tr>
<tr>
<td>111</td>
<td>Parity forced/checked as 0</td>
</tr>
</tbody>
</table>

**Bit 18: Stop Bits (STP)—**A 0 in this bit specifies that one stop bit is used to signify the end of a frame. A 1 in this bit specifies that two stop bits are used to signify the end of a frame.

**Bits 17–16: Word Length (WLGN)—**This field indicates the number of data bits transmitted or received in a frame, as follows:

<table>
<thead>
<tr>
<th>WLGN Value</th>
<th>Word Length</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>5 bits</td>
</tr>
<tr>
<td>01</td>
<td>6 bits</td>
</tr>
<tr>
<td>10</td>
<td>7 bits</td>
</tr>
<tr>
<td>11</td>
<td>8 bits</td>
</tr>
</tbody>
</table>

Data words of less than eight bits are right-justified in the Transmit Holding Register and Receive Buffer Register.

**Bits 15–10: Reserved**

**Bits 9–8: Transmit Mode (TMODE)—**This field enables data transmission and controls the operational mode of the serial port for the transmission of data, as follows:

<table>
<thead>
<tr>
<th>TMODE Value</th>
<th>Effect on Transmit Section</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>Disabled</td>
</tr>
<tr>
<td>01</td>
<td>Generate interrupt requests for service</td>
</tr>
<tr>
<td>10</td>
<td>Generate DMA Channel 0 requests</td>
</tr>
<tr>
<td>11</td>
<td>Generate DMA Channel 1 requests</td>
</tr>
</tbody>
</table>

Requests for service are requests to write the Transmit Holding Register with data to be transmitted. Placing the transmit section into the disabled state causes all internal state machines to be reset and holds the transmit section in an idle state with TXD High. Serial port programmable registers are not affected when the transmit section is disabled.

**Bits 7–3: Reserved**

**Bit 2: Receive Status Interrupt Enable (RSIE)—**This bit enables the serial port to generate an interrupt because of an exception during reception. If this bit is 1 and the serial port receives a break or experiences a framing error, parity error, or overrun error, the serial port generates a Receive Status interrupt.
Bits 1–0: Receive Mode (RMODE)—This field enables data reception and controls the operational mode of the serial port for the reception of data:

<table>
<thead>
<tr>
<th>RMODE Value</th>
<th>Effect on Receive Section</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>Disabled</td>
</tr>
<tr>
<td>01</td>
<td>Generate interrupt requests for service</td>
</tr>
<tr>
<td>10</td>
<td>Generate DMA Channel 0 requests</td>
</tr>
<tr>
<td>11</td>
<td>Generate DMA Channel 1 requests</td>
</tr>
</tbody>
</table>

Requests for service are requests to read data from the Receive Buffer Register. Placing the receive section into the disabled state causes all internal state machines to be reset and holds the receive section in an idle state. Serial port programmable registers are not affected when the receive section is disabled.

Serial Port Status Register (SPST, Address 80000084)
The Serial Port Status Register (Figure 12) indicates the status of the transmit and receive sections of the port.

Bits 31–11: Reserved

Bit 10: Transmitter Empty (TEMT)—This bit is 1 when the transmitter has no data to transmit and the Transmit Shift Register is empty. This indicates to software that it is safe to disable the transmit section.

Bit 9: Transmit Holding Register Empty (THRE) When the THRE bit is 1, the Transmit Holding Register does not contain valid data and can be written with data to be transmitted. When the THRE bit is 0, the Transmit Holding Register contains valid data not yet copied to the Transmit Shift Register for transmission and cannot be written. If so enabled by the TMODE field, the THRE bit causes an interrupt or DMA request when it is set. The THRE bit is reset automatically by writing the Transmit Holding Register. This bit is read-only, allowing other bits of the Serial Port Status Register to be written (for example, resetting the BRKI bit) without interfering with the data request.

Bit 8: Receive Data Ready (RDR)—When the RDR bit is 1, the Receive Buffer Register contains data that has been received on the serial port, and can be read to obtain the data. When the RDR bit is 0, the Receive Buffer Register does not contain valid data. If so enabled by the RMODE field, the RDR bit causes an interrupt or DMA request when it is set. The RDR bit is reset automatically by reading the Receive Buffer Register.

Bits 7–4: Reserved

Bit 3: Break Interrupt (BRKI)—The BRKI bit is set to indicate that a break has been received. If the RSIE bit is 1, the BRKI bit being set causes a Receive Status interrupt. The BRKI bit should be reset by the Receive Status interrupt handler.

Bit 2: Framing Error (FER)—This bit is set to indicate that a framing error occurred during reception of data. If the RSIE bit is 1, the FER bit being set causes a Receive Status interrupt. The FER bit should be reset by the Receive Status interrupt handler.

Bit 1: Parity Error (PER)—This bit is set to indicate that a parity error occurred during reception of data. If the RSIE bit is 1, the PER bit being set causes a Receive Status interrupt. The PER bit should be reset by the Receive Status interrupt handler.

Bit 0: Overrun Error (OER)—This bit is set to indicate that an overrun error occurred during reception of data. If the RSIE bit is 1, the OER bit being set causes a Receive Status interrupt. The OER bit should be reset by the Receive Status interrupt handler.
INTERRUPTS AND TRAPS

The Am29202 microcontroller employs a lightweight interrupt and trap facility that does not automatically save its current state in memory. Saving and restoring state information is under software control. Interrupts and traps are dispatched using a vector table that can be relocated in memory (see Table 4).

External traps, WARN, INTR3, and INTR1 are not supported on the Am29202 microcontroller. PIO signals can be used as additional interrupts when more inputs are required. Two new bits are defined in the Interrupt Control Register to support the IEEE-1284 parallel port.

Current Processor Status Register (CPS, Register 2)

This protected special-purpose register (see Figure 13) controls the behavior of the processor and its ability to recognize exceptional events. The IM field values have changed for the Am29202 microcontroller.

Bits 31–18: Reserved

Bit 17: Timer Disable (TD)—When the TD bit is 1, the Timer interrupt is disabled. When this bit is 0, the Timer interrupt depends on the value of the IE bit of the Timer Reload Register. Note that Timer interrupts may be disabled by the DA bit regardless of the value of either TD or IE. The intent of this bit is to provide a means of disabling Timer interrupts without having to perform a non-atomic read-modify-write operation on the Timer Reload Register.

Bits 16–15: Reserved

Bit 14: Interrupt Pending (IP)—This bit allows software to detect the presence of interrupts while the interrupts are disabled. The IP bit is set if an interrupt request is active, but the processor is disabled from taking the resulting interrupt due to the value of the DA, DI, or IM bits. If all interrupt requests are subsequently deactivated while still disabled, the IP bit is reset.

Bits 13–12: Trace Enable, Trace Pending (TE, TP)—The TE and TP bits implement a software-controlled, instruction single-step facility. Single stepping is not implemented directly, but rather emulated by trap sequences controlled by these bits. The value of the TE bit is copied to the TP bit whenever an instruction completes execution. When the TP bit is 1, a Trace trap occurs.

Bit 11: Trap Unaligned Access (TU)—The TU bit enables checking of address alignment for external data-memory accesses. When this bit is 1, an Unaligned Access trap occurs if the processor either generates an address for an external word not aligned on a word-address-boundary (i.e., either of the least significant two bits is 1) or generates an address for an external half-word not aligned on a half-word address boundary (i.e., the least significant address bit is 1). When the TU bit is 0, data-memory address alignment is ignored.

Alignment is ignored for input/output accesses. The alignment of instruction addresses is also ignored (unaligned instruction addresses can be generated only by indirect jumps). Interrupt/trap vector addresses always are aligned properly by the processor.

Bit 10: Freeze (FZ)—The FZ bit prevents certain registers from being updated during interrupt and trap processing, except by explicit data movement. The affected registers are: Channel Address, Channel Control, Program Counter 0, Program Counter 1, Program Counter 2, and the ALU Status Register.

When the FZ bit is 1, these registers hold their values. An affected register can be changed only by a Move-To-Special-Register instruction. When the FZ bit is 0, there is no effect on these registers and they are updated by processor instruction execution as described in this manual.

The FZ bit is set whenever an interrupt or trap is taken, holding critical state in the processor so it is not modified unintentionally by the interrupt or trap handler.

If the Freeze (FZ) bit of the Current Processor Status Register is reset from 1 to 0, two cycles are required before all program state is reflected properly in the registers affected by the FZ bit. This implies that interrupts and traps cannot be enabled until two cycles after the FZ bit is reset for proper sequencing of program state. There is no delay associated with setting the FZ bit from 0 to 1.

Bits 9–8: Reserved
Bit 7: Wait Mode (WM)—The WM bit places the processor in the Wait mode. When this bit is 1, the processor performs no operations. The Wait mode is reset by an interrupt or trap for which the processor is enabled, or by the assertion of the RESET pin.

Bits 6–5: Reserved

Bit 4: Supervisor Mode (SM)—The SM bit protects certain processor context, such as protected special-purpose registers. When this bit is 1, the processor is in the Supervisor mode and access to all processor context is allowed. When this bit is 0, the processor is in the User mode and access to protected processor context is not allowed. An attempt to access (either read or write) protected processor context causes a Protection Violation trap.

Bits 3–2: Interrupt Mask (IM)—The IM field is an encoding of the processor priority with respect to external interrupts. The interpretation of the interrupt mask is specified as follows:

<table>
<thead>
<tr>
<th>IM Value</th>
<th>Result</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>INTR0 enabled</td>
</tr>
<tr>
<td>01</td>
<td>INTR0 enabled</td>
</tr>
<tr>
<td>10</td>
<td>INTR2 and INTR0 enabled</td>
</tr>
<tr>
<td>11</td>
<td>INTR2, INTR0, and internal peripheral interrupts enabled</td>
</tr>
</tbody>
</table>

Note that the INTR0 interrupt cannot be disabled by the IM field.

Bit 1: Disable Interrupts (DI)—The DI bit prevents the processor from being interrupted by internal peripheral requests and by external interrupt requests INTR2 and INTR0. When this bit is 1, the processor ignores all internal and external interrupts. However, internal traps, Timer interrupts, and Trace traps may be taken. When this bit is 0, the processor takes any interrupt enabled by the IM field, unless the DA bit is 1.

Bit 0: Disable All Interrupts and Traps (DA)—The DA bit prevents the processor from taking any interrupts and most traps. When this bit is 1, the processor ignores interrupts and traps. When the DA bit is 0, all traps are taken; interrupts are taken if otherwise enabled.

Interrupt Control Register (ICT, Address 80000028)

Two new bits, APDI and APCI, have been added to Interrupt Control Register (Figure 14) to support the IEEE-1284-compliant parallel port. The APDI interrupt occurs when a hardware handshake-supported data transfer mode receives (or is ready to transmit) a data byte and when interrupts are desired instead of DMA. The APCI interrupt occurs for a variety of combined mask-selectable events requiring processor intervention, such as mode changes and status input. Semi-automatic and manual modes utilize APCI interrupts for some phase transitions, including data handling.

Bits 31–28: Reserved

Bit 27: Video Interrupt (VDI)—A 1 in this bit indicates the video interface has generated an interrupt request.

Bits 26–24: Reserved

Bits 23–16: I/O Port Interrupt (IOPI)—A 1 in this field indicates the respective PIO signal has generated an interrupt request. A 1 in the most significant bit of the IOPI field indicates PIO15 has caused an interrupt, the next bit indicates PIO14 has caused an interrupt, and so on.

Bit 15: Reserved

Bit 14: DMA Channel 0 Interrupt (DMA0I)—A 1 in this bit indicates DMA Channel 0 has generated an interrupt request.

Bit 13: DMA Channel 1 Interrupt (DMA1I)—A 1 in this bit indicates DMA Channel 1 has generated an interrupt request.

Bit 12: Advanced Parallel Port Data Transfer Interrupt (APDI)—A 1 in this bit indicates that the IEEE-1284 parallel port interface is requesting a data transfer.

Writing a 1 to the APDS clears the data transfer request status that caused the APDI. This is usually not necessary, because a read or write (whichever is appropriate in a particular mode) to the Advanced Parallel Data Reg-

---

"Figure 14. Interrupt Control Register"
Register automatically clears the APDS condition. Clearing the APDI bit when the DMAMODE bit in the APCT Register is set is undefined and not recommended.

**Bit 11: Advanced Parallel Port Control Condition Interrupt (APCI)**—A 1 in this bit indicates that the IEEE-1284 parallel port interface has detected a valid control condition.

This bit is the OR of all the control condition interrupt bits in the APIS register, (ECI, DEVINITI, INITLHI, INITLHI, SELINHLI, SELINLHI, PAUTOHLI, PAUTOLHI, PSTBHL and PSTBLHI), which are in turn masked from the control condition bits in the APST register. The APCI bit must be cleared separately from the bit or bits that caused the APCI interrupt.

Writing a 1 to any of the control status bits in the APST Register or to the interrupt bits in the APIS Register will clear the condition that caused the interrupt (if masked). All of the bits require such a condition clear action, except for the device initialization interrupt: It is cleared when the parallel port interface is returned to IEEE-1284 Compatibility mode.

**Bits 10–8: Reserved**

**Bit 7: Serial Port Receive Status Interrupt (RXSI)**—A 1 in this bit indicates the serial port has generated an interrupt request because of the status of the receive logic.

**Bit 6: Serial Port Receive Data Interrupt (RXDI)**—A 1 in this bit indicates the serial port has generated an interrupt request because receive data is ready.

**Bit 5: Serial Port Transmit Data Interrupt (TXDI)**—A 1 in this bit indicates the serial port has generated an interrupt request because the Transmit Holding Register is empty.

**Bits 4–0: Reserved**

**Vector Numbers**

When an interrupt or trap is taken, the processor determines an 8-bit vector number associated with the interrupt or trap. The vector number gives the number of a vector table entry. The physical address of the vector table entry is generated by replacing bits 9–2 of the value in the Vector Area Base Address Register with the vector number.

Vector numbers are either predefined or specified by an instruction causing the trap. The assignment of vector numbers is shown in Table 4 (vector numbers are in decimal notation).

An Unsupported Peripheral Address trap has been added for the Am29202 microcontroller. A vector 6 trap will occur for accesses to peripheral addresses other than those listed in Table 2.
### Table 4. Vector Number Assignments

<table>
<thead>
<tr>
<th>Number</th>
<th>Type of Trap or Interrupt</th>
<th>Cause</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Illegal Opcode</td>
<td>Executing undefined instruction(^1)</td>
</tr>
<tr>
<td>1</td>
<td>Unaligned Access</td>
<td>Access on unnatural boundary, TU = 1</td>
</tr>
<tr>
<td>2</td>
<td>Out-of-Range</td>
<td>Overflow or underflow</td>
</tr>
<tr>
<td>3–4</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>Protection Violation</td>
<td>Invalid User-mode operation(^2)</td>
</tr>
<tr>
<td>6</td>
<td>Unsupported Peripheral Address</td>
<td>Access to unsupported address</td>
</tr>
<tr>
<td>7</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>User Instruction Mapping Miss</td>
<td>No DRAM mapping for access</td>
</tr>
<tr>
<td>9</td>
<td>User Data Mapping Miss</td>
<td>No DRAM mapping for access</td>
</tr>
<tr>
<td>10</td>
<td>Supervisor Instruction Mapping Miss</td>
<td>No DRAM mapping for access</td>
</tr>
<tr>
<td>11</td>
<td>Supervisor Data Mapping Miss</td>
<td>No DRAM mapping for access</td>
</tr>
<tr>
<td>12–13</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>Timer</td>
<td>Timer Facility</td>
</tr>
<tr>
<td>15</td>
<td>Trace</td>
<td>Trace Facility</td>
</tr>
<tr>
<td>16</td>
<td>INTR0</td>
<td>INTR0 input</td>
</tr>
<tr>
<td>17</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>18</td>
<td>INTR2</td>
<td>INTR2 input</td>
</tr>
<tr>
<td>19</td>
<td>Internal</td>
<td>Internal peripheral</td>
</tr>
<tr>
<td>20–21</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>22</td>
<td>Floating-Point Exception</td>
<td>Unmasked floating-point exception(^3)</td>
</tr>
<tr>
<td>23</td>
<td>Reserved</td>
<td></td>
</tr>
<tr>
<td>24–29</td>
<td>Reserved for instruction emulation (opcodes D8–DD)</td>
<td></td>
</tr>
<tr>
<td>30</td>
<td>MULTM</td>
<td>MULTM instruction</td>
</tr>
<tr>
<td>31</td>
<td>MULTMU</td>
<td>MULTMU instruction</td>
</tr>
<tr>
<td>32</td>
<td>MULTIPLY</td>
<td>MULTIPLY instruction</td>
</tr>
<tr>
<td>33</td>
<td>DIVIDE</td>
<td>DIVIDE instruction</td>
</tr>
<tr>
<td>34</td>
<td>MULTIPLU</td>
<td>MULTIPLU instruction</td>
</tr>
<tr>
<td>35</td>
<td>DIVIDU</td>
<td>DIVIDU instruction</td>
</tr>
<tr>
<td>36</td>
<td>CONVERT</td>
<td>CONVERT instruction</td>
</tr>
<tr>
<td>37</td>
<td>SQRT</td>
<td>SQRT instruction</td>
</tr>
<tr>
<td>38</td>
<td>CLASS</td>
<td>CLASS instruction</td>
</tr>
<tr>
<td>39–41</td>
<td>Reserved for instruction emulation (opcode E7–E9)</td>
<td></td>
</tr>
<tr>
<td>42</td>
<td>FEQ</td>
<td>FEQ instruction</td>
</tr>
<tr>
<td>43</td>
<td>DEQ</td>
<td>DEQ instruction</td>
</tr>
<tr>
<td>44</td>
<td>FGT</td>
<td>FGT instruction</td>
</tr>
<tr>
<td>45</td>
<td>DGT</td>
<td>DGT instruction</td>
</tr>
<tr>
<td>46</td>
<td>FGE</td>
<td>FGE instruction</td>
</tr>
<tr>
<td>47</td>
<td>DGE</td>
<td>DGE instruction</td>
</tr>
<tr>
<td>48</td>
<td>FADD</td>
<td>FADD instruction</td>
</tr>
<tr>
<td>49</td>
<td>DADD</td>
<td>DADD instruction</td>
</tr>
<tr>
<td>50</td>
<td>FSUB</td>
<td>FSUB instruction</td>
</tr>
<tr>
<td>51</td>
<td>DSUB</td>
<td>DSUB instruction</td>
</tr>
<tr>
<td>52</td>
<td>FMUL</td>
<td>FMUL instruction</td>
</tr>
</tbody>
</table>

**Notes:**

1. This vector number also results if an external device removes INTR\(^x\) before the corresponding interrupt or trap is taken by the processor.

2. Some Supervisor-mode operations cause Protection Violations to facilitate virtualization of certain operations.

3. The Floating-Point Exception trap is not generated by the processor hardware. It is generated by the software that implements the virtual arithmetic interface.
Table 4. Vector Number Assignments (continued)

<table>
<thead>
<tr>
<th>Number</th>
<th>Type of Trap or Interrupt</th>
<th>Cause</th>
</tr>
</thead>
<tbody>
<tr>
<td>53</td>
<td>DMUL</td>
<td>DMUL instruction</td>
</tr>
<tr>
<td>54</td>
<td>FDIV</td>
<td>FDIV instruction</td>
</tr>
<tr>
<td>55</td>
<td>DDIV</td>
<td>DDIV instruction</td>
</tr>
<tr>
<td>56</td>
<td>Reserved for instruction emulation</td>
<td></td>
</tr>
<tr>
<td></td>
<td>(opcode F8)</td>
<td></td>
</tr>
<tr>
<td>57</td>
<td>FDMUL</td>
<td>FDMUL instruction</td>
</tr>
<tr>
<td>58–63</td>
<td>Reserved for instruction emulation</td>
<td></td>
</tr>
<tr>
<td></td>
<td>(opcode FA–FF)</td>
<td></td>
</tr>
<tr>
<td>64–255</td>
<td>ASSERT and EMULATE instruction traps</td>
<td>See Note 4</td>
</tr>
<tr>
<td></td>
<td>(vector number specified by instruction)</td>
<td></td>
</tr>
</tbody>
</table>

Notes: (continued)
4. Some of Vector Numbers 64–255 are reserved for software compatibility. These are documented in the Host Interface (HIF) Specification (order# 11539) available from AMD.

Sequencing of Interrupts and Traps
To resolve conflicts, interrupts and traps are taken according to the priority shown in Table 5. In this table, interrupts and traps are listed in order of decreasing priority. Interrupts and traps fall into one of two categories depending on the timing of their occurrence relative to instruction execution. The column labels Inst and Async have the following meanings:

- Inst—Generated by the execution or attempted execution of an instruction.
- Async—Generated asynchronous to and independent of the instruction being executed, although it may be a result of an instruction executed previously.

The principle for interrupt and trap sequencing is that the highest priority interrupt or trap is taken first. Other interrupts and traps either remain active until they can be taken or they are regenerated when they can be taken. This is accomplished depending on the type of interrupt or trap, as follows:

1. All traps in Table 5 with priority 8 or 9 are regenerated by the re-execution of the causing instruction.
2. Most of the interrupts and traps of priority 3 through 7 must be held by external hardware until they are taken. The exceptions to this are listed in item 3.
3. The exceptions to item 2 are the Timer interrupt and the Trace trap. These are caused by bits in various registers in the processor and are held by these registers until taken or cleared. The two relevant bits are the Interrupt (IN) bit of the Timer Reload Register for Timer interrupts and the Trace Pending (TP) bit of the Current Processor Status Register for Trace traps.
4. All traps of priority 1 and 2 in Table 5, except for the Unaligned Access trap, are not regenerated. These traps are mutually exclusive and are given high priority because they cannot be regenerated: They must be taken if they occur. If one of these traps occurs at the same time as a reset, it is not taken and its occurrence is lost.
5. The Unaligned Access trap is regenerated internally when an external access is restarted by the Channel Address, Channel Data, and Channel Control registers. Note that this trap is not necessarily exclusive to the traps discussed in item 4 above.

Exception Reporting and Restarting
The PC1 column in Table 5 describes the value held in the Program Counter 1 Register (PC1) when the interrupt or trap is taken. For traps in the Inst category, PC1 contains either the address of the instruction causing the trap, indicated by Curr, or the address of the instruction following the instruction causing the trap, indicated by Next.

For interrupts and traps in the Async category, PC1 contains the address of the first instruction not executed due to the taking of the interrupt or trap. This is the next instruction to be executed upon interrupt return, as indicated by Next in the PC1 column.
<table>
<thead>
<tr>
<th>Priority</th>
<th>Type of Interrupt or Trap</th>
<th>Inst/Async</th>
<th>PC1</th>
<th>Channel Regs</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>User-Mode Data Mapping Miss</td>
<td>Inst</td>
<td>Next</td>
<td>All</td>
</tr>
<tr>
<td></td>
<td>Supervisor-Mode Data Mapping Miss</td>
<td>Inst</td>
<td>Next</td>
<td>All</td>
</tr>
<tr>
<td></td>
<td>Unsupported Peripheral Address</td>
<td>Inst</td>
<td>Next</td>
<td>All</td>
</tr>
<tr>
<td>2</td>
<td>Unaligned Access</td>
<td>Inst</td>
<td>Next</td>
<td>All</td>
</tr>
<tr>
<td></td>
<td>Out-of-Range</td>
<td>Inst</td>
<td>Next</td>
<td>N/A</td>
</tr>
<tr>
<td></td>
<td>Assert Instructions</td>
<td>Inst</td>
<td>Next</td>
<td>N/A</td>
</tr>
<tr>
<td></td>
<td>Floating-Point Instructions</td>
<td>Inst</td>
<td>Next</td>
<td>N/A</td>
</tr>
<tr>
<td></td>
<td>Integer Multiply/Divide Instructions</td>
<td>Inst</td>
<td>Next</td>
<td>N/A</td>
</tr>
<tr>
<td></td>
<td>EMULATE</td>
<td>Inst</td>
<td>Next</td>
<td>N/A</td>
</tr>
<tr>
<td>3</td>
<td>INTR0</td>
<td>Async</td>
<td>Next</td>
<td>Multiple</td>
</tr>
<tr>
<td>4</td>
<td>INTR2</td>
<td>Async</td>
<td>Next</td>
<td>Multiple</td>
</tr>
<tr>
<td>5</td>
<td>Internal peripheral interrupts</td>
<td>Async</td>
<td>Next</td>
<td>Multiple</td>
</tr>
<tr>
<td>6</td>
<td>Timer</td>
<td>Async</td>
<td>Next</td>
<td>Multiple</td>
</tr>
<tr>
<td>7</td>
<td>Trace</td>
<td>Async</td>
<td>Next</td>
<td>Multiple</td>
</tr>
<tr>
<td>8</td>
<td>User-mode Inst Mapping Miss</td>
<td>Inst</td>
<td>Curr</td>
<td>N/A</td>
</tr>
<tr>
<td></td>
<td>Supervisor-mode Inst Mapping Miss</td>
<td>Inst</td>
<td>Curr</td>
<td>N/A</td>
</tr>
<tr>
<td>9</td>
<td>Illegal Opcode</td>
<td>Inst</td>
<td>Curr</td>
<td>N/A</td>
</tr>
<tr>
<td></td>
<td>Protection Violation</td>
<td>Inst</td>
<td>Curr</td>
<td>N/A</td>
</tr>
</tbody>
</table>

Table 5. Interrupt and Trap Priority Table
DEBUGGING AND TESTING

The Am29202 microcontroller provides debugging and testing features at both the hardware and software levels. Instruction tracing and instruction breakpoints are supported. However, the processor status outputs STAT2–STAT0 are not available on the Am29202 microcontroller.

A JTAG-compliant test access port facilitates system testing in a production environment. A new main data scan path for the Am29202 microcontroller is provided below. The ICTEST1 and ICTEST2 data paths are unchanged.

Main Data Path

Table 6 shows a 160-cell path used to access the processor pins. This path is divided into five sets of cells. Where applicable, each set has a cell that enables the outputs of the set to be driven on the processor’s pins. These cells are not connected to a processor pin. Some of these cells affect outputs not normally enabled and disabled during normal system operation.

The sets of cells are divided logically as follows: 1) clocks, requests, and reset, 2) miscellaneous peripheral control signals, 3) memory and peripheral controls, 4) instruction/data bus. Note that the GREQ, GACK, STAT2–STAT0, R/W, and TR pins are included in the main scan path for special emulation devices only; these external pins are not included on the Am29202 microcontroller.

<table>
<thead>
<tr>
<th>Bit</th>
<th>Cell Name</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>MEMCLK</td>
<td></td>
</tr>
<tr>
<td>2</td>
<td>RESET</td>
<td></td>
</tr>
<tr>
<td>3</td>
<td>LSYNC</td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>VCLK</td>
<td></td>
</tr>
<tr>
<td>5</td>
<td>INTR2</td>
<td></td>
</tr>
<tr>
<td>6</td>
<td>INTR0</td>
<td></td>
</tr>
<tr>
<td>7</td>
<td>DREQ1</td>
<td></td>
</tr>
<tr>
<td>8</td>
<td>GREQ</td>
<td></td>
</tr>
<tr>
<td>9</td>
<td>TOPDRV</td>
<td>Enables the drivers for PSYNC through PWE</td>
</tr>
<tr>
<td>10</td>
<td>PSYNCI</td>
<td>PSYNC input</td>
</tr>
<tr>
<td>11</td>
<td>PSYNCO</td>
<td>PSYNC output</td>
</tr>
<tr>
<td>12</td>
<td>VDATI</td>
<td>VDAT input</td>
</tr>
<tr>
<td>13</td>
<td>VDATO</td>
<td>VDAT output</td>
</tr>
<tr>
<td>14</td>
<td>PIOI4</td>
<td>PIO4 input</td>
</tr>
<tr>
<td>15</td>
<td>PIOO4</td>
<td>PIOO4 output</td>
</tr>
<tr>
<td>16</td>
<td>PIOI5</td>
<td>PIO5 input</td>
</tr>
<tr>
<td>17</td>
<td>PIOO5</td>
<td>PIO5 output</td>
</tr>
<tr>
<td></td>
<td>...</td>
<td></td>
</tr>
<tr>
<td>36</td>
<td>PIOI15</td>
<td>PIO15 input</td>
</tr>
<tr>
<td>37</td>
<td>PIOO15</td>
<td>PIO15 output</td>
</tr>
<tr>
<td>38</td>
<td>BUSY</td>
<td></td>
</tr>
<tr>
<td>39</td>
<td>PACK</td>
<td></td>
</tr>
<tr>
<td>40</td>
<td>PCE</td>
<td></td>
</tr>
<tr>
<td>41</td>
<td>PWE</td>
<td></td>
</tr>
<tr>
<td>42</td>
<td>PSTROBE</td>
<td></td>
</tr>
<tr>
<td>43</td>
<td>PAUTOFD</td>
<td></td>
</tr>
<tr>
<td>44</td>
<td>WAIT</td>
<td></td>
</tr>
<tr>
<td>45</td>
<td>BOOTW</td>
<td></td>
</tr>
<tr>
<td>46</td>
<td>ABIDRV</td>
<td>Enables the driving of the A21–A0 outputs</td>
</tr>
<tr>
<td>47</td>
<td>A0</td>
<td></td>
</tr>
<tr>
<td>48</td>
<td>A1</td>
<td></td>
</tr>
<tr>
<td></td>
<td>...</td>
<td></td>
</tr>
<tr>
<td>68</td>
<td>A21</td>
<td></td>
</tr>
</tbody>
</table>
Table 6. Main Data Scan Path (continued)

<table>
<thead>
<tr>
<th>Bit</th>
<th>Cell Name</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>69</td>
<td>BOTDRV</td>
<td>Enables the drivers for DACK1 through RXD</td>
</tr>
<tr>
<td>70</td>
<td>DACK1</td>
<td></td>
</tr>
<tr>
<td>71</td>
<td>R/W</td>
<td></td>
</tr>
<tr>
<td>72</td>
<td>PIAOE</td>
<td></td>
</tr>
<tr>
<td>73</td>
<td>PIAWE</td>
<td></td>
</tr>
<tr>
<td>74</td>
<td>PIACS0</td>
<td></td>
</tr>
<tr>
<td>75</td>
<td>PIACS1</td>
<td></td>
</tr>
<tr>
<td>76</td>
<td>GACK</td>
<td></td>
</tr>
<tr>
<td>77</td>
<td>TR</td>
<td></td>
</tr>
<tr>
<td>78</td>
<td>WE</td>
<td></td>
</tr>
<tr>
<td>79</td>
<td>CAS0</td>
<td></td>
</tr>
<tr>
<td>80</td>
<td>CAS1</td>
<td></td>
</tr>
<tr>
<td>81</td>
<td>CAS2</td>
<td></td>
</tr>
<tr>
<td>82</td>
<td>CAS3</td>
<td></td>
</tr>
<tr>
<td>83</td>
<td>RAS0</td>
<td></td>
</tr>
<tr>
<td>84</td>
<td>RAS1</td>
<td></td>
</tr>
<tr>
<td>85</td>
<td>RAS2</td>
<td></td>
</tr>
<tr>
<td>86</td>
<td>RAS3</td>
<td></td>
</tr>
<tr>
<td>87</td>
<td>ROMOE</td>
<td></td>
</tr>
<tr>
<td>88</td>
<td>RSWE</td>
<td></td>
</tr>
<tr>
<td>89</td>
<td>ROMCS0</td>
<td></td>
</tr>
<tr>
<td>90</td>
<td>ROMCS1</td>
<td></td>
</tr>
<tr>
<td>91</td>
<td>ROMCS2</td>
<td></td>
</tr>
<tr>
<td>92</td>
<td>ROMCS3</td>
<td></td>
</tr>
<tr>
<td>93</td>
<td>TXD</td>
<td></td>
</tr>
<tr>
<td>94</td>
<td>UCLK</td>
<td></td>
</tr>
<tr>
<td>95</td>
<td>RXD</td>
<td></td>
</tr>
<tr>
<td>96</td>
<td>DBIDRV</td>
<td>Enables the ID bus drivers</td>
</tr>
<tr>
<td>97</td>
<td>IDI0</td>
<td>ID0 input</td>
</tr>
<tr>
<td>98</td>
<td>IDO0</td>
<td>ID0 output</td>
</tr>
<tr>
<td>99</td>
<td>IDI1</td>
<td>ID1 input</td>
</tr>
<tr>
<td>100</td>
<td>IDO1</td>
<td>ID1 output</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>159</td>
<td>IDI31</td>
<td>ID31 input</td>
</tr>
<tr>
<td>160</td>
<td>IDO31</td>
<td>ID31 output</td>
</tr>
</tbody>
</table>

*Note: Drive-enable cells are shown in boldface.*
IEEE-1284-COMPLIANT
ADVANCED PARALLEL INTERFACE

The Am29202 microcontroller offers a new parallel port interface that is compliant with the IEEE Std 1284-1994 Standard Signaling Method for a Bidirectional Parallel Peripheral Interface for Personal Computers.

The new Advanced Parallel Interface (API) replaces the parallel interface included on the Am29200 and Am29205 microcontrollers (referred to in this data sheet as the classic port).

Note: This data sheet has been written with the assumption that the reader has a thorough and complete understanding of the IEEE-1284 standard and all the electrical and timing specifications it contains. IEEE Std 1284-1994 can be ordered directly from the IEEE by calling 1-800-678-IEEE (US) or 1-908-981-1393 and requesting document #SH17335.

Upgrading Hardware and Software

The Advanced Parallel Interface has been designed to minimize the hardware and software changes required to upgrade from the classic port; however, some changes will be required to upgrade.

The maximum external system circuitry needed to implement the API is shown in Figure 15. The parallel port does not attach directly to the microcontroller, but is attached to the interface via buffers. To support the new IEEE-1284-compliant parallel port, data must be latched in the interface using a bidirectional bus-driver/latch such as a 74ALS652. The handshaking signals, PSTROBE, PAUTOFD, SELECTIN, INIT, PACK, and PBUSY, are connected to the microcontroller via simple interface circuits. The inputs PSTROBE, PAUTOFD, SELECTIN, and INIT should be connected to the processor via a Schmitt-trigger inverter such as a 74HCT14, and the outputs PACK and PBUSY should be connected to the host via an inverter/driver such as a 74LS240. PERROR, SELECT, and FAULT are driven by software through programmer-defined PIOs or PIAs.

The API also requires software/driver changes, since the programmable registers and their addresses have changed from those used on the classic port. These changes are described later in this section.

Figure 15. Maximum External System Design
Minimal System Design

While the new parallel interface on the Am29202 microcontroller adds considerable functionality, it is not required that the port be operated in full IEEE-1284 compliance. Using a subset of the hardware and the register set, the designer can set up the API to operate in a mode similar to that of the classic port on the Am29200 and Am29205 microcontrollers. A minimal system design for this configuration is shown in Figure 16.

Host-to-peripheral data must be latched in the interface using a three-state latch such as a 74LS374. The handshaking signals, PSTROBE, PAUTOFD, PACK, and PBUSY, are connected to the microcontroller via simple interface circuits. The inputs PSTROBE and PAUTOFD should be connected to the processor via a Schmitt-trigger inverter such as a 74HCT14, and the outputs PACK and PBUSY should be connected to the host via an inverter such as a 74LS240.

Figure 16. Minimal System Design

Software can then minimally control the API to operate in a manner similar to the classic port on the Am29200 and Am29205 microcontrollers. This is accomplished by configuring the interface for Compatibility mode (by setting APMODE to 1) and leaving it there. Interrupts will be received for data transfer in the forward direction.

OVERVIEW

The IEEE-1284 standard specifies the operation of an extensible, bidirectional, multimode parallel interface, providing access to a variety of peripheral devices, such as printers, scanners, storage devices, and network interfaces. It supports several different communications modes that allow access to both high-speed and low-overhead communications, providing a path for data to be sent from the peripheral device to the host and reducing the amount of user interaction required to operate a peripheral. AMD's implementation of the IEEE-1284 standard on the Am29202 microcontroller provides:

- **Compatibility, Nibble, Byte, and ECP modes**—Support for peripheral-side operation in these modes (host-side designs are not supported).
- **Automatic hardware handshakes**—Correctly timed requests to support data transfers that match IEEE-1284 protocols; automatic in all modes except Nibble.
- **Hardware DMA support** in all modes except Nibble.
- **External control lines**—Access to IEEE-1284 control lines through existing classic port signals and PIO lines. Registers and control logic are provided to easily support other required mode lines and controls in software.
- **Software control**—Easy access to input status information with a variety of software strategies, including polling, interrupt service, and DMA.
- **Windows Printing System compatibility**—The Am29202 microcontroller was chosen by Microsoft as its hardware reference platform for this software.

The Am29202 microcontroller supports the standard IEEE-1284 communications modes using a mixture of hardware and software controls.

Hardware controls include fast automatic data transfer handshakes and real-time status lines, as well as interrupts and pollable status for software-driven operations.

Operations not directly supported in hardware include: mode transitions of any type, IEEE-1284 negotiation and termination, mode approvals and denials, and Nibble mode data transmission. These operations are handled using interrupts and application software.

A special control interrupt in the ICT Register is provided to manage mode changes, negotiation, and termination. Using this APCI control interrupt, software modifies an API interrupt mask register at each stage of an IEEE-1284 transition, selecting the edge required for the next interrupt (as well as doing the work required at that phase transition). This structure allows for easy control of modes without processor delay loops or polling. Data handling is facilitated by a pollable status bit and a second dedicated interrupt (APDI) in the ICT Register.
### Table 7. Feature Comparison of Supported IEEE-1284 Communication Modes

<table>
<thead>
<tr>
<th>FEATURE</th>
<th>Compatibility (Centronics)</th>
<th>Nibble</th>
<th>Byte</th>
<th>ECP</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Data Path</strong></td>
<td>Forward (Host-to-peripheral)</td>
<td>Reverse (Peripheral-to-host)</td>
<td>Reverse (Peripheral-to-host)</td>
<td>Forward (Host-to-peripheral) Reverse (Peripheral-to-host)</td>
</tr>
<tr>
<td><strong>Bidirectional</strong></td>
<td>No (Note 1)</td>
<td>No (Note 2)</td>
<td>No (Note 2)</td>
<td>Yes</td>
</tr>
<tr>
<td><strong>Full-Word Transfer</strong></td>
<td>Yes</td>
<td>No</td>
<td>No</td>
<td>Forward mode only</td>
</tr>
<tr>
<td><strong>Hardware Handshaking</strong></td>
<td>Automatic</td>
<td>Semi-automatic</td>
<td>Automatic</td>
<td>Automatic</td>
</tr>
<tr>
<td><strong>Hardware DMA Support</strong></td>
<td>Yes</td>
<td>No</td>
<td>Yes</td>
<td>Yes</td>
</tr>
</tbody>
</table>

**Notes:**
1. **Bidirectional** when used with Nibble or Byte mode with transfer direction controlled by host.
2. **Bidirectional** when used with Compatibility mode. These two modes cannot be active simultaneously.

### Communication Modes

AMD’s implementation of the IEEE-1284 standard on the Am29202 microcontroller supports the following IEEE-1284 modes (see Table 7).

- **Compatibility Mode**—Provides an asynchronous, byte-wide forward (host-to-peripheral) channel with data and status lines used according to their original (Centronics) definitions. Compatibility mode is backward compatible with many existing devices, including the PC parallel port and the classic parallel port on the Am29200 and Am29205 microcontrollers.

- **Nibble Mode**—Provides an asynchronous, reverse (Peripheral-to-host) channel, under control of the host. Data bytes are transmitted as two sequential, four-bit nibbles using four peripheral-to-host status lines. Nibble mode is used with Compatibility mode to implement a bidirectional channel. These two modes cannot be active simultaneously.

- **Byte Mode**—Provides an asynchronous, byte-wide reverse (Peripheral-to-host) channel using the eight data lines of the interface for data and the control/status lines for handshaking. Byte mode is used with Compatibility mode to implement a bidirectional channel, with transfer direction controlled by the host, when the host and peripheral both support bidirectional use of the data lines. The two modes cannot be active simultaneously.

- **Extended Capabilities Port (ECP) Mode**—Provides an asynchronous, byte-wide, bidirectional channel. For faster forward transfers, an interlocked handshake replaces Compatibility mode’s minimum timing requirements for its interface signals. A control line is provided to distinguish between command and data transfers. A command may optionally be used to indicate data compression or a channel address (determined by the application).

Mode selection is made by the application software, based on mode requests made by the external IEEE-1284 host. These mode requests are called IEEE-1284 negotiations and are attempts to communicate beyond the base level (Compatibility mode). The negotiations, responses, and mode changes are all moderated by the application software (an IEEE-1284 driver), on interrupts caused by the IEEE-1284 interface hardware, in response to IEEE-1284 activity on the interface.
EXTERNAL SIGNALS

Note: All IEEE-1284 interface signal levels discussed in this document are inverted, from the IEEE-1284 cable to the peripheral circuitry at the processor, and vice versa (see Figure 15). Signal names shown in this document in all upper case letters (e.g., PSTROBE) are Am29202 microcontroller signals; they represent IEEE Std 1284-1994 signal names (e.g., nStrobe) that have been inverted at the processor/interface chip terminal.

While many signals are named differently in each IEEE-1284 communication mode, the primary reference in this data sheet is to the Am29202 microcontroller signal name at the pin. To facilitate reference to timing diagrams in the IEEE standard document, the inverted IEEE-1284 Compatibility mode signal name is sometimes listed in this data sheet in parentheses following the Am29202 microcontroller signal name, e.g., PSTROBE (nStrobe). Table 8 maps the Am29202 microcontroller signal names to all those used in the IEEE-1284 standard.

Dedicated Signal Lines

- PACK (output)
  Output through an inverting buffer to nAck/PtrClk/PeriphClk, this signal is active when the API is enabled.

- PAUTOFD (input)
  Input via an inverting buffer from nAutofd/HostBusy/HostAck, PAUTOFD is used by the host in reverse-channel modes to signal reverse data strobe. It is also used in other contexts in various modes. The PAUTOFD signal can optionally cause control interrupts on either edge.

- PBUSY (output)
  Output through an inverting buffer to Busy/PtrBusy/PeriphAck, this signal comes from the Advanced Port when it is enabled.

- POE (output)
  Made active by a read from address 800000B0, this signal enables latched data on the data bus, to be read by the processor under interrupt or DMA control.

- PSTROBE (input)
  Input via an inverting buffer from nStrobe/HostClk, the PSTROBE signal is used in some forward modes to generate data strobe assertions and to signal data presence. In other modes, PSTROBE signals something other than a data transfer. The PSTROBE signal can optionally cause control interrupts on either edge.

- PWE (output)
  Made active by a write to address 800000B0, this signal is used to latch the data bus for outgoing (peripheral-to-host) transmission.

Mode-Allocated PIO Lines

Extended IEEE-1284 modes require dedicated control signal lines for their operation. Some of these lines appear as outputs or are read as inputs from existing PIO lines. The function of these pins changes from general-purpose PIO to specific-purpose IEEE-1284 control line while the API is enabled. When the API is enabled, the API has control of the signal lines. If the API is not enabled, the PIO port has control of the lines.

- DATASTROBE/PIO6 (output)
  The DATASTROBE line causes forward data to be latched in the external forward data latch during appropriate modes. This line supplies a strobe pulse with timing dependent upon the current API mode and controlled by the APMODE field.

- INIT/PIO4 (input)
  The INIT signal comes via an inverting buffer from nInit/nReverseRequest and can optionally cause control interrupts on either edge.

- REVOE/PIO8 (output)
  The REVOE signal is controlled by hardware and is used in Byte and ECP modes to force the data latch/buffer to drive data in the peripheral-to-host direction. This signal is used when the peripheral device has control of the IEEE-1284 data bus. Because of strict IEEE-1284 specifications on reinitialization, this signal must be driven directly.

- SELECTIN/PIO5 (input)
  The SELECTIN line comes via an inverting buffer from nSelectIn/1284Active. It transitions (along with PAUTOFD) to signal the request to negotiate an IEEE-1284 mode and to signal the termination from an IEEE-1284 mode. This line can optionally cause control interrupts on either edge.

Software-Driven Status Lines

Only the signals that are required in hardware for IEEE-1284 transfers are included in the mode-allocated PIOs. Other parallel IEEE-1284 status lines that are used during status outputs, mode transitions, or slow modes only are driven by software through programmer-defined parallel lines. PIAs or PIOs are acceptable, since these are outputs modified by software only.

- FAULT (output)
  This signal is driven by software and output to nFault/nDataAvail/nPeriphRequest.

- PERROR (output)
  This signal is driven by software and output to PError/AckDataReq/nAckReverse.

- SELECT (output)
  This signal is driven by software and output to Select/XFlag.
Table 8. IEEE-1284 Parallel Interface Signal Names by Mode

| Am29202 Microcontroller Signal Name ¹ (Inverted from IEEE-1284 bus interface) | Signal Names As Specified in IEEE Std 1284-1994 |
|---|---|---|---|---|
| | Compatibility Mode | Nibble Mode | Byte Mode | ECP Mode |
| PSTROBE | nStrobe | — | HostClk | HostClk |
| PAUTOFD | nAutoFd | HostBusy | HostBusy | HostAck |
| SELECTIN | nSelectIn | 1284Active | 1284Active | 1284Active |
| INIT | nInit | — | — | nReverseRequest |
| ID7–ID0 | Data8–Data1 | — | Data8–Data1 ³ | Data8–Data1 ³ |
| PACK | nAck | PtrClk | PtrClk | PeriphClk |
| PBUSY | Busy | PtrBusy/Data4, Data8 | PtrBusy | PeriphAck |
| PERROR | PError | AckDataReq/Data3, Data7 | AckDataReq | nAckReverse |
| SELECT | Select | XFlag/Data2, Data6 | XFlag | XFlag |
| FAULT | nFault | nDataAvail/Data1, Data5 | nDataAvail | nPeriphRequest |
| DATASTROBE ² | DATASTROBE | — | — | DATASTROBE 4 |
| REVOE ² | — | — | REVOE | REVOE ⁵ |

Notes:

1. The primary form of reference in this data sheet is to the Am29202 microcontroller signal name at the pin, shown in all upper case letters. To facilitate reference to timing diagrams in the IEEE-1284 standard document, the inverted IEEE-1284 Compatibility mode signal name is sometimes shown in parentheses following the Am29202 microcontroller signal name, e.g., PSTROBE (nStrobe).

2. These signals are not called out in the IEEE-1284 Std document. However, they are used on the Am29202 microcontroller in the modes shown.

3. When reversed by REVOE, these lines are bidirectional.

4. Used on the Am29202 microcontroller in ECP Forward mode only.

5. Used on the Am29202 microcontroller in ECP Reverse mode only.
REGISTERS

The parallel port interface is controlled through its five registers, which are summarized in Table 9.

- **The Advanced Parallel Control (APCT) Register**
  is used to enable and control the API, to change modes, and to directly or indirectly control operation of the internal hardware. This register can be written with control data, and the status of those bit fields can be read back.

- **The Advanced Parallel Status (APST) Register**
  supplies real-time status information on the operation of the API and its incoming and outgoing signals. This register is comprised of three types of signals: status signals from within API hardware, real-time snooping bits of the output and input signals used by the API, and the real-time values of the interruptible condition bits prior to being masked into the Advanced Parallel Interrupt Status Register (APIS). These values are then OR’d into the Interrupt Control (ICT) Register for the microcontroller via the APCI (Advanced Parallel Control Interrupt). The APST signals provide access to the status from polling routines or interrupt service.

- **The Advanced Parallel Interrupt Mask (APIM) Register**
  specifies the particular IEEE-1284 signal inputs that are combined to cause the next APCI interrupt; there also exists a mask for the single APDI data interrupt. (In this context, the mask allows the corresponding signal to pass through.) This allows easy programmer control as each IEEE-1284 transition occurs. Also, a special ECP Forward mode Command Interrupt and a Device Initialization interrupt is included in the interruptible signals.

- **The Advanced Parallel Interrupt Status (APIS) Register**
  reports the APST condition bits that have been masked in the APIM Register. This register is used by interrupt service routines to determine the condition that caused the latest APCI interrupt. Writing to this register with a 1 in each appropriate bit position clears the condition latch for each interrupt. Also writing to the same bit positions in the APST Register clears the same condition bits, thus allowing polling routines to easily clear the same bits as interrupt routines would do in the APIS.

- **The Advanced Parallel Data (APDT) Register**
  is a special register decode that addresses the external data latch. The register does not exist internal to the API; it causes the generation of the POE or PWE signals that read external data, or latch it, respectively.

---

**Table 9. Parallel Port Register Summary**

<table>
<thead>
<tr>
<th>Register Name</th>
<th>Mnemonic</th>
<th>Function</th>
<th>Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>Advanced Parallel Control</td>
<td>APCT</td>
<td>Reads and writes values of control bits</td>
<td>800000A0</td>
</tr>
<tr>
<td>Advanced Parallel Status</td>
<td>APST</td>
<td>Reads interface status; reads interrupt edge bits; clears interrupts</td>
<td>800000A4</td>
</tr>
<tr>
<td>Advanced Parallel Interrupt Mask</td>
<td>APIM</td>
<td>Reads and writes mask bit values</td>
<td>800000A8</td>
</tr>
<tr>
<td>Advanced Parallel Interrupt Status</td>
<td>APIS</td>
<td>Reads enabled interrupt bits and clears interrupts</td>
<td>800000AC</td>
</tr>
<tr>
<td>Advanced Parallel Data</td>
<td>APDT</td>
<td>Reads external latched parallel input data</td>
<td>800000B0</td>
</tr>
</tbody>
</table>

**Note:**
The address assignments for these registers are different from those assigned to the classic port registers on the Am29200 and Am29205 microcontrollers.
Advanced Parallel Control Register (APCT, Address 800000A0)

The Advanced Port is controlled via the Advanced Parallel Control Register (Figure 17). It contains the AP-MODE field, DMA channel select, and various control bits. All bits read back their written states, except for the AFAS bit, which reads back 0.

Bit 31: Internal Reverse Output Enable (INTREVOE)
Setting this bit to 1 forces the external signal REVOE High. REVOE changes the data direction of the external bus buffer/latch device to peripheral-to-host to drive the IEEE-1284 bus with data that has been captured from the processor. When the external parallel data direction must be reversed, software can modify this signal on entering and exiting different IEEE-1284 modes or sub-modes.

REVOE is disabled by internal hardware when the interface receives a Device Initialization condition (signaled by INIT and SELECTIN asserted).

The return to Compatibility mode automatically releases the REVOE disable. Software should determine and write the proper condition of INTREVOE before returning to Compatibility mode.

There is no effect from a Device Initialization condition if INTREVOE is set to 0.

Bits 30–28: Reserved

Bit 27: Background Status Defer (BSD)—Background Status Defer is used in Nibble mode to disable a portion of the semi-automatic handshaking, allowing status signaling back to the host.

While disabled, BSD allows PACK (nAck) deassertion semi-automatic handshakes to occur with an indefinite number of transfers.

When written to a 1, BSD disables the next PACK deassertion handshake-completion mechanism. When written to a 0, it releases the automatic handshake, but only after a delay of TACKDELAY. This delay allows the required data setup time for status information before allowing the PACK deassertion to occur.

Bit 26: Advanced Full Word Transfer (AFWT)—When AFWT is set to 0, the data transfer logic will generate one data transfer request per input byte, and the external APDT will be defined as 8 bits wide. When AFWT is set to 1 and the API is set to Compatibility or ECP Forward modes, the data transfer logic will generate a data transfer request cycle every fourth PSTROBE (nStrobe), and the external APDT will be defined as 32 bits wide (4 transfers).

The processor may read the BC field of the APST Register to determine the number of complete handshakes that have occurred since the last full word transfer. The partial value in BC is cleared by clearing AFWT.

External logic must be used to concatenate the four forward transfer bytes into a single 32-bit big-endian packed word.

Bit 25: Command Polarity Expected (CPE)—CPE is used with DMA in ECP Forward mode only to allow data and command bytes to be handled differently.

If the command bit received with an ECP data byte does not equal CPE, then APDS is asserted and DMA is requested normally.

If the command bit equals CPE, ECS is asserted, and, if masked (enabled), ECI will cause an APCI interrupt in the ICT Register. The ECS condition is not cleared automatically when the command byte is read; it must be cleared in the APIS or APST register. The automatic handshake is not completed when the command byte is read; it is completed only when ECS is cleared.

![Figure 17. Advanced Parallel Control Register](image-url)
Bit 24: Asynchronous Busy Control (ABC)—ABC is used to force PBUSY (Busy) asserted, during Compatibility mode only. ABC set to 1 forces PBUSY asserted. ABC set to 0 stops forcing PBUSY asserted, and allows PBUSY to return to the existing Compatibility-mode busy status. Whenever the peripheral can no longer accept a byte, this bit is set by software to asynchronously force PBUSY asserted.

ABC is only applicable in Compatibility mode; PBUSY transitions that are requested in other modes occur normally and are output on PBUSY. Once the API is returned to Compatibility mode, the ABC-generated (or latch-full-generated) PBUSY will still be in effect.

Bit 23: Asynchronous Force Ack Set (AFAS)—AFAS is used to generate special pulses during Compatibility mode negotiations and delayed PACK (nAck) assertion edges in Nibble mode. AFAS always reads back 0.

In Compatibility mode, a write of 1 to AFAS forces a PACK pulse of length TACKLEN to be generated immediately. This will not normally be required because reading data from the Advanced Parallel Data Register will generate a correctly timed PACK pulse automatically (whether from an interrupt-driven instruction or from DMA). This AFAS assertion can be used to force a special PACK pulse needed in negotiation.

In Nibble mode, a write of 1 to AFAS will cause a delay of length TACKDELAY, and then a PACK assertion only. A PAUTOFD (nAutoFd) assertion (normal handshake) from the host then automatically clears the PACK status in this mode.

Bit 22: Advanced Force Busy (AFBUSY)—AFBUSY is an optional control bit for the PBUSY pin in the Advanced Port. Whenever APDHHB is 1, AFBUSY set to 1 forces an active level on PBUSY and AFBUSY set to 0 forces an inactive level on PBUSY. The polarity from AFBUSY to PBUSY is inverted. This bit should be set to the proper condition before activating APDHHB.

AFBUSY is used when the API is in a mode that does not support hardware handshaking or in a handshaking mode where direct control is required.

If APDHHB is 1, AFBUSY directly controls the level driven on PBUSY, whether or not the API is active. This allows the PBUSY pin to be used for an alternate output function if the parallel port is not used.

Bit 21: Advanced Port Disable Hardware Handshake Busy (APDHHB)—When the API is enabled, APDHHB set to 1 transfers control of PBUSY to the AFBUSY (Advanced Force Busy) register bit. APDHHB set to 0 allows API hardware handshake logic to control PBUSY. The AFBUSY bit must be set to the proper condition before activating APDHHB.

Bit 20: Advanced Force Ack (AFACK)—AFACK is an optional control bit for the PACK pin in the Advanced Port. Whenever APDHHA is set to 1, AFACK set to 1 forces an active level on PACK and AFACK set to 0 forces an inactive level on PACK. The polarity from AFACK to PACK is not inverted. This bit should be set to the proper condition before activating APDHHA.

AFACK is used when the API is in a mode that does not support hardware handshaking or in a handshaking mode where direct control is required (such as negotiation).

If APDHHA is 1, AFACK directly controls the level driven on PACK, whether or not the API is active. This allows the PACK pin to be used for an alternate output function if the parallel port is not used.

Bit 19: Advanced Port Disable Hardware Handshake Ack (APDHHA)—When the API is enabled, APDHHA set to 1 transfers control of PACK to the AFACK (Advanced Force Ack) register bit. APDHHA set to 0 allows API hardware handshake logic to control PACK. The AFACK bit should be set to the proper condition before activating APDHHA.

When APDHHA is 1, the internal PACK logic will not start a PACK cycle (delayed or pulsed). This allows transitions back to internal PACK control without spurious pulses. For this reason, APDHHA should only be cleared when returning to Compatibility mode.

Bit 18: DMA Mode (DMAMODE)—DMAMODE controls which mechanism services a data transfer request condition (APDS) for modes that feature hardware handshaking. When set to 1, DMA transfers are enabled to a channel selected by the APDC field. When set to 0, DMAMODE enables interrupts on APDI (if masked).

Bits 17–16: Advanced Port DMA Channel Select (APDC)—APDC selects the DMA channel used to request a data transfer. If the API is enabled, DMAMODE is set to 1, and a data transfer request (APDS) occurs, then the DMA request of channel specified by the APDC field will be asserted.

<table>
<thead>
<tr>
<th>APDC Channel</th>
<th>APDC1</th>
<th>APDC0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Channel 0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Channel 1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>Reserved</td>
<td>1</td>
<td>x</td>
</tr>
</tbody>
</table>

Bits 15–8: Ack Length/Ack Delay (ACKLEN/ACKDELAY)—This field has two contexts: ACKLEN in Compatibility mode and ACKDELAY in all reverse modes. The period of time represented by this field is measured in MEMCLK cycles and is proportional to clock speed.
In Compatibility mode, ACKLEN is the length of the PACK (nAck) pulse generated by the automatic handshakes (or when AFAS is asserted for manual PACK control). When a data byte is read from the APDT Register or AFAS is written to a 1, a pulse is generated automatically on the PACK output of length TACKLEN. For proper operation, this field’s minimum count is 1, and the maximum is 255.

In reverse modes, when a data byte is read or when AFAS is written to a 1, PACK is asserted after a delay of length TACKDELAY. ACKDELAY is the delay value from the time data is written to the Advanced Parallel Data Register to the time the PACK signal is generated (signaling data transfer) automatically in hardware. It provides a minimum data setup time from when data is output to when the PACK active edge signals the host that the transfer is ready. The minimum value specified for this time in the IEEE standard is 500 ns. The number of cycles that this value represents will vary with the processor clock frequency.

### Bits 6–0: Advanced Parallel Mode (APMODE)

The value in APMODE (see Table 10) sets the operating mode of the API including all the automatic functions, such as data transfer request timing, PACK pulse delay and length timing, DATASTROBE source, PIO allocation, DMA direction, and PBUSY (Busy) context changes. The mode selected will remain in effect until changed. Mode changes are immediate when written. APMODE is cleared at reset time.

When set to 0, the API is disabled, and the PIO port has control of the shared signal lines. Interrupts from the API are disabled when APMODE is 0, whether their individual masks are set or not. The HL and LH status conditions for INIT, SELECTIN, PSTROBE, and PAUTOFD are not available in the APST Register when APMODE is 0.

### Table 10. APMODE Values

<table>
<thead>
<tr>
<th>APMODE</th>
<th>Mode Description</th>
<th>Handshake Mode</th>
<th>DMA Support</th>
<th>PIOs Allocated</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Disabled</td>
<td>None</td>
<td>None</td>
<td>None</td>
</tr>
<tr>
<td>1</td>
<td>Compatibility Mode</td>
<td>Automatic</td>
<td>Yes</td>
<td>INIT/PIO4, SELECTIN/PIO5, DATASTROBE/PIO6</td>
</tr>
<tr>
<td>2</td>
<td>Nibble Mode (and ID)</td>
<td>Semi-Automatic</td>
<td>No</td>
<td>INIT/PIO4, SELECTIN/PIO5</td>
</tr>
<tr>
<td>3</td>
<td>Byte Mode (and ID)</td>
<td>Automatic</td>
<td>Yes</td>
<td>INIT/PIO4, SELECTIN/PIO5, REVOE/PIO7</td>
</tr>
<tr>
<td>4</td>
<td>ECP Forward Mode</td>
<td>Automatic</td>
<td>Yes</td>
<td>INIT/PIO4, SELECTIN/PIO5, DATASTROBE/PIO6</td>
</tr>
<tr>
<td>5</td>
<td>ECP Reverse Mode (and ID)</td>
<td>Automatic</td>
<td>Yes</td>
<td>INIT/PIO4, SELECTIN/PIO5, REVOE/PIO7</td>
</tr>
</tbody>
</table>
Advanced Parallel Status Register (APST, Address 800000A4)

The status bits for the real-time signals used in communication and negotiation are available in the Advanced Parallel Status Register (Figure 18).

All edge-detection and other control condition status bits for use in polling or interrupting can be read in this register, along with the data transfer status bit. These include the eight different control input signal conditions: high-to-low and low-to-high edge detection for each of the signals PSTROBE, PAUTOFD, SELECTIN, and INIT; the ECP Command condition, the Device Initialization condition, and the Data Transfer Request condition.

All condition status bits (bits 15-0) are reset-only. Writing a 1 clears the condition, and writing a 0 does not affect the bit. Writing to read-only status does not affect the bits.

The HL and LH status conditions for INIT, SELECTIN, PSTROBE, and PAUTOFD are not available in the APST Register when APMODE is 0.

Bit 31: PBUSY — This is the real-time value of the outgoing PBUSY signal. This signal directly follows the PBUSY pin.

Bit 30: PACK — This is the real-time value of the outgoing PACK signal. This signal directly follows the PACK pin.

Bit 29: INIT — This is the real-time value of the INIT input pin. INIT is input to the device on PIO4.

Bit 28: SELECTIN — This is the real-time value of the SELECTIN input pin. SELECTIN is input to the device on PIO5.

Bit 27: PAUTOFD — This is the real-time value of the PAUTOFD input pin.

Bit 26: PSTROBE — This is the real-time value of the PSTROBE input pin.

Bits 25-22: Reserved

Bits 21-20: Byte Count (BC) — When AFWT is set to 1, the Byte Count field contains the number of bytes that have been received by the external logic for concatenation into a full-word transfer. This count is useful in handling partial-word transfers, such as data streams that are a non-AFWT modulo length, or when an ECP command occurs. BC is a read-only field and is cleared when AFWT is cleared.

Bits 19-16: Reserved

Bit 15: Advanced Port Data Transfer Status (APDS) — APDS signals the readiness for a byte (or full word, if AFWT is set to 1) of data to be transferred, irrespective of the data transfer method programmed, and may be polled.

If DMAMODE is 0 and APDM is 1, then APDI is asserted and an APDI interrupt occurs in the ICT Register. (Note that there is no APDI bit in the Advanced Parallel Interrupt Status Register; an APDS assertion masked by APDM causes an APDI interrupt in the ICT directly.)

If DMAMODE is 1 and APDS is 1, then a DMA request will be made to the channel specified by the APDC bit.

Writing a 1 to this bit will clear the data transfer request condition, although this is normally not recommended, since the data transfer request will be cleared automatically when data is read or written to the Advanced Parallel Data Register. Clearing the APDS bit when DMAMODE is true is undefined and not recommended.

Bit 14: ECP Command Status (ECS) — ECS signals an ECP Forward mode command byte within the data stream. This condition blocks the completion of the ECP Forward data handshake to allow the processor time to interpret the command before more data is accepted. This handshake is held off only for command bytes; data bytes are transferred via APDI or DMA.

---

Figure 18. Advanced Parallel Status Register
This bit causes an ECI interrupt bit to be asserted when the ECM bit is set to 1. Writing a 1 to this bit will clear the ECS condition and allow the ECP Forward data handshake to proceed.

**Bit 13: Device Initialization Status (DEVINITS)—**This bit signals that the host has initiated an initialization cycle. The IEEE-1284 specification requires that the interface proceed immediately to Compatibility mode, accomplished by software upon the DEVINITI interrupt.

This bit causes a DEVINITI interrupt bit to be asserted when the DEVINITM bit is set to 1. (REVOE is also cleared immediately in hardware.) Writing a 1 to this bit will clear the DEVINITS condition, but is not needed typically, as the condition is cleared when the interface is returned to Compatibility mode.

**Bits 12–8: Reserved**

**Bit 7: INIT High-to-Low Edge Detection Status (INITHLS)—**INITHLS signals that the INIT signal has changed from High-to-Low (nInit has gone from Low-to-High). This bit causes an INITHLI interrupt bit to be asserted when the INITLM bit is set to 1. Writing a 1 to this bit will clear the INITHLS condition.

**Bit 6: INIT Low-to-High Edge Detection Status (INITLHS)—**INITLHS signals that the INIT signal has changed from Low-to-High (nInit has gone from High-to-Low). This bit causes an INITLHI interrupt bit to be asserted when the INITLHM bit is set to 1. Writing a 1 to this bit will clear the INITLHS condition.

**Bit 5: SELECTIN High-to-Low Edge Detection Status (SELECTINHLS)—**SELECTINHLS signals that the SELECTIN signal has changed from High-to-Low (nSelectIn has gone from Low-to-High). This bit causes a SELECTINHLI interrupt bit to be asserted when the SELECTINLM bit is set to 1. Writing a 1 to this bit will clear the SELECTINHLS condition.

**Bit 4: SELECTIN Low-to-High Edge Detection Status (SELECTINLHS)—**SELECTINLHS signals that the SELECTIN signal has changed from Low-to-High (nSelectIn has gone from High-to-Low). This bit causes a SELECTINLHI interrupt bit to be asserted when the SELECTINLHM bit is set to 1. Writing a 1 to this bit will clear the SELECTINLHS condition.

**Bit 3: PAUTOFD High-to-Low Edge Detection Status (PAUTOFDHLS)—**PAUTOFDHLS signals that the PAUTOFD signal has changed from High-to-Low (nAutofd has gone from Low-to-High). This bit causes a PAUTOFDHLI interrupt bit to be asserted when the PAUTOFDLM bit is set to 1. Writing a 1 to this bit will clear the PAUTOFDHLS condition.

**Bit 2: PAUTOFD Low-to-High Edge Detection Status (PAUTOFDLHS)—**PAUTOFDLHS signals that the PAUTOFD signal has changed from Low-to-High (nAutofd signal has gone from High-to-Low). This bit causes a PAUTOFDHLI interrupt bit to be asserted when the PAUTOFDLM bit is set to 1. Writing a 1 to this bit will clear the PAUTOFDLHS condition.

**Bit 1: PSTROBE High-to-Low Edge Detection Status (PSTROBELHS)—**PSTROBELHS signals that the PSTROBE signal has changed from High-to-Low (nStrobe signal has gone from Low-to-High). This bit causes a PSTROBELHI interrupt bit to be asserted when the PSTROBELHM bit is set to 1. Writing a 1 to this bit will clear the PSTROBELHS condition.

**Bit 0: PSTROBE Low-to-High Edge Detection Status (PSTROBELHLS)—**PSTROBELHLS signals that the PSTROBE signal has changed from Low-to-High (nStrobe signal has gone from High-to-Low). This bit causes a PSTROBELHI interrupt bit to be asserted when the PSTROBELHM bit is set to 1. Writing a 1 to this bit will clear the PSTROBELHLS condition.
Advanced Parallel Interrupt Mask Register (APIM, Address 800000A8)

The Advanced Parallel Interrupt Mask Register (Figure 19) contains the interrupt mask bits for each condition status bit in the APST Register. When a mask bit is set to 1, it enables the corresponding condition status bit in the APST Register into the corresponding interrupt status bit of the APIS Register. When the mask bit is set to 0, the corresponding interrupt status bit is 0. The mask register is read/writeable.

All interrupt status bits in the APIS are OR’d together to form the aggregate Advanced Parallel Control Interrupt in the ICT Register.

Interrupts from the API are disabled when the APMODE is 0, whether their individual masks are set or not. Note that the APDM mask controls assertion of the APDI interrupt, while all other mask bits control the APCI interrupt.

Bits 31–16: Reserved

Bit 15: Advanced Port Data Transfer Interrupt Mask (APDM)—When APDM is set to 1, an assertion of the APDS bit directly causes an APDI interrupt in the ICT Register. When APDM is set to 0, there is no APDI interrupt.

Bit 14: ECP Command Interrupt Mask (ECM)—When ECM is set to 1, an assertion of the ECS bit sets the ECI interrupt bit, causing an APCI interrupt. When ECM is 0, the ECI interrupt bit is not set.

Bit 13: Device Initialization Interrupt Mask (DEVINITM)—When DEVINITM is set to 1, an assertion of the DEVINITS bit sets the DEVINITI interrupt bit, causing an APCI interrupt. When DEVINITM is 0, the DEVINITI interrupt bit is not set.

Bits 12–8: Reserved

Bit 7: INIT High-to-Low Interrupt Mask (INITHLM) When INITHLM is set to 1, an assertion of the INITHLS bit sets the INITHLI interrupt bit, causing an APCI interrupt. When INITHLM is 0, the INITHLI interrupt bit is not set.

Bit 6: INIT Low-to-High Interrupt Mask (INITLHM) When INITLHM is set to 1, an assertion of the INITLHS bit sets the INITLHI interrupt, causing an APCI interrupt. When INITLHM is set to 0, the INITLHI interrupt bit is not set.

Bit 5: SELECTIN High-to-Low Interrupt Mask (SELINLHM)—When SELINLHM is set to 1, an assertion of the SELINLHS bit sets the SELINLHI interrupt bit, causing an APCI interrupt. When SELINLHM is set to 0, the SELINLHI interrupt bit is not set.

Bit 4: SELECTIN Low-to-High Interrupt Mask (SELINHLM)—When SELINHLM is set to 1, an assertion of the SELINHLS bit sets the SELINHLI interrupt bit, causing an APCI interrupt. When SELINHLM is set to 0, the SELINHLI interrupt bit is not set.

Bit 3: PAUTOFD High-to-Low Interrupt Mask (PAUTOHLM)—When PAUTOHLM is set to 1, an assertion of the PAUTOHLS bit sets the PAUTOHLI interrupt bit, causing an APCI interrupt. When PAUTOHLM is set to 0, the PAUTOHLI interrupt bit is not set.

Bit 2: PAUTOFD Low-to-High Interrupt Mask (PAUTOLHM)—When PAUTOLHM is set to 1, an assertion of the PAUTOLHS bit sets the PAUTOLHI interrupt bit, causing an APCI interrupt. When PAUTOLHM is set to 0, the PAUTOLHI interrupt bit is not set.

Bit 1: PSTROBE High-to-Low Interrupt Mask (PSTBHLM)—When PSTBHLM is set to 1, an assertion of the PSTBHLS bit sets the PSTBHLI interrupt bit, causing an APCI interrupt. When PSTBHLM is set to 0, the PSTBHLI interrupt bit is not set.

Bit 0: PSTROBE Low-to-High Interrupt Mask (PSTBLHLM)—When PSTBLHLM is set to 1, an assertion of the PSTBLHS bit sets the PSTBLHI interrupt bit, causing an APCI interrupt. When PSTBLHLM is set to 0, the PSTBLHI interrupt bit is not set.

---

**Figure 19. Advanced Parallel Interrupt Mask Register**
Advanced Parallel Interrupt Status Register (APIS, Address 800000AC)

The Advanced Parallel Interrupt Status Register (Figure 20) contains the masked condition bits that make up the aggregate Advanced Parallel Control Interrupt in the ICT Register. The bits can be read to determine the source of the interrupt, and each bit can be written to a 1 to clear the corresponding condition and condition bit (writing to the condition bit in the APST Register performs the same function). The APCI is generated when the logical OR of all control interrupt status bits is 1.

Bits 31–16: Reserved

Bit 15: Reserved—There is no APDI interrupt in the APIS. Since there is only one data transfer interrupt, it asserts the APDI bit in the ICT Register directly. The APDS condition can be cleared in the APST Register.

Bit 14: ECP Command Interrupt (ECI)—This interrupt bit indicates that an ECP Forward command has been received. When this bit is a 1, the APCI interrupt occurs.

Writing a 1 to this bit clears the ECS and ECI conditions and releases the ECP Forward handshake, allowing more ECP data or command bytes to be received.

Bit 13: Device Initialization Interrupt (DEVINITI)—When this bit is a 1, the APCI interrupt occurs. When DEVINITI is written to a 1, the DEVINITS and DEVINITI bits are cleared.

Bits 12–8: Reserved

Bit 7: INIT High-to-Low Interrupt (INITHLI)—When this bit is a 1, the APCI interrupt occurs. When INITHLI is written to a 1, INITHLS and INITHLI are cleared.

Bit 6: INIT Low-to-High Interrupt (INITLHI)—When this bit is a 1, the APCI interrupt occurs. When INITLHI is written to a 1, INITLHS and INITLHI are cleared.

Bit 5: SELECTIN High-to-Low Interrupt (SELINHLI) When this bit is a 1, the APCI interrupt occurs. When SELINHLI is written to a 1, SELINLHS and SELINHLI are cleared.

Bit 4: SELECTIN Low-to-High Interrupt (SELINLHI) When this bit is a 1, the APCI interrupt occurs. When SELINLHI is written to a 1, SELINLHS and SELINLHI are cleared.

Bit 3: PAUTOFD High-to-Low Interrupt (PAUTOHLI) When this bit is a 1, the APCI interrupt occurs. When PAUTOHLI is written to a 1, PAUTOHLS and PAUTOHLI are cleared.

Bit 2: PAUTOFD Low-to-High Interrupt (PAUTOLHI) When this bit is a 1, the APCI interrupt occurs. When PAUTOLHI is written to a 1, PAUTOLHS and PAUTOLHI are cleared.

Bit 1: PSTROBE High-to-Low Interrupt (PSTBHLI) When this bit is a 1, the APCI interrupt occurs. When PSTBHLI is written to a 1, PSTBHLS and PSTBHLI are cleared.

Bit 0: PSTROBE Low-to-High Interrupt (PSTBLHI) When this bit is a 1, the APCI interrupt occurs. When PSTBLHI is written to a 1, PSTBLHS and PSTBLHI are cleared.

Figure 20. Advanced Parallel Interrupt Status Register
Advanced Parallel Data Register
(APDT, Address 800000B0)

The Advanced Parallel Data Register (Figure 21) is used to read data from and write data to the parallel port. This register is not implemented directly on the processor, but must be implemented by the user as an external bidirectional data latch.

Writing to the APDT address causes a decoded PWE output to write the current bus data byte or word to an external Data Register. Reading from the APDT address causes a decoded POE output to read data from the external data register to the data bus. The decoder operates even when the API is disabled.

Reading data from or writing data to the APDT automatically causes data transfer requests to be cleared and continues the appropriate handshake for the current mode, except in Nibble mode.

**Bits 7–0: Advanced Port Parallel Data (APDATA)** for 8-bit transfers (Figure 21a) or

**Bits 31–0: Advanced Port Parallel Data (APDATA)** for 32-bit transfers (Figure 21b)—APDATA contains packed-byte data being transferred to the processor and from the IEEE-1284 parallel bus. The register must exist external to the processor. The width of the field is dependent on the AFWT bit. AFWT is valid in Compatibility and ECP Forward modes only.

The instruction or DMA channel must be programmed for the proper width access to read the APDT correctly.

**INITIALIZATION**

During a processor reset, the APMODE field is set to 0, disabling parallel port interrupts and giving control of the shared PIO signals (PIO7/REVOE, PIO6/DATA-STROBE, PIO5/SELECTIN, and PIO4/INIT) to the PIO port.

In the APCT Register, all fields are set to 0 except AFBUSY, APDHHB, and ACKLEN. AFBUSY and APDHHB are set to 1, forcing PBUSY (Busy) Low. The ACKLEN field is set to all 1s.

In the APST Register, the PSTBLHS, PSTBHLS, PAUTOHLS, SELINLHS, SELINLHS, INITHLS, INITHLS, APDS, ECS, and DEVINITS bits are set to 0.

In the APIM Register, all interrupt masks are set to 0.

The POCT, PIN, POEN, and POUT registers must be configured before the parallel interface is enabled. Bits 6 and 7 of the POEN field must be set to 1; bits 4 and 5 of the POEN field must be set to 0. The parallel port interface can then be programmed incrementally, as required; there is no need to disable the interface before writing other registers.
CONTROLLING THE PARALLEL PORT INTERFACE

The API has been designed to allow easy access to input status information using a variety of software strategies, including polling, interrupt service, and DMA.

In its Advanced Parallel Status (APST) Register, the API reports a number of conditions that show either signal transitions or a data transfer request. These control and data transfer condition bits may be read and manipulated by software to control the operation of the parallel port interface (See Figures 22 and 23).

Eight of the condition bits are generated directly from external signal edges. The list below shows the signals whose edges are detected and that have corresponding edge-detection conditions in the APST Register. These input signals have one condition for high-to-low transitions, and one for low-to-high.

In general,

- **PSTROBE** signals a forward data strobe.
- **PAUTOFD** signals a reverse data strobe.
- **SELECTIN** signals 1284Active.
- **INIT** signals an ECP mode transition request or an initialization request.

The other conditions in the control group are the ECS and DEVINITS. The ECS condition signals a command byte during an ECP transfer. The DEVINITS is a signal generated when the host wants to asynchronously reinitialize the peripheral and set it back to Compatibility mode.

The APDS condition bit signals the status of a data transfer request. APDS indicates when a hardware handshake-supported data transfer mode receives (or is ready to transmit) a data byte.

**Polling**

The condition bit values in the APST Register can be used to request service for the conditions by polling from the support software. The specific condition can be cleared by writing a 1 to the corresponding condition bit in the APST Register.

**Interrupts**

If the particular condition requires faster response than polling can accomplish, an interrupt can be generated.

There are two types of API interrupts: control and data transfer. Each is supported with its own interrupt structure. The control (APCI) and data transfer (APDI) interrupts appear separately in the Interrupt Control (ICT) Register, allowing separate interrupt handlers for mode transition and data handling.

The Advanced Parallel Interrupt Mask Register (APIM) specifies the particular IEEE-1284 signal inputs that are combined to cause the next APCI interrupt. There also exists a mask (enable bit) for the single APDI data transfer interrupt. This allows easy programmer control as each IEEE-1284 transition occurs.

To generate an interrupt, the corresponding mask bit in the Advanced Parallel Interrupt Mask Register (APIM) for each condition must be set. When a condition bit is true and its mask is set, the corresponding interrupt flag is asserted in the Advanced Parallel Interrupt Status Register (APIS). This register is used by interrupt service routines to determine the condition that caused the latest APCI interrupt. All control condition interrupts and status bits must be reset manually, except for the DEVINIT status/interrupt bits, which are cleared automatically on entering Compatibility mode.

**Data Transfers**

Once a communications mode that supports full hardware handshaking is entered, polled APDS data transfer request bits, APDI interrupts, or DMA requests will cause a move of data from the Advanced Parallel Data (APDT) Register to memory in forward modes, and from memory to the APDT for reverse modes. The Advanced Parallel Data Register is a special register decode that addresses the external data latch. The register does not exist internal to the API; it causes the generation of the POE or PWE signals that read external data, or latch it, respectively.

In semi-automatically handshaked modes such as Nibble mode, data is handled by a combination of APDI and APCI interrupts.

Data transfer requests, whether serviced by polling, interrupts, or DMA, are cleared automatically when the data is transferred (read or written); normally APDS need not be cleared by software directly.

Figure 24 shows the timing of an external access. This external access is treated as either a DMA access or a processor PIA access for the purpose of prioritization with other accesses. Figure 25 shows the timing for a buffer write.

**Data Interrupts**

The DMAMODE bit controls whether the Data Transfer Request Status bit (APDS) causes an APDI data interrupt (if masked) or a DMA request.

When the data transfer condition bit APDS is set to signal a data transfer, when DMAMODE is 0, and when the Data Transfer Interrupt Mask bit APDM is 1, then the APDI interrupt bit in the ICT Register is set, interrupting the processor for a data transfer.
Note:
This example chain of events, based on PSTROBE true edge, is true for Compatibility mode when the value of APMODE is set to 1.

Figure 22. Example: Using A Control Status Condition to Generate an Interrupt in Compatibility Mode
Figure 23. Example: Using the Data Status Condition in Compatibility Mode

**Note:**
This example chain of events, based on PSTROBE true edge, is true for Compatibility mode when the value of APMODE is set to 1.
In all modes except Nibble, data handling can also be supported with DMA. When a data transfer condition (APDS) is set and DMAMODE is 1, the APDI is not asserted and a DMA transfer request is issued instead. The APDC field selects a particular DMA channel to request.

A special command interrupt allows separate handling of ECP-Forward-mode commands in the DMA data stream.

### Full-Word Transfer

A faster mode of data transfer in the forward direction is the full-word transfer. Full-word transfers are valid only in Compatibility and ECP Forward modes.

This feature allows the designer to latch input data into four external latches and to read the full word from the APDT at one time, reducing the demand placed on the processor and reducing bus bandwidth requirements.

External hardware is used in full-word transfer systems to latch and concatenate the separately strobed data bytes into a 32-bit word. Then, (in full-word transfer mode) when a 32-bit word has been assembled, the API automatically issues a single data request for the entire
word. It does not issue data transfer requests for the intervening bytes; in fact, it acknowledges them without delay, speeding up the transfer greatly.

It is inadvisable to read the external APDT Register before receiving a data byte, whether in AFWT mode or not. In either case, a data byte may be lost. Resetting the external byte counter for AFWT operation whenever the APDT is read will guarantee synchronization through ECP command intervention.

ECP Commands

ECP mode supports several advanced features to improve the effectiveness of the protocol for applications such as raster image devices. These include support for multiple channels of 8-bit bidirectional transfers, as well as support for compression using run-length encoding.

To distinguish between commands and data, the context of the ECP Forward data stream may be modified by the status of the PAUTOFD (nAutoFd) signal at transfer time. This bit is known as the command bit. The IEEE-1284 standard calls for optional changes in peripheral handling of the data stream when the status of the command bit changes. These changes are completely application-specific and are optional.

The API on the Am29202 microcontroller provides three different features to facilitate automatic handling of command conditions in ECP Forward mode. These include:

- Automatic hold-off of the data transfer mechanism by not asserting APDS on the affected command byte.
- Generation of a specialized command status (that can be masked to cause a command interrupt) called ECS (ECP Command Status).
- A way to set the expected polarity of the command bit that should cause the ECS condition. This bit is called CPE (Command Polarity Expected).

When the command bit (status of PAUTOFD) is the same as CPE, the command status is set (ECS is asserted; if masked, ECI occurs). At this point, the normal data transfer request is disabled and does not occur. The data that is modified by the command bit must be handled by a separate command handler. Even when the command data is read, the normal data handshake does not occur. This allows the peripheral to read the byte value and accomplish any actions that the command implied, before allowing the data stream to restart. The data stream will restart and continue automatically when the interrupt handler clears the ECS condition (by writing a 1 to the ECS or ECI bits).

Using Full-Word Transfer with ECP Commands

When a command occurs during an ECP full-word transfer stream, the pending data count is ignored and the ECP Command Status (and if masked, an ECP Command Interrupt) bit is asserted. The software must utilize the Byte Count (BC) field to determine the actual location of the command within the full word being captured and the amount of external data that is valid. Then, a read of the APDT captures the partial word in the embedded command.

The current (command) byte will not be handshaked until the ECS/ECI status is cleared. However, this procedure should not be accomplished until the command has been interpreted, the remaining data left in the full word distributed to the appropriate buffer, and the BC field cleared. The BC field is cleared by clearing the AFWT bit.

The remaining full-word data requires that the AFWT bit be set again and the DMA controller addresses be reset for the new buffer locations affected by the intervening command. Finally, the ECS bit is cleared to allow the interface to continue with the next AFWT data byte.
Mode Selection
Changing modes successfully involves performing two different kinds of operations in software:

- Selecting an IEEE-1284 mode and communicating that choice back to the host.
- Setting up the Am29202 microcontroller’s internal hardware to support the negotiated mode.

Communicating a Mode Choice to the Host
Although the IEEE-1284-compliant host initiates mode change requests, it is the software on the peripheral side that selects which mode the peripheral will support. When the peripheral receives a request (along with an IEEE-1284 extensibility byte) from the host to enter a specific mode, the software evaluates the request and signals the host when the requested mode is one that the peripheral will support. This procedure is well documented in IEEE Std 1284-1994 with phase transition diagrams, descriptions of signal transition events, and timing diagrams.

Configuring the API to Support a Negotiated Mode
Setting up the Am29202 microcontroller hardware to support the negotiated mode is accomplished by writing a value to the APMODE field in the APCT Register. The value of APMODE (see Table 10) tells the microcontroller to interpret incoming and outgoing signals according to handshaking protocols particular to each mode. It also sets other functions, such as the allocation of PIOs and DMA direction.

Note that setting APMODE is completely independent of the mode negotiation process. The host and peripheral negotiate for a mutually acceptable mode, which may or may not match the current APMODE setting. The programmer must reset APMODE at various times during negotiation into and out of the modes:

- Immediately after the interrupt for negotiating to another mode is received, APMODE should be set for Compatibility mode.
- Immediately before negotiation is ended, APMODE should be set to the desired value for the new mode.
- When data-direction-change interrupts occur (from ECP Forward to Reverse, or ECP Reverse to Forward), APMODE should be set for the appropriate submode.

As a general rule, the desired APMODE setting should not be enabled before the programmer is completely ready for the Am29202 microcontroller hardware to begin interpreting inputs according to the automatic handshaking protocols for that particular mode.

Software Control of Handshaking
If desired, the programmer can turn off all automatic handshaking and take direct control of all aspects of the API interface. Register fields provide complete access to all the required controls to operate the parallel interface using software alone:

- When set to 1, the APDHHA and APDHHB bits in the APCT Register turn over direct control of the PACK and PBUSY outputs to the AFACK and AFBUSY bits.
- The APDS field contains all real-time input values.
- When the APMODE field in the APCT Register is set to 0, no preset operating mode is defined. Although the LH and HL status conditions for PSTROBE, PAUTOFD, SELECTIN, and INIT are not available in the APST Register when APMODE is 0, the real-time status of these signals, as well as those for PBUSY and PACK, is available.
USING SOFTWARE IN IEEE-1284 MODES

The API hardware provides a rich set of controls that gives the programmer maximum flexibility. If desired, most of the API operation (except for negotiation) can be automatic. The programmer need only set up a few controls for the Am29202 microcontroller hardware to handle most handshakes automatically.

The key to this control is the APCI interrupt, generated on the edges of the four protocol signals and on the ECP Command and Device Initialization conditions. This interrupt is used to manage mode changes, negotiation, and termination. Application software must modify the Advanced Parallel Interrupt Mask Register at each stage of an IEEE-1284 transition, selecting the edges required for the next possible interrupts, as well as doing the work required at that phase transition.

This section presents some minimal programming suggestions, not necessarily complete or in sequence, to differentiate between what happens automatically in the Am29202 microcontroller hardware and what should be programmed in software. The programmer should use the IEEE Std 1284-1994 document as the authoritative reference source. Table 11, “Using Control Status Conditions in IEEE-1284 Modes,” is presented to facilitate reference back and forth between the two documents.

Compatibility Mode

This mode is the first, and most basic, of the IEEE-1284 modes. It is similar to the classic (Centronics) port in timing.

The API interface should always be initialized to Compatibility mode by software. This is the default IEEE-1284 communications mode for all hosts and peripherals. This mode is maintained until the host has successfully verified that it is connected to an IEEE-1284-compliant device.

From Compatibility mode, the host can either negotiate with the peripheral for another mutually supported mode or transmit data to the peripheral using Compatibility mode. A peripheral-to-host transfer is requested by the host, negotiating with the peripheral for a mutually supported communication mode. At the direction of the host, the API interface can be returned to Compatibility mode at any time.

In Compatibility mode (APMODE set to 1), the API interface provides automatically-handshaked data transfers with polling, interrupt, or DMA support for forward byte (or full-word) transfers.

Automatic Handshakes

The API generates automatic handshakes in Compatibility mode as follows: On PSTROBE (nStrobe) true edge, the PBUSY (Busy) signal goes active and the data transfer request bit (APDS) is driven true. The DATASTROBE line is pulsed automatically when PSTROBE is asserted. This causes the external low-to-high-triggered data latch to capture the data on the active edge of PSTROBE. PACK (nAck) is driven true when data is read from APDT Register, for a pulse length of TACKLEN. PBUSY is set false when PACK is set false (the pulse is completed). PAUTOFD (nAutoFd) status is available in the APST Register.

The Acknowledge Length (ACKLEN) field in the APCT Register sets the length of the PACK pulse generated by the automatic handshakes. In software:

- Set the ACKLEN field to an appropriate length of time in MEMCLK cycles. The IEEE standard calls out a minimum PACK (nAck) pulse width of 500 ns, but a longer one may be desired. The ACKLEN field can be programmed from 1 to 255 cycles in length.

Data Transfers

Data transfer is requested on PSTROBE (nStrobe) going active. This sets the APDS bit, for polling.

To program interrupt-driven data transfers:

- Set the APDM mask bit and clear DMAMODE, causing an APDI interrupt in the ICT Register whenever the APDS is set. No DMA request will be issued.

To enable DMA transfers:

- Set the DMAMODE bit to 1, causing a DMA request to the channel set in the APDC field. No APDI is generated, irrespective of the status of APDM.

Preventing Deadlocks During Data Transfer

Deadlocks can occur when the forward channel has stalled because it is full and the host is requesting status information on the reverse channel. When using forward-channel data transfers in Compatibility mode, the programmer should set up certain controls to ensure that clogging in the forward-channel does not preclude negotiation into a reverse mode.

In order to prevent deadlocks, the programmer should be aware of what is happening with the internal buffer at all times. Setting up an internal busy length that can be detected by the application allows software to determine when the internal buffer is nearing full. There should be enough space left over in the internal buffer so that, even though the internal process is shown as busy, an APDS interrupt will still be accepted for the last byte. The last byte can then be rescued out of the external register and stuck on the end of the buffer, even though it is internally thought of as full.

Note that this requires the programmer to make a distinction between an external busy, where the API is technically busy (“buffer-full” busy), and an internal...
Table 11. Using Control Status Conditions in IEEE-1284 Modes

<table>
<thead>
<tr>
<th>Status Bit Name in Am29202 Microcontroller’s APST Register</th>
<th>APST Bit Mnemonic</th>
<th>Signal State As Shown on Timing Diagrams in IEEE Std 1284-1994</th>
</tr>
</thead>
<tbody>
<tr>
<td>PStROBE Low-to-High (True) Edge Detection Status</td>
<td>PStBLHS</td>
<td>Compatibility Mode:</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Byte and Nibble Modes:</td>
</tr>
<tr>
<td></td>
<td></td>
<td>ECP Mode:</td>
</tr>
<tr>
<td>PStROBE High-to-Low (False) Edge Detection Status</td>
<td>PStBHLS</td>
<td>nStrobe True edge</td>
</tr>
<tr>
<td></td>
<td></td>
<td>HostClk False edge</td>
</tr>
<tr>
<td></td>
<td></td>
<td>HostClk True edge</td>
</tr>
<tr>
<td>PAUTOFD Low-to-High (True) Edge Detection Status</td>
<td>PAUTOLHS</td>
<td>nAutoFd True edge</td>
</tr>
<tr>
<td></td>
<td></td>
<td>HostBusy False edge</td>
</tr>
<tr>
<td></td>
<td></td>
<td>HostAck False edge</td>
</tr>
<tr>
<td>PAUTOFD High-to-Low (False) Edge Detection Status</td>
<td>PAUTOHLS</td>
<td>nAutoFd False edge</td>
</tr>
<tr>
<td></td>
<td></td>
<td>HostBusy True edge</td>
</tr>
<tr>
<td></td>
<td></td>
<td>HostAck True edge</td>
</tr>
<tr>
<td>SELECTIN Low-to-High (True) Edge Detection Status</td>
<td>SELINLHS</td>
<td>nSelectIn True edge</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1284Active False edge</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1284Active True edge</td>
</tr>
<tr>
<td>SELECTIN High-to-Low (False) Edge Detection Status</td>
<td>SELINHLS</td>
<td>nSelectIn False edge</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1284Active True edge</td>
</tr>
<tr>
<td></td>
<td></td>
<td>1284Active True edge</td>
</tr>
<tr>
<td>INIT Low-to-High (True) Edge Detection Status</td>
<td>INITLHS</td>
<td>nInit True edge</td>
</tr>
<tr>
<td></td>
<td></td>
<td>nInit True edge</td>
</tr>
<tr>
<td></td>
<td></td>
<td>nReverseRequest True edge</td>
</tr>
<tr>
<td>INIT High-to-Low (False) Edge Detection Status</td>
<td>INITHLS</td>
<td>nInit False edge</td>
</tr>
<tr>
<td></td>
<td></td>
<td>nInit False edge</td>
</tr>
<tr>
<td></td>
<td></td>
<td>nReverseRequest False edge</td>
</tr>
</tbody>
</table>

**Note:**
The LH and HL designations refer to the signal at the Am29202 microcontroller, inverted from the IEEE-1284 bus.
application-supported busy, where the application decides that no more data is going to be accepted for a period of time.

In this situation, the Advanced Forced Busy (AFBUSY) bit in the APCT Register can be used to control the PBUSY pin for the external busy condition. The Asynchronous Busy Control (ABC) bit is used for the internal busy condition, to asynchronously force PBUSY asserted when the application needs to appear busy. When set, ABC will throttle the host during those periods when the internal buffer is nearing full and the application wants the peripheral to appear busy.

A simple way of preventing deadlocks is to:

- Set ABC asserted at any time to throttle host data. Interrupts received for negotiation may continue to be accepted.

Enabling Negotiation to Another Mode

To enable IEEE-1284 negotiation, in software:

- Set SELECTIN false-edge interrupt mask (SELINHLM) and PAUTOFD true-edge interrupt mask (PAUTOLHM) to cause interrupts for transition to IEEE-1284 negotiation mode. (Such a transition normally happens only in the Forward Idle state.) When either interrupt occurs, check for real-time status of the other status value to signal the negotiation request.

Negotiation Phase

In AMD’s implementation of the IEEE-1284 standard on the Am29202 microcontroller, the process of negotiation between host and peripheral for a mutually acceptable mode is handled completely by software. The basic steps of the negotiation process are always the same, no matter what mode is the final target or how many times the same negotiation has already occurred.

The complete negotiation process is thoroughly described in IEEE Std 1284-1994. This section presents some minimal software recommendations that apply specifically to AMD’s implementation of the standard.

Negotiation starts from the SELECTIN (nSelectIn) false-edge interrupt where PAUTOFD is true, or from the PAUTOFD true-edge interrupt where SELECTIN is false.

During negotiation, the software should take direct control of the PACK (nAck) and PBUSY (Busy) status lines. On assertion of APDHHA, PACK internal status will be cleared, and PACK will not be automatically generated in hardware. In software:

- Set APDHHA and APDHHB true. Set the proper status for signaling IEEE-1284 compliancy: PERROR (PError) true, PACK (nAck) true, FAULT (nFault) false, and SELECT (Select) true.

- To ensure that the forthcoming extensibility byte is not interpreted as data, disable data transfers by clearing the APDM and DMAMODE bits.

- Clear the SELINLM and PAUTOLM bits, set the PSTBLHM bit, and return from interrupt.

Once in negotiation mode, the PSTROBE high-to-low interrupt signals an extensibility byte on the data latch. In software:

- Set the PSTROBE false-edge interrupt mask (PSTBHLHM). At that interrupt, read the extensibility byte in the APDT Register and determine if the mode can be supported (or, if the peripheral chooses to support it). APDS is cleared automatically.

- Set the status lines for the mode selected. Set internal PBUSY status. Set PERROR false and set FAULT (nFault) true if peripheral-to-host data is available. Set the SELECT (XFlag) line to its appropriate value (corresponding to the extensibility feature requested), indicating approval for that mode.

- Set APMODE to the correct value for the new mode.

- Before ending negotiation, enable a table of actions in the negotiation section of the driver. The applicable new mode will require a particular set of interrupt masks, data transfer modes, and status lines to be set.

- Set the PACK (nAck) line false, ending the negotiation.

If negotiation fails, the SELECT (Select) line is set false, host-to-peripheral busy status is placed on PBUSY (Busy), peripheral-to-host data available is set on FAULT (nFault), and PACK (nAck) is set false.

Terminating a Mode

The SELINLHM interrupt edge mask should always be set when in any IEEE-1284 mode, allowing driver support for mode termination. To enable application-driven termination back to Compatibility mode:

- Set the SELECTIN true-edge interrupt mask (SELINLM). At that interrupt, manually complete the valid-state-termination handshake described in the IEEE standard and return from interrupt. A new interrupt on SELECTIN false edge can start another negotiation.

Device ID

If the negotiated mode is a device ID mode, then that mode is entered with data pending to be sent to the host. That data is the device ID string, and it is inserted into the data stream ahead of anything else already pending. That mode is ended when the ID string has been sent and must terminate for renegotiation.
Idle Mode

If the new mode is a reverse channel mode and there is no data pending (reverse idle mode), then after the status is latched on PACK (nAck), the host will either wait at busy, terminate, or force the peripheral into an idle mode.

Idle mode can be reached by the host assertion of PAUTOFD (nAutoFd) while the host thinks there is no data available, but the interface need not switch to idle phase. Internal data available status will change asynchronously through the application, but the host’s knowledge of that status occurs only after it is signaled on FAULT (nFault) and only after being strobed in with PACK (nAck).

To signal the presence of new reverse data:
- Assert FAULT and pulse PACK.

Once in idle mode, the interface can either stay in idle, or terminate normally.

Nibble Mode

Nibble mode provides for slow software-driven reverse-channel communications only. Nibble mode is the only one of the supported IEEE-1284 modes that requires the programmer to handle data transfers completely in software. In order to set up the lines with status information in addition to data, the first and second nibbles are handled differently.

Data is carried on four status lines: FAULT (nFault), SELECT (Select), PERROR (PError), and PBUSY (Busy). No data is transferred on the signal lines used for forward-channel data. The forward channel continues to be driven by the host only, allowing unidirectional hosts to have access to a reverse channel.

There is semi-automatic hardware handshake support.

No DMA transfers are available in this mode.

SELECTIN (nSelectIn) true-edge interrupts must be enabled for application-driven termination back to Compatibility mode.

The DATASTROBE line is not activated, once in this mode.

Data Transfers

All data transfers are signaled via APDS status (and if masked, APDI interrupts) and are handled from software control. Semi-automatic handshakes are generated in this mode. To signal acknowledgment of data, PACK (nAck) is automatically deasserted on the deassertion of PAUTOFD (nAutoFd). This partial handshake support (on PAUTOFD false edge) is termed “semi-automatic.”

In software:
- Set APDHBB true and handle PBUSY manually.
- To utilize the delayed PACK mechanism, set the APDHHA bit to 0. If fully manual control is desired, set APDHHA to 1.
- Load a delay value into ACKDELAY consistent with the IEEE-1284 standard, or longer.

First Nibble

When PAUTOFD (nAutoFd) is asserted showing host not busy, the API hardware automatically generates an APDS data transfer request.

In software:
- Distribute the bits of the low nibble of the first byte into the nibble consisting of: FAULT, SELECT, PERROR, and PBUSY for Data1–Data4.
- Immediately assert AFAS to force PACK (nAck) asserted after a delay of length TACKDELAY.
The built-in delay means that the processor need not be interrupted again until the next PAUTOFD (nAutoFd) assertion (showing ready for more data). PACK (nAck) is semi-automatically deasserted on the deassertion of PAUTOFD (nAutoFd) (signaling acknowledgment of data). This completes the first nibble of the byte.

SecondNibble
For the second nibble, an extra step must be inserted at the very end of the transfer. Before deasserting PACK (nAck), the peripheral must place status information on the lines previously used for data. Then, after a data set-up time, PACK (nAck) can be deasserted, thus ending the transfer of the byte.

For this to occur, the peripheral must do two things: block the automatic deassertion of PACK (nAck) after data is sent, and be interrupted when PAUTOFD (nAutoFd) goes inactive.

The series of steps to transfer the second nibble is shown below, in order:

When PAUTOFD (nAutoFd) is again asserted showing host not busy, the API hardware generates another APDS data transfer request.

In software:
- Place the second nibble of the byte of data onto the nibble data lines as for the first nibble. Also set PAUTOHL and Background Status Defer (BSD) to 1.

PAUTOHL will alert the service routine when to take the transferred data off the nibble data lines and when to put the return status information on them.

BSD controls the semi-automatic handshake that deasserts PACK (nAck), once asserted. When BSD is 0, PACK (nAck) deasserts on PAUTOFD (nAutoFd) deassertion (handshake completes). When BSD is 1, PACK (nAck) is held asserted until BSD is again set to 0 (handshake deferred). When BSD is cleared, PACK (nAck) is deasserted after a delay of length TACKDELAY (deferred handshake completes).

- Once the mask and BSD are set to the correct levels, send the second nibble by again asserting AFAS.

After TACKDELAY, PACK (nAck) is asserted, and the host again deasserts PAUTOFD (nAutoFd). This time the PACK (nAck) is not deasserted automatically. Instead PAUTOFD (nAutoFd) deassertion causes a control interrupt on APCI. This BSD-based selection of the status-output phase increases interrupt efficiency over being interrupted every time PAUTOFD deasserts and does not require constant rewrites to the APCT Register.

In software:
- Update PBUSY (Busy) to the peripheral host-to-peripheral forward-channel-busy status (for the Compatibility mode channel), set reverse-data-available status on FAULT, set PERROR to track FAULT, and clear BSD, allowing the status phase to handshake.

After the delay, PACK (nAck) deasserts and the interface is ready to send another byte or to change modes.

Changing Modes
To enable application-driven termination back to Compatibility mode:
- Set the SELECTIN true-edge interrupt mask (SELINLHM). At that interrupt, set APMODE to 1 for Compatibility mode. Manually complete the valid-state-termination handshake described in the IEEE standard and return from interrupt. A new interrupt on SELECTIN (nSelectIn) false edge can again start another negotiation.

Nibble Idle Phase
In Nibble Idle phase, the peripheral must signal the presence of new reverse data. In software:
- Assert FAULT and pulse PACK.

Nibble ID
Nibble ID mode is identical to Nibble mode, except that Nibble ID mode is entered with data always pending, and that data is always the IEEE-1284 ID data message. Even if there is other data available in the stream, the ID message is sent before any other pending data. When the ID message is sent, the host terminates the mode and renegotiates for any further data. This mode is distinguished from Nibble mode by software only.
**Byte Mode**

Byte mode supports byte-wide reverse data transfers on the eight data lines used for forward channel data in Compatibility mode. API support for Byte mode is similar to that for Nibble mode, but offers automatic handshakes, faster transmission, and less complicated programming.

This mode, like ECP Reverse, requires a special external signal to reverse the data direction, driving latched output data onto the IEEE-1284 data bus. This line is called REVOE and drives the external dual-direction bus driver/latch (LS652 or ACT652).

The IEEE-1284 handshake protocol allows for the time required to disable the host data-driver and enable the peripheral data-driver, as well as to enter the reverse mode. An opposite sequence is used for termination.

Data transfers are requested on PAUTOFD (nAutoFd) assertion in this mode.

DMA transfers for data are enabled via the DMAMODE bit.

SELECTIN (nSelectIn) true-edge interrupts must be enabled for application-driven termination back to Compatibility mode.

The DATASTROBE line is not activated, once in this mode.

**Automatic Handshakes**

APDS occurs on PAUTOFD (nAutoFd) true edge and signals host readiness for reverse data. One data-setup time (500 ns) after the APDT data latch has been written, PACK (nAck) is automatically asserted (this is delayed through the ACKDELAY mechanism). The host will remove PAUTOFD (nAutoFd), acknowledging PACK (nAck). Finally, PACK (nAck) deassertion occurs, completing the handshake.

The host will then send a pulse on the PSTROBE (nStrobe) line signaling that the byte was accepted and processed. This PSTROBE input will not cause a forward data latching on DATASTROBE. It signals the acknowledgment of a byte only. It can be ignored, or used as a flow control indicator.

Another assertion of the PAUTOFD signal indicates that another byte should be sent; the host will only request if data is available.

The Acknowledge Delay (ACKDELAY) field in the APCT Register is the minimum data setup time from when the data is output to the time the PACK signal is generated (signaling data transfer) automatically in hardware. In software:

- Load a delay value into ACKDELAY consistent with the IEEE-1284 standard, or longer.

**Data Transfers**

Data transfer is requested on PAUTOFD (nAutoFd) going active. This sets the APDS bit.

To program interrupt-driven data transfers:

- Set the APDM mask bit and clear DMAMODE, causing an APDI interrupt in the ICT Register whenever the APDS is set. No DMA request will be issued.

To enable DMA transfers:

- Set the DMAMODE bit to 1, causing a DMA request to the channel pointed to by the APDC field. No APDI is generated, irrespective of the status of APDM.

**Using DMA in Byte Mode**

Note that when using DMA in Byte mode, the first byte cannot be transferred automatically. This is because the direction of the data driver must be reversed after the host has guaranteed disabling of its drivers. This occurs after the first byte has been requested. In software:

- Set INTREVOE immediately after PAUTOFD (nAutoFd) assertion to set up reverse transfers. (The first PAUTOFD assertion occurs after the host disables its data drivers.)

- Set an interrupt for PAUTOFD (nAutoFd) false edge. Program the DMA controller, enable it, and return from interrupt.

**Setting Status Information**

Status lines are read by the host at the end of each byte transfer.

Peripheral-to-host data available on FAULT (nFault) and forward host-to-peripheral busy status on PBUSY (Busy) must be setup at least 500 ns before the automatic deassertion of PACK (nAck).

The nDataAvail flow control structure defined in the IEEE-1284 standard requires a way to update the status on the FAULT (nFault) signal line. A simple procedure in software is to:

- Set the DMA channel length to n-1.

- Set the Count Terminate Enable (CTE) bit in the DMA Control Register.

- In the DMA count-terminate interrupt handler, clear the status of data available by setting the FAULT status to false before the next byte is requested.

- Load the last byte into the APDT Register, causing that byte to transmit automatically.

If the peripheral design requires a particular status function to be explicitly forced with a guaranteed data setup time, then the processor may set an interrupt for PAUTOFD deassertion and set Background Status Defer (BSD). BSD is used the same way as in Nibble mode.
The hold-off procedure described below is available but not required. Status lines can be updated by software at their activity times and will be interpreted by the processor at the next byte completion (PACK deassertion).

In software:

- Set BSD to hold off the PACK (nAck) deassertion that completes the handshake.
- Have the interrupt service routine for the PAUTOHLI update the status values, then clear BSD and PAUTOHLM (if it was a one-time update cycle), and return from interrupt.

The clearing of BSD starts an ACKDELAY cycle and deasserts PACK (nAck) at the completion of that period automatically, thus guaranteeing data setup time.

Changing Modes

To enable application-driven termination back to Compatibility mode:

- Set the SELECTIN true-edge interrupt mask (SELINLHM). At that interrupt, set APMODE to 1 for Compatibility mode. Determine and write the proper condition of INTREVOE. Manually complete the valid-state-termination handshake described in the IEEE standard and return from interrupt. A new interrupt on SELECTIN (nSelectIn) false edge can start another negotiation.

**Byte Idle Phase**

In Byte Idle phase, the peripheral must signal the presence of new reverse data. In software:

- Assert FAULT and pulse PACK.

**Byte ID**

Byte ID mode is identical to Byte mode, except that Byte ID mode is entered with data always pending, and that data is always the IEEE-1284 ID data message. Even if there is other data available in the stream, the ID message is sent before any other pending data. When the ID message is sent the host terminates the mode and renegotiates for any further data. This mode is distinguished from Byte mode by software only.
ECP MODE

A distinction of the ECP Forward and Reverse modes is that they can be transferred to and from each another without a renegotiation back to Compatibility mode. They differ from Nibble and Byte modes in that respect.

In order to set up the Am29202 microcontroller hardware for the correct automatic handshaking protocols, the programmer must set the APMODE field to the correct value when entering and leaving ECP Forward and ECP Reverse modes.

ECP Forward

ECP Forward mode operates similarly to the Compatibility mode, except that PBUSY (Busy) is used as reverse IEEE-1284 data strobe and PACK is not used at all.

The host signals that data is available by asserting PSTROBE (nStrobe). The peripheral regulates data flow by delaying the acknowledgment of the PSTROBE assertion when the channel is busy and the buffer is still full. This acknowledgment hold-off stops the host from continuing until the buffer is emptied. The APDS bit is then set by PSTROBE assertion. When the peripheral responds to the data transfer request (via polling, interrupt service, or DMA), the API releases the hold and asserts PBUSY (Busy). Because the host data retrieval and access time is overlapped with the peripheral data transfer time, the total bus speed is high.

The software must enable the control interrupt for INIT (nInit) assertion, to correctly transfer to the ECP Reverse mode.

The PERROR (PError) line is used to signal the setup phases after negotiation and before the idle phases (the beginning of automatically handshake data transfers). It also functions as the acknowledgment of the INIT (nInit) signal, and tells the host when it can send data.

DMA transfers may be enabled for forward data using the DMAMODE bit.

FAULT (nFault) may be driven asynchronously to signal data available for transfer in ECP Reverse mode.

SELECTIN (nSelectIn) true-edge interrupts must be enabled for application-driven termination back to Compatibility mode.

Automatic Handshakes

The host signals that data is available by asserting PSTROBE (nStrobe). Once PSTROBE asserts, hardware automatically asserts PBUSY (Busy), signaling acknowledgment and readiness to receive.

If data has not yet been extracted from the data latch from the last data byte, the handshake mechanism will hold off PBUSY (Busy) assertion until the data is read from the APDT Register (irrespective of the read mechanism).

The host then responds by deasserting PSTROBE (nStrobe). A data transfer request is generated by the API hardware, along with the DATASTROBE, at PSTROBE (nStrobe) deassertion. The DATASTROBE line is pulsed automatically on PSTROBE (nStrobe) deassertion.

Finally, the peripheral automatically signals acceptance with PBUSY (Busy) deassertion.

Distinguishing Commands From Data

ECP Forward mode uses hardware handshaking to transfer eight data bits, but the context of the data is modified by the PAUTOFD (nAutoFd) signal at transfer time. The data is interpreted as a user-defined command when PAUTOFD is asserted and interpreted as target native data when PAUTOFD is deasserted.

The instance of a command byte automatically causes an ECP Command Status (ECS) condition instead of an APDS condition. In software:

- Set the ECM and the CPE bits to cause an APCI interrupt.

The hardware handshake is automatically disabled by the internal logic, and no data transfer requests occur for that byte (until the ECS/ECI condition is cleared).

In software:

- Read the command, interpret it completely, and then re-enable hardware-handshaking by clearing the ECS or ECI bits (in either the APST or APIS registers).

Using CPE

The decision to interrupt the data stream (either DMA- or interrupt-supported) for an exception byte is controlled by the Command Polarity Expected bit.

The use of the CPE bit in ECP Forward situations with only single-byte commands in long data streams is very simple. In software:

- Set CPE to 1, allowing interrupts when PAUTOFD is High (nAutoFd or HostAck is Low). Service the ECI interrupt, read the command byte from APDT to determine its meaning, set proper application-specific context, clear interrupts (to set data stream going again), and return from interrupt.

Some systems may use the command identifiers as a means to transfer a second data stream (whether thought of as an extended command stream or a second data stream). In those conditions, where a series of command bytes (command bit set) will be transferred continuously between the non-command byte stream,
the use of CPE can support easy DMA handling of both streams.

- Set CPE to 1 to detect the first command condition. In the interrupt service routine for ECI, read the command byte directly from the APDT (the handshake does not complete in this case), and set the context or condition required.
- Then, reverse the polarity of CPE and load a new address and count into the DMA controller to handle the second (command) data stream. Move the first byte of the command stream to the buffer front and release the channel by clearing ECS/ECI, and return from interrupt.

The DMA will transfer the remaining bytes in the command stream, and when the command bit changes again, the ECS/ECI will once again occur.

- Handle the transitions between conditions in the same way, alternating between DMA pointers.

Handling Deadlocks
Note that if the peripheral deadlocks during forward data transmission, the host will signal INIT (nInit), and then, expect a PERROR (PError) to allow a reverse mode transfer.

To ensure proper handling of deadlocks:
- Always accept INITs in the middle of a handshake (ECP Busy condition). They will only come if the peripheral deadlocks (stays busy in the middle of a handshake for more than 35 ms).
- Always clear the ECP Forward channel busy status whenever INIT occurs.

Changing Modes
To transfer into ECP Reverse mode:
- Set INIT true-edge interrupt mask (INITLHM). At that interrupt, set APMODE to 5 for ECP Reverse mode. Set INTREVOE, set up any DMA control variables, reverse the polarity of the INIT interrupt, and assert PERROR (PError) to begin reverse data transfer.

To enable application-driven termination back to Compatibility mode:
- Set the SELECTIN true-edge interrupt mask (SELINLHM). At that interrupt, set APMODE to 1 for Compatibility mode. Determine and write the proper condition of INTREVOE. Manually complete the valid-state-termination handshake described in the IEEE standard and return from interrupt. A new interrupt on SELECTIN (nSelectIn) false edge can start another negotiation.

ECP Reverse
ECP Reverse mode, like Byte mode, requires a special output line to reverse the data direction, driving latched output data onto the IEEE-1284 data bus. This line is called REVOE and drives the external bidirectional bus driver/latch (LS652 or ACT652). The IEEE-1284 handshake protocol allows for the timing of host data-driver disabling and of peripheral data-driver enabling for entering reverse modes, and the opposite sequence for termination.

The control interrupt for INIT (nInit) deassertion must be enabled to correctly transfer to the ECP Forward mode.

The PERROR (PError) line functions as the acknowledgment of the INIT (nInit) signal and tells the host when it can send data, in the reverse-to-forward phase.

DMA transfers for data are enabled via the DMAMODE bit.

The host signals readiness for another byte of data by asserting PAUTOFD (nAutoFd).

SELECTIN (nSelectIn) true-edge interrupts must be enabled for application-driven termination back to Compatibility mode.

The DATASTROBE line is not activated, once in this mode.

Automatic Handshakes
The host signals readiness for data by requesting ECP Reverse mode. The API automatically generates APDS upon entry and automatically asserts PACK (nAck) after the ACKDELAY period. PACK (nAck) assertion from the peripheral is answered by PAUTOFD (nAutoFd) deassertion signaling acknowledgment.

The API logic responds to PAUTOFD (nAutoFd) deassertion by causing automatic PACK (nAck) deassertion handshake, and PACK (nAck) deassertion by the peripheral is answered by a PAUTOFD (nAutoFd) assertion from the host, signaling an end to the handshake for the byte. This final phase causes another data transfer request.

In software:
- Set the ACKLEN field to an appropriate data setup time in MEMCLK cycles.

Data Transfers
A data transfer is automatically requested in two different situations.

When the interface is first changed from ECP Forward to ECP Reverse, the data transfer request is set, allowing the programmer to setup the DMA control variables and then transfer to ECP Reverse without being required to “prime the pump” (which entails writing the first byte into
the APDT Register from the program and loading the DMA controller for n-1 bytes).

Once ECP Reverse mode is established, PAUTOFD (nAutoFd) assertion at the end of a transfer automatically causes the next data transfer request.

To enable reverse data transfers:

- Set INTREVOE immediately after the PAUTOFD (nAutoFd) assertion.

To program interrupt-driven data transfers:

- Set the APDM mask bit and clear DMAMODE, causing a APDI interrupt in the ICT Register whenever the APDS is set. No DMA request will be issued.

To enable DMA transfers:

- Set the DMAMODE bit to 1, causing a DMA request to the channel pointed to by the APDC field. No APDI is generated, irrespective of the status of APDM.

**Distinguishing Commands From Data**

ECP Reverse mode uses hardware handshaking to transfer eight data bits to the host, but the context of the data may be modified by the PBUSY (Busy) signal.

- To transfer data using DMA, force AFBUSY to the condition required for the data stream, sending all bytes as data.
- To send commands using DMA, set the DMA byte count for the stretch of non-command data, allowing automatic handshaking and DMA data support.
- Set the CTE bit in the DMA Control Register.

Then, on the DMA count-terminate interrupt, the processor may assert the command bit and send a single command byte by writing AFBUSY and writing the command byte directly to the APDT.

- Program the next stretch of non-command data into the DMA byte length for the next automatic handshaking period.

If data transfer is handled by APDI interrupts only, then each individual request for data may be used to set both reverse data into the APDT, as well as the command status into AFBUSY.

**Changing Modes**

To transfer directly into ECP Forward mode:

- Set INIT false-edge interrupt mask (INITHLM). At that interrupt, set APMODE to 4 for ECP Forward mode. Set INTREVOE to 0 and assert PSTROBE (nStrobe) to begin forward data transfer.

If the host transitions back to ECP Forward mode with the INIT (nInit) deassertion, pending data transfer requests must be cleared before returning to ECP Forward mode. In software:

- Write a 1 to the APDS (after disabling the DMA controller if used).

To enable application-driven termination back to Compatibility mode:

- Set the SELECTIN true-edge interrupt mask (SELINLHM). At that interrupt, set APMODE to 1 for Compatibility mode. Determine and write the proper condition of INTREVOE. Manually complete the valid-state-termination handshake described in the IEEE standard and return from interrupt. A new interrupt on SELECTIN (nSelectIn) false edge can start another negotiation.

**ECP Reverse ID**

ECP Reverse ID mode is identical to ECP Reverse mode, except that ECP Reverse ID mode is entered with data always pending, and that data is always the IEEE-1284 ID data message. Even if there is other data available in the stream, the ID message is sent before any other pending data. When the ID message is sent, the host terminates the mode and renegotiates for any further data. This mode is distinguished from ECP Reverse mode by software only.
ABSOLUTE MAXIMUM RATINGS

Storage Temperature ................. –65°C to +125°C
Voltage on any Pin
with Respect to GND ................. –0.5 to VCC +0.5 V
Maximum VCC .......................... 6.0 V DC

Stresses outside the stated ABSOLUTE MAXIMUM RATINGS may cause permanent device failure. Functionality at or above these limits is not implied. Exposure to absolute maximum ratings for extended periods may affect device functionality.

OPERATING RANGES

Commercial (C) Devices
Case Temperature (Tc) ................. 0°C to +85°C (C)
Supply Voltage (Vcc) .................... +4.75 to +5.25 V

Operating ranges define those limits between which the functionality of the device is guaranteed.

DC CHARACTERISTICS over COMMERCIAL Operating Range

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter Description</th>
<th>Test Conditions</th>
<th>Notes</th>
<th>Advance Information</th>
</tr>
</thead>
<tbody>
<tr>
<td>VIL</td>
<td>Input Low Voltage</td>
<td>1</td>
<td>–0.5</td>
<td>0.8 V</td>
</tr>
<tr>
<td>VILCLK</td>
<td>INCLK Input Low Voltage</td>
<td>1</td>
<td>–0.5</td>
<td>0.8 V</td>
</tr>
<tr>
<td>VILH</td>
<td>Input High Voltage</td>
<td>1</td>
<td>2.0 VCC +0.5</td>
<td></td>
</tr>
<tr>
<td>VILHCLK</td>
<td>INCLK Input High Voltage</td>
<td>2</td>
<td>VCC +0.5</td>
<td></td>
</tr>
<tr>
<td>VOL</td>
<td>Output Low Voltage for All Outputs except MEMCLK</td>
<td>IOL = 3.2 mA</td>
<td>0.45 V</td>
<td></td>
</tr>
<tr>
<td>VOH</td>
<td>Output High Voltage for All Outputs except MEMCLK</td>
<td>IOH = –400 µA</td>
<td>2.4 V</td>
<td></td>
</tr>
<tr>
<td>ILI</td>
<td>Input Leakage Current</td>
<td>0.45 V ≤ VIN ≤ VCC –0.45 V</td>
<td>2</td>
<td>±10 or +10/–200 µA</td>
</tr>
<tr>
<td>ILO</td>
<td>Output Leakage Current</td>
<td>0.45 V ≤ VOUT ≤ VCC –0.45 V</td>
<td>±10 µA</td>
<td></td>
</tr>
<tr>
<td>ICCOP</td>
<td>Operating Power Supply Current</td>
<td>VCC = 5.25 V, Outputs Floating; Holding RESET active</td>
<td>3 4 5</td>
<td>175 mA 234 mA 280 mA</td>
</tr>
<tr>
<td>VOLC</td>
<td>MEMCLK Output Low Voltage</td>
<td>IOLC = 20 mA</td>
<td>0.6 V</td>
<td></td>
</tr>
<tr>
<td>VOC</td>
<td>MEMCLK Output High Voltage</td>
<td>IOHC = –20 mA</td>
<td>VCC –0.6 V</td>
<td></td>
</tr>
</tbody>
</table>

Notes:
1. All inputs except INCLK.
2. The Low input leakage current is –200 µA for the following inputs: TCK, TDI, TMS, TRST, DREQ1, WAIT, INTR2, and INTR0. These pins have weak internal pull-up transistors.
3. ICC measured at 12.5 MHz, Vcc=5.25 V, Reset Condition.
4. ICC measured at 16.7 MHz, Vcc=5.25 V, Reset Condition.
5. ICC measured at 20.0 MHz, Vcc=5.25 V, Reset Condition.

CAPACITANCE

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Parameter Description</th>
<th>Test Conditions</th>
<th>Advance Information</th>
</tr>
</thead>
<tbody>
<tr>
<td>CIN</td>
<td>Input Capacitance</td>
<td></td>
<td>Min 15</td>
</tr>
<tr>
<td>CINCLK</td>
<td>INCLK Input Capacitance</td>
<td></td>
<td>15 pF</td>
</tr>
<tr>
<td>CMEMCLK</td>
<td>MEMCLK Capacitance</td>
<td>fC = 10 MHz</td>
<td>20 pF</td>
</tr>
<tr>
<td>COUT</td>
<td>Output Capacitance</td>
<td></td>
<td>20 pF</td>
</tr>
<tr>
<td>CI/O</td>
<td>I/O Pin Capacitance</td>
<td></td>
<td>20 pF</td>
</tr>
</tbody>
</table>

Note:
Limits guaranteed by characterization.
## SWITCHING CHARACTERISTICS over COMMERCIAL Operating Range

<table>
<thead>
<tr>
<th>No.</th>
<th>Parameter Description</th>
<th>Test Conditions (Note 1)</th>
<th>Advance Information</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td>20 MHz</td>
</tr>
<tr>
<td>1</td>
<td>INCLK Period (=0.5T)</td>
<td>Note 2, 9</td>
<td>Min</td>
</tr>
<tr>
<td>2</td>
<td>INCLK High Time</td>
<td>Note 2</td>
<td>9</td>
</tr>
<tr>
<td>3</td>
<td>INCLK Low Time</td>
<td>Note 2</td>
<td>9</td>
</tr>
<tr>
<td>4</td>
<td>INCLK Rise Time</td>
<td>Note 2</td>
<td>4</td>
</tr>
<tr>
<td>5</td>
<td>INCLK Fall Time</td>
<td>Note 2</td>
<td>4</td>
</tr>
<tr>
<td>6</td>
<td>MEMCLK Delay from INCLK</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>Synchronous Output Valid Delay from MEMCLK Rising Edge</td>
<td>Note 3a</td>
<td>1</td>
</tr>
<tr>
<td>7a</td>
<td>Synchronous Output Valid Delay from MEMCLK Rising Edge</td>
<td>Note 3a</td>
<td>1</td>
</tr>
<tr>
<td>7b</td>
<td>Synchronous Output Valid Delay from MEMCLK Falling Edge</td>
<td>Note 3b</td>
<td>1</td>
</tr>
<tr>
<td>8</td>
<td>Synchronous Output Disable Delay from MEMCLK Rising Edge</td>
<td>Note 8</td>
<td>1</td>
</tr>
<tr>
<td>9</td>
<td>Synchronous Input Setup Time</td>
<td></td>
<td>10</td>
</tr>
<tr>
<td>10</td>
<td>Synchronous Input Hold Time</td>
<td></td>
<td>0</td>
</tr>
<tr>
<td>11</td>
<td>Asynchronous Pulse Width</td>
<td>Note 4a, 9</td>
<td>4T</td>
</tr>
<tr>
<td>11a</td>
<td>Asynchronous Pulse Width</td>
<td>Note 4b</td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>MEMCLK High Time</td>
<td>Note 5</td>
<td>0.5T–3</td>
</tr>
<tr>
<td>13</td>
<td>MEMCLK Low Time</td>
<td>Note 5</td>
<td>0.5T–3</td>
</tr>
<tr>
<td>14</td>
<td>MEMCLK Rise Time</td>
<td>Note 5</td>
<td>0</td>
</tr>
<tr>
<td>15</td>
<td>MEMCLK Fall Time</td>
<td>Note 5</td>
<td>0</td>
</tr>
<tr>
<td>16</td>
<td>UCLK, VCLK Period</td>
<td>Note 2</td>
<td>25</td>
</tr>
<tr>
<td>17</td>
<td>UCLK, VCLK High Time</td>
<td>Note 2, 8</td>
<td>9</td>
</tr>
<tr>
<td>18</td>
<td>UCLK, VCLK Low Time</td>
<td>Note 2, 8</td>
<td>9</td>
</tr>
<tr>
<td>19</td>
<td>UCLK, VCLK Rise Time</td>
<td>Note 2</td>
<td>4</td>
</tr>
<tr>
<td>20</td>
<td>UCLK, VCLK Fall Time</td>
<td>Note 2</td>
<td>4</td>
</tr>
<tr>
<td>21</td>
<td>Synchronous Output Valid Delay from VCLK Edge</td>
<td>Note 6</td>
<td>1</td>
</tr>
<tr>
<td>22</td>
<td>Input Setup Time to VCLK Edge</td>
<td>Note 6, 7</td>
<td>10</td>
</tr>
<tr>
<td>23</td>
<td>Input Hold Time to VCLK Edge</td>
<td>Note 6, 7</td>
<td>0</td>
</tr>
<tr>
<td>24</td>
<td>TCK Frequency</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### Notes:
1. All outputs driving 80 pF, measured at V<sub>OL</sub>=1.5 V and V<sub>OH</sub>=1.5 V. For higher capacitance, add 1 ns output delay per 20 pF loading, up to 300 pF total capacitance.
2. INCLK, VCLK, and UCLK can be driven with TTL inputs. If not used, UCLK must be tied High.
3. a. Parameter 7a applies only to the outputs PIO15–PIO4 and DACR1. Parameter 7 applies to the remaining outputs.
   b. Parameter 7b applies only to the outputs RASx, CASx, RSWE, and ROMOE. Some of these signals can also be asserted during the rising edge of MEMCLK, depending on the type of access being performed.
4. a. Parameter 11 applies to all asynchronous inputs except LSYNC and PSYNC.
   b. The LSYNC and PSYNC minimum width time is two bit-times. One bit-time corresponds to one internal video clock period. The internal video clock period is a function of the VCLK period and the programmed VCLK divisor.
5. MEMCLK can drive an external load of 100 pF.
6. Active VCLK edge depends on the CLKI bit in the Video Control Register.
7. LSYNC and PSYNC may be treated as synchronous signals by meeting setup and hold times. The synchronization delay still applies.
8. Not production tested but guaranteed by design or characterization.
9. T=1 MEMCLK period, as defined by the actual frequency on the MEMCLK pin.
SWITCHING WAVEFORMS

INCLK

MEMCLK

Synchronous Outputs

Synchronous Inputs

Asynchronous Inputs

UCLK, VCLK

VCLK-Relative Outputs

VCLK-Relative Inputs

Note: Video Timing may be relative to VCLK falling edge if CLKI = 1.
SWITCHING TEST CIRCUIT

Model of Dynamic Test Load

Note:

$C_L$ is guaranteed to be a minimum 80-pF parasitic load. It represents the distributed load parasitic attributed to the test hardware and instrumentation present during production testing.

THERMAL CHARACTERISTICS

PQFP Package

The Am29202 microcontroller is specified for operation with case temperature ranges for a commercial temperature device. Case temperature is measured at the top center of the package as shown in the figure below.

The various temperatures and thermal resistances can be determined using the following equations along with information given in Table 12. (The variable $P$ is power in watts.)

$$
\theta_{JA} = \theta_{JC} + \theta_{CA}
$$

$$
P = I_{CCOP} \cdot V_{CC}
$$

$$
T_J = T_C + P \cdot \theta_{JC}
$$

$$
T_J = T_A + P \cdot \theta_{JA}
$$

$$
T_C = T_J - P \cdot \theta_{JC}
$$

$$
T_C = T_A + P \cdot \theta_{CA}
$$

$$
T_A = T_J - P \cdot \theta_{JA}
$$

$$
T_A = T_C - P \cdot \theta_{CA}
$$

Allowable ambient temperature curves for various airflows are given in Figures 26 and 27. These graphs assume a maximum $V_{CC}$ and a maximum power supply current equal to $I_{CCOP}$. All calculations made using the above information should guarantee that the operating case temperature does not exceed the maximum case temperature. Since $P$ is a function of operating frequency, calculations can also be made to determine the ambient temperature at various operating speeds.
**Table 12. PQFP Thermal Characteristics (°C/Watt) Surface Mounted**

<table>
<thead>
<tr>
<th>Am29202 Microcontroller</th>
<th>Airflow—ft./min. (m/sec)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0 (0)</td>
</tr>
<tr>
<td></td>
<td>200 (1.01)</td>
</tr>
<tr>
<td></td>
<td>400 (2.03)</td>
</tr>
<tr>
<td></td>
<td>600 (3.04)</td>
</tr>
<tr>
<td>θ_{JA} Junction-to-Ambient</td>
<td>36</td>
</tr>
<tr>
<td>θ_{JC} Junction-to-Case</td>
<td>8</td>
</tr>
<tr>
<td>θ_{CA} Case-to-Ambient</td>
<td>28</td>
</tr>
</tbody>
</table>

**Figure 26. Maximum Allowable Ambient Temperature**
(Data Sheet Limit, I_{CCOPmax}, V_{CC}=+5.25 V, Average Thermal Impedance)

**Figure 27. Thermal Impedance**
PHYSICAL DIMENSIONS
PQB 132, Trimmed and Formed
Plastic Quad Flat Pack (measured in inches)

Note:
Not to scale. For reference only.
PQB 132 (continued)

Section S–S

Detail X

Note:
Not to scale. For reference only.

Trademarks

High C is a registered trademark of MetaWare, Inc.
Microsoft and Windows are registered trademarks of Microsoft Corp.

Product names used in this publication are for identification purposes only and may be trademarks of their respective companies.
© 1995 Advanced Micro Devices, Inc.