Rockwell International

Semiconductor Products Division \\ \section*{CONTROLLIER PRODOCTS \\ \section*{CONTROLLIER PRODOCTS DHMA BOOR} DHMA BOOR}

# 1987 CONTROLLER PRODUCTS DATA BOOK 



# Rockwell International 

Semiconductor Products Division

Rockwell Semiconductor Products Division is headquartered in Newport Beach, California with Field Sales Offices located throughout the United States, Canada, Europe and the Far East. Their listings, plus those of domestic and international representatives and distributors, appear in Appendix A.

DEFINITION OF DOCUMENT TYPES

| Document Type | Product Status | Definition |
| :--- | :--- | :--- |
| Product Preview | Formative or <br> Development | The document type contains the general features and/or specifications for a product <br> in definition or development. The features and/or specifications may change in any <br> manner without notice. |
| Product Summary | Development or <br> Production | This document type contains the general features and/or specifications of a product <br> in development or in production. Additional information is usually available in a sepa- <br> rate document, not contained in this book, such as a Designer's Guide. |
| Data Sheet | Sampling or <br> Pre-Production | This document type contains preliminary or design-to-characteristic data for a product <br> in pre-production. Additional and/or refined characteristic data will be released in <br> subsequent revisions to the document. |
| Data Sheet | Production | This document type contains final specification information resulting from measured <br> characteristics. This document type is subject to revision if characteristics are further <br> refined during production. |
| Product Description | Production | This document type contains final specification information resulting from measured <br> characteristics along with additional application aid information. This document type <br> is subject to revision if characteristics are further refined during production. |
| Application Note | Development or <br> Production | This document type contains application aids in the use of the subject product. Sche- <br> matics included in an application note are intended to convey system design concept <br> only. |


#### Abstract

\section*{NOTICE}

Information furnished by Rockwell International Corporation is believed to be accurate and reliable. However, no responsibility is assumed by Rockwell International for its use, nor any infringement of patents or other rights of third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of Rockwell International other than for circuitry embodied in a Rockwell product. Rockwell International reserves the right to change circuitry at any time without notice. All document in this book are subject to change without notice.


## TABLE OF CONTENTS

Part No./Data Book Page Index ..... iv
Controller Products - Providing Solutions for Your VLSI Requirements ..... V
Product Index ..... vii
1 CMOS 8-Bit Microprocessors \& Peripherals ..... 1-1
Product Family Overview ..... 1-2
R65C02, R65C102 and R65C112 Microprocessors (CPU) ..... 1-3
R65C21 Peripheral Interface Adapter (PIA) ..... 1-19
R65C22 Versatile Interface Adapter (VIA) ..... 1-31
R65NC22 Versatile Interface Adapter (VIA) ..... 1-53
R65C24 Peripheral Interface Adapter/Timer (PIAT) ..... 1-75
R65C51 Asynchronous Communications Interface Adapter (ACIA) ..... 1-95
R65C52 Dual Asynchronous Communications Interface Adapter (DACIA) ..... 1-116
2 NMOS 8-Bit Microprocessors \& Peripherals ..... 2-1
Product Family Overview ..... 2-2
R650X and R651X Microprocessors (CPU) ..... 2-3
R6520 Peripheral Interface Adapter (PIA) ..... 2-18
R6522 Versatile Interface Adapter (VIA) ..... 2-30
R6532 RAM-I/O-Timer (RIOT) ..... 2-52
R6545/R6545E CRT Controller (CRTC) ..... 2-62
R6549 Color Video Display Generator (CVDG) ..... 2-81
R6551 Asynchronous Communications Interface Adapter (ACIA) ..... 2-112
3 8-Bit Microcomputers ..... 3-1
Product Family Overview ..... 3-2
R65C10 One-Chip Microcomputer ..... 3-3
R6500/1 One-Chip Microcomputer ..... 3-26
R6500/1E Microprocessor Emulator Device ..... 3-49
R6500/1EB Backpack Emulator ..... 3-57
R6500/11, /12 and /15 One-Chip Microcomputers ..... 3-63
R65/11EB Backpack Emulators ..... 3-98
R6501 One-Chip Microprocessor ..... 3-103
R6511Q One-Chip Microprocessor and R6500/13 One-Chip Microcomputer ..... 3-138
R6518 One-Chip Microprocessor ..... 3-173
R65F11 and R65F12 FORTH Based Microcomputers ..... 3-203
R65FRx FORTH Development and Kernel ROMs ..... 3-235
4 16-Bit Microprocessors and Peripherals ..... 4-1
Product Family Overview ..... 4-2
R68000 16-bit Microprocessing Unit (MPU) ..... 4-3
R68C552 Dual Asynchronous Communications Interface Adapter (DACIA) ..... 4-62
R68560 Multi-Protocol Communications Controller (MPCC) ..... $4-83$
5 Intelligent Display Controllers ..... 5-1
Product Family Overview ..... 5-2
10937 and 10957 Alphanumeric Display Controller ..... 5-3
10938 and 10939 Dot Matrix Display Controller ..... 5-11
10939, 10942 and 10943 Dot Matrix Display Controller ..... 5-21
10941 and 10939 Alphanumeric and Bargraph Display Controller ..... 5-31
10951 Bargraph and Numeric Display Controller ..... 5-41
10955 Segmented Display Controller/Driver ..... 5-51
6 Application Notes ..... 6-1
Low-Cost Crystal Oscillator for Clock Input ..... 6-3
R6500/R6532 Timer Interrupt Precautions ..... 6-4
A Dot Matrix Controller System Design Using 10938/10939 Display Drivers and R6500/1EB Microcomputer ..... 6-6
Intelligent Display Controller Designer's Notes ..... 6-22
A SPD Regional Offices and U.S./Canada Sales Reps ..... A-1
SPD Industrial Distributors ..... A-3
SPD International Distributors/Sales Reps ..... A-6
Notes ..... A. 7

## PART NO./DATA BOOK PAGE INDEX

Part No./Description ..... Page
10937 and 10957 Alphanumeric Display Controller ... ..... 5-3
10938 and 10939 Dot Matrix Display Controller ..... 5-11
10939, 10942 and 10943 Dot Matrix Display Controller ..... 5-21
10941 and 10939 Alphanumeric and Bargraph Display Controller ..... 5-31
10951 Bargraph and Numeric Display Controller ..... 5-41
10955 Segmented Display Controller/Driver ..... 5-51
R65/11EB Backpack Emulators ..... 3-98
R6500/1 One-Chip Microcomputer ..... 3-26
R6500/11, /12 and /15 One-Chip Microcomputer ..... 3-63
R6500/1E Microprocessor Emulator Device ..... 3-49
R6500/1EB Backpack Emulator ..... 3-57
R6501 One-Chip Microprocessor ..... 3-103
R650X Microprocessors (CPU) ..... 2-3
R6511Q One-Chip Microprocessor and
R6500/13 One-Chip Microcomputer ..... 3-138
R6518 One-Chip Microprocessor ..... 3-173
R6520 Peripheral Interface Adapter (PIA) ..... 2-18
R6522 Versatile Interface Adapter (VIA) ..... 2-30
R6532 RAM-I/O-Timer (RIOT) ..... 2-52
Part No./DescriptionR6545 CRT Controller (CRTC)2-62
R6549 Color Video Display Generator (CVDG) ..... 2-81
R6551 Asynchronous Communications Interface Adapter (ACIA) ..... 2-112
R65C02 Microprocessors (CPU) ..... 1-3
R65C10 One-Chip Microcomputer ..... 3-3
R65C21 Peripheral Interface Adapter (PIA) ..... 1-19
R65C22 Versatile Interface Adapter (VIA) ..... 1-31
R65C24 Peripheral Interface Adapter/Timer (PIAT) ..... 1-75
R65C51 Asynchronous Communications Interface Adapter (ACIA) ..... 1-95
R65C52 Dual Asynchronous Communications Interface Adapter (DACIA) ..... 1-116
R65F11 and R65F12 FORTH Based Microcomputers. ..... 3-203
R65FRx FORTH Development and Kernel ROMs ..... 3-235
R65NC22 Versatile Interface Adapter (VIA) ..... 1-53
R68000 16-bit Microprocessing Unit (MPU) ..... 4-3
R68560 Multi-Protocol Communications Controller (MPCC) ..... 4-83
R68C552 Dual Asynchronous Communications Interface Adapter (DACIA) ..... 4-62

## CONTROLLER PRODUCTS Providing Solutions for Your VLSI Requirements

Rockwell International designs and manufactures a family of VLSI products to serve your system requirements. As shown in the diagram below, compatible controller products are available for a wide range of 16 -bit and 8 -bit applications. Peripheral devices operate on either the 68000 or the 6500 microprocessor bus structure. Many of the peripheral devices are now being used on additional bus structures such as 8085,80286 and Z80, just to name a few.
The product line utilizing the R6502 processor, recognized world-wide for its high performance, was recently improved by redesigning it in a CMOS process. Enhancements include a $200 \%$ improvement in speed and a 20 times reduction in power dissipation.

These products are produced in high volume at a modern state-of-the-art facility located in Newport Beach, California, and are packaged in a newly constructed, fully automated manufacturing facility in Mexicali, Mexico. The class 10,000 clean room environment produces devices to the most stringent industry standards. Rockwell has the organization, systems and support to manufacture products to existing and future quality levels.

In fact, Rockwell is the first and only semiconductor company to offer a 5 year warranty. You can rely on customer satisfaction and service when choosing a Rockwell semiconductor product.


Serving System Requirements

## PRODUCT INDEX

## CMOS 8-Bit Microprocessors \& Peripherals

## NMOS 8-Bit Microprocessors \& Peripherals

## 8-Bit Microcomputers

## Intelligent Display Controllers

## Application Notes

## Section 1 CMOS 8-Bit Microprocessors \& Peripherals

Page
Product Family Overview ..... 1-2
R65C02, R65C102 and R65C112 Microprocessors (CPU) ..... 1-3
R65C21 Peripheral Interface Adapter (PIA) ..... 1-19
R65C22 Versatile Interface Adapter (VIA) ..... 1-31
R65NC22 Versatile Interface Adapter (VIA) ..... 1-53
R65C24 Peripheral Interface Adapter/Timer (PIAT) ..... 1-75
R65C51 Asynchronous Communications Interface Adapter (ACIA) ..... 1-95
R65C52 Dual Asynchronous Communications Interface Adapter (DACIA) ..... 1-116

## CMOS 8-bit Microprocessors \& Peripherals Fastest Executing - Low Power

There is no CMOS microprocessor family easier to implement than the R65CXX. It is the fastest instruction executing 8 -bit family available. It's software compatible with a family of single-chip microcomputers and has three powerful CPUs and peripherals for parallel and serial I/O.

In the 8 -bit range, nothing gives faster instruction execution ( $500 \mu \mathrm{~s}$ ) with most parts available in $1,2,3$ and 4 MHz versions. Thirteen address modes provide the most efficient ways of addressing memory. R65CXX peripherals are system oriented, designed to implement systems with minimum device count.

Because of its inherent characteristics, advanced Rockwell CMOS provides low power consumption, high noise immunity and high speed operation. Its 2 MHz CPU dissipates only 40 mW (compared to 800 mW in NMOS) and requires only 10 mA standby current. Instruction memory requirements are $20 \%$ less due to added bit manipulation features.
The entire 8-bit R65CXX family is upward compatible with the 16 -bit 68000 bus, software compatible with Rockwell's 8 -bit microcomputers, and are the building blocks for a wide range of system applications. It's one of the world's highest performing and lowest cost microprocessors.


CMOS R65CXX Microprocessor Family

## R65C02, R65C102 and R65C112 R65C00 Microprocessors (CPU)

## DESCRIPTION

The 8 -bit R65C00 microprocessor family of devices are produced using CMOS silicon gate technology which provides advanced system architecture for performance speed and system costeffectiveness enhancements over their NMOS counterparts, the R6500 family of microprocessor devices.

Three CPU devices are available. All are software-compatible and provide 64 K bytes of memory addressing, two interrupt inputs, and on-chip clock oscillators and/or drivers. All are bus-compatible with the NMOS R6500 family devices.

The CMOS family includes two microprocessors (R65C02 and R65C102) with on-board clock oscillators and drivers and one microprocessor (R65C112) driven by an external clock. The on-chip clock versions are aimed at high performance, low-cost applications where single phase inputs, crystal or RC inputs provide the time base. The slave processor version is geared for multiprocessor system applications where maximum timing control is mandatory. All R65C00 microprocessors are available in ceramic and plastic packaging, operating frequency of $1 \mathrm{MHz}, 2 \mathrm{MHz}, 3 \mathrm{MHz}$ and 4 MHz , and commercial and industrial temperature versions. All three devices are available in 40-pin DIP or 44-pin PLCC packages.

## MAJOR FEATURES AND DIFFERENCES

| Feature | R65C02 | R65C102 | R65C112 |
| :--- | :---: | :---: | :---: |
| Pin compatible with NMOS R6502 | X |  |  |
| 64K addressable bytes of memory | X | X | X |
| IRQ interrupt | X | X | X |
| On-chip clock oscillator |  | X |  |
| External clock only | X |  | X |
| TTL level single phase clock input | X | X |  |
| RC time base clock input | X | X |  |
| Crystal time base clock input | X | X |  |
| Single phase clock input |  |  | X |
| Two phase output clock | X | X |  |
| SYNC and RDY signals | X | X | X |
| Bus Enable (BE) signal |  | X | X |
| Memory Lock (ML) output signal |  | X | X |
| Direct Memory Access (DMA) capacity |  | X | X |
| NMI interrupt signal | X | X | X |

## FEATURES

- CMOS silicon gate technology
- Low Power (4 mA/MHz)
- Software compatible with R6502
- Single $5 \mathrm{~V} \pm 5 \%$ power supply requirements
- Eight-bit parallel processing
- Decimal and binary arithmetic
- True indexing capability
- Programmable stack pointer
- Interrupt capability
- Non-maskable interrupt
- Eight-bit bidirectional data bus
- Memory address range of up to 64 K bytes
- "Ready" input
- Direct memory access (DMA) capability
- Memory lock output
- $1 \mathrm{MHz}, 2 \mathrm{MHz}, 3 \mathrm{MHz}$, and 4 MHz versions
- Choice of external or on-chip clocks
- On-chip clock options
-External single clock input
—Direct crystal input ( $\div 4$ )
- Commercial and industrial temperature versions
- Pipeline architecture
- Slave processor version (R65C112)


## ORDERING INFORMATION

```
Part Number:
R65C02
R65C102 --
R65C112
```



```
                                    Blank = 0 O C to +70'C
                    E = -40 % to + 85 %
                    M = - 55 % C to 125' C
            -Frequency Range
            1 = 1 MHz
            2=2 MHz
                        3=3MHz
                4=4MHz
            Package
                C = 40-Pin Ceramic DIP
                P = 40-Pin Plastic DIP
                J = 44-Pin Plastic Leaded Chip
                    Carrier (PLCC)
```


## INTERFACE SIGNALS

Figure 1 shows the pin assignments for the members of the R65C00 CPU family. All devices are housed in 40-pin ceramic or plastic dual-in-line (DIP) or 44-pin plastic leaded chip carrier (PLCC) packages.
Refer to the timing diagrams (Figures 3,4 , and 5 ) for the particular device in the following discussion.

## CLOCK SIGNALS (R65C02)

The R65C02 requires an external $\emptyset 0$ clock. See Figure 6 for an example clock circuit. $\emptyset 0$ is a TTL level input that is used to generate the internal clocks of the R65C02. Two full level output clocks are generated by the R65C02. The $\emptyset 2$ clock is in phase with $\emptyset 0$. The $\emptyset 1$ clock output is $180^{\circ}$ out of phase with $\emptyset 0$. When the input clock is stopped, the CPU is in the standby mode. See Figure 8 for special standby mode considerations.
For non-critical timing configurations, a simple RC or crystal network may be strapped between $\emptyset 0$ (IN) and $\emptyset 1$ (OUT).

## CLOCK SIGNALS (R65C102)

The R65C102 internal clocks may be generated by a TTL level single phase input, an RC time base input, or a crystal time base input ( $\div 4$ ) using the XTLO and XTLI input pins. See Figure 7 for an example of a crystal time base circuit. Two full level output clocks are generated by the R65C102. The $\emptyset 2$ clock output provides timing for external $\mathrm{R} / \overline{\mathrm{W}}$ operations. Addresses are valid after the address delay time ( $\mathrm{t}_{\mathrm{ADS}}$ ) referenced to the falling edge of $\emptyset 2$ (OUT). The $\emptyset 4$ output is a quadrature output clock that is delayed from the falling edge of the $\emptyset 2$ clock by delay time $t_{\text {AVs }}$. Using the $\emptyset 4$ clock, addresses are valid at the rising edge of $\emptyset 4$.

## CLOCK SIGNALS (R65C112)

All internal clock signals for the R65C112 are generated by the input clock signal $\emptyset 2(\mathbb{N})$. Since this device is intended to be operated in the slave mode it does not have internal clock generation, but rather requires the external clock $\emptyset 2$ (IN) from a host device. Figure 7 shows an example of a clock circuit for the R65C112 configured for slave mode.

## ADDRESS BUS (A0-A15)

Address lines A0-A15 form a 16-bit address bus for memory and I/O exchanges on the data bus. The output of each address line is TTL compatible, capable of driving one standard TTL load and 130 pF .

## DATA BUS (D0-D7)

The data lines (D0-D7) constitute an 8-bit bidirectional data bus used for data exchanges to and from the device and peripherals. The outputs are tri-state buffers capable of driving one TTL load and 130 pF .

## BUS ENABLE (BE)

This signal allows external control of the data and the address output buffers and $\mathrm{R} / \overline{\mathrm{W}}$. For normal operation, BE is high causing the address buffers and $\mathrm{R} / \overline{\mathrm{W}}$ to be active and the data buffers to be active during a write cycle. For external control, BE is held low to disable the buffers. BE is an asynchronous signal and
therefore not related to, or controlled by the CPU internal clock signals. Figure 5 shows timing relationships of $B E$ to $R / \bar{W}$ and address output buffers.

## INTERRUPT REQUEST ( $\overline{\mathrm{RQ}}$ )

This TTL compatible input requests that an interrupt sequence begin within the microprocessor. $\overline{\mathrm{RQ}}$ is sampled at the falling edge of $\emptyset 2$ prior to the last cycle of the instruction; if the interrupt flag in the processor status register is zero, the current instruction is completed and the interrupt sequence begins during $\emptyset 1$. The program counter and processor status register are stored in the stack. The microprocessor will then set the interrupt mask flag high so that no further $\overline{\mathrm{IRQ}}$ s may occur. At the end of this cycle, the program counter low byte will be loaded from address FFFE, and program counter high byte from location FFFF, thus transferring program control to the memory vector located at these addresses. The RDY signal must be in the high state for any interrupt to be recognized. A 3K ohm external resistor should be used for proper wire OR operation.

## MEMORY LOCK ( $\overline{\mathrm{ML}}$ )

In a multiprocessor system, the $\overline{M L}$ output indicates the need to defer the rearbitration of the next bus cycle to ensure the integrity of read-modify-write instructions. $\overline{\mathrm{ML}}$ goes low during ASL, DEC, INC, LSR, ROL, ROR, RMB, SMB, TRB, TSB memory referencing instructions. This signal is low for the modify and write cycles.

## NON-MASKABLE INTERRUPT (NMI)

A negative-going edge on this input requests that a nonmaskable interrupt sequence be generated within the microprocessor. The $\overline{N M I}$ is sampled during $\emptyset 2$; the current instruction is completed and the interrupt sequence begins during $\emptyset 1$. The program counter is loaded with the interrupt vector from locations FFFA (low byte) and FFFB (high byte), thereby transferring program control to the non-maskable interrupt routine.

## NOTE

Since this interrupt is non-maskable, another $\overline{\text { NMI }}$ can occur before the first is finished. Care should be taken when using $\overline{\mathrm{NMI}}$ to avoid this.

## READY (RDY)

This input allows the user to single-cycle the microprocessor on all cycles including write cycles. A negative transition to the low state, during or coincident with $\emptyset 2$, will halt the microprocessor with the output address lines reflecting the current address. This condition will remain through a subsequent $\emptyset 2$ in which the RDY signal is low. This feature allows microprocessor interfacing with low-speed memory as well as direct memory access (DMA).

## READ/WRITE (R/W)

This signal is normally in the high state indicating that the microprocessor is reading data from memory or I/O bus. In the low state the data bus has valid data from the microprocessor to be stored at the addressed memory location.

## SET OVERFLOW ( $\overline{\mathbf{S O}})$

A negative transition on this line sets the overflow bit $(\mathrm{V})$ in the processor status register. The signal is sampled prior to the rising edge of $\emptyset 2$ by the $\overline{\mathrm{SO}}$ setup time ( $\mathrm{t}_{\mathrm{sos}}$ ).

|  | a. R65C02 <br> 44-PIN PLCC |
| :---: | :---: |
|  | b. R65C102 <br> 44-PIN PLCC |
|  <br> 40-PIN DIP |  |

Figure 1. Pin Assignments

## RESET ( $\overline{\operatorname{RES}}$ )

This input resets the microprocessor. Reset must be held low for at least two clock cycles after $\mathrm{V}_{\text {cc }}$ reaches operating voltage from a power down. A positive transition on this pin will then cause an initialization sequence to begin. Likewise, after the system has been operating, a low on this line of at least two cycles will cease microprocessing activity, followed by initialization after the positive edge on RES.
When a positive edge is detected, there is an initialization sequence lasting seven clock cycles. Then the interrupt mask flag is set, the decimal mode is cleared, and the program counter is loaded with the restart vector from locations FFFC (low byte) and FFFD (high byte). This is the start location for program control. This input should be high in normal operation.

## SYNCHRONIZE (SYNC)

This output line identifies those cycles during which the microprocessor is fetching the instruction operation code (OP CODE). The SYNC line goes high during $\emptyset 1$ of an OP CODE fetch and stays high for the remainder of that cycle. If the RDY line is pulled low during the clock cycle in which SYNC went high, the processor will stop in its current state and will remain in the state until the RDY line goes high. In this manner, the SYNC signal can be used to controI RDY to cause single instruction execution.

## FUNCTIONAL DESCRIPTION

Figure 2 shows the block diagram of the R65C00 CPU internal architecture for all three devices. With the exception of the crystal oscillator, clock signals, Memory Lock (ML), and Bus Enable (BE) signals, the internal architecture of the three members of the R65C00 CPU of devices is identical. This block diagram supports the following text that describes the function of each of the device's major elements.

## CRYSTAL OSCILLATOR (R65C102 Only)

The crystal oscillator, driven by a crystal across XTLO and XTLI, divides the crystal frequency by four to provide the basic $\emptyset 2$ clock signal that drives the internal clock generator.

## CLOCK GENERATOR

The clock generator develops all internal clock signals, and (where applicable) external clock signals, associated with the device. It is the clock generator that drives the timing control unit and the external timing for slave mode operations.

## TIMING CONTROL

The timing control unit keeps track of the instruction cycle being monitored. The unit is set to zero each time an instruction fetch is executed and is advanced at the beginning of each phase one clock pulse for as many cycles as is required to complete the instruction. Each data transfer which takes place between the registers depends upon decoding the contents of both the instruction register and the timing control unit.

## PROGRAM COUNTER

The 16-bit program counter provides the addresses which step the microprocessor through sequential instructions in a program.
Each time the microprocessor fetches an instruction from program memory, the lower byte of the program counter ( PCL ) is placed on the low-order bits of the address bus and the higher byte of the
program counter ( PCH ) is placed on the high-order 8 bits. The counter is incremented each time an instruction or data is fetched from program memory.

## INSTRUCTION REGISTER AND DECODE

Instructions fetched from memory are gated onto the internal data bus. These instructions are latched into the instruction register, then decoded, along with timing and interrupt signals, to generate control signals for the various registers.

## ARITHMETIC AND LOGIC UNIT (ALU)

All arithmetic and logic operations take place in the ALU including incrementing and decrementing internal registers (except the program counter). The ALU has no internal memory and is used only to perform logical and transient numerical operations.

## ACCUMULATOR

The accumulator is a general purpose 8-bit register that stores the results of most arithmetic and logic operations, and in addition, the accumulator usually contains one of the two data words used in these operations.

## INDEX REGISTERS

There are two 8 -bit index registers ( X and Y ), which may be used to count program steps or to provide an index value to be used in generating an effective address.
When executing an instruction which specifies indexed addressing, the CPU fetches the op code and the base address, and modifies the address by adding the index register to it prior to performing the desired operation. Pre- or post-indexing of indirect addresses is possible (see addressing modes).

## STACK POINTER

The stack pointer is an 8-bit register used to control the addressing of the variable-length stack on page one. The stack pointer is automatically incremented and decremented under control of the microprocessor to perform stack manipulations under direction of either the program or interrupts ( $\overline{N M I}$ and $\overline{\mathrm{RQ}}$ ). The stack allows simple implementation of nested subroutines and multiple level interrupts. The stack pointer should be initialized before any interrupts or stack operations occur.

## PROCESSOR STATUS REGISTER

The 8 -bit processor status register contains seven status flags. Some of the flags are controlled by the program, others may be controlled both by the program and the CPU. The R65C00 instruction set contains a number of conditional branch instructions which are designed to allow testing of these flags.

## HARDWARE ENHANCEMENTS

The R65C00 family of CPU devices have incorporated hardware enhancements over their NMOS counterpart, the R6502. These hardware enhancements are:

- The NMOS device would ignore the assertion of a Ready (RDY) during a write operation. The CMOS family will stop the processor during $\emptyset 2$ clock if RDY is asserted during a write operation.
- On the NMOS device, unused input-only pins ( $\overline{\mathrm{RQ}}, \overline{\mathrm{NMI}}, \mathrm{RDY}$, $\overline{\mathrm{RES}}$, and $\overline{\mathrm{SO}}$ ) must be connected to a low impedance signal to avoid noise problems. These unused pins on the CMOS devices are internally connected by a high impedance to $\mathrm{V}_{\mathrm{CC}}$ (approximately 250 K ohms).


Figure 2. R65C00 Internal Architecture

## ADDRESSING MODES

The R65C00 CPU family has 15 address modes (two more than the NMOS equivalent family). In the following discussion of these addressing modes, a bracketed expression follows the title of the mode. This expression is the term used in the Instruction Set Op Code Matrix table (later in this product description) to make it easier to identify the actual addressing mode used by the instruction.

ACCUMULATOR ADDRESSING [Accum] - This form of addressing is represented with a one byte instruction, implying an operation on the accumulator.

IMMEDIATE ADDRESSING [IMM] - In immediate addressing, the second byte of the instruction contains the operand, with no further memory addressing required.

ABSOLUTE ADDRESSING [ABS] - In absolute addressing, the second byte of the instruction specifies the eight low order bits of the effective address while the third byte specifies the eight high order bits. Thus the absolute addressing mode allows access to the entire 64 K bytes of addressable memory.

ZERO PAGE ADDRESSING [ZP] - The zero page instructions allow for shorter code and execution times by fetching only the second byte of the instruction and assuming a zero high address byte. Careful use of the zero page can result in significant increase in code efficiency.

ZERO PAGE INDEXED ADDRESSING [ZP, $X$ or $Y$ ] - ( $X, Y$ indexing) - This form of addressing is used with the index register and is referred to as "Zero Page, $X$ " or "Zero Page, $Y$ ". The effective address is calculated by adding the second byte to the contents of the index register. Since this is a form of "Zero Page" addressing, the content of the second byte references a location in page zero. Additionally, due to the "Zero Page" addressing nature of this mode, no carry is added to the high order eight bits of memory and crossing of page boundaries does not occur.

ABSOLUTE INDEXED ADDRESSING [ABS, $X$ or $Y$ ] - ( $X, Y$ indexing) - This form of addressing is used in conjunction with $X$ and $Y$ index register and is referred to as "Absolute, $X$ " and "Absolute, $Y$ ". The effective address is formed by adding the contents of $X$ or $Y$ to the address contained in the second and third bytes of the instruction. This mode allows the index register to contain the index or count value and the instruction to contain the base address. This type of indexing allows any location referencing and the index to modify fields, resulting in reduced coding and execution time.

INDEXED ABSOLUTE INDIRECT [(ABS, X)]* - The contents of the second and third instruction bytes are added to the $X$-register. The sixteen-bit result is a memory address containing the effective address. (JMP (ABS, X) only).

IMPLIED ADDRESSING [Implied] - In the implied addressing mode, the address containing the operand is implicitly stated in the operation code of the instruction.

RELATIVE ADDRESSING [Relative] - Relative addressing is used only with branch instructions and establishes a destination for the conditional branch.

The second byte of the instruction becomes the operand which is an "Offset" added to the contents of the lower eight bits of the program counter when the counter is set at the next instruction. The range of the offset is -128 to +127 bytes from the next instruction.

ZERO PAGE RELATIVE ADDRESSING [ZP REL]* - This mode bit tests the zero page location specified for bit set/reset per the mask and performs a conditional relative branch based on the results of the bit test.

INDEXED INDIRECT ADDRESSING [(IND, X)] — in indexed indirect addressing (referred to as (Indirect, X)), the second byte of the instruction is added to the contents of the X index register, discarding the carry. The result of this addition points to a memory location on page zero whose contents are the low order eight bits of the effective address. The next memory location in page zero contains the high order eight bits of the effective address. Both memory locations specifying the high and low order bytes of the effective address must be in page zero.

INDIRECT INDEXED ADDRESSING [(IND), Y] — In indirect indexed addressing (referred to as (Indirect), Y), the second byte of the instruction points to a memory location in page zero. The contents of this memory location are added to the contents of the Y index register, the result being the low order eight bits of the effective address. The carry from this addition is added to the contents of the next page zero memory location, the result being the high order eight bits of the effective address.

ABSOLUTE INDIRECT [(ABS)] - The second byte of the instruction contains the low order eight bits of a memory location. The high order eight bits of that memory location are contained in the third byte of the instruction. The contents of the fully specified memory location are the low order byte of the effective address. The next memory location contains the high order byte of the effective address which is loaded into the sixteen bits of the program counter. (JMP (ABS) only.)

INDIRECT [(IND)]* - The second byte of the instruction contains a zero page address serving as the indirect pointer.

## ENHANCEMENTS OVER R6502

The CMOS family of microprocessor devices has been designed with many enhancements over the R6502 NMOS device while maintaining software compatibility. Besides the increased speed and lower power consumption inherent in CMOS technology, the R65C00 family has the following additional characteristics.

- 12 new instructions for a total of 68
- 59 new op codes, for a total of 210
- Two new addressing modes
- Seven software/operational enhancements
- Two hardware enhancements

[^0]
## INSTRUCTION SET

Table 1 lists the instruction set for the CMOS CPU family in alphabetic order according to mnemonic. Tabe 2 lists the hexadecimal codes for each of the instructions that are new to the CMOS family and were not available in the NMOS R6502 device family. Table 3 lists those instructions that were available on the

NMOS family, but have been assigned new addressing modes in the CMOS CPU family.

## OPERATIONAL ENHANCEMENTS

Table 4 lists the operational enhancements that have been added to the CMOS family of CPU devices and compares the results with their NMOS R6502 counterpart.

Table 1. Alphabetic Listing of the R65C00 Instruction Set

| Mnemonic |  | Function | Mnemonic |  | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| (2) <br> (2) | ADC | Add Memory to Accumulator with Carry |  | NOP | No Operation |
|  | AND | "AND" Memory with Accumulator |  |  |  |
|  | ASL | Shift Left One Bit (Memory or Accumulator) | (2) | ORA | "OR" Memory with Accumlator |
| (1) | BBR | Branch on Bit Reset |  | PHA | Push Accumulator on Stack |
|  | BBS | Branch on Bit Set |  | PHP | Push Processor Status on Stack |
|  | BCC | Branch on Carry Clear | (1) | PHX | Push X Register on Stack |
|  | BCS | Branch on Carry Set | (1) | PHY | Push Y Register on Stack |
|  | BEQ | Branch on Result Zero |  | PLA | Pull Accumulator from Stack |
| (2) | BIT | Test Bits in Memory with Accumulator |  | PLP | Pull Processor Status from Stack |
|  | BMI | Branch on Result Minus | (1) | PLX | Pull X Register from Stack |
|  | BNE | Branch on Result not Zero | (1) | PLY | Pull Y Register from Stack |
|  | BPL | Branch on Result Plus |  |  |  |
| (1) | BRA | Branch Always | (1) | RMB | Reset Memory Bit |
|  | BRK | Force Break |  | ROL | Rotate One Bit Left (Memory or Accumulator) |
|  | BVC | Branch on Overflow Clear |  | ROR | Rotate One Bit Right (Memory or Accumulator) |
|  | BVS | Branch on Overflow Set |  | RTI | Return from Interrupt |
|  |  |  |  | RTS | Return from Subroutine |
|  | CLC | Clear Carry Flag |  |  |  |
|  | CLD | Clear Decimal Mode |  | SBC | Subtract Memory from Accumulator with Borrow |
|  | CLI | Clear Interrupt Disable Bit |  | SEC | Set Carry Flag |
|  | CLV | Clear Overflow Flag |  | SED | Set Decimal Mode |
| (2) | CMP | Compare Memory and Accumulator |  | SEI | Set Interrupt Disable Status |
|  | CPX | Compare Memory and Index X | (1) | SMB | Set Memory Bit |
|  | CPY | Compare Memory and Index $Y$ | (2) | STA | Store Accumulator in Memory |
|  |  |  |  | STX | Store Index X in Memory |
| (2) | DEC | Decrement Memory by One |  | STY | Store Index Y in Memory |
|  | DEX | Decrement Index $X$ by One | (1) | STZ | Store Zero |
|  | DEY | Decrement Index Y by One |  |  |  |
|  |  |  |  | TAX | Transfer Accumulator to Index X |
| (2) | EOR | "Exclusive-OR" Memory with Accumulator |  | TAY | Transfer Accumulator to Index Y |
|  |  |  | (1) | TRB | Test and Reset Bits |
| (2) | INC | Increment Memory by One | (1) | TSB | Test and Set Bits |
|  | INX | Increment Index X by One |  | TSX | Transfer Stack Pointer to Index X |
|  | INY | Increment Index Y by One |  | $\begin{aligned} & \text { TXA } \\ & \text { TXS } \end{aligned}$ | Transfer Index $X$ to Accumulator Transfer Index X to Stack Register |
| (2) | JMP | Jump to New Location |  | TYA | Transfer Index $Y$ to Accumulator |
|  | JSR | Jump to New Location Saving Return Address |  |  |  |
| (2) | LDA | Load Accumulator with Memory |  |  |  |
|  | LDX | Load Index X with Memory |  |  |  |
|  | LDY | Load Index Y with Memory |  |  |  |
|  | LSR | Shift One Bit Right (Memory or Accumulator) |  |  |  |
| Notes: <br> (1) Instruction not available on the NMOS family. <br> (2) R6502 instruction with additional addressing mode(s). |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |

Table 2. Hexadecimal Codes For New Instructions in the R65C00 Microprocessors

| Hex | Mnemonic | Description |
| :--- | :--- | :--- |
| 80 | BRA | Branch relative always [Relative] |
| DA | PHX | Push X on stack [Implied] |
| $5 A$ | PHY | Push Y on stack [Implied] |
| FA | PLX | Pull X from stack [Implied |
| $7 A$ | PLY | Store zero [Absolute] |
| 9 C | STZ | Store zero [ABS, X] |
| $9 E$ | STZ | Store zero [ZP] |
| 64 | STZ | Store zero [ZP, X] |
| 74 | STZ | Test and reset memory bits with accumulator [ABS] |
| 1 C | TRB | Test and reset memory bits with accumulator [ZP] |
| 14 | TRB | Test and set memory bits with accumulator [ABS] |
| $0 C$ | TSB | Test and set memory bits with accumulator [ZP] |
| 04 | TSB | Branch on bit reset [Bit Manipulation, ZP, REL] |
| $0 F-7 F^{(1)}$ | BBR | Reset memory bit [Bit Manipulation, ZP] |
| $8 F-F F\left({ }^{(1)}\right.$ | BBS | Set memory bit [Bit Manipulation, ZP] |
| $07-77^{(1)}$ | RMB |  |
| 87-F7(1) | SMB |  |
| Note: |  |  |
| 1. Most significant digit change only. |  |  |

Table 3. Hexadecimal Codes For R65C00 Instructions With New Addressing Modes

| Hex | Mnemonic | Description |
| :---: | :---: | :---: |
| 72 | ADC | Add memory to accumulator with carry [(IND)] |
| 32 | AND | AND memory with accumulator [(IND)] |
| 3 C | BIT | Test memory bits with accumulator [ABS, X] |
| 34 | BIT | Test memory bits with accumulator [ZP, X] |
| 89 | BIT | Test Immediate with accumulator [IMM] |
| D2 | CMP | Compare memory and accumulator [(IND)] |
| 3A | DEC | Decrement accumulator [Accum] |
| 52 | EOR | Exclusive Or memory with accumulator [(IND)] |
| 1A | INC | Increment accumulator [Accum] |
| 7 C | JMP | Jump (New addressing mode) [(ABS, X)] |
| B2 | LDA | Load accumulator with memory [(IND)] |
| 12 | ORA | OR memory with accumulator [(IND)] |
| F2 | SBC | Subtract Memory from accumulator with borrow [(IND)] |
| 92 | STA | Store accumulator in memory [(IND)] |

Table 4. R65C00 Operational Enhancements

| Function | NMOS R6502 Microprocessor | CMOS R65C00 Family Microprocessor |
| :--- | :--- | :--- |
| Indexed addressing across page boundary. | Extra read of invalid address. | Extra read of last instruction byte. |
| Execution of invalid op codes. | Some terminate only by reset. Results are <br> undefined. | All are NOPs (reserved for future use). |
| Jump Indirect, operand $=$ XXFF. | Page address does not increment. | Page address increments and adds one addi- <br> tional cycle. |
| Read/modify/write instructions at effective <br> address. | One read and two write cycles. | Two read and one write cycle. |
| Decimal flag. | Indeterminate after reset. | Initialized to binary mode (D $=0$ ) after reset <br> and interrupts. |
| Flags after decimal operation. | Invalid N, V and Z flags. | Valid flag adds one additional cycle. |
| Interrupt after fetch of BRK instruction. | Interrupt vector is loaded, BRK vector is <br> ignored. | BRK is executed, then interrupt is executed. |

## R65C02, R65C102, and R65C112

 R65C00 Microprocessors (CPU)
## INSTRUCTION SET OP CODE MATRIX

The following matrix shows the 210 Op Codes associated with the R65C00 family of CPU devices. The matrix identifies the hexadecimal code, the mnemonic code, the addressing mode,
the number of instruction bytes, and the number of machine cycles associated with each Op Code. Also, refer to the instruction set summary for additional information on these Op Codes.



Notes:

1. Add 1 to N if page boundary is crossed
2. Add 1 to N if branch occurs to came page.

Add 2 to N if branch occurs to different page.
3. Carry not $(\overline{\mathrm{C}})=$ Borrow.
4. Effects 8 -bit data field of the spectied zero page address.
5. Add 1 to $N$ if in Decimal Mode.
6. On the Bit inmediate instruction, the results of the $M_{7}$ and $M_{s}$ bits ( $N$ and $V$ flags) are indeterminate and should be considered invalic. invalid. Accumulator must be checked for zero result.
8. JMP (OP Code 6C) is an Absolute Indirect Addressing Mode (ABS).

LEGEND
$\begin{aligned} X & =\operatorname{Index} X \\ Y & =\text { Index } Y\end{aligned}$
$A=$ Accumulator
$M=$ Memory per, effective address
$M_{s}=$ Memory per stack pointer
$\mathrm{M}_{\mathrm{b}}=$ Selecter zero
$\mathrm{M}_{\mathrm{y}}=$ Memory Bit 7

SWITCHING CHARACTERISTICS (Over operating conditions unless otherwise noted)

| Parameter | Symbol | 1 MHz |  | 2 MHz |  | 3 MHz |  | 4 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |

## CLOCK TIMING

| $\emptyset 2$ Cycle Time | $\mathrm{t}_{\mathrm{CYC}}$ | 1000 | Note 1 | 500 | Note 1 | 333 | Note 1 | 250 | Note 1 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Ø2 Low Pulse Width | $\mathrm{t}_{\mathrm{CL}}$ | 430 | 5000 | 210 | 5000 | 150 | 5000 | 100 | 5000 | ns |
| $\emptyset 2$ High Pulse Width | ${ }^{\text {t }}$ CH | 450 | - | 220 | - | 160 | - | 110 | - | ns |
| ¢0 Low to 02 Low Skew ${ }^{(2)}$ | $\mathrm{t}_{\text {DLY }}$ | - | 50 | - | 50 | - | 40 | - | 30 | ns |
| $\emptyset 2$ Low to 01 High Skew ${ }^{(2)}$ | $t_{\text {DLY }}$ | -20 | 20 | -20 | 20 | -20 | 20 | -20 | 20 | ns |
| XTLI High to $\emptyset 2$ Low ${ }^{(4)}$ | $\mathrm{t}_{\mathrm{DXI}}$ | - | 100 | - | 100 | - | 100 | - | 100 | ns |
| XTLO Low to $\emptyset 2$ Low ${ }^{(4)}$ | $\mathrm{t}_{\text {DXO }}$ | - | 75 | - | 75 | - | 75 | - | 75 | ns |
| $\emptyset 2$ Low to $\emptyset 4$ High Delay ${ }^{(4)}$ | $\mathrm{t}_{\text {AVS }}$ | - | 250 | - | 125 | - | 85 | - | 65 | ns |
| $\emptyset 4$ Low Pulse Width ${ }^{(4)}$ | $t_{64 L}$ | 430 | - | 210 | - | 150 | - | 100 | - | ns |
| $\emptyset 4$ High Pulse Width ${ }^{(4)}$ | $t_{64 H}$ | 450 | 5000 | 220 | 5000 | 160 | 5000 | 110 | 5000 | ns |
| Clock Rise and Fall Times | $t_{\text {R }}, t_{F}$ | - | 25 | - | 20 | - | 15 | - | 12 | ns |

READ/WRITE TIMING

| $\mathrm{R} / \overline{\mathrm{W}}$ Delay Time | $t_{\text {RWS }}$ | - | 125 | - | 100 | - | 85 | - | 70 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R/ $\bar{W}$ Hold Time | $t_{\text {HRW }}$ | 15 | - | 15 | - | 15 | - | 15 | - | ns |
| Address Delay Time | $\mathrm{t}_{\text {ADS }}$ | - | 125 | - | 100 | - | 85 | - | 70 | ns |
| Address Valid to $\emptyset 4 \mathrm{High}^{(4)}$ | $t_{\text {A }}{ }^{\text {4 }}$ | 100 | - | 25 | - | 10 | - | 0 | - | ns |
| Address Hold Time | $t_{\text {HA }}$ | 15 | - | 15 | - | 15 | - | 15 | - | ns |
| Read Access Time | $\mathrm{t}_{\text {ACC }}$ | 775 | - | 340 | - | 215 | - | 160 | - | ns |
| Read Data Setup Time | $t_{\text {DSU }}$ | 100 | - | 60 | - | 40 | - | 30 | - | ns |
| Read Data Hold Time | $t_{\text {HR }}$ | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| Write Data Delay Time ${ }^{(2)}$ | $t_{\text {wDS }}$ | - | 200 | - | 110 | - | 85 | - | 55 | ns |
| Write Data Delay Time ${ }^{(4)}$ | $t_{\text {DDW }}$ | - | 200 | - | 110 | - | 85 | - | 65 | ns |
| Write Data Delay Time ${ }^{(6)}$ | $t_{\text {DD12 }}$ | - | 450 | - | 235 | - | 170 | - | 120 | ns |
| Write Data Hold Time | $\mathrm{t}_{\mathrm{HW}}$ | 30 | - | 30 | - | 30 | - | 30 | - | ns |

## CONTROL LINE TIMING

| SYNC Delay | $t_{\text {SYS }}$ | - | 125 | - | 100 | - | 85 | - | 70 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RDY Setup Time | $t_{\text {RDS }}$ | 200 | - | 110 | - | 80 | - | 60 | - | ns |
| $\overline{\text { SO }}$ Setup Time | $\mathrm{t}_{\mathrm{sos}}$ | 75 | - | 50 | - | 40 | - | 30 | - | ns |
| ML Delay Time(5) | $t_{\text {MLS }}$ | - | 125 | - | 100 | - | 85 | - | 70 | ns |
| ML Hold Time ${ }^{(4)}$ | $\mathrm{t}_{\mathrm{HML}}$ | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| ML Hold Time ${ }^{(6)}$ | $\mathrm{t}_{\mathrm{HML}}$ | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| BE Delay Time ${ }^{(5)(8)}$ | $t_{\text {bE }}$ | - | 40 | - | 40 | - | 40 | - | 40 | ns |
| $\overline{\mathrm{IRQ}}, \overline{\mathrm{RES}}$ Setup Time | tis | 200 | - | 110 | - | 80 | - | 60 | - | ns |
| $\overline{\text { NMI Setup Time }}$ | $\mathrm{t}_{\text {NMI }}$ | 300 | - | 200 | - | 170 | - | 150 | - | ns |

## Notes:

1. R65C02 and R65C102 minimum operating frequency is limited by $\emptyset 2$ low pulse width. All processors can be stopped with $\emptyset 2$ held high.
2. R65C02 only.
3. Note 3 deleted.
4. R65C102 only.
5. R65C102 and R65C112 only.
6. R65C112 only.
7. Measurement points shown are 0.8 V (low) and 2.0 V (high) for outputs and 1.5 V (low and high) for inputs, unless otherwise specified.
8. BE signal is asynchronous.


Figure 3. Timing Diagram for the R65C02 and R65C112


Figure 4. Timing Diagram for the R65C102


NOTE: BUS ENABLE APPLIES TO THE R65C102 AND R65C112. BE IS ASYNCHRONOUS AND THEREFORE NOT DIRECTLY RELATED TO THE ©2 CLOCK.

Figure 5. Timing Diagram for Bus Enable (BE)

## CLOCK/CRYSTAL CONSIDERATIONS

A crystal controlled time base generator circuit should be used to drive $\emptyset 0$ ( IN ) (R65C02) or the XTLI and XTLO (R65C102) inputs. Alternatively, a TTL level clock input to XTLI may be used, with XTLO floating.
Figure 6 shows a time base generation scheme, for a 4 MHz operation of the R65C02, that has been tested and proven reliable for normal environments.

Figure 7 shows a possible external clock scheme for a R65C102 and R65C112 master/slave configuration.
The on-chip oscillator is designed for a parallel resonant crystal connected between XTLI and XTLO pins. The equivalent oscillator circuit is shown in Figure 7.

A parallel resonant crystal is specified by its load capacitance and series resonant resistance. For proper oscillator operation, the load capacitance $\left(\mathrm{C}_{\mathrm{L}}\right)$, series resistance $\left(\mathrm{R}_{\mathrm{s}}\right)$ and the crystal resonant frequency ( $F$ ) must meet the following two relations:

$$
\begin{gathered}
(C+5)=2 C_{L} \quad \text { or } C=2 C_{L}-5 \\
R_{s} \leq R_{s \operatorname{smax}}=\frac{2 \times 10^{6}}{\left(F C_{L}\right)^{2}}
\end{gathered}
$$

where: $F$ is in $M H z, C$ and $C_{L}$ is in $p F$, and $R$ is in ohms.
To select a parallel resonant crystal for the oscillator, first select the load capacitance from a crystal manufacturer's catalog. Next, calculate $R_{\text {smax }}$ based on $F$ and $C_{L}$. The selected crystal must have a $R_{s}$ less than the $R_{\text {smax }}$.

For example, if $\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}$ for a 4 MHz parallel resonant crystal, then

$$
\begin{aligned}
& \mathrm{C}=(2 \times 30)-5=55 \mathrm{pF} \\
& \text { (use standard value of } 56 \mathrm{pF} \text { ) }
\end{aligned}
$$

The series resistance of the crystal must be less than

$$
R_{\text {smax }}=\frac{2 \times 10^{6}}{(4 \times 30)^{2}}=138 \mathrm{ohms}
$$



Figure 6. Example of R65C02 External Time Base Generator Circuit

## NOTE

As with any clock oscilltor circuit, stray capacitance due to board layout can affect circuit operation requiring "fine tuning"' (e.g. component repositioning or value change) of the circuits shown in Figures 6 and 7. Shunt capacitance (C) includes stray capacitance.


Notes: 1. The oscillator in the R 65 C 102 is parallel resonant.
2. R65C102 crystal frequency is divided by 4 , i.e., $\phi 2$ (OUT) $=$ F/4.
3. See STOPPING THE CLOCK.

Figure 7. Example of R65C102/R65C112 Master/Slave Clock Circuit

## STOPPING THE CLOCK-STANDBY MODE

Caution must be exercised when configuring the R65C02 or R65C112 in the standby mode (i.e., $\emptyset 0$ IN or $\emptyset 2$ IN clock stopped). The input clock can be held in the high state indefinitely; however, if the input clock is held in the low state longer than 5 microseconds, internal register and data status can be lost. Figure 8 shows a circuit that will stop the $\emptyset 0 \mathrm{IN}(\mathrm{R} 65 \mathrm{C} 02)$ or ф2 IN (R65C112) clock in the high state during standby mode.


Figure 8. Stopping the Clock (Standby Mode) Circuit

## ABSOLUTE MAXIMUM RATINGS*

| Parameter | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | Vdc |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | -0.3 to $\mathrm{V}_{\mathrm{CC}}+0.3$ | Vdc |
| Output Voltage | $\mathrm{V}_{\text {OUT }}$ | -0.3 to $\mathrm{V}_{\mathrm{CC}}+0.3$ | Vdc |
| Storage Temperature | $\mathrm{T}_{\mathrm{STG}}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## OPERATING CONDITIONS

| Parameter | Symbol | Value |
| :--- | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $5 \mathrm{Vdc} \pm 5 \%$ |
| Operating Temperature (Ambient) | $\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$ | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Commercial |  | $40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ <br> Industrial <br> Military |
|  |  | $55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ |

## ELECTRICAL CHARACTERISTICS

(Over operating conditions unless otherwise noted)

| Parameter | Symbol | Min | Typ ${ }^{4}$ | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\begin{aligned} & 2.0 \\ & 2.4 \end{aligned}$ |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}+0.3 \\ & \mathrm{~V}_{\mathrm{CC}}+0.3 \end{aligned}$ | V |  |
| Input Low Voltage $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$ | $\mathrm{V}_{\text {IL }}$ | $\begin{aligned} & -0.3 \\ & -0.3 \end{aligned}$ |  | $\begin{aligned} & +0.8 \\ & +0.4 \end{aligned}$ | V |  |
| Input High Voltage $\emptyset 0$ R65C02) | $\mathrm{V}_{\mathrm{IHO}}$ | 2.4 |  | $\mathrm{V}_{\mathrm{CC}}+0.3$ | V |  |
| Input Low Voltage $\emptyset 0$ (R65C02) | $\mathrm{V}_{\text {ILO }}$ | -0.3 |  | +0.4 | V |  |
| Input High Voltage $\emptyset 2$ (IN) (R65C112) | $\mathrm{V}_{\mathrm{HH} 2}$ | $V_{C C}-0.4$ |  | $\mathrm{V}_{\mathrm{CC}}+0.3$ | V |  |
| Input Low Voltage $\emptyset 2$ (IN) (R65C112) | $\mathrm{V}_{\text {IL2 }}$ | -0.3 |  | +0.4 | V |  |
| Input Leakage Current $\overline{\mathrm{NMI}}, \overline{\mathrm{IRQ}}, \mathrm{BE}, \mathrm{RDY}, \overline{\mathrm{RES}}, \overline{\mathrm{SO}}$ $\emptyset 2$ (IN), $\varnothing 0$ (IN), XTLI | $\mathrm{I}_{\mathrm{N}}$ | - |  | $\begin{gathered} -50 \\ 1.0 \end{gathered}$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V} \text { to } 5.25 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=0 \mathrm{~V} \end{aligned}$ |
| Three-State (Off State) Input Current Data Lines | ${ }^{\text {TSI }}$ | - |  | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Output High Voltage <br> SYNC, Data, AO-A15, R/W, $\emptyset 1$ (OUT), $\emptyset 2$ (OUT), $\emptyset 4$ (OUT), $\overline{M L}$ | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 |  | - | V | $\begin{aligned} & \mathrm{V}_{C C}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A} \end{aligned}$ |
| Output Low Voltage <br> SYNC, Data, AO-A15, R/W, $\emptyset 1$ (OUT), $\emptyset 2$ (OUT), $\emptyset 4$ (OUT), $\overline{M L}$ | $\mathrm{V}_{\mathrm{OL}}$ | - |  | +0.4 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{LOAD}}=1.6 \mathrm{~mA} \end{aligned}$ |
| Supply Current <br> Standby ${ }^{4}$ <br> Active (R65C02) <br> Active (R65C102) <br> Active (R65C112) <br> Low Power (R65C02) <br> Low Power (R65C102) <br> Low Power (R65C112) | $\mathrm{I}_{\mathrm{CC}}$ | $\begin{aligned} & - \\ & - \\ & - \\ & \hline \end{aligned}$ | $\begin{gathered} 2 \\ 2.6 \\ 5 \\ 2 \\ 1.5 \\ 3 \\ 0.7 \end{gathered}$ | $\begin{gathered} 10 \\ 4 \\ 7 \\ 4 \\ 2 \\ 5 \\ 1 \end{gathered}$ | $\mu \mathrm{A}$ $\mathrm{mA} / \mathrm{MHz}$ $\mathrm{mA} / \mathrm{MHz}$ $\mathrm{mA} / \mathrm{MHz}$ $\mathrm{mA} / \mathrm{MHz}$ $\mathrm{mA} / \mathrm{MHz}$ $\mathrm{mA} / \mathrm{MHz}$ | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ $\begin{aligned} & R D Y=0 \\ & R D Y=0 \\ & \text { RDY }=0 \end{aligned}$ |
| Capacitance <br> $\overline{\mathrm{NMI}}, \overline{\mathrm{IRQ}}, \overline{\mathrm{SO}}, \mathrm{BE}, \mathrm{RDY}$ <br> SYNC, Data, A0-A15, R/W, $\emptyset 1$ (OUT), $\emptyset 2$ (OUT), $\emptyset 4$ (OUT), $\overline{M L}$, XTLO <br> Ø0 (IN), XTLI <br> $\emptyset 2$ (IN) | $\begin{aligned} & \mathrm{C}_{\mathrm{IN}} \\ & \mathrm{C}_{\mathrm{OUT}} \\ & \\ & \mathrm{C}_{0} \\ & \mathrm{C}_{2} \\ & \hline \end{aligned}$ | $\begin{aligned} & - \\ & - \\ & - \end{aligned}$ |  | $\begin{array}{r} 7 \\ 10 \\ \\ 10 \\ 30 \end{array}$ | pF | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\ & \mathrm{f}=1 \mathrm{MHz} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |
| Notes: <br> 1. All units are direct current (dc). <br> 2. Negative sign indicates outward current flow, positive indicates <br> 3. $\overline{\mathrm{IRQ}}$ and $\overline{\mathrm{NMI}}$ require external pull-up resistor. <br> 4. Typical values shown for $V_{C C}=5.0 \mathrm{~V}$ and $T_{A}=25^{\circ} \mathrm{C}$. | inward flow |  |  |  |  |  |

## PACKAGE DIMENSIONS

40-PIN CERAMIC DIP


|  | MILLIMETERS |  | INCHES |  |
| :---: | :---: | :---: | :---: | :---: |
| DIM | MIN | MAX | MIN | MAX |
| A | 50.29 | 51.31 | 1.980 | 2.020 |
| B | 15.11 | 15.88 | 0.595 | 0.625 |
| C | 2.54 | 4.19 | 0.100 | 0.165 |
| D | 0.38 | 0.53 | 0.015 | 0.021 |
| F | 0.76 | 1.27 | 0.030 | 0.050 |
| G | 2.54 BSC |  | 0.100 |  |
| BSC |  |  |  |  |
| H | 0.76 | 1.78 | 0.030 | 0.070 |
| K | 0.20 | 0.33 | 0.008 | 0.013 |
| L | 2.54 | 4.19 | 0.100 | 0.165 |
| M | $0^{\circ}$ | 15.37 | 0.575 | 0.605 |
| N | 0.51 | $10^{\circ}$ | $0^{\circ}$ | $10^{\circ}$ |

## 40-PIN PLASTIC DIP



| DIM | MILLIMETERS |  | INCHES |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |  |
| A | 51.82 | 52.32 | 2.040 | 2.060 |  |  |
| B | 13.46 | 13.97 | 0.530 | 0.550 |  |  |
| C | 3.56 | 5.08 | 0.140 | 0.200 |  |  |
| D | 0.38 | 0.53 | 0.015 | 0.021 |  |  |
| F | 1.02 |  | 1.52 | 0.040 |  |  |
| G | 2.54 BSC |  | 0.100 |  |  |  |
| H | 1.65 | 2.16 | 0.065 |  |  |  |
| J | 0.20 |  | 0.30 | 0.008 |  | 0.012 |
| K | 3.30 |  | 4.32 | 0.130 |  | 0.170 |
| L | 15.24 |  | BSC | 0.600 |  | BSC |
| M | $7^{\circ}$ |  | $10^{\circ}$ | $7^{\circ}$ |  | $10^{\circ}$ |
| N | 0.51 |  | 1.02 | 0.020 |  | 0.040 |

44-PIN PLASTIC LEADED CHIP CARRIER (PLCC)


TOP VIEW

CHAM.J $\times 45^{\circ} 7$
 0

side view


SECTION A-A TYP FOR BOTH AXIS (EXCEPT FOR BEVELED EDGE)

CHAM.


3 PLCS

## 11 PINS

PER SIDE EQUALLY SPACES BOTTOM VIEW

| DIM | MILLIMETERS |  | INCHES |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | 4.14 | 4.39 | 0.163 | 0.173 |  |
| A1 | 1.37 | 1.47 | 0.054 | 0.058 |  |
| A2 | 2.31 | 2.46 | 0.091 | 0.097 |  |
| b | 0.457 TYP |  | 0.018 |  | TYP |
| D | 17.45 | 17.60 | 0.687 | 0.693 |  |
| D1 | 16.46 | 16.56 | 0.648 | 0.652 |  |
| D2 | 12.62 | 12.78 | 0.497 | 0.503 |  |
| D3 | 15.75 REF |  | 0.620 REF |  |  |
| e | 1.27 BSC |  | 0.050 BSC |  |  |
| h | 1.15 TYP |  | 0.045 TYP |  |  |
| J | 0.25 TYP |  | 0.010 TYP |  |  |
| $\alpha$ | $45^{\circ}$ TYP |  | $45^{\circ}$ TYP |  |  |
| R | 0.89 TYP |  | 0.035 TYP |  |  |
| R1 | 0.25 TYP |  | 0.010 TYP |  |  |

## R65C21 Peripheral Interface Adapter (PIA)

## DESCRIPTION

The R65C21 Peripheral Interface Adapter (PIA) is designed to solve a broad range of peripheral control problems in the implementation of microcomputer systems. This device allows a very effective trade-off between software and hareware by providing significant capability and flexibility in a low cost chip. When coupled with the power and speed of the R6500, R6500/* or R65C00 family of microprocessors, the R65C21 allows implementation of very complex systems at a minimum overall cost.

Control of peripheral devices is handled primarily through two 8 -bit bidirectional ports. Each of these lines can be programmed to act as either an input or an output. In addition, four peripheral control/interrupt input lines are provided. These lines can be used to interrupt the processor or to "handshake" data between the processor and a peripheral device.

## FEATURES

- Low power CMOS N-well silicon gate technology
- Direct replacement for NMOS R6520 or MC6821 PIA
- Two 8-bit bidirectional I/O ports with individual data direction control
- Automatic "Handshake" control of data transfers
- Two interrupts (one for each port) with program control
- $1,2,3$, and 4 MHz versions
- Commercial and industrial temperature range versions
- Wide variety of packages
-40-pin plastic and ceramic DIP
- 44-pin plastic leaded chip carrier (PLCC)
- Single +5 Vdc power requirement
- Compatible with the R6500, R6500/* and R65C00 family of microprocessors



Figure 1. R65C21 Pin Assignments

## ORDERING INFORMATION



## INTERFACE SIGNALS

The PIA interfaces to the R6500, R6500/* or the R65C00 microprocessor family with a reset line, a $\emptyset 2$ clock line, a read/write line, two interrupt request lines, two register select lines, three chip select lines, and an 8 -bit bidirectional data bus.

The PIA interfces to the peripheral devices with four interrupt/ control lines and two 8 -bidirectional data ports.

Figure 1 (on the front page) shows the R65C21 PIA pin assignments and Figure 2 groups the signals by functional interface.

## CHIP SELECT (CSO, CS1, $\overline{\text { CS2 }}$ )

The PIA is selected when CS0 and CS1 are high and $\overline{\mathrm{CS} 2}$ is low. These three chip select lines are normally connected to the processor address lines either directly or through external
decoder circuits. When the PIA is selected, data will be transferred between the data lines and PIA registers, and/or peripheral interface lines as determined by the R/W, RS0, and RS1 lines and the contents of Control Registers A and B.

## RESET SIGNAL ( $\overline{\text { RES }})$

The Reset ( $\overline{\mathrm{RES}}$ ) input initializes the R65C21 PIA. A low signal on the $\overline{R E S}$ input causes all internal registers to be cleared.

## CLOCK SIGNAL (02)

The Phase 2 Clock Signal ( $\varnothing 2$ ) is the system clock that triggers all data transfers between the CPU and the PIA. $\varnothing 2$ is generated by the CPU and is therefore the synchronizing signal between the CPU and the PIA.

## READ/WRITE SIGNAL (R/W)

Read/Write $(\mathrm{R} \overline{\mathrm{W}})$ controls the direction of data transfers between the PIA and the data lines associated with the CPU and the peripheral devices. $\mathrm{R} / \overline{\mathrm{W}}$ high permits the peripheral devices to transfer data to the CPU from the PIA. R/W low allows data to be transferred from the CPU to the peripheral devices from the PIA.

## REGISTER SELECT (RS0, RS1)

The two Register Select lines (RS0, RS1), in conjunction with the Control Registers' (CRA, CRB) Data Direction Register access bits select the various R65C21 registers to be accessed by the CPU. RSO and RS1 are normally connected to the microprocessor (CPU) address output lines. Through control of these lines, the CPU can write directly into the Control Registers (CRA, CRB), the Data Direction Registers (DDRA, DDRB) and the Peripheral Output Registers (ORA, ORB). In addition, the processor may directly read the contents of the Control Registers and the Data Direction Registers. Accessing the Peripheral Output Register for the purpose of reading data back into the processor operates differently on the ORA and the ORB registers and, therefore, are shown separately in Table 1.


Figure 2. R65C21 ACIA Interface Signals

Table 1. ORA and ORB Register Addressing

| Register <br> Address <br> (Hex) | Register <br> Select Lines |  | Data Direction <br> Control |  | Register Operation |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | RS1 | RS0 | CRA <br> (Bit 2) | CRB <br> (Bit 2) | R $\overline{\mathbf{W}}=$ H | R/ $\bar{W}=$ L |
| 0 | L | L | 1 | - | Read PIBA | Write ORA |
| 1 | L | H | - | - | Read DDRA | Write DDRA |
| 2 | H | L | - | - | Read CRA | Write CRA |
| 2 | H | L | - | 0 | Read PIBB | Write ORB |
| 3 | Head DDRB | Write DDRB |  |  |  |  |

## INTERRUPT REQUEST LINES ( $\overline{(\mathrm{RQA}}, \overline{\mathrm{IRQB}})$

The active low Interrupt Request lines ( $\overline{\mathrm{RQA}}$ and $\overline{\mathrm{IRQB}}$ ) act to interrupt the microprocessor either directly or through external interrupt priority circuitry. These lines are open drain and are capable of sinking 1.6 mA from an external source. This permits all interrupt request lines to be tied together in a wired-OR configuration. The $A$ and $B$ in the titles of these lines correspond to the peripheral port $A$ and the peripheral port $B$ so that each interrupt request line services one peripheral data port.

Each Interrupt Request line has two interrupt flag bits which can cause the Interrupt Request line to go low. These flags are bits 6 and 7 in the two Control Registers (CRA, CRB). These flags act as the link between the peripheral interrupt signals and the microprocessor interrupt inputs. Each flag has a corresponding interrupt disable bit which allows the processor to enable or disable the interrupt from each of the four interrupt inputs (CA1, CA2, CB1, CB2). The four interrupt flags are set by active transitions of the signal on the interrupt input (CA1, CA2, CB1, CB2).

CRA bit 7 (IRQA1) is always set by an active transition of the CA1 interrupt input signal. However, $\overline{\mathrm{IRQA}}$ can be disabled by setting bit 0 in CRA to a 0 . Likewise, CRA bit 6 (IRQA2) is set by an active transition of the CA2 interrupt input signal and IRQA can be disabled by setting bit 3 in CRA to a 0 .

Both bit 6 and bit 7 in CRA are reset by a "Read Peripheral Output Register A" operation. This is defined as an operation in which the read/write, proper data direction register and register select signals are provided to allow the processor to read the Peripheral A I/O port. A summary of $\overline{\mathrm{IRQA}}$ control is shown in Table 2.

Control of $\overline{\mathrm{RQB}}$ is performed in exactly the same manner as that described above for $\overline{\mathrm{IRQA}}$ (Table 2). Bit 7 in CRB (IRQB1) is set by an active transition on CB1 and IRQB from this flag is controlled by CRB bit 0 . Likewise, bit $6(\overline{\mathrm{RQB} 2})$ in CRB is set by an active transition on CB2, and $\overline{\mathrm{RQQB}}$ from this flag is controlled by CRB bit 3 . Also, both bit 6 and bit 7 of CRB are reset by a "Read Peripheral B Output Register" operation.

Table 2. $\overline{\mathrm{IRQA}}$ and $\overline{\mathrm{IRQB}}$ Control Summary

| Control Register Bits | Action |
| :---: | :---: |
| CRA-7 $=1$ and CRA-0 $=1$ | $\overline{\text { IRQA }}$ goes low (Active) |
| CRA-6 $=1$ and CRA-3 $=1$ | $\overline{\text { \|RQA }}$ goes low (Active) |
| CRB-7 $=1$ and CRB-0 $=1$ | $\overline{\text { \|RQB }}$ goes low (Active) |
| CRB-6 $=1$ and CRB-3 $=1$ | $\overline{\mathrm{TRQB}}$ goes low (Active) |

## INTERRUPT INPUT/PERIPHERAL CONTROL LINES (CA1, CA2, CB1, CB2)

The four interrupt input/peripheral control lines provide a number of special peripheral control functions. These lines greatly enhance the power of the two general purpose interface ports (PAO-PA7), PB0-PB7). Figure 4 summarizes the operation of these control lines.

CA1 is an interrupt input only. An active transition of the signal on this input will set bit 7 of the Control Register A to a logic 1. The active transition can be programmed by setting a 0 in bit 1 of the CRA if the interrupt flag (bit 7 of CRA) is to be set on a negative transition of the CA1 signal or a 1 if it is to be set on a positive transition.

CA2 can act as a totally independent interrupt or as a peripheral control output. As an input (CRA, bit $5=0$ ) it acts to set the interrupt flag, bit 6 of CRA, to a logic 1 on the active transition selected by bit 4 of CRA.

These control register bits and interrupt inputs serve the same basic function as that described above for CA1. The input signal sets the interrupt flag which serves as the link between the peripheral device and the processor interrupt structure. The interrupt disable bit allows the processor to exercise control over the system interrupt.

In the output mode (CRA, bit $5=1$ ), CA2 can operate independently to generate a simple pulse each time the microprocessor reads the data on the Peripheral $A$ I/O port. This mode is selected by setting CRA, bit 4 to a 0 and CRA, bit 3 to a 1 . This pulse output can be used to control the counters, shift registers, etc., which make sequential data available on the Peripheral input lines.

A second output mode allows CA2 to be used in conjunction with CA1 to "handshake" between the processor and the peripheral device. On the A side, this technique allows positive control of data transfers from the peripheral device into the microprocessor. The CA1 input signals the processor that data is available by interrupting the processor. The processor reads the data and sets CA2 low. This signals the peripheral device that it can make new data available.

The final output mode can be selected by setting bit 4 of CRA to a 1. In this mode, CA2 is a simple peripheral control output which can be set high or low by setting bit 3 of CRA to a 1 or 0 , respectively.

CB1 operates as an interrupt input only in the same manner as CA1. Bit 7 of CRB is set by the active transition selected by bit 0 of CRB. Likewise, the CB2 input mode operates exactly the same as the CA2 input modes. The CB2 output modes, CRB bit $5=1$, differ somewhat from those of CA2. The pulse output occurs when the processor writes data into the Peripheral B Output Register. Also, the "handshaking" operates on data transfers from the processor into the peripheral device.

## FUNCTIONAL DESCRIPTION

The R65C21 PIA is organized into two independent sections referred to as the A Side and the B Side. Each section consists of a Control Register (CRA, CRB), Data Direction Register (DDRA, DDRB), Output Register (ORA, ORB), Interrupt Status Control (ISCA, ISCB), and the buffers necessary to drive the Peripheral Interface buses. Data Bus Buffers (DBB) interface data from the two sections to the data bus, while the Data Input Register (DIR) interfaces data from the DBB to the PIA registers. Chip Select and R $\bar{W}$ control circuitry interface to the processor bus control lines. Figure 3 is a block diagram of the R65C21 PIA.

## DATA INPUT REGISTER (DIR)

When the microprocessor writes data into the PIA, the data which appears on the data bus during the $\emptyset 2$ clock pulse is latched into the Data Input Register (DIR). The data is then transferred into one of six internal registers of the PIA after the trailing edge
of the $\emptyset 2$ clock. This assures that the data on the peripheral output lines will make smooth transitions from high to low (or from low to high) and the voltage will remain stable except when it is going to the opposite polarity.

## CONTROL REGISTERS (CRA AND CRB)

Table 3 illustrates the bit designation and functions in the two control registers. The control registers allow the microprocessor to control the operation of the Interrupt Control inputs (CA1, CA2, CB1, CB2), and Peripheral Control outputs (CA2, CB2). Bit 2 in each register controls the addressing of the Data Direction Registers (DDRA, DDRB) and the Output Registers (ORA, ORB). In addition, two bits (bit 6 and 7) in each control register indicate the status of the Interrupt Input lines (CA1, CA2, CB1, CB2). These Interrupt Status bits (IRQA1, IRQA2 or IRQB1, IRQB2) are normally interrogated by the microprocessor during the $\overline{\mathrm{IRQ}}$ interrupt service routine to determine the source of the interrupt.


Figure 3. R65C21 PIA Block Diagram

Table 3. Control Registers Bit Designations

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CRA | IRQA1 | IRQA2 | CA2 Control |  |  | DDRA/ORA Select | CA1 Control |  |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CRB | IRQB1 | IRQB2 | CB2 Control |  |  | DDRB/ORB Select | CB1 Control |  |

## DATA DIRECTION REGISTERS (DDRA, DDRB)

The Data Direction Registers (DDRA, DDRB) allow the processor to program each line in the 8-bit Peripheral I/O port to be either an input or an output. Each bit in DDRA controls the corresponding line in the Peripheral A port and each bit in DDRB controls the corresponding line in the Peripheral B port. Writing a 0 in a bit position in the Data Direction Register causes the corresponding Peripheral I/O line to act as an input; a 1 causes it to act as an output.

Bit 2 in each Control Register (CRA and CRB) controls access to the Data Direction Register or the Peripheral interface. If bit 2 is a 1 , a Peripheral Output register (ORA, ORB) is selected, and if bit 2 is a 0 , a Data Direction Register (DDRA, DDRB) is selected. The Data Direction Register Access Control bit, together with the Register Select lines (RS0, RS1) selects the various internal registers as shown in Table 1.

## PERIPHERAL OUTPUT REGISTER (ORA, ORB)

The Peripheral Output Registers (ORA, ORB) store the output data from the Data Bus Buffers (DBB) which appears on the Peripheral I/O port. If a line on the Peripheral A Port is programmed as an output by the DDRA, writing a 0 into the corresponding bit in the ORA causes that line to go low ( $\leq 0.4 \mathrm{Vdc}$ ); writing a 1 causes the line to go high. The lines of the Peripheral $B$ port are controlled by ORB in the same manner.

## INTERRUPT STATUS CONTROL (ISCA, ISCB)

The four interrupt/peripheral control lines (CA1, CA2, CB1, CB2) are controlled by the Interrupt Status Control logic (A, B). This logic interprets the contents of the corresponding Control Register and detects active transitions on the interrupt inputs.

## PERIPHERAL I/O PORTS (PAO-PA7, PB0-PB7)

The Peripheral A and Peripheral B I/O ports allow the microprocessor to interface to the input lines on the peripheral device by writing data into the Peripheral Output Register. They also allow the processor to interface with the peripheral device output lines by reading the data on the Peripheral Port input lines directly onto the data bus and into the internal registers of the processor.

Each of the Peripheral I/O lines can be programmed to act as an input or an output. This is accomplished by setting a 1 in the corresponding bit in the Data Direction Register for those lines which are to act as outputs. A 0 in a bit of the Data Direction Register causes the corresponding Peripheral I/O lines to act as an input.

The buffers which drive the Peripheral A I/O lines contain "passive" pull-up devices. These pull-up devices are resistive in nature and therefore allow the output voltage to go to $\mathrm{V}_{\mathrm{CC}}$ for a logic 1 . The switches can sink a full 3.2 mA , making these buffers capable of driving two standard TTL loads.

In the input mode, the pull-up devices are still connected to the I/O pin and still supply current to this pin. For this reason, these lines also represent two standard TTL loads in the input mode.

The Peripheral B I/O port duplicates many of the functions of the Peripheral A port. The process of programming these lines to act as an input or an output is similar to the Peripheral A port, as is the effect of reading or writing this port. However, there are several characteristics of the buffers driving these lines which affect their use in peripheral interfacing.

The Peripheral B I/O port buffers are push-pull devices, i.e., the pull-up devices are switched OFF in the 0 state and ON for a logic 1 . Since these pull-ups are active devices, the logic 1 voltage will not go higher than +2.4 Vdc .

Another difference between the PA0-PA7 lines and the PBO through PB7 lines is that they have three-state capability which allows them to enter a high impedance state when programmed to be used as input lines. In addition, data on these lines will be read properly, when programmed as output lines, even if the data signals fall below 2.0 Vdc for a "high'" state or are above 0.8 Vdc for a "low" state. When programmed as output, each line can drive at least a two TTL load and may also be used as a source of up to 3.2 mA at 1.5 Vdc to directly drive the base of a transistor switch, such as a Darlington pair.

Because these outputs are designed to drive transistors directly, the output data is read directly from the Peripheral Output Register for those lines programmed to act as inputs.

The final characteristic is the high-impedance input state which is a function of the Peripheral B push-pull buffers. When the Peripheral B I/O lines are programmed to act as inputs, the output buffer enters the high impedance state.

## DATA BUS BUFFERS (DBB)

The Data Bus Buffers are 8-bit bidirectional buffers used for data exchange, on the D0-D7 Data Bus, between the microprocessor and the PIA. These buffers are tri-state and are capable of driving a two TTL load (when operating in an output mode) and represent a one TTL load to the microprocessor (when operating in an input mode).

## CONTROL REGISTER A (CRA)

CA2 INPUT MODE (BIT 5 = 0)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \hline \text { IRQA1 } \\ & \text { FLAG } \end{aligned}$ | $\begin{gathered} \hline \text { IRQA2 } \\ \text { FLAG } \end{gathered}$ | CA2 INPUT MODE SELECT $(=0)$ | IRQA2 TRANSITION SELECT | $\begin{gathered} \overline{\mathrm{IRQA}} \\ \text { ENABLE } \\ \text { FOR IRQA2 } \end{gathered}$ | DDRA/ORA SELECT | IRQA1 TRANSITION SELECT | $\begin{gathered} \overline{\mathrm{IRQA}} \\ \text { ENABLE } \\ \text { FOR IRQA1 } \end{gathered}$ |
|  |  |  |  |  |  |  |  |

CA2 OUTPUT MODE (BIT $5=1$ )

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { IRQA1 } \\ & \text { FLAG } \end{aligned}$ | 0 | CA2 OUTPUT MODE SELECT (=1) | CA2 OUTPUT CONTROL | CA2 RESTORE CONTROL | DDRA/ORA SELECT | IRQA1 TRANSITION SELECT | $\begin{gathered} \overline{\mathrm{IRQA}} \\ \text { ENABLE } \\ \text { FOR IRQA1 } \\ \hline \end{gathered}$ |
|  |  |  | CA2 CONTROL |  |  | IRQA/IRQA1 CONTROL |  |

CA2 INPUT OR OUTPUT MODE (BIT 5 = 0 OR 1)

| Bit 7 | IRQA1 FLAG |
| :---: | :---: |
| 1 | A transition has occurred on CA1 that satisfies the bit 1 IRQA1 transition polarity criteria. This bit is cleared by a read of Output Register A or by RES. |
| 0 | No transition has occurred on CA1 that satisfies the bit 1 IRQA1 transition polarity criteria. |
| Bit 2 | DATA DIRECTION REGISTER A/OUTPUT REGISTER A SELECT |
| 1 | Select Output Register A. |
| 0 | Select Data Direction Register A. |
| Bit 1 | IRQA1 TRANSITION SELECT |
| 1 | Set IRQA1 Flag (bit 7) on a positive (low-to-high) transition of CA1. |
| 0 | Set IRQA1 Flag (bit 7) on a negative (high-to-low) transition of CA1. |
| Bit 0 | $\overline{\text { IRQA }}$ ENABLE FOR IRQA1 |
| 1 | Enable assertion of $\overline{\mathrm{IRQA}}$ when IRQA1 Flag (bit 7) is set. |
| 0 | Disable assertion of IRQA when IRQA1 Flag (bit 7 ) is set. |

## CA2 INPUT MODE (BIT 5 = 0)

| Bit 6 | IRQA2 FLAG |
| :---: | :---: |
| 1 | A transition has occurred on CA2 that satisfies the bit 4 |
|  | IRQA2 transition polarity criteria. This flag is cleared by a read of Output Register A or by RES. |
| 0 | No transition has occurred on CA2 that satisfies the bit 4 IRQA2 transition polarity criteria. |
|  |  |
| Bit 5 | CA2 MODE SELECT |
| 0 | Select CA2 Input Mode. |
| Bit 4 | IRQA2 TRANSITION SELECT |
| 1 | Set IRQA2 Flag (bit 6) on a positive (low-to-high) transition of CA2. |
| 0 | Set IRQA2 Flag (bit 6) on a negative (high-to-low) transition of CA2. |
| Bit 3 | IRQA ENABLE FOR IRQA2 |
| 1 | Enable assertion of $\overline{\mathrm{IRQA}}$ when IRQA2 Flag (bit 6) is set. |
| 0 | Disable assertion of IRQA when IRQA2 Flag (bit 6) is set. |

CA2 OUTPUT MODE (BIT $5=0$ )

| Bit 6 | NOT USED |
| :---: | :---: |
| 0 | Always zero. |
| Bit 5 | CA2 MODE SELECT |
| 1 | Select CA2 Output Mode. |
| Bit 4 | CA2 OUTPUT CONTROL |
| 1 | CA2 goes low when a zero is written into CRA bit 3. CA2 goes high when a one is written into CRA bit 3. |
| 0 | CA2 goes low on the first negative (high-to-low) $\emptyset 2$ clock transition following a read of Output Register A. CA2 returns high as specified by bit 3 |
| Bit 3 | CA2 READ STROBE RESTORE CONTROL ( $4=0$ ) |
| 1 | CA2 returns high on the next $\emptyset 2$ clock negative transition following a read of Output Register A. |
| 0 | CA2 returns high on the next active CA1 transition following a read of Output Register A as specified by bit 1 . |

Figure 4. Control Line Operations Summary (1 of 2)

## CONTROL REGISTER B (CRB)

CB2 INPUT MODE (BIT $5=0$ )

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IRQB1 FLAG | $\begin{gathered} \text { IRQB2 } \\ \text { FLAG } \end{gathered}$ | $\begin{gathered} \text { CB2 INPUT } \\ \text { MODE SELECT } \\ (=0) \end{gathered}$ | IRQB2 TRANSITION SELECT | $\overline{\mathrm{IRQB}}$ ENABLE FOR IRQB2 | DDRB/ORB SELECT | IRQB1 TRANSITION SELECT | $\overline{\mathrm{IRQB}}$ ENABLE FOR IRQB1 |
|  |  |  | IRQB/IRQB2 CONTROL |  |  | $\overline{\text { RQB }} /$ RQQB1 $^{2}$ CONTROL |  |

## CB2 OUTPUT MODE (BIT $5=1$ )

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IRQB1 FLAG | 0 | CB2 OUTPUT MODE SELECT ( $=1$ ) | CB2 OUTPUT CONTROL | CB2 RESTORE CONTROL | DDRB/ORB SELECT | IRQB1 TRANSITION SELECT | $\begin{gathered} \overline{\mathrm{IRQB}} \\ \text { ENABLE } \\ \text { FOR IRQB1 } \end{gathered}$ |
|  |  |  | $\begin{gathered} \text { CB2 } \\ \text { CONTROL } \end{gathered}$ |  |  | $\overline{\text { RQB }} /$ RQB1 CONTROL |  |

## CB2 INPUT OR OUTPUT MODE (BIT $5=0$ OR 1)

| Bit 7 | IRQB1 FLAG |
| :---: | :---: |
| 1 | A transition has occurred on CB1 that satisfies the bit 1 IRQB1 transition polarity criteria. This bit is cleared by a read of Output Register B or by $\overline{\mathrm{RES}}$. |
| 0 | No transition has occurred on CB1 that satisfies the bit 1 IRQB1 transition polarity criteria. |
| Bit 2 | DATA DIRECTION REGISTER B/OUTPUT REGISTER B SELECT |
| 1 | Select Output Register B. |
| 0 | Select Data Direction Register B. |
| Bit 1 | IRQB1 TRANSITION SELECT |
| 1 | Set IRQB1 Flag (bit 7) on a positive (low-to-high) transition of CB1. |
| 0 | Set IRQB1 Flag (bit 7) on a negative (high-to-low) transition of CB1. |
| Bit 0 | $\overline{\text { IRQB }}$ ENABLE FOR IRQB1 |
| 1 | Enable assertion of IRQB when IRQB1 Flag (bit 7) is set. |
| 0 | Disable assertion of $\overline{\text { IRQB }}$ when IRQB1 Flag (bit 7) is set. |

## CB2 INPUT MODE (BIT 5 = $\mathbf{0}$ )

| $\begin{gathered} \text { Bit } 6 \\ 1 \end{gathered}$ | IRQB2 FLAG |
| :---: | :---: |
|  | A transition has occurred on CB2 that satisfies the bit 4 |
|  | IRQB2 transition polarity criteria. This flag is cleared by a read of Output Register B or by $\overline{\text { RES }}$. |
| 0 | No transition has occurred on CB2 that satisfies the bit 4 IRQB2 transition polarity criteria. |
| $\begin{gathered} \text { Bit } 5 \\ 0 \end{gathered}$ | CB2 MODE SELECT |
|  | Select CB2 Input Mode. |
| $\begin{gathered} \text { Bit } 4 \\ 1 \end{gathered}$ | IRQB2 TRANSITION SELECT |
|  | Set IRQB2 Flag (bit 6) on a positive (low-to-high) transition of CB2. |
| 0 | Set IRQB2 Flag (bit 6) on a negative (high-to-low) transition of CB2. |
| Bit 3 | $\overline{\text { IRQB ENABLE FOR IRQB2 }}$ |
| 1 | Enable assertion of IRQB when IRQB2 Flag (bit 6) is set. |
| 0 | Disable assertion of $\overline{\mathrm{RQB}}$ when IRQA2 Flag (bit 6) is set. |

CB2 OUTPUT MODE (BIT $5=0$ )

| Bit 6 | NOT USED <br> 0 <br> Always zero. |
| :---: | :--- |
| Bit 5 | CB2 MODE SELECT <br> 1 <br> Select CB2 Output Mode. |
| Bit 4 | CB2 OUTPUT CONTROL <br> 1 |
| CB2 goes low when a zero is written into CRB bit 3. <br> CB2 goes high when a one is written into CRB bit 3. <br> CB2 goes low on the first negative (high-to-low) $\emptyset 2$ clock |  |
|  | transition following a read of Output Register B. <br> CB2 returns high as specified by bit 3 |
| Bit 3 | CB2 READ STROBE RESTORE CONTROL (4 $=0)$ <br> CB2 returns high on the next $\emptyset 2$ clock negative |
| 0 | transition following a read of Output Register B. <br> CB2 returns high on the next active CB1 transition <br> following a read of Output Register B as specified by <br> bit 1. |

Figure 4. Control Line Operations Summary (2 of 2)

## READING THE PERIPHERAL A I/O PORT

Performing a Read operation with RS1 $=0$, RSO $=0$ and the Data Direction Register Access Control bit (CRA-2) $=1$, directly transfers the data on the Peripheral A I/O lines to the data bus. In this situation, the data bus will contain both the input and output data. The processor must be programmed to recognize and interpret only those bits which are important to the particular peripheral operation being performed.

Since the processor always reads the Peripheral A I/O port pins instead of the actual Peripheral Output Register (ORA), it is possible for the data read by the processor to differ from the contents of the Peripheral Output Register for an output line. This is true when the I/O pin is not allowed to go to a full
+2.4 Vdc when the Peripheral Output register contains a logic 1. In this case, the processor will read a 0 from the Peripheral A pin, even though the corresponding bit in the Peripheral Output register is a 1 .

## READING THE PERIPHERAL B I/O PORT

Reading the Peripheral B I/O port yields a combination of input and output data in a manner similar to the Peripheral A port. However, data is read directly from the Peripheral B Output Register (ORB) for those lines programmed to act as outputs. It is therefore possible to load down the Peripheral B Output lines without causing incorrect data to be transferred back to the processor on a Read operation.


Figure 5. Read Timing Waveforms


Figure 6. Write Timing Waveform

## SWITCHING WAVEFORMS

$\left(V_{C C}=5.0 \mathrm{Vdc} \pm 5 \%, V_{S S}=0, T_{A}=T_{L}\right.$ to $T_{H}$, unless otherwise noted $)$

## bus timing

| Parameter | Symbol | 1 MHz |  | 2 MHz |  | 3 MHz |  | 4 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $\emptyset 2$ Cycle | $\mathrm{t}_{\mathrm{CYC}}$ | 1.0 | - | 0.5 | - | 0.33 | - | 0.25 | - | $\mu \mathrm{S}$ |
| $\emptyset 2$ Pulse Width | $\mathrm{t}_{\mathrm{C}}$ | 450 | - | 220 | - | 160 | - | 110 | - | ns |
| $\emptyset 2$ Rise and Fall Time | $\mathrm{trc}_{\mathrm{rc}}, \mathrm{t}_{\mathrm{fc}}$ | - | 25 | - | 15 | - | 12 | - | 10 | ns |
| Read |  |  |  |  |  |  |  |  |  |  |
| Address Set-Up Time | $t_{\text {ACR }}$ | 140 | - | 70 | - | 53 | - | 35 | - | ns |
| Address Hold Time | $t_{C A R}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| Peripheral Data Set-Up Time | $t_{\text {PCR }}$ | 300 | - | 150 | - | 110 | - | 75 | - | ns |
| Data Bus Delay Time | $\mathrm{t}_{\mathrm{CDR}}$ | - | 335 | - | 145 | - | 105 | - | 85 | ns |
| Data Bus Hold Time | $\mathrm{t}_{\mathrm{HR}}$ | 20 | - | 20 | - | 20 | - | 20 | - | ns |
| Write |  |  |  |  |  |  |  |  |  |  |
| Address Set-Up Time | $t_{\text {ACW }}$ | 140 | - | 70 | - | 53 | - | 35 | - | ns |
| Address Hold Time | $\mathrm{t}_{\text {caw }}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| R/ $\bar{W}$ Set-Up Time | $\mathrm{t}_{\text {wow }}$ | 180 | - | 90 | - | 67 | - | 45 | - | ns |
| $\mathrm{R} / \bar{W}$ Hold Time | $\mathrm{t}_{\text {cww }}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| Data Bus Set-Up Time | $t_{\text {dew }}$ | 180 | - | 90 | - | 67 | - | 45 | - | ns |
| Data Bus Hold Time | $\mathrm{t}_{\text {HW }}$ | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| Peripheral Data Delay Time | $\mathrm{t}_{\text {CPW }}$ | - | 1.0 | - | 0.5 | - | 0.5 | - | 0.5 | $\mu \mathrm{S}$ |
| Peripheral Data Delay Time to CMOS Level | $\mathrm{t}_{\text {cmos }}$ | - | 2.0 | - | 1.0 | - | 0.7 | - | 0.5 | $\mu \mathrm{S}$ |

## PERIPHERAL INTERFACE TIMING

| Peripheral Data Set-Up | $\mathrm{t}_{\mathrm{PCR}}$ | 300 | - | 150 | - | 110 | - | 75 | - |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\emptyset 2$ Low to CA2 Low Delay | $\mathrm{t}_{\mathrm{CA} 2}$ | - | 1.0 | - | 0.5 | - | 0.5 | - | 0.5 |
| $\emptyset 2$ Low to CA2 High Delay | $\mathrm{t}_{\mathrm{RS} 1}$ | - | 1.0 | - | 0.5 | - | 0.5 | - | 0.5 |
| CA1 Active to CA2 High Delay | $\mathrm{t}_{\mathrm{RS} 2}$ | - | 2.0 | - | 1.0 | - | 1.0 | - | 1.0 |
| $\emptyset 2$ High to CB2 Low Delay | $\mathrm{t}_{\mathrm{CB} 2}$ | - | 1.0 | - | 0.5 | - | 0.5 | - | 0.5 |
| Peripheral Data Valid to CB2 Low Delay | $\mathrm{t}_{\mathrm{DC}}$ | 0 | 1.5 | 0 | 0.75 | 0 | 0.5 | 0 S |  |
| $\emptyset 2$ High to CB2 High Delay | $\mathrm{t}_{\mathrm{RS} 1}$ | - | 1.0 | - | 0.5 | - | 0.5 | - | 0.57 |
| CB1 Active to CB2 High Delay | $\mathrm{t}_{\mathrm{RS} 2}$ | - | 2.0 | - | 1.0 | - | 0.67 | - | 0.5 |
| CA1, CA2, CB1 and CB2 <br> Input Rise and Fall Time | $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}$ | - | 1.0 | - | 1.0 | - | 1.0 | - | 1.0 |

NOTE: Timing measurements are referenced to and from a low voltage of 0.8 Vdc and a high voltage of 2.0 Vdc .

ABSOLUTE MAXIMUM RATINGS*

| Parameter | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | Vdc |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | -0.3 to $\mathrm{V}_{\mathrm{CC}}+0.3$ | Vdc |
| Output Voltage | $\mathrm{V}_{\mathrm{OUT}}$ | -0.3 to $\mathrm{V}_{\mathrm{CC}}+0.3$ | Vdc |
| Operating Temperature Range <br> Commercial <br> Industrial | $\mathrm{T}_{\mathrm{A}}$ | 0 to +70 <br> -40 to +85 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature |  | $\mathrm{T}_{\mathrm{STG}}$ | -55 to +150 |

*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## OPERATING CONDITIONS

| Parameter | Symbol | Value |
| :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $5 \mathrm{~V} \pm 5 \%$ |
| Temperature Range | $\mathrm{T}_{\mathrm{A}}$ | $\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$ |
| Commercial |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Industrial |  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

## ELECTRICAL CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{S S}=0, T_{A}=T_{L}\right.$ to $T_{H}$, unless otherwise noted)

| Parameter | Symbol | Min. | Typ. ${ }^{3}$ | Max. | Unit ${ }^{2}$ | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | +2.0 | - | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | -0.3 | - | +0.8 | V |  |
| Input Leakage Current R $\bar{W}, \overline{R E S}, R S 0, R S 1, C S 0, \overline{C S} 2, C A 1, C B 1, ~ \emptyset 2$ CS1 | $\mathrm{I}_{\mathrm{N}}$ | - | $\pm 1$ | $\begin{array}{r}  \pm 2.5 \\ \pm 10.0 \end{array}$ | $\mu \mathrm{A}$ | $\begin{aligned} & V_{1 N}=0 \mathrm{~V} \text { to } V_{c \mathrm{C}} \\ & V_{C C}=5.25 \mathrm{~V} \end{aligned}$ |
| Input Leakage Current for Three-State Off D0-D7, PB0-PB7, CB2 | $\mathrm{I}_{\text {TSI }}$ | - | $\pm 2$ | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Input High Current PAO-PA7, CA2 | $\mathrm{I}_{\mathrm{H}}$ | $-200$ | $-300$ | - | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IH}}=2.0 \mathrm{~V}$ |
| Input Low Current PAO-PA7, CA2 | $I_{\text {IL }}$ | - | -2 | -3.2 | mA | $\mathrm{V}_{\mathrm{IL}}=0.8 \mathrm{~V}$ |
| Output High Voltage Logic PB0-PB7, CB2 (Darlington Drive) | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & 2.4 \\ & 1.5 \end{aligned}$ | - | - | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=-200 \mu \mathrm{~A} \\ & \mathrm{I}_{\text {LOAD }}=-3.2 \mathrm{~mA} \end{aligned}$ |
| $\begin{aligned} & \text { Output Low Voltage } \\ & \text { PA0-PA7, CA2, PB0-PB7, CB2 } \\ & \text { D0-D7, IRQA, IRQB } \end{aligned}$ | $\mathrm{V}_{\text {OL }}$ | - | - | +0.4 | V | $\begin{aligned} & V_{C C}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=3.2 \mathrm{~mA} \\ & \mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA} \end{aligned}$ |
| Output High Current (Sourcing) Logic PB0-PB7, CB2 (Darlington Drive) | IOH | $\begin{aligned} & -200 \\ & -3.2 \end{aligned}$ | $\begin{gathered} -1500 \\ -6 \end{gathered}$ | - | $\begin{aligned} & \mu \mathrm{A} \\ & \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V} \end{aligned}$ |
| Output Low Current (Sinking) PA0-PA7, PB0-PB7, CB2, CA2 D0-D7, $\overline{\mathrm{IRQA}}, \overline{\mathrm{IRQB}}$ | IOL | $\begin{aligned} & 3.2 \\ & 1.6 \end{aligned}$ | - | - | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| Output Leakage Current (Off State) IRQA, IRQB | IOFF | - | 1 | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | - | 7 | 10 | $\mathrm{mW} / \mathrm{MHz}$ |  |
| Input Capacitance <br> D0-D7, PA0-PA7, PB0-PB7, CA2, CB2 <br> R/W, $\overline{\text { RES }}, \mathrm{RS} 0, \mathrm{RS} 1, \mathrm{CS} 0, \mathrm{CS} 1, \overline{\mathrm{CS} 2}$ <br> CA1, CB1; $\emptyset 2$ | $\mathrm{C}_{\text {IN }}$ | - | - | $\begin{array}{r} 10 \\ 7 \\ 20 \end{array}$ | pF <br> pF <br> pF | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V} \\ & V_{I N}=0 \mathrm{~V} \\ & f=2 \mathrm{MHZ} \\ & T_{A}=25^{\circ} \mathrm{C} \end{aligned}$ |
| Output Capacitance | $\mathrm{C}_{\text {OUT }}$ | - | - | 10 | pF |  |

## Notes:

1. All units are direct current (dc) except capacitance.
2. Negative sign indicates outward current flow, positive indicates inward flow.
3. Typical values are shown for $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

## PACKAGE DIMENSIONS



## R65C22 Versatile Interface Adapter (VIA)

## DESCRIPTION

The R65C22 Versatile Interface Adapter (VIA) is a very flexible I/O control device. In addition, this device contains a pair of very powerful 16-bit interval timers, a serial-to-parallel/parallel-to serial shift register and input data latching on the peripheral ports. Expanded handshaking capability allows control of bidirectional data transfers between VIA's in multiple processor systems.

The R65C22 includes functions for programmed control of up to two peripheral devices (Ports A and B). These two program controlled 8 -bit bidirectional peripheral I/O ports allow direct interfacing between the microprocessor and selected peripheral units. Each port has input data latching capability. Two programmable Data Direction Registers ( A and B ) allow selection of data direction (input or output) on an individual line basis.

The R65C22 also has two programmable 16-bit Interval Timer/Counters with latches. Timer 1 may be operated in a OneShot Interrupt Mode with interrupts on each count-to-zero, or in a Free-Run Mode with a continuous series of evenly spaced interrupts. Timer 2 functions as both an interval and pulse counter. Serial data transfers are provided by a serial-to-parallel/parallel-to-serial shift register. Application versatility is further increased by various control registers, including-the Interrupt Flag Register, the Interrupt Enable Register, the Auxiliary Control Register and the Peripheral Control Register.

## FEATURES

- Low power CMOS N -well silicon gate technology
- Fully compatible with NMOS 6522 devices
- Two 8-bit bidirectional I/O ports
- Two 16-bit programmable timer/counters
- Serial bidirectional peripheral I/O
- TTL compatible peripheral control lines
- Expanded "handshake" capability allows positive control of data transfers between processor and peripheral devices.
- Latched output and input registers on both I/O ports
- $1,2,3$, and 4 MHz operation
- Commercial and industrial temperature range versions
- Single +5 Vdc power requirement
- Wide variety of packages
- 40-pin plastic and ceramic DIP
-44-pin plastic leaded chip carrier (PLCC)


Figure 1. R65C22 Pin Assignments

## ORDERING INFORMATION



## INTERFACE SIGNALS

Figure 1 (on the front page) shows the R65C22 VIA pin assignments and Figure 2 groups the signals by functional interface.

## RESET (RES)

Reset ( $\overline{\mathrm{RES}}$ ) clears all internal registers (except T 1 and T2 counters and latches, and the Shift Register (SR) ). In the RES condition, all peripheral interface lines ( PA and PB ) are placed in the input state. Also, the Timers (T1 and T2), SR and interrupt logic are disabled from operation.

## INPUT CLOCK (PHASE 2)

The system Phase 2 ( $\emptyset 2$ ) Input Clock controls all data transfers between the R65C22 and the microprocessor.

## READ/WRITE (R/W)

The direction of the data transfers between the R65C22 and the system processor is controlled by the $R / \bar{W}$ line in conjunction with the CS1 and $\overline{C S 2}$ inputs. When $R / \bar{W}$ is low (write operation) and the R65C22 is selected, data is transferred from the processor bus into the selected R65C22 register. When R $\bar{W}$ is high (read operation) and the R65C22 is selected, data is transferred from the selected R65C22 register to the processor bus.

## DATA BUS (DO-D7)

The eight bidirectional Data Bus lines transfer data between the R65C22 and the microprocessor. During a read operation, the contents of the selected R65C22 internal register are transferred to the microprocessor via the Data Bus lines. During a write operation, the Data Bus lines serve as high impedance inputs over which data is transferred from the microprocessor to a selected R65C22 register. The Data Bus lines are in the high impedance state when the R65C22 is unselected.


Figure 2. R65C22 VIA Interface Signals

## CHIP SELECTS (CS1, $\overline{\mathbf{C S 2}}$ )

Normally, the two chip select lines are connected to the microprocessor address lines. This connection may be direct or through decoding. To access a selected R65C22 register, CS1 must be high (logic 1) and $\overline{\mathrm{CS}}$ must be low (logic 0 ).

## REGISTER SELECTS (RS0-RS3)

The Register Select inputs allow the microprocessor to select one of 16 internal registers within the R65C22. Refer to Table 1 for Register Select coding and a functional description.

## INTERRUPT REQUEST ( $\overline{\mathrm{RQ}}$ )

The Interrupt Request ( $\overline{\mathrm{IRQ}}$ ) output signal is generated whenever an internal Interrupt Flag bit is set and the corresponding Interrupt Enable bit is a Logic 1. The Interrupt Request output is an open-drain configuration, thus allowing the $\overline{\mathrm{IRQ}}$ signal to be wire-ORed to a common microprocessor IRQ input line.

## PERIPHERAL PORT A (PA0-PA7)

Peripheral Data Port A is an 8 -line, bidirectional bus for the transfer of data, control and status information between the R65C22 and a peripheral device. Each Peripheral Data Port bus line may be individually programmed as either an input or output under control of a Data Direction Register. Data flow direction may be selected on a line-by-line basis with intermixed input and output lines within the same port. When a " 0 " is written to any bit position of the Data Direction Register, the corresponding line will be programmed as an input. When a " 1 " is written into any bit position of the register, the corresponding data line will serve as an output. Polarity of the data output is determined by the Output Register, while input data may be latched into the Input Register under control of the CA1 line. All modes are program controlled by the microprocessor by way of the R65C22's internal control registers. Each Peripheral Data Port line represents two TTL loads in the input mode and will drive two standard TTL loads in the output mode. A typical output circuit for Peripheral Data Port A is shown in Figure 3.

## PORT A CONTROL LINES (CA1, CA2)

Control lines CA1 and CA2 serve as interrupt inputs or handshake outputs for Peripheral Data Port A. Each line controls an internal Interrupt Flag with a corresponding Interrupt Enable bit. CA1 also controls the latching of Input Data on Port A. CA1 is a high impedance input, while CA2 represents two standard TTL loads in the input mode. In the output mode, CA2 will drive two standard TTL loads.

## PORT B (PB0-PB7)

Peripheral Data Port B is an 8-line, bidirectional bus which is controlled by an Output Register, Input Register and Data Direction Register in a manner much the same as Data Port A. With respect to Port B, the output signal on line PB7 may be controlled by Timer 1 while Timer 2 may be programmed to count pulses on the PB6 line. Port B lines represent two standard TTL loads in the input mode and will drive two TTL loads in the
output mode. Port B lines are also capable of sourcing 3.2 mA at 1.5 Vdc in the output mode. This allows the outputs to directly drive Darlington transistor circuits. A typical output circuit for Port B is shown in Figure 3.

## PORT B CONTROL LINES (CB1, CB2)

Control lines CB1 and CB2 serve as interrupt inputs or handshake outputs for Peripheral Data Port B. Like Port A, these two control lines control an internal Interrupt Flag with a corresponding Interrupt Enable bit. These lines also serve as a serial data port under control of the Shift Register (SR). Each control line represents two standard TTL loads in the input mode and can drive two TTL loads in the output mode. Note that CB1 and CB2 can drive Darlington transistor circuits, because they both will source 3.2 mA at 1.5 Vdc . Each line represents two standard TTL loads in the input mode and will drive two standard TTL loads in the output mode.

Table 1. R65C22 Register Addressing

| Register Number | RS Coding |  |  |  | Register Desig. | Register/Description |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | RS3 | RS2 | RS1 | RSO |  | Write (R/W = L) | Read (R/W = H) |
| 0 | 0 | 0 | 0 | 0 | ORB/IRB | Output Register B | Input Register B |
| 1 | 0 | 0 | 0 | 1 | ORA/RA | Output Register A | Input Register A |
| 2 | 0 | 0 | 1 | 0 | DDRB | Data Direction Register B |  |
| 3 | 0 | 0 | 1 | 1 | DDRA | Data Direction Register A |  |
| 4 | 0 | 1 | 0 | 0 | T1C-L | T1 Low-Order Latches | T1 Low-Order Counter |
| 5 | 0 | 1 | 0 | 1 | T1C-H | T1 High-Order Counter |  |
| 6 | 0 | 1 | 1 | 0 | T1L-L | T1 Low-Order Latches |  |
| 7 | 0 | 1 | 1 | 1 | T1L-H | T1 High-Order Latches |  |
| 8 | 1 | 0 | 0 | 0 | T2C-L | T2 Low-Order Latches | T2 Low-Order Counter |
| 9 | 1 | 0 | 0 | 1 | T2C-H | T2 High-Order Counter |  |
| 10 | 1 | 0 | 1 | 0 | SR | Shift Register |  |
| 11 | 1 | 0 | 1 | 1 | ACR | Auxiliary Control Register |  |
| 12 | 1 | 1 | 0 | 0 | PCR | Peripheral Control Register |  |
| 13 | 1 | 1 | 0 | 1 | IFR | Interrupt Flag Register |  |
| 14 | 1 | 1 | 1 | 0 | IER | Interrupt Enable Register |  |
| 15 | 1 | 1 | 1 | 1 | ORAIRA | Output Register $\mathrm{A}^{*}$ | Input Register $\mathrm{A}^{*}$ |
| NOTE: *Same as Register 1 except no handshake. |  |  |  |  |  |  |  |



Figure 3. Port A and B Output Circuits

## FUNCTIONAL DESCRIPTION

The internal organization of the R65C22 VIA is illustrated in Figure 4.

## PORT A AND PORT B OPERATION

The R65C22 VIA has two 8-bit bidirectional I/O ports (Port A and Port B) and each port has two associated control lines.

Each 8-bit peripheral port has a Data Direction Register (DDRA, DDRB) for specifying whether the peripheral pins are to act as inputs or outputs. A " 0 " in a bit of the Data Direction Register causes the corresponding peripheral pin to act as an input. A " 1 " causes the pin to act as an output.

Each peripheral pin is also controlled by a bit in the Output Register (ORA, ORB) and the Input Register (IRA, IRB). When the pin is programmed as an output, the voltage on the pin is controlled by the corresponding bit of the Output Register. A "1" in the Output Register causes the output to go high, and a " 0 " causes the output to go low. Data may be written into Output

Register bits corresponding to pins which are programmed as inputs. In this case, however, the output signal is unaffected.

Reading a peripheral port causes the contents of the Input Register (IRA, IRB) to be transferred onto the Data Bus. With input latching disabled, IRA will always reflect the levels on the PA pins. With input latching enabled, IRA will reflect the levels on the PA pins at the time the latching occurred (via CA1).

The IRB register operates similar to the IRA register. However, for pins programmed as outputs there is a difference. When reading IRA, the level on the pin determines whether a " 0 " or a " 1 " is sensed. When reading IRB, however, the bit stored in the output register, ORB, is the bit sensed. Thus, for outputs which have large loading effects and which pull an output " 1 " down or which pull an output " 0 " up, reading IRA may result in reading a " 0 " when a " 1 " was actually programmed, and reading a " 1 " when a " 0 "' was programmed. Reading IRB, on the other hand, will read the " 1 " or " 0 " level actually programmed, no matter what the loading on the pin.

Figures 5 through 8 illustrate the formats of the port registers.


Figure 4. R65C22 VIA Block Diagram

## HANDSHAKE CONTROL OF DATA TRANSFERS

The R65C22 allows positive control of data transfers between the system processor and peripheral devices through the operation of "handshake"' lines. Port A lines (CA1, CA2) handshake data on both a read and a write operation while the Port B lines (CB1, CB2) handshake on a write operation only.

## Read Handshake

Positive control of data transfers from peripheral devices into the system processor can be accomplished very effectively using Read Handshaking. In this case, the peripheral device must generate the equivalent of a "Data Ready" signal to the processor signifying that valid data is present on the peripheral


Figure 5. Output Register B (ORB), Input Register B (IRB)

Figure 7. Data Direction Register B (DDRB)
port. This signal normally interrupts the processor, which then reads the data, causing generation of a "Data Taken" signal. The peripheral device responds by making new data available. This process continues until the data transfer is complete.

In the R65C22, automatic "Read" Handshaking is possible on the Peripheral A port only. The CA1 interrupt input pin accepts the "Data Ready" signal and CA2 generates the "Data Taken", signal. The "Data Ready"' signal will set an internal flag which may interrupt the processor or which may be polled under program control. The "Data Taken" signal can either be a pulse or a level which is set low by the system processor and is cleared by the "Data Ready" signal. These options are shown in Figure 9 which illustrates the normal Read Handshake sequence.


Figure 6. Output Register A (ORA), Input Register A (IRA)


Figure 8. Data Direction Register A (DDRA)


Figure 9. Read Handshake Timing (Port A Only)

## Write Handshake

The sequence of operations which allows handshaking data from the system processor to a peripheral device is very similar to that described for Read Handshaking. However, for Write Handshaking, the R65C22 generates the "Data Ready" signal and the peripheral device must respond with the "Data Taken'' signal. This can be accomplished on both the PA port and the PB port on the R65C22. CA2 or CB2 act as a "Data Ready" output in either the handshake mode or pulse mode and CA1 or CB1 accept the "Data Taken" signal from the peripheral device, setting the interrupt flag and clearing the "Data Ready" output. This sequence is shown in Figure 10.

## Latching

The PA port and the PB port on the R65C22 can be enabled in the Auxiliary Control Register (Figure 14) to be latched by their individual port control lines (CA1, CB1). Latching is selectable to be on the rising or falling edge of the signal at each individual port control line. Selection of operating modes for CA1, CA2, CB1 and CB2 is accomplished by the Peripheral Control Register (Figure 11).


Figure 11. Peripheral Control Register (PCR)


Figure 10. Write Handshake Timing

## COUNTER/TIMERS

There are two independent 16 -bit counter/timers (called Timer 1 and Timer 2) in the R65C22. Each timer is controlled by writing bits into the Auxiliary Control Register (ACR) to select the mode of operation (Figure 14).

## Timer 1 Operation

Interval Timer T1 consists of two 8-bit latches (Figure 12) and a 16 -bit counter (Figure 13). The latches store data which is to be loaded into the counter. After loading, the counter decrements at $\emptyset 2$ clock rate. Upon reaching zero, an interrupt flag is set, and IRQ goes low if the T1 interrupt is enabled. Timer 1 then
disables any further interrupts and automatically transfers the contents of the latches into the counter and continues to decrement. In addition, the timer may be programmed to invert the output signal on peripheral pin PB7 each time it "times-out". Each of these modes is discussed separately below.

Note that the processor does not write directly into the low-order counter (T1C-L). Instead, this half of the counter is loaded automatically from the low order latch (T1L-L) when the processor writes into the high order counter (T1C-H). In fact, it may not be necessary to write to the low order counter in some applications since the timing operation is triggered by writing to the high order latch.

REG 6-TIMER 1 LOW-ORDER LATCH


WRITE - 8 BITS LOADED INTO TI LOW-ORDER
LATCHES THIS OPERATION IS NO
DIFFERENT THAN A WRITE INTO
REG 4
READ - 8 BITS FROM T1 LOW-ORDER LATCHES
TRANSFEAON THIS MPU UNLIKE REG 4
RESET OF T1 INTERRUPT FLAG

REG 7-TIMER 1 HIGH-ORDER LATCH


WRITE - 8 BITS LOADED INTO TI HIGH-ORDER LATCHES. UNLIKE REG 4 OPERATION NO LATCH-TO-COUNTER TRANSFERS TAKE PLACE. T1 INTERRUPT FLAG IS


Figure 12. Timer 1 (T1) Latch Registers

REG 4-TIMER 1 LOW-ORDER COUNTER


WRITE - 8 BITS LOADED INTO TI LOW-ORDER LATCHES LATCH CONTENTS ARE TRANSFERRED INTO LOW-ORDER COUNTER AT THE TIME THE HIGH.
ORDER COUNTER IS LOADED (REG 5)
READ - 8 BITS FROM T1 LOW-ORDER COUNTER TRANSFERRED TO MPU IN ADDITION. T1 INTERRUPT FLAG IS RESET (BIT 6 . IN INTERRUPT FLAG REGISTER)

REG 5-TIMER 1 HIGH-ORDER COUNTER


WRITE - 8 BITS LOADED INTO T1 HIGH-ORDER LATCHES. ALSO, AT THIS TIME BOTH
HIGH. AND LOW-ORDER LATCHES ARE TRANSFERRED INTO T1 COUNTER T1 INTERRUPT FLAG ALSO IS RESET
READ - 8 BITS FROM T1 HIGH-ORDER COUNTER TRANSFERRED TO MPU.

Figure 13. Timer 1 (T1) Counter Registers


Figure 14. Auxiliary Control Register (ACR)

## Timer 1 One-Shot Mode

The Timer 1 one-shot mode generates a single interrupt for each timer load operation. As with any interval timer, the delay between the "write T1C-H" operation and generation of the processor interrupt is a direct function of the data loaded into the timing counter. In addition to generating a single interrupt, Timer 1 can be programmed to produce a single negative pulse on the PB 7 peripheral pin. With the output enabled $(A C R 7=1)$ a "write T1C-H" operation will cause PB7 to go low. PB7 will return high when Timer 1 times out. The result is a single programmable width pulse.

Timing for the R65C22 interval timer one-shot modes is shown in Figure 15.

In the one-shot mode, writing into the T1L-H has no effect on the operation of Timer 1. However, it will be necessary to assure that the low order latch contains the proper data before initiating the count-down with a "write T1C-H" operation. When the processor writes into the high order counter ( $\mathrm{T} 1 \mathrm{C}-\mathrm{H}$ ), the T1 interrupt flag will be cleared, the contents of the low order latch will be transferred into the low order counter, and the timer will begin to decrement at system clock rate. If the PB7 output is enabled, this signal will go low on the falling edge of $\emptyset 2$ following the write operation. When the counter reaches zero, the T1 interrupt flag will be set, the $\overline{\mathrm{RQ}}$ pin will go low (interrupt enabled), and the signal on PB7 will go high. At this time the counter will continue to decrement at system clock rate. This allows the system processor to read the contents of the counter to determine the time since interrupt. However, the T1 interrupt flag cannot be set again unless it has been cleared as described in this specification.


Figure 15. Timer 1 One-Shot Mode Timing

## Timer 1 Free-Run Mode

The most important advantage associated with the latches in T1 is the ability to produce a continuous series of evenly spaced interrupts and the ability to produce a square wave on PB7 whose frequency is not affected by variations in the processor interrupt response time. This is accomplished in the "free-running" mode.

In the free-running mode, the interrupt flag is set and the signal on PB7 is inverted each time the counter reaches zero at which time the timer automatically transfers the contents of the latch into the counter ( 16 bits) and continues to decrement from there. The interrupt flag can be cleared by writing T1C-H or T1L-H, by reading T1C-L, or by writing directly into the flag as described later. However, it is not necessary to rewrite the timer to enable setting the interrupt flag on the next time-out.

All interval timers in the R65C22 are "re-triggerable". Rewriting the counter will always re-initialize the time-out period. In fact,
the time-out can be prevented completely if the processor continues to rewrite the timer before it reaches zero. Timer 1 will operate in this manner if the processor writes into the high order counter (T1C-H). However, by loading the latches only, the processor can access the timer during each down-counting operation without affecting the time-out in process. Instead, the data loaded into the latches will determine the length of the next time-out period. This capability is particularly valuable in the freerunning mode with the output enabled. In this mode, the signal on PB7 is inverted and the interrupt flag is set with each timeout. By responding to the interrupts with new data for the latches, the processor can determine the period of the next half cycle during each half cycle of the output signal on PB7. In this manner, very complex waveforms can be generated.

A precaution to take in the use of PB7 as the timer output concerns the Data Direction Register contents for PB7. Both DDRB bit 7 and ACR bit 7 must be 1 for PB7 to function as the timer output. If one is 1 and other is 0 , then PB7 functions as a normal outpin pin, controlled by ORB bit 7.


Figure 16. Timer 1 Free-Run Mode Timing

## Timer 2 Operation

Timer 2 operates as an interval timer (in the "one-shot" mode only), or as a counter for counting negative pulses on the PB6 peripheral pin. A single control bit in the Auxiliary Control Register selects between these two modes. This timer is comprised of a "write-only" lower-order latch (T2L-L), a "read-only" low-order counter (T2C-L) and a read/write high order counter (T2C-H). The counter registers act as a 16-bit counter which decrements at $\emptyset 2$ rate. Figure 17 illustrates the T2 Latch/Counter Registers.

## Timer 2 One-Shot Mode

As an interval timer, T2 operates in the "one-shot" mode similar to Timer 1. In this mode, T2 provides a single interrupt for each "write T2C-H" operation. After timing out, the counter will continue to decrement. However, setting of the interrupt flag is disabled after initial time-out so that it will not be set by the counter
decrementing again through zero. The processor must rewrite T2C-H to enable setting of the interrupt flag. The interrupt flag is cleared by reading T2C-L or by writing T2C-H. Timing for this operation is shown in Figure 18.

## Timer 2 Pulse Counting Mode

In the pulse counting mode, T2 counts a predetermined number of negative-going pulses on PB6. This is accomplished by first loading a number into T . Writing into T2C-H clears the interrupt flag and allows the counter to decrement each time a pulse is applied to PB6. The interrupt flag is set when T2 counts down past zero. The counter will then continue to decrement with each pulse on PB6. However, it is necessary to rewrite T2C-H to allow the interrupt flag to set on a subsequent time-out. Timing for this mode is shown in Figure 19. The pulse must be low on the leading edge of $\emptyset 2$.


Figure 17. Timer 2 (T2) Latch/Counter Registers


Figure 18. Timer 2 One-Shot Mode Timing


Figure 19. Timer 2 Pulse Counting Mode

## SHIFT REGISTER OPERATION

The Shift Register (SR) performs serial data transfers into and out of the CB2 pin under control of an internal modulo-8 counter. Serial data transfer in and out of the Shift Register (SR) begin with the most significant bit (MSB) first. Shift pulses can be applied to the CB1 pin from an external source or, with the proper mode selection, shift pulses generated internally will appear on the CB1 pin for controlling external devices.

The control bits which select the various shift register operating modes are located in the Auxiliary Control Register. Figure 20 illustrates the configuration of the SR data bits and Figure 21 shows the SR control bits of the ACR.

## SR Mode 0 - Shift Register Interrupt Disabled

Mode 0 disables the Shift Register interrupt. In this mode the microprocessor can write or read the SR and the SR will shift on each CB1 positive edge shifting in the value on CB2. In this mode the SR interrupt Flag is disabled (held to a logic 0 ).

## SR Mode 1 - Shift In Under Control of T2

In mode 1, the shifting rate is controlled by the low order 8 bits of T2 (Figure 22). Shift pulses are generated on the CB1 pin to


Figure 20. Shift Register
control shifting in external devices. The time between transitions of this output clock is a function of the system clock period and the contents of the low order T2 latch ( N ).

The shifting operation is triggered by the read or write of the SR if the SR flag is set in the IFR. Otherwise the first shift will occur at the next time-out of T2 after a read or write of the SR. The input data should change before the positive-going edge of CB1 clock pulse. This data is shifted into the shift register during the $\emptyset 2$ clock cycle following the positive-going edge of the CB1 clock pulse. After 8 CB1 clock pulses, the shift register interrupt flag will set and $\overline{\mathrm{RQ}}$ will go low.

## SR Mode 2 - Shift In Under $\boldsymbol{0} 2$ Control

In mode 2, the shift rate is a direct function of the system clock frequency (Figure 23). CB1 becomes an output which generates shift pulses for controlling external devices. Timer 2 operates as an independent interval timer and has no effect on SR. The shifting operation is triggered by reading or writing the Shift Register. Data is shifted, first into bit 0 and is then shifted into the next higher order bit of the shift register on the trailing edge of each $\emptyset 2$ clock pulse. After 8 clock pulses, the shift register interrupt flag will be set, and the output clock pulses on CB1 will stop.

REG 11-AUXILIARY CONTROL REGISTER


| 4 | 3 | 2 | OPERATION |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | DISABLED |
| 0 | 0 | 1 | SHIFT IN UNDER CONTROL OF T2 |
| 0 | 1 | 0 | SHIFT IN UNDER CONTROL OF $\emptyset 2$ |
| 0 | 1 | 1 | SHIFT IN UNDER CONTROL OF EXT CLK |
| 1 | 0 | 0 | SHIFT OUT FREE RUNNING AT T2 RATE |
| 1 | 0 | 1 | SHIFT OUT UNDER CONTROL OF T2 |
| 1 | 1 | 0 | SHIFT OUT UNDER CONTROL OF 02 |
| 1 | 1 | 1 | SHIFT OUT UNDER CONTROL OF EXT CLK |

Figure 21. Shift Register Modes


Figure 22. SR Mode 1 - Shift In Under T2 Control

## SR Mode 3 - Shift In Under CB1 Control

In mode 3, external pin CB1 becomes an input (Figure 24). This allows an external device to load the shift register at its own pace. The shift register counter will interrupt the processor each time 8 bits have been shifted in. The shift register stops after 8 counts and must be reset to start again. Reading or writing the Shift Register resets the Interrupt Flag and initializes the SR counter to count another 8 pulses.

Note that the data is shifted during the first system clock cycle following the positive-going edge of the CB1 shift pulse. For this reason, data must be held stable during the first full cycle following CB1 going high.

## SR Mode 4 - Shift Out Under T2 Control (Free-Run)

Mode 4 is very similar to mode 1 in which the shifting rate is
set by T2. However, in mode 4 the SR Counter does not stop the shifting operation (Figure 25). Since the Shift Register bit 7 (SR7) is recirculated back into bit 0 , the 8 bits loaded into the shift register will be clocked onto CB2 repetitively. In this mode the shift register counter is disabled.

## SR Mode 5 - Shift Out Under T2 Control

In mode 5, the shift rate is controlled by T2 (as in mode 1). The shifting operation is triggered by the read or write of the SR if the SR flag is set in the IFR (Figure 26). Otherwise the first shift will occur at the next time-out of T2 after a read or write of the SR. However, with each read or write of the shift register the SR Counter is reset and 8 bits are shifted onto CB2. At the same time, 8 shift pulses are generated on CB1 to control shifting in external devices. After the 8 shift pulses, the shifting is disabled, the SR Interrupt Flag is set and CB2 remains at the last data level.


Figure 23. SR Mode 2 - Shift In Under $\emptyset 2$ Control


Figure 24. SR Mode 3 - Shift In Under CB1 Control


Figure 25. SR Mode 4 - Shift Out Under T2 Control (Free-Run)

## SR Mode 6 - Shift Out Under $\$ 2$ Control

In mode 6, the shift rate is controlled by the $\emptyset 2$ system clock (Figure 27).

## SR Mode 7 - Shift Out Under CB1 Control

In mode 7, shifting is controlled by pulses applied to the CB1 pin by an external device (Figure 28). The SR counter sets the SR

Interrupt Flag each time it counts 8 pulses but it does not disable the shifting function. Each time the microprocessor, writes or reads the shift register, the SR Interrupt Flag is reset and the SR counter is initialized to begin counting the next 8 shift pulses on pin CB1. After 8 shift pulses, the Interrupt Flag is set. The microprocessor can then load the shift register with the next byte of data.


Figure 26. SR Mode 5 - Shift Out Under T2 Control


Figure 27. SR Mode 6 - Shift Out Under $\mathbf{~} 2$ Control


Figure 28. SR Mode 7 - Shift Out Under CB1 Control

## INTERRUPT OPERATION

Controlling interrupts within the R65C22 involves three principal operations. These are flagging the interrupts, enabling interrupts and signaling to the processor that an active interrupts exists within the chip. Interrupt flags are set in the Interrupt Flag Register (IFR) by conditions detected within the R65C22 or on inputs to the R65C22. These flags normally remain set until the interrupt has been serviced. To determine the source of an interrupt, the microprocessor must examine these flags in order, from highest to lowest priority.

Associated with each interrupt flag is an interrupt enable bit in the Interrupt Enable Register (IER). This can be set or cleared by the processor to enable interrupting the processor from the corresponding interrupt flag. If an interrupt flag is set to a logic 1 by an interrupting condition, and the corresponding interrupt enable bit is set to a 1 , the Interrupt Request Output (IRQ) will go low. IRQ is an "open-collector" output which can be "wire-OR'ed" with other devices in the system to interrupt the processor.

## Interrupt Flag Register (IFR)

In the R65C22, all the interrupt flags are contained in one register, i.e., the IFR (Figure 29). In addition, bit 7 of this register will be read as a logic 1 when an interrupt exists within the chip. This allows very convenient polling of several devices within a system to locate the source of an interrupt.

The Interrupt Flag Register (IFR) may be read directly by the processor. In addition, individual flag bits may be cleared by writing a " 1 " into the appropriate bit of the IFR. When the proper chip select and register signals are applied to the chip, the contents of this register are placed on the data bus. Bit 7 indicates the status of the $\overline{\mathrm{IRQ}}$ output. This bit corresponds to the logic


Figure 29. Interrupt Flag Register (IFR)
function: $\overline{\mathrm{IRQ}}=\mathrm{IFR} 6 \times$ IER6 + IFR5 $\times$ IER5 + IFR4 $\times$ IER4 + IFR3 $\times$ IER3 + IFR2 $\times$ IER2 + IFR1 $\times$ IER1 + IFR0 $\times$ IERO.

## Note:

$$
x=\operatorname{logic} A N D,+=\text { Logic OR. }
$$

The IFR bit 7 is not a flag. Therefore, this bit is not directly cleared by writing a logic 1 into it. It can only be cleared by clearing all the flags in the register or by disabling all the active interrupts as discussed in the next section.

## Interrupt Enable Register (IER)

For each interrupt flag in IFR, there is a corresponding bit in the Interrupt Enable Register (IER) (Figure 30). Individual bits in the IER can be set or cleared to facilitate controlling individual interrupts without affecting others. This is accomplished by writing to the (IER) after bit 7 set or cleared to, in turn, set or clear selected enable bits. If bit 7 of the data placed on the system data bus during this write operation is a 0 , each 1 in bits 6 through 0 clears the corresponding bit in the Interrupt Enable Register. For each zero in bits 6 through 0 , the corresponding bit is unaffected.

Selected bits in the IER can be set by writing to the IER with bit 7 in the data word set to a 1. In this case, each 1 in bits 6 through 0 will set the corresponding bit. For each zero, the corresponding bit will be unaffected. This individual control of the setting and clearing operations allows very convenient control of the interrupts during system operation.

In addition to setting and clearing IER bits, the contents of this register can be read at any time. Bit 7 will be read as a logic 1 , however.

REG 14-INTERRUPT ENABLE REGISTER


NOTES
1 IF BIT 7 IS A " 0 ". THEN EACH " 1 " IN BITS 0 - 6 DISABLES THE
CORRESPONDING INTERRUPT
2 IF BIT 7 IS A " 1 "..THEN EACH " 1 " IN BITS $0-6$ ENABLES THE CORRESPONDING INTERRUPT
3 IF A READ OF THIS REGISTER IS DONE, BIT 7 WILL BE " 1 " AND ALL OTHER BITS WILL REFLECT THEIR ENABLE/DISABLE STATE

Figure 30. Interrupt Enable Register (IER)

## SWITCHING CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0, \mathrm{~T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}\right.$ to $\mathrm{T}_{\mathrm{H}}$, unless otherwise noted)

## PERIPHERAL INTERFACE TIMING

| Parameter | Symbol | Min. | Max. | Unit | Figure |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Rise and Fall Time for CA1, CB1, CA2 and CB2 Input Signals | $t_{r}, t_{f}$ | - | 1.0 | $\mu \mathrm{S}$ | - |
| Delay Time, Clock Negative Transition to CA2 Negative Transition (read handshake or pulse mode) | $\mathrm{t}_{\mathrm{CA} 2}$ | - | 1.0 | $\mu \mathrm{S}$ | 31a, 31b |
| Delay Time, Clock Negative Transition to CA2 Positive Transition (pulse mode) | $\mathrm{t}_{\text {RS } 1}$ | - | 1.0 | $\mu \mathrm{S}$ | 31a |
| Delay Time, CA1 Active Transition to CA2 Positive Transition (handshake mode) | $\mathrm{t}_{\text {RS2 }}$ | - | 2.0 | $\mu \mathrm{S}$ | 31b |
| Delay Time, Clock Positive Transition to CA2 or CB2 Negative Transition (write handshake) | ${ }^{\text {W WHS }}$ | 0.05 | 1.0 | $\mu \mathrm{S}$ | 31c, 31d |
| Delay Time, Periphral Data Valid to CB2 Negative Transition | $t_{\text {DS }}$ | 0.20 | 1.5 | $\mu \mathrm{S}$ | 31c, 31d |
| Delay Time, Clock Positive Transition to CA2 or CB2 Positive Transition (pulse mode) | $\mathrm{t}_{\text {RS3 }}$ | - | 1.0 | $\mu \mathrm{S}$ | 31c |
| Delay Time, CA1 or CB1 Active Transition to CA2 or CB2 Positive Transition (handshake mode) | $\mathrm{t}_{\mathrm{RS} 4}$ | - | 2.0 | $\mu \mathrm{S}$ | 31d |
| Delay Time Required from CA2 Output to CA1 Active Transition (handshake mode) | $\mathrm{t}_{21}$ | 400 | - | ns | 31d |
| Setup Time, Peripheral Data Valid to CA1 or CB1 Active Transition (input latching) | $t_{\text {IL }}$ | 300 | - | ns | 31 e |
| CA1, CB1 Setup Prior to Transition to Arm Latch | $t_{\text {AL }}$ | 300 | - | ns | 31 e |
| Peripheral Data Hold After CA1, CB1 Transition | $t_{\text {PDH }}$ | 150 | - | ns | 31 e |
| Shift-Out Delay Time - Time from $\emptyset 2$ Falling Edge to CB2 Data Out | $\mathrm{t}_{\text {SR1 }}$ | - | 300 | ns | 31 f |
| Shift-In Setup Time - Time from CB2 Data In to $\emptyset 2$ Rising Edge | $\mathrm{t}_{\text {SR2 }}$ | 300 | - | ns | 31g |
| External Shift Clock (CB1) Setup Time Relative to $\emptyset 2$ Trailing Edge | $\mathrm{t}_{\text {SR3 }}$ | 100 | $\mathrm{T}_{\mathrm{Cr}}$ | ns | 31g |
| Pulse Width - PB6 Input Pulse | $\mathrm{t}_{\text {IPW }}$ | $2 \times \mathrm{T}_{\mathrm{CY}}$ | - |  | $31 i$ |
| Pulse Width - CB1 Input Clock | $\mathrm{t}_{\mathrm{ICW}}$ | $2 \times \mathrm{T}_{C Y}$ | - |  | 31h |
| Pulse Spacing - PB6 Input Pulse | $\mathrm{t}_{\text {IPS }}$ | $2 \times \mathrm{T}_{C Y}$ | - |  | $31 i$ |
| Pulse Spacing - CB1 Input Pulse | $\mathrm{t}_{\text {ICS }}$ | $2 \times \mathrm{T}_{C Y}$ | - |  | 31h |

BUS TIMING

| Parameter | Symbol | 1 MHz |  | 2 MHz |  | 3 MHz |  | 4 MHZ |  | Unit | Figure |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |  |
| Cycle Time | $\mathrm{t}_{\mathrm{CY}}$ | 1000 | - | 500 | - | 330 | - | 250 | - | ns |  |
| Phase 2 Pulse Width High | $t_{\text {PWH }}$ | 470 | - | 240 | - | 160 | - | 120 | - | ns | 32a, |
| Phase 2 Pulse Width Low | $t_{\text {PWL }}$ | 470 | - | 240 | - | 160 | - | 120 | - | ns | 32b |
| Phase 2 Transition | $\mathrm{t}_{\mathrm{R}, \mathrm{F}}$ | - | 30 | - | 30 | - | 30 | - | 30 | ns |  |
| Read |  |  |  |  |  |  |  |  |  |  |  |
| Select, R/W Setup | $t_{\text {ACR }}$ | 160 | - | 90 | - | 65 | - | 45 | - | ns | 32a |
| Select, R/W Hold | $\mathrm{t}_{\text {CAR }}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |  |
| Data Bus Delay | $\mathrm{t}_{\text {CDR }}$ | - | 320 | - | 150 | - | 130 | - | 75 | ns |  |
| Data Bus Hold | $\mathrm{t}_{\mathrm{HR}}$ | 10 | - | 10 | - | 10 | - | 10 | - | ns |  |
| Peripheral Data Setup | $\mathrm{t}_{\text {PCR }}$ | 300 | - | 150 | - | 110 | - | 75 | - | ns |  |
| Write |  |  |  |  |  |  |  |  |  |  |  |
| Select R/W Setup | $\mathrm{t}_{\text {ACW }}$ | 160 | - | 90 | - | 65 | - | 45 | - | ns | 32 b |
| Select, R/ $\bar{W}$ Hold | $\mathrm{t}_{\text {CAW }}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |  |
| Data Bus Setup | $\mathrm{t}_{\text {DCW }}$ | 195 | - | 75 | - | 65 | - | 45 | - | ns |  |
| Data Bus Hold | $\mathrm{t}_{\mathrm{HW}}$ | 10 | - | 10 | - | 10 | - | 10 | - | ns |  |
| Peripheral Data Delay | $\mathrm{t}_{\text {CPW }}$ | - | 1000 | - | 500 | - | 330 | - | 250 | ns |  |

## PERIPHERAL INTERFACE WAVEFORMS



Figure 31a. CA2 Timing for Read Handshake, Pulse Mode


Figure 31b. CA2 Timing for Read Handshake, Handshake Mode


Figure 31c. CA2, CB2 Timing for Write Handshake, Pulse Mode


Figure 31d. CA2, CB2 Timing for Write Handshake, Handshake Mode


Figure 31e. Peripheral Data Input Latching Timing


Figure 31f. Timing for Shift Out with Internal or External Shift Clocking


NOTE: SET UP TIMES $\mathrm{t}_{\mathrm{SR} 2}$ AND $\mathrm{t}_{\mathrm{SR} 3}$ MUST BE OBSERVED.
Figure 31g. Timing for Shift In with Internal or External Shift Clocking


Figure 31h. External Shift Clock Timing


Figure 31i. Pulse Count Input Timing

## BUS TIMING WAVEFORMS



Figure 32a. Read Timing Waveforms


Figure 32b. Write Timing Waveforms

## ABSOLUTE MAXIMUM RATINGS*

| Parameter | Symbol | Value | Unit |
| :--- | :--- | :--- | :--- |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | Vdc |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | -0.3 to $\mathrm{V}_{\mathrm{CC}}+0.3$ | Vdc |
| Output Voltage | $\mathrm{V}_{\mathrm{OUT}}$ | -0.3 to $\mathrm{V}_{\mathrm{CC}}+0.3$ | Vdc |
| Operating Temperature <br> Commercial <br> Industrial | $\mathrm{T}_{\mathrm{A}}$ | 0 to +70 <br> -40 to +85 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature |  | $\mathrm{T}_{\mathrm{STG}}$ | -55 to +150 |

## OPERATING CONDITIONS

| Parameter | Symbol | Value |
| :---: | :---: | :--- |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $5 \mathrm{~V} \pm 5 \%$ |
| Temperature Range | $\mathrm{T}_{\mathrm{A}}$ | $\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$ |
| Commercial |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Industrial |  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## ELECTRICAL CHARACTERISTICS

$\left(V_{C C}=5.0 \mathrm{Vdc} \pm 5 \%, V_{S S}=0, T_{A}=T_{L}\right.$ to $T_{H}$, unless otherwise noted)

| Parameter | Symbol | Min. | Typ. ${ }^{3}$ | Max. | Unit ${ }^{1}$ | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage Logic $\emptyset_{2}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\begin{array}{r} +2.0 \\ +2.4 \\ \hline \end{array}$ | - | $\begin{aligned} & \mathrm{v}_{\mathrm{Cc}} \\ & \mathrm{v}_{\mathrm{cc}} \\ & \hline \end{aligned}$ | V |  |
| Input Low Voltage Logic $\emptyset_{2}$ | $\mathrm{V}_{\mathrm{IL}}$ | $\begin{aligned} & -0.3 \\ & -0.4 \end{aligned}$ | - | $\begin{aligned} & +0.8 \\ & +0.4 \\ & \hline \end{aligned}$ | v |  |
| Input Leakage Current <br> R $\bar{W}, \overline{R E S}$, RSO, RS1, RS2, RS3, CS1, $\overline{C S 2}, C A 1, ~ \emptyset 2$ | $\mathrm{I}_{\mathrm{N}}$ | - | $\pm 1$ | $\pm 2.5$ | $\mu \mathrm{A}$ | $\begin{aligned} & V_{1 N}=0 \mathrm{~V} \text { to } \mathrm{V}_{\mathrm{CC}} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Input Leakage Current for Three-State Off DO-D7 | ${ }^{\text {TS }}$ I | - | $\pm 2$ | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & \mathrm{VCC}=5.25 \mathrm{~V} \end{aligned}$ |
| Input Migh Current <br> PA0-PA7, CA2, PB0-PB7, CB1, CB2 | $\mathrm{I}_{\mathrm{H}}$ | -200 | -400 | - | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ |
| Input Low Current PA0-PA7, CA2, PB0-PB7, CB1, CB2 | $1 / 2$ | - | -2 | -2.6 | mA | $\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V}$ |
| Output High Voltage <br> All outputs <br> PB0-PB7, CB1 and CB2 (Darlington Drive) | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & 2.4 \\ & 1.5 \end{aligned}$ | - | - | v | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=200 \mu \mathrm{~A} \\ & \mathrm{I}_{\text {LOAD }}=-3.2 \mathrm{~mA} \end{aligned}$ |
| $\begin{aligned} & \text { Output Low Voltage } \\ & \text { PA0-PA7, CA2, PB0-PB7, CB1, CB2, } \\ & \text { D0-D7, } \overline{\mathrm{IRQ}} \end{aligned}$ | $\mathrm{V}_{\text {OL }}$ | - | - | $+0.4$ | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=3.2 \mathrm{~mA} \\ & \mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA} \end{aligned}$ |
| Output High Current (Sourcing) Logic <br> PB0-PB7, CB1 and CB2 (Darlington Drive) | ${ }^{1} \mathrm{OH}$ | $\begin{aligned} & -200 \\ & -3.2 \end{aligned}$ | $\begin{gathered} -1500 \\ -6 \end{gathered}$ | - | $\begin{aligned} & \mu \mathrm{A} \\ & \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V} \end{aligned}$ |
| Output Low Current (Sinking) | 1 OL | 3.2 | - | - | mA | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| Output Leakage Current (Off State) $\overline{\mathrm{IRQ}}$ | $\mathrm{I}_{\text {OFF }}$ | - | 1 | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | - | 7 | 10 | mW/MHz |  |
| Input Capacitance <br> D0-D7, PA0-PA7, CA1, CA2, PB0-PB7, CB1, CB2 $R / \bar{W}, \overline{R E S}, R S 0, R S 1, R S 2, R S 3, C S 1, \overline{C S} 2$, $\emptyset 2$ | $\mathrm{C}_{\text {IN }}$ | - | - | $\begin{gathered} 10 \\ 7 \\ 20 \end{gathered}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V} \\ & V_{\text {IN }}=0 \mathrm{~V} \\ & f_{=2}=2 \mathrm{MHZ} \\ & T_{A}=25^{\circ} \mathrm{C} \end{aligned}$ |
| Output Capacitance | $\mathrm{C}_{\text {OUT }}$ | - | - | 10 | pF |  |
| Notes: . <br> 1. All units are direct current (DC) except for capacitance. <br> 2. Negative sign indicates outward current flow, positive indicates inward flow. <br> 3. Typical values shown for $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$. |  |  |  |  |  |  |

## PACKAGE DIMENSIONS

40-PIN CERAMIC DIP


|  | MILLIMETERS |  | INCHES |  |
| :---: | :---: | :---: | :---: | :---: |
| DIM | MIN | MAX | MIN | MAX |
| A | 50.29 | 5131 | 1980 | 2.020 |
| B | 15.11 | 1588 | 0.595 | 0.625 |
| C | 254 | 4.19 | 0.100 | 0165 |
| D | 0.38 | 053 | 0015 | 0021 |
| F | 0.76 | 1.27 | 0.030 | 0.050 |
| G | 254 BSC |  | 0.100 |  |
| H SC |  |  |  |  |
| J | 0.76 | 178 | 0.030 | 0070 |
| K | 0.20 | 0.33 | 0.008 | 0.013 |
| L | 14.60 | 4.19 | 0.37 | 0.575 |
| M | $0^{\circ}$ | $10^{\circ}$ | 0.165 |  |
| N | 0.51 | 152 | 0605 |  |

## 40-PIN PLASTIC DIP



|  | MILLIMETERS |  | INCHES |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DIM | MIN | MAX | MIN | MAX |  |  |
| A | 51.28 | 52.32 | 2.040 | 2.060 |  |  |
| B | 13.72 | 14.22 | 0.540 | 0.560 |  |  |
| C | 3.55 | 5.08 | 0.140 | 0.200 |  |  |
| D | 0.36 | 0.51 | 0.014 | 0.020 |  |  |
| F | 1.02 |  | 1.52 | 0.040 |  | 0.060 |
| G | 2.54 |  | BSC | 0.100 |  | BSC |
| H | 1.65 | 2.16 | 0.065 |  |  |  |
| J | 0.20 | 0.30 | 0.008 |  |  |  |
| K | 3.30 |  | 4.32 | 0.012 |  |  |
| L | 15.24 |  | 0.130 | 0.170 |  |  |
| M | $7^{\circ}$ |  | $10^{\circ}$ | $7^{\circ}$ |  | $10^{\circ}$ |
| N | 0.51 |  | 1.02 | 0.020 |  | 0.040 |

44-PIN PLASTIC LEADED CHIP CARRIER (PLCC)


| DIM | MILLIMETERS |  | INCHES |  |
| :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |
| A | 4.14 | 4.39 | 0.163 | 0.173 |
| A1 | 1.37 | 1.47 | 0.054 | 0.058 |
| A2 | 2.31 | 2.46 | 0.091 | 0.097 |
| b | 0.457 TYP |  | 0.018 TYP |  |
| D | 17.45 | 17.60 | 0.687 | 0.693 |
| D1 | 16.46 | 16.56 | 0.648 | 0.652 |
| D2 | 12.62 | 12.78 | 0.497 | 0.503 |
| D3 | 15.75 REF |  | 0.620 REF |  |
| e | 1.27 BSC |  | 0.050 BSC |  |
| h | 1.15 TYP |  | 0.045 TYP |  |
| $J$ | 0.25 TYP |  | 0.010 TYP |  |
| $\alpha 2$ | $45^{\circ}$ TYP |  | $45^{\circ}$ TYP |  |
| R | 0.89 TYP |  | 0.035 TYP |  |
| R1 | 0.25 TYP |  | 0.010 TYP |  |

## R65NC22/R65C22 DIFFERENCES

| R65C22 | R65NC22 |
| :---: | :---: |
| 1. Register select lines are decoded during $\overline{\mathbf{\chi} 2}$. | 1. Register select lines are decoded during $\overline{\emptyset 2}$ only if $\overline{\mathrm{CS} 2}$ is active low. |
| 2. CB1 must not change during last 100 ns of $\emptyset 2$. CB1 must have a pulse width greater than one period. | 2. CB1 can change anytime but is sampled only during $\bar{\emptyset}$. CB1 must have a pulse greater than one period. |
| 3. PB0-PB7 and CB1, CB2 have active pull-ups. | 3. PB0-PB7 and CB1, CB2 have passive pull ups ( $\approx 3 \mathrm{~K} \Omega$ ). |
| 4. PB0-PB7, CB1 and CB2 represent two standard TTL loads in the input mode and will drive two standard TTL loads in the output mode. | 4. PB0-PB7, CB1 and CB2 represent one standard TTL load in the input mode and will drive one standard TTL load in the output mode. |

## R65NC22 Versatile Interface Adapter (VIA)

## DESCRIPTION

The R65NC22 Versatile Interface Adapter (VIA) is a very flexible I/O control device. In addition, this device contains a pair of very powerful 16-bit interval timers, a serial-to-parallel/parallelto serial shift register and input data latching on the peripheral ports. Expanded handshaking capability allows control of bidirectional data transfers between VIA's in multiple processor systems.

The R65NC22 includes functions for programmed control of up to two peripheral devices (Ports A and B). These two program controlled 8-bit bidirectional peripheral I/O ports allow direct interfacing between the microprocessor and selected peripheral units. Each port has input data latching capability. Two programmable Data Direction Registers (A and B) allow selection of data direction (input or output) on an individual line basis.

The R65NC22 also has two programmable 16-bit Interval Timer/Counters with latches. Timer 1 may be operated in a OneShot Interrupt Mode with interrupts on each count-to-zero, or in a Free-Run Mode with a continuous series of evenly spaced interrupts. Timer 2 functions as both an interval and pulse counter. Serial data transfers are provided by a serial-to-parallel/parallel-to-serial shift register. Application versatility is further increased by various control registers, including-the Interrupt Flag Register, the Interrupt Enable Register, the Auxiliary Control Register and the Peripheral Control Register.

## FEATURES

- Low power CMOS N-well silicon gate technology
- Fully compatible with NMOS 6522 devices
- Two 8-bit bidirectional I/O ports
- Two 16-bit programmable timer/counters
- Serial bidirectional peripheral I/O
- TTL compatible peripheral control lines
- Expanded "handshake" capability allows positive control of data transfers between processor and peripheral devices.
- Latched output and input registers on both I/O ports
- $1,2,3$, and 4 MHz operation
- Commercial and industrial temperature range versions
- Single +5 Vdc power requirement
- Wide variety of packages
- 40-pin plastic and ceramic DIP
- 44-pin plastic leaded chip carrier (PLCC)



NC $=$ NO INTERNAL CONNECTION 44-PIN PLCC

Figure 1. R65NC22 Pin Assignments

## ORDERING INFORMATION

Part Number:
R65NC22


Temperature Range ( $T_{L}$ to $T_{H}$ ):
Blank $=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
$E=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Frequency
$1=1 \mathrm{MHz}$
$2=2 \mathrm{MHz}$
$3=3 \mathrm{MHz}$
$4=4 \mathrm{MHz}$
Package
$C=40-$ Pin Ceramic DIP
$\mathrm{P}=40-\mathrm{Pin}$ Plastic DIP
$J=44-$ Pin Plastic Leaded Chip Carrier (PLCC)

## INTERFACE SIGNALS

Figure 1 (on the front page) shows the R65NC22 VIA pin assignments and Figure 2 groups the signals by functional interface.

## RESET ( $\overline{\text { RES }})$

Reset ( $\overline{\mathrm{RES}}$ ) clears all internal registers (except T 1 and T 2 counters and latches, and the Shift Register (SR)). In the RES condition, all peripheral interface lines (PA and PB) are placed in the input state. Also, the Timers (T1 and T2), SR and interrupt logic are disabled from operation.

## INPUT CLOCK (PHASE 2)

The system Phase 2 ( $\emptyset 2$ ) Input Clock controls all data transfers between the R65NC22 and the microprocessor.

## READ/WRITE (R/W)

The direction of the data transfers between the R65NC22 and the system processor is controlled by the $\mathrm{R} \bar{W}$ line in conjunction with the CS1 and $\overline{C S 2}$ inputs. When R $\bar{W}$ is low (write operation) and the R65NC22 is selected, data is transferred from the processor bus into the selected R65NC22 register. When $\mathrm{R} \overline{\mathrm{N}}$ is high (read operation) and the R65NC22 is selected, data is transferred from the selected R65NC22 register to the processor bus.

## DATA BUS (D0-D7)

The eight bidirectional Data Bus lines transfer data between the R65NC22 and the microprocessor. During a read operation, the contents of the selected R65NC22 internal register are transferred to the microprocessor via the Data Bus lines. During a write operation, the Data Bus lines serve as high impedance inputs over which data is transferred from the microprocessor to a selected R65NC22 register. The Data Bus lines are in the high impedance state when the R65NC22 is unselected.

## CHIP SELECTS (CS1, $\overline{\mathbf{C S 2}}$ )

Normally, the two chip select lines are connected to the microprocessor address lines. This connection may be direct or through decoding. To access a selected R65NC22 register, CS1 must be high (logic 1) and CS2 must be low (logic 0).


Figure 2. R65NC22 VIA Interface Signals

## REGISTER SELECTS (RS0-RS3)

The Register Select inputs allow the microprocessor to select one of 16 internal registers within the R65NC22. Refer to Table 1 for Register Select coding and a functional description. The RS lines are decoded only if CS2 is low.

## INTERRUPT REQUEST ( $\overline{\text { IRQ }}$ )

The Interrupt Request ( $\overline{\mathrm{RQ}}$ ) output signal is generated whenever an internal Interrupt Flag bit is set and the corresponding Interrupt Enable bit is a Logic 1. The Interrupt Request output is an open-drain configuration, thus allowing the $\overline{\mathrm{RQ}}$ signal to be wire-ORed to a common microprocessor IRQ input line.

## PORT A DATA LINES (PA0-PA7)

Peripheral Data Port A is an 8 -line, bidirectional bus for the transfer of data, control and status information between the R65NC22 and a peripheral device. Each Peripheral Data Port bus line may be individually programmed as either an input or output under control of a Data Direction Register. Data flow direction may be selected on a line-by-line basis with intermixed input and output lines within the same port. When a " 0 " is written to any bit position of the Data Direction Register, the corresponding line will be programmed as an input. When a " 1 " is written into any bit position of the register, the corresponding data line will serve as an output. Polarity of the data output is determined by the Output Register, while input data may be latched into the Input Register under control of the CA1 line. All modes are program controlled by the microprocessor by way of the R65NC22's internal control registers. Each Peripheral Data Port line represents two TTL loads in the input mode and will drive two standard TTL loads in the output mode. A typical output circuit for Peripheral Data Port A is shown in Figure 3.

## PORT A CONTROL LINES (CA1, CA2)

Control lines CA1 and CA2 serve as interrupt inputs or handshake outputs for Peripheral Data Port A. Each line controls an internal Interrupt Flag with a corresponding Interrupt Enable bit. CA1 also controls the latching of Input Data on Port A. CA1 is a high impedance input, while CA2 represents two standard TTL loads in the input mode. In the output mode, CA2 will drive two standard TTL loads.

## PORT B DATA LINES (PB0-PB7)

Peripheral Data Port B is an 8 -line, bidirectional bus which is controlled by an Output Register, Input Register and Data Direction Register in a manner much the same as Data Port A. With respect to Port B, the output signal on line PB7 may be controlled by Timer 1 while Timer 2 may be programmed to count pulses on the PB6 line. Port B lines represent one standard TTL load in the input mode and will drive one TTL load in the output mode. Port B lines are also capable of sourcing 3.2 mA at 1.5 Vdc in the output mode. This allows the outputs to directly
drive Darlington transistor circuits. A typical output circuit for Port $B$ is shown in Figure 3.

## PORT B CONTROL LINES (CB1, CB2)

Control lines CB1 and CB2 serve as interrupt inputs or handshake outputs for Peripheral Data Port B. Like Port A, these two control lines control an internal Interrupt Flag with a corresponding Interrupt Enable bit. Similar to CA1, CB1 controls the latching of input data on Port B. These lines also serve as a serial data port under control of the Shift Register (SR). Each control line represents one standard TTL load in the input mode and can drive one TTL load in the output mode.

Table 1. R65NC22 Register Addressing

| Reglster Number | RS Coding |  |  |  | Register Desig. | Register/Description |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | RS3 | RS2 | RS1 | RS0 |  | Write (R/W = L) | Read (R/W = H) |
| 0 | 0 | 0 | 0 | 0 | ORB/IRB | Output Register B | Input Register B |
| 1 | 0 | 0 | 0 | 1 | ORAIRA | Output Register A | Input Register A |
| 2 | 0 | 0 | 1 | 0 | DDRB | Data Direction Register B |  |
| 3 | 0 | 0 | 1 | 1 | DDRA | Data Direction Register A |  |
| 4 | 0 | 1 | 0 | 0 | T1C-L | T1 Low-Order Latches | T1 Low-Order Counter |
| 5 | 0 | 1 | 0 | 1 | T1C-H | T1 High-Order Counter |  |
| 6 | 0 | 1 | 1 | 0 | T1L-L | T1 Low-Order Latches |  |
| 7 | 0 | 1 | 1 | 1 | T1L-H | T1 High-Order Latches |  |
| 8 | 1 | 0 | 0 | 0 | T2C-L | T2 Low-Order Latches | T2 Low-Order Counter |
| 9 | 1 | 0 | 0 | 1 | T2C-H | T2 High-Order Counter |  |
| 10 | 1 | 0 | 1 | 0 | SR | Shift Register |  |
| 11 | 1 | 0 | 1 | 1 | ACR | Auxiliary Control Register |  |
| 12 | 1 | 1 | 0 | 0 | PCR | Peripheral Control Register |  |
| 13 | 1 | 1 | 0 | 1 | IFR | Interrupt Flag Register |  |
| 14 | 1 | 1 | 1 | 0 | IER | Interrupt Enable Register |  |
| 15 | 1 | 1 | 1 | 1 | ORA/IRA | Output Register $\mathrm{A}^{*}$ | Input Register $\mathrm{A}^{*}$ |
| TE: *Sam | egis | $x$ ce | hand |  |  |  |  |



Figure 3. Port A and B Output Circuits

## FUNCTIONAL DESCRIPTION

The internal organization of the R65NC22 VIA is illustrated in Figure 4.

## PORT A AND PORT B OPERATION

The R65NC22 VIA has two 8-bit bidirectional I/O ports (Port A and Port B) and each port has two associated control lines.

Each 8-bit peripheral port has a Data Direction Register (DDRA, DDRB) for specifying whether the peripheral pins are to act as inputs or outputs. A " 0 "' in a bit of the Data Direction Register causes the corresponding peripheral pin to act as an input. A " 1 " causes the pin to act as an output.

Each peripheral pin is also controlled by a bit in the Output Register (ORA, ORB) and the Input Register (IRA, IRB). When the pin is programmed as an output, the voltage on the pin is controlled by the corresponding bit of the Output Register. A " 1 " in the Output Register causes the output to go high, and a " 0 " causes the output to go low. Data may be written into Output

Register bits corresponding to pins which are programmed as inputs. In this case, however, the output signal is unaffected.

Reading a peripheral port causes the contents of the Input Register (IRA, IRB) to be transferred onto the Data Bus. With input latching disabled, IRA will always reflect the levels on the PA pins. With input latching enabled, IRA will reflect the levels on the PA pins at the time the latching occurred (via CA1).

The IRB register operates similar to the IRA register. However, for pins programmed as outputs there is a difference. When reading IRA, the level on the pin determines whether a " 0 " or a " 1 " is sensed. When reading IRB, however, the bit stored in the output register, ORB, is the bit sensed. Thus, for outputs which have large loading effects and which pull an output " 1 " down or which pull an output " 0 " up, reading IRA may result in reading a " 0 " when a " 1 " was actually programmed, and reading a " 1 " when a " 0 " was programmed. Reading IRB, on the other hand, will read the " 1 "' or " 0 " level actually programmed, no matter what the loading on the pin.

Figures 5 through 8 illustrate the formats of the port registers.


Figure 4. R65NC22 VIA Block Diagram

## HANDSHAKE CONTROL OF DATA TRANSFERS

The R65NC22 allows positive control of data transfers between the system processor and peripheral devices through the operation of "handshake"' lines. Port A lines (CA1, CA2) handshake data on both a read and a write operation while the Port B lines (CB1, CB2) handshake on a write operation only.

## Read Handshake

Positive control of data transfers from peripheral devices into the system processor can be accomplished very effectively using Read Handshaking. In this case, the peripheral device must generate the equivalent of a "Data Ready" signal to the processor signifying that valid data is present on the peripheral


Figure 5. Output Register B (ORB), Input Register B (IRB)


Figure 7. Data Direction Register B (DDRB)
port. This signal normally interrupts the processor, which then reads the data, causing generation of a "Data Taken" signal. The peripheral device responds by making new data available. This process continues until the data transfer is complete.

In the R65NC22, automatic "Read" Handshaking is possible on the Peripheral A port only. The CA1 interrupt input pin accepts the "Data Ready" signal and CA2 generates the "Data Taken" signal. The "Data Ready" signal will set an internal flag which may interrupt the processor or which may be polled under program control. The "Data Taken' signal can either be a pulse or a level which is set low by the system processor and is cleared by the "Data Ready" signal. These options are shown in Figure 9 which illustrates the normal Read Handshake sequence.


Figure 6. Output Register A (ORA), Input Register A (IRA)


Figure 8. Data Direction Register A (DDRA)


Figure 9. Read Handshake Timing (Port A Only)

## Write Handshake

The sequence of operations which allows handshaking data from the system processor to a peripheral device is very similar to that described for Read Handshaking. However, for Write Handshaking, the R65NC22 generates the "Data Ready" signal and the peripheral device must respond with the "Data Taken" signal. This can be accomplished on both the PA port and the PB port on the R65NC22. CA2 or CB2 act as a "Data Ready" output in either the handshake mode or pulse mode and CA1 or CB1 accept the "Data Taken" signal from the peripheral device, setting the interrupt flag and clearing the "Data Ready" output. This sequence is shown in Figure 10.

## Latching

The PA port and the PB port on the R65NC22 can be enabled in the Auxiliary Control Register (Figure 14) to be latched by their individual port control lines (CA1, CB1). Latching is selectable to be on the rising or falling edge of the signal at each individual port control line. Selection of operating modes for CA1, CA2, CB1 and CB2 is accomplished by the Peripheral Control Registor (Figure 11).


Figure 11. Peripheral Control Register (PCR)


Figure 10. Write Handshake Timing

## COUNTER/TIMERS

There are two independent 16-bit counter/timers (called Timer 1 and Timer 2) in the R65NC22. Each timer is controlled by writing bits into the Auxiliary Control Register (ACR) to select the mode of operation (Figure 14).

## Timer 1 Operation

Interval Timer T1 consists of two 8-bit latches (Figure 12) and a 16 -bit counter (Figure 13). The latches store data which is to be loaded into the counter. After loading, the counter decrements at $\emptyset 2$ clock rate. Upon reaching zero, an interrupt flag is set, and IRQ goes low if the T1 interrupt is enabled. Timer 1 then
disables any further interrupts and automatically transfers the contents of the latches into the counter and continues to decrement. In addition, the timer may be programmed to invert the output signal on peripheral pin PB7 each time it "times-out". Each of these modes is discussed separately below.

Note that the processor does not write directly into the low-order counter (T1C-L). Instead, this half of the counter is loaded automatically from the low order latch (T1L-L) when the processor writes into the high order counter (T1C-H). In fact, it may not be necessary to write to the low order counter in some applications since the timing operation is triggered by writing to the high order latch.

REG 6-TIMER 1 LOW-ORDER LATCH


WRITE - 8 BITS LOADED INTO T1 LOW-ORDER
LATCHES THIS OPERATION IS NO
DIFFERENT THAN A WRITE INTO REG 4.
READ - 8 BITS FROM TI LOW-ORDER LATCHES TRANSFERRED TO MPU UNLIKE REG 4 OPERATION. THIS DOES NOT CAUSE RESET OF T1 INTERRUPT FLAG

REG 7-TIMER 1 HIGH-ORDER LATCH


COUNT value

Figure 12. Timer 1 ( T 1 ) Latch Registers

REG 4-TIMER 1 LOW-ORDER COUNTER


WRITE - B BITS LOADED INTO TI LOW-ORDER LATCHES LATCH CONTENTS ARE
TRANSFERRED INTO LOW-ORDER TRANSFERRED INTO LOW-ORDER
COUNTER AT THE TIME THE HIGH. COUNTER AT THE TIME THE HIGH-
ORDER COUNTER IS LOADED (REG 5)
READ - 8 BITS FROM T1 LOW-ORDER COUNTER TRANSFERRED TO MPU. IN ADDITION. IT INTERRUPT FLAG IS RESET (BIT
IN INTERRUPT FLAG REGISTER)

REG 5-TIMER 1 HIGH-ORDER COUNTER


WRITE - 8 BITS LOADED INTO T1 HIGH-ORDER
LATCHES ALSO. AT THIS TIME BOTH
HIGH- AND LOW-ORDER LATCHES ARE
HIGH- AND LOW-ORDER LATCHES ARE
TRANSFERRED INTO T1 COUNTER.
READ - 8 BITS FROM T1 HIGH-ORDER COUNTER
TRANSFERRED TO MPU.

Figure 13. Timer 1 (T1) Counter Registers


Figure 14. Auxiliary Control Register (ACR)

## Timer 1 One-Shot Mode

The Timer 1 one-shot mode generates a single interrupt for each timer load operation. As with any interval timer, the delay between the "write T1C-H" operation and generation of the processor interrupt is a direct function of the data loaded into the timing counter. In addition to generating a single interrupt, Timer 1 can be programmed to produce a single negative pulse on the PB7 peripheral pin. With the output enabled (ACR7 =1) a "write T1C-H" operation will cause PB7 to go low. PB7 will return high when Timer 1 times out. The result is a single programmable width pulse.

Timing for the R65NC22 interval timer one-shot modes is shown in Figure 15.
In the one-shot mode, writing into the T1L-H has no effect on the operation of Timer 1. However, it will be necessary to
assure that the low order latch contains the proper data before initiating the count-down with a "write T1C-H" operation. When the processor writes into the high order counter (T1C-H), the T1 interrupt flag will be cleared, the contents of the low order latch will be transferred into the low order counter, and the timer will begin to decrement at system clock rate. If the PB7 output is enabled, this signal will go low on the falling edge of $\emptyset 2$ following the write operation. When the counter reaches zero, the T1 interrupt flag will be set, the $\overline{\mathrm{R} Q}$ pin will go low (interrupt enabled), and the signal on PB7 will go high. At this time the counter will continue to decrement at system clock rate. This allows the system processor to read the contents of the counter to determine the time since interrupt. However, the T1 interrupt flag cannot be set again unless it has been cleared as described in this specification.


Figure 15. Timer 1 One-Shot Mode Timing

## Timer 1 Free-Run Mode

The most important advantage associated with the latches in T1 is the ability to produce a continuous series of evenly spaced interrupts and the ability to produce a square wave on PB7 whose frequency is not affected by variations in the processor interrupt response time. This is accomplished in the "free-running" mode.

In the free-running mode, the interrupt flag is set and the signal on PB7 is inverted each time the counter reaches zero at which time the timer automatically transfers the contents of the latch into the counter ( 16 bits) and continues to decrement from there. The interrupt flag can be cleared by writing T1C-H or T1L-H, by reading T1C-L, or by writing directly into the flag as described later. However, it is not necessary to rewrite the timer to enable setting the interrupt flag on the next time-out.

All interval timers in the R65NC22 are "re-triggerable". Rewriting the counter will always re-initialize the time-out period. In fact,
the time-out can be prevented completely if the processor continues to rewrite the timer before it reaches zero. Timer 1 will operate in this manner if the processor writes into the high order counter (T1C-H). However, by loading the latches only, the processor can access the timer during each down-counting operation without affecting the time-out in process. Instead, the data loaded into the latches will determine the length of the next time-out period. This capability is particularly valuable in the freerunning mode with the output enabled. In this mode, the signal on PB7 is inverted and the interrupt flag is set with each timeout. By responding to the interrupts with new data for the latches, the processor can determine the period of the next half cycle during each half cycle of the output signal on PB7. In this manner, very complex waveforms can be generated.

A precaution to take in the use of PB7 as the timer output concerns the Data Direction Register contents for PB7. Both DDRB bit 7 and ACR bit 7 must be 1 for PB7 to function as the timer output. If one is 1 and other is 0 , then PB7 functions as a normal outpin pin, controlled by ORB bit 7.


Figure 16. Timer 1 Free-Run Mode Timing

## Timer 2 Operation

Timer 2 operates as an interval timer (in the "one-shot" mode only), or as a counter for counting negative pulses on the PB6 peripheral pin. A single control bit in the Auxiliary Control Register selects between these two modes. This timer is comprised of a "write-only" lower-order latch (T2L-L), a "read-only" low-order counter (T2C-L) and a read/write high order counter (T2C-H). The counter registers act as a 16-bit counter which decrements at Ø2 rate. Figure 17 illustrates the T2 Latch/Counter Registers.

## Timer 2 One-Shot Mode

As an interval timer, T2 operates in the "one-shot" mode similar to Timer 1. In this mode, T2 provides a single interrupt for each "write T2C-H" operation. After timing out, the counter will continue to decrement. However, setting of the interrupt flag is disabled after initial time-out so that it will not be set by the counter
decrementing again through zero. The processor must rewrite T2C-H to enable setting of the interrupt flag. The interrupt flag is cleared by reading T2C-L or by writing T2C-H. Timing for this operation is shown in Figure 18.

## Timer 2 Pulse Counting Mode

In the pulse counting mode, T2 counts a predetermined number of negative-going pulses on PB6. This is accomplished by first loading a number into T 2 . Writing into $\mathrm{T} 2 \mathrm{C}-\mathrm{H}$ clears the interrupt flag and allows the counter to decrement each time a pulse is applied to PB6. The interrupt flag is set when T2 counts down past zero. The counter will then continue to decrement with each pulse on PB6. However, it is necessary to rewrite T2C-H to allow the interrupt flag to set on a subsequent time-out. Timing for this mode is shown in Figure 19. The pulse must be low on the leading edge of $\emptyset 2$.


Figure 17. Timer 2 (T2) Latch/Counter Registers


Figure 18. Timer 2 One-Shot Mode Timing


Figure 19. Timer 2 Pulse Counting Mode

## SHIFT REGISTER OPERATION

The Shift Register (SR) performs serial data transfers into and out of the CB2 pin under control of an internal modulo-8 counter. Serial data transfer in and out of the Shift Register (SR) begin with the most significant bit (MSB) first. Shift pulses can be applied to the CB1 pin from an external source or, with the proper mode selection, shift pulses generated internally will appear on the CB1 pin for controlling external devices.

The control bits which select the various shift register operating modes are located in the Auxiliary Control Register. Figure 20 illustrates the configuration of the SR data bits and Figure 21 shows the SR control bits of the ACR.

## SR Mode 0 - Shift Register Interrupt Disabled

Mode 0 disables the Shift Register interrupt. In this mode the microprocessor can write or read the SR and the SR will shift on each CB1 positive edge shifting in the value on CB2. In this mode the SR interrupt Flag is disabled (held to a logic 0 ).

## SR Mode 1 - Shift In Under Control of T2

In mode 1, the shifting rate is controlled by the low order 8 bits of T2 (Figure 22). Shift pulses are generated on the CB1 pin to control shifting in external devices. The time between transitions


Figure 20. Shift Register
of this output clock is a function of the system clock period and the contents of the low order T 2 latch ( N ).

The shifting operation is triggered by the read or write of the SR if the SR flag is set in the IFR. Otherwise the first shift will occur at the next time-out of T2 after a read or write of the SR. The input data should change before the positive-going edge of CB1 clock pulse. This data is shifted into the shift register during the ゆ2 clock cycle following the positive-going edge of the CB1 clock pulse. The minimum CB1 positive pulse width must be one clock period. After 8 CB1 clock pulses, the shift register interrupt flag will set and $\overline{\mathrm{RQ}}$ will go low.

## SR Mode 2 - Shift In Under $\mathbf{~} 2$ Control

In mode 2, the shift rate is a direct function of the system clock frequency (Figure 23). CB1 becomes an output which generates shift pulses for controlling external devices. Timer 2 operates as an independent interval timer and has no effect on SR. The shifting operation is triggered by reading or writing the Shift Register. Data is shifted, first into bit 0 and is then shifted into the next higher order bit of the shift register on the trailing edge of each $\emptyset 2$ clock pulse. After 8 clock pulses, the shift register interrupt flag will be set, and the output clock pulses on CB1 will stop.


Figure 21. Shift Register Modes


Figure 22. SR Mode 1 - Shift In Under T2 Control

## SR Mode 3 - Shift In Under CB1 Control

In mode 3, external pin CB1 becomes an input (Figure 24). This allows an external device to load the shift register at its own pace. The shift register counter will interrupt the processor each time 8 bits have been shifted in. The shift register stops after 8 counts and must be reset to start again. Reading or writing the Shift Register resets the Interrupt Flag and initializes the SR counter to count another 8 pulses.
Note that the data is shifted during the first system clock cycle following the positive-going edge of the CB1 shift pulse. For this reason, data must be held stable during the first full cycle following CB1 going high. The minimum CB1 positive pulse width must be one clock period.

## SR Mode 4 - Shift Out Under T2 Control (Free-Run)

Mode 4 is very similar to mode 1 in which the shifting rate is set by T2. However, in mode 4 the SR Counter does not stop
the shifting operation (Figure 25). Since the Shift Register bit 7 (SR7) is recirculated back into bit 0 , the 8 bits loaded into the shift register will be clocked onto CB2 repetitively. In this mode the shift register counter is disabled.

## SR Mode 5 - Shift Out Under T2 Control

In mode 5, the shift rate is controlled by T 2 (as in mode 1). The shifting operation is triggered by the read or write of the SR if the SR flag is set in the IFR (Figure 26). Otherwise the first shift will occur at the next time-out of T2 after a read or write of the SR. However, with each read or write of the shift register the SR Counter is reset and 8 bits are shifted onto CB2. At the same time, 8 shift pulses are generated on CB1 to control shifting in external devices. After the 8 shift pulses, the shifting is disabled, the SR Interrupt Flag is set and CB2 remains at the last data level.


Figure 23. SR Mode 2 - Shift In Under $\mathbf{\phi}$ Control


Figure 24. SR Mode 3 - Shift In Under CB1 Control


Figure 25. SR Mode 4 - Shift Out Under T2 Control (Free-Run)

## SR Mode 6 - Shift Out Under 02 Control

In mode 6, the shift rate is controlled by the $\emptyset 2$ system clock (Figure 27).

SR Mode 7 - Shift Out Under CB1 Control
In mode 7, shifting is controlled by pulses applied to the CB1 pin by an external device (Figure 28). The SR counter sets the SR

Interrupt Flag each time it counts 8 pulses but it does not disable the shifting function. Each time the microprocessor, writes or reads the shift register, the SR Interrupt Flag is reset and the SR counter is initialized to begin counting the next 8 shift pulses on pin CB1. After 8 shift pulses, the Interrupt Flag is set. The microprocessor can then load the shift register with the next byte of data.

Figure 26. SR Mode 5 - Shift Out Under T2 Control


Figure 27. SR Mode 6 - Shift Out Under 02 Control


Figure 28. SR Mode 7 - Shift Out Under CB1 Control

## INTERRUPT OPERATION

Controlling interrupts within the R65NC22 involves three principal operations. These are flagging the interrupts, enabling interrupts and signaling to the processor that an active interrupts exists within the chip. Interrupt flags are set in the Interrupt Flag Register (IFR) by conditions detected within the R65NC22 or on inputs to the R65NC22. These flags normally remain set until the interrupt has been serviced. To determine the source of an interrupt, the microprocessor must examine these flags in order, from highest to lowest priority.
Associated with each interrupt flag is an interrupt enable bit in the Interrupt Enable Register (IER). This can be set or cleared by the processor to enable interrupting the processor from the corresponding interrupt flag. If an interrupt flag is set to a logic 1 by an interrupting condition, and the corresponding interrupt enable bit is set to a 1, the Interrupt Request Output (IRQ) will go low. $\overline{\mathrm{IRQ}}$ is an "open-collector" output which can be "wire-OR'ed" with other devices in the system to interrupt the processor.

## Interrupt Flag Register (IFR)

In the R65NC22, all the interrupt flags are contained in one register, i.e., the IFR (Figure 29). In addition, bit 7 of this register will be read as a logic 1 when an interrupt exists within the chip. This allows very convenient polling of several devices within a system to locate the source of an interrupt.

The Interrupt Flag Register (IFR) may be read directly by the processor. In addition, individual flag bits may be cleared by writing a " 1 " into the appropriate bit of the IFR. When the proper chip select and register signals are applied to the chip, the contents of this register are placed on the data bus. Bit 7 indicates the status of the $\overline{\mathrm{IRQ}}$ output. This bit corresponds to the logic
REG 13-INTERRUPT FLAG REGISTER

| 76 | ${ }^{6} 5$ | $4_{4}^{4} 3$ | 2 1 0 <br>    | SET BY | CLEARED BY |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $C A 2-1$ | CA2 ACtive edge | READ OR WRITE READ OR WAI |
|  |  |  |  | CAI ACtive edge | READ OR WRITE REG (ORA) |
|  |  |  | reg | COMPLETE 8 SHIFTS | READ OR WRITE SHIETREG |
|  |  |  |  | CB2 ACTIVE EDGE | READ OR WRITE ORE* |
|  |  | - |  | CB1 ACTIVE EDGE | READ OR WRITE OR |
|  |  |  |  |  | READ Th LOWOR WRITE T2 HIGH |
|  |  |  |  | TIME.OUT OF TI | READ TI LOW OR WRITE TI HIGH |
|  |  |  |  | ANY ENABLED INTERRUPT | CLEAR ALL interrupis |

- IF THE CA2/CB2 CONTROL IN THE PCR IS SELECTED AS "INDEPENDENT" INTERRUPT INPUT, THEN READING OR
WRITING THE OUTPUT REGISTER ORA/ORB WILL NOT
CLEAR THE FLAG BIT INSTEAD, THE BIT MUST BE
CLEARED BY WRITING INTO THE IFR, AS DESCRIBED
previousty
function: $\overline{\mathrm{IRQ}}=\mathrm{IFR} 6 \times \mathrm{IER6}+\mathrm{IFR} 5 \times \mathrm{IER} 5+\mathrm{IFR} 4 \times \mathrm{IER} 4$ + IFR3 $\times$ IER3 + IFR2 $\times$ IER2 + IFR1 $\times$ IER1 + IFR0 $\times$ IERO.


## Note:

$$
x=\operatorname{logic~AND},+=\text { Logic OR. }
$$

The IFR bit 7 is not a flag. Therefore, this bit is not directly cleared by writing a logic 1 into it. It can only be cleared by clearing all the flags in the register or by disabling all the active interrupts as discussed in the next section.

## Interrupt Enable Register (IER)

For each interrupt flag in IFR, there is a corresponding bit in the Interrupt Enable Register (IER) (Figure 30). Individual bits in the IER can be set or cleared to facilitate controlling individual interrupts without affecting others. This is accomplished by writing to the (IER) after bit 7 set or cleared to, in turn, set or clear selected enable bits. If bit 7 of the data placed on the system data bus during this write operation is a 0 , each 1 in bits 6 through 0 clears the corresponding bit in the Interrupt Enable Register. For each zero in bits 6 through 0 , the corresponding bit is unaffected.

Selected bits in the IER can be set by writing to the IER with bit 7 in the data word set to a 1. In this case, each 1 in bits 6 through 0 will set the corresponding bit. For each zero, the corresponding bit will be unaffected. This individual control of the setting and clearing operations allows very convenient control of the interrupts during system operation.

In addition to setting and clearing IER bits, the contents of this register can be read at any time. Bit 7 will be read as a logic 1 , however.

REG 14-INTERRUPT ENABLE REGISTER


NOTES
1 IF BIT 7 IS A "O". THEN EACH " 1 "IN BITS 0-6 DISABLES THE
CORRESPONDING INTERRUPT
2 IF BIT 7 IS A " 1 ", THEN EACH " 1 " IN BITS 0 - 6 ENABLES THE
CORRESPONDING INTERRUPT
基

ALL OTHER BITS WILL REFLECT THEIR ENABLE/DISABLE STATE.

Figure 29. Interrupt Flag Register (IFR)
Figure 30. Interrupt Enable Register (IER)

## SWITCHING CHARACTERISTICS

$\left(V_{C C}=5.0 \mathrm{Vdc} \pm 5 \%, V_{S S}=0, T_{A}=T_{L}\right.$ to $T_{H}$, unless otherwise noted)
PERIPHERAL INTERFACE TIMING

| Parameter | Symbol | Min. | Max. | Unit | Figure |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Rise and Fall Time for CA1, CB1, CA2 and CB2 Input Signals | $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}$ | - | 1.0 | $\mu \mathrm{S}$ | - |
| Delay Time, Clock Negative Transition to CA2 Negative Transition (read handshake or pulse mode) | $\mathrm{t}_{\mathrm{CA} 2}$ | - | 1.0 | $\mu \mathrm{S}$ | 31a, 31b |
| Delay Time, Clock Negative Transition to CA2 Positive Transition (pulse mode) | $\mathrm{t}_{\text {RS1 }}$ | - | 1.0 | $\mu \mathrm{S}$ | 31a |
| Delay Time, CA1 Active Transition to CA2 Positive Transition (handshake mode) | $\mathrm{t}_{\mathrm{RS} 2}$ | - | 2.0 | $\mu \mathrm{S}$ | 31b |
| Delay Time, Clock Positive Transition to CA2 or CB2 Negative Transition (write handshake) | ${ }^{\text {twHS }}$ | 0.05 | 1.0 | $\mu \mathrm{S}$ | 31c, 31d |
| Delay Time, Periphral Data Valid to CB2 Negative Transition | $t_{\text {DS }}$ | 0.20 | 1.5 | $\mu \mathrm{S}$ | 31c, 31d |
| Delay Time, Clock Positive Transition to CA2 or CB2 Positive Transition (pulse mode) | $\mathrm{t}_{\text {RS3 }}$ | - | 1.0 | $\mu \mathrm{S}$ | 31c |
| Delay Time, CA1 or CB1 Active Transition to CA2 or CB2 Positive Transition (handshake mode) | $\mathrm{t}_{\text {RS4 }}$ | - | 2.0 | $\mu \mathrm{S}$ | 31d |
| Delay Time Required from CA2 Output to CA1 Active Transition (handshake mode) | $\mathrm{t}_{21}$ | 400 | - | ns | 31d |
| Setup Time, Peripheral Data Valid to CA1 or CB1 Active Transition (input latching) | $\mathrm{t}_{\text {LL }}$ | 300 | - | ns | 31 e |
| CA1, CB1 Setup Prior to Transition to Arm Latch | $\mathrm{t}_{\mathrm{AL}}$ | 300 | - | ns | 31 e |
| Peripheral Data Hold After CA1, CB1 Transition | $\mathrm{t}_{\mathrm{PDH}}$ | 150 | - | ns | 31 e |
| Shift-Out Delay Time - Time from $\emptyset 2$ Falling Edge to CB2 Data Out | $t_{\text {SR1 }}$ | - | 300 | ns | 311 |
| Shift Clock Setup Time - Time from CB1 Shift Clock to $\emptyset 2$ Rising Edge | $t_{\text {SR2 }}$ | 0 | - | ns | 31g |
| Pulse Width - PB6 Input Pulse | $\mathrm{t}_{\text {IPW }}$ | $2 \times T_{C Y}$ | - |  | 31 i |
| Pulse Width - CB1 Input Clock | $\mathrm{tacw}^{\text {c }}$ | $2 \times \mathrm{T}_{C Y}$ | - |  | 31h |
| Pulse Spacing - PB6 Input Pulse | $\mathrm{t}_{\text {IPS }}$ | $2 \times \mathrm{T}_{C Y}$ | - |  | 31 i |
| Pulse Spacing - CB1 Input Pulse | $\mathrm{t}_{\text {ICS }}$ | $2 \times \mathrm{T}_{C Y}$ | - |  | 31h |
| Note: CB1 input sampled while $\emptyset 2$ is low. |  |  |  |  |  |

## BUS TIMING

| Parameter | Symbol | 1 MHz |  | 2 MHz |  | 3 MHz |  | 4 MHZ |  | Unit | Figure |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |  |
| Cycle Time | $\mathrm{t}_{\mathrm{CY}}$ | 1000 | - | 500 | - | 330 | - | 250 | - | ns |  |
| Phase 2 Pulse Width High | $t_{\text {PWH }}$ | 470 | - | 240 | - | 160 | - | 120 | - | ns | 32a, |
| Phase 2 Pulse Width Low | $\mathrm{t}_{\text {PWL }}$ | 470 | - | 240 | - | 160 | - | 120 | - | ns | 32b |
| Phase 2 Transition | $\mathrm{t}_{\mathrm{R}, \mathrm{F}}$ | - | 30 | - | 30 | - | 30 | - | 30 | ns |  |
| Read |  |  |  |  |  |  |  |  |  |  |  |
| Select, R/W Setup | $t_{\text {ACR }}$ | 160 | - | 90 | - | 65 | - | 45 | - | ns | 32a |
| Select, R/ $\bar{W}$ Hold | $\mathrm{t}_{\text {CAR }}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |  |
| Data Bus Delay | $\mathrm{t}_{\mathrm{CDR}}$ | - | 320 | - | 150 | - | 130 | - | 75 | ns |  |
| Data Bus Hold | $\mathrm{t}_{\mathrm{HR}}$ | 10 | - | 10 | - | 10 | - | 10 | - | ns |  |
| Peripheral Data Setup | $t_{\text {PCR }}$ | 300 | - | 150 | - | 110 | - | 75 | - | ns |  |
| Write |  |  |  |  |  |  |  |  |  |  |  |
| Select, R/̄W Setup | $t_{\text {ACW }}$ | 160 | - | 90 | - | 65 | - | 45 | - | ns | 32b |
| Select, R/ $\bar{W}$ Hold | $\mathrm{t}_{\text {caw }}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |  |
| Data Bus Setup | $\mathrm{t}_{\text {DCW }}$ | 195 | - | 75 | - | 65 | - | 45 | - | ns |  |
| Data Bus Hold | $\mathrm{t}_{\mathrm{HW}}$ | 10 | - | 10 | - | 10 | - | 10 | - | ns |  |
| Peripheral Data Delay | $\mathrm{t}_{\text {CPW }}$ | - | 1000 | - | 500 | - | 330 | - | 250 | ns |  |

## PERIPHERAL INTERFACE WAVEFORMS



Figure 31a. CA2 Timing for Read Handshake, Pulse Mode


Figure 31b. CA2 Timing for Read Handshake, Handshake Mode


Figure 31c. CA2, CB2 Timing for Write Handshake, Pulse Mode


Figure 31d. CA2, CB2 Timing for Write Handshake, Handshake Mode


Figure 31e. Peripheral Data Input Latching Timing


Figure 31f. Timing for Shift Out with Internal or External Shift Clocking


Figure 31g. Timing for Shift In with Internal or External Shift Clocking


Figure 31h. External Shift Clock Timing


Figure 31i. Pulse Count Input Timing

## BUS TIMING WAVEFORMS



Figure 32a. Read Timing Waveforms


Figure 32b. Write Timing Waveforms

ABSOLUTE MAXIMUM RATINGS*

| Parameter | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | Vdc |
| Input Voltage | $\mathrm{V}_{\text {IN }}$ | -0.3 to $V_{C C}+0.3$ | Vdc |
| Output Voltage | $\mathrm{V}_{\text {OUT }}$ | -0.3 to $V_{C C}+0.3$ | Vdc |
| Operating Temperature Commercial Industrial | $\mathrm{T}_{\mathrm{A}}$ | $\begin{array}{r} 0 \text { to }+70 \\ -40 \text { to }+85 \end{array}$ | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## OPERATING CONDITIONS

| Parameter | Symbol | Value |
| :--- | :--- | :--- |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $5 \mathrm{~V} \pm 5 \%$ |
| Temperature Range | $\mathrm{T}_{\mathrm{A}}$ | $\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$ |
| Commercial |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Industrial |  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

## ELECTRICAL CHARACTERISTICS

( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{S S}=0, T_{A}=T_{L}$ to $T_{H}$, unless otherwise noted)

| Parameter | Symbol | Min. | Typ. ${ }^{3}$ | Max. | Unit ${ }^{1}$ | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage Logic | $\mathrm{V}_{1 \mathrm{H}}$ | $+2.0$ | - | $V_{C C}$ | V |  |
| Input Low Voltage Logic | VIL | -0.3 | - | +0.8 | V |  |
| Input Leakage Current <br> R/ $\bar{W}, \overline{R E S}, R S 0, R S 1, R S 2, R S 3, C S 1, \overline{C S} 2, C A 1, ~ \emptyset 2$ | $\mathrm{I}_{\mathrm{IN}}$ | - | $\pm 1$ | $\pm 2.5$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{1 \mathrm{~N}}=0 \mathrm{~V} \text { to } \mathrm{V}_{\mathrm{CC}} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Input Leakage Current for Three-State Off DO-D7 | $\mathrm{I}_{\text {TSI }}$ | - | $\pm 2$ | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & V_{C C}=5.25 \mathrm{~V} \end{aligned}$ |
| Input High Current PA0-PA7, CA2, PB0-PB7, CB1, CB2 | $\mathrm{I}_{\mathrm{H}}$ | -200 | -400 | - | $\mu \mathrm{A}$ | $\mathrm{V}_{1 \mathrm{H}}=2.4 \mathrm{~V}$ |
| $\begin{aligned} & \text { Input Low Current } \\ & \text { PA0-PA7, CA2 } \\ & \text { PB0-PB7, CB1, CB2 } \\ & \hline \end{aligned}$ | ILI | - | $\begin{gathered} -1.6 \\ - \\ \hline \end{gathered}$ | $\begin{array}{r} -2.6 \\ -1.6 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | $\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V}$ |
| Output High Voltage <br> All outputs <br> PB0-PB7 (Darlington Drive) | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & 2.4 \\ & 1.5 \end{aligned}$ | - | - | $\begin{aligned} & V \\ & V \end{aligned}$ | $\begin{aligned} & V_{C C}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=200 \mu \mathrm{~A} \\ & \mathrm{I}_{\text {LOAD }}=-3.2 \mathrm{~mA} \end{aligned}$ |
| $\begin{aligned} & \text { Output Low Voltage } \\ & \text { PA0-PA7, CA2, D0-D7 } \\ & \text { IRQ, PB0-PB7, CB1, CB2 } \end{aligned}$ | $\mathrm{V}_{\mathrm{OL}}$ | - | - | +0.4 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=3.2 \mathrm{~mA} \\ & \mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA} \end{aligned}$ |
| Output High Current (Sourcing) All outputs PB0-PB7 (Darlington Drive) CB1, CB2 | ${ }^{\mathrm{OH}}$ | $\begin{array}{r} -200 \\ -3.2 \\ -750 \\ \hline \end{array}$ | $\begin{gathered} -1500 \\ -6 \\ - \\ \hline \end{gathered}$ | - | $\begin{aligned} & \mu \mathrm{A} \\ & \mathrm{~mA} \\ & \mu \mathrm{~A} \\ & \hline \end{aligned}$ | $\begin{aligned} \mathrm{V}_{\mathrm{OH}} & =2.4 \mathrm{~V} \\ \mathrm{~V}_{\mathrm{OH}} & =1.5 \mathrm{~V} \\ \mathrm{~V}_{\mathrm{OH}} & =2.4 \mathrm{~V} \end{aligned}$ |
| Output Low Current (Sinking) PAO-PA7, CA2, D0-D7 All others | $\mathrm{I}_{\mathrm{OL}}$ | $\begin{aligned} & 3.2 \\ & 1.6 \\ & \hline \end{aligned}$ | - | - | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \\ & \hline \end{aligned}$ | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| Output Leakage Current (Off State) $\overline{1 R Q}$ | loff | - | 1 | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Power Dissipation | $P_{D}$ | - | 7 | 10 | $\mathrm{mW} / \mathrm{MHz}$ |  |
| Input Capacitance <br> D0-D7, PA0-PA7, CA1, CA2, PB0-PB7, CB1, CB2 <br> R/W, $\overline{\text { RES }}$, RS0, RS1, RS2, RS3, CS1, CS2 <br> ф2 | $\mathrm{C}_{\text {IN }}$ | - | - | $\begin{gathered} 10 \\ 7 \\ 20 \\ \hline \end{gathered}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V} \\ & V_{I N}=0 \mathrm{~V} \\ & f^{\prime}=2 \mathrm{MHz} \\ & T_{A}=25^{\circ} \mathrm{C} \end{aligned}$ |
| Output Capacitance | $\mathrm{C}_{\text {OUT }}$ | - | - | 10 | pF |  |

## Notes:

1. All units are direct current (DC) except for capacitance.
2. Negative sign indicates outward current flow, positive indicates inward flow.
3. Typical values shown for $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.
4. Maximum loading on CB1 and CB2 is 50 pF .

## PACKAGE DIMENSIONS

40-PIN CERAMIC DIP


| DIM | MILLIMETERS |  | INCHES |  |
| :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |
| A | 50.29 | 51.31 | 1.980 | 2.020 |
| B | 14.86 | 15.62 | 0.100 | 0.615 |
| C | 2.54 | 4.19 | 0.585 | 0.165 |
| D | 0.38 | 0.53 | 0.015 | 0.021 |
| F | 0.76 | 1.40 | 0.030 | 0.055 |
| G | 2.54 | BSC | 0.100 |  |
| BSC |  |  |  |  |
| H | 0.76 | 1.78 | 0.030 | 0.070 |
| J | 0.20 | 0.33 | 0.008 | 0.013 |
| K | 2.54 | 4.19 | 0.100 | 0.165 |
| L | 14.60 | 15.37 | 0.575 | 0.605 |
| M | $0^{\circ}$ | $10^{\circ}$ | $0^{\circ}$ | $10^{\circ}$ |
| N | 0.51 | 1.52 | 0.020 | 0.060 |

40-PIN PLASTIC DIP


| DIM | MILLIMETERS |  | INCHES |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |  |  |
| A | 51.28 | 52.32 | 2.040 | 2.060 |  |  |  |
| B | 13.72 | 14.22 | 0.540 | 0.560 |  |  |  |
| C | 3.55 | 5.08 | 0.140 | 0.200 |  |  |  |
| D | 0.36 | 0.51 | 0.014 | 0.020 |  |  |  |
| F | 1.02 | 1.52 | 0.040 |  |  |  |  |
| G | 2.54 BSC |  | 0.100 |  |  |  |  |
| H | 1.65 |  | 2.16 | 0.065 |  | 0.085 |  |
| J | 0.20 |  | 0.30 | 0.008 |  |  |  |
| K | 3.30 |  | 4.32 | 0.012 |  |  |  |
| L | 15.24 |  | 0.130 | 0.170 |  |  |  |
| M | $7^{\circ}$ |  | $10^{\circ}$ | 0.600 |  | $7^{\circ}$ | $10^{\circ}$ |
| N | 0.51 |  | 1.02 | 0.020 |  | 0.040 |  |

44-PIN PLASTIC LEADED CHIP CARRIER (PLCC)


R65NC22/R65C22 DIFFERENCES

| R65C22 | R65NC22 |
| :---: | :---: |
| 1. Register select lines are decoded during $\overline{\mathbf{2}}$. | 1. Register select lines are decoded during $\overline{\emptyset 2}$ only if $\overline{\mathrm{CS} 2}$ is active low. |
| 2. CB1 must not change during last 100 ns of $\emptyset 2$. CB1 must have a pulse width greater than one period. | 2. CB1 can change anytime but is sampled only during $\bar{\varnothing} 2$. CB1 must have a pulse greater than one period. |
| 3. PB0-PB7 and CB1, CB2 have active pull-ups. | 3. PB0-PB7 and CB1, CB2 have passive pull ups ( $\approx 3 \mathrm{~K} \Omega$ ). |
| 4. PB0-PB7, CB1 and CB2 represent two standard TTL loads in the input mode and will drive two standard TTL loads in the output mode. | 4. PB0-PB7, CB1 and CB2 represent one standard TTL load in the input mode and will drive one standard TTL load in the output mode. |

## DESCRIPTION

The R65C24 Peripheral Interface Adapter/Timer (PIAT) is designed to solve a broad range of peripheral control problems in the implementation of microcomputer systems. This device allows a very effective trade-off between software and hardware by providing significant capability and flexibility in a low cost chip. When coupled with the power and speed of the R6500, R6500/* or R65C00 family of microprocessors, the R65C24 allows implementation of very complex systems at a minimum overall cost.

Control of peripheral devices is handled primarily through two 8 -bit bidirectional ports. Each of these lines can be programmed to act as either an input or an output. In addition, four peripheral control/interrupt input lines are provided. These lines can be used to interrupt the processor or to "handshake" data between the processor and a peripheral device.

The PIAT also contains one 16-bit Counter/Timer comprised of a 16-bit counter, two 8 -bit latches associated with the counter, and an $\theta$-bit snapshot latch for the upper half of the counter. A counter mode control register, under software direction, selects any one of eight counter modes of operation, and the status register contains an underflow flag to report counter time-out. A maskable interrupt request allows immediate CPU notification upon counter time-out.

## FEATURES

- Low power CMOS $N$-well sillicon gate technology
- Two 8-bit bidirectional I/O ports with individual data direction control
- Programmable 16 -bit Counter/Timer with eight modes of operation
- Three 8-bit latches associated with the Counter/Timer
- Selectable divide-by-sixteen prescaler for all modes
- Automatic "Handshake" control of data transfers
- Three interrupts with program control
- Port A
- Port B
- Counter/Timer
- $1,2,3$, and 4 MHz versions
- Commercial and industrial temperature range versions
- Wide variety of packages
-40-pin plastic and ceramic DIP
- 44-pin plastic leaded chip carrier (PLCC)
- Single +5 Vdc power requirement
- Compatible with the R6500, R6500/* and R65C00 family of microprocessors


40-PIN DIP


44-PIN PCC

CONNECTION

Figure 1. R65C24 Pin Assignments

## ORDERING INFORMATION



## INTERFACE SIGNALS

The PIAT interfaces to the R6500, R6500/* or the R65C00 microprocessor family with a reset line, a $\emptyset 2$ clock line, a read/write line, an interrupt request line, three register select lines, two chip select lines, and an 8 -bit bidirectional data bus.

The PIAT interfaces to the peripheral devices with four interrupt/control lines and two 8 -bit bidirectional data ports. A Counter/Timer input/output line (CNTR) also interfaces to a peripheral device.
Figure 1 (on the front page) shows the pin assignments for these interface signals and Figure 2 shows the interface relationship of these signal as they pertain to the CPU and the peripheral devices.

## CHIP SELECT (CSO, $\overline{\mathbf{C S} 2)}$

The PIAT is selected when CSO is high and CS2 is low. These two chip select lines are normally connected to the processor address lines either directly or through external decoder circuits. When the PIAT is selected, data will be transferred between the data lines and PIAT registers, and/or peripheral interface lines as determined by the R/W, RS0, RS1 and RS2 lines and the contents of Control Registers A and B.

## NOTE:

An R65C24 PIAT may be installed in a circuit in place of an R65C21 PIA subject to chip select considerations. Since the R65C21 has a CS1 input and the R54C24 does not have a CS1 input, the PIAT will be selected in the same addresses as the PIA and maybe more depending upon external address decoding circuitry.

## RESET SIGNAL ( $\overline{\operatorname{RES}})$

The Reset ( $\overline{\mathrm{RES}}$ ) input initializes the R65C24 PIAT. A low signal on the ( $\overline{\mathrm{RES}}$ ) input causes all internal registers to be cleared.

## CLOCK SIGNAL ( $\mathbf{~}^{2}$ )

The Phase 2 Clock Signal ( $\emptyset 2$ ) is the system clock that triggers all data transfers between the CPU and the PIAT. $\emptyset 2$ is generated by the CPU and is therefore the synchronizing signal between the CPU and the PIAT.

## READ/WRITE SIGNAL (R/ $\bar{W}$ )

Read/Write ( $\mathrm{R} \bar{W}$ ) controls the direction of data transfers between the PIAT and the data lines associated with the CPU and the peripheral devices. A high on the R/W line permits the peripheral devices to transfer data to the CPU from the PIAT. A low on the $\mathrm{R} / \overline{\mathrm{W}}$ line allows data to be transfered from the CPU to the peripheral devices from the PIAT.

## REGISTER SELECT (RSO, RS1, RS2)

Two of the Register Select lines (RSO, RS1), in conjunction with the Control Registers (CRA, CRB), select various R65C24 registers to be accessed by the CPU. RS0 and RS1 are normally connected to the microprocessor (CPU) address output lines. Through control of these lines, the CPU can write directly into the Control Registers (CRA, CRB), the Data Direction Registers (DDRA, DDRB) and the Peripheral Output Registers (ORA, ORB). In addition, the processor may directly read the contents of the Control Registers and the Data Direction Registers. Accessing the Peripheral Output Register for the purpose of reading data back into the processor operates differently on the ORA and the ORB registers and, therefore, are shown separately in Table 1.


Figure 2. Interface Signals Relationship

Table 1. Peripheral Register Addressing

|  | Register <br> Select <br> Lines |  | Data <br> Direction <br> Register <br> Control |  | Register Operation |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :--- |
| Register <br> Address <br> (Hex) | RS2 | RS1 | RSO | CRA <br> (Bit 2) | CRB <br> (Bit 2) | R/ $\bar{W}=$ H | R/ $\bar{W}=$ L |
| 4 | H | L | L | 1 | - | Read PIBA | Write ORA |
| 4 | H | L | L | 0 | - | Read DDRA | Write DDRA |
| 5 | H | L | H | - | - | Read CRA | Write CRA |
| 6 | H | H | L | - | 1 | Read PIBB | Write ORB |
| 6 | H | H | L | - | 0 | Read DDRB | Write DDRB |
| 7 | H | H | H | - | - | Read CRB | Write CRB |

Register Select line RS2 determines whether the addressed registers are part of the Counter/Timer or the peripheral Port A and Port B sections of the PIAT. When RS2 is high, the Port A/Port B registers shown in Table 1 are selected. When the RS2 is low, the Counter/Timer registers are selected and operated upon as shown in Table 2.

## INTERRUPT REQUEST LINE ( $\overline{(\mathrm{RQ}}$ )

Three internal active low Interrupt Request lines ( $\overline{\mathrm{IRQA}}, \overline{\mathrm{IRQB}}$, and $\overline{\mathrm{RQT}}$ ) act to interrupt the microprocessor through the external $\overline{\mathrm{RQ}}$ output. $\overline{\mathrm{IRQ}}$ is an open drain output and is capable of sinking 1.6 mA from an external source. This permits all interrupt request lines to be tied together in a wired-OR configuration. The $A$ and $B$ in the titles of these internal lines correspond to the peripheral port $A$ and the peripheral port $B$ so that each interrupt request line services one peripheral data port. The T corresponds to the Counter/Timer generated interrupt request.
$\overline{\text { IRQA }}$ and $\overline{\text { IRQB }}$ Lines - These two internal Interrupt Request lines are associated with the Port A and Port B sections of the PIAT and are controlled by Control Registers CRA and CRB, and the Peripheral Control lines CA1, CA2, CB1, and CB2.

These Interrupt Request lines have three interrupt flag bits which can cause the Interrupt Request line to go low. These flags are bits 6 and 7 in the two Control Registers (CRA, CRB). These flags act as the link between the peripheral interrupt signals and the microprocessor interrupt inputs. Each flag has a corresponding interrupt disable bit which allows the processor to enable or disable the interrupt from each of the four interrupt inputs (CA1, CA2, CB1, CB2). The four interrupt flags are set (enabled) by active transitions of the signal on the interrupt input (CA1, CA2, CB1, CB2).

CRA bit 7 (IRQA1) is always set by an active transition of the CA1 interrupt input signal. However, $\overline{\mathrm{IRQA}}$ can be disabled by setting bit 0 in CRA to a 0 . Likewise, CRA bit 6 (IRQA2) can be

Table 2. Counter/Timer Register Addressing

| Register <br> Address <br> (Hex) | Register <br> Select Lines |  | Counter/Timer Operation |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |

set by an active transition of the CA2 interrupt input signal and $\overline{\text { IRQA }}$ can be disabled by setting bit 3 in CRA to a 0.

Both bit 6 and bit 7 in CRA are reset by a "Read Peripheral Output Register A" operation. This is defined as an operation in which the read/write, proper data direction register and register select signals are provided to allow the processor to read the Peripheral A I/O port. A summary of IRQA control is shown in Table 3.

Control of $\overline{\mathrm{RQB}}$ is performed in exactly the same manner as that described above for $\overline{\text { IRQA }}$ (Table 3). Bit 7 in CRB (IRQB1) is set by an active transition on CB1 and IRQB from this flag is controlled by CRB bit 0 . Likewise, bit 6 (IRQB2) in CRB is set by an active transition on CB2, and IRQB from this flag is controlled by CRB bit 3 . Also, both bit 6 and bit 7 of CRB are reset by a "Read Peripheral B Output Register" operation.

IRQT Line - The internal IRQT line is associated with the Counter/Timer and is controlled by the IRQT Enable bit in the Counter Mode Control Register and the Underflow Flag in the Status Register. A thorough discussion of the functions and operation of the IRQT line is given in the Counter/Timer Operation section of this product description.

Table 3. $\overline{\mathrm{IRQA}}$ and $\overline{\mathrm{IRQB}}$ Control Summary

| Control Register Bits | Action |
| :---: | :---: |
| CRA $-7=1$ and CRA $-0=1$ | $\overline{\text { IRQA }}$ goes low (Active) |
| $\mathrm{CRA}-6=1$ and CRA $-3=1$ | $\overline{\mathrm{RQA}}$ goes low (Active) |
| $\mathrm{CRB}-7=1$ and CRB- $0=1$ | $\overline{\mathrm{RQB}}$ goes low (Active) |
| $\mathrm{CRB}-6=1$ and CRB-3 $=1$ | $\overline{\mathrm{TRQB}}$ goes low (Active) |

## INTERRUPT INPUT/PERIPHERAL CONTROL LINES (CA1, CA2, CB1, CB2)

The four interrupt input/peripheral control lines provide a number of special peripheral control functions. These lines greatly enhance the power of the two general purpose interface ports (PA0-PA7, PB0-PB7). Figure 5 summarizes the operation of these control lines.

CA1 is an interrupt input only. An active transition of the signal on this input will set bit 7 of the Control Register A to a logic 1. The active transition can be programmed by setting a 0 in bit 1 of the CRA if the interrupt flag (bit 7 of CRA) is to be set on a negative (high to low) transition of the CA1 signal, or by setting a 1 if it is to be set on a positive (low to high) transition.

CA2 can act as a totally independent interrupt or as a peripheral control output. As an input (CRA, bit $5=0$ ) it acts to set the interrupt flag, bit 6 of CRA, to a logic 1 on the active transition selected by bit 4 of CRA.

These control register bits and interrupt inputs serve the same basic function as that described above for CA1. The input signal sets the interrupt flag which serves as the link between the peripheral device and the processor interrupt structure. The interrupt disable bit allows the processor to exercise control over the system interrupt.

In the output mode (CRA, bit $5=1$ ), CA2 can operate independently to generate a single pulse each time the microprocessor reads the data on the Peripheral A I/O port. This mode is selected by setting CRA, bit 4 to a 0 and CRA, bit 3 to a 1 . This pulse output can be used to control the counters, shift registers, etc. which make sequential data available on the Peripheral input lines.

A second output mode allows CA2 to be used in conjunction with CA1 to "handshake" between the processor and the peripheral device. On the $A$ side, this technique allows positive control of data transfers from the peripheral device into the microprocessor. The CA1 input signals the processor that data is available by interrupting the processor. The processor reads the data and sets CA2 low. This signals the peripheral device that it can make new data available.

The final output mode can be selected by setting bit 4 of CRA to a 1. In this mode, CA2 is a simple peripheral control output which can be set high or low by setting bit 3 of CRA to a 1 or a 0 , respectively.

CB1 operates as an interrupt input only in the same manner as CA1. Bit 7 of CRB is set by the active transition selected by bit 0 of CRB. Likewise, the CB2 input mode operates exactly the same as the CA2 input modes. The CB2 output modes, CRB bit $5=1$, differ somewhat from those of CA2. The pulse output occurs when the processor writes data into the Peripheral B Output Register. Also, the "handshaking" operates on data transfers from the processor into the peripheral device.

## FUNCTIONAL DESCRIPTION

The R65C24 PIAT is organized into three independent sections referred to as the A Side, the B Side, and a Counter/Timer. The A Side and B Side each consist of a Control Register (CRA, CRB), Data Direction Register (DDRA, DDRB), Output Register (ORA, ORB), Interrupt Status Control (ISCA, ISCB), and the buffers necessary to drive the Peripheral Interface buses. Data Bus Buffers (DBB) interface data from the two sections to the data bus, while the Data Input Register (DIR) interfaces data from the DBB to the PIAT registers. Chip Select and R/W control circuitry interface to the processor bus control lines. The Counter/Timer consists of a 16-bit counter; i.e., an 8-bit Upper Counter (UC) and 8-bit Lower Counter (LC), an 8-bit Upper Latch (UL), an 8-bit Lower Latch (LL), an 8-bit Snapshot Latch (SL), and a Status Register (SR). A Counter Mode Control Register (CMCR) selects the Counter/Timer mode of operation. Figure 3 is a block diagram of the R65C24 PIAT.

## DATA INPUT REGISTER (DIR)

When the microprocessor writes data into the PIAT, the data which appears on the data bus during the $\$ 2$ clock pulse is latched into the Data Input Register (DIR). The data is then transferred into one of six internal registers of the PIAT after the trailing edge of the $\emptyset 2$ clock. This assures that the data on the peripheral output lines will make smooth transitions from high to low (or from low to high) and the voltage will remain stable except when it is going to the opposite polarity.

## CONTROL REGISTERS (CRA AND CRB)

Table 4 illustrates the bit designation and functions in the two control registers. The control registers allow the microprocessor to control the operation of the interrupt Control inputs (CA1, CA2, CB1, CB2), and Peripheral Control outputs (CA2, CB2). Bit 2 in each register controls the addressing of the Data Direction Registers (DDRA, DDRB) and the Output Registers (ORA, ORB). In addition, two bits (bit 6 and 7) in each control register indicate the status of the Interrupt Input lines (CA1, CA2, CB1, CB2). These Interrupt Status bits (IRQA1, IRQA2 or IRQB1, IRQB2) are normally interrogated by the microprocessor during the $\overline{\mathrm{RQ}}$ interrupt service routine to determine the source of the interrupt.

## DATA DIRECTION REGISTERS (DDRA, DDRB)

The Data Direction Registers (DDRA, DDRB) allow the processor to program each line in the 8 -bit Peripheral I/O port to be either an input or an output. Each bit in DDRA controls the corresponding line in the Peripheral A port and each bit in DDRB controls the corresponding line in the Peripheral B port. Writing a 0 in a bit position in the Data Direction Register causes the corresponding Peripheral I/O line to act as an input; a 1 causes it to act as an output.

Bit 2 (DDRA, DDRB) in each Control Register (CRA and CRB) controls the accessing to the Data Direction Register or the Peripheral interface. If bit 2 is a 1, a Peripheral Output register (ORA, ORB) is selected, and if bit 2 is a 0 , a Data Direction Register (DDRA, DDRB) is selected. The Data Direction Register Access Control bit, together with the Register Select lines (RSO, RS1 and RS2) selects the various internal registers as shown in Table 1.


Figure 3. R65C24 PIAT Block Diagram

Table 4. Control Registers Bit Designations

| $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ |
| :---: | :---: | :---: | :---: | :---: |
| IRQA1 | IRQA2 | CA2 Control | DDRA <br> Access | $\mathbf{1}$ |


| $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ |
| :---: | :---: | :---: | :---: | :---: |
| IRQB1 | IRQB2 | CB2 Control | $\mathbf{2}$ | $\mathbf{1}$ |

In order to write data into DDRA, ORA, DDRB, or ORB registers, bit 2 in the proper Control Register must first be set. The desired register may then be accessed with the address determined by the address interconnect technique used.

## PERIPHERAL OUTPUT REGISTERS (ORA, ORB)

The Peripheral Output Registers (ORA, ORB) store the output data from the Data Bus Buffers (DBB) which appears on the Peripheral I/O port. If a line on the Peripheral A Port is programmed as an output by the DDRA, writing a 0 into the corresponding bit in the ORA causes that line to go low ( $\leq 0.4 \mathrm{Vdc}$ ); writing a 1 causes the line to go high. The lines of the Peripheral $B$ port are controlled by ORB in the same manner.

## INTERRUPT STATUS CONTROL (ISCA, ISCB)

The four interrupt/peripheral control lines (CA1, CA2, CB1, CB2) are controlled by the Interrupt Status Control logic (A, B). This logic interprets the contents of the corresponding Control Register and detects active transitions on the interrupt inputs.

## PERIPHERAL I/O PORTS (PA0-PA7, PB0-PB7)

The Peripheral A and Peripheral B l/O ports allow the microprocessor to interface to the input lines on the peripheral device by writing data into the Peripheral Output Register. They also allow the processor to interface with the peripheral device output lines by reading the data on the Peripheral Port input lines directly onto the data bus and into the internal registers of the processor.

Each of the Peripheral I/O lines can be programmed to act as an input or an output. This is accomplished by setting a 1 in the corresponding bit in the Data Direction Register for those lines which are to act as outputs. A 0 in a bit of the Data Direction Register causes the corresponding Peripheral I/O lines to act as an input.

The buffers which drive the Peripheral A I/O lines contain "passive" pull-up devices. These pull-up devices are resistive in nature and therefore allow the output voltage to go to Vcc for a logic 1. The switches can sink a full 3.2 mA , making these buffers capable of driving two standard TTL loads.

In the input mode, the pull-up devices are still connected to the I/O pin and still supply current to this pin. For this reason, these lines also represent two standard TTL loads in the input mode.

The Peripheral B I/O port duplicates many of the functions of the Peripheral A port. The process of programming these lines to act as an input or any output is similar to the Peripheral A port, as is the effect of reading or writing this port. However, there are several characteristics of the buffers driving these lines which affect their use in peripheral interfacing.

The Peripheral BI/O port buffers are push-pull devices i.e., the pull-up devices are switched OFF in the 0 state and ON for a logic 1. Since these pull-ups are active devices, the logic 1 voltage will not go higher than +2.4 Vdc .

Unlike the PAO-PA7 lines (which have pull-up devices), the PBO through PB7 lines have three-state capability which allows them to enter a high impedance state when programmed to be used as input lines. In addition, data on these lines will be read properly, when programmed as output lines, even if the data signals fall below 2.0 Vdc for a "high" state or are above 0.8 Vdc for a "low" state. When programmed as output, each line can drive at least a two TTL load and may also be used as a source of up to 3.2 mA at 1.5 Vdc to directly drive the base of a transistor switch, such as a Darlington pair.

Because these outputs are designed to drive transistors directly, the output data is read directly from the Peripheral Output Register for those lines programmed to act as inputs.

The final characteristic is the high-impedance input state which is a function of the Peripheral B push-pull buffers. When the Peripheral B I/O lines are programmed to act as inputs, the output buffer enters the high impedance state.

## DATA BUS BUFFERS (DBB)

The Data Bus Buffers are 8-bit bidirectional buffers used for data exchange, on the D0-D7 Data Bus, between the miroprocessor and the PIAT. These buffers are tri-state and are capable of driving a two TTL load (when operating in an output mode) and represent a one TTL load to the microprocessor (when operating in an input mode).

## COUNTER/TIMER

The Counter/Timer includes a 16 -bit counter and three 8 -bit data latches. It also includes an 8-bit Counter Mode Control Register (CMCR) to select the Counter/Timer operating mode and options and an 8 -bit Status Register to report time-out conditions as well as peripheral data port interrupt conditions. Figure 4 illustrates the Timer/Counter.

Counter/Latches - The Upper Counter (UC) and Lower Counter (LC) form a 16-bit down-counter that counts either $\emptyset 2$ clock pulses from the processor bus or external events from input line CNTR, depending on the mode selected. The Upper Latch (UL) and Lower Latch (LL) hold the initial higher- and lowerorder count values to be loaded into the counter. The Snapshot Latch (SL) is loaded with the value of the UC when the LC is read or the LL is written into by the PIAT. After a read of the LC, the Snapshot Latch is read to provide the current 16-bit value of the counter. The Underflow Flag (UF) in the Status Register $(\mathrm{SR})$ is set to a 1 whenever the counter (UC, LC) decrements past $\$ 0000$. A Prescaler can be program activated to divide-bysixteen rather than divide-by-one for any of the Counter/Timer modes.

Counter Mode Control Register - The Counter Mode Control Register (CMCR) allows program selection of any of eight Counter/Timer modes of operation, for the enabling or disabling of the Prescaler, and the enabling or disabling of the IRQT interrupt line. Bits 2, 1 and 0 of the CMCR select one of the following Counter/Timer operating modes:

Disable Counter/Timer
One-Shot Interval Timer
Free-Run Interval Timer
Pulse Width Measurement
Event Counter
One-Shot Pulse Width Generation
Free-Run Pulse Generation
Retriggerable Interval Timer
Bit 7 of the CMCR controls the $\overline{\mathrm{RQT}}$ line. When bit 7 is set to a 1 , IRQT is enabled and an Underflow Flag (UF bit in the

Status Register set to a 1) will cause $\overline{\mathrm{RQ}}$ to be asserted. When bit 7 is set to a 0 , the $\overline{\mathrm{RQT}}$ is disabled.

Bit 4 of the CMCR enables or disables the Prescaler. A 1 in bit 4 causes the Prescaler to be enabled so that the Counter/Timer is operating in a divide-by-sixteen mode. When this bit is a 0 the Prescaler is disabled so that the Counter/Timer is operating in a normal (divide-by-one) mode.

Status Register - Bit 7 of the Status Register (SR) reports the Counter Underflow Status. This underflow (UF) bit is set to 1 when the counter decrements past $\$ 0000$. When this bit is set, the $\overline{\mathrm{RQ}}$ output will be asserted if the Interrupt Enable bit in the CMCR is set to a 1 . The status of the Port A Interrupt Flag (IRQA) and Port B Interrupt Flag (IRQB) are reported in bits 6 and 5, respectively, in addition to being reported in the ISCA and ISCB registers.


Figure 4. Counter/Timer


| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { IRQA1 } \\ & \text { FLAG } \end{aligned}$ | $\begin{aligned} & \text { IRQA2 } \\ & \text { FLAG } \end{aligned}$ | $\begin{aligned} & \text { CA2 INPUT } \\ & \text { MODE SELECT } \\ & (=0) \end{aligned}$ | IRQA2 POSITIVE TRANSITION | $\begin{gathered} \overline{\mathrm{IRQA}} \\ \text { ENABLE } \\ \text { FOR IRQA2 } \end{gathered}$ | $\begin{aligned} & \text { ORA } \\ & \text { SELECT } \end{aligned}$ | $\begin{gathered} \text { IRQA1 } \\ \text { POSITIVE } \\ \text { TRANSITION } \end{gathered}$ | $\begin{gathered} \overline{\mathrm{TRQA}} \\ \text { ENABLE } \\ \text { FOR IRQA1 } \end{gathered}$ |
|  |  |  | $\overline{\text { IRQA }}$ IRQA2 CONTROL |  |  | IRQA/IRQA1 CONTROL |  |

CA2 OUTPUT MODE (BIT $5=1$ )

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { IRQA1 } \\ & \text { FLAG } \end{aligned}$ | 0 | CA2 OUTPUT <br> MODE SELECT $(=1)$ | CA2 OUTPUT CONTROL | CA2 RESTORE CONTROL | ORA SELECT | IRQA1 POSITIVE TRANSITION | ```IRQA ENABLE FOR IRQA1``` |
|  |  |  | CA2 CONTROL |  |  | $\overline{\text { RQA }}$ IRQA1 CONTROL |  |

CA2 INPUT OR OUTPUT MODE (BIT $5=0$ or 1)

| Bit 7 | IRQA1 FLAG |
| :---: | :---: |
| 1 | A transition has occurred on CA1 that satisfies the bit 1 IRQA1 transition polarity criteria. This bit is cleared by a read of Output Register $A$ or by $\overline{\text { RES }}$. |
| 0 | No transition has occurred on CA1 that satisfies the bit 1 IRQA1 transition polarity criteria. |
| Bit 2 | OUTPUT REGISTER A SELECT |
| 1 | Select Output Register A. |
| 0 | Select Data Direction Register A. |
| Bit 1 | IRQA1 POSITIVE TRANSITION |
| 1 | Set IRQA1 Flag (bit 7) on a positive (low-to-high) transition of CA1. |
| 0 | Set IRQA1 Flag (bit 7) on a negative (high-to-low) transition of CA1. |
| Bit 0 | $\overline{\text { IRQA }}$ ENABLE FOR IRQA1 |
| 1 | Enable assertion of $\overline{\mathrm{IRQA}}$ when IRQA1 Flag (bit 7) is set. |
| 0 | Disable assertion of $\overline{\mathrm{RQAA}}$ when IRQA1 Flag (bit 7) is set. |

CA2 INPUT MODE (BIT $5=0$ )

```
Bit 6 IRQA2 FLAG
1 A transition has occurred on CA2 that satisfies the bit 4 IRQA2 transition polarity criteria. This flag is cleared by a read of Output
        Register A or by \overline{RES}.
    0 No transition has occurred on CA2 that satisfies the bit 4 IRQA2 transition polarity criteria.
Bit 5 CA2 MODE SELECT
    0 Select CA2 Input Mode.
Bit 4 IRQA2 POSITIVE TRANSITION
    1 Set IRQA2 Flag (bit 6) on a positive (low-to-high) transition of CA2.
    0 Set IRQA2 Flag (bit 6) on a negative (high-to-low) transition of CA2.
Bit 3 IRQA ENABLE FOR IRQA2
    1 Enable assertion of \overline{IRQA}}\mathrm{ when IRQA2 Flag (bit 6) is set.
0 Disable assertion of IRQA when IRQA2 Flag (bit 6) is set.
```

CA2 OUTPUT MODE (BIT $5=1$ )

| Bit 6 | NOT USED |
| :---: | :---: |
| 0 | Always zero. |
| Bit 5 | CA2 MODE SELECT |
| 1 | Select CA2 Output Mode. |
| Bit 4 | CA2 OUTPUT CONTROL |
| 1 | CA2 goes low when a zero is written into CRA bit 3. CA2 goes high when a one is written into CRA bit 3. |
| 0 | CA2 goes low on the first negative (high-to-low) $\emptyset 2$ clock transition following a read of Output Register A. CA2 returns high as specified by bit 3 . |
| Bit 3 | CA2 READ STROBE RESTORE CONTROL (BIT $4=0$ ) |
| 1 | CA2 returns high on the next $\emptyset 2$ clock negative transition following a read of Output Register A. |
| 0 | CA2 returns high on the next active CA1 transition following a read of Output Register A as specified by bit 1. |

Figure 5. Summary of Control Lines Operation (1 of 2)

CB2 INPUT MODE (BIT $5=0$ )
CONTROL REGISTER B (CRB)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { IRQB1 } \\ & \text { FLAG } \end{aligned}$ | $\begin{aligned} & \text { IRQB2 } \\ & \text { FLAG } \end{aligned}$ | $\begin{gathered} \text { CB2 INPUT } \\ \text { MODE SELECT } \\ (=0) \end{gathered}$ | $\begin{gathered} \text { IRQB2 } \\ \text { POSITIVE } \\ \text { TRANSITION } \end{gathered}$ | $\begin{gathered} \overline{\mathrm{RQ} \bar{B}} \\ \text { ENABLE } \\ \text { FOR IRQB2 } \end{gathered}$ | $\begin{aligned} & \text { ORB } \\ & \text { SELECT } \end{aligned}$ | $\begin{gathered} \text { IRQB1 } \\ \text { POSITIVE } \\ \text { TRANSITION } \end{gathered}$ | $\begin{gathered} \overline{\mathrm{IRQB}} \\ \text { ENABLE } \\ \text { FOR IRQB1 } \end{gathered}$ |
|  |  |  | $\begin{gathered} \overline{\mathrm{RQB}} \\ \mathrm{CON} \end{gathered}$ |  |  |  |  |

CB2 OUTPUT MODE (BIT $5=1$ )

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { IRQB1 } \\ & \text { FLAG } \end{aligned}$ | 0 | CB2 OUTPUT MODE SELECT (=1) | CB2 <br> OUTPUT CONTROL | CB2 RESTORE CONTROL | ORB SELECT | IRQB1 POSITIVE TRANSITION | $\begin{gathered} \overline{\text { IRQB }} \\ \text { ENABLE } \\ \text { FOR IRQB1 } \end{gathered}$ |
|  |  |  | CB2 CONTROL |  |  | $\overline{\mathrm{IRQB}} / \mathrm{IRQB} 1$ CONTROL |  |

CB2 INPUT OR OUTPUT MODE (BIT $5=0$ or 1)

| Bit 7 | IRQB1 FLAG |
| :---: | :---: |
| 1 | A transition has occurred on CB1 that satisfies the bit 1 IRQB1 transition polarity criteria. This bit is cleared by a read of Output Register $B$ or by $\overline{\mathrm{RES}}$. |
| 0 | No transition has occurred on CB1 that satisfies the bit 1 IRQB1 transition polarity criteria. |
| Bit 2 | OUTPUT REGISTER B SELECT |
| 1 | Select Output Register B. |
| 0 | Select Data Direction Register B. |
| Bit 1 | IRQB1 POSITIVE TRANSITION |
| 1 | Set IRQB1 Flag (bit 7) on a positive (low-to-high) transition of CB1. |
| 0 | Set IRQB1 Flag (bit 7) on a negative (high-to-low) transition of CB1. |
| Bit 0 | IRQB ENABLE FOR IRQB1 |
| 1 | Enable assertion of $\overline{\mathrm{TRQB}}$ when IRQB1 Flag (bit 7) is set. |
| 0 | Disable assertion of IRQB when IRQB1 Flag (bit 7) is set. |

CB2 INPUT MODE (BIT $5=0$ )

| Bit 6 | IRQB2 FLAG |
| :---: | :---: |
| 1 | A transition has occurred on CB2 that satisfies the bit 4 IRQB2 transition polarity criteria. This flag is cleared by a read of Output Register B or by $\overline{\mathrm{RES}}$. |
| 0 | No transition has occurred on CB2 that satisfies the bit 4 IRQB2 transition polarity criteria. |
| Bit 5 | CB2 MODE SELECT |
| 0 | Select CB2 Input Mode. |
| Bit 4 | IRQB2 POSITIVE TRANSITION |
| 1 | Set IRQB2 Flag (bit 6) on a positive (low-to-high) transition of CB2. |
| 0 | Set IRQB2 Flag (bit 6) on a negative (high-to-low) transition of CB2. |
| Bit 3 | $\overline{\text { IRQB }}$ ENABLE FOR IRQB2 |
| 1 | Enable assertion of $\overline{\text { IRQB }}$ when IRQB2 Flag (bit 6) is set. |
| 0 | Disable assertion of $\overline{\mathrm{IRQB}}$ when IRQB2 Flag (bit 6) is set. |

CB2 OUTPUT MODE (BIT $5=1$ )

| Bit 6 | NOT USED |
| :---: | :---: |
| 0 | Always zero. |
| Bit 5 | CB2 MODE SELECT |
| 1 | Select CB2 Output Mode. |
| Bit 4 | CB2 OUTPUT CONTROL |
| 1 | CB2 goes low when a zero is written into CRB bit 3. CB2 goes high when a one is written into CRB bit 3. |
| 0 | CB2 goes low on the first negative (high-to-low) $\emptyset 2$ clock transition following a write to Output Register B. CB2 returns high as specified by bit 3 . |
| Bit 3 | CB2 WRITE STROBE RESTORE CONTROL (BIT $4=0$ ) |
| 1 | CB2 returns high on the next $\emptyset 2$ clock negative transition following a write to Output Register B. |
| 0 | CB2 returns high on the next active CB1 transition following a write to Output Register B as specified by bit 1. |

Figure 5. Summary of Control Lines Operation (2 of 2)

## COUNTER/TIMER REGISTERS

## COUNTER MODE CONTROL REGISTER (CMCR)

The 8-bit Counter Mode Control Register (CMCR) selects the Counter/Timer mode of operation and enables or disables both the internal $\overline{\mathrm{IRQT}}$ and the Prescaler. The format of the CMCR is:

| 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IRQT <br> Enabled | 0 | 0 | Prescaler <br> Enabled | 0 | Counter/Timer Mode |  |


| Bit 7 | $\overline{\text { IRQT }}$ Enabled |
| :---: | :---: |
| 0 | $\overline{\text { IRQT }}$ Disabled |
| 1 | $\overline{\text { IRQT }}$ Enabled |

Bits 6-5 Not used, don't care value during write.

| Bit 4 | Prescaler Enabled |
| :---: | :--- |
| 0 | Prescaler Disabled $(\div 1)$ |
| 1 | Prescaler Enabled $(\div 16)$ |

Bit 3 Not used, don't care value during write.

Bits 2-0

| $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ | Counter/Timer Mode |
| :--- | :--- | :--- | :--- |
| $\mathbf{0}$ | $\mathbf{0}$ | $\mathbf{0}$ | Mode 0-Disable Counter/Timer |
| 0 | 0 | 1 | Mode 1-One-Shot Interval Timer |
| 0 | 1 | 0 | Mode 2-Free-Run Interval Timer |
| 0 | 1 | 1 | Mode 3-Pulse Width Measurement |
| 1 | 0 | 0 | Mode 4-Event Counter |
| 1 | 0 | 1 | Mode 5-One-Shot Pulse Width Generation |
| 1 | 1 | 0 | Mode 6-Free-Run Pulse Generation |
| 1 | 1 | 1 | Mode 7-Retriggerable Interval Timer |

The CMCR can be written into at any time without disabling or stopping the Counter/Timer. This allows the Counter/Timer mode of operation to be changed while it is still in operation. However, selecting Mode 0 disables the Counter/Timer and stops its operation. The Prescaler and the IRQT interrupt can also be enabled or disabled at any time. The CMCR is written to when the register address is 3 and $R / \bar{W}$ is low.

## STATUS REGISTER (SR)

The 8-bit Status Register (SR) reports the status of three interrupt conditions: Counter underflow (IRQT), Port A interrupt (IRQA) and Port B interrupt ( $\overline{\mathrm{IRQB}}$ ). The format of the Status Register is:

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| UF (IRQT) <br> Interrupt <br> Flag | IRQA <br> Interrupt <br> Flag | IRQB <br> Interrupt <br> Flag | 1 | 1 | 1 | 1 | 1 |

Bit 7 Counter Underflow (UF) Interrupt Flag
0 Counter underflow has not occurred.
1 Counter underflow has occurred.
Bit 6 IRQA Interrupt Flag
0 Port A interrupt has not occurred.
1 Port A interrupt has occurred.
Bit 5 IRQB Interrupt Flag
0 Port B interrupt has not occurred.
1 Port B interrupt has occurred.

Bit
4-0 Not used, always read as shown in register figure.

The Counter Underflow (UF) Interrupt, bit 7, is updated in the same clock cycle that an underflow condition occurs on the Counter/Timer. The IRQA and IRQB interrupt flags (bits 6 and 5 ) are updated at the rising edge of the next $\emptyset 2$ clock immediately following the setting of corresponding interrupt bits in the CRA register. The IRQA Interrupt Flag is set whenever the IRQA1 or IRQA2 bit is set. The IRQB Interrupt Flag is set whenever the IRQB1 or IRQB2 bit is set. The Counter Underflow bit is cleared whenever the Snapshot Latch is read, the Upper Latch (UL) is written to at register address 0 , Mode 0 is selected in the CMCR, or a $\overline{R E S}$ occurs. The Status Register is read when the register address is 3 and $R / \bar{W}$ is high.

## LOWER LATCH (LL)

The Lower Latch (LL) holds the least significant 8-bits of the 16 -bit latch value. The $L L$ is written from the data bus (D0-D7) when the register address is 2 and $R \bar{W}$ is low. When the LL is loaded, the contents of the UC are copied into the Snapshot Latch (SL) without affecting the counting operation of the UC.

## UPPER LATCH (UL)

The Upper Latch (UL) holds the most significant 8 -bits of the 16 -bit latch value. The UL is written from the data bus (D0-D7) when $R \bar{W}$ is low and the register address is either 0 or 1 . The difference in the two register address functions are:

## Register Address 0

1. The UL is loaded from D0-D7.
2. The contents of the latches (UL and LL) are transferred to the counters (UC and LC, respectively).
3. The UF bit is cleared in the SR.
4. The Counter is enabled, i.e., the count in UC and LC is decremented by one upon detection of a rising edge on either $\emptyset 2$ or CNTR (depending upon mode selection) as scaled by the Prescaler.

## Register Address 1

1. The UL is loaded from D0-D7.
2. All other elements of the Counter/Timer are unaffected.

## LOWER COUNTER (LC)

The Lower Counter (LC) holds the least significant 8-bits of the 16-bit counter.

When the LC decrements below $\$ 00,1$ is borrowed from the UC to load \$FF into the LC.

The LC is read to the data bus (D0-D7) when the register address is 2 and $\mathrm{R} / \overline{\mathrm{W}}$ is high. When LC is read, the 8 -bit contents of the UC is transferred to the Snapshot Latch without affecting the operation of the counter (i.e., the count-down continues without interruption).

## UPPER COUNTER

The Upper Counter (UC) holds the most significant 8-bits of the 16 -bit counter. The UC is read to the data bus (D0-D7) when the register address is 1 and $R / \bar{W}$ is high. When the UC is read, there is no other effect on the Counter/Timer operation. Counter underflow occurs when the LC borrows a 1 from an UC value of $\$ 00$.

## Note:

When reading the UC directly, the value read can be one count too high if the LC value is just above $\$ 00$ at the start of the read since an underflow in the LC will result in decrementing the UC by one count. The Snapshot Latch should be read to obtain the UC value corresponding to the LC value.

## SNAPSHOT LATCH (SL)

The Snapshot Latch holds the value of the UC corresponding to the LC value. The SL is loaded with the value of the UC when the $L L$ is written to, or when the LC is read. The $S L$ is read to the data bus (D0-D7) when the register address is 0 and $R / \bar{W}$ is high, without affecting the counting operation. When the SL is read, the UF in the SR is cleared. Since the SL is loaded with the value of the UC whenever the LC is read, an accurate count of the total 16 -bit counter can be made without the need for further calculations to account for delays between the reading of the LC and the UC.

## COUNTER/TIMER OPERATION

The Counter/Timer has eight modes of operation. The Counter/ Timer is always either disabled (mode 0 ) or operating in one of the other seven modes as selected in the Counter Mode Control Register (CMCR).

To operate the Counter/Timer, first issue Mode 0 to stop any counting in progress due to a previously selected mode, to clear the counter underflow bit in the SR and to disable the IRQT interrupt. The order of mode selection and latch loading depends upon the desired mode. Generally, if a timer mode based on the $\emptyset 2$ clock rate is to be selected, first select the mode then write the timer initialization value to the latch. Write the LL first then the UL value (to register address 0 ). When the UL is written, the

UL and LL values are loaded into the UC and LC, respectively, . and the counter is enabled. The counter then decrements one count for every positive edge (low to high) transition detected on the $\emptyset 2$ or CNTR input (depending on the selected mode) as scaled by the Prescaler. In most modes, each time the counter underflows below $\$ 0000$, the underflow bit is set in the SR, the counter reloads to the latch value and the down-counting continues. If the UF bit is set when the IRQT is enabled in the CMCR, the $\overline{\mathrm{IRQ}}$ output will be asserted to the processor.

## MODE 0-DISABLE COUNTER/TIMER

The Counter/Timer is disabled (all counting stops), the IRQT interrupt (bit 7 in the CMCR) is disabled, and the counter underflow (bit 7 in the SR) is cleared. Mode 0 may be selected at any time by selecting Mode 0 in the CMCR or upon $\overline{\text { RES }}$ which initializes the CMCR to $\$ 00$. Selecting Mode 0 in the CMCR does not affect any data in the LL or UL, any count in the LC or UC, or any data in the SL.

## MODE 1-ONE SHOT INTERVAL TIMER

The counter counts down once from the latch value at the $\varnothing 2$ clock rate (as scaled by the Prescaler) and sets the UF bit in the SR upon underflow. The counter starts when data is written to the UL at register address 0 , which causes the UL and LL values to be loaded into the UC and LC, respectively. When the counter decrements below $\$ 0000$, the UF bit in the SR is set. The set UF bit causes $\overline{I R Q}$ to be asserted if the $\overline{\mathrm{IRQT}}$ Enable bit is set in the CMCR. Upon decrementing below \$0000, the UC and LC are automatically reset to a value of \$FFFF and the counter continues down-counting. However, the UF bit in the SR will not be set again (due to the counter again decrementing through \$0000) until the UL is again written at register address 0 . The CNTR line is not used in this mode. Figure 6 shows the timing relationship for Mode 1 operation.

Typical Application: Can be used for an accurate time delay such as would be required to control the duration of time to have a thermal printer element activated.

## MODE 2-FREE-RUN INTERVAL TIMER

The counter repetitively counts down at the $\emptyset 2$ clock rate, as scaled by the Prescaler, and sets the UF bit in the SR each time the counter underflows. The counter is initialized to the UL and LL values and starts down counting at the clock rate when the UL value is written to register address 0 . Each time the counter decrements below \$0000, the UF bit in the SR is set, the counter is reloaded with the UL and LL value, and the count-down cycle continues. If the IRQT Enable bit is set in the CMCR, $\overline{\mathrm{IRQ}}$ will be asserted upon each time-out. The CNTR line is not used in this mode. Figure 7 shows the timing relationship for Mode 2 operation.

Typical Application: Can be used for a timed interrupt structure when a hardware location needs updating at specific intervals, such as would be required to update a multiplexed display.


Figure 6. Mode 1-One-Shot Interval Timer Timing


Figure 7. Mode 2-Free-Run Interval Timer Timing

## MODE 3-PULSE WIDTH MEASUREMENT

The counter counts down from the latch value at the $\emptyset 2$ clock rate (scaled by the Prescaler) from the time the CNTR input goes low until CNTR goes high to provide a measurement of the CNTR low pulse duration. The counter is loaded with the value of the UL and LL upon writing UL to register address 0 . The counter starts decrementing at the scaled $\emptyset 2$ clock rate when the CNTR line goes low and stops decrementing when the CNTR line returns high. If the counter decrements below $\$ 0000$ before the CNTR line goes high, the UF bit in the SR is set, the counter is reloaded with the UL and LL value, and the cycle continues down until CNTR goes high. Once the CNTR line has cycled from high to low and back to high, the Counter/Timer will ignore any additional high to low transitions on the CNTR line. To reinitiate Mode 3 , it is necessary to reload the UL by writing to register address 0 . Figure 8 shows the timing relationships for a Mode 3 operation.

Typical Application: Can be used to measure the duration of an event from an external device. Allows an accurate measurement of the duration of a logical low pulse on the CNTR line.

## MODE 4-EVENT COUNTER

CNTR is an input and the Counter/Timer counts the number of positive transitions on CNTR. The counter is initially loaded with the UL and LL value when the UL is written to register address 0 . The counter then decrements one count on the falling edge of the CNTR input after a falling edge (high-to-low transition) is detected on the $\emptyset 2$ clock. The maximum rate at which this falling edge can be detected is one-half the $\emptyset 2$ clock rate. When the counter decrements below $\$ 0000$, the UF bit in the SR is set, the counter is reloaded with the UL and LL value and the operation repeats. Figure 9 shows the timing relationship of a Mode 4 operation.
Typical Application: Can be used with a timed software loop to count external events (i.e., a frequency counter).

Figure 8. Mode 3-Pulse Width Measurement Timing


Figure 9. Mode 4-Event Counter Timing

## MODE 5-ONE-SHOT PULSE WIDTH GENERATION

CNTR is an output which can be pulsed low for a programmed time interval. When this mode is selected in the CMCR, the CNTR output goes high if the UF bit is set. It goes low if the UF bit is cleared. The CNTR line then goes low when data is written to the UL at register address 0 , which also starts the counter. The counter decrements from the UL and LL value at the $\emptyset 2$ clock rate as scaled by the Prescaler. When the counter decrements below $\$ 0000$, the CNTR output goes high, the UF bit is set in the SR, the counter is reloaded with \$FFFF and the count-down continues. Figure 10 shows the timing relationship of Mode 5 operation.

Note that clearing the UF bit after it is set upon the first timeout causes CNTR to go low, in which case CNTR will again go high upon the next counter timeout.

Typical Application: Can be used to hold-off (delay) an external hardware event on an asynchronous basis such as disallowing a motor startup until certain parameters are met.

## MODE 6-FREE-RUN PULSE GENERATION

CNTR is an output and the Counter/Timer can be programmed to generate a symmetrical waveform, an asymmetrical waveform, or a string of varying width pulses on CNTR. The CNTR line is forced low when data is written to the UL at register address

0 which also starts the counter. The counter decrements at the $\emptyset 2$ clock rate as scaled by the Prescaler. When the counter decrements below $\$ 0000$, CNTR toggles from low to high (or high to low depending upon its initial state), the counter is reloaded with the UL and LL value and the counter continues down-counting. The UF bit in the SR is set the first time the counter decrements past $\$ 0000$ and is cleared only if a new write to UL at register address 0 occurs. Figure 11 shows the timing relationship of a Mode 6 operation.

This mode can be used to generate an asymmetrical waveform by toggling the UL and LL with the CNTR high and low times. Immediately after starting the counter with the first CNTR low time, load the LL and UL (by writing to register address 1, which does not restart the counter) with the CNTR high time. When the first counter underflow occurs, the counter loads the new latch value (i.e., the CNTR high time) into the counter and continues counting. During the $\overline{\mathrm{RQ}}$ interrupt processing resulting from the first counter time-out, load the LL and UL (at register address 1) with the original CNTR low time. Continue to alternate loading of the high and low time latch values during the interrupt processing for the duration of the mode.

Typical Application: Can be used to supply external circuitry with a software variable clock based upon the system $\emptyset 2$ clock (e.g., a tone generator for audio feedback).


Figure 10. Mode 5-One-Shot Pulse Width Generation Timing


Figure 11. Mode 6-Free-Run Pulse Generation Timing

## MODE 7-RETRIGGERABLE INTERVAL TIMER

The Counter/Timer operates as a timer which is retriggered, i.e., reinitialized to its starting value, upon detection of a negative transition on the CNTR input. The counter is initially loaded with the UL and LL value when the UL is written to register address 0 . The counter starts decrementing at the $\emptyset 2$ clock rate (as scaled by the Prescaler) when a falling edge (high to low transition) is detected on CNTR. The counter is reinitialized to the UL and $L L$ value whenever a falling edge is subsequently detected on CNTR. If the counter decrements past $\$ 0000$ before the falling edge is detected, the UF bit is set in the SR, the counter is initialized to the UL and LL value and the count-down continues.

Typical Application: Can be used to monitor signals that should be periodic and can interrupt the processor if the signal being monitored does not occur within a specified time frame; such as a synchronous motor that has fallen out of synchronization.

## PRESCALER

The Counter/Timer operates in either the divide by one or divide by sixteen mode. In the divide by one mode, the counter holds from 1 to 65,535 counts. The counter capacity is therefore $1 \mu \mathrm{~s}$ to $65,535 \mu \mathrm{~s}$ at $1 \mathrm{MHz} \emptyset 2$ clock rate or $0.25 \mu \mathrm{~s}$ to $16,383 \mu \mathrm{~s}$ at a $4 \mathrm{MHz} \emptyset 2$ clock rate. Timer intervals greater than the maximum counter value can be easily measured by counting underflow flags or $\overline{\mathrm{RQ}}$ interrupt requests.

The divide by sixteen prescaler can be enabled to extend the timing interval by 16 . This provides timing from 1048.56 ms ( 1 MHz ) to $260.21 \mathrm{~ms}(4 \mathrm{MHz})$. The prescaler clocks the Counter/Timer at the $\emptyset 2$ clock rate divided by sixteen, except for Mode 4. In Mode 4, sixteen positive CNTR edges must occur to decrement the Counter/Timer by one count.

## INITIALIZING THE COUNTER/TIMER

The following program segment is one suggested technique for initializing the Counter/Timer:
;Data Definition

| SL | $=\$ \times X X 0$ |
| :--- | :--- |
| UC | $=\$ \times \times X 1$ |
| LC | $=\$ \times X X 2$ |
| SR | $=\$ \times X X 3$ |
| ULEC | $=\$ \times X X 0$ |
| UL | $=\$ \times X X 1$ |
| LL | $=\$ \times X X 2$ |
| CMCR | $=\$ X X X 3$ |

;Snapshot Latch
;Upper Counter
;Lower Counter
;Status Register
;Upper Latch and Enable Counter
;Upper Latch
;Lower Latch
;Counter Mode Control Register
;Program

| LDA | $\# \$$ mode0 | ;disable Counter/Timer |
| :--- | :--- | :--- |
| STA | CMCR | ;write to mode register |
| LDA | $\# \$$ mode | ;select mode and Prescaler and |
|  |  | IRQT enable/disable |
| STA | CMCR | ;write to mode register |


| LDA | \#\$lovalue | ;lower latch value |
| :--- | :--- | :--- |
| STA | LL | ;write to lower latch |
| LDA | \#\$hivalue | ;upper latch value |
| STA | ULEC | ;write to upper latch |
|  |  | ;clear underflow flag, and enable <br> counter |

The following instructions change the mode while the Counter/Timer is in operation:
$\left.\begin{array}{ccc}\text { LDA } & \# \text { mode } & \text {;select desired mode, except } \\ \text { mode } 0\end{array}\right]$;write to mode register

The change of mode operation will take effect immediately. Thus, the Free-Run Internal Timer mode (Mode 2) could be systematically stopped by changing to the One-Shot Interval Timer mode (Mode 1). The Counter/Timer will then halt operation when the underflow condition occurs. This technique can also be used to enable or disable $\overline{\mathrm{IRQ}}$ during program execution.

## READING THE COUNTER/TIMER

To service an interrupt request, the following sequence can be used:

| BIT | \$status | ;get underflow flag |
| :--- | :--- | :--- |
| BNE | error | ;check if flag is set |
| LDA | \$LC | ;get low counter value for overflow |
| LDX | \$SL | ;get high counter value for overflow |
|  |  | ;underflow flag is cleared |

By reading the LC and SL, it is possible to determine the amount of time between the interrupt request and servicing the interrupt.

To read a timer value at any time, the suggested technique is as follows:

| LDA | \$LC | ;get low counter value <br> ;upper counter transferred to <br> snapshot |
| :--- | :--- | :--- |
|  | . | ;any miscellaneous code to store <br> value if desired |
| LDA | \$SL | ;get high counter value |

## READ/WRITE TIMING

 CHARACTERISTICS OF PIATFigure 13 is a timing diagram for the R65C24 PIAT during a Read operation (input mode). Figure 14 is a timing diagram for the PIAT during a Write operation (output mode).


Figure 12. Mode 7-Retriggerable Interval Timer Timing


Figure 13. Read Timing Diagram


Figure 14. Write Timing Diagram

## READING THE PERIPHERAL A I/O PORT

Performing a Read operation with RS1 $=0$, RS0 $=0$ and the Data Direction Register Access Control bit (CRA-2) $=1$, directly transfers the data on the Peripheral A I/O lines to the data bus. In this situation, the data bus will contain both the input and output data. The processor must be programmed to recognize and interpret only those bits which are important to the particular peripheral operation being performed.

Since the processor always reads the Peripheral A I/O port pins instead of the actual Peripheral Output Register (ORA), it is possible for the data read by the processor to differ from the contents of the Peripheral Output Register for an output line. This is true when the $/ / \mathrm{O}$ pin is not allowed to go to a full +2.4 Vdc
when the Peripheral Output register contains a logic 1. In this case, the processor will read a 0 from the Peripheral A pin, even though the corresponding bit in the Peripheral Output register is a 1 .

## READING THE PERIPHERAL B I/O PORT

Reading the Peripheral $B / / O$ port yields a combination of input and output data in a manner similar to the Peripheral A port. However, data is read directly from the Peripheral B Output Register (ORB) for those lines programmed to act as outputs. It is therefore possible to load down the Peripheral B Output lines without causing incorrect data to be transferred back to the processor on a Read operation.

## SWITCHING CHARACTERISTICS

$\left(V_{C C}=5.0 \mathrm{Vdc} \pm 5 \%, V_{S S}=0, T_{A}=T_{L}\right.$ to $T_{H}$, unless otherwise noted)

## BUS TIMING

| Parameter | Symbol | 1 MHz |  | 2 MHz |  | 3 MHz |  | 4 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $\emptyset 2$ Cycle | $\mathrm{t}_{\mathrm{CYC}}$ | 1.0 | - | 0.5 | - | 0.33 | - | 0.25 | - | $\mu \mathrm{S}$ |
| ¢2 Pulse Width | $t_{c}$ | 450 | - | 220 | - | 160 | - | 110 | - | ns |
| $\emptyset 2$ Rise and Fall Time | $\mathrm{trc}_{\mathrm{rc}}, \mathrm{t}_{\mathrm{fc}}$ | - | 25 | - | 15 | - | 12 | - | 10 | ns |
| Read |  |  |  |  |  |  |  |  |  |  |
| Address Set-Up Time | $\mathrm{t}_{\text {ACR }}$ | 140 | - | 70 | - | 53 | - | 35 | - | ns |
| Address Hold Time | $t_{\text {cAR }}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| Peripheral Data Set-Up Time | $\mathrm{t}_{\mathrm{PCR}}$ | 300 | - | 150 | - | 110 | - | 75 | - | ns |
| Data Bus Delay Time | $\mathrm{t}_{\mathrm{CDR}}$ | - | 335 | - | 145 | - | 105 | - | 85 | ns |
| Data Bus Hold Time | $t_{\text {HR }}$ | 20 | - | 20 | - | 20 | - | 20 | - | ns |
| Write |  |  |  |  |  |  |  |  |  |  |
| Address Set-Up Time | $t_{\text {ACW }}$ | 140 | - | 70 | - | 53 | - | 35 | - | ns |
| Address Hold Time | $\mathrm{t}_{\text {caw }}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| R/W Set-Up Time | $\mathrm{t}_{\text {WCW }}$ | 180 | - | 90 | - | 67 | - | 45 | - | ns |
| R/W Hold Time | $\mathrm{t}_{\mathrm{CWW}}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| Data Bus Set-Up Time | $\mathrm{t}_{\mathrm{DCW}}$ | 180 | - | 90 | - | 67 | - | 45 | - | ns |
| Data Bus Hold Time | $\mathrm{t}_{\text {HW }}$ | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| Peripheral Data Delay Time | $\mathrm{t}_{\text {CPW }}$ | - | 1.0 | - | 0.5 | - | 0.5 | - | 0.5 | $\mu \mathrm{S}$ |
| Peripheral Data Delay Time to CMOS Level | $\mathrm{t}_{\text {CMOS }}$ | - | 2.0 | - | 1.0 | - | 0.7 | - | 0.5 | $\mu \mathrm{S}$ |

## PERIPHERAL INTERFACE TIMING

| Peripheral Data Set-Up | $\mathrm{t}_{\mathrm{PCR}}$ | 300 | - | 150 | - | 110 | - | 75 | - |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\emptyset 2$ Low to CA2 Low Delay | $\mathrm{t}_{\mathrm{CA} 2}$ | - | 1.0 | - | 0.5 | - | 0.5 | - | 0.5 |
| $\emptyset 2$ Low to CA2 High Delay | $\mathrm{t}_{\mathrm{RS} 1}$ | - | 1.0 | - | 0.5 | - | 0.5 | - | 0.5 |
| $\emptyset 2$ Low to CNTR Low/High Delay | $\mathrm{t}_{\mathrm{CNTR}}$ | - | 1.0 | - | 0.5 | - | 0.5 | - | 0.5 |
| CA1 Active to CA2 High Delay | $\mathrm{t}_{\mathrm{RS} 2}$ | - | 2.0 | - | 1.0 | - | 1.0 | - | 1.0 |
| $\phi 2$ High to CB2 Low Delay | $\mathrm{t}_{\mathrm{CB} 2}$ | - | 1.0 | - | 0.5 | - | $\mu \mathrm{s}$ |  |  |
| Peripheral Data Valid to CB2 Low Delay | $\mathrm{t}_{\mathrm{DC}}$ | 0 | 1.5 | 0 | 0.75 | 0 | 0.5 | 0 | 0.37 |
| $\emptyset 2$ High to CB2 High Delay | $\mathrm{t}_{\mathrm{RS} 1}$ | - | 1.0 | - | 0.5 | - | 0.5 | - | 0.5 |
| CB1 Active to CB2 High Delay | $\mathrm{t}_{\mathrm{RS} 2}$ | - | 2.0 | - | 1.0 | - | 0.67 | - | 0.5 |
| CA1, CA2, CB1 and CB2 <br> Input Rise and Fall Time | $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}$ | - | 1.0 | - | 1.0 | - | 1.0 | - | 1.0 |

[^1]ABSOLUTE MAXIMUM RATINGS*

| Parameter | Symbol | Value | Unit |
| :--- | :--- | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | Vdc |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | -0.3 to $\mathrm{V}_{\mathrm{CC}}+0.3$ | Vdc |
| Output Voltage | $\mathrm{V}_{\mathrm{OUT}}$ | -0.3 to $\mathrm{V}_{\mathrm{CC}}+0.3$ | Vdc |
| Operating Temperature Range <br> Commercial <br> Industrial | $\mathrm{T}_{\mathrm{A}}$ | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature |  | -40 to +85 |  |

## OPERATING CONDITIONS

| Parameter | Symbol | Value |
| :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $5 \mathrm{~V} \pm 5 \%$ |
| Temperature Range | $\mathrm{T}_{\mathrm{A}}$ | $\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$ |
| Commercial |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Industrial |  | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## ELECTRICAL CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{S S}=0, T_{A}=T_{\mathrm{L}}\right.$ to $\mathrm{T}_{\mathrm{H}}$, unless otherwise noted $)$

| Parameter | Symbol | Min. | Typ. ${ }^{3}$ | Max. | Unit ${ }^{2}$ | Test Conditions |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Input High Voltage <br> All except R/W, CS2 <br> R/W, CS2 | $\mathrm{V}_{\mathrm{IH}}$ |  |  |  |  |  |
| Input Low Voltage |  | +2.0 |  |  |  |  |

## PACKAGE DIMENSIONS



## R65C51

Asynchronous Communications Interface Adapter (ACIA)

## DESCRIPTION

The Rockwell CMOS R65C51 Asynchronous Communications Interface Adapter (ACIA) provides an easily implemented, program controlled interface between 8 -bit microprocessor-based systems and serial communication data sets and modems.

The ACIA has an internal baud rate generator. This feature eliminates the need for multiple component support circuits, a crystal being the only other part required. The Transmitter baud rate can be selected under program control to be any one of 15 different rates from 50 to 19,200 baud, or $1 / 16$ times an external clock rate. The Receiver baud rate may be selected under program control to be either the Transmitter rate, or at $1 / 16$ times an external clock rate. The ACIA has programmable word lengths of $5,6,7$, or 8 bits; even, odd, or no parity; $1,1 \frac{1 / 2}{2}$, or 2 stop bits.

The ACIA is designed for maximum programmed control from the microprocessor (MPU), to simplify hardware implementation. Three separate registers permit the MPU to easily select the R65C51's operating modes and data checking parameters and determine operational status.

## FEATURES

- Low power CMOS N -well silicon gate technology
- Replacement for NMOS R6551 ACIA
- Full duplex operation with buffered receiver and transmitter
- Data set/modem control functions
- Internal baud rate generator with 15 programmable baud rates (50 to 19,200)
- Program-selectable internally or externally controlled receiver rate
- Programmable word lengths, number of stop bits, and parity bit generation and detection
- Programmable interrupt control
- Program reset
- Program-selectable serial echo mode
- Two chip selects
- 1 or 2 MHz operation
- $5.0 \mathrm{Vdc} \pm 5 \%$ supply requirements
- Wide range of packages available
-28 -pin ceramic or plastic DIP
-28 -pin plastic leaded chip carrier (PLCC)
- Full TTL compatibility
- Compatible with R6500, R6500/* and R65C00 microprocessors

| $\mathrm{v}_{\text {ss }} \square$ | 1 | 28 | $\square \mathrm{R} / \overline{\mathrm{W}}$ |
| :---: | :---: | :---: | :---: |
| cso | 2 | 27 | $\square 02$ |
| $\overline{\text { CS1 }}$ | 3 | 26 | $\square \overline{\mathrm{IRO}}$ |
| $\overline{\text { RES }}$ | 4 | 25 | $\square \mathrm{D7}$ |
| RxC | 5 | 24 | $\square \mathrm{D} 6$ |
| XTLI $\square$ | 6 | 23 | $\square \mathrm{D} 5$ |
| XTLO | 7 | 22 | $\square \mathrm{D} 4$ |
| $\overline{\text { RTS }}$ | 8 | 21 | $\square \mathrm{D} 3$ |
| $\overline{\text { CTS }}$ | 9 | 20 | $\square \mathrm{D} 2$ |
| TxD - | 10 | 19 | $\square \mathrm{D} 1$ |
| $\overline{\text { DTR }}$ | 11 | 18 | $\square \mathrm{DO}$ |
| RXD | 12 | 17 | $\square \overline{\text { DSR }}$ |
| RSO - | 13 | 16 | $\square \overline{\mathrm{DCD}}$ |
| RS1 | 14 | 15 | $\square \mathrm{V}_{\text {cc }}$ |
|  |  |  |  |



Figure 1. R65C51 ACIA Pin Assignments

## ORDERING INFORMATION

## Part Number:

R65C51


$$
\text { C }=28 \text {-Pin Ceramic DIP }
$$

P $=28-$ Pin Plastic DIP
$J=28-$ Pin Plastic Leaded
Chip Carrier (PLCC)

## INTERFACE SIGNALS

Figure 1 (front page) shows the R65C51 ACIA pin assignments and Figure 2 groups the signals by functional interface.

## MICROPROCESSOR INTERFACE

## Reset ( $\overline{\text { RES }}$ )

During system initialization, a low on the $\overline{R E S}$ input causes a hardware Reset to occur. Upon Reset, the Command Register and the Control Register are cleared (all bits set to 0). The Status Register is cleared with the exception of the indications of Data Set Ready and Data Carrier Detect, which are externally controlled by the $\overline{\mathrm{DSR}}$ and $\overline{\mathrm{DCD}}$ lines, and the Transmitter Empty bit, which is set. $\overline{\text { RES }}$ must be held low for one $\emptyset 2$ clock cycle for a reset to occur.

## Input Clock ( $\mathbf{Q 2}^{\text {) }}$

The input clock is the system $\emptyset 2$ clock and clocks all data transfers between the system microprocessor and the ACIA.

## Read/Write (R/W)

The $R \bar{W}$ input, generated by the microprocessor controls the direction of data transfers. A high on the $R \bar{W}$ pin allows the processor to read the data supplied by the ACIA, a low allows a write to the ACIA.

## Interrupt Request (IRQ)

The $\overline{\mathrm{RQ}} \mathrm{pin}$ is an interrupt output from the interrupt control logic. It is an open drain output, permitting several devices to be connected to the common $\overline{\mathrm{IRQ}}$ microprocessor input. Normally a high level, $\overline{\mathrm{IRQ}}$ goes low when an interrupt occurs.

## Data Bus (D0-D7)

The eight data line (D0-D7) pins transfer data between the processor and the ACIA. These lines are bi-directional and are normally high-impedance except during Read cycles when the ACIA is selected.

## Chip Selects (CS0, $\overline{\text { CS1 }}$ )

The two chip select inputs are normally connected to the processor address lines either directly or through decoders. The ACIA is selected when CSO is high and CS1 is low. When the ACIA is selected, the internal registers are addressed in accordance with the register select lines (RSO, RS1).

## Register Selects (RS0, RS1)

The two register select lines are normally connected to the processor address lines to allow the processor to select the various ACIA internal registers. Table 1 shows the internal register select decoding.

Table 1. ACIA Register Selection

|  |  | Register Operation |  |
| :---: | :---: | :--- | :--- |
| RS1 | RS0 | R/ $\overline{\mathbf{W}}=$ Low | $\mathbf{R} / \overline{\mathbf{W}}=$ High |
| L | L | Write Transmit Data <br> Register | Read Receiver <br> Data Register |
| L | H | Programmed Reset <br> (Data is "Don't <br> Care") | Read Status <br> Register |
| H | L | Write Command <br> Register | Read Command <br> Register |
| H | H | Write Control <br> Register | Read Control <br> Register |

The Command Register controls parity, receiver echo mode, transmitter interrupt control, the state of the $\overline{\mathrm{RTS}}$ line, receiver interrupt control, and the state of the DTR line.

The Control Register controls the number of stop bits, word length, receiver clock source, and baud rate.

The Status Register indicates the states of the $\overline{I R Q}, \overline{\mathrm{DSR}}$, and $\overline{\mathrm{DCD}}$ lines, Transmitter and Receiver Data Registers, and Overrun, Framing, and Parity Error conditions.

The Transmitter and Receiver Data Registers are used for temporary data storage by the ACIA Transmit and Receive circuits.

Only the Command and Control registers can be both read and written. The programmed Reset operation does not cause any data transfer, but is used to clear bits 4 through 0 in the Command register and bit 2 in the Status Register. The control Register is unchanged by a programmed Reset. It should be noted that the programmed Reset is slightly different from the hardware Reset (RES); refer to the register description.


Figure 2. ACIA Interface Diagram

## ACIA/MODEM INTERFACE

## Crystal Pins (XTLI, XTLO)

These pins are normally directly connected to a parallel mode external crystal ( 1.8432 MHz ) to derive the various baud rates. Note that capacitors are required from XTLI to ground and from XTLO to ground. Alternatively, an externally generated clock can drive the XTLI pin, in which case the XTLO pin must float.

## Transmit Data (TxD)

The TxD output line transfers serial non-return-to-zero (NRZ) data to the modem. The least significant bit (LSB) of the Transmit Data Register is the first data bit transmitted and the rate of data transmission is determined by the baud rate selected or by an external transmitter clock. This selection is made by programming the Control Register.

## Receive Data (RxD)

The RxD input line transfers serial NRZ data into the ACIA from the modem, LSB first. The receiver data rate is determined by the programmed baud rate or by an externally generated receiver clock. The selection is made by programming the Control Register.

## Receive Clock (RxC)

$R \times C$ is a bi-directional pin which is either the external receiver clock input or a clock output of $16 x$ the baud rate. The latter
mode results if the internal baud rate generator is selected for receiver data clocking.

## Request to Send (RTS)

The $\overline{\text { RTS }}$ output pin controls the modem from the processor. The state of the RTS pin is determined by the contents of the Command Register.

## Clear to Send (CTS)

The $\overline{\mathrm{CTS}}$ input pin controls the transmitter operation. The enable state is with CTS low. The transmitter is automatically disabled if $\overline{C T S}$ is high.

## Data Terminal Ready (DTR)

This output pin indicates the status of the ACIA to the modem. A low on DTR indicates the ACIA is enabled, a high indicates it is disabled. The processor controls this pin via bit 0 of the Command Register.

## Data Set Ready ( $\overline{\mathrm{DSR}}$ )

The $\overline{\mathrm{DSR}}$ input pin indicates to the ACIA the status of the modem. A low indicates the "ready" state and a high, "not-ready."

## Data Carrier Detect ( $\overline{\mathrm{DCD}}$ )

The $\overline{\mathrm{DCD}}$ input pin indicates to the ACIA the status of the carrierdetect output of the modem. A low indicates that the modem carrier signal is present and a high, that it is not.

## FUNCTIONAL DESCRIPTION

A block diagram of the R65C51 ACIA is presented in Figure 3. A description of each functional element of the device follows.

## DATA BUS BUFFERS

The Data Bus Buffer interfaces the system data lines to the internal data bus. The Data Bus Buffer is bi-directional. When the $R \bar{W}$ line is low and the chip is selected, the Data Bus Buffer writes the data from the system data lines to the ACIA internal data bus. When the $R / \bar{W}$ line is high and the chip is selected, the Data Bus Buffer drives the data from the internal data bus to the system data bus.

## INTERRUPT LOGIC

The Interrupt Logic will cause the $\overline{\mathrm{RQ}}$ line to the microprocessor to go low when conditions are met that require the attention of the microprocessor. The conditions which can cause an interrupt will set bit 7 and the appropriate bit of bits 3 through 6 in the Status Register, if enabled. Bits 5 and 6 correspond to the Data Carrier Detect ( $\overline{\mathrm{DCD}}$ ) logic and the Data Set Ready ( $\overline{\mathrm{DSR}}$ ) logic. Bits 3 and 4 correspond to the Receive Data Register full and the Transmitter Data Register empty conditions. These conditions can cause an interrupt request if enabled by the Command Register.

## I/O CONTROL

The I/O Control Logic controls the selection of internal registers for a data transfer on the internal data bus and the direction of the transfer to or from the register.
The registers are selected by the Register Select (RS1, RS0) and Read/Write ( $R / \bar{W}$ ) lines as shown in Table 1.

## TIMING AND CONTROL

The Timing and Control logic controls the timing of data transfers on the internal data bus, the registers, the Data Bus Buffer, the microprocessor data bus, and the hardware reset.

Timing is controlled by the system $\emptyset 2$ clock input. The chip will perform data transfers to or from the microcomputer data bus during the $\emptyset 2$ high period when selected.

All registers will be initialized by the Timing and Control Logic when the Reset ( $\overline{\operatorname{RES}}$ ) line goes low. See the individual register description for the state of the registers following a hardware reset.

## TRANSMITTER AND RECEIVER DATA REGISTERS

These registers are used as temporary data storage for the ACIA Transmit and Receive circuits. Both the Transmitter and Receiver are selected by a Register Select 0 (RSO) and Register Select 1 (RS1) low condition. The Read/Write (R/W) line determines which actually uses the internal data bus; the Transmitter Data Register is write only and the Receiver Data Register is read only.

Bit 0 is the first bit to be transmitted from the Transmitter Data Register (least significant bit first). The higher order bits follow in order. Unused bits in this register are "don't care" bits.

The Receiver Data Register holds the first received data bit in bit 0 (least significant bit first). Unused high-order bits are " 0 ". Parity bits are not contained in the Receiver Data Register. They are stripped off after being used for parity checking.


Figure 3. R65C51 ACIA Block Diagram

## STATUS REGISTER

The Status Register indicates the state of interrupt conditions and other non-interrupt status information. The interrupt conditions are Data Set Ready and Data Carrier Detect transitions, Transmitter Data Register Empty and Receiver Data Register Full as reported in bits 6 through 3, respectively. If any of these bits are set, the Interrupt (IRQ) indicator (bit 7) is also set. Overrun, Framing Error, and Parity Error are also reported (bits 2 through 0 , respectively).


| Bit 7 | Interrupt (IRQ) |
| :---: | :--- |
| 0 | No interrupt |
| 1 | Interrupt has occurred |
| Bit $\mathbf{6}$ | Data Set Ready (DSR) |
| 0 | DSR low (ready) |
| 1 | DSR high (not ready) |
| Bit 5 | Data Carrier Detect (DCD) |
| 0 | DCD low (detected) |
| 1 | DCD high (not detected) |
| Bit 4 | Transmitter Data Register Empty |
| 0 | Not empty |
| 1 | Empty |
| Bit 3 | Receiver Data Register Full |
| 0 | Not full |
| 1 | Full |
| Bit 2 | Overrun* |
| 0 | No overrun |
| 1 | Overrun has occurred |
| Bit 1 | Framing Error* |
| 0 | No framing error |
| 1 | Framing error detected |
| Bit 0 | Parity Error* |
| 0 | No parity error |
| 1 | Parity error detected |

*No interrupt occurs for these conditions

## Reset Initialization



Hardware reset Program reset

Parity Error (Bit 0), Framing Error (Bit 1),
and Overrun (Bit 2)
None of these bits causes a processor interrupt to occur, but they are normally checked at the time the Receiver Data Register is read so that the validity of the data can be verified. These bits are self clearing (i.e., they are automatically cleared after a read of the Receiver Data Register.)

## Receiver Data Register Full (Bit 3)

This bit goes to a 1 when the ACIA transfers data from the Receiver Shift Register to the Receiver Data Register, and goes to a 0 (is cleared) when the processor reads the Receiver Data Register.

## Transmitter Data Register Empty (Bit 4)

This bit goes to a 1 when the ACIA transfers data from the Transmitter Data Register to the Transmitter Shift Register, and goes to a 0 (is cleared) when the processor writes new data onto the Transmitter Data Register.

NOTE: There is a delay of approximately $1 / 16$ of a bit time after the TDR becomes emptylfull before this flag is updated.

## Data Carrier Detect (Bit 5) and Data Set Ready (Bit 6)

These bits reflect the levels of the $\overline{\mathrm{DCD}}$ and $\overline{\mathrm{DSR}}$ inputs to the ACIA. A 0 indicates a low level (true condition) and a 1 indicates a high level (false). Whenever either of these inputs change state, an immediate processor interrupt (IRQ) occurs, unless bit 1 of the Command Register (IRD) is set to a 1 to disable $\overline{\mathrm{IRQ}}$. When the interrupt occurs, the status bits indicate the levels of the inputs immediately after the change of state occurred. Subsequent level changes will not affect the status bits until after the Status Register has been interrogated by the processor. At that time, another interrupt will immediately occur and the status bits will reflect the new state. These bits are not automatically cleared (or reset) by an internal operation.

## Interrupt (Bit 7)

This bit goes to a 1 whenever an interrupt condition occurs and goes to a 0 (is cleared) when the Status Register is read.

## CONTROL REGISTER

The Control Register selects the desired baud rate, frequency source, word length, and the number of stop bits.


| Bit 7 | Stop Bit Number (SBN) |
| :---: | :---: |
| 0 | 1 Stop bit |
| 1 | 2 Stop bits |
| 1 | 11/2 Stop bits |
|  | For WL = 5 and no parity |
| 1 | 1 Stop bit <br> For WL = 8 and parity |

Bits 6-5 Word Length (WL)

| $\frac{6}{0}$ | $\frac{5}{0}$ |  |
| :---: | :---: | :---: |
| 0 | No. Bits |  |
| 0 | 1 | 8 |
| 1 | 0 | 6 |
| 1 | 1 | 5 |

Bit 4 Receiver Clock Source (RCS)
0 External receiver clock
1 Baud rate
Bits 3-0 Selected Baud Rate (SBR)

| $\frac{3}{0}$ | $\frac{2}{0}$ | $\frac{1}{0}$ |  | $\frac{0}{0}$ |
| :--- | :--- | :--- | :--- | :--- |
|  | $\frac{\text { Baud }}{}$ |  |  |  |
| 0 | 0 | 0 |  | 1 |
| TxC rate $\div 16^{*}$ |  |  |  |  |
| 0 | 0 | 1 | 0 | 75 |
| 0 | 0 | 1 | 1 | 109.92 |
| 0 | 1 | 0 | 0 | 134.58 |
| 0 | 1 | 0 | 1 | 150 |
| 0 | 1 | 1 | 0 | 300 |
| 0 | 1 | 1 | 1 | 600 |
| 1 | 0 | 0 | 0 | 1200 |
| 1 | 0 | 0 | 1 | 1800 |
| 1 | 0 | 1 | 0 | 2400 |
| 1 | 0 | 1 | 1 | 3600 |
| 1 | 1 | 0 | 0 | 4800 |
| 1 | 1 | 0 | 1 | 7200 |
| 1 | 1 | 1 | 0 | 9600 |
| 1 | 1 | 1 | 1 | 19,200 |

*XTLI is the input for the External Transmitter Clock (TxC)

## Reset Initialization



## Selected Baud Rate (Bits 0, 1, 2, 3)

These bits select the Transmitter baud rate, which can be at $1 / 16$ an external transmitter clock rate or one of 15 other rates controlled by the internal baud rate generator.

If the Receiver clock uses the same baud rate as the transmitter (bit $4=1$ ), then RxC becomes an output (at 16x the baud rate) and can be used to slave other circuits to the ACIA. Figure 4 shows the Transmitter and Receiver layout.


Figure 4. Transmitter/Receiver Clock Circuits

## Receiver Clock Source (Bit 4)

This bit controls the clock source to the Receiver. A 0 causes the Receiver to operate at a baud rate of $1 / 16$ the external receiver clock on pin RxC. A 1 causes the Receiver to operate at the same baud rate as is selected for the transmitter.

## Word Length (Bits 5, 6)

These bits determine the word length to be used (5, 6, 7 or 8 bits).

## Stop Bit Number (Bit 7)

This bit determines the number of stop bits used. A 0 always indicates one stop bit. A 1 indicates $1 \frac{1}{2}$ stop bits if the word length is 5 with no parity selected, 1 stop bit if the word length is 8 with parity selected, and 2 stop bits in all other configurations.

## COMMAND REGISTER

The Command Register controls specific modes and functions.


| Bits 7-6 | Parity Mode Control (PMC) |
| :---: | :---: |
| $7 \quad 6$ |  |
| 0 | Odd parity transmitted/received |
| 0 | Even parity transmitted/received |
| 0 | Mark parity bit transmitted |
|  | Parity check disabled |
| 1 | Space parity bit transmitted |
|  | Parity check disabled |
| Bit 5 | Parity Mode Enabled (PME) |
| 0 | Parity mode disabled |
|  | No parity bit generated |
|  | Parity check disabled |
| 1 | Parity mode enabled |
| Bit 4 | Receiver Echo Mode (REM) |
| 0 | Receiver normal mode |
| 1 | Receiver echo mode |
|  | Bits 2 and 3 must also be zero for receiver echo mode, $\overline{\mathrm{RTS}}$ will be low. |

Bits 3-2 Transmitter Interrupt Control (TIC)

| $\frac{3}{0}$ | $\frac{2}{0}$ | $\overline{\text { RTS }}$ | $=$ High, transmitter disabled |
| :--- | :--- | :--- | :--- |
| 0 | 1 | $\overline{\text { RTS }}=$ | $=$ Low, transmit interrupt enabled |
| 1 | 0 | $\overline{\text { RTS }}=$ | $=$ Low, transmit interrupt disabled |
| 1 | 1 | $\overline{\text { RTS }}=$ | $=$ Low, transmit interrupt disabled |
|  |  |  | transmit break on TxD |

Bit 1 Receiver Interrupt Request Disabled (IRD)
$0 \quad \overline{\mathrm{RQ}}$ enabled (receiver)
$1 \quad \overline{\mathrm{RQ}}$ disabled (receiver)
Bit $0 \quad$ Data Terminal Ready (DTR)
0 Data terminal not ready (DTR high)*
1 Data terminal ready (DTR low)

## Data Terminal Ready (Bit 0)

This bit enables all selected interrupts and controls the state of the Data Terminal Ready (DTR) line. A 0 indicates the microcomputer system is not ready by setting the DTR line high. A 1 indicates the microcomputer system is ready by setting the $\overline{\mathrm{DTR}}$ line low. $\overline{\mathrm{DTR}}$ also enables and disables the transmitter and receiver.

## Receiver Interrupt Control (Bit 1)

This bit disables the Receiver $\overline{\mathrm{DCD}}$ and $\overline{\mathrm{DSR}}$ from generating an interrupt when set to a 1 . The Receiver $\overline{\mathrm{DCD}}$ and $\overline{\mathrm{DSR}}$ interrupts are enabled when this bit is set to a 0 and Bit 0 is set to a 1.

## Transmitter Interrupt Control (Bits 2, 3)

These bits control the state of the Ready to Send ( $\overline{\mathrm{RTS}}$ ) line and the Transmitter interrupt.

## Receiver Echo Mode (Bit 4)

A 1 enables the Receiver Echo Mode and a 0 disables the Receiver Echo Mode. When bit 4 is a 1 bits 2 and 3 must be 0 . In the Receiver Echo Mode, the Transmitter returns each transmission received by the Receiver delayed by one-half bit time.

## Parity Mode Enable (Bit 5)

This bit enables parity bit generation and checking. A 0 disables parity bit generation by the Transmitter and parity bit checking by the Receiver. A 1 bit enables generation and checking of parity bits.

## Parity Mode Control (Bits 6, 7)

These bits determine the type of parity generated by the Transmitter, (even, odd, mark or space) and the type of parity check done by the Receiver (even, odd, or no check).

Reset Initialization

| 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |


| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Hardware reset ( $\overline{R E S}$ ) |  |  |  |  |  |  |  |



## NOTE

*The transmitter is disabled immediately. The receiver is disabled but will first complete receiving a byte in process of being received.
**A "BREAK" is transmitted only after the end of a character stream. If the Transmitter Data Register contains a character, the "BREAK" is not transmitted.

## STATUS REGISTER OPERATION

Because of the special functions of the various status bits, there is a suggested sequence for checking them. When an interrupt occurs, the ACIA should be interrogated, as follows:

1. Read Status Register

This operation automatically clears Bit 7 ( $\overline{\mathrm{IRQ}})$. Subsequent transitions on $\overline{\mathrm{DSR}}$ and $\overline{\mathrm{DCD}}$ will cause another interrupt.
2. Check $\overline{\mathrm{RQ}}$ (Bit 7) in the data read from the Status Register If not set, the interrupt source is not the ACIA.
3. Check $\overline{\mathrm{DCD}}$ and $\overline{\mathrm{DSR}}$

These must be compared to their previous levels, which must have been saved by the processor. If they are both 0 (modem "on-line") and they are unchanged, then the remaining bits must be checked.
4. Check RDRF (Bit 3)

Check for Receiver Data Register Full.
5. Check Parity, Overrun, and Framing Error (Bits 0-2) if the Receiver Data Register is full.
6. Check TDRE (Bit 4)

Check for Transmitter Data Register Empty.

## PROGRAM RESET OPERATION

A program Reset occurs when the processor performs a write operation to the ACIA with RSO low and RS1 high. The program

Reset operates somewhat differently from the hardware Reset ( $\overline{\mathrm{RES}} \mathrm{pin}$ ) and is described as follows:

1. Internal registers are not completely cleared. Check register formats for the effect of a program Reset on internal registers.
2. The $\overline{D T R}$ line goes high immediately.
3. Receiver and transmitter interrupts are disabled immediately. If $\overline{\mathrm{RQ}}$ is low when the reset occurs, it stays low until serviced, unless interrupt was caused by $\overline{D C D}$ or $\overline{D S R}$ transition.
4. $\overline{D C D}$ and $\overline{D S R}$ interrupts are disabled immediately. If $\overline{\operatorname{RQ}}$ is low and was caused by $\overline{D C D}$ or $\overline{D S R}$, then it goes high, also $\overline{\mathrm{DCD}}$ and $\overline{\mathrm{DSR}}$ status bits subsequently will follow the input lines, although no interrupt will occur.
5. Overrun cleared, if set.

## TRANSMITTER AND RECEIVER OPERATION

## Continuous Data Transmit

In the normal operating mode, the interrupt request output ( $\overline{\mathrm{RQQ}}$ ) signals when the ACIA is ready to accept the next data word to be transmitted. This interrupt occurs at the beginning of the Start Bit. When the processor reads the Status Register of the ACIA, the interrupt is cleared.

The processor must then identify that the Transmit Data Register is ready to be loaded and must then load it with the next data word. This must occur before the end of the Stop Bit, otherwise a continuous "MARK" will be transmitted. Figure 5 shows the continuous Data Transmit timing relationship.


Figure 5. Continuous Data Transmit

## Continuous Data Receive

Similar to the Continuous Data Transmit case, the normal operation of this mode is to assert $\overline{\mathrm{RQ}}$ when the ACIA has received a full data word. This occurs at about $9 / 16$ point through the Stop Bit. The processor must read the Status Register and
read the data word before the next interrupt, otherwise the Overrun condition occurs. Figure 6 shows the continuous Data Receive Timing Relationship.


Figure 6. Continuous Data Receive

## Transmit Data Register Not Loaded by Processor

If the processor is unable to load the Transmit Data Register in the allocated time, then the TXD line goes to the "MARK" condition until the data is loaded. $\overline{\mathrm{IRQ}}$ interrupts continue to occur at the same rate as previously, except no data is transmitted.

When the processor finally loads new data, a Start Bit immediately occurs, the data word transmission is started, and another interrupt is initiated, signaling for the next data word. Figure 7 shows the timing relationship for this mode of operation.


Figure 7. Transmit Data Register Not Loaded by Processor

## Effect of CTS on Transmitter

$\overline{\mathrm{CTS}}$ is the Clear-to-Send signal generated by the modem. It is normally low (true state) but may go high in the event of some modem problems. When this occurs, the TxD line goes to the "MARK" condition after the entire last character (including parity and stop bit) has been transmitted, unless CTS goes high during the start
bit. Then TxD goes immediately to a "MARK" condition. Bit 4 in the Status Register indicates that the Transmitter Data Register is not empty and $\overline{\mathrm{RQ}}$ is not asserted. $\overline{\mathrm{CTS}}$ is a transmit control line only, and has no effect on the ACIA Receiver Operation. Figure 8 shows the timing relationship for this mode of operation.


Figure 8. Effect of CTS on Transmitter

## Effect of Overrun on Receiver

If the processor does not read the Receiver Data Register in the allocated time, when the next interrupt occurs, the new data word is not transferred to the Receiver Data Register, but the Overrun
status bit is set. Thus, the Data Register will contain the last valid data word received and all following data is lost. Figure 9 shows the timing relationship for this mode.


Figure 9. Effect of Overrun on Receiver

## Echo Mode Timing

In Echo Mode, the TxD line re-transmits the data on the RxD line, delayed by $1 / 2$ of the bit time, as shown in Figure 10.


Figure 10. Echo Mode Timing

## Effect of CTS on Echo Mode Operation

In Echo Mode, the Receiver operation is unaffected by $\overline{\mathrm{CTS}}$, however, the Transmitter is affected when CTS goes high, i.e., the TXD line immediately goes to a continuous "MARK" condition. In this case, however, the Status Request indicates that
the Receiver Data Register is full in response to an $\overline{\mathrm{RQ}}$, so the processor has no way of knowing that the Transmitter has ceased to echo. See Figure 11 for the timing relationship of this mode.


Figure 11. Effect of $\overline{\text { CTS }}$ on Echo Mode

## Overrun in Echo Mode

If Overrun occurs in Echo Mode, the Receiver is affected the same way as a normal overrun in Receive Mode. For the retransmitted data, when overrun occurs, the TxD line goes to the
"MARK" condition until the first Start Bit after the Receiver Data Register is read by the processor. Figure 12 shows the timing relationship for this mode.


Figure 12. Overrun in Echo Mode

## Framing Error

Framing Error is caused by the absence of Stop Bit(s) on received data. A Framing Error is indicated by the setting of bit 1 in the Status Register at the same time the Receiver Data Register Full bit is set, also in the Status Register. In response to IRQ, generated by RDRF, the Status Register can also be
checked for the Framing Error. Subsequent data words are tested for Framing Error separately, so the status bit will always reflect the last data word received. See Figure 13 for Framing Error timing relationship.


Figure 13. Framing Error

## Effect of $\overline{\mathrm{DCD}}$ on Receiver

$\overline{D C D}$ is a modem output indicating the status of the carrier-fre-quency-detection circuit of the modem. This line goes high for a loss of carrier. Normally, when this occurs, the modem will stop transmitting data some time later. The ACIA asserts $\overline{\mathrm{IRQ}}$ whenever $\overline{D C D}$ changes state and indicates this condition via bit 5 in the Status Register.

Once such a change of state occurs, subsequent transitions will not cause interrupts or changes in the Status Register until the first interrupt is serviced. When the $\overline{\mathrm{DCD}}$ input is high, the receiver is disabled (see Figure 14).


Figure 14. Effect of $\overline{\mathrm{DCD}}$ on Receiver

## Timing with $11 / 2$ Stop Bits

It is possible to select $11 / 2$ Stop Bits, but this occurs only for 5 -bit data words with no parity bit. In this case, the $\overline{\mathrm{RQ}}$ asserted for Receiver Data Register Full occurs halfway through the
trailing half-Stop Bit. Figure 15 shows the timing relationship for this mode.


Figure 15. Timing with $11 / 2$ Stop Bits

## Transmit Continuous "BREAK"

This mode is selected via the ACIA Command Register and causes the Transmitter to send continuous "BREAK" characters, beginning with the next character transmitted. At least one full "BREAK" character will be transmitted, even if the processor quickly re-programs the Command Register transmit mode. Later, when the Command Register is programmed back to normal transmit mode, an immediate Stop Bit will be generated and transmission will resume. Figure 16 shows the timing relationship for this mode.

## NOTE

If, while operating in the Transmit Continuous "BREAK" mode, the CTS should go to a high, the TXD will be overridden by the CTS and will go to continuous "MARK" at the beginning of the next character transmitted after the $\overline{\text { CTS }}$ goes high.


Figure 16. Transmit Continuous "BREAK"

## Receive Continuous "BREAK"

In the event the modem transmits continuous "BREAK" char- shows the timing relationship for continuous "BREAK" acters, the ACIA will terminate receiving. Reception will resume only after a Stop Bit is encountered by the ACIA. Figure 17
characters.


Figure 17. Receive Continuous "BREAK"

## CRYSTAL/CLOCK CONSIDERATIONS

## CLOCK OSCILLATOR

The on-chip oscillator is designed for a parallel resonant crystal connected between XTLI and XTLO pins. The equivalent oscillator circuit is shown in Figure 18.


Figure 18. Internal Clock

A parallel resonant crystal is specified by its load capacitance and series resonant resistance. For proper oscillator operation, the load capacitance $\left(\mathrm{C}_{\mathrm{L}}\right)$, series resistance $\left(\mathrm{R}_{\mathrm{s}}\right)$ and the crystal resonant frequency ( F ) must meet the following two relations:

$$
\begin{gathered}
(C+2)=2 C_{L} \quad \text { or } C=2 C_{L}-2 \\
R_{S} \leq R_{s \max }=\frac{2 \times 10^{6}}{\left(F C_{L}\right)^{2}}
\end{gathered}
$$

where: $F$ is in $M H z ; C$ and $C_{L}$ are in $p F ; R$ is in ohms.

To select a parallel resonant crystal for the oscillator, first select the load capacitance from a crystal manufacturer's catalog. Next, calculate $\mathrm{R}_{\text {smax }}$ based on F and $\mathrm{C}_{\mathrm{L}}$. The selected crystal must have a $R_{s}$ less than the $R_{\text {smax }}$.

For example, if $C_{L}=13 \mathrm{pF}$ for a 1.8432 MHz parallel resonant crystal, then

$$
C=(2 \times 13)-2=18 \mathrm{pF}
$$

The series resistance of the crystal must be less than

$$
R_{s \operatorname{smax}}=\frac{2 \times 10^{6}}{(1.8432 \times 13)^{2}} \cong 3.3 \mathrm{~K} \text { ohms }
$$

## EXTERNAL CLOCK MODES

The XTLI input may be used as an external clock input (Figure 19). For this implementation, a times 16 clock is input on XTLI and XTLO is left open.


Figure 19. External Clock

## GENERATION OF NON-STANDARD BAUD RATES

## Divisors

The internal counter/divider circuit generates appropriate divisors to produce standard baud rates when a 1.8432 MHz crystal is connected between XTLI and XTLO. Control Register bits $0-3$ select the divisor for a particular baud rate as shown in Table 2.

## Generating Non-Standard Baud Rates

By using a different crystal, non-standard baud rates may be generated. These can be determined by:

$$
\text { Baud Rate }=\frac{\text { Crystal Frequency }}{\text { Divisor }}
$$

Furthermore, it is possible to drive the ACIA with an off-chip oscillator to achieve other baud rates. In this case, XTALI (pin 6) must be the clock input and XTALO (pin 7) must be a no-connect.

Table 2. Divisor Selection

| Control Register Bits |  |  |  | Divisor Selected For The Internal Counter | Baud Rate Generated With 1.8432 MHz Crystal | Baud Rate Generated With a Crystal of Frequency (F) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 3 | 2 | 1 | 0 |  |  |  |
| 0 | 0 | 0 | 0 | 16 | External Transmitter Clock Rate $\div 16$ | External Transmitter Clock Rate $\div 16$ |
| 0 | 0 | 0 | 1 | 36,864 | $\frac{1.8432 \times 10^{6}}{36,864}=50$ | $\frac{F}{36,864}$ |
| 0 | 0 | 1 | 0 | 24,576 | $\frac{1.8432 \times 10^{6}}{24,576}=75$ | $\frac{F}{24,576}$ |
| 0 | 0 | 1 | 1 | 16,769 | $\frac{1.8432 \times 10^{6}}{16,769}=109.92$ | $\frac{F}{16,769}$ |
| 0 | 1 | 0 | 0 | 13,704 | $\frac{1.8432 \times 10^{6}}{13,704}=134.51$ | $\frac{F}{13,704}$ |
| 0 | 1 | 0 | 1 | 12,288 | $\frac{1.8432 \times 10^{6}}{12,288}=150$ | $\frac{F}{12,288}$ |
| 0 | 1 | 1 | 0 | 6,144 | $\frac{1.8432 \times 10^{6}}{6,144}=300$ | $\frac{F}{6,144}$ |
| 0 | 1 | 1 | 1 | 3,072 | $\frac{1.8432 \times 10^{6}}{3,072}=600$ | $\frac{F}{3,072}$ |
| 1 | 0 | 0 | 0 | 1,536 | $\frac{1.8432 \times 10^{6}}{1,536}=1,200$ | $\frac{F}{1,536}$ |
| 1 | 0 | 0 | 1 | 1,024 | $\frac{1.8432 \times 10^{6}}{1,024}=1,800$ | $\frac{F}{1,024}$ |
| 1 | 0 | 1 | 0 | 768 | $\frac{1.8432 \times 10^{6}}{768}=2,400$ | $\frac{F}{768}$ |
| 1 | 0 | 1 | 1 | 512 | $\frac{1.8432 \times 10^{6}}{512}=3,600$ | $\begin{gathered} \hline F \\ \hline 512 \\ \hline \end{gathered}$ |
| 1 | 1 | 0 | 0 | 384 | $\frac{1.8432 \times 10^{6}}{384}=4,800$ | $\frac{F}{384}$ |
| 1 | 1 | 0 | 1 | 256 | $\frac{1.8432 \times 10^{6}}{256}=7,200$ | $\frac{F}{256}$ |
| 1 | 1 | 1 | 0 | 192 | $\frac{1.8432 \times 10^{6}}{192}=9,600$ | $\frac{F}{192}$ |
| 1 | 1 | 1 | 1 | 96 | $\frac{1.8432 \times 10^{6}}{96}=19,200$ | $\frac{F}{96}$ |

## DIAGNOSTIC LOOP-BACK OPERATING MODES

It may be desirable to include in the system a facility for local loop-back testing.

In local loop-back testing, the Modem and Data Link must be effectively disconnected and the ACIA transmitter connected back to its own receiver, so that the processor can perform diagnostic checks on the system, excluding the actual data channel.

The ACIA does not contain automatic loop-back operating modes, but they may be implemented with the addition of a small amount of external circuitry. Figure 20 indicates the necessary logic to be used with the ACIA. The LLB line is the positive-true signal to enable local loop-back operation. Essentially, LLB = high does the following:

1. Disables outputs TxD, $\overline{\mathrm{DTR}}$, and $\overline{\mathrm{RTS}}$ (to Modem).
2. Disables inputs RxD, $\overline{\mathrm{DCD}}, \overline{\mathrm{CTS}}, \overline{\mathrm{DSR}}$ (from Modem).
3. Connects transmitter outputs to respective received inputs (i.e., TxD to RxD, $\overline{D T R}$ to $\overline{D C D}, \overline{R T S}$ to $\overline{C T S}$ ).

LLB may be tied to a peripheral control pin (from an R65C21 or R65C24, for example) to provide processor control of local loop-back operation. In this way, the processor can easily perform local loop-back diagnostic testing.

## MISCELLANEOUS

1. If Echo Mode is selected, $\overline{\mathrm{RTS}}$ goes low.
2. If Bit 0 of Command Register ( $\overline{\text { DTR }}$ ) is 0 (disabled), then:
a) All interrupts are disabled, including those caused by $\overline{\mathrm{DCD}}$ and $\overline{\text { DSR }}$ transitions.
b) Transmitter is disabled immediately.
c) Receiver is disabled, but a character currently being received will be completed first.
3. Odd parity occurs when the sum of all the 1 bits in the data word (including the parity bit) is odd.
4. In the receive mode, the received parity bit does not go into the Receiver Data Register, but generates parity error or no parity error for the Status Register.
5. Transmitter and Receiver may be in full operation simultaneously. This is "full-duplex" mode.


NOTES: 1. HIGH ON LLB SELECTS LOCAL LOOP-bACK MODE.
2. HIGH ON 74157 SELECT INPUT GATES "B" INPUTS TO " Y " OUTPUTS; LOW GATES " $A$ " TO " $Y$ ".

Figure 20. Loop-Back Circuit Schematic
6. If the RxD line inadvertently goes low and then high right after a Stop Bit, the ACIA does not interpret this as a Start Bit, but samples the line again halfway into the bit time to determine if it is a true Start Bit or a false one. For false Start Bit detection, the ACIA does not begin to receive data, instead, only a true Start Bit initiates receiver operation.
7. $\overline{D C D}$ and $\overline{D S R}$ transitions, although causing immediate processor interrupts, have no affect on transmitter operation. Data will continue to be sent, unless the processor forces the transmitter to turn off. Since these are high-impedance inputs, they must not be permitted to float (un-connected). If unused, they must be tied to GND.
8. If TDRE is checked by polling (rather than by interrupt), a period of at least $1 / 16$ Baud clock should be allowed after loading Tx Data Buffer to ensure that TDRE is valid.

## READ TIMING DIAGRAM

Timing diagrams for transmit with external clock, receive with external clock, and $\overline{\mathrm{RQ}}$ generation are shown in Figures 21, 22 and 23, respectively. The corresponding timing characteristics are listed in Table 3.

Table 3. Transmit/Receive Characteristics

| Characteristic | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Transmit/Receive Clock Rate | $\mathrm{t}_{\mathrm{CCY}}$ | 400* | - | 400* | - | ns |
| Transmit/Receive Clock High Time | $\mathrm{t}_{\mathrm{CH}}$ | 175 | - | 175 | - | ns |
| Transmit/Receive Clock Low Time | $\mathrm{t}_{\mathrm{CL}}$ | 175 | - | 175 | - | ns |
| XTLI to TxD Propagation Delay | $t_{D D}$ | - | 500 | - | 500 | ns |
| $\overline{\text { RTS }}, \overline{\text { DTR }}$ <br> Propagation Delay | ${ }^{\text {D DLY }}$ | - | 500 | - | 500 | ns |
| $\overline{\mathrm{IRQ}}$ Propagation Delay (Clear) | $\mathrm{t}_{\text {IRQ }}$ | - | 500 | - | 500 | ns |
| Notes:$\left(\mathrm{t}_{\mathrm{R}}, \mathrm{t}_{\mathrm{F}}=10 \text { to } 30 \mathrm{~ns}\right)$ |  |  |  |  |  | $\mathrm{t}_{\mathrm{CCY}}$ |



Figure 21. Transmit Timing with External Clock


Figure 22. Receive External Clock Timing


Figure 23. Interrupt and Output Timing

SWITCHING CHARACTERISTICS
$\left(V_{C C}=5.0 \mathrm{Vdc} \pm 5 \%, V_{S S}=0, T_{A}=T_{L}\right.$ to $T_{H}$, unless otherwise noted)

| Parameter | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Q2 Cycle Time | $\mathrm{t}_{\mathrm{CYC}}$ | 1000 | - | 500 | - | ns |
| ¢2 Pulse Width | $t_{C}$ | 400 | - | 200 | - | ns |
| Address Set-Up Time | $t_{\text {ACW }}, t_{\text {ACR }}$ | 120 | - | 60 | - | ns |
| Address Hold Time | $t_{\text {CAH, }}, t_{\text {CAR }}$ | 0 | - | 0 | - | ns |
| R/ $\bar{W}$ Set-Up Time | $t_{\text {WCW }}, t_{\text {WCR }}$ | 120 | - | 60 | - | ns |
| R/ $\bar{W}$ Hold Time | $\mathrm{t}_{\text {CWH }}$ | 0 | - | 0 | - | ns |
| Data Bus Set-Up Time | $\mathrm{t}_{\mathrm{DCW}}$ | 150 | - | 60 | - | ns |
| Data Bus Hold Time | $t_{\text {HW }}$ | 20 | - | 10 | - | ns |
| Read Access Time (Valid Data) | $\mathrm{t}_{\mathrm{CDR}}$ | - | 200 | - | 170 | ns |
| Read Hold Time | $t_{\text {HR }}$ | 20 | - | 10 | - | ns |
| Bus Active Time (Invalid Data) | $\mathrm{t}_{\text {CDA }}$ | 40 | 一 | 20 | - | ns |

## Notes:

1. $t_{R}$ and $t_{F}=10$ to 30 ns .
2. Timing measurements are referenced to/from a low of 0.8 volts and a high of 2.0 volts.


Write Timing Diagram


Read Timing Diagram

## ABSOLUTE MAXIMUM RATINGS*

| Parameter | Symbol | Value | Unit |
| :--- | :--- | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | Vdc |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | -0.3 to $\mathrm{V}_{\mathrm{CC}}+0.3$ | Vdc |
| Output Voltage | $\mathrm{V}_{\mathrm{OUT}}$ | -0.3 to $\mathrm{V}_{\mathrm{CC}}+0.3$ | Vdc |
| Operating Temperature <br> Commercial | $\mathrm{T}_{\mathrm{A}}$ | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\mathrm{STG}}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

## OPERATING CONDITIONS

| Parameter | Symbol | Value |
| :--- | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $5 \mathrm{Vdc} \pm 5 \%$ |
| Temperature Range <br> Commercial | $\mathrm{T}_{\mathrm{A}}$ | $\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$ <br> $0^{\circ}$ to $70^{\circ} \mathrm{C}$ c |

*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## ELECTRICAL CHARACTERISTICS

$\left(V_{C C}=5.0 \mathrm{Vdc} \pm 5 \%, V_{S S}=0, T_{A}=T_{L}\right.$ to $T_{H}$, unless otherwise noted $)$

| Parameter | Symbol | Min | Typ | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage Except XTLI XTLI | $\mathrm{V}_{\mathrm{IH}}$ | $\begin{aligned} & 2.0 \\ & 2.8 \end{aligned}$ | - | $\begin{aligned} & V_{c c} \\ & v_{c c} \end{aligned}$ | V |  |
| Input Low Voltage Except XTLI XTLI | $\mathrm{V}_{\mathrm{IL}}$ | $\begin{aligned} & -0.3 \\ & -0.3 \end{aligned}$ | - | $\begin{aligned} & +0.8 \\ & +0.4 \end{aligned}$ | V |  |
| Input Leakage Current: <br> $\emptyset 2, \mathrm{R} / \overline{\mathrm{W}}, \overline{\mathrm{RES}}, \mathrm{CSO}, \overline{\mathrm{CS} 1}, \mathrm{RSO}, \mathrm{RS} 1, \overline{\mathrm{CTS}}, \mathrm{R} \times \mathrm{D}, \overline{\mathrm{DCD}}, \overline{\mathrm{DSR}}$ | $\mathrm{I}_{\mathrm{N}}$ | - | $\pm 1$ | $\pm 2.5$ | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=0 \mathrm{~V} \text { to } \mathrm{V}_{\mathrm{CC}} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Input Leakage Current (Three State Off) D0-D7 | ${ }^{\text {TSI }}$ | - | $\pm 2$ | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\text {IN }}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Output High Voltage: D0-D7, TxD, RxC, $\overline{R T S}, \overline{D T R}$ | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 | - | - | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A} \end{aligned}$ |
| Output Low Voltage: D0-D7, TxD, RxC, $\overline{\mathrm{RTS}}, \overline{\mathrm{DTR}}, \overline{\mathrm{RQ}}$ | $\mathrm{V}_{\mathrm{OL}}$ | - | - | 0.4 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA} \end{aligned}$ |
| Output High Current (Sourcing): D0-D7, TxD, RxC, RTS, DTR | ${ }^{1} \mathrm{OH}$ | -100 | -400 | - | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ |
| Output Low Current (Sinking): D0-D7, TxD, RxC, $\overline{\mathrm{RTS}}, \overline{\mathrm{DTR}}, \overline{\mathrm{IRQ}}$ | Iol | 1.6 | - | - | mA | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| Output Leakage Current (off state): $\overline{\mathrm{IRQ}}$ | Ioff | - | - | 10 | ${ }_{\mu} \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=5.0 \mathrm{~V}$ |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | - | 7 | 10 | $\mathrm{mW} / \mathrm{MHz}$ |  |
| Input Capacitance ф2 All except $\emptyset 2$ | $\begin{aligned} & \mathrm{C}_{\mathrm{CLK}} \\ & \mathrm{C}_{\text {IN }} \end{aligned}$ | - | - | $\begin{aligned} & 20 \\ & 10 \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V} \\ & V_{I N}=0 \mathrm{~V} \\ & f=2 \mathrm{MHz} \\ & T_{A}=25^{\circ} \mathrm{C} \end{aligned}$ |
| Output Capacitance | Cout | - | - | 10 | pF |  |

## Notes:

1. All units are direct current (dc) except for capacitance.
2. Negative sign indicates outward current flow, positive indicates inward flow.
3. Typical values are shown for $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{TA}=25^{\circ} \mathrm{C}$.

## PACKAGE DIMENSIONS

| 28-PIN CERAMIC DIP |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $28 \quad \square \quad 15$ |  | MILLIMETERS |  | INCHES |  |
|  | DIM | MIN | MAX | MIN | MAX |
| B | A | 35.05 | 3607 | 1.380 | 1.420 |
| - | B | 15.11 | 15.88 | 0595 | 0625 |
| $\square-14$ | C | 2.54 | 4.19 | 0.100 | 0.165 |
|  | D | 0.38 | 0.53 | 0.015 | 0021 |
| $\longrightarrow$ - | F | 0.76 | 1.27 | 0.030 | 0050 |
| F | G | 2.54 BSC |  | 0.100 BSC |  |
|  | H | 0.76 | 1.78 | 0.030 0.070 |  |
| TH $\longrightarrow \square$ | J |  | 0.33 | 0.008 | 0.013 |
|  | K | 2.54 | 4.19 | 0.100 | 0.165 |
|  | L | 14.60 | 15.37 | 0.575 | 0605 |
|  | M | $0^{\circ}$ | $10^{\circ}$ | $0^{\circ}$ | $10^{\circ}$ |
|  | N | 0.51 | 1.52 | 0.020 | 0.060 |
| 28-PIN PLASTIC DIP |  |  |  |  |  |
|  | DIM | MIN | MAX | MIN | MAX |
| 28, | A | 36.32 | 37.34 | 1.430 | 1.470 |
| - B | B | 1346 | 13.97 | 0.530 | 0.550 |
| $1{ }^{2}$ | c | 3.56 | 508 | 0.140 | 0.200 |
| 1.14 | D | 0.38 | 0.53 | 0.015 | 0.021 |
|  | F | 1.02 | 1.52 | 0.040 | 0.060 |
| $\longrightarrow A \longrightarrow$ | G | 2.54 BSC |  | 0.100 BSC |  |
|  | H | 1.65 | 2.16 | 0.065 | 0.085 |
|  | J | 0.20 | 0.30 | 0.008 | 0.012 |
|  | K | 3.30 | 4.32 | 0.130 | 0.170 |
|  | L | 15.24 BSC |  | 0.600 BSC |  |
| $\rightarrow+G\|\rightarrow\| \rightarrow F \rightarrow D \quad K \rightarrow M$ | M | $7^{\circ}$ <br> 0.51 | $10^{\circ}$ | $7^{70}$ | $10^{\circ}$ |
|  | N |  | 1.02 |  | 0.040 |

## 28-PIN PLASTIC LEADED CHIP CARRIER (PLCC)



## PRELIMINARY

## DESCRIPTION

The Rockwell CMOS R65C52 Dual Asynchronous Communications Interface Adapter (DACIA) provides an easily implemented, program controlled two-channel interface between 8 -bit microprocessor-based systems and serial communication data sets and modems.

The DACIA is designed for maximum programmed control from the microprocessor (MPU) to simplify hardware implementation. Dual sets of registers allow independent control and monitoring of each channel.

Transmitter and Receiver bit rates may be controlled by an internal baud rate generator or external times 16 clocks. The baud rate generator accepts either a crystal or a clock input, and provides 15 programmable baud rates. When a 3.6864 MHz crystal is used, the baud rates range from 50 bps to $38,400 \mathrm{bps}$.

The DACIA may be programmed to transmit and receive frames having word lengths of 5, 6, 7 or 8 bits; even, odd, space, mark or no parity; and 1 or 2 stop bits.

A Compare Register, and the ability to detect address frames, facilitate address recognition in a multidrop mode.

## FEATURES

- Low power CMOS N-well silicon gate technology
- Two independent full duplex channels with buffered receivers and transmitters.
- Data set/modem control functions
- Internal baud rate generator with 15 programmable baud rates ( 50 bps to $38,400 \mathrm{bps}$ )
- Program-selectable internally or externally controlled receiver and transmitter bit rates
- Programmable word lengths, number of stop bits, and parity bit generation and detection
- Programmable interrupt control
- Edge detect for $\overline{D C D}, \overline{D S R}$, and $\overline{C T S}$
- Program-selectable echo mode for each channel
- Compare Register
- Address/Data frame recognition
- $5.0 \mathrm{Vdc} \pm 5 \%$ supply requirements
- 40-pin plastic or ceramic DIP or 44-pin PLCC
- Full TTL or CMOS input/output compatibility
- Compatible with R6500 and R65C00 microprocessors and R6500/* microcomputers


## ORDERING INFORMATION

## Part Number:

R65C52

Temperature Range ( $T_{L}$ to $T_{H}$ ): Blank $=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
$E=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

Frequency Range:
$1=1 \mathrm{MHz}$
$2=2 \mathrm{MHz}$
$3=3 \mathrm{MHz}$
Package
$C=40-$ Pin Ceramic DIP
$P=40-$ Pin Plastic DIP
$J=44-$ Pin Plastic Leaded
Chip Carrier (PLCC)

## INTERFACE SIGNALS

The DACIA is available in a 40-pin DIP or a 44 -pin PLCC. Figure 1 shows the pin assignments for each package. The DACIA interface signals are shown in Figure 2. Table 1 contains a description of each signal.

| $\overline{\text { RES }}$ | 1 | 40 | $\mathrm{V}_{\mathrm{cc}}$ |
| :---: | :---: | :---: | :---: |
| NC | 2 | 39 | $\square \overline{\mathrm{cs}}$ |
| Xtall | 3 | 38 | R/ $\bar{W}$ |
| Xtalo | 4 | 37 | RS2 |
| CLK OUT | 5 | 36 | RS1 |
| NC | 6 | 35 | RSo |
| $\overline{\text { DSR2 }}$ | 7 | 34 | NC |
| $\overline{\text { DCD2 }}$ | 8 | 33 | $\overline{\text { DSR1 }}$ |
| CTS2 | 9 | 32 | $\overline{\text { DCD1 }}$ |
| $\overline{\text { RTS2 }}$ | 10 | 31 | CTS1 |
| $\overline{\text { RQ2 }}$ | 11 | 30 | - $\overline{\text { RTS }}$ |
| RxD2 | 12 | 29 | $\overline{\mathrm{IRQ1}}$ |
| $\overline{\text { DTR2 }}$ | 13 | 28 | $\square \mathrm{RxD1}$ |
| TxD2 | 14 | 27 | $\square \overline{\text { DTR1 }}$ |
| TxC | 15 | 26 | $\square \mathrm{TXD1}$ |
| D7 | 16 | 25 | $\square \mathrm{RxC}$ |
| D6 | 17 | 24 | $\square \mathrm{DO}$ |
| D5 | 18 | 23 | $\square \mathrm{D}_{1}$ |
| D4 | 19 | 22 | $\square \mathrm{D} 2$ |
| $\mathrm{v}_{\text {ss }}$ | 20 | 21 | D3 |

40-PIN DIP


44-PIN PLCC

NC = NO CONNECTION. NO SIGNAL SHOULD BE CONNECTED TO THIS PIN.

Figure 1. R65C52 Pin Assignments


Figure 2. R65C52 DACIA Interface Signals

Table 1. DACIA Interface Signal Definitions

| Signal | Pin No. |  | 1/0 | Name/Description |
| :---: | :---: | :---: | :---: | :---: |
|  | DIP | PLCC |  |  |
| Host Interface |  |  |  |  |
| $\overline{\text { RES }}$ | 1 | 24 | 1 | Reset. Active low input controlling the reset function. This signal must be driven low for a minimum of $4 \mu \mathrm{~s}$ for a valid reset to occur. It is driven high during normal operation. |
| $\mathrm{R} / \overline{\mathrm{W}}$ | 38 | 20 | 1 | Read/Write. Input controlling the direction of data transfer. It is driven low during write cycles, and is driven high at all other times. |
| $\overline{\mathrm{CS}}$ | 39 | 21 | 1 | Chip Select. Active low input enabling data transfers between the host CPU and the DACIA. The DACIA latches register selects and the R/ $\bar{W}$ input on the falling edge of $\overline{C S}$. It latches input data on the rising edge of $\overline{\mathrm{CS}}$. |
| RS0-RS3 | 35-37 | 17-19 | 1 | Register Select. Three inputs controlling access to the DACIA internal registers. Table 3 lists the coding for each register. |
| D0-D3 | 24-21 | $6-3$ | 1/0 | Data Bus. Eight bidirectional lines used to transfer data between the host and the DACIA. These lines |
| D4-D7 | $19-16$ | $44-41$ |  | output data during READ cycles when $\overline{\mathrm{CS}}$ is low. At all other times, they are in the high impedance state. |
| $\frac{\overline{\operatorname{IRQ1}}}{\frac{1 R Q 2}{2}}$ | $\begin{aligned} & 29 \\ & 11 \end{aligned}$ | $\begin{aligned} & 11 \\ & 35 \end{aligned}$ | 0 | Interrupt Request. Two active low, open-drain outputs from the interrupt control logic. These outputs are normally high. An IRQ line goes low when one of the flags of the associated ISR is set if the corresponding enable bit is set in the IER. |
| Clock Interface |  |  |  |  |
| XTALI <br> XTALO | 3 4 | 26 | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | Crystal Input/Output. One input and one output through which the reference signal for the internal clock oscillator is supplied. A parallel resonant crystal may be connected across the pins or a clock may be input at XTALI. When a clock is used, XTALO must be left open. |
| CLK OUT | 5 | 29 | 0 | Clock Out. A buffered output from the internal clock oscillator which is in phase with XTALI. This output may be used to drive the XTALI input of another DACIA. Therefore, several DACIA chips may be driven with one crystal. |
| RxC | 25 | 7 | 1 | Receiver Clock. Input for external 16x receiver clock. |
| TxC | 15 | 39 | 1 | Transmitter Clock. Input for external 16x transmitter clock. |
| Serial Channel Interface |  |  |  |  |
| $\overline{\overline{\text { DTR1 }} \text { DTR2 }}$ | 27 13 | 9 37 | 0 | Data Terminal Ready. Two general purpose outputs which are set high upon reset. The output level is programmed by setting the appropriate bit in the associated Format Register (FR) high or low. The state of each DTR line is reflected by the DTR LVL bit in the associated Control Status Register (CSR). |
| $\overline{\overline{\text { DSR1 }}}$ | 33 7 | 15 31 | 1 | Data Set Ready. Two general purpose inputs. An active transition sets the $\overline{\mathrm{DSR}} \mathrm{T}$ bit in the Interrupt Enable Register (ISR). The $\overline{\mathrm{DSR}}$ LVL bit in the associated CSR reflects the current state of a $\overline{\mathrm{DSR}}$ line. |
| $\overline{\overline{\text { RTS1 }}}$ | 30 10 | 12 34 | 0 | Request To Send. Two general purpose outputs which are set high upon reset. The output level is programmed by setting the appropriate bit in the associated FR high or low. The state of an RTS line is reflected by the $\overline{\mathrm{RTS}}$ LVL bit in the associated CSR. |
| $\overline{\overline{\text { CTS } 1}}$ | 31 9 | 13 33 | 1 | Clear To Send. The $\overline{\mathrm{CTS}}$ control line inputs allow handshaking by the transmitters. When $\overline{\mathrm{CTS}}$ is low, the data is transmitted continuously. When CTS is high, the Transmit Data Register Empty bit (TDRE) in the associated ISR is not set. The word presently in the Transmit Shift Register is sent normally. Any active transition on a $\overline{\mathrm{CTS}}$ line sets the $\overline{\mathrm{CTS}} \mathrm{T}$ bit in the appropriate ISR. The $\overline{\mathrm{CTS}}$ LVL bit in the associated CSR reflects the current state of $\overline{C T S}$. |
| $\begin{aligned} & \text { TxD1 } \\ & \text { TxD2 } \end{aligned}$ | 26 14 | 8 38 | 0 | Transmit Data. The TxD outputs transfer serial non-return to zero (NRZ) data to the data communications equipment (DCE). The data is transferred, LSB first, at a rate determined by the baud rate generator or external clock. |
| $\overline{\overline{D C D 1 ~}}$ | 32 8 | 14 32 | 1 | Data Carrier Detect. Two general purpose inputs. An active transition sets the $\overline{\mathrm{DCD}} \mathrm{T}$ bit in the appropriate ISR. The $\overline{\mathrm{DCD}}$ LVL bit in the associated CSR reflects the current state of a $\overline{\mathrm{DCD}}$ line. |
| $\begin{aligned} & \text { RxD1 } \\ & \text { RxD2 } \end{aligned}$ | $\begin{aligned} & 28 \\ & 12 \end{aligned}$ | 10 36 | 1 | Receive Data. The RxD inputs transfer serial NRZ data into the DACIA from the DCE, LSB first. The receiver baud rate is determined by the baud rate generator or external clock. |
| Power |  |  |  |  |
| VCC VSS | 40 20 | 22 1 | 1 | DC Power Input. 5.0V $\pm 5 \%$. <br> Power and Signal Reference. |

## FUNCTIONAL DESCRIPTION

Figure 3 is a block diagram of the DACIA which consists of two asynchronous communications interface adapters with common microprocessor interface control logic and data bus buffers. The individual functional elements of the DACIA are described in the following paragraphs.

## RESET LOGIC

The Reset Logic sets various internal registers, status bits and control lines to a known state. The $\overline{\mathrm{RES}}$ input must be driven low for a minimum of $4 \mu \mathrm{~s}$ for a valid reset to occur. At this time, the IERs are set to $\$ 80$, the RDRs and ACRs are cleared, and the compare mode is disabled. Also, the $\overline{\text { DTR }}$ and $\overline{\text { RTS }}$ outputs are driven high and the $\overline{C T S}, \overline{D C D}$ and $\overline{\mathrm{DSR}}$ transition detect flags are cleared. No other bits are affected.

## DATA BUS BUFFER

The Data Bus Buffer is a bidirectional interface between the data lines and the internal data bus. The state of the Data Bus Buffer is controlled by the I/O Control Logic and the Interrupt Logic. Table 2 summarizes the Data Bus Buffer states.

## I/O CONTROL LOGIC

The I/O Control Logic controls data transfers between the Internal Registers and the Data Bus Buffer. Internal Register selection is determined by the Register Select inputs as shown in Table 3. When $R / \bar{W}$ is high and $\overline{C S}$ is low, data from the selected register
is transferred from the internal data bus to the data lines. When $\overline{\mathrm{CS}}$ is high, the DACIA is deselected and the data lines are tri-stated.

## INTERRUPT LOGIC

The interrupt logic causes the $\overline{\mathrm{RQ}}$ lines ( $\overline{\mathrm{RQ} 1}$ or $\overline{\mathrm{RQ} 2}$ ) to go low when conditions are met that require the attention of the MPU. There are two registers (the Interrupt Enable Register and the Interrupt Status Register) involved in the control of interrupts in the DACIA. Corresponding bits in both registers must be set to cause an $\overline{\mathrm{R} Q}$.

## CLOCK OSCILLATOR LOGIC

The internal clock oscillator supplies the time base for the baud rate generator. The oscillator can be driven by a crystal or an external clock.

The baud rate generator may be disabled by connecting XTALI to ground and leaving XTALO open. When this is done, a transmitter times 16 clock must be input at TxC, a receiver times 16 clock must be input at RxC and the Control Registers must be programmed to select TxC and RxC clocks.

Table 2. Data Bus Buffer Summary

| Control Signals |  |  |
| :---: | :---: | :--- |
| R/W | $\overline{\text { CS }}$ | Data Bus Buffer State |
| L | L | Write Mode - Tri-State |
| H | L | Read Mode - Output Data |
| X | H | Deselected - Tri State |



Figure 3. DACIA Block Diagram

Table 3. DACIA Register Selection

| Register Select Lines |  |  |  | Register Accessed |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Write |  | Read |  |
| HEX | RS2 | RS1 | RSO | Symbol | Name | Symbol | Name |
| 0 | L | L | L | IER1 | Interrupt Enable Register 1 | ISR1 | Interrupt Status Register 1 |
| 1 | L | L | H | CR1 | Control Register 11 | CSR1 | Control Status Register 1 |
|  |  |  |  | FR1 | Format Register $1^{2}$ |  |  |
| 2 | L | H | L | CDR1 | Compare Data Register ${ }^{13}$ |  | Not Used |
|  |  |  |  | ACR1 | Auxiliary Control Register ${ }^{14}$ |  |  |
| 3 | L | H | H | TDR1 | Transmit Data Register 1 | RDR1 | Receive Data Register 1 |
| 4 | H | L | L | IER2 | Interrupt Enable Register 2 | ISR2 | Interrupt Status Register 2 |
| 5 | H | L | H | CR2 | Control Register $2^{1}$ | CSR2 | Control Status Register 2 |
|  |  |  |  | FR2 | Format Register $2^{2}$ |  |  |
| 6 | H | H | L | CDR2 | Compare Data Register $2^{3}$ |  | Not Used |
|  |  |  |  | ACR2 | Auxiliary Control Register ${ }^{24}$ |  |  |
| 7 | H | H | H | TDR2 | Transmit Data Register 2 | RDR2 | Receive Data Register 2 |
| Notes: <br> 1. D7 must be set low to write to the Control Registers. <br> 2. D7 must be set high to write to the Format Registers. <br> 3. Control Register bit 6 must be set to 0 to access the Compare Register. <br> 4. Control Register bit 6 must be set to 1 to access the Auxiliary Control Register. |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |

## SERIAL DATA CHANNELS

Two independent serial data channels are available for the full duplex (simultaneous transmit and receive) transfer of asynchronous frames. Separate internal registers are provided for each channel for the selection of frame parameters (number of bits per character, parity options, etc.), status flags, interrupt control and handshake. The asynchronous frame format is shown in Figure 4.

Transmit data from the host system is loaded into the Transmit Data Register. From there, it is transferred to the Transmit Shift Register where it is shifted, LSB first, onto the TXD line. All transmissions begin with a start bit and end with the user selected number of stop bits. A parity bit is transmitted before the stop bit(s) if parity is enabled.

Receive data is shifted into the Receive Shift Register from the associated RxD line. Start and stop bits are stripped from the frame and the data is transferred to the Receive Data Register. Parity bits may be discarded or stored in the ISR.

Five I/O lines are provided for each channel for handshake with the data communications equipment (DCE). Four of these signals ( $\overline{\mathrm{RTS}}, \overline{\mathrm{DTR}}, \overline{\mathrm{DSR}}$ and $\overline{\mathrm{DCD}}$ ) are general purpose inputs or outputs. The fifth signal, CTS, enables/disables the transmitter. When CTS
is high and the Transmit Shift Register is empty, the transmitter (except for Echo Mode) is inhibited. When CTS is low, the transmitter is enabled.


Figure 4. Asynchronous Frame Format

## INTERNAL REGISTERS

The DACIA contains ten control registers and four status registers in addition to the transmit and receive registers. The Control Registers provide for control of frame parameters, baud rate, interrupt generation, handshake lines, transmission and reception. The status registers provide status information on transmit and receive registers, error conditions and interrupt sources. Table 4 summarizes the bit definitions of these registers. A detailed description follows.

Table 4. Register Formats

| Register Select (Hex) | Register | $\mathrm{R} / \overline{\mathrm{W}}$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | $\begin{gathered} \text { Reset } \\ \text { Value } \\ 76543210 \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 0 \\ & 4 \end{aligned}$ | ISR1 ISR2 | R | ANY BIT SET | TDRE | $\overline{\text { CTST }}$ | $\overline{\text { DCDT }}$ | $\overline{\text { DSRT }}$ | PAR | F/O/B | RDRF | 1-00000 - |
| $\begin{aligned} & 0 \\ & 4 \end{aligned}$ | IER1 IER2 | w | $\begin{array}{\|c\|} \hline \text { CLR/SET } \\ \text { BITS } \end{array}$ | TDRE IE | $\begin{aligned} & \hline \overline{\text { CTST }} \\ & \text { IE } \end{aligned}$ | $\overline{\overline{D C D}}$ IE | $\overline{\mathrm{DSR}} \mathrm{T}$ IE | $\begin{aligned} & \text { PAR } \\ & \text { IE } \end{aligned}$ | F/O/B IE | $\begin{gathered} \text { RDRF } \\ \text { IE } \\ \hline \end{gathered}$ | - 0000000 |
| $\begin{aligned} & 1 \\ & 5 \end{aligned}$ | $\begin{aligned} & \text { CSR1 } \\ & \text { CSR2 } \end{aligned}$ | R | FE | TUR | CTS LVL | $\begin{aligned} & \overline{\mathrm{DCD}} \\ & \mathrm{LVL} \end{aligned}$ | $\overline{\text { DSR }}$ | BRK | ¢ $\overline{\text { DTR }}$ | $\begin{aligned} & \overline{\overline{\text { RTS }}} \\ & \text { LVL } \end{aligned}$ | 1-... 011 |
| $\begin{aligned} & 1 \\ & 5 \end{aligned}$ | $\begin{aligned} & \text { CR1 } \\ & \text { CR2 } \end{aligned}$ | w | 0 | $\begin{aligned} & \hline \mathrm{CDR} / \\ & \mathrm{ACR} \end{aligned}$ | $\begin{aligned} & \text { STOP } \\ & \text { BITS } \end{aligned}$ | ECHO |  | BIT | E SEL |  | 0-...... |
| $\begin{aligned} & 1 \\ & 5 \end{aligned}$ | $\begin{aligned} & \text { FR1 } \\ & \text { FR2 } \end{aligned}$ | w | 1 | DAT | ITS |  |  | $\begin{aligned} & \text { PAR } \\ & \text { EN } \end{aligned}$ | $\begin{aligned} & \overline{\text { DTR }} \\ & \text { CNTL } \end{aligned}$ | $\begin{aligned} & \hline \overline{\text { RTS }} \\ & \text { CNTL } \end{aligned}$ | 1---.... |
| $\begin{aligned} & 2 \\ & 6 \end{aligned}$ | CDR1 CDR2 | $\begin{gathered} W \\ (C R 6=0) \end{gathered}$ |  |  |  | COMPA | DATA |  |  |  | ------. |
| $\begin{aligned} & 2 \\ & 6 \end{aligned}$ | ACR1 ARC2 | $\begin{gathered} W \\ (C R 6=1) \end{gathered}$ |  |  |  |  |  |  | TRNS BRK | $\begin{gathered} \text { PAR } \\ \text { ERR/ST } \end{gathered}$ | - 00 |
| $\begin{aligned} & 3 \\ & 7 \end{aligned}$ | RDR1 RDR2 | R |  |  |  | EIVE D | REGIS |  |  |  | 00000000 |
| $\begin{aligned} & 3 \\ & 7 \end{aligned}$ | TDR1 TDR2 | W |  |  |  | NSMIT D | A REGIS |  |  |  | ------. |

## INTERRUPT STATUS REGISTERS (ISR1, ISR2)

The Interrupt Status Registers are read-only registers indicating the status of each interrupt source. Bits 6 through 0 are set when the indicated IRQ condition has occurred. Bit 7 is set to a 1 when any $\overline{\mathrm{RQQ}}$ source bit is set, or if Echo Mode is disabled, when CTS is high.

| 7 6 5 4 3 2 1 0 <br> ANY <br> BIT <br> SET TDRE $\overline{\text { CTST }}$ $\overline{\text { DCDT }}$ $\overline{\text { DSRT }}$ PAR F/O/B RDRF <br> Address $=0,4$        |  |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Reset Value $=1-00000-$ |  |  |  |  |  |

Address $=0,4$
Reset Value $=1.00000$ -

| Bit 7 | Any Bit Set |
| :---: | :---: |
| 1 | Any bit ( 6 through 0 ) has been set to a 1 or $\overline{\mathrm{CTS}}$ is high with echo disabled |
| 0 | No bits have been set to a 1 or echo is enabled |
| Bit 6 | Transmit Data Register Empty (TDRE) |
| 1 | Transmit Data Register is empty and CTS is low |
| 0 | Transmit Data Register is full or CTS is high |
| Bit 5 | Transition On CTS Line ( $\overline{\mathbf{C T S T}}$ ) |
| 1 | A positive or negative transition has occurred on CTS |
| 0 | No transition has occurred on CTS, or ISR has been Read |
| Bit 4 | Transition On $\overline{\mathrm{DCD}}$ Line ( $\overline{\mathrm{DCD}}$ ) |
| 1 | A positive or negative transition has occurred on $\overline{D C D}$ |
| 0 | No transition has occurred on $\overline{D C D}$, or ISR has been Read |
| Bit 3 | Transition On $\overline{\text { DSR }}$ Line ( $\overline{\mathrm{DSR}}$ ) |
| 1 | A positive or negative transition has occurred on DSR |
| 0 | No transition has occurred on $\overline{\mathrm{DSR}}$, or ISR has been Read |
| Bit 2 | Parity Status (PAR) |
|  | ACR bit $0=0$ |
| 1 | A parity error has occurred in received data |
| 0 | No parity error has occurred, or the Receive Data |
|  | $A C R$ bit $0=1$ |
| 1 | Parity bit $=1$ |
| 0 | Parity bit $=0$ |
| Bit 1 | Frame Error, Overrun, Break |
| 1 | A framing error, receive overrun, or receive break has occurred or has been detected |
| 0 | No error, overrun, break has occurred or RDR has been Read |
| Bit 0 | Receive Data Register Full (RDRF) |
| 1 | Receive Data Register is full |
| 0 | Receive Data Register is empty |

## INTERRUPT ENABLE REGISTERS (IER1, IER2)

The Interrupt Enable Registers are write-only registers that
enable/disable the $\overline{\mathrm{RQ}}$ sources. $\overline{\mathrm{IRQ}}$ sources are enabled by writing to an IER with bit 7 set to a 1 and the bit for every $\overline{\mathrm{RQ}}$ source to be enabled set to a $1 . \overline{\mathrm{RQ}}$ sources are disabled by writing to an IER with bit 7 reset to a 0 and the bit for every source to be disabled set to a 1. Any source bit reset to 0 is unaffected and remains in its original state. Thus, writing $\$ 7 \mathrm{~F}$ to an IER disables all of that channel's interrupts and writing an \$FF to an IER enables all of that channel's interrupts.

| $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SET <br> BITS | TDRE <br> IE | $\overline{C T S T} T$ <br> IE | $\overline{\mathrm{DCDT}}$ <br> IE | $\overline{\mathrm{DSR}} \mathrm{IE}$ <br> IE | PAR <br> IE | F/O/B <br> IE | RDRF <br> IE |

Address $=0,4$

## Bit 7 <br> 1

0
Bits 0-6
1 Select for enable/disable
0
No change

## CONTROL STATUS REGISTERS (CSR1, CSR2)

The Control Status Registers are read-only registers that provide I/O status and error condition information. A CSR is normally read after an IRQ has occurred to determine the exact cause of the interrupt condition.

| $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FE | TUR | $\overline{\mathrm{CTS}}$ <br> LVL | $\overline{\mathrm{DCD}}$ <br> LVL | $\overline{\mathrm{DSR}}$ <br> LVL | BRK | $\overline{\mathrm{DTR}}$ <br> LVL | $\overline{\mathrm{RTS}}$ <br> LVL |

Address $=1,5$

## Enable/Disable

Enable selected IRQ source
Disable selected IRQ source
Reset Value $=-0000000$

| Bit 7 | Framing Error (FE) |
| :---: | :---: |
| 1 | A framing error occurred in receive data |
| 0 | No framing error occurred, or the RDR was read |
| Bit 6 | Transmitter Underrun (TUR) |
| 1 | Transmit Shift Register is empty and TDRE is set |
| 0 | Transmitter Shift Register is not empty |
| Bit 5 | $\overline{\text { CTS }}$ Level ( $\overline{\text { CTS }}$ LVL) |
| 1 | CTS line is high |
| 0 | CTS line is low |
| Bit 4 | $\overline{\overline{D C D}}$ Level ( $\overline{\mathrm{DCD}}$ LVL) |
| 1 | $\overline{\text { DCD }}$ line is high |
| 0 | $\overline{\mathrm{DCD}}$ line is low |
| Bit 3 |  |
| 1 | DSR line is high |
| 0 | $\overline{\text { DSR }}$ line is low |
| Bit 2 | Receive Break (BRK) |
| 1 | A Receive Break has occurred |
| 0 | No Receive Break occurred, or RDR was read |
| Bit 1 | $\overline{\text { DTR }}$ Level ( $\overline{\text { DTR LVL) }}$ |
| 1 | DTR line is high |
| 0 | DTR line is low |
| Bit 0 | $\overline{\text { RTS }}$ Level ( $\overline{\mathrm{RTS}} \mathrm{LVL}$ ) |
| 1 | RTS line is high |
| 0 | RTS line is low |

## CONTROL REGISTERS (CR1, CR2)

The Control Registers are write-only registers. They control access to the Auxiliary Control Register and the Compare Data Register. They select the number of stop bits, control Echo Mode, and select the data rate.
(Accessed when Bit $7=0$ )

| $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{0}$ | CDR/ACR | STOP <br> BITS | ECHO | BAUD RATE SEL |  |  |  |

Address $=1,5$
Reset Value $=0 \ldots \ldots$.

## FORMAT REGISTERS (FR1, FR2)

The Format Registers are write-only registers. They select the number of data bits per character and parity generation/checking options. They also control $\overline{\mathrm{RTS}}$ and $\overline{\mathrm{DTR}}$.
(Accessed when Bit $7=1$ )

| $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | DATA | PAR | PAR | $\overline{\text { DTR }}$ | $\overline{\text { RTS }}$ |  |  |
|  | BITS | SEL | EN | CNTL | CNTL |  |  |

Address $=1,5$

| $\begin{gathered} \text { Bit } 7 \\ 1 \end{gathered}$ | Control or Format Register Access Format Register |
| :---: | :---: |
| Bits 6-5 | Number of Data Bits Per Character |
| 65 |  |
| 00 | 5 |
| 01 | 6 |
| 10 | 7 |
| 11 | 8 |
| Bits 4-3 | Parity Mode Selection |
| 43 |  |
| 00 | Odd Parity |
| 01 | Even Parity |
| 10 | Mark in Parity bit |
| 11 | Space in Parity bit |
| Bit 2 | Parity Enable |
| 1 | Parity as specified by bits 4-3 |
| 0 | No Parity |
| Bit 1 | $\overline{\text { DTR Control }}$ |
| 1 | Set DTR high |
| 0 | Set DTR low |
| Bit 0 | $\overline{R T S}$ Control |
| 1 | Set RTS high |
| 0 | Set $\overline{\text { RTS }}$ low |

## COMPARE DATA REGISTERS (CDR1, CDR2)

The Compare Data Registers are write-only registers which can be accessed when CR bit $6=0$. By writing a value into the CDR, the DACIA is put in the compare mode. In this mode, setting of the RDRF bit is inhibited until a character is received which matches the value in the CDR. The next character is then received and the RDRF bit is set. The receiver will now operate normally until the CDR is again loaded.
(Control Register bit $6=0$ )

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| COMPARE DATA |  |  |  |  |  |  |  |

Address $=2,6$
Reset Value $=\cdots \ldots .$. .

## AUXILIARY CONTROL REGISTERS (ACR1, ACR2)

The Auxiliary Control Registers are write-only registers. Bits 7-2 are unused. Bit 1 causes the transmitter to transmit a BREAK. Bit 0 determines whether parity error or the parity bit is displayed in ISR bit 2.

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  | TRNS BRK | $\begin{gathered} \text { PAR } \\ \text { ERR/ST } \end{gathered}$ |


| Bits 7-2 | Not Used |
| :---: | :--- |
| Bit 1 | Transmit Break (TRNS BRK) |
| 1 | Transmit continuous Break |
| 0 | Normal transmission |
| Bit 0 | Parity Error/State (PAR ERR/ST) |
| 1 | Send value of parity bit to ISR bit 2 (Address |
| 0 | Recognition mode) |
| 0 | Send Parity Error status to ISR bit 2 |

## RECEIVE DATA REGISTERS (RDR1, RDR2)

The Receive Data Registers are read-only registers which are loaded with the received data character of each frame. Start bits, stop bits and parity bits are stripped off of incoming frames before the data is transferred from the Receive Shift Register to the Receive Data Register. For characters of less than eight bits, the unused bits are the high order bits which are set to 0.

| $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RECEIVE DATA |  |  |  |  |  |  |  |

Address $=3,7$
Reset Value $=00000000$

## TRANSMIT DATA REGISTERS (TDR1, TDR2)

The Transmit Data Registers are write-only registers which are loaded from the CPU with data to be transmitted. For data characters of less than eight bits, the unused bits are the high order bits which are "don't care".


Address $=3,7$
Reset Value

## OPERATION

## TERMINATION OF UNUSED INPUTS

Noise on floating inputs can affect chip operation. All unused inputs must be terminated. If the baud rate generator is bypassed, XTALI must be connected to ground (XTALO is an output and must be left open). If the external clock mode is not used, RxC and TxC may be tied either to +5 V or to ground. If the handshake inputs are not needed, the $\overline{\text { CTS }}$ inputs should be tied low to enable the transmitters. The $\overline{D C D}$ and $\overline{D S R}$ inputs may either be tied high or low.

## RESET INITIALIZATION

During power on initialization, all readable registers should be read to assure that the status registers are initialized. Specifically, the RDRF bit of the Interrupt Status Registers is not initialized by reset. The Receiver Data Registers must be read to clear this bit.

## BAUD RATE CLOCK OPTIONS

The receiver and transmitter clocks may be supplied either by the internal Baud Rate Generator or by user supplied external clocks. Both channels may use the same clock source or one may use the Baud Rate Generator and the other channel external clocks. If both channels use the Baud Rate Generator, each channel may have a different bit rate. The options are shown in Figure 5.

An internal clock oscillator supplies the time base for the Baud Rate Generator. The oscillator can be driven by a crystal or an external clock.

If the on-chip oscillator is driven by a crystal, a parallel resonant crystal is connected between the XTALI and XTALO pins. The equivalent oscillator circuit is shown in Figure 6.

A parallel resonant crystal is specified by its load capacitance and series resonant resistance. For proper oscillator operation, the load capacitance $\left(\mathrm{C}_{\mathrm{L}}\right)$, series resistance $\left(\mathrm{R}_{S}\right)$ and the crystal resonant frequency $(F)$ must meet the following two relations:

$$
\begin{gathered}
(C+2)=2 C_{L} \quad \text { or } \quad C=2 C_{L}-2 \\
R_{s} \leq R_{s \max }=\frac{2 \times 10^{6}}{\left(F C_{L}\right)^{2}}
\end{gathered}
$$

where: $F$ is in $M H z ; C$ and $C_{L}$ are in $p F ; R$ is in ohms.

To select a parallel resonant crystal for the oscillator, first select the load capacitance from a crystal manufacturer's catalog. Next, calculate $R_{\text {smax }}$ based on $F$ and $C_{L}$. The selected crystal must have a $R_{s}$ less than the $R_{\text {smax }}$.


Figure 5. Baud Rate Clock Options


Figure 6.
For example, if $\mathrm{C}_{\mathrm{L}}=22 \mathrm{pF}$ for a 3.6864 MHz parallel resonant crystal, then

$$
\mathrm{C}=(2 \times 22)-2=42 \mathrm{pF} \text { (use standard value of } 43 \mathrm{pF} \text { ) }
$$

The series resistance of the crystal must be less than

$$
R_{\text {smax }}=\frac{2 \times 10^{6}}{(3.6864 \times 22)^{2}}=304 \mathrm{ohms}
$$

If the on-chip oscillator is driven by an external clock, the clock is input at XTALI and XTALO is left open.

An internal counter/divider circuit divides the frequency input at XTALI by the divisor selected in bits 3 through 0 of the Control Registers. Table 5 lists the divisors that may be selected and shows the bit rates generated with a 3.6864 MHz crystal or clock input. Other bit rates may be generated by changing the clock or crystal frequency. However, the input frequency must not exceed 4 MHz .

For external clock operation, a transmitter times 16 clock must be supplied at TxC and a receiver times 16 clock must be input at RxC. Since there are separate receiver and transmitter clock inputs, the receiver data rate may be different from the transmitter data rate.

Table 5. Baud Rate Generator Divisor Selection

| Control Register Bits |  |  |  | Divisor Selected For The Internal Counter | Baud Rate Generated With 3.6864 MHz Crystal or Clock | Baud Rate Generated* With a Crystal or Clock of Frequency ( f ) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 3 | 2 | 1 | 0 |  |  |  |
| 0 | 0 | 0 | 0 | 73,728 | $\left(3.6864 \times 10^{6}\right) / 73,728=50$ | f/73,728 |
| 0 | 0 | 0 | 1 | 33,538 | $\left(3.6864 \times 10^{6}\right) / 33,538=109.92$ | f/33,538 |
| 0 | 0 | 1 | 0 | 27,408 | $\left(3.6864 \times 10^{6}\right) / 27,408=134.58$ | f/27,408 |
| 0 | 0 | 1 | 1 | 24,576 | $\left(3.6864 \times 10^{6}\right) / 24,576=150$ | f/24,576 |
| 0 | 1 | 0 | 0 | 12,288 | $\left(3.6864 \times 10^{6}\right) / 12,288=300$ | f/12,288 |
| 0 | 1 | 0 | 1 | 6,144 | $\left(3.6864 \times 10^{6}\right) / 6,144=600$ | f/6,144 |
| 0 | 1 | 1 | 0 | 3,072 | $\left(3.6864 \times 10^{6}\right) / 3,072=1,200$ | f/3,072 |
| 0 | 1 | 1 | 1 | 2,048 | $\left(3.6864 \times 10^{6}\right) / 2,048=1,800$ | f/2,048 |
| 1 | 0 | 0 | 0 | 1,536 | $\left(3.6864 \times 10^{6}\right) / 1,536=2,400$ | f/1,536 |
| 1 | 0 | 0 | 1 | 1,024 | $\left(3.6864 \times 10^{6}\right) / 1,024=3,600$ | f/1,024 |
| 1 | 0 | 1 | 0 | 768 | $\left(3.6864 \times 10^{6}\right) / 768=4,800$ | f/768 |
| 1 | 0 | 1 | 1 | 512 | $\left(3.6864 \times 10^{6}\right) / 512=7,200$ | f/512 |
| 1 | 1 | 0 | 0 | 384 | $\left(3.6864 \times 10^{6}\right) / 384=9,600$ | f/384 |
| 1 | 1 | 0 | 1 | 192 | $\left(3.6864 \times 10^{6}\right) / 192=19,200$ | f/192 |
| 1 | 1 | 1 | 0 | 96 | $\left(3.6864 \times 10^{6}\right) / 96=38,400$ | f/96 |
| 1 | 1 | 1 | 1 | 16 | Transmitter Baud Rate $=$ TxC/16 | er Baud Rate $=$ RxC/16 |
| $* \text { Baud Rate }=\frac{\text { Frequency }}{\text { Divisor }}$ |  |  |  |  |  |  |

## CONTINUOUS DATA TRANSMIT

In the normal operating mode, the TDRE bit in the ISR signals the MPU that the DACIA is ready to accept the next data word. An $\overline{\mathrm{RQ}}$ occurs if the corresponding TDRE IRQ enable bit is set in the IER. The TDRE bit is set at the beginning of the start bit. When the MPU writes a word to the TDR the TDRE bit is cleared. In order to maintain continuous transmission the TDR must be loaded before the stop bit(s) are ended. Figure 7 shows the relationship between $\overline{\mathrm{RQ}}$ and TxD for the Continuous Data Transmit mode.

## CAUTION:

When the Baud Rate Generator is the clock source, writing to the Format or Control Register of a channel with an active transmitter can result in loss of data. Do not write to the Control or Format Register when the transmitter is shifting out data. This precaution does not apply to channels using the external clock option, i.e., TxC.


Figure 7. Continuous Data Transmit

## TRANSMIT UNDERRUN CONDITION

If the MPU is unable to load the TDR before the last stop bit is sent, the TxD line goes to the MARK condition and the underrun flag
(TUR) is set. This condition persists until the TDR is loaded with a new word. Figure 8 shows the relation between $\overline{\mathrm{RQ}}$ and TxD for the Transmit Underrun Condition.


Figure 8. Transmit Underrun Condition Relationship

## TRANSMIT BREAK CHARACTER

A BREAK may be transmitted by setting bit 1 of the ACR (Transmit Break bit) to a 1 . The BREAK is transmitted after the character in the Transmit Shift Register is sent. If there is a character in the Transmit Data Register, it will be transmitted after the BREAK is terminated. The Transmit Break bit must remain set for at least
one character time to assure that a proper BREAK is transmitted. If the Transmit Break bit is cleared before one character time of BREAK has been transmitted, the BREAK will be terminated after one character time has elapsed. If the Transmit Break bit is cleared after one character time of BREAK has been transmitted, the BREAK will be terminated immediately. Figure 9 shows the relationship of TXD, $\overline{\mathrm{IRQ}}$ and ACR bit 1 for various BREAK options.


Figure 9. Transmit BREAK

## EFFECTS OF CTS ON TRANSMITTER

The $\overline{\mathrm{CTS}}$ control line controls the transmission of data or the handshaking of data to a "busy" device (such as a printer). When the CTS line is low, the transmitter operates normally. A high condition inhibits the TDRE bit in the ISR from becoming set. Transmission of the word currently in the shift register is completed but any word in the TDR is held until CTS goes low.

Any transition on CTS sets bit 5 (CTST) of the ISR. A high on CTS forces bit 6 (TDRE) of the ISR to a 0 . Bit 7 of the ISR also goes to a 1 when CTS is high, if Echo Mode is disabled. Thus, when the ISR is $\$ 80$, it means that CTS is high and no interrupt source requires service. A processor interrupt will not be generated under these circumstances, but an ISR polling routine should accommodate this.


Figure 10. Effects of $\overline{\text { CTS }}$ on Transmitter

## ECHO MODE TIMING

In the Echo Mode, the TxD line re-transmits the data received on the RxD line, delayed by $1 / 2$ of a bit time. An internal underrun mode must occur before Echo Mode will start transmitting. In normal transmit mode if TDRE occurs (indicating end of data) an
underflow flag would be set and continuous Mark transmitted. If Echo is initiated, the underflow flag will not be set at end of data and continuous Mark will not be transmitted. Figure 11 shows the relationship of RxD and TxD for Echo Mode.


Figure 11. Echo Mode Timing

## CONTINUOUS DATA RECEIVE

The normal receive mode sets the RDRF bit in the ISR when the DACIA channel has received a full data word. This occurs at about the 9/16 point through the stop bit. The processor must read the RDR before the next stop bit, or an overrun error occurs. Figure 12 shows the relationship between $\overline{\mathrm{RQ}}$ and RxD for the continuous Data Receive mode.

## CAUTION:

When the Baud Rate Generator is the clock source, writing to the Control or Format Registers of a channel with an active receiver can result in loss of data. Do not write to the Control or Format Registers when the receiver is shifting in data. This precaution is not necessary on channels using the external clock option, i.e., RxC.


Figure 12. Continuous Data Receive

## EFFECTS OF OVERRUN ON RECEIVER

If the processor does not read the RDR before the stop bit of the next word, an overrun error occurs, the overrun bit is set in the ISR, and the new data word is not transferred to the RDR. The RDR
contains the last word not read by the MPU and all following data is lost. The receiver will return to normal operation when the RDR is read. Figure 13 shows the relationship of $\overline{\mathrm{IRQ}}$ and RxD when overrun occurs.


Figure 13. Effects of Overrun on Receiver

## RECEIVE BREAK CHARACTER

In the event that a Break character is received by the receiver, the Break bit is set. The receiver does not set the RDRF bit and remains in this state until a stop bit is received. At this time the
next character is to be received normally. Figure 14 shows the relationship of IRQ and RxD for a Receive Break Character.


Figure 14. Receive Break Character

## FRAMING ERROR

Framing error is caused by the absence of stop bit(s) on received data. The framing error bit is set when the RDRF bit is set. Subsequent data words are tested separately, so the status bit always
reflects the last data word received. Figure 15 shows the relationship of $\overline{\mathrm{RQ}}$ and RxD when a framing error occurs.


Figure 15. Framing Error

## PARITY ERROR DETECT/ADDRESS FRAME RECOGNITION

The Parity Status bit (ISR bit 2) may be programmed to indicate parity errors (ACR bit $0=0$ ) or to display the parity bit received (ACR bit $0=1$ ).

In applications where parity checking is used, one of the parity checking modes is enabled by setting bits 2,3 and 4 of the Format Register to the desired option and bit 0 of the Auxiliary Control Register is reset to 0 . Then, when the RDRF bit (bit 0 ) is set in the ISR, the PAR bit (bit 2) will be set when a parity error is detected.

In multi-drop applications, the parity bit is used as an address/data flag. It is set to 1 for address frames and is 0 on data frames. For
this type of operation, bit 0 of the ACR is set to a 1 and bits 2, 3 and 4 of the $F R$ select a parity checking mode. Then, ISR bit 2 will be set to a 1 by incoming address frames and it will be a 0 on data frames.

## COMPARE MODE

The Compare Mode is automatically enabled, i.e., the channel is put to sleep, whenever data is written to the Compare Data Register. NOTE: Bit 6 of the Control Register must be set to 0 to enable access to the Compare Data Register. When the channel is in the compare mode, the RDRF bit (bit 0 of the ISR) is forced to a 0 . Upon receipt of a matching character, normal receiver operation resumes and the RDRF bit (bit 0 of the ISR) will be set upon receipt of the next character.

## SPECIFICATIONS

## DACIA READ/WRITE WAVEFORMS



## DACIA READ/WRITE CYCLE TIMING

$\left(V_{C C}=5 \mathrm{Vdc} \pm 5 \%, V_{S S}=0 \mathrm{Vdc}, T_{A}=T_{L}\right.$ to $T_{H}$, unless otherwise noted $)$

|  | Characteristic | Symbol | 1 MHz |  | 2 MHz |  | 3 MHz |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Number |  |  | Min. | Max. | Min. | Max. | Min. | Max. | Unit |
| 1 | R/W, RSO-RS2 Valid to $\overline{\overline{C S}}$ Low (Setup) | $\mathrm{T}_{\text {RSU }}$ | 0 | - | 0 | - | 0 | - | ns |
| 2 | $\overline{\mathrm{CS}}$ Low to R/ $\bar{W}$, RSO-RS2 Invalid (Hold) | $\mathrm{T}_{\text {RH }}$ | 45 | - | 45 | - | 45 | - | ns |
| 3 | $\overline{\mathrm{CS}}$ Pulse Width | $\mathrm{T}_{\mathrm{CP}}$ | 640 | - | 320 | - | 210 | - | ns |
| 6 | $\overline{\mathrm{CS}}$ Low to Data Valid (Read) | $\mathrm{T}_{\text {CDV }}$ | - | 340 | - | 245 | - | 210 | ns |
| 8 | $\overline{\mathrm{CS}}$ High to Data Invalid (Read) | $\mathrm{T}_{\text {CDR }}$ | 10 | 50 | 10 | 50 | 10 | 50 | ns |
| 9 | Data Valid to $\overline{\mathrm{CS}}$ High (Write, Setup) | $\mathrm{T}_{\text {DSU }}$ | 20 | - | 20 | - | 20 | - | ns |
| 10 | $\overline{\mathrm{CS}}$ High to Data Invalid (Write Hold) | $\mathrm{T}_{\text {CDW }}$ | 30 | - | 30 | - | 30 | - | ns |

DACIA TRANSMIT/RECEIVER WAVEFORMS


TRANSMIT/RECEIVE AND INTERRUPT ACKNOWLEDGE TIMING
$\left(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}\right.$ to $\mathrm{T}_{\mathrm{H}}$, unless otherwise noted $)$

| Number | Characteristic | Symbol | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |


| TRANSMIT/RECEIVE TIMING |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 12 | Transmit/Receive Clock Rate | $\mathrm{t}_{\mathrm{Cr}}$ | 250 | - | ns |
| 13 | Transmit/Receive Clock High | ${ }^{\text {cher }}$ | 100 | - | ns |
| 14 | Transmit/Receive Clock Low | $\mathrm{t}_{\mathrm{CL}}$ | 100 | - | ns |
| 15 | TXC, RxC to TxD Propagation Delay | $\mathrm{t}_{\mathrm{DD}}$ | - | 285 | ns |
| 16 | TxC, RxC to IRQ Propagation Delay | $t_{\text {DI }}$ | - | 250 | ns |
| 17 | $\overline{\text { CTS }}$, $\overline{\mathrm{DCD}}, \overline{\mathrm{DSR}}$ Valid to IRQ Low | $\mathrm{t}_{\mathrm{CTI}}$ | - | 150 | ns |
| 18 | $\overline{\mathrm{RQ}}$ Propagation Delay (Clear) | $\mathrm{t}_{\text {IRO }}$ | - | 150 | ns |
| 19 | $\overline{\text { RTS, }}$ (TTR Propagation Delay | $t_{\text {DLY }}$ | - | 150 | ns |

## ABSOLUTE MAXIMUM RATINGS*

| Parameter | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | Vdc |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | -0.3 to $\mathrm{V}_{\mathrm{CC}}+0.3$ | Vdc |
| Output Voltage | $\mathrm{V}_{\mathrm{OUT}}$ | -0.3 to $\mathrm{V}_{\mathrm{CC}}+0.3$ | Vdc |
| Operating Temperature <br> Commercial <br> Industrial | $\mathrm{T}_{\mathrm{A}}$ | 0 to +70 <br> -40 to +85 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

## OPERATING CONDITIONS

| Parameter | Symbol | Value |
| :--- | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $5 \mathrm{~V} \pm 5 \%$ |
| Temperature Range <br> Commercial <br> Industrial | $\mathrm{T}_{\mathrm{A}}$ | 0 to $70^{\circ} \mathrm{C}$ <br> $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## DC CHARACTERISTICS

( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0, \mathrm{~T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$, unless otherwise noted)

| Parameter | Symbol | Min | Typ | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage <br> Except XTALI and XTALO <br> XTALI and XTALO | $V_{1 H}$ | $\begin{aligned} & +2.0 \\ & +2.4 \end{aligned}$ | - | $\begin{aligned} & V_{C C}+0.3 \\ & V_{C C}+0.3 \end{aligned}$ | V |  |
| Input Low Voltage Except XTALI and XTALO XTALI and XTALO | $V_{\text {IL }}$ | $\begin{aligned} & -0.3 \\ & -0.3 \end{aligned}$ | - | $\begin{aligned} & +0.8 \\ & +0.4 \end{aligned}$ | V |  |
| Input Leakage Current $R / \bar{W}, \overline{R E S}, R S 0, R S 1, R S 2, R \times D, \overline{C T S}, \overline{D C D}, \overline{D S R}, R x C$, TxC, $\overline{C S}$ | $I_{\text {IN }}$ | - | 10 | 50 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V} \text { to } 5.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Input Leakage Current for Three-State Off D0-D7 | $\mathrm{I}_{\text {TSI }}$ | - | $\pm 2$ | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & V_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Output High Voltage D0-D7, TxD, CLK OUT, RTS, DTR | $\mathrm{V}_{\mathrm{OH}}$ | $+2.4$ | - | - | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A} \end{aligned}$ |
| Output Low Voltage DO-D7, TxD, CLK OUT, RTS, DTR | $\mathrm{V}_{\mathrm{OL}}$ | - | - | $+0.4$ | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{LOAD}}=1.6 \mathrm{~mA} \end{aligned}$ |
| Output Leakage Current (Off State) $\overline{I R Q}$ | loff | - | $\pm 2$ | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OUT}}=0 \text { to } 2.4 \mathrm{~V} \end{aligned}$ |
| Power Dissipation | $P_{0}$ | - | - | 10 | mW/MHz |  |
| Input Capacitance <br> Except XTALI and XTALO <br> XTALI and XTALO | $\mathrm{C}_{\mathrm{IN}}$ | - | - | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | $\begin{aligned} & V_{\mathrm{CC}}=5.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\ & \mathrm{f}=2 \mathrm{MHz} \end{aligned}$ |
| Output Capacitance | $\mathrm{C}_{\text {OUT }}$ | - |  | 10 | pF | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |

## Notes:

1. All units are direct current (dc) except for capacitance.
2. Negative sign indicates outward current flow, positive indicates inward flow.
3. Typical values are shown for $V_{C C}=5.0 \mathrm{~V}$ and $T_{A}=25^{\circ} \mathrm{C}$.

## PACKAGE DIMENSIONS



## Section 2 <br> NMOS 8-Bit Microprocessors \& Peripherals

Page
Product Family Overview ..... 2-2
R650X and R651X Microprocessors (CPU) ..... 2-3
R6520 Peripheral Interface Adapter (PIA) ..... 2-18
R6522 Versatile Interface Adapter (VIA) ..... 2-30
R6532 RAM-I/O-Timer (RIOT) ..... 2-52
R6545/R6545E CRT Controller (CRTC) ..... 2-62
R6549 Color Video Display Generator (CVDG) ..... 2-81
R6551 Asynchronous Communications Interface Adapter (ACIA) ..... 2-112

## NMOS 8-bit Microprocessors and Peripherals Largest Selling 8-Bit Family

The NMOS R6500 microprocessor family has a wide range of CPUs and peripheral controllers plus versatile memory-1/O timer combinations. It is software compatible with the CMOS microprocessor and peripheral family, as well as, with the family of single-chip microcomputers.

A parallel processing, pipeline architecture provides faster instruction execution and data throughput. Thirteen address modes provide the most efficient ways of addressing memory.

R6500 peripherals are system oriented and are designed to implement systems with a minimum device count. Fast instruction execution ( $1 \mu \mathrm{~s}$ and $2 \mu \mathrm{~s}$ ) is available in 2 and 1 MHz versions, respectively.

The entire 8-bit R6500 family is upward compatible with the 16-bit 68000 bus, software compatible with the Rockwell 8 -bit microcomputers, and are the building blocks for a wide range of system applications.


NMOS R65XX Microprocessor Family

## R650X and R651X Microprocessors (CPU)

## DESCRIPTION

The 8-bit R6500 microprocessor devices are produced with N -channel, silicon gate technology. Performance speeds are enhanced by advanced system architecture. This innovative architecture results in smaller chips-the semiconductor threshold is cost-effectivity. System cost-effectivity is further enhanced by providing a family of 10 software-compatible microprocessor (CPU) devices, described in this document. Rockwell also provides single chip microcomputers, memory and peripheral devices-as well as low-cost design aids and documentation.

Ten CPU devices are available. All are software-compatible. They provide options of addressable memory, interrupt input, on-chip clock oscillators and drivers. All are bus-compatible with earlier generation microprocessors like the M6800 devices.

The R650X and R651X family includes six microprocessors with on-board clock oscillators and drivers and four microprocessors driven by external clocks. The on-chip clock versions are aimed at high performance, low cost applications where single phase inputs, crystal or RC inputs provide the time base. The external clock versions are geared for multiprocessor system applications where maximum timing control is mandatory. All R6500 microprocessors are also available in a variety of packaging (ceramic and plastic), operating frequency ( $1 \mathrm{MHz}, 2 \mathrm{MHz}$ and 3 MHz ) and temperature (commercial and industrial) versions.

ORDERING INFORMATION


## FEATURES

- N-channel, silicon gate, depletion load technology
- 8 -bit parallel processing
- 56 instructions
- Decimal and binary arithmetic
- Thirteen addressing modes
- True indexing capability
- Programmable stack pointer
- Variable length stack
- Interrupt request
- Non-maskable interrupt
- Use with any type of speed memory
- 8-bit bidirectional data bus
- Addressable memory range of up to 64 K bytes
- "Ready" input
- Direct Memory Access capability
- Bus compatible with M6800
- $1 \mathrm{MHz}, 2 \mathrm{MHz}$, and 3 MHz versions
- Choice of external or on-chip clocks
- On-chip clock options
-External single clock input
-Crystal time base input
- Commercial and industrial temperature versions
- Pipeline architecture
- Single +5 V supply


## R6500 CPU FAMILY MEMBERS

| Microprocessors with Internal Two Phase Clock Generator |  |  |
| :--- | :---: | :---: |
| Model | No. Pins | Addressable Memory |
| R6502 | 40 | 64K Bytes |
| R6503 | 28 | 4K Bytes |
| R6504 | 28 | 8K Bytes |
| R6505 | 28 | 4K Bytes |
| R6506 | 28 | 4K Bytes |
| R6507 | 28 | $8 K$ Bytes |
|  |  |  |
| Microprocessors with External Two Phase Clock Input |  |  |
|  |  |  |
| Model | No. Pins | Addressable Memory |
| R6512 | 40 |  |
| R6513 | 28 | 64K Bytes |
| R6514 | 28 | 4K Bytes |
| R6515 | 28 | $8 K$ Bytes |
|  |  | 4K Bytes |

## INTERFACE SIGNAL DESCRIPTIONS

## CLOCKS $(\varnothing 1, \varnothing 2)$

The R651X requires a two phase non-overlapping clock that runs at the $\mathrm{V}_{\mathrm{CC}}$ voltage level. The R650X clocks are supplied with an internal clock generator. The frequency of these clocks is externally controlled.

## ADDRESS BUS (A0-A15)

The address line outputs access data in memory device locations or cells, access data in I/O device registers and/or effect logical operations in I/O or controller devices depending on system design. The addressing range is determined by the number of address lines available on the particular CPU device. The R6502 and R6512 can address 64 K bytes with a 16 -bit address bus (A0-A15); the R6504, R6507, and the R6514 can address 8 K bytes with a 13 -bit address bus (A0-A12); and the R6503, R6505, R6506, R6513, and R6515 can address 4K bytes with a 12 -bit address bus (A0-A11). These outputs are TTL-compatible and are capable of driving one standard TTL load and 130 pF .

## DATA BUS (D0-D7)

The data lines (D0-D7) form an 8-bit bidirectional data bus which transfers data between the CPU and memory or peripheral devices. The outputs are tri-state buffers capable of driving one standard TTL load and 130 pF .

## DATA BUS ENABLE (DBE, R6512 ONLY)

The TTL-compatible DBE input allows external control of the tristate data output buffers and will enable the microprocessor bus driver when in the high state. In normal operation DBE is driven by the phase two ( $(2)$ clock, thus allowing data output from microprocessor only during $\varnothing$ 2. During the read cycle, the data bus drivers are internally disabled, becoming essentially an open circuit. To disable data bus drivers externally, DBE should be held low.

## READY (RDY)

The Ready input signal allows the user to halt or single cycle the microprocessor on all cycles except write cycles. A negative transition to the low state during or coincident with phase one ( $\varnothing 1$ ) will halt the microprocessor with the output address lines reflecting the current address being fetched. If Ready is low during a write cycle, it is ignored until the following read operation. This condition will remain through a subsequent phase two (Ø2) in which the Ready signal is low. This feature allows microprocessor interfacing with the low speed PROMs as well as Direct Memory Access (DMA).

## INTERRUPT REQUEST ( $\overline{\mathrm{RQ}}$ )

The TTL level active-low $\overline{\mathrm{IRQ}}$ input requests that an interrupt sequence begin within the microprocessor. The microprocessor will complete the current instruction being executed before recognizing the request. At that time, the interrupt mask bit in the Processor Status Register will be examined. If the interrupt mask flag is not set, the microprocessor will begin an interrupt sequence. The Program Counter and Processor Status Register
are stored in the stack. The microprocessor will then set the interrupt mask flag high so that no further interrupts can occur. At the end of this cycle, the program counter low will be loaded from address FFFE, and program counter high from location FFFF, therefore transferring program control to the memory vector located at these addresses. The RDY signal must be in the high state for any interrupt to be recognized. A $3 \mathrm{~K} \Omega$ external resistor should be used for proper wire-OR operation.

## NON-MASKABLE INTERRUPT ( $\overline{\mathrm{NMI})}$

A negative going edge on the $\overline{N M I}$ input requests that a nonmaskable interrupt sequence be generated within the microprocessor.
$\overline{N M I}$ is an unconditional interrupt. Following completion of the current instruction, the sequence of operations defined for $\overline{\mathrm{RQ}}$ will be performed, regardless of the state interrupt mask flag. The vector address loaded into the program counter, low and high, are locations FFFA and FFFB respectively, thereby transferring program control to the memory vector located at these addresses. The instructions loaded at these locations cause the microprocessor to branch to a non-maskable interrupt routine in memory.
$\overline{\mathrm{NMI}}$ also requires an external $3 \mathrm{~K} \Omega$ register to $\mathrm{V}_{\mathrm{CC}}$ for proper wire-OR operations.
Inputs $\overline{\mathrm{RQ}}$ and $\overline{\mathrm{NMI}}$ are hardware interrupts lines that are sampled during $\varnothing 2$ (phase 2) and will begin the appropriate interrupt routine on the $\varnothing 1$ (phase 1) following the completion of the current instruction.

## SET OVERFLOW FLAG ( $\overline{\mathbf{S O}}$ )

A negative going edge on the $\overline{\mathrm{SO}}$ input sets the overflow bit in the Processor Status Register. This signal is sampled on the trailing edge of $\emptyset 1$ and must be externally synchronized.

## SYNC

The SYNC output line identifies those cycles in which the microprocessor is doing an OP CODE fetch. The SYNC line goes high during $\varnothing 1$ of an OP CODE fetch and stays high for the remainder of that cycle. If the RDY line is pulled low during the $\varnothing 1$ clock pulse in which SYNC went high, the processor will stop in its current state and will remain in the state until the RDY line goes high. In this manner, the SYNC signal can be used to control RDY to cause single instruction execution.

## RESET ( $\overline{\mathrm{RES}}$ )

The active low $\overline{\mathrm{RES}}$ resets, or starts, the microprocessor from a power down or restart condition. During the time that this line is held low, writing to or from the microprocessor is inhibited. When a positive edge is detected on the input, the microprocessor will immediately begin the reset sequence.
After a system initialization time of six clock cycles, the mask interrupt flag is set and the microprocessor loads the program counter from the memory vector locations FFFC and FFFD. This is the start location for program control.

After $V_{C C}$ reaches 4.75 volts in a power up routine, reset must be held low for at least two clock cycles. At this time the R/W and SYNC signals become valid.

## R6502 FEATURES

－ 64 K addressable bytes of memory（A0－A15）
－On－chip clock
TTL－level single phase input
RC time base input
crystal time base input
－Two phase output clock for timing of support chips
－$\overline{\mathrm{RQ}}$ interrupt
－$\overline{\mathrm{NMI}}$ interrupt
－RDY signal
－SYNC signal （can be used for single instruction execution）
－40－pin DIP

| vss | － | 1 | 40 | $\square \overline{\text { RES }}$ |
| :---: | :---: | :---: | :---: | :---: |
| RDY | － | 2 | 39 | $\Phi_{2}$（OUT） |
| $\phi_{1}$ lout | $\square$ | 3 | 38 | $\square$ So |
| $\overline{\text { IRO }}$ | $\square$ | 4 | 37 | $\varphi_{0}(1 N)$ |
| N C | ［ | 5 | 36 | En．c |
| $\overline{\text { NMI }}$ | $\square$ | 6. | 35 | $\square \mathrm{Cc}$ |
| SYNC | O | 7 ） | 34 | $\square / \bar{w}$ |
| vCC | Cr |  | 33 | صoo |
| AO | $\square$ | ${ }_{9}$ R6502 | 32 | Qoi |
| A 1 | $\square$ | 10 | 31 | صD2 |
| A2 | $\square$ | 11 | 30 | $\square \mathrm{D}$ |
| A3 | $\square$ | 12 | 29 | $\square \mathrm{D}^{\text {4 }}$ |
| A4 | G | 13 | 28 | صD5 |
| A5 | － | 14 | 27 | صD6 |
| A6 | $\square$ | 15 | 26 | صロ7 |
| A 7 | $\square$ | 16 | 25 | صA15 |
| A8 | $\square$ | 17 | 24 | D $\mathrm{Al}^{4}$ |
| A9 | 5 | 18 | 23 | P 13 |
| A 10 | C | 19 | 22 | A 12 |
| A11 | $\square$ | 20 | 21 | صvss |

－

## R6503 FEATURES

－ 4 K addressable bytes of memory（A0－A11）
－On－chip clock
－$\overline{\mathrm{RQ}}$ interrupt
－$\overline{\mathrm{NMI}}$ interrupt
－28－pin DIP


## R6504 FEATURES

－ 8 K addressable bytes of memory（AO－A12）
－On－chip clock
－$\overline{\mathrm{RQ}}$ interrupt
－28－pin DIP


## R6505 FEATURES

－ 4 K addressable bytes of memory（A0－A11）
－On－chip clock
－$\overline{\mathrm{RQ}}$ interrupt
－RDY signal
－28－pin DIP

| $\overline{\text { RES }}$ | 128 | $8 \Phi_{2}$（OUT） |
| :---: | :---: | :---: |
| vSS | 2 | $\square \phi_{0}(1 \mathrm{~N})$ |
| RDY ${ }^{\text {d }}$ | 3 | $\mathrm{R}^{\prime} \overline{\mathbf{w}}$ |
| IRO | 42 | 己 Do |
| vac ${ }^{\text {c }}$ | $5 \quad 2$ | DD1 |
| AO | 2 | D 2 |
| $A_{1}$ | R6505 ${ }^{2}$ | صロ3 |
| A2 $\square$ | ${ }_{8}{ }^{1} 6$ | صD4 |
| A3 | 2 | D D5 |
| A4 | 10 | صD6 |
| A5 | 11 | ЭD7 |
| $A 6$ | 12 | A 11 |
| A） | 13 | －A 10 |
| A8 | 14 | コ 49 |

## R6506 FEATURES

- 4 K addressable bytes of memory (A0-A11)
- On-chip clock
- Two phase output clock for timing of support chips
- $\overline{\mathrm{RQ}}$ interrupt
- 28-pin DIP



## R6507 FEATURES

- 8 K addressable bytes of memory (A0-A12)
- On-chip clock
- RDY signal
- 28-pin DIP



## R6512 FEATURES

- 64 K addressable bytes of memory (A0-A15)
- Two phase clock input
- $\overline{\mathrm{RQ}}$ interrupt
- $\overline{\mathrm{NMI}}$ interrupt
- RDY signal
- SYNC signal
- Data Bus Enable

| vss ${ }^{\text {d }}$ | 1 | 40 | ص $\overline{\text { RES }}$ |
| :---: | :---: | :---: | :---: |
| RDY | 2 | 39 | ص $\phi_{2}$ (OUT) |
| $\phi_{1}(\mathrm{IN})$ | 3 | 38 | ص ${ }^{\text {s0 }}$ |
| $\overline{\mathrm{RO}}$ | 4 | 37 | $\phi_{2}(\mathrm{IN}) *$ |
| vss | 5 | 36 | Die |
| तला |  | 35 | $\square \mathrm{n} . \mathrm{c}$. |
| sync | 7 | 34 | $\square \mathrm{R} / \overline{\mathrm{w}}$ |
| vcc ${ }^{\text {d }}$ | 8 | 33 | ص Do |
| aO | 9 R6512 | 32 | ص D1 |
| A1 ${ }^{\text {a }}$ | 10 | 31 | صD2 |
| A2 ${ }^{\text {2 }}$ | 11 | 30 | ص $\mathbf{\square}$ |
| A3 | 12 | 29 | ص D4 |
| A4 당 | 13 | 28 | صD5 |
| A5 - | 14 | 27 | ص D |
| A6 | 15 | 26 | D7 |
| A7 ${ }^{\text {a }}$ | 16 | 25 | صA15 |
| A8 | 17 | 24 | صA14 |
| A9 | 18 | 23 | صA13 |
| A10 | 19 | 22 | ص A12 |
| A11 | 20 | 21 | ص vss |

*Pins 37 and 39 are connected internally

## R6513 FEATURES

- 4 K addressable bytes of memory (A0-A11)
- Two phase clock input
- $\overline{\mathrm{RQ}}$ interrupt
- $\overline{\mathrm{NM}}$ interrupt
- 28-pin DIP



## R6514 FEATURES

- 8K addressable bytes of memory (A0-A12)
- Two phase clock input
- $\overline{\mathrm{RQ}}$ interrupt



## R6515 FEATURES

- 4 K addressable bytes of memory (A0-A11)
- Two phase clock input
- $\overline{\mathrm{RQ}}$ interrupt
- RDY signal
- 28-pin DIP



## FUNCTIONAL DESCRIPTION

The internal organization of all R6500 CPUs is identical except for some variations in clock interface, the number of address output lines, and some unique input/output lines between versions.

## CLOCK GENERATOR

The clock generator develops all internal clock signals, and (where applicable) external clock signals, associated with the device. It is the clock generator that drives the timing control unit and the external timing for slave mode operations.

## TIMING CONTROL

The timing control unit keeps track of the instruction cycle being monitored. The unit is set to zero each time an instruction fetch is executed and is advanced at the beginning of each phase one clock pulse for as many cycles as is required to complete the instruction. Each data transfer which takes place between the registers depends upon decoding the contents of both the instruction register and the timing control unit.

## PROGRAM COUNTER

The 16-bit program counter provides the addresses which step the microprocessor through sequential instructions in a program.

Each time the microprocessor fetches an instruction from program memory, the lower byte of the program counter (PCL) is placed on the low-order bits of the address bus and the higher byte of the program counter ( PCH ) is placed on the high-order 8 bits. The counter is incremented each time an instruction or data is fetched fromprogram memory.

## INSTRUCTION REGISTER AND DECODE

Instructions fetched from memory are gated onto the internal data bus. These instructions are latched into the instuction register, then decoded, along with timing and interrupt signals, to generate control signals for the various registers.

## ARITHMETIC AND LOGIC UNIT (ALU)

All arithmetic and logic operations take place in the ALU including incrementing and decrementing internal registers (except the program counter). The ALU has no internal memory and is used only to perform logical and transient numerical operations.

## ACCUMULATOR

The accumulator is a general purpose 8-bit register that stores the results of most arithmetic and logic operations, and in addition, the accumulator usually contains one of the two data words used in these operations.

## INDEX REGISTERS

There are two 8-bit index registers ( $X$ and $Y$ ), which may be used to count program steps or to provide an index value to be used in generating an effective address.

When executing an instruction which specifies indexed addressing, the CPU fetches the op code and the base address, and modifies the address by adding the index register to it prior to performing the desired operation. Pre- or post-indexing of indirect addresses is possible (see addressing modes).

## STACK POINTER

The stack pointer is an 8-bit register used to control the addressing of the variable-length stack on page one. The stack pointer is automatically incremented and decremented under control of the microprocessor to perform stack manipulations under direction of either the program or interrupts ( $\overline{\mathrm{NMI})}$ ) and $\overline{\mathrm{RQ}}$ ). The stack allows simple implementation of nested subroutines and multiple level interrupts. The stack pointer should be initialized before any interrupts or stack operations occur.

## PROCESSOR STATUS REGISTER

The 8-bit processor status register contains seven status flags. Some of the flags are controlled by the program, others may be controlled both by the program and the CPU.


## INSTRUCTION SET

The R6500 CPU has 56 instruction types which are enhanced by up to 13 addressing modes for each instruction. The

Accumulator, index registers, Program Counter, Stack Pointer and Processor Status Register are illustrated below.

## Alphabetic Listing of Instruction Set

| Mnemonic | Function | Mnemonic | Function |
| :---: | :---: | :---: | :---: |
| ADC | Add Memory to Accumulator with Carry "AND" Memory with Accumulator Shift Left One Bit (Memory or Accumulator) | JMP | Jump to New Location |
| AND |  | JSR | Jump to New Location Saving Return Address |
| ASL |  |  |  |
|  | Branch on Carry Clear | LDA | Load Accumulator with Memory |
| BCC |  | LDX | Load Index X with Memory |
| BCS | Branch on Carry Set Branch on Result Zero | LDY | Load Index Y with Memory |
| BEQ |  | LSR | Shift One Bit Right (Memory or Accumulator) |
| BIT | Branch on Result Zero <br> Test Bits in Memory with Accumulator |  |  |
| BMI | Branch on Result Minus <br> Branch on Result not Zero | NOP | No Operation |
| BNE |  |  |  |
| BPL | Branch on Result PlusForce Break | ORA | "OR" Memory with Accumulator |
| BRK |  |  |  |
| BVC | Branch on Overflow Clear Branch on Overflow Set | PHA | Push Accumulator on Stack |
| BVS |  | PHP | Push Processor Status on Stack |
|  |  | PLA | Pull Accumulator from Stack |
| CLC | Clear Carry Flag <br> Clear Decimal Mode | PLP | Pull Processor Status from Stack |
| CLD |  |  |  |
| CLI | Clear Interrupt Disable Bit | ROL | Rotate One Bit Left (Memory or Accumulator) |
| CLV | Clear Overflow FlagCompare Memory and Accumulator | ROR | Rotate One Bit Right (Memory or Accumulator) |
| CMP |  | RTI | Return from Interrupt |
| CPX | Compare Memory and Index X Compare Memory and Index $Y$ | RTS | Return from Subroutine |
| CPY |  |  | Subtract Memory from Accumulator with Borrow |
|  |  | SBC | Subtract Memory from Accumulator with Borrow |
| DEC | Decrement Memory by One | SEC | Set Carry Flag |
| DEX | Decrement Index $X$ by One | SED | Set Decimal Mode |
| DEY | Decrement Index Y by One | SEI | Set Interrupt Disable Status |
|  |  | STA | Store Accumulator in Memory |
| EOR | "Exclusive-OR" Memory with Accumulator | STX | Store Index X in Memory |
| INC | Increment Memory by One | ST | Store Index Y in Memory |
| INX | Increment Index X by One | TAX | Transfer Accumulator to Index X |
| INY | Increment Index Y by One | TAY | Transfer Accumulator to Index $Y$ |
|  |  | TSX | Transfer Stack Pointer to Index X |
|  |  | TXA | Transfer Index X to Accumulator |
|  |  | TXS | Transfer Index X to Stack Register Transter Index $Y$ to Accumulator |



Programming Model

## ADDRESSING MODES

The R6500 CPU family has 13 addressing modes. In the following discussion of these addressing modes, a bracketed expression follows the title of the mode. This expression is the term used in the Instruction Set Op Code Matrix table (later in this product description) to make it easter to identify the actual addressing mode used by the instruction.

ACCUMULATOR ADDRESSING [Accum]-This form of addressing is represented with a one byte instruction, implying an operation on the accumulator.

IMMEDIATE ADDRESS [IMM]-In immediate addressing, the second byte of the instruction contains the operand, with no further memory addressing required.

ABSOLUTE ADDRESSING [Absolute]-In absolute addressing, the second byte of the instruction specifies the eight low order bits of the effective address while the third byte specifies the eight high order bits. Thus, the absolute addressing mode allows access to the entire 64 K bytes of addressable memory.

ZERO PAGE ADDRESSING [ZP]-The zero page instructions allow for shorter code and execution times by fetching only the second byte of the instruction and assuming a zero high address byte. Careful use of the zero page can result in significant increase in code efficiency.

INDEXED ZERO PAGE ADDRESSING [ZP, X or Y]-This form of addressing is used with the index register and is referred to as "Zero Page, X " or 'Zero Page, Y '. The effective address is calculated by adding the second byte to the contents of the index register. Since this is a form of "Zero Page" addressing, the content of the second byte references a location in page zero. Additionally, due to the "Zero Page" addressing nature of this mode, no carry is added to the high order eight bits of memory and crossing of page boundaries does not occur.

INDEXED ABSOLUTE ADDRESSING [ABS, X or Y ]This form of addressing is used in conjunction with $X$ and $Y$ index register and is referred to as "Absolute, X " and "Absolute, Y ." The effective address is formed by adding the contents of $X$ or Y to the address contained in the second and third bytes of the instruction. This mode allows the index register to contain the index or count value and the instruction to contain the base
address. This type of indexing allows referencing of any location and the index may modify multiple fields, resulting in reduced coding and execution time.

IMPLIED ADDRESSING [Implied]-In the implied addressing mode, the address containing the operand is implicitly stated in the operation code of the instruction.

RELATIVE ADDRESSING [Relative]-Relative addressing is used only with branch instructions and establishes a destination for the conditional branch.

The second byte of the instruction is an operand. This operand is an offset which is added to the program counter when the counter is set at the next instruction. The range of the offset is -128 to +127 bytes.

INDEXED INDIRECT ADDRESSING [(IND, X)]-In indexed indirect addressing (referred to as (Indirect, $X$ )), the second byte of the instruction is added to the contents of index register X discarding the carry. The result of this addition points to a memory location on page zero which contains the low order byte of the effective address. The next memory location in page zero contains the high order byte of the effective address. Both memory locations specifying the effective address must be in page zero.

INDIRECT INDEXED ADDRESSING [(IND), Y)]—In indirect indexed addressing (referred to as (Indirect), Y ), the second byte of the instruction points to a memory location in page zero. The contents of this memory location are added to the contents of index register Y . The result is the low order byte of the effective address. The carry from this addition is added to the contents of the next page zero memory location, to form the high order byte of the effective address.

ABSOLUTE INDIRECT [Indirect]-The second byte of the instruction contains the low order byte of a memory location. The high order eight bits of that memory location are contained in the third byte of the instruction. The contents of the fully specified memory location are the low order byte of the effective address. The next memnory location contains the high order byte of the effective address which is loaded into the sixteen bits of the program counter. (JMP (IND) only)

## INSTRUCTION SET OP CODE MATRIX

The following matrix shows the Op Codes associated with the R6500 family of CPU devices. The matrix identifies the hexadecimal code, the mnemonic code, the addressing mode, the
number of instruction bytes, and the number of machine cycles associated with each Op Code. Also, refer to the instruction set summary for additional information on these Op Codes.

| - | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\sum_{0}$ | BRK Implied 17 | $\begin{array}{\|c\|} \hline \text { ORA } \\ \text { (IND, X) } \\ 26 \end{array}$ |  |  |  | $\begin{aligned} & \text { ORA } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { ASL } \\ & \text { ZP } \\ & 25 \end{aligned}$ |  |  | $\begin{aligned} & \text { ORA } \\ & \text { IMM } \\ & 22 \end{aligned}$ | ASL Accum 12 |  |  | $\begin{aligned} & \text { ORA } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { ASL } \\ & \text { ABS } \\ & 36 \end{aligned}$ |  |
| 1 | BPL <br> Relative <br> 2 2* | $\begin{array}{\|c\|} \hline \text { ORA } \\ \text { (IND), Y } \\ 25^{*} \end{array}$ |  |  |  | $\begin{gathered} \text { ORA } \\ \text { ZP, } \mathrm{X} \\ 24 \end{gathered}$ | $\begin{gathered} \text { ASL } \\ \text { ZP, X } \\ 26 \end{gathered}$ |  | $\begin{gathered} \text { CLC } \\ \text { Implied } \\ 12 \end{gathered}$ | $\left.\begin{array}{\|c} \hline \text { ORA } \\ \text { ABS, } Y \\ 3 \end{array} \right\rvert\,$ |  |  |  | $\begin{gathered} \text { ORA } \\ \text { ABS, } x \\ 34^{*} \end{gathered}$ | $\begin{gathered} \text { ASL } \\ \text { ABS, } \mathrm{X} \\ 3 \mathrm{~B} \end{gathered}$ |  |
| 2 | $\begin{array}{c}\text { JSR } \\ \text { Absolute } \\ 3\end{array}$ |  |  |  | $\begin{gathered} \text { BIT } \\ \text { ZP } \\ 2.3 \\ \hline \end{gathered}$ | $\begin{aligned} & \text { AND } \\ & \text { ZP } \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{ROL} \\ & \mathrm{ZP} \\ & 2 \quad 5 \\ & \hline \end{aligned}$ |  |  | $\begin{aligned} & \text { AND } \\ & \text { IMM } \\ & 2 \quad 2 \\ & \hline \end{aligned}$ | ROL Accum 12 |  | $\begin{aligned} & \text { BIT } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \text { AND } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \mathrm{ROL} \\ & \mathrm{ABS} \\ & 36 \end{aligned}$ |  |
| 3 | BMI <br> Relative 2 2** | AND (IND), $Y$ $25^{*}$ |  |  |  | $\begin{aligned} & \text { AND } \\ & \text { ZP, } \mathrm{X} \\ & 2 \end{aligned}$ | $\begin{gathered} \mathrm{ROL} \\ \mathrm{ZP}, \mathrm{X} \\ 2 \quad 6 \end{gathered}$ |  | SEC Implied 12 | AND ABS, $Y$ 3 4* |  |  |  | AND ABS, X $34^{*}$ | $\begin{array}{\|c} \mathrm{ROL} \\ \mathrm{ABS}, \mathrm{X} \\ 37 \end{array}$ |  |
| 4 | RTI Implied 16 | $\begin{gathered} \text { EOR } \\ \text { (IND, X) } \\ 266 \end{gathered}$ |  |  |  | $\begin{aligned} & \text { EOR } \\ & \text { ZP } \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { LSR } \\ & \text { ZP } \\ & 2 \quad 5 \\ & \hline \end{aligned}$ |  | PHA Implied 13 | $\begin{aligned} & \text { EOR } \\ & \text { IMM } \\ & 22 \end{aligned}$ | LSR Accum $1 \quad 2$ |  | $\begin{aligned} & \text { JMP } \\ & \text { ABS } \\ & 3 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { EOR } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \text { LSR } \\ & \text { ABS } \\ & 3 \quad 6 \end{aligned}$ |  |
| 5 | BVC <br> Relative 2 2** |  |  |  |  | $\begin{aligned} & \text { EOR } \\ & \text { ZP, X } \\ & 24 \\ & \hline \end{aligned}$ | $\begin{gathered} \text { LSR } \\ \text { ZP, } X \\ 26 \end{gathered}$ |  |  | $\begin{array}{\|c\|} \hline \text { EOR } \\ \text { ABS, Y } \\ 34^{*} \end{array}$ |  |  |  | $\begin{aligned} & \text { EOR } \\ & \text { ABS, } x \\ & 34^{\circ} \end{aligned}$ | $\begin{gathered} \text { LSR } \\ \text { ABS, } x \\ 3 \quad 7 \end{gathered}$ |  |
| 6 | RTS Implied 16 | $A D C$ <br> $(I N D, X)$ <br> 2 |  |  |  | $\begin{aligned} & A D C \\ & Z P \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \mathrm{ROR} \\ & \mathrm{ZP} \\ & 2 \quad 5 \end{aligned}$ |  | $\begin{gathered} \text { PLA } \\ \text { Implied } \\ 1 \quad 4 \end{gathered}$ | $\begin{aligned} & \hline \text { ADC } \\ & \text { IMM } \\ & 2 \quad 2 \\ & \hline \end{aligned}$ | ROR Accum 12 |  | JMP Indirect $3 \quad 5$ | $\begin{aligned} & \hline \text { ADC } \\ & \text { ABS } \\ & 3 \quad 4 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { ROR } \\ & \text { ABS } \\ & 3 \quad 6 \\ & \hline \end{aligned}$ |  |
| 7 | BVS <br> Relative 2 2* | $\begin{array}{\|c\|} \hline \text { ADC } \\ \text { (IND), } Y \\ 25^{*} \end{array}$ |  |  |  | $\begin{aligned} & \text { ADC } \\ & \text { ZP, X } \\ & 24 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { ROR } \\ & \text { ZP, } X \\ & 26 \end{aligned}$ |  | SEI Implied $1 \quad 2$ |  |  |  |  | $\begin{gathered} \text { ADC } \\ \text { ABS, } x \\ 34^{*} \end{gathered}$ | $\begin{gathered} \text { ROR } \\ \text { ABS, } X \\ 37 \end{gathered}$ |  |
| 8 |  | $\begin{gathered} \text { STA } \\ \text { (IND, X) } \\ 266 \end{gathered}$ |  |  | $\begin{aligned} & \text { STY } \\ & \text { ZP } \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { STA } \\ & \text { ZP } \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { STX } \\ & \text { ZP } \\ & 2 \quad 3 \\ & \hline \end{aligned}$ |  | DEY Implied $1 \quad 2$ |  | TXA Implied $1 \quad 2$ 12 |  | $\begin{aligned} & \text { STY } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { STA } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \text { STX } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ |  |
| 9 | BCC <br> Relative 2 2* |  |  |  | $\begin{gathered} \text { STY } \\ \text { ZP, X } \\ 24 \end{gathered}$ | $\begin{gathered} \text { STA } \\ \text { ZP, X } \\ 24 \\ \hline \end{gathered}$ | $\begin{gathered} \text { STX } \\ \text { ZP, Y } \\ 24 \\ \hline \end{gathered}$ |  | TYA Implied 12 | STA ABS, Y $3 \quad 5$ | TXS Implied 12 |  |  | $\begin{gathered} \text { STA } \\ \text { ABS, } x \\ 3 \quad 5 \end{gathered}$ |  |  |
| A | $\begin{aligned} & \text { LDY } \\ & \text { IMM } \\ & 22 \\ & \hline \end{aligned}$ | $\begin{gathered} \text { LDA } \\ \text { (IND, } \mathrm{X}) \\ 2 \quad 6 \end{gathered}$ | $\begin{aligned} & \text { LDX } \\ & \text { IMM } \\ & 22 \end{aligned}$ |  | $\begin{aligned} & \text { LDY } \\ & \mathrm{ZP} \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { LDA } \\ & \mathrm{ZP} \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { LDX } \\ & \text { ZP } \\ & 2 \quad 3 \\ & \hline \end{aligned}$ |  | TAY Implied 12 | $\begin{aligned} & \text { LDA } \\ & \text { IMM } \\ & 2 \quad 2 \end{aligned}$ | TAX Implied 12 |  | $\begin{aligned} & \text { LDY } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \text { LDA } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \text { LDX } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ |  |
| B | BCS <br> Relative 2 2** |  |  |  | $\begin{aligned} & \text { LDY } \\ & \text { ZP, X } \\ & 24 \end{aligned}$ | $\begin{aligned} & \text { LDA } \\ & \text { ZP, X } \\ & 24 \end{aligned}$ | $\begin{gathered} \text { LDX } \\ \text { ZP, Y } \\ 24 \\ \hline \end{gathered}$ |  | CLV Implied 12 |  | TSX <br> Implied <br> $1 \quad 2$ |  |  | LDA ABS, $X$ $34^{*}$ |  |  |
| C | $\begin{aligned} & \text { CPY } \\ & \text { IMM } \\ & 2 \quad 2 \\ & \hline \end{aligned}$ | $\begin{gathered} \text { CMP } \\ \text { (IND, X) } \\ 266 \end{gathered}$ |  |  | $\begin{aligned} & \hline \mathrm{CPY} \\ & \mathrm{ZP} \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { CMP } \\ & \text { ZP } \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{DEC} \\ & \mathrm{ZP} \\ & 2 \quad 5 \\ & \hline \end{aligned}$ |  | INY Implied 12 | $\begin{aligned} & \text { CMP } \\ & \text { IMM } \\ & 22 \end{aligned}$ | DEX Implied $1 \quad 2$ |  | $\begin{aligned} & \mathrm{CFY} \\ & \mathrm{ABS} \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \text { CMP } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { DEC } \\ & \text { ABS } \\ & 3 \quad 6 \end{aligned}$ |  |
| D | BNE <br> Relative $22^{* *}$ | CMP <br> (IND), $Y$ <br> $25^{*}$ |  |  |  | $\begin{aligned} & \text { CMP } \\ & \text { ZP, } X \\ & 24 \\ & \hline \end{aligned}$ | $\begin{gathered} \text { DEC } \\ \text { ZP, } X \\ 26 \end{gathered}$ |  | CLD Implied 12 |  |  |  |  | $\begin{gathered} \text { CMF } \\ \text { ABS, } \times \\ 34^{.} \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { ABS, } X \\ 37 \end{gathered}$ |  |
| E | $\begin{aligned} & \text { CPX } \\ & \text { IMM } \\ & 22 \end{aligned}$ | $2 S B$ <br> SBC <br> $(I N D, X)$ <br> 2 <br> 2 |  |  | $\begin{aligned} & \text { CPX } \\ & \text { ZP } \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { SBC } \\ & \text { ZP } \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{array}{r} 1 \mathrm{NC} \\ \mathrm{ZP} \\ 2 \quad 5 \\ \hline \end{array}$ |  | INX Implied 12 | $\begin{aligned} & \hline \text { SBC } \\ & \text { IMM } \\ & 2 \quad 2 \\ & \hline \end{aligned}$ | NOP implied 12 |  | $\begin{aligned} & \text { CPX } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \text { SBC } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \text { ABS } \\ & 3 \quad 6 \end{aligned}$ |  |
| F | BEQ Relative 2 2** | SBC (IND), $Y$ $25^{*}$$\|$ |  |  |  | $\begin{gathered} \mathrm{SBC} \\ \mathrm{ZP}, \mathrm{X} \\ 24 \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { ZP, } X \\ 2.6 \end{gathered}$ |  | SED Implied 12 | SBC <br> $A B S, Y$ <br> 3 |  |  |  | $\begin{array}{\|c\|} \hline \text { SBC } \\ \text { ABS, } X \\ 3 \end{array} 4^{*}$ |  |  |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |


*Add 1 to N if page boundary is crossed.
**Add 1 to $N$ if branch occurs to same page; add 2 to N if branch occurs to different page.

## INSTRUCTION SET SUMMARY



## R650X CLOCK TIMING



R651X CLOCK TIMING


R65XX READ WRITE TIMING


## AC CHARACTERISTICS

| Characteristic | Symbol | $\begin{aligned} & \text { R65XX } \\ & (1 \mathrm{MHz}) \end{aligned}$ |  | $\begin{aligned} & \text { R65XXA } \\ & \text { (2 MHz) } \end{aligned}$ |  | $\begin{aligned} & \text { R65XXB } \\ & (3 \mathrm{MHz}) \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |

R650X CLOCK TIMING

| Clock Cycle Time | $\mathrm{T}_{\mathrm{CYC}}$ | 1.0 | 10 | 0.5 | 10 | 0.33 | 10 | $\mu \mathrm{s}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\emptyset 0$ (IN) Low Pulse Width | TL.ø0 | 480 | - | 240 | - | 160 | - | ns |
| $\emptyset 0$ (IN) High Pulse Width | $\mathrm{T}_{\mathrm{H} 00}$ | 460 | - | 240 | - | 160 | - | ns |
| $\phi 0$ (IN) Rise and Fall Time ${ }^{1,2}$ | $\mathrm{T}_{\text {Ro }}, \mathrm{T}_{\text {fo }}$ | - | 10 | - | 10 | - | 10 | ns |
| $\phi 1$ (OUT) High Pulse Width | $\mathrm{T}_{\text {PWHO1 }}$ | 460 | - | 235 | - | 155 | - | ns |
| ¢2 (OUT) High Pulse Width | $\mathrm{T}_{\text {PWH02 }}$ | 460 | - | 240 | - | 160 | - | ns |
| Delay Between $\emptyset 1$ (OUT) and $\varnothing 2$ (OUT) | $\mathrm{T}_{\mathrm{D}}$ | 0 | - | 0 | - | 0 | - | ns |
| $\emptyset 1$ (OUT), $\emptyset 2$ (OUT) Rise and Fall Time ${ }^{1,2}$ | $\mathrm{T}_{\mathrm{R}}, \mathrm{T}_{\mathrm{F}}$ | - | 25 | - | 25 | - | 15 | ns |

R651X CLOCK TIMING

| Clock Cycle Time | $\mathrm{T}_{\mathrm{CYC}}$ | 1.0 | 10 | 0.5 | 10 | 0.33 | 10 | $\mu \mathrm{s}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\emptyset 1$ (IN) High Pulse Width | $\mathrm{T}_{\text {PWH01 }}$ | 430 | - | 215 | - | 150 | - | ns |
| ¢2 (IN) High Pulse Width | $\mathrm{T}_{\text {PWH@2 }}$ | 470 | - | 235 | - | 160 | - | ns |
| Delay Between $\emptyset 1$ and $\emptyset 2$ | T | 0 | - | 0 | - | 0 | - | ns |
| 91 (IN), 92 (IN) Rise and Fall Time ${ }^{1,3}$ | $\mathrm{T}_{\mathrm{R}}, \mathrm{T}_{\mathrm{F}}$ | - | 25 | - | 20 | - | 15 | ns |

R65XX READ/WRITE TIMING

| $\mathrm{R} / \bar{W}$ Setup Time | T ${ }_{\text {RWS }}$ | - | 225 | - | 140 | - | 110 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R $\bar{W}$ Hold Time | $T_{\text {HRW }}$ | 30 | - | 30 | - | 15 | - | ns |
| Address Setup Time | $\mathrm{T}_{\text {ADS }}$ | - | 225 | - | 140 | - | 110 | ns |
| Address Hold Time | $\mathrm{T}_{\text {HA }}$ | 30 | - | 30 | - | 15 | - | ns |
| Read Access Time | $\mathrm{T}_{\text {ACC }}$ | - | 650 | - | 310 | - | 170 | ns |
| Read Data Setup Time | $\mathrm{T}_{\text {DSU }}$ | 100 | - | 50 | - | 50 | - | ns |
| Read Data Hold Time | $\mathrm{T}_{\mathrm{HR}}$ | 10 | - | 10 | - | 10 | - | ns |
| Write Data Setup Time | $\mathrm{T}_{\text {MDS }}$ | - | 175 | - | 100 | - | 85 | ns |
| Write Data Hold Time | $\mathrm{T}_{\mathrm{HW}}$ | 30 | - | 30 | - | 15 | - | ns |
| SYNC Hold Time | $\mathrm{T}_{\text {SYH }}$ | 30 | - | 30 | - | 15 | - | ns |
| RDY Setup Time | $\mathrm{T}_{\text {RDY }}$ | 100 | - | 50 | - | 35 | - | ns |
| $\overline{\text { SO Setup Time }}$ | $\mathrm{T}_{\text {so }}$ | 100 | - | 50 | - | 35 | - | ns |
| SYNC Setup Time | $\mathrm{T}_{\text {SYN }}$ | - | 225 | - | 140 | - | 110 | ns |

## Notes:

1. Loads: All output except clocks $=1 \mathrm{TTL}+130 \mathrm{pF}$. Clock outputs $=1 \mathrm{TTL}+30 \mathrm{pF}$.
2. Measured between 0.8 and 2.0 points on waveform load.
3. Measured between $10 \%$ and $90 \%$ points on waveforms.
4. *RDY must never switch states within $R_{\text {RDY }}$ to end of $\emptyset 2$.


## ABSOLUTE MAXIMUM RATINGS*

| Parameter | Symbol | Value | Unit |
| :--- | :--- | :--- | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | Vdc |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | -0.3 to +7.0 | Vdc |
| Operating Temperature Range <br> Commercial <br> Industrial | $\mathrm{T}_{\mathrm{A}}$ |  | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\mathrm{STG}}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## OPERATING CONDITIONS

| Parameter | Symbol | Value |
| :--- | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $5 \mathrm{~V} \pm 5 \%$ |
| Temperature Range | $\mathrm{T}_{\mathrm{A}}$ |  |
| Commercial <br> Industrial |  | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |

## DC CHARACTERISTICS

$\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{S S}=0 ; T_{A}=T_{L}\right.$ to $T_{H}$, unless otherwise noted)

| Parameter | Symbol | Min. | Typ. ${ }^{5}$ | Max. | Unit ${ }^{1}$ | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage Logic $\emptyset 0$ (IN) <br> ф1 (IN), 02 (IN) | $\mathrm{V}_{\mathrm{IH}}$ | $\begin{gathered} 2.0 \\ 2.4 \\ V_{C C}-0.3 \\ \hline \end{gathered}$ | - | $\begin{gathered} V_{\mathrm{Cc}} \\ \mathrm{~V}_{\mathrm{CC}} \\ \mathrm{~V}_{\mathrm{CC}}+0.25 \\ \hline \end{gathered}$ | V |  |
| Input Low Voltage Logic $\emptyset 0(\mathrm{IN}), \emptyset 1$ (IN), $\emptyset 2$ (IN) | VIL | $\begin{aligned} & -0.3 \\ & -0.3 \end{aligned}$ | - | $\begin{aligned} & 0.8 \\ & 0.4 \end{aligned}$ | V |  |
| Input Leakage Current Logic (Excl. RDY, $\overline{\mathrm{SO}}$ ) $\emptyset 1$ (IN), $\emptyset 2$ (IN) 00 (IN) | $\mathrm{I}_{\mathrm{IN}}$ | — | - | $\begin{array}{r} 2.5 \\ 100 \\ 10 \\ \hline \end{array}$ | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=0 \mathrm{~V} \text { to } 5.25 \mathrm{~V} \\ & V_{C}=0 \mathrm{~V} \end{aligned}$ |
| Input Leakage Current for Three State Offf D0-D7 | ${ }^{\text {TSI }}$ | - | - | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Output High Voltage <br> SYNC, D0-D7, A0-A15, R $\bar{W}, ~ \emptyset 1$ (OUT), $\emptyset 2$ (OUT) | $\mathrm{V}_{\mathrm{OH}}$ | +2.4 | - | - | V | $\begin{aligned} & \mathrm{I}_{\mathrm{LOAD}}=-100 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V} \end{aligned}$ |
| Output Low Voltage SYNC, D0-D7, AO-A15, R $\bar{W}, ~ \emptyset 1$ (OUT), $\emptyset 2$ (OUT) | $\mathrm{V}_{\mathrm{OL}}$ | - | - | $+0.4$ | V | $\begin{aligned} & \mathrm{I}_{\mathrm{LOAD}}=1.6 \mathrm{ma} \\ & \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V} \end{aligned}$ |
| Power Dissipation 1 and 2 MHz 3 MHz | $P_{\text {D }}$ | - | $\begin{aligned} & 450 \\ & 500 \end{aligned}$ | $\begin{aligned} & 700 \\ & 800 \end{aligned}$ | mW |  |
| ```Capacitance Logic D0-D7 A0-A15, R/\overline{W}, SYNC \emptyset0 (IN) \1 (IN) \2 (IN)``` | C <br> $\mathrm{C}_{\mathrm{IN}}$ <br> $\mathrm{C}_{\text {OUT }}$ <br> $\mathrm{C} \emptyset_{0(\mathrm{IN})}$ <br> C $\emptyset 1$ <br> Cゆ2 | $\begin{aligned} & - \\ & - \\ & - \end{aligned}$ | $\begin{aligned} & - \\ & - \\ & - \\ & 30 \\ & 50 \end{aligned}$ | $\begin{aligned} & 10 \\ & 15 \\ & 12 \\ & 15 \\ & 50 \\ & 80 \end{aligned}$ | pF | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\ & \mathrm{f}=1 \mathrm{MHz} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |

## Notes:

1. All units are direct current (dc) except for capacitance.
2. Negative sign indicates outward current flow, positive indicates inward flow.
3. $\overline{\mathrm{RQ}}$ and $\overline{\mathrm{NMI}}$ require 3 K pull-up resistor.
4. $\emptyset 1(\mathrm{IN})$ and $\emptyset 2(\mathrm{IN})$ apply to R6512, 13,14 , and 15 ; $\emptyset 0(\mathrm{IN})$ applies to R6502, 03, 04, 05, 06 and 07.
5. Typical values shown for $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

## R6520 <br> Peripheral Interface Adapter (PIA)

## DESCRIPTION

The R6520 Peripheral Interface Adapter (PIA) is designed to solve a broad range of peripheral control problems in the implementation of microcomputer systems. This device allows a very effective trade-off between software and hardware by providing significant capability and flexibility in a low cost chip. When coupled with the power and speed of the R6500, R6500/* or R65C00 family of microprocessors, the R6520 allows implementation of very complex systems at a minimum overall cost.

Control of peripheral devices is handled primarily through two 8 -bit bidirectional ports. Each of these lines can be programmed to act as either an input or an output. In addition, four peripheral control/interrupt input lines are provided. These lines can be used to interrupt the processor or to "handshake" data between the processor and a peripheral device.

## ORDERING INFORMATION

| Part Number |
| :--- |
| R6520 |
| $\left[\begin{array}{r}\text { Lemperature Range }\left(T_{L} \text { to } T_{H}\right): \\ \text { Blank }=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ \mathrm{E}=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \\ \text { Package: } \\ \mathrm{C}=40-\text { Pin Ceramic DIP } \\ \mathrm{P}=40 \text {-Pin Plastic DIP } \\ \text { Frequency Range: } \\ \text { No letter }=1 \mathrm{MHz} \\ \mathrm{A}=2 \mathrm{MHz} \\ \text {. }\end{array}\right.$ |

## FEATURES

- Two 8-bit directional I/O ports with individual data direction control
- Automatic "Handshake" control of data transfers
- Two interrupts (one for each port) with program control
- Commercial and industrial temperature range versions
- 40-pin plastic and ceramic versions
- 5 volt $\pm 5 \%$ supply requirements
- Compatible with the R6500, R6500/* and R65C00 family of microprocessors
- 1 and 2 MHz versions


Figure 1. R6520 Pin Configuration

## FUNCTIONAL DESCRIPTION

The R6520 PIA is organized into two independent sections referred to as the A Side and the B Side. Each section consists of a Control Register (CRA, CRB), Data Direction Register (DDRA, DDRB), Output Register (ORA, OBR), Interrupt Status Control (ISCA, ISCB), and the buffers necessary to drive the

Peripheral Interface buses. Data Bus Buffers (DBB) interface data from the two sections to the data bus, while the Data Input Register (DIR) interfaces data from the DBB to the PIA registers. Chip Select and $\mathrm{R} / \overline{\mathrm{W}}$ control circuitry interface to the processor bus control lines. Figure 2 is a block diagram of the R6520 PIA.


Figure 2. R6520 PIA Block Diagram

## DATA INPUT REGISTER (DIR)

When the microprocessor writes data into the PIA, the data which appears on the data bus during the $\$ 2$ clock pulse is latched into the Data Input Register (DIR). The data is then transferred into one of six internal registers of the PIA after the trailing edge of the $\emptyset 2$ clock. This assures that the data on the peripheral output lines will make smooth transitions from high to low (or from low to high) and the voltage will remain stable except when it is going to the opposite polarity.

## CONTROL REGISTERS (CRA and CRB)

Table 1 illustrates the bit designation and functions in the two control registers. The control registers allow the microprocessor to control the operation of the Interrupt Control inputs (CA1, CA2, CB1, CB2), and Peripheral Control outputs (CA2, CB2). Bit 2 in each register controls the addressing of the Data Direction Registers (DDRA, DDRB) and the Output Registers (ORA, ORB). In addition, two bits (bit 6 and 7) in each control register indicate the status of the Interrupt Input lines (CA1, CA2, CB1, CB2). These Interrupt Status bits (IRQA1, IRQA2 or IRQB1, IRQB2) are normally interrogated by the microprocessor during the $\overline{\mathrm{RQ}}$ interrupt service routine to determine the source of the interrupt.

Bit 2 (DDRA, DDRB) in each Control Register (CRA and CRB) controls access to the Data Direction Register or the Peripheral Interface. If bit 2 is a " 1 ," a Peripheral Output Register (ORA, ORB) is selected, and if bit 2 is a " 0 ," a Data Direction Register (DDRA, DDRB) is selected. The Data Direction Register Access Control bit, together with the Register Select lines (RSO, RS1) selects the various internal registers as shown in Table 2.

In order to write data into DDRA, ORA, DDRB, or ORB registers, bit 2 in the proper Control Register must first be set. The desired register may then be accessed with the address determined by the address interconnect technique used.

## DATA DIRECTION REGISTERS (DDRA, DDRB)

The Data Direction Registers (DDRA, DDRB) allow the processor to program each line in the 8 -bit Peripheral I/O port to be either an input or an output. Each bit in DDRA controls the corresponding line in the Peripheral A port and each bit in DDRB controls the corresponding line in the Peripheral B port. Writing a " 0 " in a bit position in the Data Direction Register causes the corresponding Peripheral I/O line to act as an input; a " 1 " causes it to act as an output.

## PERIPHERAL OUTPUT REGISTERS (ORA, ORB)

The Peripheral Output Registers (ORA, ORB) store the output data from the Data Bus Buffers (DBB) which appears on the Peripheral I/O port. If a line on the Peripheral A Port is programmed as an output by the DDRA, writing a 0 into the corresponding bit in the ORA causes that line to go low ( $<0.4 \mathrm{~V}$ ); writing a 1 causes the line to go high. The lines of the Peripheral $B$ port are controlled by ORB in the same manner.

## INTERRUPT STATUS CONTROL (ISCA, ISCB)

The four interrupt/peripheral control lines (CA1, CA2, CB1, CB2) are controlled by the Interrupt Status Control logic (A, B). This logic interprets the contents of the corresponding Control Register and detects active transitions on the interrupt inputs.

## PERIPHERAL I/O PORTS (PA0-PA7, PB0-PB7)

The Peripheral A and Peripheral B I/O ports allow the microprocessor to interface to the input lines on a peripheral device by writing data into the Peripheral Output Register. They also allow the processor to interface with the peripheral device output lines by reading the data on the Peripheral Port input lines directly onto the data bus and into the internal registers of the processor.

Each of the Peripheral I/O lines can be programmed to act as an input or an output. This is accomplished by setting a 1 in the corresponding bit in the Data Direction Register for those lines which are to act as outputs. A 0 in a bit of the Data Direction Register causes the corresponding Peripheral I/O lines to act as an input.

The buffers which drive the Peripheral A I/O lines contain "passive" pull-up devices. These pull-up devices are resistive in nature and therefore allow the output voltage to go to VCC for a logic 1 . The switches can sink 1.6 mA , making thesse buffers capable of driving one standard TTL load.

In the input mode, the pull-up devices are still connected to the I/O pin and still supply current to this pin. For this reason, these lines also represent one standard TTL load in the input mode.

The Peripheral B I/O port duplicates many of the functions of the Peripheral A port. The process of programming these lines to act as an input or an output is similar to the Peripheral A port, as is the effect of reading or writing this port. However, there are several characteristics of the buffers driving these lines which affect their use in peripheral interfacing.

Table 1. Control Registers Bit Designations


The Peripheral B I/O port buffers are push-pull devices i.e., the pull-up devices are switched OFF in the 0 state and ON for a logic 1 . Since these pull-ups are active devices, the logic 1 voltage will not go higher than +2.4 V .

Another difference between the PAO-PA7 lines and the PBO through PB7 lines is that they have three-state capability which allows them to enter a high impedance state when programmed to be used as input lines. In addition, data on these lines will be read properly, when programmed as output lines, even if the data signals fall below 2.0 volts for a "high"' state or are above 0.8 volts for a "low" state. When programmed as output, each line can drive at least one TTL load and may also be used as a source of up to 1 milliampere at 1.5 volts to directly drive the base of a transistor switch, such as a Darlington pair.

## DATA BUS BUFFER (DBB)

The Data Bus Buffer is an 8-bit bidirectional buffer used for data exchange, on the D0-D7 Data Bus, between the microprocessor and the PIA. This buffer is tri-stateable and is capable of driving a two TTL load (when operating in an output mode) and represents a one TTL load to the microprocessor (when operating in an input mode).

## INTERFACE SIGNALS

The PIA interfaces to the R6500, R6500/* or the R65C00 microprocessor family with a reset line, a $\emptyset$ clock line, a read/write line, two interrupt request lines, two register select lines, three chip select lines, and an 8 -bit bidirectional data bus.

The PIA interfaces to the peripheral device with four interrupt/ control lines and two 8 -bit bidirectional data ports.

Figure 1 (on the front page) shows the pin assignments for these interface signals and Figure 3 shows the interface relationship of these signals to the CPU and the peripheral devices.

## CHIP SELECT (CS0, CS1, $\overline{\mathbf{C S 2}})$

The PIA is selected when CS0 and CS1 are high and CS2 is low. These three chip select lines are normally connected to the processor address lines either directly or through external decoder circuits. When the PIA is selected, data will be transferred between the data lines and PIA registers, and/or peripheral interface lines as determined by the RW, RSO, and RS1 lines and the contents of Control Registers A and B.

## RESET SIGNAL ( $\overline{\operatorname{RES}}$ )

The Reset ( $\overline{\operatorname{RES}}$ ) input initializes the R6520 PIA. A low signal on the RES input causes all internal registers to be cleared.

## CLOCK SIGNAL ( ${ }^{(\$ 2)}$

The Phase 2 Clock Signal ( $\emptyset 2$ ) is the system clock that triggers all data transfers between the CPU and the PIA. $\emptyset 2$ is generated by the CPU and is therefore the synchronizing signal between the CPU and the PIA.

## READ/WRITE SIGNAL (R/W)

Read/Write ( $\mathrm{R} / \overline{\mathrm{W}}$ ) controls the direction of data transfers between the PIA and the data lines associated with the CPU and the peripheral devices. A high on the R/W line permits the peripheral device to transfer data to the CPU from the PIA. A low on the R $\bar{W}$ line allows data to be transferred from the CPU to the peripheral devices from the PIA.

## REGISTER SELECT (RSO, RST)

The two Register Select lines (RSO, RS1), in conjunction with the Control Registers (CRA, CRB) Data Direction Register access bits (bit 2), select the various R6520 registers to be accessed by the CPU. RS0 and RS1 are normally connected to the microprocessor (CPU) address output lines. Through control of these lines, the CPU can write directly into the Control


Figure 3. Interface Signals Relationship

Registers (CRA, CRB), the Data Direction Registers (DDRA, DDRB), and the Peripheral Output Registers (ORA, ORB). In addition, the processor may directly read the contents of the Control Registers and the Data Direction Registers. Table 2 shows the internal register address decoding.

Table 2. Internal Register Addressing

| Register Address (Hex) | Register Select Lines |  | Data Direction Control |  | Register Operation |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | RS1 | RS0 | CRA <br> (Bit 2) | $\begin{array}{\|c\|} \hline \text { CRB } \\ \text { (Bit 2) } \end{array}$ | $\mathrm{R} / \bar{W}=\mathrm{H}$ | $\mathrm{R} / \overline{\mathbf{W}}=\mathrm{L}$ |
| 0 | L | L | 1 | - | Read PIBA | Write ORA |
| 0 | L | L | 0 | - | Read DDRA | Write DDRA |
| 1 | L | H | - | - | Read CRA | Write CRA |
| 2 | H | L | - | 1 | Read PIBB | Write ORB |
| 2 | H | L | - | 0 | Read DDRB | Write DDRB |
| 3 | H | H | - | - | Read CRB | Write CRB |

## INTERRUPT REQUEST LINES (IRQA, $\overline{\text { IRQB })}$

The active low Interrupt Request lines ( $\overline{\mathrm{RQA}}$ and $\overline{\mathrm{RQB}}$ ) act to interrupt the microprocessor either directly or through external interrupt priority circuitry. These lines are open drain and are capable of sinking 1.6 milliamps from an external source. This permits all interrupt request lines to be tied together in a wiredOR configuration. The $A$ and $B$ in the titles of these lines correspond to the peripheral port $A$ and the peripheral port $B$ so that each interrupt request line services one peripheral data port.

Each Interrupt Request line has two interrupt flag bits which can cause the Interrupt Request line to go low. These flags are bits 6 and 7 in the two Control Registers (CRA, CRB). These flags act as the link between the peripheral interrupt signals and the microprocessor interrupt inputs. Each flag has a corresponding interrupt disable bit which allows the processor to enable or disable the interrupt from each of the four interrupt inputs (CA1, CA2, CB1, CB2). The four interrupt flags are set (enabled) by active transitions of the signal on the interrupt input (CA1, CA2, CB1, CB2).

CRA bit 7 (IRQA1) is always set by an active transition of the CA1 interrupt input signal. However, $\overline{\mathrm{RQA}}$ can be disabled by setting bit 0 in CRA to a 0 . Likewise, CRA bit 6 (IRQA2) can be set by an active transition of the CA2 interrupt input signal and $\overline{\text { IRQA }}$ can be disabled by setting bit 3 in CRA to a 0 .

Both bit 6 and bit 7 in CRA are reset by a "Read Peripheral Output Register A" operation. This is defined as an operation in which the read/write, proper data direction register and register select signals are provided to allow the processor to read the Peripheral A I/O port. A summary of $\overline{\mathrm{RQA}}$ control is shown in Table 3.

Control of $\overline{\mathrm{TQB}}$ is performed in exactly the same manner as that described above for IRQA. Bit 7 in CRB (IRQB1) is set by an active transition on CB1 and $\overline{\mathrm{RQB}}$ from this flag is controlled
transition on CB2, and IRQB from this flag is controlled by CRB bit 3.
Also, both bit 6 and bit 7 of CRB are reset by a "Read Peripheral B Output Register" operation. A summary of $\overline{\mathrm{IRQB}}$ control is shown in Table 3.

Table 3. $\overline{\mathrm{IRQA}}$ and $\overline{\mathrm{IRQB}}$ Control Summary

| Control Register Bits | Action |
| :---: | :---: |
| CRA $-7=1$ and CRA $-0=1$ | $\overline{\text { RQA }}$ goes low (Active) |
| CRA $-6=1$ and CRA- $3=1$ | $\overline{\text { IRQA }}$ goes low (Active) |
| CRB- $7=1$ and CRB- $0=1$ | $\overline{\overline{R Q B}}$ goes low (Active) |
| CRB $-6=1$ and CRB-3 $=1$ | $\overline{\text { RQB }}$ goes low (Active) |
| Note: |  |

The flags act as the link between the peripheral interrupt signals and the processor interrupt inputs. The interrupt disable bits allow the processor to control the interrupt function.

## INTERRUPT INPUT/PERIPHERAL CONTROL LINES (CA1, CA2, CB1, CB2)

The four interrupt input/peripheral control lines provide a number of special peripheral control functions. These lines greatly enhance the power of the two general purpose interface ports (PAO-PA7, PB0-PB7). Figure 4 summarizes the operation of these control lines.

CA1 is an interrupt input only. An active transition of the signal on this input will set bit 7 of the Control Register A to a logic 1. The active transition can be programmed by setting a " 0 " in bit 1 of the CRA if the interrupt flag (bit 7 of CRA) is to be set on a negative transition of the CA1 signal or a " 1 " if it is to be set on a positive transition.

## Note:

A negative transition is defined as a transition from a high to a low, and a positive transition is defined as a transition from a low to a high voltage.

CA2 can act as a totally independent interrupt or as a peripheral control output. As an input (CRA, bit $5=0$ ) it acts to set the interrupt flag, bit 6 of CRA, to a logic 1 on the active transition selected by bit 4 of CRA.

These control register bits and interrupt inputs serve the same basic function as that described above for CA1. The input signal sets the interrupt flag which serves as the link between the peripheral device and the processor interrupt structure. The interrupt disable bit allows the processor to exercise control over the system interrupt.

In the output mode (CRA, bit $5=1$ ), CA2 can operate independently to generate a simple pulse each time the microprocessor reads the data on the Peripheral A I/O port. This mode is selected by setting CRA, bit 4 to a 0 and CRA, bit 3 to a 1 . This pulse output can be used to control the counters, shift registers, etc., which make sequential data available on the Peripheral input lines.

CA2 INPUT MODE (BIT $5=0$ )

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IRQA1 <br> FLAG | $\begin{gathered} \text { IRQA2 } \\ \text { FLAG } \end{gathered}$ | CA2 INPUT <br> MODE SELECT ( $=0$ ) | IRQA2 POSITIVE TRANSITION | $\begin{gathered} \overline{\mathrm{IRQA}} \\ \text { ENABLE } \\ \text { FOR IRQA2 } \end{gathered}$ | DDRA/ORA SELECT | IRQA1 POSITIVE TRANSITION | $\begin{gathered} \overline{\mathrm{IRQA}} \\ \text { ENABLE } \\ \text { FOR IRQA1 } \end{gathered}$ |
|  |  |  | IRQA $\mathrm{CON}$ |  |  | IRQA |  |

CA2 OUTPUT MODE (BIT 5 = 1)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { IRQA1 } \\ & \text { FLAG } \end{aligned}$ | 0 | CA2 OUTPUT MODE SELECT (=1) | CA2 OUTPUT CONTROL | CA2 RESTORE CONTROL | DDRA/ORA SELECT | $\begin{gathered} \text { IRQA1 } \\ \text { POSITIVE } \\ \text { TRANSITION } \end{gathered}$ | $\begin{gathered} \overrightarrow{\text { IRQA }} \\ \text { ENABLE } \\ \text { FOR IRQA1 } \end{gathered}$ |
|  |  |  | $\begin{gathered} \text { CA2 } \\ \text { CONTROL } \end{gathered}$ |  |  | IRQA IRQA1 CONTROL |  |

CA2 INPUT OR OUTPUT MODE (BIT $5=0$ or 1)

| Bit 7 | IRQA1 FLAG |
| :---: | :---: |
| 1 | A transition has occurred on CA1 that satisfies the bit 1 IRQA1 transition polarity criteria. This bit is cleared by a read of Output Register A or by $\overline{R E S}$. |
| 0 | No transition has occurred on CA1 that satisfies the bit 1 IRQA1 transition polarity criteria. |
| Bit 2 | OUTPUT REGISTER A SELECT |
| 1 | Select Output Register A. |
| 0 | Select Data Direction Register A. |
| Bit 1 | IRQA1 POSITIVE TRANSITION |
| 1 | Set IRQA1 Flag (bit 7) on a positive (low-to-high) transition of CA1. |
| 0 | Set IRQA1 Flag (bit 7) on a negative (high-to-low) transition of CA1. |
| Bit 0 | IRQA ENABLE FOR IRQA1 |
| 1 | Enable assertion of $\overline{\text { IRQA }}$ when IRQA1 Flag (bit 7) is set. |
| 0 | Disable assertion of IRQA when IRQA1 Flag (bit 7) is set. |

CA2 INPUT MODE (BIT $5=0$ )

```
Bit 6 IRQA2 FLAG
    1 A transition has occurred on CA2 that satisfies the bit 4
    IRQA2 transition polarity criteria. This flag is cleared by
    a read of Output Register A or by \overline{RES.}
0 No transition has occurred on CA2 that satisfies the bit 4 IRQA2 transition polarity criteria.
Bit 5 CA2 MODE SELECT
0 Select CA2 Input Mode.
Bit 4 IRQA2 POSITIVE TRANSITION
1 Set IRQA2 Flag (bit 6) on a positive (low-to-high) transition of CA2.
0 Set IRQA2 Flag (bit 6) on a negative (high-to-low) transition of CA2.
Bit 3 IRQA ENABLE FOR IRQA2
1 Enable assertion of IRQA when IRQA2 Flag (bit 6) is set.
0 Disable assertion of \(\overline{\operatorname{IRQA}}\) when IRQA2 Flag (bit 6) is set.
```

CA2 OUTPUT MODE (BIT $5=1$ )
Bit 6 NOT USED
0 Always zero.

Bit 5 CA2 MODE SELECT
1 Select CA2 Output Mode.

## Bit 4 CA2 OUTPUT CONTROL

1 CA2 goes low when a zero is written into CRA bit 3. CA2 goes high when a one is written into CRA bit 3.
$0 \quad$ CA2 goes low on the first negative (high-to-low) 02 clock transition following a read of Output Register A. CA2 returns high as specified by bit 3.

Bit 3 CA2 READ STROBE RESTORE CONTROL ( $4=0$ )
1 CA2 returns high on the next $\emptyset 2$ clock negative transition following a read of Output Register A.
$0 \quad$ CA2 returns high on the next active CA1 transition following a read of Output Register A as specified by bit 1.

Figure 4. Control Line Operations Summary (1 of 2)

## CONTROL REGISTER B (CRB)

CB2 INPUT MODE (BIT $5=0$ )

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { IRQB1 } \\ & \text { FLAG } \end{aligned}$ | $\begin{aligned} & \text { IRQB2 } \\ & \text { FLAG } \end{aligned}$ | CB2 INPUT MODE SELECT ( $=0$ ) | $\begin{gathered} \text { IRQB2 } \\ \text { POSITIVE } \\ \text { TRANSITION } \end{gathered}$ | $\begin{gathered} \overline{\mathrm{IRQB}} \\ \text { ENABLE } \\ \text { FOR IRQB2 } \end{gathered}$ | DDRB/ORB SELECT | $\begin{gathered} \text { IRQB1 } \\ \text { POSITIVE } \\ \text { TRANSITION } \end{gathered}$ | $\begin{gathered} \overline{\mathrm{TRQB}} \\ \text { ENABLE } \\ \text { FOR IRQB1 } \end{gathered}$ |
|  |  |  | $\begin{aligned} & \overline{\mathrm{TRQB}} \\ & \mathrm{CON} \end{aligned}$ |  |  | $\begin{array}{r} \overline{\mathrm{RQQB}} \\ \mathrm{CON} \end{array}$ |  |

CB2 OUTPUT MODE (BIT $5=1$ )

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { IRQB1 } \\ & \text { FLAG } \end{aligned}$ | 0 | CB2 OUTPUT <br> MODE SELECT (=1) | CB2 OUTPUT CONTROL | $\begin{gathered} \text { CB2 } \\ \text { RESTORE } \\ \text { CONTROL } \end{gathered}$ | DDRB/ORB SELECT | IRQB1 POSITIVE TRANSITION | $\begin{gathered} \overline{\mathrm{IRQB}} \\ \text { ENABLE } \\ \text { FOR IRQB1 } \end{gathered}$ |
|  |  |  | CB2 CONTROL |  |  | $\overline{\mathrm{RQB}} / \mathrm{IRQB} 1$ CONTROL |  |

CB2 INPUT OR OUTPUT MODE (BIT $5=0$ or 1)

| Bit 7 | IRQB1 FLAG |
| :---: | :---: |
| 1 | A transition has occurred on CB1 that satisfies the bit 1 IRQB1 transition polarity criteria. This bit is cleared by a read of Output Register $B$ or by $\overline{\mathrm{RES}}$. |
| 0 | No transition has occurred on CB1 that satisfies the bit 1 IRQB1 transition polarity criteria. |
| Bit 2 | OUTPUT REGISTER B SELECT |
| 1 | Select Output Register B. |
| 0 | Select Data Direction Register B. |
| Bit 1 | IRQB1 POSITIVE TRANSITION |
| 1 | Set IRQB1 Flag (bit 7) on a positive (low-to-high) transition of CB1. |
| 0 | Set IRQB1 Flag (bit 7) on a negative (high-to-low) transition of CB1. |
| Bit 0 | $\overline{\text { IRQB ENABLE FOR IRQB1 }}$ |
| 1 | Enable assertion of $\overline{\mathrm{RQB}}$ when IRQB1 Flag (bit 7) is set. |
| 0 | Disable assertion of $\overline{\mathrm{RQB}}$ when IRQB1 Flag (bit 7) is set. |

CB2 INPUT MODE (BIT $5=0$ )
Bit 6 IRQB2 FLAG
1 A transition has occurred on CB2 that satisfies the bit 4 IRQB2 transition polarity criteria. This flag is cleared by a read of Output Register B or by RES.
0 No transition has occurred on CB2 that satisfies the bit 4 IRQB2 transition polarity criteria.

Bit 5 CB2 MODE SELECT
0 Select CB2 Input Mode.
Bit 4 IRQB2 POSITIVE TRANSITION
1 Set IRQB2 Flag (bit 6) on a positive (low-to-high) transition of CB2.
0 Set IRQB2 Flag (bit 6) on a negative (high-to-low) transition of CB2.

Bit 3 IRQB ENABLE FOR IRQB2
1 Enable assertion of $\overline{\mathrm{RQB}}$ when IRQB2 Flag (bit 6) is set.
0 Disable assertion of $\overline{\mathrm{IRQB}}$ when IRQB2 Flag (bit 6) is set.

CB2 OUTPUT MODE (BIT $5=1$ )

| Bit 6 | NOT USED |
| :---: | :---: |
| 0 | Always zero. |
| Bit 5 | CB2 MODE SELECT |
| 1 | Select CB2 Output Mode. |
| Bit 4 | CB2 OUTPUT CONTROL |
| 1 | CB2 goes low when a zero is written into CRB bit 3. CB2 goes high when a one is written into CRB bit 3. |
| 0 | CB2 goes low on the first negative (high-to-low) $\emptyset 2$ clock transition following a write to Output Register B. CB2 returns high as specified by bit 3 . |
| Bit 3 | CB2 WRITE STROBE RESTORE CONTROL (BIT $4=0$ ) |
| 1 | CB2 returns high on the next $\emptyset 2$ clock negative transition following a write to Output Register B. |
| 0 | CB2 returns high on the next active CB1 transition following a write to Output Register B as specified by bit 1 . |

Bit 5 CB2 MODE SELECT
1 Select CB2 Output Mode.
Bit 4 CB2 OUTPUT CONTROL
$1 \quad$ CB2 goes low when a zero is written into CRB bit 3.
$0 \quad$ CB2 goes low clock transition following a write to Output Register B. CB2 returns high as specified by bit 3 .

Bit 3 CB2 WRITE STROBE RESTORE CONTROL (BIT $4=0$ )
CB2 returns high on the next 02 clock negative transition following a write to Output Register B. following a write to Output Register B as specified by bit 1.

Figure 4. Control Line Operations Summary (2 of 2)

A second output mode allows CA2 to be used in conjunction with CA1 to "handshake" between the processor and the peripheral device. On the A side, this technique allows positive control of data transfers from the peripheral device into the microprocessor. The CA1 input signals the processor that data is available by interrupting the processor. The processor reads the data and sets CA2 low. This signals the peripheral device that it can make new data available.

The final output mode can be selected by setting bit 4 of CRA to a 1 . In this mode, CA2 is a simple peripheral control output which can be set high or low by setting bit 3 or CRA to a 1 or a 0 respectively.

CB1 operates as an interrupt input only in the same manner as CA1. Bit 7 of CRB is set by the active transition selected by bit 0 of CRB. Likewise, the CB2 input mode operates exactly the same as the CA2 input modes. The CB2 output modes, CRB bit $5=1$, differ somewhat from those of CA2. The pulse output occurs when the processor writes data into the Peripheral B Output Register. Also, the "handshaking" operates on data transfers from the processor into the peripheral device.

## READING THE PERIPHERAL A I/O PORT

Performing a Read operation with RS1 $=0$, RS0 $=0$ and the Data Direction Register Access Control bit (CRA-2) $=1$, directly
transfers the data on the Peripheral A I/O lines to the data bus. In this situation, the data bus will contain both the input and output data. The processor must be programmed to recognize and interpret only those bits which are important to the particular peripheral operation being performed.

Since the processor always reads the Peripheral A I/O port pins instead of the actual Peripheral Output Register (ORA), it is possible for the data read by the processor to differ from the contents of the Peripheral Output Register for an output line. This is true when the I/O pin is not allowed to go to a full +2.4 V DC when the Peripheral Output register contains a logic 1. In this case, the processor will read a 0 from the Peripheral A pin, even though the corresponding bit in the Peripheral Output register is a 1.

## READING THE PERIPHERAL B I/O PORT

Reading the Peripheral BI/O port yields a combination of input and output data in a manner similar to the Peripheral A port. However, data is read directly from the Peripheral B Output Register (ORB) for those lines programmed to act as outputs. It is therefore possible to load down the Peripheral B Output lines without causing incorrect data to be transferred back to the processor on a Read operation.


Figure 5. Read Timing Waveforms


Figure 6. Write Timing Waveforms

BUS TIMING CHARACTERISTICS

| Parameter | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $\emptyset 2$ Cycle | ${ }^{\text {cher }}$ | 1.0 | - | 0.5 | - | $\mu \mathrm{S}$ |
| 02 Pulse Width | $\mathrm{t}_{\mathrm{C}}$ | 0.47 | 5 | 0.24 | 5 | $\mu \mathrm{S}$ |
| Ø2 Rise and Fall Time | $t_{r c}, t_{f c}$ | - | 25 | - | 15 | ns |

## READ TIMING

| Address Set-Up Time | $t_{\text {ACR }}$ | 180 | - | 90 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address Hold Time | $t_{\text {CAR }}$ | 0 | - | 0 | - | ns |
| Peripheral Data Set-Up Time | $t_{\text {PCR }}$ | 300 | - | 150 | - | ns |
| Data Bus Delay Time | ${ }^{\text {chen }}$ | - | 395 | - | 190 | ns |
| Data Bus Hold Time | $t_{\text {HR }}$ | 10 | - | 10 | - | ns |

## WRITE TIMING

| Address Set-Up Time | $\mathrm{t}_{\text {ACW }}$ | 180 | - | 90 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address Hold Time | $t_{\text {caw }}$ | 0 | - | 0 | - | ns |
| R/W Set-Up Time | $\mathrm{t}_{\text {WCW }}$ | 130 | - | 65 | - | ns |
| R/ $\bar{W}$ Hold Time | $\mathrm{t}_{\text {cWW }}$ | 50 | - | 25 | - | ns |
| Data Bus Set-Up Time | $\mathrm{t}_{\mathrm{DCW}}$ | 300 | - | 150 | - | ns |
| Data Bus Hold Time | $\mathrm{t}_{\mathrm{HW}}$ | 10 | - | 10 | - | ns |

PERIPHERAL INTERFACE TIMING

| Peripheral Data Set-Up | $t_{\text {PCR }}$ | 300 | - | 150 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Peripheral Data Delay Time | $t_{\text {CDW }}$ | - | 1.0 | - | 0.5 | $\mu \mathrm{S}$ |
| Peripheral Data Delay Time to CMOS Level | $\mathrm{t}_{\mathrm{CMOS}}$ | - | 2.0 | - | 1.0 | $\mu \mathrm{S}$ |
| ¢2 Low to CA2 Low Delay | $\mathrm{t}_{\mathrm{CA} 2}$ | - | 1.0 | - | 0.5 | $\mu \mathrm{S}$ |
| ¢2 Low to CA2 High Delay | $\mathrm{t}_{\mathrm{RS} 1}$ | - | 1.0 | - | 0.5 | $\mu \mathrm{S}$ |
| CA1 Active to CA2 High Delay | $\mathrm{t}_{\text {RS2 }}$ | - | 2.0 | - | 1.0 | $\mu \mathrm{S}$ |
| $\emptyset 2$ High to CB2 Low Delay | ${ }^{\text {t }} \mathrm{CB} 2$ | - | 1.0 | - | 0.5 | $\mu \mathrm{S}$ |
| Peripheral Data Valid to CB2 Low Delay | $t_{\text {DC }}$ | 0 | 1.5 | 0 | 0.75 | $\mu \mathrm{S}$ |
| Ø2 High to CB2 High Delay | $\mathrm{t}_{\text {fS1 }}$ | - | 1.0 | - | 0.5 | $\mu \mathrm{S}$ |
| CB1 Active to CB2 High Delay | $\mathrm{t}_{\text {RS2 }}$ | - | 2.0 | - | 1.0 | $\mu \mathrm{S}$ |
| CA1, CA2, CB1 and CB2 Input Rise and Fall Time | $t_{\text {r }}, \mathrm{t}_{\text {f }}$ | - | 1.0 | - | 1.0 | $\mu \mathrm{S}$ |

## ABSOLUTE MAXIMUM RATINGS*

| Parameter | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | Vdc |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | -0.3 to $+\mathrm{V}_{\mathrm{CC}}$ | Vdc |
| Operating Temperature Range <br> Commercial <br> Industrial | $\mathrm{T}_{\mathrm{A}}$ | $\mathrm{T}_{\mathrm{L}} \mathrm{T}_{\mathrm{H}}$ | ${ }^{\circ} \mathrm{C}$ |
| 0 to +70 |  |  |  |
| -40 to +85 |  |  |  |
| Storage Temperature |  | $\mathrm{T}_{\text {STG }}$ | -55 to +150 |${ }^{\circ} \mathrm{C}$.

*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## OPERATING CONDITIONS

| Parameter | Symbol | Value |
| :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $5 \mathrm{~V} \pm 5 \%$ |
| Temperature Range | $\mathrm{T}_{\mathrm{A}}$ |  |
| Commercial <br> Industrial |  | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |

## DC CHARACTERISTICS

$\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{S S}=0, T_{A}=T_{L}\right.$ to $T_{H}$, unless otherwise noted)

| Parameter | Symbol | Min. | Typ. ${ }^{3}$ | Max. | Unit ${ }^{1}$ | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | +2.0 | - | $\mathrm{V}_{\mathrm{cc}}$ | V |  |
| Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ | -0.3 | - | +0.8 | V |  |
| ```Input Leakage Current R/\overline{W},\overline{RES}, RS0, RS1, CS0, CS1, \overline{CS2,} CA1, CB1, प2``` | $\mathrm{I}_{\mathrm{IN}}$ | - | $\pm 1$ | $\pm 2.5$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{1 \mathrm{~N}}=0 \mathrm{~V} \text { to } 5.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=0 \mathrm{~V} \end{aligned}$ |
| Input Leakage Current for Three-State Off D0-D7, PB0-PB7, CB2 | $\mathrm{I}_{\text {TSI }}$ | - | $\pm 2$ | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & V_{C C}=5.25 \mathrm{~V} \end{aligned}$ |
| Input High Current PAO-PA7, CA2 | $I_{I H}$ | -100 | -250 | - | $\mu \mathrm{A}$ | $\mathrm{V}_{1 \mathrm{H}}=2.4 \mathrm{~V}$ |
| Input Low Current PA0-PA7, CA2 | $1 / 2$ | - | -1 | -1.6 | mA | $\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V}$ |
| Output High Voltage <br> All outputs PB0-PB7, CB2 (Darlington Drive) | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & 2.4 \\ & 1.5 \end{aligned}$ | - | - | $\begin{aligned} & \mathrm{V} \\ & \mathrm{~V} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\text {LOAD }}=-1.0 \mathrm{~mA} \end{aligned}$ |
| Output Low Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | - | +0.4 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{LOAD}}=1.6 \mathrm{~mA} \end{aligned}$ |
| Output High Current (Sourcing) <br> Logic <br> PB0-PB7, CB2 (Darlington Drive) | $\mathrm{I}_{\mathrm{OH}}$ | $\begin{aligned} & -100 \\ & -1.0 \end{aligned}$ | $\begin{gathered} -1000 \\ -2.5 \end{gathered}$ | $\begin{gathered} - \\ -10 \\ \hline \end{gathered}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V} \end{aligned}$ |
| Output Low Current (Sinking) | IOL | 1.6 | - | - | mA | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| Output Leakage Current (Off State) IRQA, $\overline{\text { IRQB }}$ | Ioff | - | 1 | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ |  | 200 | 500 | mW |  |
| Input Capacitance D0-D7, PAO-PA7, PB0-PB7, CA2, CB2 R $\bar{W}, \overline{R E S}, R S 0, R S 1, ~ C S 0, ~ C S 1, ~ \overline{C S 2} 2$ CA1, CB1, $\emptyset 2$ | $\mathrm{C}_{\text {IN }}$ | - | - | $\begin{aligned} & 10 \\ & 7.0 \\ & 20 \end{aligned}$ | pF | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\ & \mathrm{f}=1 \mathrm{MHz} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |
| Output Capacitance | $\mathrm{C}_{\text {OUT }}$ | - | - | 10 | pF |  |
| Notes: <br> 1. All units are direct current (dc) except for capacitance. <br> 2. Negative sign indicates outward current flow, positive indicates inward flow. <br> 3. Typical values are shown for $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$. |  |  |  |  |  |  |

## PACKAGE DIMENSIONS

## 40-PIN CERAMIC DIP



SEATING PLANE


## 40-PIN PLASTIC DIP



|  | MILLIMETERS |  |  | INCHES |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
| DIM | MIN | MAX | MIN | MAX |  |
| A | 5128 | 5232 | 2040 | 2060 |  |
| B | 1372 | 1422 | 0540 | 0560 |  |
| C | 355 | 508 | 0140 | 0200 |  |
| D | 036 | 051 | 0014 | 0020 |  |
| F | 102 | 152 | 0040 | 0060 |  |
| G | 254 | BSC | 0100 |  |  |
| BSC |  |  |  |  |  |
| H | 165 | 216 | 0065 | 0085 |  |
| J | 020 | 030 | 0008 | 0012 |  |
| K | 3.30 | 4.32 | 0.130 | 0.170 |  |
| L | 1524 | BSC | 0600 | BSC |  |
| M | 7 | 10 | 7 | 10 |  |
| N | 051 | 102 | 0020 | 0040 |  |

## R6522 <br> Versatile Interface Adapter (VIA)

## DESCRIPTION

The R6522 Versatile Interface Adapter (VIA) is a very flexible I/O control device. In addition, this device contains a pair of very powerful 16-bit interval timers, a serial-to-parallel/parallel-to serial shift register and input data latching on the peripheral ports. Expanded handshaking capability allows control of bidirectional data transfers between VIA's in multiple processor systems.

The R6522 includes functions for programmed control of up to two peripheral devices (Ports A and B). These two program controlled 8 -bit bidirectional peripheral I/O ports allow direct interfacing between the microprocessor and selected peripheral units. Each port has input data latching capability. Two programmable Data Direction Registers (A and B) allow selection of data direction (input or output) on an individual line basis.

The R6522 also has two programmable 16-bit Interval Timer/Counters with latches. Timer 1 may be operated in a OneShot Interrupt Mode with interrupts on each count-to-zero, or in a Free-Run Mode with a continuous series of evenly spaced interrupts. Timer 2 functions as both an interval and pulse counter. Serial data transfers are provided by a serial-to-parallel/parallel-to-serial shift register. Application versatility is further increased by various control registers, including-the Interrupt Flag Register, the Interrupt Enable Register, the Auxiliary Control Register and the Peripheral Control Register.

ORDERING INFORMATION


## FEATURES

- Two 8-bit bidirectional I/O ports
- Two 16-bit programmable timer/counters
- Serial bidirectional peripheral I/O
- TTL compatible peripheral control lines
- Expanded "handshake" capability allows positive control of data transfers between processor and peripheral devices.
- Latched output and input registers on both I/O ports
- 1 and 2 MHz operation
- Commercial and industrial temperature range versions
- Single +5 Vdc power requirement

Figure 1. R6522 Pin Assignments

## INTERFACE SIGNALS

Figure 1 (on the front page) shows the R6522 VIA pin assignments and Figure 2 groups the signals by functional interface.

## RESET ( $\overline{\text { RES }}$ )

Reset (RES) clears all internal registers (except T1 and T2 counters and latches, and the Shift Register (SR) ). In the $\overline{\text { RES }}$ condition, all peripheral interface lines ( PA and PB ) are placed in the input state. Also, the Timers (T1 and T2), SR and interrupt logic are disabled from operation.

## INPUT CLOCK (PHASE 2)

The system Phase 2 ( $\emptyset 2$ ) Input Clock controls all data transfers between the R6522 and the microprocessor.

## READ/WRITE (R/W)

The direction of the data transfers between the R6522 and the system processor is controlled by the R/W line in conjunction with the CS1 and $\overline{C S 2}$ inputs. When $R \bar{W}$ is low (write operation) and the R6522 is selected, data is transferred from the processor bus into the selected R6522 register. When $R \bar{W}$ is high (read operation) and the R6522 is selected, data is transferred from the selected R6522 register to the processor bus.

## DATA BUS (DO-D7)

The eight bidirectional Data Bus lines transfer data between the R6522 and the microprocessor. During a read operation, the contents of the selected R6522 internal register are transferred to the microprocessor via the Data Bus lines. During a write operation, the Data Bus lines serve as high impedance inputs over which data is transferred from the microprocessor to a selected R6522 register. The Data Bus lines are in the high impedance state when the R6522 is unselected.

## CHIP SELECTS (CS1, CS2)

Normally, the two chip select lines are connected to the microprocessor address lines. This connection may be direct or through decoding. To access a selected R6522 register, CS1 must be high (logic 1) and CS2 must be low (logic 0 ).

## REGISTER SELECTS (RS0-RS3)

The Register Select inputs allow the microprocessor to select one of 16 internal registers within the R6522. Refer to Table 1 for Register Select coding and a functional description.

## REGISTER SELECTS (RS0-RS3)

The Register Select inputs allow the microprocessor to select one of 16 internal registers within the R6522. Refer to Table 1 for Register Select coding and a functional description.

## INTERRUPT REQUEST ( $\overline{\text { IRQ }})$

The Interrupt Request ( $\overline{\mathrm{IRQ}}$ ) output signal is generated whenever an internal Interrupt Flag bit is set and the corresponding Interrupt Enable bit is a Logic 1. The Interrupt Request output is an


Figure 2. R6522 VIA Interface Signals
open-drain configuration, thus allowing the $\overline{\mathrm{RQ}}$ signal to be wire-ORed to a common microprocessor IRQ input line.

## PORT A DATA LINES (PAO-PA7)

Peripheral Data Port A is an 8-line, bidirectional bus for the transfer of data, control and status information between the R6522 and a peripheral device. Each Peripheral Data Port bus line may be individually programmed as either an input or output under control of a Data Direction Register. Data flow direction may be selected on a line-by-line basis with intermixed input and output lines within the same port. When a " 0 " is written to any bit position of the Data Direction Register, the corresponding line will be programmed as an input. When a " 1 " is written into any bit position of the register, the corresponding data line will serve as an output. Polarity of the data output is determined by the Output Register, while input data may be latched into the Input Register under control of the CA1 line. All modes are program controlled by the microprocessor by way of the R6522's internal control registers. Each Peripheral Data Port line represents one TTL load in the input mode and will drive one standard TTL load in the output mode. A typical output circuit for Peripheral Data Port $A$ is shown in Figure 3.

## PORT A CONTROL LINES (CA1, CA2)

Control lines CA1 and CA2 serve as interrupt inputs or handshake outputs for Peripheral Data Port A. Each line controls an internal Interrupt Flag with a corresponding Interrupt Enable bit. CA1 also controls the latching of Input Data on Port A. CA1 is a high impedance input, while CA2 represents one standard TTL load in the input mode. In the output mode, CA2 will drive one standard TTL load.

## PORT B DATA LINES (PB0-PB7)

Peripheral Data Port B is an 8 -line, bidirectional bus which is controlled by an Output Register, Input Register and Data Direction Register in a manner much the same as Data Port A. With respect to Port B, the output signal on line PB7 may be controlled by Timer 1 while Timer 2 may be programmed to count pulses on the PB6 line. Port B lines represent one standard TTL load in the input mode and will drive one TTL load in the output mode. Port B lines are also capable of sourcing 1.0 mA at 1.5 Vdc in the output mode. This allows the outputs to directly drive Darlington transistor circuits. A typical output circuit for Port $B$ is shown in Figure 3.

## PORT B CONTROL LINES (CB1, CB2)

Control lines CB1 and CB2 serve as interrupt inputs or handshake outputs for Peripheral Data Port B. Like Port A, these two control lines control an internal Interrupt Flag with a corresponding Interrupt Enable bit. Similar to CA1, CB1 controls the latching of input data on Port B . These lines also serve as a serial data port under control of the Shift Register (SR). Each control line represents one standard TTL load in the input mode and can drive one TTL load in the output mode. CB2 can also drive a Darlington transistor circuit; however, CB1 cannot.

Table 1. R6522 Register Addressing

| Register Number | RS Coding |  |  |  | $\begin{aligned} & \text { Register } \\ & \text { Desla. } \end{aligned}$ | Register/Description |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | RS3 | RS2 | RS1 | RSO |  | Write ( $\mathrm{R} / \mathrm{W}=\mathrm{L}$ ) | Read ( $\mathrm{R} / \overline{\mathrm{W}}=\mathrm{H}$ ) |
| 0 | 0 | 0 | 0 | 0 | ORB/IRB | Output Register B | Input Register B |
| 1 | 0 | 0 | 0 | 1 | ORA/IRA | Output Register A | Input Register A |
| 2 | 0 | 0 | 1 | 0 | DDRB | Data Direction Register B |  |
| 3 | 0 | 0 | 1 | 1 | DDRA | Data Direction Register A |  |
| 4 | 0 | 1 | 0 | 0 | T1C-L | T1 Low-Order Latches | T1 Low-Order Counter |
| 5 | 0 | 1 | 0 | 1 | T1C-H | T1 High-Order Counter |  |
| 6 | 0 | 1 | 1 | 0 | T1L-L | T1 Low-Order Latches |  |
| 7 | 0 | 1 | 1 | 1 | T1L-H | T1 High-Order Latches |  |
| 8 | 1 | 0 | 0 | 0 | T2C-L | T2 Low-Order Latches | T2 Low-Order Counter |
| 9 | 1 | 0 | 0 | 1 | T2C-H | T2 High-Order Counter |  |
| 10 | 1 | 0 | 1 | 0 | SR | Shift Register |  |
| 11 | 1 | 0 | 1 | 1 | ACR | Auxiliary Control Register |  |
| 12 | 1 | 1 | 0 | 0 | PCR | Peripheral Control Register |  |
| 13 | 1 | 1 | 0 | 1 | IFR | Interrupt Flag Register |  |
| 14 | 1 | 1 | 1 | 0 | IER | Interrupt Enable Register |  |
| 15 | 1 | 1 | 1 | 1 | ORAIRA | Output Register $\mathrm{A}^{*}$ | Input Register ${ }^{*}$ * |
| NOTE: *Same as Register 1 except no handshake. |  |  |  |  |  |  |  |



Figure 3. Port A and B Output Circuits

## FUNCTIONAL DESCRIPTION

The internal organization of the R6522 VIA is illustrated in Figure 4.

## PORT A AND PORT B OPERATION

The R6522 VIA has two 8-bit bidirectional I/O ports (Port A and Port B) and each port has two associated control lines.

Each 8-bit peripheral port has a Data Direction Register (DDRA, DDRB) for specifying whether the peripheral pins are to act as inputs or outputs. A " 0 " in a bit of the Data Direction Register causes the corresponding peripheral pin to act as an input. A " 1 " causes the pin to act as an output.

Each peripheral pin is also controlled by a bit in the Output Register (ORA, ORB) and the Input Register (IRA, IRB). When the pin is programmed as an output, the voltage on the pin is controlled by the corresponding bit of the Output Register. A " 1 " in the Output Register causes the output to go high, and a " 0 " causes the output to go low. Data may be written into Output

Register bits corresponding to pins which are programmed as inputs. In this case, however, the output signal is unaffected.

Reading a peripheral port causes the contents of the Input Register (IRA, IRB) to be transferred onto the Data Bus. With input latching disabled, IRA will always reflect the levels on the PA pins. With input latching enabled, IRA will reflect the levels on the PA pins at the time the latching occurred (via CA1).

The IRB register operates similar to the IRA register. However, for pins programmed as outputs there is a difference. When reading IRA, the level on the pin determines whether a " 0 " or a " 1 " is sensed. When reading IRB, however, the bit stored in the output register, ORB, is the bit sensed. Thus, for outputs which have large loading effects and which pull an output " 1 " down or which pull an output " 0 " up, reading IRA may result in reading a " 0 " when a " 1 " was actually programmed, and reading a " 1 " when a " 0 " was programmed. Reading IRB, on the other hand, will read the " 1 " or " 0 " level actually programmed, no matter what the loading on the pin.

Figures 5 through 8 illustrate the formats of the port registers.


Figure 4. R6522 VIA Block Diagram

## HANDSHAKE CONTROL OF DATA TRANSFERS

The R6522 allows positive control of data transfers between the system processor and peripheral devices through the operation of "handshake" lines. Port A lines (CA1, CA2) handshake data on both a read and a write operation while the Port B lines (CB1, CB2) handshake on a write operation only.

## Read Handshake

Positive control of data transfers from peripheral devices into the system processor can be accomplished very effectively using Read Handshaking. In this case, the peripheral device must generate the equivalent of a "Data Ready" signal to the processor signifying that valid data is present on the peripheral


Figure 5. Output Register B (ORB), Input Register B (IRB)


Figure 7. Data Direction Register B (DDRB)
port. This signal normally interrupts the processor, which then reads the data, causing generation of a "Data Taken" signal. The peripheral device responds by making new data available. This process continues until the data transfer is complete.

In the R6522, automatic "Read" Handshaking is possible on the Peripheral A port only. The CA1 interrupt input pin accepts the "Data Ready" signal and CA2 generates the "Data Taken" signal. The "Data Ready" signal will set an internal flag which may interrupt the processor or which may be polled under program control. The "Data Taken" signal can either be a pulse or a level which is set low by the system processor and is cleared by the "Data Ready" signal. These options are shown in Figure 9 which illustrates the normal Read Handshake sequence.


Figure 6. Output Register A (ORA), Input Register A (IRA)


Figure 8. Data Direction Register A (DDRA)


Figure 9. Read Handshake Timing (Port A Only)

## Write Handshake

The sequence of operations which allows handshaking data from the system processor to a peripheral device is very similar to that described for Read Handshaking. However, for Write Handshaking, the R6522 generates the "Data Ready" signal and the peripheral device must respond with the "Data Taken" signal. This can be accomplished on both the PA port and the PB port on the R6522. CA2 or CB2 act as a "Data Ready" output in either the handshake mode or pulse mode and CA1 or CB1 accept the "Data Taken" signal from the peripheral device, setting the interrupt flag and clearing the "Data Ready" output. This sequence is shown in Figure 10.

## Latching

The PA port and the PB port on the R6522 can be enabled in the Auxiliary Control Register (Figure 14) to be latched by their individual port control lines (CA1, CB1). Latching is selectable to be on the rising or falling edge of the signal at each individual port control line. Selection of operating modes for CA1, CA2, CB1 and CB2 is accomplished by the Peripheral Control Register (Figure 11).


Figure 11. Peripheral Control Register (PCR)


Figure 10. Write Handshake Timing

## COUNTER/TIMERS

There are two independent 16 -bit counter/timers (called Timer 1 and Timer 2) in the R6522. Each timer is controlled by writing bits into the Auxiliary Control Register (ACR) to select the mode of operation (Figure 14).

## Timer 1 Operation

Interval Timer T1 consists of two 8-bit latches (Figure 12) and a 16-bit counter (Figure 13). The latches store data which is to be loaded into the counter. After loading, the counter decrements at $\emptyset 2$ clock rate. Upon reaching zero, an interrupt flag is set, and IRQ goes low if the T1 interrupt is enabled. Timer 1 then
disables any further interrupts and automatically transfers the contents of the latches into the counter and continues to decrement. In addition, the timer may be programmed to invert the output signal on peripheral pin PB7 each time it "times-out". Each of these modes is discussed separately below.

Note that the processor does not write directly into the low-order counter (T1C-L). Instead, this half of the counter is loaded automatically from the low order latch (T1L-L) when the processor writes into the high order counter (T1C-H). In fact, it may not be necessary to write to the low order counter in some applications since the timing operation is triggered by writing to the high order latch.

REG 6-TIMER 1 LOW-ORDER LATCH


WRITE - 8 BITS LOADED INTO T1 LOW-ORDER LATCHES THIS OPERATION IS NO DIFFERENT THAN A WRITE INTO REG 4
READ - 8 BITS FROM T1 LOW.ORDER LATCHES
TRANSFERRED TO MPU UNLIKE REG 4
OPERATION, THIS DOES NOT CAUSE
RESET OF T1 INTERRUPT FLAG

REG 7-TIMER 1 HIGH-ORDER LATCH


WRITE - 8 BITS LOADED INTO T1 HIGH-ORDER LATCHES UNLIKE REG 4 OPERATION NO LATCH-TO-COUNTER TRANSFERS TAKE PLACE.
READ - 8 BITS FROM T1 HIGH-ORDER LATCHES TRANSFERRED TO MPU.

Figure 12. Timer 1 (T1) Latch Registers

REG 4-TIMER 1 LOW-ORDER COUNTER


WRITE - 8 BITS LOADED INTO TI LOW-ORDER
LATCHES. LATCH CONTENTS ARE
TRANSFERRED INTO LOW-ORDER COUNTER AT THE TIME THE HIGH-
ORDER COUNTER IS LOADED (REG 5)
READ - 8 BITS FROM T1 LOW-ORDER COUNTER 8 BITS FROM T1 LOW-ORDER COUNTER
TRANSFERRED TO MPU. IN ADDITION, T1 INTERRUPT FLAG IS RESET (BIT 6 IN INTERRUPT FLAG REGISTER).

REG 5-TIMER 1 HIGH-ORDER COUNTER


WRITE - 8 BITS LODED INTO TI HIGH-ORDER
LATCHES. ALSO, AT THIS TIME BOTH HIGH- AND LOW-ORDER LATCHES TRANSFERRED INTO T1 COUNTER.
READ - 8 IBTS FROM T1 HIGH-ORDER COUNTER
TRANSFERRED TO MPU

Figure 13. Timer 1 (T1) Counter Registers


Figure 14. Auxiliary Control Register (ACR)

## Timer 1 One-Shot Mode

The Timer 1 one-shot mode generates a single interrupt for each timer load operation. As with any interval timer, the delay between the "write T1C-H" operation and generation of the processor interrupt is a direct function of the data loaded into the timing counter. In addition to generating a single interrupt, Timer 1 can be programmed to produce a single negative pulse on the PB7 peripheral pin. With the output enabled (ACR7 $=1$ ) a "write T1C-H" operation will cause PB7 to go low. PB7 will return high when Timer 1 times out. The result is a single programmable width pulse.

Timing for the R6522 interval timer one-shot modes is shown in Figure 15.

In the one-shot mode, writing into the T1L-H has no effect on the operation of Timer 1. However, it will be necessary to assure
that the low order latch contains the proper data before initiating the count-down with a "write T1C-H" operation. When the processor writes into the high order counter (T1C-H), the T1 interrupt flag will be cleared, the contents of the low order latch will be transferred into the low order counter, and the timer will begin to decrement at system clock rate. If the PB7 output is enabled, this signal will go low on the falling edge of $\emptyset 2$ following the write operation. When the counter reaches zero, the T1 interrupt flag will be set, the $\overline{\mathrm{RQ}}$ pin will go low (interrupt enabled), and the signal on PB7 will go high. At this time the counter will continue to decrement at system clock rate. This allows the system processor to read the contents of the counter to determine the time since interrupt. However, the T1 interrupt flag cannot be set again unless it has been cleared as described in this specification.


Figure 15. Timer 1 One-Shot Mode Timing

## Timer 1 Free-Run Mode

The most important advantage associated with the latches in T1 is the ability to produce a continuous series of evenly spaced interrupts and the ability to produce a square wave on PB7 whose frequency is not affected by variations in the processor interrupt response time. This is accomplished in the "free-running" mode.

In the free-running mode, the interrupt flag is set and the signal on PB7 is inverted each time the counter reaches zero at which time the timer automatically transfers the contents of the latch into the counter ( 16 bits) and continues to decrement from there. The interrupt flag can be cleared by writing T1C-H or T1L-H, by reading T1C-L, or by writing directly into the flag as described later. However, it is not necessary to rewrite the timer to enable setting the interrupt flag on the next time-out.

All interval timers in the R6522 are "re-triggerable". Rewriting the counter will always re-initialize the time-out period. In fact,
the time-out can be prevented completely if the processor continues to rewrite the timer before it reaches zero. Timer 1 will operate in this manner if the processor writes into the high order counter (T1C-H). However, by loading the latches only, the processor can access the timer during each down-counting operation without affecting the time-out in process. Instead, the data loaded into the latches will determine the length of the next timeout period. This capability is particularly valuable in the freerunning mode with the output enabled. In this mode, the signal on PB7 is inverted and the interrupt flag is set with each timeout. By responding to the interrupts with new data for the latches, the processor can determine the period of the next half cycle during each half cycle of the output signal on PB7. In this manner, very complex waveforms can be generated.

A precaution to take in the use of PB7 as the timer output concerns the Data Direction Register contents for PB7. Both DDRB bit 7 and ACR bit 7 must be 1 for PB7 to function as the timer output. If one is 1 and other is 0 , then PB7 functions as a normal outpin pin, controlled by ORB bit 7.


Figure 16. Timer 1 Free-Run Mode Timing

## Timer 2 Operation

Timer 2 operates as an interval timer (in the "one-shot" mode only), or as a counter for counting negative pulses on the PB6 peripheral pin. A single control bit in the Auxiliary Control Register selects between these two modes. This timer is comprised of a "write-only" lower-order latch (T2L-L), a "read-only" low-order counter (T2C-L) and a read/write high order counter (T2C-H). The counter registers act as a 16 -bit counter which decrements at Ø2 rate. Figure 17 illustrates the T2 Latch/Counter Registers.

## Timer 2 One-Shot Mode

As an interval timer, T2 operates in the "one-shot" mode similar to Timer 1. In this mode, T2 provides a single interrupt for each "write T2C-H" operation. After timing out, the counter will continue to decrement. However, setting of the interrupt flag is disabled after initial time-out so that it will not be set by the counter
decrementing again through zero. The processor must rewrite T2C-H to enable setting of the interrupt flag. The interrupt flag is cleared by reading T2C-L or by writing T2C-H. Timing for this operation is shown in Figure 18.

## Timer 2 Pulse Counting Mode

In the pulse counting mode, T2 counts a predetermined number of negative-going pulses on PB6. This is accomplished by first loading a number into T 2 . Writing into $\mathrm{T} 2 \mathrm{C}-\mathrm{H}$ clears the interrupt flag and allows the counter to decrement each time a pulse is applied to PB6. The interrupt flag is set when T2 counts down past zero. The counter will then continue to decrement with each pulse on PB6. However, it is necessary to rewrite T2C-H to allow the interrupt flag to set on a subsequent time-out. Timing for this mode is shown in Figure 19. The pulse must be low on the leading edge of $\emptyset 2$.


Figure 17. Timer 2 (T2) Latch/Counter Registers


Figure 18. Timer 2 One-Shot Mode Timing


Figure 19. Timer 2 Pulse Counting Mode

## SHIFT REGISTER OPERATION

The Shift Register (SR) performs serial data transfers into and out of the CB2 pin under control of an internal modulo-8 counter. Serial data transfer in and out of the Shift Register (SR) begin with the most significant bit (MSB) first. Shift pulses can be applied to the CB1 pin from an external source or, with the proper mode selection, shift pulses generated internally will appear on the CB1 pin for controlling external devices.

The control bits which select the various shift register operating modes are located in the Auxiliary Control Register. Figure 20 illustrates the configuration of the SR data bits and Figure 21 shows the SR control bits of the ACR.

## SR Mode 0 - Shift Register Interrupt Disabled

Mode 0 disables the Shift Register interrupt. In this mode the microprocessor can write or read the SR and the SR will shift on each CB1 positive edge shifting in the value on CB2. In this mode the SR interrupt Flag is disabled (held to a logic 0 ).

## SR Mode 1 - Shift In Under Control of T2

In mode 1, the shifting rate is controlled by the low order 8 bits of T2 (Figure 22). Shift pulses are generated on the CB1 pin to control shifting in external devices. The time between transitions
of this output clock is a function of the system clock period and the contents of the low order T2 latch (N).

The shifting operation is triggered by the read or write of the SR if the SR flag is set in the IFR. Otherwise the first shift will occur at the next time-out of T2 after a read or write of the SR. The input data should change before the positive-going edge of CB1 clock pulse. This data is shifted into the shift register during the ф2 clock cycle following the positive-going edge of the CB1 clock pulse. The minimum CB1 positive pulse width must be one clock period. After 8 CB1 clock pulses, the shift register interrupt flag will set and $\overline{\mathrm{IRQ}}$ will go low.

## SR Mode 2 - Shift In Under 02 Control

In mode 2, the shift rate is a direct function of the system clock frequency (Figure 23). CB1 becomes an output which generates shift pulses for controlling external devices. Timer 2 operates as an independent interval timer and has no effect on SR. The shifting operation is triggered by reading or writing the Shift Register. Data is shifted, first into bit 0 and is then shifted into the next higher order bit of the shift register on the trailing edge of each $\emptyset 2$ clock pulse. After 8 clock pulses, the shift register interrupt flag will be set, and the output clock pulses on CB1 will stop.

REG 11-AUXILIARY CONTROL REGISTER

Figure 21. Shift Register Modes


| 4 | 3 | 2 | OPERATION |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | DISABLED |
| 0 | 0 | 1 | SHIFT IN UNDER CONTROL OF T2 |
| 0 | 1 | 0 | SHIFT IN UNDER CONTROL OF ' 2 |
| 0 | 1 | 1 | SHIFT IN UNDER CONTROL OF EXT CLK |
| 1 | 0 | 0 | SHIFT OUT FREE RUNNING AT T2 RATE |
| 1 | 0 | 1 | SHIFT OUT UNDER CONTROL OF T2 |
| 1 | 1 | 0 | SHIFT OUT UNDER CONTROL OF $l_{2}$ |
| 1 | 1 | 1 | SHIFT OUT UNDER CONTROL OF EXT CLK |

Figure 20. Shift Register


Figure 22. SR Mode 1 - Shift In Under T2 Control

## SR Mode 3 - Shift In Under CB1 Control

In mode 3, external pin CB1 becomes an input (Figure 24). This allows an external device to load the shift register at its own pace. The shift register counter will interrupt the processor each time 8 bits have been shifted in. The shift register stops after 8 counts and must be reset to start again. Reading or writing the Shift Register resets the Interrupt Flag and initializes the SR counter to count another 8 pulses.
Note that the data is shifted during the first system clock cycle following the positive-going edge of the CB1 shift pulse. For this reason, data must be held stable during the first full cycle following CB1 going high. The minimum CB1 positive pulse width must be one clock period.

SR Mode 4 - Shift Out Under T2 Control (Free-Run) Mode 4 is very similar to mode 1 in which the shifting rate is set by T2. However, in mode 4 the SR Counter does not stop
the shifting operation (Figure 25). Since the Shift Register bit 7 (SR7) is recirculated back into bit 0 , the 8 bits loaded into the shift register will be clocked onto CB2 repetitively. In this mode the shift register counter is disabled.

## SR Mode 5 - Shift Out Under T2 Control

In mode 5, the shift rate is controlled by T2 (as in mode 1). The shifting operation is triggered by the read or write of the SR if the SR flag is set in the IFR (Figure 26). Otherwise the first shift will occur at the next time-out of T2 after a read or write of the SR. However, with each read or write of the shift register the SR Counter is reset and 8 bits are shifted onto CB2. At the same time, 8 shift pulses are generated on CB1 to control shifting in external devices. After the 8 shift pulses, the shifting is disabled, the SR Interrupt Flag is set and CB2 remains at the last data level.


Figure 23. SR Mode 2 - Shift In Under $\mathbf{Q}^{2}$ Control


Figure 24. SR Mode 3 - Shift In Under CB1 Control


Figure 25. SR Mode 4 - Shift Out Under T2 Control (Free-Run)

SR Mode 6 - Shift Out Under 02 Control
In mode 6, the shift rate is controlled by the $\emptyset 2$ system clock (Figure 27).

## SR Mode 7 - Shift Out Under CB1 Control

In mode 7, shifting is controlled by pulses applied to the CB1 pin by an external device (Figure 28). The SR counter sets the SR

Interrupt Flag each time it counts 8 pulses but it does not disable the shifting function. Each time the microprocessor, writes or reads the shift register, the SR Interrupt Flag is reset and the SR counter is initialized to begin counting the next 8 shift pulses on pin CB1. After 8 shift pulses, the Interrupt Flag is set. The microprocessor can then load the shift register with the next byte of data.


Figure 26. SR Mode 5 - Shift Out Under T2 Control


Figure 27. SR Mode 6 - Shift Out Under $\mathbf{Q L}_{2}$ Control


Figure 28. SR Mode 7 - Shift Out Under CB1 Control

## INTERRUPT OPERATION

Controlling interrupts within the R6522 involves three principal operations. These are flagging the interrupts, enabling interrupts and signaling to the processor that an active interrupts exists within the chip. Interrupt flags are set in the Interrupt Flag Register (IFR) by conditions detected within the R6522 or on inputs to the R6522. These flags normally remain set until the interrupt has been serviced. To determine the source of an interrupt, the microprocessor must examine these flags in order, from highest to lowest priority.

Associated with each interrupt flag is an interrupt enable bit in the Interrupt Enable Register (IER). This can be set or cleared by the processor to enable interrupting the processor from the corresponding interrupt flag. If an interrupt flag is set to a logic 1 by an interrupting condition, and the corresponding interrupt enable bit is set to a 1, the Interrupt Request Output ( $\overline{\mathrm{RQ}}$ ) will go low. $\overline{\mathrm{IRQ}}$ is an "open-collector" output which can be "wire-OR'ed" with other devices in the system to interrupt the processor.

## Interrupt Flag Register (IFR)

In the R6522, all the interrupt flags are contained in one register, i.e., the IFR (Figure 29). In addition, bit 7 of this register will be read as a logic 1 when an interrupt exists within the chip. This allows very convenient polling of several devices within a system to locate the source of an interrupt.

The Interrupt Flag Register (IFR) may be read directly by the processor. In addition, individual flag bits may be cleared by writing a " 1 " into the appropriate bit of the IFR. When the proper chip select and register signals are applied to the chip, the contents of this register are placed on the data bus. Bit 7 indicates the status of the $\overline{\mathrm{IRQ}}$ output. This bit corresponds to the logic


Figure 29. Interrupt Flag Register (IFR)
function: $\overline{\mathrm{IRQ}}=\mathrm{IFR} 6 \times \mathrm{IER6}+\mathrm{IFR} 5 \times \mathrm{IER} 5+\mathrm{IFR} 4 \times \mathrm{IER} 4$ + IFR3 $\times$ IER3 + IFR $2 \times$ IER $2+$ IFR1 $\times$ IER1 + IFR0 $\times$ IERO.

## Note:

$$
x=\text { logic AND },+=\text { Logic OR. }
$$

The IFR bit 7 is not a flag. Therefore, this bit is not directly cleared by writing a logic 1 into it. It can only be cleared by clearing all the flags in the register or by disabling all the active interrupts as discussed in the next section.

## Interrupt Enable Register (IER)

For each interrupt flag in IFR, there is a corresponding bit in the Interrupt Enable Register (IER) (Figure 30). Individual bits in the IER can be set or cleared to facilitate controlling individual interrupts without affecting others. This is accomplished by writing to the (IER) after bit 7 set or cleared to, in turn, set or clear selected enable bits. If bit 7 of the data placed on the system data bus during this write operation is a 0 , each 1 in bits 6 through 0 clears the corresponding bit in the Interrupt Enable Register. For each zero in bits 6 through 0 , the corresponding bit is unaffected.

Selected bits in the IER can be set by writing to the IER with bit 7 in the data word set to a 1. In this case, each 1 in bits 6 through 0 will set the corresponding bit. For each zero, the corresponding bit will be unaffected. This individual control of the setting and clearing operations allows very convenient control of the interrupts during system operation.

In addition to setting and clearing IER bits, the contents of this register can be read at any time. Bit 7 will be read as a logic 1 , however.

REG 14-INTERRUPT ENABLE REGISTER


NOTES.

1. IF BIT 7 IS A " 0 ". THEN EACH " 1 " IN BITS $0-6$ DISABLES THE CORRESPONDING INTERRUPT.
2. IF BIT 7 IS A " 1 ", THEN EACH " 1 " IN BITS 0-6 ENABLES THE CORRESPONOING INTERRUPT.
3. IF A READ OF THIS REGISTER IS DONE, BIT 7 WILL BE "1" AND ALL OTHER BITS WILL REFLECT THEIR ENABLE/DISABLE STATE.

Figure 30. Interrupt Enable Register (IER)

## PERIPHERAL INTERFACE CHARACTERISTICS

| Symbol | Characteristic | Min. | Max. | Unit | Figure |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{r}, t_{f}$ | Rise and Fall Time for CA1, CB1, CA2 and CB2 Input Signals | - | 1.0 | $\mu \mathrm{S}$ | - |
| $\mathrm{t}_{\text {CA2 }}$ | Delay Time, Clock Negative Transition to CA2 Negative Transition (read handshake or pulse mode) | - | 1.0 | $\mu \mathrm{S}$ | 31a, 31b |
| $t_{\text {RS1 }}$ | Delay Time, Clock Negative Transition to CA2 Positive Transition (pulse mode) | - | 1.0 | $\mu \mathrm{S}$ | 31a |
| $\mathrm{t}_{\mathrm{RS} 2}$ | Delay Time, CA1 Active Transition to CA2 Positive Transition (handshake mode) | - | 2.0 | $\mu \mathrm{S}$ | 31b |
| $t_{\text {WHS }}$ | Delay Time, Clock Positive Transition to CA2 or CB2 Negative Transition (write handshake) | 0.05 | 1.0 | $\mu \mathrm{S}$ | 31c, 31d |
| $t_{\text {dS }}$ | Delay Time, Peripheral Data Valid to CB2 Negative Transition | 0.20 | 1.5 | $\mu \mathrm{S}$ | 31c, 31d |
| $t_{\text {RS3 }}$ | Delay Time, Clock Positive Transition to CA2 or CB2 Positive Transition (pulse mode) | - | 1.0 | $\mu \mathrm{S}$ | 31 c |
| $\mathrm{t}_{\text {RS4 }}$ | Delay Time, CA1 or CB1 Active Transition to CA2 or CB2 Positive Transition (handshake mode) | - | 2.0 | $\mu \mathrm{S}$ | 31d |
| $\mathrm{t}_{21}$ | Delay Time Required from CA2 Output to CA1 Active Transition (handshake mode) | 400 | - | ns | 31d |
| $\mathrm{t}_{\text {LL }}$ | Setup Time, Peripheral Data Valid to CA1 or CB1 Active Transition (input latching) | 300 | - | ns | 31 e |
| $\mathrm{t}_{\mathrm{AL}}$ | CA1, CB1 Setup Prior to Transition to Arm Latch | 300 | - | ns | 31 e |
| $t_{\text {PDH }}$ | Peripheral Data Hold After CA1, CB1 Transition | 150 | - | ns | 31 e |
| $\mathrm{t}_{\text {SR1 }}$ | Shift-Out Delay Time - Time from $\phi_{2}$ Falling Edge to CB2 Data Out | - | 300 | ns | 317 |
| $t_{\text {SR2 }}$ | Shift-In Setup Time - Time from CB2 Data In to $\phi_{2}$ Rising Edge | 300 | - | ns | 31 g |
| $\mathrm{t}_{\text {SR3 }}$ | External Shift Clock (CB1) Setup Time Relative to $\phi_{2}$ Trailing Edge | 100 | $\mathrm{T}_{\mathrm{CY}}$ | ns | 31 g |
| $\mathrm{I}_{\text {IPW }}$ | Pulse Width - PB6 Input Pulse | $2 \times \mathrm{T}_{C Y}$ | - |  | 31 i |
| $\mathrm{t}_{\mathrm{ICW}}$ | Pulse Width - CB1 Input Clock | $2 \times \mathrm{T}_{C Y}$ | - |  | 31h |
| $t_{\text {IPS }}$ | Pulse Spacing - PB6 Input Pulse | $2 \times \mathrm{T}_{C Y}$ | - |  | 311 |
| $\mathrm{t}_{10}$ CS | Pulse Spacing - CB1 Input Pulse | $2 \times \mathrm{T}_{C Y}$ | - |  | 31h |

## PERIPHERAL INTERFACE WAVEFORMS



Figure 31a. CA2 Timing for Read Handshake, Pulse Mode


Figure 31b. CA2 Timing for Read Handshake, Handshake Mode


Figure 31c. CA2, CB2 Timing for Write Handshake, Pulse Mode


Figure 31d. CA2, CB2 Timing for Write Handshake, Handshake Mode


Figure 31e. Peripheral Data Input Latching Timing


Figure 31f. Timing for Shift Out with Internal or External Shift Clocking


Figure 31g. Timing for Shift in with Internal or External Shift Clocking


Figure 31h. External Shift Clock Timing


Figure 31i. Pulse Count Input Timing

## BUS TIMING CHARACTERISTICS

| Parameter | R6522 (1 MHz) | R6522A (2 MHz) |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |

## READ TIMING

| Cycle Time | $\mathrm{T}_{\mathrm{CY}}$ |  | 1 | 10 | 0.5 | 10 | $\mu \mathrm{S}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address Set-Up Time | $\mathrm{T}_{\text {ACR }}$ |  | 180 | - | 90 | - | ns |
| Address Hold Time | $\mathrm{T}_{\text {CAR }}$ |  | 0 | - | 0 | - | ns |
| Peripheral Data Set-Up Time | $\mathrm{T}_{\text {PCR }}$ |  | 300 | - | 150 | - | ns |
| Data Bus Delay Time | $\mathrm{T}_{\text {CDR }}$ |  | - | 365 | - | 190 | ns |
| Data Bus Hold Time | $\mathrm{T}_{\mathrm{HR}}$ | - | 10 | - | 10 | - | ns |

## WRITE TIMING

| Cycle Time | $\mathrm{T}_{\mathrm{CY}}$ | 1 | 10 | 0.50 | 10 | $\mu \mathrm{S}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\emptyset 2$ Pulse Width | $\mathrm{T}_{\mathrm{C}}$ | 470 | - | 235 | - | ns |
| Address Set-Up Time | $\mathrm{T}_{\text {ACW }}$ | 180 | - | 90 | - | ns |
| Address Hold Time | TCAW | 0 | - | 0 | - | ns |
| R $\bar{W}$ Set-Up Time | $\mathrm{T}_{\text {wcw }}$ | 180 | - | 90 | - | ns |
| R/W Hold Time | $\mathrm{T}_{\text {cww }}$ | 0 | - | 0 | - | ns |
| Data Bus Set-Up Time | $\mathrm{T}_{\text {DCW }}$ | 200 | - | 90 | - | ns |
| Data Bus Hold Time | $\mathrm{T}_{\mathrm{HW}}$ | 10 | - | 10 | - | ns |
| Peripheral Data Delay Time | $\mathrm{T}_{\text {CPW }}$ | - | 1.0 | - | 0.5 | $\mu \mathrm{S}$ |
| Peripheral Data Delay Time to CMOS Levels | $\mathrm{T}_{\text {CMOS }}$ | - | 2.0 | - | 1.0 | $\mu \mathrm{S}$ |
| Note: $\mathrm{t}_{\mathrm{R}}$ and $\mathrm{t}_{\mathrm{F}}=10$ to 30 ns . |  |  |  |  |  |  |

## BUS TIMING WAVEFORMS



Read Timing Waveforms


ABSOLUTE MAXIMUM RATINGS*

| Parameter | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | Vdc |
| Input Voltage | $\mathrm{V}_{\text {IN }}$ | -0.3 to +7.0 | VdC |
| Operating Temperature <br> Commercial <br> Industrial | $\mathrm{T}_{\mathrm{A}}$ | 0 to +70 <br> -40 to +85 | ${ }^{\circ} \mathrm{C}$ |
| ${ }^{\circ} \mathrm{C}$ |  |  |  |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

*NOTE: Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## OPERATING CONDITIONS

| Parameter | Symbol | Value |
| :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $5 \mathrm{~V} \pm 5 \%$ |
| Temperature Range <br> Commercial | $\mathrm{T}_{\mathrm{A}}$ | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |

## DC CHARACTERISTICS

$\left(V_{C C}=5.0 \mathrm{Vdc} \pm 5 \%, V_{S S}=0, T_{A}=T_{L}\right.$ to $T_{H}$, unless otherwise noted)

| Parameter | Symbol | Min. | Typ. ${ }^{3}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\mathrm{V}_{\text {IH }}$ | 2.4 | - | $\mathrm{V}_{\mathrm{cc}}$ | V |  |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | -0.3 | - | 0.4 | V |  |
| Input Leakage Current <br> R $\bar{W}, \overline{\text { RES }}, \mathrm{RSO}, \mathrm{RS} 1, \mathrm{RS} 2, \mathrm{RS} 3, \mathrm{CS} 1, \overline{\mathrm{CS} 2}, \mathrm{CA} 1, ~ \emptyset 2$ | $\mathrm{I}_{\text {IN }}$ | - | $\pm 1$ | $\pm 2.5$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V} \text { to } 5.25 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=0 \mathrm{~V} \end{aligned}$ |
| Input Leakage Current for Three-State Off D0-D07 | $\mathrm{I}_{\text {TSI }}$ | - | $\pm 2$ | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & \mathrm{VCC}=5.25 \mathrm{~V} \end{aligned}$ |
| Input High Current <br> PAO-PA7, CA2, PB0-PB7, CB1, CBS | $I_{1 H}$ | -100 | -200 | - | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\text {IN }}=2.4 \mathrm{~V} \\ & V_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Input Low Current PAO-PA7, CA2, PB0-PB7, CB1, CB2 | $\mathrm{I}_{\mathrm{L}}$ | - | -0.9 | -1.8 | mA | $\begin{aligned} & V_{\mathrm{VL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Output High Voltage <br> All outputs <br> PB0-PB7, CB2 (Darlington Drive) | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & 2.4 \\ & 1.5 \end{aligned}$ | - | - | $\begin{aligned} & \mathrm{V} \\ & \mathrm{v} \end{aligned}$ | $\begin{aligned} & V_{\text {CC }}=4.75 \mathrm{~V} \\ & I_{\text {LOAD }}=-100 \mu \mathrm{~A} \\ & \text { L }_{\text {LOAD }}=-1.0 \mathrm{~mA} \end{aligned}$ |
| Output Low Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | - | 0.4 | V | $\begin{aligned} & V_{C C}=4.75 \mathrm{~V} \\ & l_{\text {LOAD }}=1.6 \mathrm{~mA} \end{aligned}$ |
| ```Output High Current (Sourcing) Logic PBO-PB7, CB2 (Darlington Drive)``` | IOH | $\begin{array}{r} -100 \\ -1.0 \\ \hline \end{array}$ | $\begin{gathered} -1000 \\ -2.5 \\ \hline \end{gathered}$ | $-10$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mathrm{~mA} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V} \end{aligned}$ |
| Output Low Current (Sinking) | $\mathrm{l}_{\mathrm{OL}}$ | 1.6 | - | - | mA | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| Output Leakage Current (Off State) | Ioff | - | 4 | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | - | 450 | 700 | mW |  |
| Input Capacitance <br> R $\bar{W}, \overline{\text { RES }}, \mathrm{RSO}, \mathrm{RS} 1, \mathrm{RS} 2, \mathrm{RS} 3, \mathrm{CS} 1, \overline{\mathrm{CS} 2}$, D0-D7, PAO-PA7, CA1, CA2, PB0-PB7 <br> CB1, CB2 <br> $\emptyset 2$ Input | $\mathrm{C}_{\text {IN }}$ | - <br> - | - | $\begin{gathered} 7 \\ 10 \\ 20 \end{gathered}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \\ & \mathrm{pF} \\ & \hline \end{aligned}$ | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V} \\ & V_{\mathrm{IN}}=0 \mathrm{~V} \\ & \mathrm{f}=1 \mathrm{MHz} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |
| Output Capacitance | $\mathrm{C}_{\text {OUT }}$ | - | - | 10 | pF |  |

## Notes:

1. All units are direct current (DC) except for capacitance.
2. Negative sign indicates outward current flow, positive indicates inward flow.
3. Typical values shown for $V_{C C}=5.0 \mathrm{~V}$ and $T_{A}=25^{\circ} \mathrm{C}$.

## PACKAGE DIMENSIONS

## 40-PIN CERAMIC DIP



40-PIN PLASTIC DIP


| DIM | MILLIMETERS |  | INCHES |  |
| :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |
| A | 5128 | 52.32 | 2040 | 2060 |
| B | 1372 | 1422 | 0540 | 0560 |
| C | 3.55 | 508 | 0140 | 0200 |
| D | 0.36 | 051 | 0014 | 0.020 |
| F | 102 | 152 | 0.040 | 0060 |
| G | 254 BSC |  | 0.100 BSC |  |
| H | 165 | 216 | 0.065 | 0085 |
| J | 020 | 030 | 0008 | 0012 |
| K | 305 | 356 | 0120 | 0140 |
| L | 15.24 BSC |  | 0600 BSC |  |
| M | $7{ }^{\circ}$ | $10^{\circ}$ | 7 | $10^{\circ}$ |
| N | 0.51 | 102 | 0.020 | 0040 |

## R6532 <br> RAM-I/O-Timer (RIOT)

## DESCRIPTION

The R6532 RAM-I/O-Timer (RIOT) integrates random access memory (RAM), parallel I/O data ports and timer functions into a single peripheral device which operates in conjunction with any CPU in the R6500 microprocessor family. It is comprised of a $128 \times 8$ static RAM, two software-controlled, 8 -bit bidirectional data ports allowing direct interfacing between the microcomputer and peripheral devices, a software programmable interval timer, with interrupt, capable of timing in various intervals from 1 to 262,144 clock periods, and a programmable edge-detect circuit.

## FEATURES

- $128 \times 8$ static RAM
- Two 8 bit bidirectional data ports
- Programmable interval timer with interrupt capability
- TTL \& CMOS compatible peripheral lines
- One port has direct transistor drive capability
- Programmable edge-sensitive interrupt input
- 8 bit bidirectional data bus
- 6500/6800 bus compatible
- 1 MHz and 2 MHz parts available
- Single +5 V power supply


R6532 Pin Configuration

## INTERFACE SIGNALS

## RESET ( $\overline{\operatorname{RES}})$

During system initialization, a low $\overline{\operatorname{RES}}$ input causes a zeroing of all four I/O registers. This in turn causes all I/O buses to act as inputs thus protecting external components from possible damage and erroneous data while the system is being configured under software control. The Data Bus Buffers are put into an OFF-STATE during Reset. Interrupt capability is disabled with the $\overline{\operatorname{RES}}$ signal. The $\overline{\operatorname{RES}}$ signal must be held low for at least two clock periods when reset is required.

## READ/WRITE ( $\mathrm{R} / \overline{\mathrm{W}}$ )

The $R / \bar{W}$ signal is supplied by the microprocessor and controls the transfer of data to and from the R6532. A high on the R/W pin allows the processor to read (with proper addressing) the data supplied by the R6532. A low on the R/W pin allows a write (with proper addressing) to the R6532.

## INTERRUPT REQUEST (IRQ)

The $\overline{\mathrm{RQ}}$ pin is an interrupt pin from the interrupt control logic. The pin will be normally high with a low indicating an interrupt from the R6532. An external 3K pull-up resistor is required. The IRQ pin may be activated by a transition on PA7 or timeout of the interval timer.

## DATA BUS (D0-D7)

The R6532 has eight bidirectional data pins (D0-D7). These pins connect to the system's data lines and transfer data between the R6532 and the microprocessor data bus. The output buffers remain off, or tri-stated, except when the R6532 is selected for a Read operation.

## ADDRESS LINES (A0-A6)

There are seven address pins (A0-A6). In addition, there is the $\overline{\mathrm{RAM}}$ SELECT $(\overline{\mathrm{RS}})$ pin. The pins A0-A6 and $\overline{\mathrm{RS}}$ are always used as addressing pins. There are two additional pins which are used as CHIP SELECTS. They are pins CS1 and CS2. Tables 1 and 2 identify the functions selected and registers addressed depending upon the address line and $\overline{R S}$ inputs in conjunction with the R/W level.

## I/O PORTS (PA0-PA7, PB0-PB7)

The R6532 has 16 pins available for peripheral I/O operations. Each pin is individually software programmable to act as either an input or an output. The 16 pins are divided into two 8 -bit ports, PAO-PA7 and PB0-PB7. (PA7 also has another use which is discussed later.) Each is set up as an input by writing a " 0 " into the corresponding bit of the data direction register. A "1" written into the data direction register causes its corresponding bit to be an output. When in the input mode, the peripheral output buffers are in the "1" state and the internal pull-up device acts as less than one TTL load to the peripheral data lines. On a Read operation, the microprocessor reads the peripheral pin. When the peripheral device gets information from the R6532 it receives data stored in the data register. The microprocessor reads valid pin information if the peripheral lines are greater than 2.0 volts for a " 1 " and less than 0.8 volt for a " 0 " as the peripheral pins are all TTL compatible. Pins PBOPB7 are also capable of sourcing 3 ma at 1.5 V , thus making them capable of Darlington drive.


RIOT Interface Signals

Table 1. Address Decoding

| Operation | $\overline{\text { RS }}$ | R/W | A4 | A3 | A2 | A1 | A0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Write RAM | 0 | 0 | - | - | - | - | - |
| Read RAM | 0 | 1 | - | - | - | - | - |
| Write Output Reg A | 1 | 0 | - | - | 0 | 0 | 0 |
| Read Output Reg A | 1 | 1 | - | - | 0 | 0 | 0 |
| Write DDRA | 1 | 0 | - | - | 0 | 0 | 1 |
| Read DDRA | 1 | 1 | - | - | 0 | 0 | 1 |
| Write Output Reg B | 1 | 0 | - | - | 0 | 1 | 0 |
| Read Output Reg B | 1 | 1 | - | - | 0 | 1 | 0 |
| Write DDRB | 1 | 0 | - | - | 0 | 1 | 1 |
| Read DDRB | 1 | 1 | - | - | 0 | 1 | 1 |
| Write Timer |  |  |  |  |  |  |  |
| $\div 1 \mathrm{~T}$ | 1 | 0 | 1 | (a) | 1 | 0 | 0 |
| $\div 8 \mathrm{~T}$ | 1 | 0 | 1 | (a) | 1 | 0 | 1 |
| $\div 64 T$ | 1 | 0 | 1 | (a) | 1 | 1 | 0 |
| $\div 1024 \mathrm{~T}$ | 1 | 0 | 1 | (a) | 1 | 1 | 1 |
| Read Timer | 1 | 1 | - | (a) | 1 | - | 0 |
| Read Interrupt Flag | 1 | 1 | - | - | 1 | - | 1 |
| Write Edge Detect Control | 1 | 0 | 0 | - | 1 | (b) | (c) |

Notes:
— = Don't Care, "1" = High level ( $\geqslant 2.4 \mathrm{~V}$ ), " 0 " = Low level ( $\leqslant 0.4 \mathrm{~V}$ )
(a) $A 3=0$ to disable timer interrupt
$A 3=1$ to enable timer interrupt
(c) $\mathrm{A} 0=0$ for negative edge-detect $A 0=1$ for positive edge-detect
(b) A1 $=0$ to disable PA7 interrupt A1 $=1$ to enable PA7 interrupt

Table 2. Register Addressing

| Start <br> Address + | Register/Function | Start <br> Address + | Register/Function |
| :---: | :---: | :---: | :---: |
| \$0 | DRA ('A' side data register) | \$7 | Write edge-detect control (positive edge-detece, |
| \$1 | DDRA ('A' side data direction register) |  | enable interrupt) |
| \$2 | DRB ('B' side data register) | \$C | Read timer (enable interrupt) |
| \$3 | DDRB ('B' side data direction register) | \$14 | Write timer (divide by 1, disable interrupt) |
| \$4 | Read timer (disable interrupt) | \$15 | Write timer (divide by 8 , disable interrupt) |
| \$4 | Write edge-detect control (negative edge-detect, | \$16 | Write timer (divide by 64, disable interrupt) |
|  | disable interrupt) | \$17 | Write timer (divide by 1024, disable interrupt) |
| \$5 | Read interrupt flag register (bit $7=$ timer, bit $6=$ | \$1C | Write timer (divide by 1, enable interrupt) |
|  | PA7 edge-detect) Clear PA7 flag | \$1D | Write timer (divide by 8 , enable interrupt) |
| \$5 | Write edge-detect control (positive edge-detect, disable interrupt) | $\begin{aligned} & \$ 1 E \\ & \$ 1 F \end{aligned}$ | Write timer (divide by 64 , enable interrupt) Write timer (divide by 1024, enable interrupt) |
| \$6 | Write edge-detect control (negative edge-detect, enable interrupt) |  |  |

## INTERNAL ORGANIZATION

The R6532 is divided into four basic sections, RAM, I/O, Timer, and Interrupt Control. The RAM interfaces directly with the microprocessor through the system data bus and address lines. The I/O section consists of two 8-bit halves. Each half contains a Data Direction Register (DDR) and a Data Register (DR).

## RAM-128 BYTES (1024 BITS)

The $128 \times 8$ Read/Write Memory acts as a conventional static RAM and can be accessed from the microprocessor by selecting the chip (CS1 $=$ high, $\overline{\mathrm{CS} 2}=$ low) and by setting $\overline{\mathrm{RS}}$ low. Address lines A0 through A6 then select the desired byte of storage.

## I/O PORTS AND REGISTERS

The I/O Ports consist of eight lines which can be individually programmed to act as either an input or an output. A logic zero in a bit of the Port A Data Direction Register (DDRA) causes the corresponding line of Port A to act as an input. A logic one causes the corresponding Port A line to act as an output. The voltage on any line programmed to be an output is determined by the corresponding bit in the Port A Data Register (DRA).

Data is read directly from the data pins during any read operation. For any output pin, the data transferred into the processor will be the same as that contained in the Data Register if the voltage on the pin is allowed to go to 2.4 V for a logic one. Note that for input lines, the processor can write into the corresponding bit of the Data Register. This will not affect the polarity on the pin until the corresponding bit of DDRA is set to a logic one to allow the I/O line to act as an output.

The operation of the Port $B$ is exactly the same as the normal 1/O operation of the Port A. Each of the eight lines can each be programmed to act as either an input or as an output by placing a 0 or a 1 into the Port B Data Direction register (DDRB). In the output mode, the voltage on a peripheral pin is controlled by the Port B Data Register (DRB).

The primary difference between Port A and the Port B is in the operation of the output buffers which drive these pins. The Port B output buffers are push-pull devices which are capable of sourcing 3 ma at 1.5 V . This allows these pins to directly drive transistor switches. To assure that the microprocessor will read proper data on a "Read Port B" operation, logic in the R6532 allows the microprocessor to read the Output Register instead of reading the peripheral pin as on Port $A$.


R6532 Block Diagram

## EDGE DETECTING WITH PA7

In addition to acting as a peripheral I/O line, the PA7 line can be used as an edge-detecting input. In this mode, an active transition sets the internal interrupt flag (bit 6 of the Interrupt Flag register). Setting the interrupt flag causes $\overline{\mathrm{RQ}}$ output to go low if the PA7 interrupt has been enabled.

Control of the PA7 edge detecting mode is accomplished by writing to one of four addresses. In this operation, AO controls the polarity of the active transition and A1 acts to enable or disable interrupting of the processor. The data which is placed on the Data Bus during this operation is discarded and has no effect on the control of PA7.

The PA7 interrupt flag is set on an active transition, even if the pin is being used as a normal input or as a peripheral control output. The flag is also set by an active transition if the PA7 interrupt is disabled. The reset signal ( $\overline{\mathrm{RES}}$ ) disables the PA7 interrupt and enables negative (high-to-low) edge detection on PA7. The PA7 edge detect logic can be set to detect either a positive or negative transition and to either enable or disable interrupt ( $\overline{\mathrm{RQ}})$ generation upon detection.

During system initialization, the interrupt flag may inadvertently be set by an unexpected transition on the PA7. It is therefore recommended that the interrupt flag be cleared before enabling interrupting from PA7. To clear PA7 interrupt flag, simply read the interrupt Flag Register.

## INTERVAL TIMER

The Timer section of the R6532 contains three basic parts: preliminary divide down register, programmable 8 -bit register and interrupt logic.

The Timer can be programmed to count up to 255 time intervals. Each time interval can be either 1T, 8T, 64T or 1024 T increments, where T is the system clock period. When a full count is reached, an interrupt flag is set to logic " 1 ". After the interrupt flag is set the internal clock begins counting down at the system clock rate to a maximum of -255 T . Thus, after the interrupt flag is set, a Read of the timer will tell how long since the flag was set up to a maximum of 255T.


Basic Elements of Interval Timer

## INTERVAL TIMER EXAMPLE

The 8 -bit microprocessor data bus transfers data to and from the Timer. If a count of 52 time intervals were to be counted, the pattern 000110100 would be put on the data bus and written into the divide by 1 Timer register.

At the same time that data is being written to the Timer, the counting intervals of $1,8,64,1024 \mathrm{~T}$ are decoded from address lines AO and A1. During a Read or Write Operation address line A3 controls the interrupt enable, i.e., $A 3=1$ enables $\overline{\mathrm{RQ}}$, A3 $=0$ disables IRQ. When the time is read prior to the interrupt flag being set, the number of time intervals remaining will be read, i.e., $51,50,49$, etc.

When the Timer has counted through 00000000 on the next count time an interrupt will occur and the counter will read $\begin{array}{lllllll}1 & 1 & 1 & 1 & 1 & 1 & 1\end{array}$ 1. After the interrupt flag is set, the timer register decrements at a divide by " 1 " rate of the system clock. If the timer is read after the interrupt flag is set and a value of 11100100 is read, the time since interrupt is 27T. The value read is in two's complement, but remember that interrupt occurred on count number one. Therefore, we must subtract 1.


Thus, to arrive at the total elapsed time, merely do a two's complement add to the original time written into the timer. Again, assume time written as $00110100(=52)$. With a divide by 8 , total time to interrupt is $(52 \times 8)+1=417 \mathrm{~T}$. Total elapsed time would be $416 \mathrm{~T}+27 \mathrm{~T}=443 \mathrm{~T}$, assuming the value read after interrupt was 11100100 .

The interrupt flag will be reset whenever the Timer is accessed by a read or a write. However, the reading of the timer at the same time the interrupt occurs will not reset the interrupt flag. When the interrupt flags are read (D7 for the timer, D6 for the edge detect) data bus lines D0-D5 go to 0 .

When reading the timer after an interrupt, A3 should be low so as to disable the IRQ pin. This is done so as to avoid future interrupts until after another Write timer operation.


Interval Time Example Waveforms

## BUS AND PERIPHERAL TIMING WAVEFORMS



WRITE TIMING


AC CHARACTERISTICS

| Characteristic | Symbol | $\begin{gathered} \text { R6532 } \\ (1 \mathrm{MHz}) \end{gathered}$ |  | $\begin{aligned} & \mathrm{R} 6532 \mathrm{~A} \\ & (2 \mathrm{MHz}) \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Clock Cycle Time | $\mathrm{T}_{\mathrm{CrC}}$ | 1 | 10 | 0.5 | 10 | $\mu \mathrm{S}$ |
| Clock Pulse Width | $\mathrm{T}_{\mathrm{C}}$ | 470 | - | 240 | - | ns |
| Rise \& Fall Times | $\mathrm{T}_{\mathrm{R}}, \mathrm{T}_{\mathrm{F}}$ | - | 25 | - | 15 | ns |

READ TIMING

| Address Set Up Time | $\mathrm{T}_{\text {ACR }}$ | 180 | - | 90 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address Hold Time | $\mathrm{T}_{\text {CAR }}$ | 0 | - | 0 | - | ns |
| R/ $\bar{W}$ Set Up Time | $\mathrm{T}_{\text {WCR }}$ | 180 | - | 90 | - | ns |
| Data Bus Delay Time | $\mathrm{T}_{\text {CDR }}$ | - | 395 | - | 190 | n |
| Data Bus Hold Time | $\mathrm{T}_{\mathrm{HR}}$ | 10 | - | 10 | - | ns |
| Peripheral Data Set Up Time | $\mathrm{T}_{\text {PCR }}$ | 300 | - | 150 | - | ns |

WRITE TIMING

| $\emptyset 2$ Cycle Time | $\mathrm{T}_{\mathrm{CyC}}$ | 1 | 10 | 0.5 | 10 | $\mu \mathrm{s}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\emptyset 2$ Pulse Width | $\mathrm{T}_{\mathrm{C}}$ | 470 | - | 240 | - | ns |
| Address Set Up Time | $\mathrm{T}_{\text {ACW }}$ | 180 | - | 90 | - | ns |
| Address Hold Time | $\mathrm{T}_{\text {CAH }}$ | 0 | - | 0 | - | ns |
| R/W Set Up Time | TWCW | 180 | - | 90 | - | ns |
| R/VW Hold Time | $\mathrm{T}_{\text {CWH }}$ | 0 | - | 0 | - | ns |
| Data Bus Set-Up Time | Tocw | 300 | - | 150 | - | ns |
| Data Bus Hold Time | $\mathrm{T}_{\mathrm{HW}}$ | 10 | - | 10 | - | ns |
| Peripheral Data Delay Time | $\mathrm{T}_{\text {CPW }}$ | - | 1 | - | 0.5 | $\mu \mathrm{S}$ |
| Peripheral Data Delay Time CMOS | $\mathrm{T}_{\text {cmos }}$ | - | 2 | - | 1 | $\mu \mathrm{S}$ |

MAXIMUM RATINGS*

| Parameter | Symbol | Value | Unit |
| :--- | :--- | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | Vdc |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | -0.3 to +7.0 | Vdc |
| Operating Temperature <br> Commercial <br> Industrial | $\mathrm{T}_{\mathrm{A}}$ | 0 to +70 <br> -40 to +85 | ${ }^{\circ} \mathrm{C}$ |
| ${ }^{\circ} \mathrm{C}$ |  |  |  |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

*NOTE: Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## DC CHARACTERISTICS

( $V_{C C}=5.0 \pm 5 \%, T_{A}=T_{L}$ to $T_{H}$ unless otherwise noted)

| Parameter | Symbol | Min | Max | Unit ${ }^{(1)}$ | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.4 | $V_{\text {cc }}$ | V |  |
| Input Low Voltage | $V_{\text {IL }}$ | 0 | 0.4 | V |  |
| Input Leakage Current: <br> A0-A6, RS, R $\bar{W}, \overline{R E S}, ~ \emptyset 2, C S 1, \overline{C S} 2$ | $\mathrm{I}_{\mathrm{N}}$ | - | 2.5 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{i N}=5.25 \mathrm{~V} \\ & V_{C C}=0 \mathrm{~V} \end{aligned}$ |
| Input Leakage Current for Three-State Off DO-D7 | $\mathrm{I}_{\text {TSI }}$ | - | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ to 2.4 V |
| Input High Current PA0-PA7, PBO-PB7 | $\mathrm{I}_{\mathrm{H}}$ | -100 | - | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ |
| Input Low Current PA0-PA7, PB0-PB7 | ILL | - | -1.6 | mA | $\mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V}$ |
| ```Output High Voltage PA0-PA7, PB0-PB7 (TTL drive), D0-D7 PB0-PB7 (other than TTL drive, e.g., Darlington)``` | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & 2.4 \\ & 1.5 \end{aligned}$ | - | V | $\begin{aligned} & V_{C C}=4.75 \mathrm{~V} \\ & I_{\text {LOAD }}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\text {LOAD }}=3 \mathrm{~mA} \end{aligned}$ |
| Output Low Voltage D0-D7 | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.4 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA} \end{aligned}$ |
| Output High Current (Sourcing) <br> PAO-PA7, PB0-PB7 (TTL drive), D0-D7 PB0-PB7 (other drive, e.g., Darlington) | IOH | $\begin{array}{r} -100 \\ -3.0 \\ \hline \end{array}$ | - | $\begin{aligned} & \mu A \\ & m A \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V} \end{aligned}$ |
| Output Low Current (Sinking) PA0-PA7, PB0-PB7 | Iol | 1.6 | - | mA | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| Input Capacitance $\emptyset 2$ Other | $\mathrm{C}_{\text {CLK }}$ $\mathrm{C}_{\mathrm{IN}}$ | - | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | $\begin{aligned} & V_{\mathrm{CC}}=5.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| $\therefore$ Output Capacitance | $\mathrm{C}_{\text {OUT }}$ | - | 10 | pF |  |
| Power Dissipation | $P_{\text {D }}$ | - | 1000 | mW | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ |

## Notes:

1. All units are direct current (DC).
2. Negative sign indicates outward current flow, positive indicates inward flow.

## PACKAGE DIMENSIONS

## 40-PIN CERAMIC DIP



2

## 40-PIN PLASTIC DIP



|  | MILLIMETERS |  | INCHES |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
| DIM | MIN | MAX | MIN | MAX |  |
| A | 51.28 | 52.32 | 2.040 | 2.060 |  |
| B | 13.72 | 1422 | 0.540 | 0.560 |  |
| C | 3.55 | 508 | 0.140 | 0.200 |  |
| D | 0.36 | 0.51 | 0.014 | 0020 |  |
| F | 1.02 | 1.52 | 0.040 |  | 0.060 |
| G | 2.54 |  | BSC | 0.100 |  |
| BSC |  |  |  |  |  |
| H | 165 | 2.16 | 0065 | 0.085 |  |
| J | 0.20 |  | 030 | 0008 | 0.012 |
| K | 305 | 3.56 | 0.120 |  | 0.140 |
| L | 15.24 | BSC | 0600 |  | BSC |
| M | $7^{\circ}$ | $10^{\circ}$ | $7^{\circ}$ |  | $10^{\circ}$ |
| N | 051 | 102 | 0020 | 0040 |  |

## R6545/R6545E CRT Controller (CRTC)

## DESCRIPTION

The R6545/R6545E CRT Controller (CRTC) interfaces an 8-bit microprocessor to CRT raster scan video displays, and adds an advanced CRT controller to the established and expanding line of R6500, R6500/* and R65C00 microprocessor, microcomputer and peripheral device products.

The R6545 and R6545E devices differ only in the character clock frequency (CCLK) specifications. The maximum CCLK frequency is 2.5 MHz for the R6545 and 3.7 MHz for the R6545E. Throughout this document, the nomenclature R6545 applies to both devices, unless specified otherwise.

The R6545 provides refresh memory addresses and character generator row addresses which allow up to 16 K characters with 32 scan lines per character to be addressed. A major advantage of the R6545 is that the refresh memory may be addressed in either straight binary or by row/column.

Other functions in the R6545 include an internal cursor register which generates a cursor output when its contents are equal to the current refresh address. Programmable cursor start and end registers allow a cursor of up to the full character scan in height to be placed on any scan lines of the character. Variable cursor display blink rates are provided. A light pen strobe input allows capture of the current refresh address in an internal light pen register. The refresh address lines are configured to provide direct dynamic memory refresh.

All timing for the video refresh memory signals is derived from the character clock input (CCLK). Shift register, latch, and multiplex control signals (when needed) are provided by external high-speed timing. The mode control register allows noninterlaced video display modes at 50 or 60 Hz refresh rate. The internal status register may be used to monitor the R6545 operation. The $\overline{\operatorname{RES}}$ input allows the CRTC-generated field rate to be dynamically-synchronized with line frequency jitter.

## FEATURES

- Compatible with 8 -bit microprocessors
- 3.7 MHz character clock operation (R6545E)
- 2.5 MHz character clock operation (R6545)
- Refresh RAM may be configured in row/column or straight binary addressing
- Alphanumeric and limited graphics capability
- Up and down scrolling by page, line, or character
- Programmable vertical sync width
- Fully programmable display (rows, columns, character matrix)
- Video display RAM may be configured as part of microprocessor memory field or independently slaved to R6545 (Transparent Addressing)
- Interlaced or non-interlaced scan
- $50 / 60 \mathrm{~Hz}$ refresh rate
- Fully programmable cursor
- Light pen register
- Addresses refresh RAM to 16 K characters
- No external DMA required
- Internal status register
- 40-pin ceramic or plastic DIP
- Pin-compatible with MC6845R
- Single $+5 \pm 5 \%$ Vdc power supply


## ORDERING INFORMATION

```
Part Number:
R6545
\(\left[\begin{array}{c}{\left[\begin{array}{c}\text { Operating Temperature }\left(T_{L} \text { to } T_{H}\right) \\ \text { No Letters }=0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ \mathrm{E}\end{array} \mathrm{=} 40^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C}\right.} \\ \text { Package } \\ \mathrm{P}=40 \text {-Pin Plastic DIP } \\ \mathrm{C}=40 \text {-Pin Ceramic DIP } \\ \mathrm{J}=44 \text {-Pin Plastic Leaded Chip Carrier (PLCC) } \\ \text { Operating Frequency (Bus) } \\ \text { No Letter }=1 \mathrm{MHz} \\ \mathrm{A}=2 \mathrm{MHz} \\ \text { Character } \mathrm{Clock} \mathrm{Frequency} \mathrm{(CCLK)} \\ \text { No Letter }=2.5 \mathrm{MHz} \\ \mathrm{E}=3.7 \mathrm{MHz}\end{array}\right.\)
```



## INTERFACE SIGNAL DESCRIPTION

Figure 1 illustrates the interface between the CPU, the R6545, and the video circuitry. Figure 2 shows typical timing waveforms at the video interface.


Figure 1. R6545 Interface Diagram

## CPU INTERFACE

## 02 (Phase 2 Clock)

The Phase 2 ( $\emptyset 2$ ) input clock triggers all data transfers between the system processor (CPU) and the R6545. Since there is no maximum limit to the allowable $\emptyset 2$ clock time, it is not necessary for it to be a continuous clock. This capability permits the R6545 to be easily interfaced to non-6500 compatible microprocessors.

## R/W (Read/Write)

The $R \bar{W}$ input signal generated by the processor controls the direction of data transfers. A high on the R/W pin allows the processor to read the data supplied by the R6545, a low on the $R / \bar{W}$ pin allows data on data lines D0-D7 to be written into the R6545.

## $\overline{\mathbf{C S}}$ (Chip Select)

The Chip Select input is normally connected to the processor address bus either directly or through a decoder. The R6545 is selected when CS is low. Then, data may be written to, or read from, the R6545 depending on the state of RS and R/W.

## RS (Register Select)

The Register Select input allows access to internal registers. A low on this pin permits writing ( $\mathrm{R} / \overline{\mathrm{W}}=$ low) into the Address Register and reading ( $\mathrm{R} / \overline{\mathrm{W}}=$ high) from the Status Register. The Address Register selects the register accessed when RS is high.

## D0-D7 (Data Bus)

The eight data lines (D0-D7) transfer data between the processor and the R6545. These lines are bidirectional and are normally high-impedance except during read cycles when the chip is selected $(\overline{\mathrm{CS}}=$ low $)$.

## VIDEO INTERFACE

## HSYNC (Horizontal Sync)

The HSYNC active-high output signal determines the start of the horizontal raster line. It may drive a CRT monitor directly or may be used for composite video generation. HSYNC time position and width are fully programmable.

## VSYNC (Vertical Sync)

The VSYNC active-high output signal determines the start of the vertical frame. Like HSYNC, VSYNC may drive a CRT monitor or composite video generation circuits. VSYNC time position and width are both programmable.

## DISPLAY ENABLE (Display Enable)

The DISPLAY ENABLE active-high output signal indicates when the R6545 is generating active display information. The number of horizontal display characters per row and the number of vertical display rows are both fully programmable and together generate the DISPLAY ENABLE signal. DISPLAY ENABLE may be delayed one character time by setting bit 4 of R8 to a 1 .

## CURSOR (Cursor Coincidence)

The CURSOR active-high output signal indicates when the scan coincides with the programmed cursor position. The cursor position is programmable to any character in the address field. Furthermore, within the character, the cursor may be programmed to be any block of scan lines, since the cursor start scan line and end scan line are both programmable. The cursor output may be delayed by one character time by setting Bit 5 of R8 to a 1.

## LPEN (Light Pen Strobe)

The LPEN edge-sensitive input signal loads the internal Light Pen Register. A low-to-high transition activates LPEN.

## CCLK (Clock)

The CCLK character timing clock input signal is the time base for all internal count/control functions.

## $\overline{\text { RES }}$

The $\overline{\operatorname{RES}}$ active-low input signal initializes all internal scan counter circuits. When RES is low, all internal counters stop and clear and all scan and video outputs go low; control registers are unaffected. $\overline{R E S}$ must stay low for at least one CCLK period. All scan timing initiates when $\overline{\text { RES }}$ goes high. In this way, $\overline{\text { RES }}$ can synchronize display frame timing with line frequency. $\overline{R E S}$ may also synchronize multiple CRTC's in horizontal and/or vertical split screen operation.

## REFRESH RAM AND CHARACTER ROM INTERFACE

## MAO-MA13 (Refresh RAM Address Lines)

These 14 active-high output signals address the refresh RAM for character storage and display operations. The starting scan address is fully programmable and the ending scan address is determined by the total number of characters displayed, which is also programmable, in terms of characters/line and lines/frame.

There are two selectable address modes for MA0-MA13:

In the straight binary mode (R8, Mode Control, bit $2=0$ ), characters are stored in successive memory locations. Thus, the software design must translate row and column character coordinates into sequentially-numbered addresses for Refresh memory operations.

In the row/column mode (R8, Mode Control, bit $2=1$ ), MA0MA7 become column addresses CC0-CC7 and MA8-MA13
become row address CR0-CR5. In this case, the software manipulates characters in terms of row and column locations, but additional address compression circuits are needed to convert the CCO-CC7 and CRO-CR5 addresses into a memoryefficient binary address scheme.

## RA0-RA4 (Raster Address Lines)

These five active-high output signals select each raster scan within an individual character row. The number of raster scan lines is programmable and determines the character height, including spaces between character rows.

The high-order line, RA4, is unique in that it can also function as a strobe output pin when the R6545 is programmed to operate in the "Transparent Address Mode." In this case the strobe is an active-high output and is true at the time the Refresh RAM updates address gates on to the address lines, MAO-MA13. In this way, updates and readouts of the Refresh RAM can be made under control of the R6545 with only a small amount of external circuitry.


Figure 2. Vertical and Horizontal Timing

## INTERNAL REGISTER DESCRIPTION

Table 1 summarizes the internal registers and indicates their address selection and read/write capabilities.

## ADDRESS REGISTER

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | $\mathrm{A}_{4}$ | $\mathrm{~A}_{3}$ | $\mathrm{~A}_{2}$ | $\mathrm{~A}_{1}$ | $\mathrm{~A}_{0}$ |

This 5-bit write-only register is used as a "pointer" to direct CRTCICPU data transfers within the CRTC. It contains the number of the desired register $(0-31)$. When RS is low, this register may be loaded; when RS is high, the selected register is the one whose identity is stored in this address register.

## STATUS REGISTER (SR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| UR | LRF | VRT | - | - | - | - | - |

This 3-bit register contains the status of the CRTC.

SR

UR -Update Ready
Register R31 has been either read or written by the CPU.
An update strobe has occurred.

LRF -LPEN Register Full
Register R16 or R17 has been read by the CPU. LPEN strobe has been received.

## VRT -Vertical Re-Trace

Scan is not currently in the vertical re-trace time. Scan is currently in its vertical re-trace time. NOTE: This bit goes to a 1 when vertical re-trace starts. It goes to a 0 five character clock times before vertical re-trace ends to ensure that critical timings for refresh RAM operations are met.

Table 1. Internal Register Summary


## RO-HORIZONTAL TOTAL CHARACTERS

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| NUMBER OF CHARACTERS -1 |  |  |  |  |  |  |  |

This 8 -bit write-only register contains the total of displayed and non-displayed characters, minus one, per horizontal line. This register determines the frequency of HSYNC.

## R1—HORIZONTAL DISPLAYED CHARACTERS

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| NUMBER OF CHARACTERS |  |  |  |  |  |  |  |

This 8 -bit write-only register contains the number of displayed characters per horizontal line.

## R2-HORIZONTAL SYNC POSITION

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| HORIZONTAL SYNC POSITION |  |  |  |  |  |  |  |

This 8-bit write-only register contains the position of HSYNC on the horizontal line, in terms of the character location number on the line. The position of the HSYNC determines the left to right location of the displayed text on the video screen. In this way, the side margins are adjusted.

## R3-HORIZONTAL AND VERTICAL SYNC WIDTHS

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{~V}_{3}$ | $\mathrm{~V}_{2}$ | $\mathrm{~V}_{1}$ | $\mathrm{~V}_{0}$ | $\mathrm{H}_{3}$ | $\mathrm{H}_{2}$ | $\mathrm{H}_{1}$ | $\mathrm{H}_{0}$ |

This 8-bit write-only register contains the widths of both HSYNC and VSYNC as follows:

## HVSW

7-4 VSYNC Pulse Width
The width of the vertical sync pulse (VSYNC) expressed as the number of scan lines. When bits $4-7$ are all 0, VSYNC is 16 scan lines wide.

## HVSW

## 3-0 HSYNC Pulse Width

The width of the horizontal sync pulse (HSYNC) expressed as the number of character clock times (CCLK). When bits 0-3 are all zero, HSYNC is 16 bit times wide.

Control of these parameters allows the R6545 to interface with a variety of CRT monitors, since the HSYNC and VSYNC timing signals may be accommodated without the use of external one shot timing.

## R4-VERTICAL TOTAL ROWS

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | NO. OF CHAR. ROWS -1 |  |  |  |  |  |  |

The 7-bit Vertical Total Register contains the total number of character rows in a frame, minus one. This register, along with R5, determines the overall frame rate, which should be close
to the line frequency to ensure flicker-free appearance. If the frame time is adjusted to be longer than the period of the line frequency, then RES may provide absolute synchronism.

## R5—VERTICAL TOTAL LINE ADJUST

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | SCAN LINES |  |  |  |  |

The 5-bit write-only Vertical Total Line Adjust Register (R5) contains the number of additional scan lines needed to complete an entire frame scan and is intended as a fine adjustment for the video frame time.

## R6-VERTICAL DISPLAYED ROWS

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | DISPLAYED CHAR. ROWS |  |  |  |  |  |  |

This 7-bit write-only register contains the number of displayed character rows in each frame. This determines the vertical size of the displayed text.

## R7-VERTICAL SYNC POSITION

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | VERTICAL POSITION |  |  |  |  |  |  |

This 7-bit write-only register selects the character row time at which the vertical SYNC pulse occurs and, thus, positions the displayed text in the vertical direction.

## R8-MODE CONTROL (MC)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| UM(T) | US(T) | CSK | DES | RRA | RAD | IMC |  |

This 8-bit write-only register selects the operating modes of the R6545, as follows:

[^2]\mp@subsup{}{}{4
SYSCLK
\overline{OCS}, \overline{DRCS, \overline{TTXREQ}, A0, A1, A13, R \overline{WW}}\mathrm{ ,}
VSYNC, ADO-AD7

``` & \(\mathrm{C}_{\text {IN }}\) & - & - & \[
\begin{array}{r}
10 \\
5
\end{array}
\] & pF & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \text {, chip } \\
& \text { deselected, pin } \\
& \text { Under test at } 0 \mathrm{~V} \text {, } \\
& \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \\
& \mathrm{f}=0.98 \mathrm{MHz} \\
& \text { (SYSCLK } \\
& =28.6363 \mathrm{MHz} \text { ) }
\end{aligned}
\] \\
\hline \multicolumn{7}{|l|}{\begin{tabular}{l}
Notes: \\
1. Output Load: 1 TTL gate; \(C_{L}=140 \mathrm{pF}\) \\
2. Output Load: 1 TTL gate; \(\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}\) \\
3. Output Load: 6 DRAM, 2 LS244 buffers and 1 LS245 transceiver; \(C_{L}=180 \mathrm{pF}\) \\
4. This parameter is periodically sampled and is not \(100 \%\) tested.
\end{tabular}} \\
\hline
\end{tabular}

\section*{ABSOLUTE MAXIMUM RATINGS*}
\begin{tabular}{|l|l|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.3 to +7.0 & V \\
\hline Input Voltages & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to +7.0 & V \\
\hline Operating Temperature & \(\mathrm{T}_{\mathrm{A}}\) & 0 to +70 & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\text {STO }}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
-NOTE: Stresses above those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{PACKAGE DIMENSIONS}

\section*{40-PIN PLASTIC DIP}

\begin{tabular}{|c|c|c|c|c|}
\hline \multirow{2}{*}{ DIM } & \multicolumn{2}{|c|}{ MILLIMETERS } & \multicolumn{2}{c|}{ INCHES } \\
\cline { 2 - 5 } & MIN & MAX & MIN & MAX \\
\hline A & 51.28 & 52.32 & 2.040 & 2.060 \\
\hline B & 13.72 & 14.22 & 0.540 & 0.560 \\
\hline C & 3.55 & 5.08 & 0.140 & 0.200 \\
\hline D & 0.36 & 0.51 & 0.014 & 0.020 \\
\hline F & 1.02 & 1.52 & 0.040 & 0.060 \\
\hline G & \multicolumn{2}{|c|}{2.54 BSC } & \multicolumn{2}{|c|}{0.100 BSC } \\
\hline H & 1.65 & 2.16 & 0.065 & 0.085 \\
\hline J & 0.20 & 0.30 & 0.008 & 0.012 \\
\hline K & 3.05 & 3.56 & 0.120 & 0.140 \\
\hline L & \multicolumn{2}{|c|}{15.24} & BSC & \multicolumn{2}{|c|}{0.600} & BSC \\
\hline M & \(7{ }^{\circ}\) & \(10^{\circ}\) & \multicolumn{2}{|c|}{\(7^{\circ}\)} \\
\hline N & 0.51 & \(10^{\circ}\) \\
\hline
\end{tabular}

\title{
R6551 \\ Asynchronous Communications Interface Adapter (ACIA)
}

\section*{DESCRIPTION}

The Rockwell R6551 Asynchronous Communications Interface Adapter (ACIA) provides an easily implemented, program controlled interface between 8 -bit microprocessor-based systems and serial communication data sets and modems.

The ACIA has an internal baud rate generator. This feature eliminates the need for multiple component support circuits, a crystal being the only other part required. The Transmitter baud rate can be selected under program control to be either 1 of 15 different rates from 50 to 19,200 baud, or at \(1 / 16\) times an external clock rate. The Receiver baud rate may be selected under program control to be either the Transmitter rate, or at \(1 / 16\) times an external clock rate. The ACIA has programmable word lengths of \(5,6,7\), or 8 bits; even, odd, or no parity; \(1,1 \frac{1}{2}\), or 2 stop bits.

The ACIA is designed for maximum programmed control from the microprocessor (MPU), to simplify hardware implementation. Three separate registers permit the MPU to easily select the R6551's operating modes and data checking parameters and determine operational status.

The Command Register controls parity, receiver echo mode, transmitter interrupt control, the state of the RTS line, receiver interrupt control, and the state of the \(\overline{\text { DTR }}\) line.

The Control Register controls the number of stop bits, word length, receiver clock source, and baud rate.

The Status Register indicates the states of the \(\overline{\mathrm{RQ}}, \overline{\mathrm{DSR}}\), and \(\overline{\mathrm{DCD}}\) lines, Transmitter and Receiver Data Registers, and Overrun, Framing, and Parity Error conditions.

The Transmitter and Receiver Data Registers are used for temporary data storage by the ACIA Transmit and Receiver circuits.

\section*{ORDERING INFORMATION}

\section*{FEATURES}
- Compatible with 8-bit microprocessors
- Full duplex operation with buffered receiver and transmitter
- Data set/modem control functions
- Internal baud rate generator with 15 programmable baud rates (50 to 19,200)
- Program-selectable internally or externally controlled receiver rate
- Programmable word lengths, number of stop bits, and parity bit generation and detection
- Programmable interrupt control
- Program reset
- Program-selectable serial echo mode
- Two chip selects
- 2 or 1 MHz operation
- \(5.0 \mathrm{Vdc} \pm 5 \%\) supply requirements
- 28-pin plastic or ceramic DIP
- Full TTL compatibility
- Compatible with R6500, R6500/* and R65C00 microprocessors


Figure 1. R6551 ACIA Pin Configuration


Figure 2. ACIA Internal Organization

\section*{FUNCTIONAL DESCRIPTION}

A block diagram of the ACIA is presented in Figure 2. A description of each functional element of the device follows.

\section*{DATA BUS BUFFERS}

The Data Bus Buffer interfaces the system data lines to the internal data bus. The Data Bus Buffer is bi-directional. When the \(R / \bar{W}\) line is low and the chip is selected, the Data Bus Buffer writes the data from the system data lines to the ACIA internal data bus. When the \(\mathrm{R} \bar{W}\) line is high and the chip is selected, the Data Bus Buffer drives the data from the internal data bus to the system data bus.

\section*{INTERRUPT LOGIC}

The Interrupt Logic will cause the \(\overline{\mathrm{RQ}}\) line to the microprocessor to go low when conditions are met that require the attention of the microprocessor. The conditions which can cause an interrupt will set bit 7 and the appropriate bit of bits 3 through 6 in the Status Register, if enabled. Bits 5 and 6 correspond to the Data Carrier Detect ( \(\overline{\mathrm{DCD}}\) ) logic and the Data Set Ready ( \(\overline{\mathrm{DSR}}\) ) logic. Bits 3 and 4 correspond to the Receiver Data Register full and the Transmitter Data Register empty conditions. These conditions can cause an interrupt request if enabled by the Command Register.

\section*{I/O CONTROL}

The I/O Control Logic controls the selection of internal registers for a data transfer on the internal data bus and the direction of the transfer to or from the register.

The registers are selected by the Register Select (RS1, RSO) and Read/Write \((\mathrm{R} / \overline{\mathrm{W}})\) lines as described later in Table 1.

\section*{TIMING AND CONTROL}

The Timing and Control logic controls the timing of data transfers on the internal data bus, the registers, the Data Bus Buffer, the microprocessor data bus, and the hardware reset.

Timing is controlled by the system \(\emptyset 2\) clock input. The chip will perform data transfers to or from the microcomputer data bus during the \(\emptyset 2\) high period when selected.

All registers will be initialized by the Timing and Control Logic when the Reset ( \(\overline{\mathrm{RES}}\) ) line goes low. See the individual register description for the state of the registers following a hardware reset.

\section*{TRANSMITTER AND RECEIVER DATA REGISTERS}

These registers are used as temporary data storage for the ACIA Transmit and Receive Circuits. Both the Transmitter and Receiver are selected by a Register Select 0 (RSO) and Register Select 1 (RS1) low condition. The Read/Write ( \(R / \bar{W}\) ) line determines which actually uses the internal data bus; the Transmitter Data Register is write only and the Receiver Data Register is read only.

Bit 0 is the first bit to be transmitted from the Transmitter Data Register (least significant bit first). The higher order bits follow in order. Unused bits in this register are "don't care".

The Receiver Data Register holds the first received data bit in bit 0 (least significant bit first). Unused high-order bits are " 0 ". Parity bits are not contained in the Receiver Data Register. They are stripped off after being used for parity checking.

\section*{STATUS REGISTER}

The Status Register indicates the state of interrupt conditions and other non-interrupt status information. The interrupt conditions are Data Set Ready and Data Carrier Detect transitions, Transmitter Data Register Empty and Receiver Data Register Full as reported in bits 6 through 3, respectively. If any of these bits are set, the Interrupt (IRQ) indicator (bit 7) is also set. Overrun, Framing Error and Parity Error are also reported (bits 2 through 0 respectively).

\begin{tabular}{|c|c|}
\hline Bit 7 & Interrupt (IRQ) \\
\hline 0 & No interrupt \\
\hline 1 & Interrupt has occurred \\
\hline Bit 6 & Data Set Ready ( \(\overline{\mathrm{DSR}})\) \\
\hline 0 & DSR low (ready) \\
\hline 1 & \(\overline{\mathrm{DSR}}\) high (not ready) \\
\hline Bit 5 & Data Carrier Detect ( \(\overline{\mathrm{DCD}}\) ) \\
\hline 0 & \(\overline{\mathrm{DCD}}\) low (detected) \\
\hline 1 & \(\overline{\mathrm{DCD}}\) high (not detected) \\
\hline Bit 4 & Transmitter Data Register Empty \\
\hline 0 & Not empty \\
\hline 1 & Empty \\
\hline Bit 3 & Receiver Data Register Full \\
\hline 0 & Not full \\
\hline 1 & Full \\
\hline Bit 2 & Overrun* \\
\hline 0 & No overrun \\
\hline 1 & Overrun has occurred \\
\hline Bit 1 & Framing Error* \\
\hline 0 & No framing error \\
\hline 1 & Framing error detected \\
\hline Bit 0 & Parity Error* \\
\hline 0 & No parity error \\
\hline 1 & Parity error detected \\
\hline
\end{tabular}
*No interrupt occurs for these conditions

\section*{Reset Initialization}


Hardware reset
Program reset

Parity Error (Bit 0), Framing Error (Bit 1), and Overrun (Bit 2)

None of these bits causes a processor interrupt to occur, but they are normally checked at the time the Receiver Data Register is read so that the validity of the data can be verified. These bits are self clearing (i.e., they are automatically cleared after a read of the Receiver Data Register)

\section*{Receiver Data Register Full (Bit 3)}

This bit goes to a 1 when the ACIA transfers data from the Receiver Shift Register to the Receiver Data Register, and goes to a 0 (is cleared) when the processor reads the Receiver Data Register.

\section*{Transmitter Data Register Empty (Bit 4)}

This bit goes to a 1 when the ACIA transfers data from the Transmitter Data Register to the Transmitter Shift Register, and goes to a 0 (is cleared) when the processor writes new data onto the Transmitter Data Register.

NOTE: There is a delay of approximately \(1 / 16\) of a bit time after TDR becomes empty/full before this flag is updated.

\section*{Data Carrier Detect (Bit 5) and Data Set Ready (Bit 6)}

These bits reflect the levels of the \(\overline{D C D}\) and \(\overline{D S R}\) inputs to the ACIA. A 0 indicates a low level (true condition) and a 1 indicates a high level (false). Whenever either of these inputs change state, an immediate processor interrupt (IRQ) occurs. When the interrupt occurs, the status bits indicate the levels of the inputs immediately after the change of state occurred. Subsequent level changes will not affect the status bits until after the Status Register has been interrogated by the processor. At that time, another interrupt will immediately occur and the status bits will reflect the new input levels. These bits are not automatically cleared (or reset) by an internal operation.

\section*{Interrupt (Bit 7)}

This bit goes to a 1 whenever an interrupt condition occurs and goes to a 0 (is cleared) when the Status Register is read.

\section*{CONTROL REGISTER}

The Control Register selects the desired baud rate, frequency source, word length, and the number of stop bits.


Bits 3-0 Selected Baud Rate (SBR)
\begin{tabular}{lllll}
\(\frac{3}{0}\) & \(\frac{2}{0}\) & \(\frac{1}{0}\) & \(\frac{0}{0}\) & \(\frac{\text { Baud }}{16 x \text { External Clock }}\) \\
0 & 0 & 0 & 1 & 50 \\
0 & 0 & 1 & 0 & 75 \\
0 & 0 & 1 & 1 & 109.92 \\
0 & 1 & 0 & 0 & 134.58 \\
0 & 1 & 0 & 1 & 150 \\
0 & 1 & 1 & 0 & 300 \\
0 & 1 & 1 & 1 & 600 \\
1 & 0 & 0 & 0 & 1200 \\
1 & 0 & 0 & 1 & 1800 \\
1 & 0 & 1 & 0 & 2400 \\
1 & 0 & 1 & 1 & 3600 \\
1 & 1 & 0 & 0 & 4800 \\
1 & 1 & 0 & 1 & 7200 \\
1 & 1 & 1 & 0 & 9600 \\
1 & 1 & 1 & 1 & 19,200
\end{tabular}

\section*{Reset Initialization}
\begin{tabular}{|l|l|l|llllll|l}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline- & - & - & - & - & - & - & - \\
\hline
\end{tabular} \begin{tabular}{l} 
Hardware reset ( \(\overline{\mathrm{RES}})\) \\
Program reset
\end{tabular}

\section*{Selected Baud Rate (Bits 0, 1, 2, 3)}

These bits select the Transmitter baud rate, which can be at \(1 / 16\) an external clock rate or one of 15 other rates controlled by the internal baud rate generator.

If the Receiver clock uses the same baud rate as the transmitter, then RxC becomes an output and can be used to slave other circuits to the ACIA. Figure 3 shows the Transmitter and Receiver layout.


\section*{Receiver Clock Source (Bit 4)}

This bit controls the clock source to the Receiver. A 0 causes the Receiver to operate at a baud rate of \(1 / 16\) an external clock. A 1 causes the Receiver to operate at the same baud rate as is selected for the transmitter.

\section*{Word Length (Bits 5, 6)}

These bits determine the word length to be used \((5,6,7\) or 8 bits).

\section*{Stop Bit Number (Bit 7)}

This bit determines the number of stop bits used. A 0 always indicates one stop bit. A 1 indicates \(11 / 2\) stop bits if the word length is 5 with no parity selected, 1 stop bit if the word length is 8 with parity selected, or 2 stop bits in all other configurations.

\section*{COMMAND REGISTER}

The Command Register controls specific modes and functions.

\begin{tabular}{|c|c|}
\hline Bits 7-6 & Parity Mode Control (PMC) \\
\hline \(7 \quad 6\) & \\
\hline 0 & Odd parity transmitted/received \\
\hline 0 & Even parity transmitted/received \\
\hline \multirow[t]{2}{*}{0} & Mark parity bit transmitted \\
\hline & Parity check disabled \\
\hline \multirow[t]{2}{*}{1} & Space parity bit transmitted \\
\hline & Parity check disabled \\
\hline \multirow[t]{4}{*}{\[
\begin{gathered}
\text { Bit } 5 \\
0
\end{gathered}
\]} & Parity Mode Enabled (PME) \\
\hline & Parity mode disabled \\
\hline & No parity bit generated \\
\hline & Parity check disabled \\
\hline 1 & Parity mode enabled \\
\hline Bit 4 & Receiver Echo Mode (REM) \\
\hline 0 & Receiver normal mode \\
\hline 1 & Receiver echo mode \\
\hline & Bits 2 and 3 must also be zero for receiver echo mode, \(\overline{\mathrm{RTS}}\) will be low. \\
\hline
\end{tabular}

Bits 3-2 Transmitter Interrupt Control (TIC)
\begin{tabular}{|c|c|c|}
\hline 0 & \(\frac{2}{0}\) & \\
\hline 0 & 1 & \(\overline{\text { RTS }}=\) Low, transmit interrupt enabled \\
\hline 1 & 0 & RTS \(=\) Low, tansmit interrupt disabled \\
\hline 1 & 1 & \(\overline{\text { RTS }}=\) Low, transmit interrupt disabled, transmit break on TxD** \\
\hline
\end{tabular}

Bit 1 Receiver Interrupt Request Disabled (IRD)
\(0 \quad \overline{\mathrm{IRQ}}\) enabled (receiver)
\(1 \quad \overline{\mathrm{RQ}}\) disabled (receiver)
Bit \(0 \quad\) Data Terminal Ready (DTR)
0 Data terminal not ready (DTR high)*
1 Data terminal ready (DTR low)

\section*{NOTES}
*The transmitter is disabled immediately. The receiver is disabled but will first complete receiving a byte in process of being received.
**A break is transmitted only after the end of a character stream. If the Transmit Data Register contains a character, the break is not transmitted.

\section*{Data Terminal Ready (Bit 0)}

This bit enables all selected interrupts and controls the state of the Data Terminal Ready ( \(\overline{\mathrm{DTR}}\) ) line. A 0 indicates the microcomputer system is not ready by setting the DTR line high. A 1 indicates the microcomputer system is ready by setting the \(\overline{\text { DTR }}\) line low. \(\overline{\text { DTR }}\) also enables and disables the transmitter and receiver.

\section*{Receiver Interrupt Control (Bit 1)}

This bit disables the Receiver from generating an interrupt when set to a 1 . The Receiver interrupt is enabled when this bit is set to a 0 and Bit 0 is set to a 1 .

\section*{Transmitter Interrupt Control (Bits 2, 3)}

These bits control the state of the Ready to Send ( \(\overline{\mathrm{RTS}}\) ) line and the Transmitter interrupt.

\section*{Receiver Echo Mode (Bit 4)}

A 1 enables the Receiver Echo Mode and a 0 disables the Receiver Echo Mode. When bit 4 is a 1 bits 2 and 3 must be 0 . In the Receiver Echo Mode, the Transmitter returns each transmission received by the Receiver delayed by one-half bit time.

\section*{Parity Mode Enable (Bit 5)}

This bit enables parity bit generation and checking. A 0 disables parity bit generation by the Transmitter and parity bit checking by the Receiver. A 1 bit enables generation and checking of parity bits.

\section*{Parity Mode Control (Bits 6, 7)}

These bits determine the type of parity generated by the Transmitter, (even, odd, mark or space) and the type of parity check done by the Receiver (even, odd, or no check).

\section*{Reset Initialization}
\begin{tabular}{|l|l|l|l|l|l|l|l|l}
7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & Hardware reset ( \(\overline{\mathrm{RES}}\) ) \\
\hline- & - & - & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

\section*{INTERFACE SIGNALS}

Figure 4 shows the ACIA interface signals associated with the microprocessor and the modem.


Figure 4. ACIA Interface Diagram

\section*{MICROPROCESSOR INTERFACE}

\section*{Reset ( \(\overline{\text { RES }})\)}

During system initialization a low on the \(\overline{R E S}\) input causes a hardware reset to occur. Upon reset, the Command Register and the Control Register are cleared (all bits set to 0 ). The Status Register is cleared with the exception of the indications of Data Set Ready and Data Carrier Detect, which are externally controlled by the \(\overline{\mathrm{DSR}}\) and \(\overline{\mathrm{DCD}}\) lines, and the transmitter Empty bit, which is set. \(\overline{\text { RES }}\) must be held low for one \(\emptyset 2\) clock cycle for a reset to occur.

\section*{Input Clock (02)}

The input clock is the system \(\emptyset 2\) clock and clocks all data transfers between the system microprocessor and the ACIA.

NOTE: The specified maximum cycle time for the signal on this input is \(40 \mu \mathrm{~s}\). This specification must be observed to prevent loss of data.

\section*{Read/Write (R/W)}

The \(\mathrm{R} / \overline{\mathrm{W}}\) input, generated by the microprocessor controls the direction of data transfers. A high on the \(R / \bar{W}\) pin allows the processor to read the data supplied by the ACIA, a low allows a write to the ACIA.

\section*{Interrupt Request ( \(\overline{\mathrm{IRQ}}\) )}

The \(\overline{\mathrm{RQ}}\) pin is an interrupt output from the interrupt control logic. It is an open drain output, permitting several devices to be connected to the commmon \(\overline{\mathrm{RQ}}\) microprocessor input. Normally a high level, \(\overline{I R Q}\) goes low when an interrupt occurs.

\section*{Data Bus (D0-D7)}

The eight data line (D0-D7) pins transfer data between the processor and the ACIA. These lines are bi-directional and are normally high-impedance except during Read cycles when the ACIA is selected.

\section*{Chip Selects (CS0, \(\overline{\mathrm{CS} 1)}\)}

The two chip select inputs are normally connected to the processor address lines either directly or through decoders. The ACIA is selected when CS0 is high and CS1 is low. When the ACIA is selected, the internal registers are addressed in accordance with the register select lines (RS0, RS1).

\section*{Register Selects (RSO, RS1)}

The two register select lines are normally connected to the processor address lines to allow the processor to select the various ACIA internal registers. Table 1 shows the internal register select decoding.

Table 1. ACIA Register Selection
\begin{tabular}{|c|c|l|l|}
\hline \multirow{2}{*}{ RS1 } & RS0 & \multicolumn{2}{|c|}{ Register Operation } \\
\cline { 3 - 4 } & \multicolumn{1}{|c|}{ R/信 = Low } & \multicolumn{1}{|c|}{ R/ \(\bar{W}=\) High } \\
\hline L & L & \begin{tabular}{l} 
Write Transmit Data \\
Register
\end{tabular} & \begin{tabular}{l} 
Read Receiver \\
Data Register
\end{tabular} \\
\hline L & H & \begin{tabular}{l} 
Programmed Reset \\
(Data is "Don't \\
Care")
\end{tabular} & \begin{tabular}{l} 
Read Status \\
Register
\end{tabular} \\
\hline H & L & \begin{tabular}{l} 
Write Command \\
Register
\end{tabular} & \begin{tabular}{l} 
Read Command \\
Register
\end{tabular} \\
\hline H & H & \begin{tabular}{l} 
Write Control \\
Register
\end{tabular} & \begin{tabular}{l} 
Read Control \\
Register
\end{tabular} \\
\hline
\end{tabular}

Only the Command and Control registers can be both read and written. The programmed Reset operation does not cause any data transfer, but is used to clear bits 4 through 0 in the Command register and bit 2 in the Status Register. The Control Register is unchanged by a programmed Reset. It should be noted that the programmed Reset is slightly different from the hardware Reset (RES); refer to the register description.

\section*{ACIA/MODEM INTERFACE}

\section*{Crystal Pins (XTLI, XTLO)}

These pins are normally directly connected to a series mode external crystal ( 1.8432 MHz ) to derive the various baud rates. Alternatively, an externally generated clock can drive the XTLI pin, in which case the XTLO pin must float. XTLI is the input pin for the transmit clock.

\section*{Transmit Data (TxD)}

The TxD output line transfers serial nonreturn-to-zero (NRZ) data to the modem. The least significant bit (LSB) of the Transmit Data Register is the first data bit transmitted and the rate of data transmission is determined by the baud rate selected or by an external clock. This selection is made by programming the Control Register.

\section*{Receive Data (RxD)}

The RxD input line transfers serial NRZ data into the ACIA from the modem, LSB first. The receiver data rate is determined by the programmed baud rate or by an externally generated receiver clock. The selection is made by programming the Control Register.

\section*{Receive Clock (RxC)}
\(R x C\) is a bi-directional pin which is either the receiver \(16 x\) clock input or the receiver \(16 x\) clock output. The latter mode results if the internal baud rate generator is selected for receiver data clocking.

\section*{Request to Send ( \(\overline{\text { RTS }}\) )}

The \(\overline{\text { RTS }}\) output pin controls the modem from the processor. The state of the RTS pin is determined by the contents of the Command Register.

\section*{Clear to Send ( \(\overline{C T S}\) )}

The \(\overline{\mathrm{CTS}}\) input pin controls the transmitter operation. The enable state is with CTS low. The transmitter is automatically disabled if \(\overline{\mathrm{CTS}}\) is high.

\section*{Data Terminal Ready ( \(\overline{\text { DTR }}\) )}

This output pin indicates the status of the ACIA to the modem. A low on \(\overline{D T R}\) indicates the ACIA is enabled, a high indicates it is disabled. The processor controls this pin via bit 0 of the Command Register.

\section*{Data Set Ready ( \(\overline{\mathrm{DSR}}\) )}

The \(\overline{\mathrm{DSR}}\) input pin indicates to the ACIA the status of the modem. A low indicates the "ready" state and a high, "notready."

\section*{Data Carrier Detect ( \(\overline{\mathrm{DCD}}\) )}

The \(\overline{D C D}\) input pin indicates to the ACIA the status of the carrierdetect output of the modem. A low indicates that the modem carrier signal is present and a high, that it is not.

\section*{TRANSMITTER AND RECEIVER OPERATION}

\section*{Continuous Data Transmit}

In the normal operating mode, the interrupt request output ( \(\overline{\mathrm{R} Q}\) ) signals when the ACIA is ready to accept the next data word to be transmitted. This interrupt occurs at the beginning of the Start Bit. When the processor reads the Status Register of the ACIA, the interrupt is cleared.

The processor must then identify that the Transmit Data Register is ready to be loaded and must then load it with the next data word. This must occur before the end of the Stop Bit, otherwise a continuous "MARK" will be transmitted. Figure 5 shows the continuous Data Transmit timing relationship.


Figure 5. Continuous Data Transmit

\section*{Continuous Data Receive}

Similar to the Continuous Data Transmit case, the normal operation of this mode is to assert \(\overline{\mathrm{RQ}}\) when the ACIA has received a full data word. This occurs at about \(9 / 16\) point through the Stop Bit. The processor must read the Status Register and
read the data word before the next interrupt, otherwise the Overrun condition occurs. Figure 6 shows the continuous Data Receive Timing Relationship.


Figure 6. Continuous Data Receive

\section*{Transmit Data Register Not Loaded by Processor}

If the processor is unable to load the Transmit Data Register in the allocated time, then the TxD line goes to the "MARK" condition until the data is loaded. \(\overline{\mathrm{IRQ}}\) interrupts continue to occur at the same rate as previously, except no data is transmitted.

When the processor finally loads new data, a Start Bit immediately occurs, the data word transmission is started, and another interrupt is initiated, signaling for the next data word. Figure 7 shows the timing relationship for this mode of operation.


Figure 7. Transmit Data Register Not Loaded by Processor

\section*{Effect of \(\overline{\text { CTS }}\) on Transmitter}
\(\overline{\mathrm{CTS}}\) is the Clear-to-Send Signal generated by the modem. It is normally low (true state) but may go high in the event of some modem problems. When this occurs, the TxD line immediately goes to the "MARK" condition. Interrupts continue at the same rate, but the Status Register does not indicate that the Transmit

Data Register is empty. Since there is no status bit for \(\overline{\mathrm{CTS}}\), the processor must deduce that CTS has gone to the FALSE (high) state. \(\overline{\text { CTS }}\) is a transmit control line only, and has no effect on the R6551 Receiver Operation. Figure 8 shows the timing relationship for this operation.


Figure 8. Effect of CTS on Transmitter

\section*{Effect of Overrun on Receiver}

If the processor does not read the Receiver data Register in the allocated time, then, when the next interrupt occurs, the new data word is not transferred to the Receiver Data Register, but the

Overrun status bit is set. Thus, the Data Register will contain the last valid data word received and all following data is lost. Figure 9 shows the timing relationship for this mode.


Figure 9. Effect of Overrun on Receiver

\section*{Echo Mode Timing}

In Echo Mode, the TxD line re-transmits the data on the RxD line, delayed by \(1 / 2\) of the bit time, as shown in Figure 10.


Figure 10. Echo Mode Timing

\section*{Effect of CTS on Echo Mode Operation}

In Echo Mode, the Receiver operation is unaffected by \(\overline{\mathrm{CTS}}\), however, the Transmitter is affected when CTS goes high, i.e., the TxD line immediately goes to a continuous "MARK" condition. In this case, however, the Status Request indicates that
the Receiver Data Register is full in response to an \(\overline{\mathrm{RQ}}\), so the processor has no way of knowing that the Transmitter has ceased to echo. See Figure 11 for the timing relationship of this mode.


Figure 11. Effect of \(\overline{\mathrm{CTS}}\) on Echo Mode

\section*{Overrun in Echo Mode}

If Overrun occurs in Echo Mode, the Receiver is affected the same way as a normal overrun in Receive Mode. For the retransmitted data, when overrun occurs, the TxD line goes to the
"MARK" condition until the first Start Bit after the Receiver Data Register is read by the processor. Figure 12 shows the timing relationship for this mode.


Figure 12. Overrun in Echo Mode

\section*{Framing Error}

Framing Error is caused by the absence of Stop Bit(s) on received data. A Framing Error is indicated by the setting of bit 1 in the Status Register at the same time the Receiver Data Register Full bit is set, also in the Status Register. In response to \(\overline{\mathrm{RQ}}\),
generated by RDRF, the Status Register can also be checked for the Framing Error. Subsequent data words are tested for Framing Error separately, so the status bit will always reflect the last data word received. See Figure 13 for Framing Error timing relationship.


Figure 13. Framing Error

\section*{Effect of \(\overline{\mathrm{DCD}}\) on Receiver}
\(\overline{D C D}\) is a modem output indicating the status of the carrier-fre-quency-detection circuit of the modem. This line goes high for a loss of carrier. Normally, when this occurs, the modem will stop transmitting data some time later. The ACIA asserts \(\overline{\mathrm{RQ}}\) whenever \(\overline{\mathrm{DCD}}\) changes state and indicates this condition via bit 5 in the Status Register.

Once such a change of state occurs, subsequent transitions will not cause interrupts or changes in the Status Register until the first interrupt is serviced. When the Status Register is read by the processor, the ACIA automatically checks the level of the \(\overline{D C D}\) line, and if it has changed, another \(\overline{\mathrm{RQ}}\) occurs (see Figure 14).


Figure 14. Effect of DCD on Receiver

\section*{Timing with \(11 / 2\) Stop Bits}

It is possible to select \(11 / 2\) Stop Bits, but this occurs only for 5-bit data words with no parity bit. In this case, the \(\overline{\mathrm{RQ}}\) asserted for Receiver Data Register Full occurs halfway through the
trailing half-Stop Bit. Figure 15 shows the timing relationship for this mode.


Figure 15. Timing with \(11 / 2\) Stop Bits

\section*{Transmit Continuous "BREAK"}

This mode is selected via the ACIA Command Register and causes the Transmitter to send continuous "BREAK" characters, beginning with the next character transmitted. At least one full "BREAK" character will be transmitted, even if the processor quickly re-programs the Command Register transmit mode. Later, when the Command Register is programmed back to normal transmit mode, an immediate Stop Bit will be generated and transmission will resume. Figure 16 shows the timing relationship for this mode.

\section*{Note}

If, while operating in the Transmit Continuous "BREAK" mode, the \(\overline{C T S}\) should go to a high, the TXD will be overridden by the CTS and will go to continuous "MARK" at the beginning of the next character transmitted after the \(\overline{\mathrm{CTS}}\) goes high.


Figure 16. Transmit Continuous "BREAK"

\section*{Receive Continuous "BREAK"}

In the event the modem transmits continuous "BREAK" characters, the ACIA will terminate receiving. Reception will resume only after a Stop Bit is encountered by the ACIA. Figure 17
shows the timing relationship for continuous "BREAK" characters.


Figure 17. Receive Continuous "BREAK"

\section*{STATUS REGISTER OPERATION}

Because of the special functions of the various status bits, there is a suggested sequence for checking them. When an interrupt occurs, the ACIA should be interrogated, as follows:
1. Read Status Register

This operation automatically clears Bit 7 (IRQ). Subsequent transitions on DSR and DCD will cause another interrupt.
2. Check IRQ (Bit 7) in the data read from the Status Register

If not set, the interrupt source is not the ACIA.
3. Check \(\overline{D C D}\) and \(\overline{D S R}\)

These must be compared to their previous levels, which must have been saved by the processor. If they are both 0 (modem "on-line") and they are unchanged then the remaining bits must be checked.
4. Check RDRF (Bit 3)

Check for Receiver Data Register Full.
5. Check Parity, Overrun, and Framing Error (Bits 0-2) if the Receiver Data Register is full.
6. Check TDRE (Bit 4)

Check for Transmitter Data Register Empty.
7. If none of the above conditions exist, then \(\overline{\mathrm{CTS}}\) must have gone to the false (high) state.

\section*{PROGRAM RESET OPERATION}

A program reset occurs when the processor performs a write operation to the ACIA with RSO. Iow and RS1 high. The program reset operates somewhat different from the hardware reset ( \(\overline{\operatorname{RES}} \mathrm{pin}\) ) and is described as follows:
1. Internal registers are not completely cleared. Check register formats for the effect of a program reset on internal registers.
2. The \(\overline{\mathrm{DTR}}\) line goes high immediately.
3. Receiver and transmitter interrupts are disabled immediately. If \(\overline{\mathrm{IRQ}}\) is low when the reset occurs, it stays low until serviced, unless interrupt was caused by \(\overline{\mathrm{DCD}}\) or \(\overline{\mathrm{DSR}}\) transition.
4. \(\overline{\mathrm{DCD}}\) and \(\overline{\mathrm{DSR}}\) interrupts are disabled immediately. If \(\overline{\mathrm{IRQ}}\) is low and was caused by \(\overline{D C D}\) or \(\overline{D S R}\), then it goes high, also \(\overline{D C D}\) and \(\overline{D S R}\) status bits subsequently will follow the input lines, although no interrupt will occur.
5. Overrun cleared, if set.

\section*{MISCELLANEOUS}
1. If Echo Mode is selected, \(\overline{\mathrm{RTS}}\) goes low.
2. If Bit 0 of Command Register ( \(\overline{\mathrm{DTR}})\) is 0 (disabled), then:
a) All interrupts are disabled, including those caused by \(\overline{\mathrm{DCD}}\) and \(\overline{\mathrm{DSR}}\) transitions.
b) Transmitter is disabled immediately.
c) Receiver is disabled, but a character currently being received will be completed first.
3. Odd parity occurs when the sum of all the 1 bits in the data word (including the parity bit) is odd.
4. In the receive mode, the received parity bit does not go into the Receiver Data Register, but generates parity error or no parity error for the Status Register.
5. Transmitter and Receiver may be in full operation simultaneously. This is "full-duplex" mode.
6. If the RxD line inadvertently goes low and then high right after a Stop Bit, the ACIA does not interpret this as a Start Bit, but samples the line again halfway into the bit time to determine if it is a true Start Bit or a false one. For false Start Bit detection, the ACIA does not begin to receive data, instead, only a true Start Bit initiates receiver operation.
7. \(\overline{\mathrm{DCD}}\) andd \(\overline{\mathrm{DSR}}\) transitions, although causing immediate processor interrupts, have no affect on transmitter operation. Data will continue to be sent, unless the processor forces transmitter to turn off. Since these are high-impedance inputs, they must not be permitted to float (un-connected). If unused, they must be terminated to GND.

\section*{CRYSTAL/CLOCK CONSIDERATIONS}

\section*{CLOCK OSCILLATOR}

The on-chip oscillator is designed for a series resonant crystal connected between XTLI and XTLO pins (Figure 18).
A series resonant crystal is specified by the series resistance \(\left(R_{s}\right)\) at its series resonant frequency. For proper oscillator operation, the selected series resonant crystal should have a series resistance less than 400 ohms.


Figure 18. Internal Clock Connection

\section*{BAUD RATE GENERATION}

\section*{DIVISORS}

The internal counter/divider circuit generates appropriate divisors to produce standard baud rates when a 1.8432 MHz crystal is connected between XTLI and XTLO. Control Register bits 0-3 select the divisor for a particular bit rate as shown in Table 2.

\section*{EXTERNAL CLOCK}

The XTLI input may be used as an external clock input (Figure 19). For this implementation, a times 16 clock is input on XTLI and XTLO is left open.


Figure 19. External Clock Connection

\section*{generating non-standard baud rates}

By using a different crystal, non-standard baud rates may be generated. These can be determined by:
\[
\text { Baud Rate }=\frac{\text { Crystal Frequency }}{\text { Divisor }}
\]

Furthermore, it is possible to drive the ACIA with an off-chip oscillator to achieve other baud rates. In this case, XTALI (pin 6) must be the clock input and XTALO (pin 7) must be a no-connect.

Table 2. Divisor Selection
\begin{tabular}{|c|c|c|c|}
\hline \begin{tabular}{c} 
Control \\
Register \\
Bits
\end{tabular} & \begin{tabular}{c} 
Divisor Selected \\
For The \\
Internal Counter
\end{tabular} & \begin{tabular}{c} 
Baud Rate Generated \\
With \(1.8432 ~ M H z\) \\
Crystal
\end{tabular} & \begin{tabular}{c} 
Baud Rate Generated \\
With a Crystal \\
of Frequency (F)
\end{tabular} \\
\hline \(\mathbf{3} \mathbf{2} \boldsymbol{1} \boldsymbol{0}\) & No Divisor Selected & \(16 \times\) External Clock at Pin RxC & 16 \(\times\) External Clock at Pin RxC \\
\hline 0 & 0 & 0 & 0
\end{tabular}

\section*{DIAGNOSTIC LOOP-BACK} OPERATING MODES

A simplified block diagram for a system incorporating an ACIA is shown in Figure 20.

It may be desirable to include in the system a facility for local loopback testing.

In loop-back testing from the point of view of the processor, the Modem and Data Link must be effectively disconnected and the ACIA transmitter connected back to its own receiver, so that the processor can perform diagnostic checks on the system, excluding the actual data channel.

The ACIA does not contain automatic loop-back operating modes, but they may be implemented with the addition of a small amount of external circuitry. Figure 21 indicates the necessary logic to be used with the ACIA. The LLB line is the positive-true signal to enable local loop-back operation. Essentially, LLB = high does the following:
1. Disables outputs TXD, \(\overline{\mathrm{DTR}}\), and \(\overline{\mathrm{RTS}}\) (to Modem).
2. Disables outputs \(\mathrm{R} \times \mathrm{D}, \overline{\mathrm{DCD}}, \overline{\mathrm{CTS}}, \overline{\mathrm{DSR}}\) (from Modem).
3. Connects transmitter outputs to respective receiver inputs (i.e. \(T \times D\) to \(R \times D, \overline{D T R}\) to \(\overline{D C D}, \overline{R T S}\) to \(\overline{C T S})\).

LLB may be tied to a peripheral control pin (from an R6520 or R6522, for example) to provide processor control of local loop-back operation. In this way, the processor can easily perform local loopback diagnostic testing.


Figure 20. Simplified System Diagram


Figure 21. Loop-Back Circuit Schematic

\section*{READ TIMING DIAGRAM}

Timing diagrams for transmit with external clock, receive with external clock, and \(\overline{\mathrm{RQ}}\) generation are shown in Figures 22, 23 and 24, respectively. The corresponding timing characteristics are listed in the Table 3.

Table 3. Transmit/Receive Characteristics
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Characteristic} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|l|}{2 MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min & Max & Min & Max & \\
\hline Transmit/Receive Clock Rate & \(\mathrm{t}_{\mathrm{cCY}}\) & 400* & - & 400* & - & ns \\
\hline Transmit/Receive Clock High Time & \({ }^{\text {t }}\) CH & 175 & - & 175 & - & ns \\
\hline Transmit/Receive Clock Low Time & \({ }^{\text {ctL }}\) & 175 & - & 175 & - & ns \\
\hline \begin{tabular}{l}
XTLI to TxD \\
Propagation Delay
\end{tabular} & \(t_{D D}\) & - & 500 & - & 500 & ns \\
\hline RTS Propagation Delay & \(\mathrm{t}_{\text {DLY }}\) & - & 500 & - & 500 & ns \\
\hline \(\overline{\overline{R Q}}\) Propagation Delay (Clear) & \(\mathrm{t}_{\mathrm{IRQ}}\) & - & 500 & - & 500 & ns \\
\hline Load Capacitance DTR, RTS TxD & \(\mathrm{C}_{\mathrm{L}}\) & - & \[
\begin{array}{r}
130 \\
30
\end{array}
\] & - & \[
\begin{array}{r}
130 \\
30
\end{array}
\] & \[
\begin{aligned}
& \mathrm{pF} \\
& \mathrm{pF}
\end{aligned}
\] \\
\hline \multicolumn{7}{|l|}{Notes:
\[
\left(t_{R}, t_{F}=10 \text { to } 30 \mathrm{~ns}\right)
\]} \\
\hline \multicolumn{7}{|l|}{*The baud rate with external clocking is: Baud Rate \(=\frac{1}{16 \times \mathrm{t}_{\mathrm{CCY}}}\)} \\
\hline
\end{tabular}


Figure 22. Transmit Timing with External Clock


Figure 23. Receive External Clock Timing


Figure 24. Interrupt and Output Timing

\section*{AC CHARACTERISTICS}
( \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{S S}=0, \mathrm{~T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}\) to \(\mathrm{T}_{\mathrm{H}}\), unless otherwise noted)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Parameter} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min & Max & Min & Max & \\
\hline Cycle Time & \(t_{\text {cre }}\) & 1.0 & 40 & 0.5 & 40 & \(\mu \mathrm{s}\) \\
\hline \(\emptyset 2\) Pulse Width & \({ }_{\text {t }}\) & 400 & - & 200 & - & ns \\
\hline Address Set-Up Time & \(\mathrm{t}_{\text {ACW }}, \mathrm{t}_{\text {ACR }}\) & 120 & - & 70 & - & ns \\
\hline Address Hold Time & \(\mathrm{t}_{\text {CAH }}, \mathrm{t}_{\text {CAR }}\) & 0 & - & 0 & - & ns \\
\hline R/W Set-Up Time & \(t_{\text {WCW }}, t_{\text {WCR }}\) & 120 & - & 70 & - & ns \\
\hline R/W Hold Time & \(\mathrm{t}_{\text {cWh }}\) & 0 & - & 0 & - & ns \\
\hline Data Bus Set-Up Time & \(t_{\text {dow }}\) & 150 & - & 60 & - & ns \\
\hline Data Bus Hold Time & \(\mathrm{t}_{\mathrm{HW}}\) & 20 & - & 20 & - & ns \\
\hline Read Access Time (Valid Data) & \(t_{\text {cDR }}\) & - & 200 & - & 150 & ns \\
\hline Read Hold Time & \(\mathrm{t}_{\mathrm{HR}}\) & 20 & - & 20 & - & ns \\
\hline Bus Active Time (Invalid Data) & \(t_{\text {CDA }}\) & 40 & - & 40 & - & ns \\
\hline
\end{tabular}

Notes: 1. \(\mathrm{t}_{\mathrm{R}}\) and \(\mathrm{t}_{\mathrm{F}}=10\) to 30 ns .
2. D0-D7 load capacitance \(=130 \mathrm{pF}\).
3. Timing measurements are referenced to/from a low of 0.8 volts and a high of 2.0 volts.

CS0, \(\overline{\mathbf{C S}}, \mathrm{RS} 0, \mathrm{RS} 1\)


Write Timing Diagram


Read Timing Diagram

\section*{ABSOLUTE MAXIMUM RATINGS}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.3 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\text {IN }}\) & -0.3 to \(\mathrm{V}_{\mathrm{CC}}\) & Vdc \\
\hline Output Voltage & \(\mathrm{V}_{\mathrm{OUT}}\) & -0.3 to \(\mathrm{V}_{\mathrm{CC}}\) & Vdc \\
\hline Operating Temperature & \(\mathrm{T}_{\mathrm{A}}\) & 0 to +70 & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\mathrm{STG}}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{OPERATING CONDITIONS}
\begin{tabular}{|l|c|c|}
\hline Parameter & Symbol & Value \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & \(5 \mathrm{~V} \pm 5 \%\) \\
\hline Temperature Range & \(\mathrm{T}_{\mathrm{A}}\) & \\
Commercial & & \(0^{\circ}\) to \(70^{\circ} \mathrm{C}\) \\
Industrial & & \(-40^{\circ} \mathrm{C}\) to \(+85^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}

\section*{DC CHARACTERISTICS}
\(\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{S S}=0, T_{A}=T_{L}\right.\) to \(T_{H}\), unless otherwise noted)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ & Max & Unit & Test Conditions \\
\hline \begin{tabular}{l}
Input High Voltage \\
Except XTLI and XTLO \\
XTLI and XTLO
\end{tabular} & \(\mathrm{V}_{\text {IH }}\) & \[
\begin{aligned}
& 2.0 \\
& 2.4
\end{aligned}
\] & - & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{cc}} \\
& \mathrm{~V}_{\mathrm{cc}}
\end{aligned}
\] & V & \\
\hline \begin{tabular}{l}
Input Low Voltage \\
Except XTLI and XTLO \\
XTLI and XTLO
\end{tabular} & \(V_{\text {IL }}\) & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{SS}} \\
& \mathrm{~V}_{\mathrm{SS}}
\end{aligned}
\] & - & \[
\begin{aligned}
& 0.8 \\
& 0.4
\end{aligned}
\] & V & \\
\hline Input Leakage Current \(\emptyset 2, R / \bar{W}, \overline{R E S}, C S 0, C S 1, R S 0, R S 1, \overline{C T S}, R x D, \overline{D C D}, \overline{D S R}\) & IIN & - & - & 2.5 & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& V_{1 N}=0 \mathrm{~V} \text { to } 5 \mathrm{~V} \\
& V_{C C}=0 \mathrm{~V}
\end{aligned}
\] \\
\hline Input Leakage Current for High Impedance (Three State Off)
D0-D7 & \(I_{\text {TSI }}\) & - & - & \(\pm 10.0\) & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& V_{\mathrm{IN}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\
& V_{\mathrm{CC}}=5.25 \mathrm{~V}
\end{aligned}
\] \\
\hline Output High Voltage D0-D7, TxD, RxC, \(\overline{R T S}, \overline{D T R}\) & \(\mathrm{V}_{\mathrm{OH}}\) & 2.4 & - & - & V & \[
\begin{aligned}
& I_{\text {LOAD }}=-100 \mu \mathrm{~A} \\
& V_{C C}=4.75 \mathrm{~V}
\end{aligned}
\] \\
\hline Output Low Voltage D0-D7, TxD, RxC, \(\overline{R T S}, \overline{D T R}, \overline{\mathrm{RQ}}\) & V OL & - & - & 0.4 & V & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\
& \mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA}
\end{aligned}
\] \\
\hline Output High Current (Sourcing) D0-D7, TxD, RxC, RTS, DTR & IOH & -100 & - & - & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}\) \\
\hline Output Low Current (Sinking) D0-D7, TxD, RxC, RTS, \(\overline{D T R}, \overline{I R Q}\) & IOL & 1.6 & - & - & mA & \(\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}\) \\
\hline Output Leakage Current (off state) \(\overline{\mathrm{RQ}}\) & Ioff & - & - & 10.0 & \(\mu \mathrm{A}\) & \(V_{\text {OUT }}=5 \mathrm{~V}\) \\
\hline Clock Capacitance
(ø2) & \(\mathrm{C}_{\text {cLK }}\) & - & - & 20 & pF & \(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}\) \\
\hline Input Capacitance except \(\emptyset 2\), XTLI, XTLO & \(\mathrm{C}_{\text {IN }}\) & - & - & 10 & pF & \[
\begin{aligned}
& V_{1 N}=0 V \\
& f=1 \mathrm{MHz}
\end{aligned}
\] \\
\hline Output Capacitance & Cout & - & - & 10 & pF & \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) \\
\hline Power Dissipation & \(P_{\text {D }}\) & - & 170 & 300 & mW & \(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}

\section*{PACKAGE DIMENSIONS}

i

\section*{Section 3 \\ 8-Bit Microcomputers}
Page
Product Family Overview ..... 3-2
R65C10 One-Chip Microcomputer ..... 3-3
R6500/1 One-Chip Microcomputer ..... 3-26
R6500/1E Microprocessor Emulator Device ..... 3-49
R6500/1EB Backpack Emulator ..... 3-57
R6500/11, /12 and /15 One-Chip Microcomputers ..... 3-63
R65/11EB Backpack Emulators ..... 3-98
R6501 One-Chip Microprocessor ..... 3-103
R6511Q One-Chip Microprocessor and R6500/13 One-Chip Microcomputer ..... 3-138
R6518 One-Chip Microprocessor ..... 3-173
R65F11 and R65F12 FORTH Based Microcomputers ..... 3-203
R65FRx FORTH Development and Kernel ROMs ..... 3-235

\section*{CMOS and NMOS 8-Bit Microcomputers Highest Industry Performers}

The R6500 single-chip CMOS and NMOS microcomputers provide high-speed and low CMOS power while being completely software compatible with the 8 -bit multi-chip family. They let you move easily from a multi-chip to a single-chip solution when the application warrants. They also function as intelligent peripheral controllers. The R65C10, a CMOS version of the R6500/1, combines the low power of CMOS with advanced pipelining architecture to provide an efficient high-speed single-chip system solution.

Features of the microcomputer family include 1.5 K to 4 K bytes of ROM, 64 to 192 bytes of RAM, 23 to 56 I/O ports, multiple use counter/timers, serial communication
channels, bit manipulation instructions, expansion bus, multiple bus interfaces, directly executable RAM with low power standby, and multiple interrupts - all from a single 5 V power supply. They are also available in ROM-less versions, for large memory system applications and for developing and simulating products in prototype, with external memory.

And, the R65F11 and R65F12 even have all system software on the chip, including an operating system and high-level FORTH language. It is an extremely versatile microcomputer, and is available in three configurations to accommodate application programs to 48 K .
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline FEATURE/MODELS & R6500/1 & R6500/11 & R6500/12 & R6500/13 & R6500/15 & R65C10 \\
\hline - INSTRUCTION SPEED & 1000ns & 1000ns & 1000ns & 1000ns & 1000ns & 500 ns \\
\hline - ROM (x8) & 2K & 3K & 3K & 256 & 4K & 2K \\
\hline - RAM (x8) & 64 & 192 & 192 & 192 & 192 & 64 \\
\hline - I/O LINES & 32 & 32 & 56 & 32 & 32 & 32 \\
\hline - SERIAL COMM. & - & USART & USART & USART & UART & - \\
\hline -16-BIT COUNTERS & ONE & Two & Two & Two & two & ONE \\
\hline - EXPANSION BUS & - & 16K & 16K & 65K & 16K & - \\
\hline - INTERRUPTS & & & & & & \\
\hline - external & 5 & 6 & 6 & 6 & 6 & 5 \\
\hline - INTERNAL & 1 & 4 & 4 & 4 & 4 & 1 \\
\hline - OPERATING POWER (mW) & 750 & 800 & 800 & 800 & 800 & 40 \\
\hline - STANDBY (mW) & 35* & 12* & 12* & 12* & 12* & 12 \\
\hline - PACKAGE & \[
\begin{gathered}
40 \text { DIP } \\
44 \text { PLCC }
\end{gathered}
\] & \[
\begin{aligned}
& 40 \text { DIP } \\
& 44 \text { PLCC }
\end{aligned}
\] & 64 QUIP 68 PLCC & 64 QUIP 68 PLCC & 40 DIP 44 PLCC & 40 DIP 44 PLCC \\
\hline * Standby RAM & & & & & & \\
\hline
\end{tabular}

\section*{SECTION I INTRODUCTION}

\section*{SUMMARY}

The Rockwell R65C10 microcomputer is a complete 8-bit computer fabricated on a single chip using an N -well silicon gate CMOS process. The R65C10 complements an industry standard line of R6500 and R65C00 microprocessors, R6500/* and R65C00/* microcomputers and compatible peripheral devices. The R65C10 has a wide range of microcomputer applications where high 8 -bit performance, minimal chip count and low power consumption is required.
The R65C10 consists of a 6502 Central Processing Unit (CPU), 2048 bytes of mask programmable Read Only Memory (ROM), 64 bytes of Random Access Memory (RAM) and interface circuitry for peripheral devices. The parallel interface consists of four 8 -bit ports including two edge detect lines. A 16 -bit counter/timer with four selectable modes is also included.

The innovative architecture and the demonstrated high performance of the R65C02 CPU, as well as instruction simplicity, result in system cost-effectiveness and a wide range of computational power. These features make the R65C10 a leading candidate for low-power single-chip microcomputer applications.

Hardware enhancements of the R65C10 include a softwarecontrolled system and/or counter/timer clock prescaler, and an ultra-low-power Stop mode.

This description assumes that the reader is familiar with the R6502 CPU programming capabilities as described in the R6500 Programming Manual (Order No. 202).

ORDERING INFORMATION
\begin{tabular}{rl} 
R65C10 \\
Temperature Range \\
No letter & \(=0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\) \\
E & \(=-40^{\circ} \mathrm{C}\) to \(+85^{\circ} \mathrm{C}\) \\
Operating Frequency (Internal \(\emptyset 2\) clock) \\
1 & \(=1 \mathrm{MHz}\) \\
2 & \(=2 \mathrm{MHz}\) \\
3 & \(=3 \mathrm{MHz}\) \\
4 & \(=4 \mathrm{MHz}\) \\
Package \\
C & \(=40-\) pin CERDIP \\
P & \(=40-\)-pin Plastic DIP \\
J & \(=44-\)-pin Plastic Leaded \\
& Chip Carrier (PLCC)
\end{tabular}

\section*{FEATURES}
- Single-chip microcomputer
- R6502 CPU instruction compatible
- 8-bit parallel processing
- Decimal or binary arithmetic
- Variable length stack
- True indexing capability
- 13 addressing modes
- Internal 1 MHz to 4 MHz clock with crystal or clock input
- Internal divide-by-2 network
-2 MHz to 8 MHz crystal input
-20 kHz to 8 MHz clock input
- Software-controllable prescaler
- Selectable system clock and timer clock prescaler or timer clock only prescaler
- Divide by 8, 32, 64, or 128 options
- Low-power oscillator Stop mode (cleared by \(\overline{R E S}\) )
- 15 mW to 60 mW operating power ( 1 MHz to 4 MHz )
- \(2 \mathrm{~K} \times 8\) ROM on-chip
- \(64 \times 8\) RAM on-chip
- 32 bidirectional TTL compatible I/O lines
-1 positive edge-sensitive I/O line
-1 negative edge-sensitive I/O line
- 1 bidirectional TTL compatible counter I/O line
- 16 -bit buffered timer/counter with four modes
- Interval timer
- Pulse generator
- Event counter
- Pulse width measurement
- Three maskable interrupt requests (IRQ)
-1 counter overflow
-2 I/O edge detect
- \(\overline{\mathrm{NMI}}\) and \(\overline{\mathrm{RES}}\) inputs
- Available in 40-pin DIP and 44-pin PLCC packages
- \(+5 \mathrm{~V} \pm 10 \%\) power

\section*{SECTION 2 \\ INTERFACE DESCRIPTION}

This section describes the interface requirements for the R65C10 single-chip microcomputer. An interface diagram for the R65C10 is shown in Figure 2-1. The R65C10 pin assignments are
identified in Figure 2-2. The function of each pin of the R65C10 is explained in Table 2-1.


Figure 2-1. R65C10 Interface Diagram


Figure 2-2. R65C10 Pin Assignments

Table 2-1. R65C10 Pin Description
\begin{tabular}{|c|c|c|}
\hline Signal Name & I/O & Description \\
\hline \(\mathrm{V}_{\mathrm{Cc}}\) & & POWER. +5 Vdc ; must be connected to both pins. \\
\hline \(V_{\text {SS }}\) & & GROUND. Signal return and power ground (0V). \\
\hline XTLI & 1 & CRYSTAL INPUT. The crystal or external clock input to the internal clock oscillator. The oscillator generates the internal master clock at the frequency of the input crystal/clock divided either by 1 or by 2 depending upon mask option. The system and counter/timer clocks are derived from the master clock under control of the Prescaler Control Register. \\
\hline XTLO & 0 & CRYSTAL OUTPUT. The crystal output from the internal clock oscillator. XTLO should be left open when a clock is input at XTLI. \\
\hline \(\overline{\text { RES }}\) & 1 & RESET. The active low \(\overline{\text { RES }}\) input initializes the R65C10. This signal must not transition from low to high for at least eight cycles after \(V_{C C}\) reaches operating range and the internal oscillator has stabilized. \\
\hline \(\overline{\mathrm{NMI}}\) & 1 & NON-MASKABLE INTERRUPT. A negative-going edge on the \(\overline{\text { NMI }}\) input interrupts the CPU. \\
\hline PA0-PA7 & I/O & PORT A. General purpose I/O Port A. \\
\hline PB0-PB7 & I/O & PORT B. General purpose I/O Port B. \\
\hline PC0-PC7 & 1/O & PORT C. General purpose I/O Port C. \\
\hline PD0-PD7 & I/O & PORT D. General purpose I/O Port D. \\
\hline & & Four 8-bit ports used for either input or output. Each line consists of an active transistor to \(\mathrm{V}_{S S}\) and an optional active pull-up to \(V_{C C}\) (see Section 4.3). The two lower bits of the Port A (PAO and PA1) also serve as edge-detect inputs with maskable interrupts. PAO detects a positive-going edge and PA1 detects a negative-going edge. \\
\hline CNTR & 1/0 & COUNTER. This line is either an input to, or an output from, the counter. CNTR is an input in the event counter and pulse width measurement modes, and is an output in the pulse generator modes. It consists of an active transistor to \(\mathrm{V}_{\mathrm{SS}}\) and an optional active pull-up to \(\mathrm{V}_{\mathrm{CC}}\). \\
\hline
\end{tabular}

\title{
SECTION 3 SYSTEM ARCHITECTURE
}

This section provides a functional description of the R65C10. A block diagram of the R65C10 is presented in Figure 3-1.

\subsection*{3.1 INDEX REGISTERS}

There are two 8 -bit index registers: X and Y . Either index register can be used as a base to modify the program counter contents and thus obtain a new address-the sum of the program counter contents and the index register contents.

When executing an instruction which specifies indexed addressing, the CPU fetches the op code and the address, and modifies the address from memory by adding the index register to it prior to loading or storing the value of memory.

\subsection*{3.2 STACK POINTER}

The Stack Pointer is an 8-bit register. It is automatically incremented and decremented under control of the CPU to perform stack manipulation in response to program instructions, the NMI interrupt input or the internally generated IRQ interrupt. The Stack Pointer must be initialized by the user program. The JSR, BRK, RTI, and RTS instructions use the stack and the Stack Pointer. The stack is located in RAM from address 0 to address \(\$ 3 \mathrm{~F}\) ( 0 to 63 decimal).

\subsection*{3.3 ARITHMETIC AND LOGIC UNIT (ALU)}

All arithmetic and logic operations take place in the ALU, including incrementing and decrementing internal registers (except the Program Counter). The ALU cannot store data for more than one cycle. If data is placed on the inputs to the ALU at the beginning of a cycle, the result is always gated into one of the storage registers or to memory during the next cycle.

Each bit of the ALU has two inputs. These inputs can be tied to various internal buses or to a logic 0 ; the ALU then generates the function (AND, OR, SUM, and so on) using the data on the two inputs.

\subsection*{3.4 ACCUMULATOR}

The Accumulator is a general purpose 8 -bit register that stores the results of most arithmetic and logic operations. In addition, the Accumulator usually contains one of the two data words used in these operations.

\subsection*{3.5 PROGRAM COUNTER}

The 12 -bit Program Counter provides the addresses that step the processor through sequential instructions in a program. Each time the processor fetches an instruction from the program
memory, the lower (least significant) byte of the Program Counter (PCL) is placed on the eight low-order lines of the internal address bus and the higher (most significant) byte of the Program Counter (PCH) is placed on the four high-order lines of the internal address bus. The Program Counter is incremented each time an instruction or data is fetched from program memory.

\subsection*{3.6 INSTRUCTION REGISTER AND INSTRUCTION DECODE}

Instructions are fetched from ROM or RAM and gated onto the internal data bus. These instructions are latched into the Instruction Register, then decoded along with timing and interrupt signals to generate control signals for the various registers.

\subsection*{3.7 PROCESSOR STATUS REGISTER (PSR)}

The 8-bit Processor Status Register, shown in Figure 3-2, contains seven status flags. Some of these flags are controlled by the user program; others may be controlled both by the user program and the CPU. The R65C10 instruction set contains a number of conditional branch instructions which allow testing of these flags. Each of the seven processor status flags is described in the following paragraphs.

\section*{CARRY (C) BIT}

The Carry (C) bit can be considered as the ninth bit of an arithmetic operation. It is set to logic 1 if a carry from the eighth bit has occurred, or cleared to logic 0 of no carry occurred, as the result of arithmetic operations.

The Carry bit may be set or cleared under program control by use of the Set Carry (SEC) or Clear Carry (CLC) instruction, respectively. Other operations which affect the Carry bit are ADC, ASL, CMP, CPX, CPY, LSR, PLP, ROL, ROR, RTI, and SBC.

\section*{ZERO (Z) BIT}

The Zero (Z) bit is set to logic 1 by the CPU during any data movement or by any calculation which sets all eight bits of the result to zero. This bit is cleared to logic 0 when the resultant eight bits of a data movement or calculation operation are not all zero. The R65C10 instruction set contains no instruction to specifically set or clear the Zero bit. The Zero bit is, however, affected by the following instructions: ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TXA, TSX, and TYA.



Figure 3-2. Processor Status Register

\section*{INTERRUPT DISABLE (I) BIT}

The Interrupt Disable (I) bit controls the servicing of the internal interrupt request (IRQ). If the I bit is reset to logic 0 , the IRQ will be serviced. If the bit is set to logic 1 , the IRQ will be ignored. The CPU will set the Interrupt Disable bit to logic 1 if NMI, an enabled IRQ interrupt or the \(\overline{\mathrm{RES}}\) signal is detected.

The I bit is restored by the Pull Processor Status from Stack (PLP) instruction, or as the result of executing a Return from Interrupt (RTI) instruction (provided the Interrupt Disable bit was cleared prior to the interrupt). The Interrupt Disable bit may be set or cleared under program control using a Set Interrupt Disable (SEI) or a Clear Interrupt Disable (CLI) instruction, respectively.

\section*{DECIMAL MODE (D) BIT}

The Decimal Mode (D) bit controls the arithmetic mode of the CPU. When this bit is set to a logic 1, the adder operates as
a decimal adder. When this bit is cleared to logic 0 , the adder operates as a straight binary adder. The adder mode is controlled only by two instructions. The Set Decimal Mode (SED) instruction sets the D bit; the Clear Decimal Mode (CLD) instruction clears it. The PLP and RTI instructions also affect the Decimal Mode Bit. The Decimal Mode Bit is cleared upon power application and by \(\overline{R E S}\) thus establishing binary mode.

\section*{BREAK (B) BIT}

The Break (B) bit indicates the condition which caused the IRQ service routine to be entered. If the IRQ service routine was entered because the CPU executed a BRK command, the B bit will be set to logic 1. If the IRQ routine was entered as the result of an IRQ occurring, the \(B\) bit will be cleared to logic 0 . There are no instructions which can set or clear this bit.

\section*{OVERFLOW (V) BIT}

The Overflow \((\mathrm{V})\) bit indicates that the result of a signed, binary addition or subtraction operation is a value that cannot be contained in seven bits \((-128 \leq n \leq+127)\). The indicator only has meaning when signed arithmetic (sign and seven magnitude bits) is performed. When the ADC or SBC instruction is performed, the \(V\) bit is set to logic 1 if the polarity of the sign bit (bit 7) is changed because the result exceeds +127 or -128 ; otherwise the V bit is cleared to logic 0 . The V bit may also be cleared under program control by the Clear Overflow (CLV) instruction.

The Overflow bit may also be used with the BIT instruction. The BIT instruction, which may be used to sample interface devices, allows the Overflow bit to reflect the condition of Bit 6 in the sampled field. During a BIT instruction, the Overflow bit is set equal to the content of Bit 6 of the data tested with the BIT instruction. When used in this mode, the Overflow bit has nothing to do with signed arithmetic, but is just another sense bit for the CPU. Instructions which affect the V flag are ADC, BIT, CLV, PLP, RTI, and SBC.

\section*{NEGATIVE (N) BIT}

The Negative ( \(N\) ) bit copies the arithmetic sign bit value resulting from a data movement or an arithmetic operation. If the sign bit is set, the resulting value of the data movement or arithmetic operation is negative and the N bit is a logic 1 ; if the sign bit is cleared, the result of the data movement or arithmetic operation is positive and the N bit is a logic 0 . There are no instructions that set or clear the N bit since the N bit represents only the status of a result. The instructions that affect the state of the bit are: ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TSX, TXA, and TYA.

\subsection*{3.8 I/O ADDRESS DECODE}

The internal memory, control registers, I/O ports, and Counter/ Latch are memory mapped into the 4096-byte address space. The I/O Address Decode logic decodes the address from the internal address bus and routes enable signals to the appropriate functions. The memory map of the R65C10 is shown in Figure 3-3.
\begin{tabular}{|c|c|c|}
\hline \multirow[b]{2}{*}{Parameter} & \multicolumn{2}{|c|}{Address} \\
\hline & Hex & Dec \\
\hline IRQ Vector High & FFF & 4095 \\
\hline IRQ Vector Low & FFE & 4094 \\
\hline RES Vector High & FFD & 4093 \\
\hline RES Vector Low & FFC & 4092 \\
\hline NMI Vector High & FFB & 4091 \\
\hline NMI Vector Low & FFA & 4090 \\
\hline R65C10 User Program & \[
\begin{gathered}
\text { FF9 } \\
: \\
800 \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
4089 \\
\vdots \\
2048 \\
\hline
\end{gathered}
\] \\
\hline Unassigned & \[
\begin{gathered}
\text { 7FF } \\
\vdots \\
094 \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
2047 \\
\vdots \\
148 \\
\hline
\end{gathered}
\] \\
\hline Port D Direction Register (Write Only) \({ }^{3}\) & 093 & 147 \\
\hline Port C Direction Register (Write Only) \({ }^{3}\) & 092 & 146 \\
\hline Port B Direction Register (Write Only) \({ }^{3}\) & 091 & 145 \\
\hline Port A Direction Register (Write Only) \({ }^{3}\) & 090 & 144 \\
\hline Control Register (CR) & 08F & 143 \\
\hline Prescaler Control Register (PCR) & 08E & 142 \\
\hline Stop Mode (Write Only) \({ }^{3}\) & 08D & 141 \\
\hline Unassigned & \[
\begin{aligned}
& 08 \mathrm{C} \\
& 08 \mathrm{~B}
\end{aligned}
\] & \[
\begin{aligned}
& 140 \\
& 139
\end{aligned}
\] \\
\hline Clear PA1 Neg Edge Detected (Write Only) \({ }^{1}\) & OBA & 138 \\
\hline Clear PAO Pos Edge Detected (Write Only) \({ }^{1}\) & 089 & 137 \\
\hline Upper Latch and Transfer Latch to Counter, Clear Counter Overflow (Write Only) \({ }^{2}\) & 088 & 136 \\
\hline Lower Count, Clear Counter Overflow (Read Only) \({ }^{2}\) & 087 & 135 \\
\hline Upper Count (Read Only) & 086 & 134 \\
\hline Lower Latch (Write Only) & 085 & 133 \\
\hline Upper Latch (Write Only) & 084 & 132 \\
\hline Port D (PD) & 083 & 131 \\
\hline Port C (PC) & 082 & 130 \\
\hline Port B (PB) & 081 & 129 \\
\hline Port A (PA) & 080 & 128 \\
\hline Unassigned & \[
\begin{gathered}
07 F \\
0 \\
040
\end{gathered}
\] & 127
\(\vdots\)
64 \\
\hline User RAM & \[
\begin{gathered}
03 F \\
0 \\
000
\end{gathered}
\] & 63
0
0 \\
\hline \multicolumn{3}{|l|}{\begin{tabular}{l}
Notes: 1. I/O command only; i.e., no stored data. \\
2. Clears Counter Overflow - Bit 7 in Control Register. \\
3. Mask option.
\end{tabular}} \\
\hline
\end{tabular}

Figure 3-3. R65C10 Memory Map

\section*{\(3.9 \mathbf{2 K} \times 8\) ROM}

The internal \(2,048 \times 8\)-bit Read Only Memory (ROM) usually contains the user's program instructions and other fixed constants. These program instructions and constants are maskprogrammed during fabrication.

The ROM is mapped from \(\$ 800\) to \(\$ F F F\).

\section*{\(3.1064 \times 8\) RAM}

The internal \(64 \times 8\)-bit Random Access Memory (RAM) contains the user program stack and is used for scratchpad memory during system operation. This RAM is completely static in operation and requires no clock or dynamic refresh. The data contained in RAM is read out nondestructively with the same polarity as the input data. In the event that execution stops, RAM data is retained until execution resumes.

The R65C10 RAM is assigned page zero memory address 0 to \$03F.

\subsection*{3.11 CLOCK OSCILLATOR}

The Clock Oscillator provides the basic timing signals used by the R65C10. The reference frequency is provided by an external source and can be from a crystal or clock input. The external frequency may vary from 2 MHz to 8 MHz for a parallel resonant crystal input or from 20 kHz to 8 MHz for a clock input. The external clock rate is divided by 2 or 1 to generate an internal master clock (MCLK) as shown in Figure 3-4. Selection of the input crystal/clock divide-by-2 or divide-by-1 is a mask option. The divide-by-2 option can be used with either a crystal or clock input. The divide-by-1 option can be used only with a clock input. The divide-by-2 option causes the R65C10 to operate at the same internal frequency as the R6500/1 or R6500/1E when connected to the same input clock frequency. MCLK may be prescaled by four different values under program control (discussed below).

The on-chip oscillator is designed for a parallel resonant crystal connected between XTLI and XTLO pins. The equivalent oscillator circuit is shown in Figure 3-5A.

A parallel resonant crystal is specified by its load capacitance and series resonant resistance. For proper oscillator operation, the load capacitance \(\left(\mathrm{C}_{\mathrm{L}}\right)\), series resistance \(\left(\mathrm{R}_{\mathrm{S}}\right)\) and the crystal resonant frequency ( \(F\) ) must meet the following two relations:
\[
\begin{gathered}
(C+22)=2 C_{L} \quad \text { or } C=2 C_{L}-22 \\
R_{s} \leq R_{s m a x}=\frac{2 \times 10^{6}}{\left(F C_{L}\right)^{2}}
\end{gathered}
\]
where: F is in \(\mathrm{MHz} ; \mathrm{C}\) and \(\mathrm{C}_{\mathrm{L}}\) are in pF ; R is in ohms.
To select a parallel resonant crystal for the oscillator, first select the load capacitance from a crystal manufacturer's catalog. Next, calculate \(R_{\text {smax }}\) based on \(F\) and \(C_{L}\). The selected crystal must have a \(R_{s}\) less than the \(R_{\text {smax }}\).


Figure 3-4. Internal System Clock Timing

For example, if \(\mathrm{C}_{\mathrm{L}}=30 \mathrm{pF}\) for a 4 MHz parallel resonant crystal, then
\[
\mathrm{C}=(2 \times 30)-22=38 \mathrm{pF} \text { (Use standard value of } 39 \mathrm{pF} \text {.) }
\]
(Note: \(C=\) Total shunt capacitance including that due to board layout.)

The series resistance of the crystal must be less than
\[
R_{s \max }=\frac{2 \times 10^{6}}{(4 \times 30)^{2}}=139 \mathrm{ohms}
\]

The R65C10 internal oscillator and clock can be stopped under program control (Stop mode) and restarted by a \(\overline{\text { RES }}\) input. The Stop mode is described in Section 4.

\subsection*{3.12 PRESCALER CONTROL}

Clock prescaler mode and value selection is controlled by the Prescaler Control Register (PCR) at the address \$08E (see Figure 3-6). The prescaler mode (PM) is determined by the value written to bits 0 and 1 . The prescaler value (PV) is determined by the value written to bits 2 and 3 . The system clock ( \((12\) ) and timer clock (TCLK) rates are determined by the combination of selected prescaler mode and value. When prescaler mode 0 is selected, \(\emptyset 2\) and TCLK both run at the internal master clock (MCLK) rate regardless of the selected prescaler value. \(\emptyset 2\) runs at MCLK in prescaler modes 0 and 1 and at MCLK \(\div\) PV in prescaler mode 3. TCLK runs at MCLK in prescaler mode 0 and at MCLK \(\div\) PV in prescaler modes 1 and 3 . Prescaler mode 2 is illegal and will cause indeterminate operation if selected.

The selected prescaler value is invoked in the cycle following the write or interrupt occurrence. Waveforms for five of these operations are illustrated in Figure 3-7.

A. Crystal Input

B. Clock Input

Notes:
1. Clock input divide-by-2 option must be selected.
2. Clock input divide-by-2 selected.
3. Clock input divide-by-1 selected.

Figure 3-5. Clock Oscillator Input Options

\subsection*{3.13 CONTROL REGISTER (CR)}

The Control Register (CR), shown in Figure 3-8, is located at address \(\$ 8\). The CR contains five control bits and three status bits. The control bits must be written to the Control Register. The status bits can be read, along with the previously written control bits, by reading the register. All control and status bits in the Control Register are cleared to 0 by the assertion of \(\overline{\operatorname{RES}}\). The signals controlled by and reported in the CR are described in the following paragraphs.

Bits 0 to 4 in the Control Register are control bits (Figure 3-8). The control signals are set by writing a 1 into the respective bit position, and cleared either by writing a 0 into the respective bit position or by assertion of \(\overline{\text { EES }}\).

Bits 5 to 7 in the Control Register are status bits (Figure 3-8). The status bits are read-only information. Each status bit is set to a 1 by monitoring circuitry, and is cleared to a 0 either by writing to specific address or by assertion of \(\overline{\text { RES. }}\)

\section*{COUNTER MODE CONTROL 0 AND 1}

Counter Mode Control signals CMC0 and CMC1 (bits 0 and 1) control the Counter operating modes. The modes of operation and the corresponding configuration of CMC0 and CMC1 are shown in Figure 3-8. These modes are selected by writing the appropriate bit values into the Counter Mode Control bits.
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \[
\begin{aligned}
& \text { ADDR } \\
& \text { \$08E }
\end{aligned}
\] & NOT USED & & V1 & V0 & M1 & M0 \\
\hline
\end{tabular}

Bits 3-2 Prescaler Value (PV) Select \({ }^{1}\)
\begin{tabular}{lll}
\(\frac{\text { V1 }}{0}\) & \(\frac{\text { V0 }}{0}\) & \(\frac{\text { Prescale Value }}{\text { Divide by } 8}\) \\
0 & 1 & Divide by 32 \\
1 & 0 & Divide by 64 \\
1 & 1 & Divide by 128
\end{tabular}

Bits 1-0 Prescaler Mode (PM) Select \({ }^{1}\)
\begin{tabular}{ccclll}
\(\frac{\text { M1 }}{0}\) & \(\frac{\text { M0 }}{0}\) & \(\frac{\text { Mode }}{}\) & \begin{tabular}{l}
\begin{tabular}{c} 
System Clock \\
\((\emptyset 2)\) Rate
\end{tabular}
\end{tabular} & \begin{tabular}{l} 
Timer Clock \\
(TCLK) Rate
\end{tabular} \\
0 & 1 & 1 & MCLK & & MCLK \\
1 & 0 & 2 & N/A & & MCLK \(\div\) PV \\
1 & 1 & 3 & MCLK \(\div\) MV & N/A (Illegal Mode) \\
& & & MCLK \(\div\) PV
\end{tabular}

Note: 1. All bits are reset to 0 by \(\overline{\operatorname{RES}}\).
Figure 3-6. Prescaler Control Register

The Counter is reset to the Interval Timer mode (Mode 0 ) by assertion of RES (which causes Os to be loaded into all bits of the Control Register).

\section*{PA1 INTERRUPT ENABLE BIT (A1IE)}

If the PA1 Interrupt Enable bit (bit 2) is set to a 1, IRQ will occur when the PA1 Negative Edge Detected bit (bit 5 ) is set to a 1.

\section*{PAO INTERRUPT ENABLE BIT (AOIE)}

If the PAO Interrupt Enable bit (bit 3) is set to a 1, IRQ will occur when the PAO Positive Edge Detected bit (bit 6) is set to a 1.

\section*{COUNTER INTERRUPT ENABLE BIT (CIE)}

If the Counter Interrupt Enable Bit (bit 4) is set to a 1, IRQ will occur when Counter Overflow (bit 7) is set to a 1.

\section*{PA1 NEGATIVE EDGE DETECTED BIT (A1ED)}

The PA1 Negative Edge Detected bit (bit 5) is set to a 1 whenever a negative (falling) edge is detected on PA1. This bit is cleared to a 0 by writing to address \(\$ 08 \mathrm{~A}\) or by assertion of \(\overline{\mathrm{RES}}\).

The edge detecting circuitry is active regardless of whether PA1 is an input or is an output. When PA1 is used as an output, A1ED will be set when the negative edge is detected during a high-tolow transition. When PA1 is used as an input and the negative


Figure 3-7. Prescaler Waveform Examples
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{ADDR \$08F} & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline & \multicolumn{2}{|l|}{INTERRUPT STATUS} & \multicolumn{3}{|l|}{INTERRUPT ENABLE} & \multicolumn{2}{|l|}{\multirow[t]{2}{*}{TIMER MODE CONTROL}} \\
\hline \$08F TIMER & PAO & PA1 & TIMER & PAO & PA1 & & \\
\hline Bit 7 & COUN & ER OV & ERFLOW & (CT & & & \\
\hline 1 & Count & overf & w occu & red & & & \\
\hline 0 & No co & ter ov & erflow & & & & \\
\hline Bit 6 & PAO P & SITIV & EDGE & DETE & (AOE & D) \({ }^{1}\) & \\
\hline 1 & PAO & itive & dge det & cted & & & \\
\hline 0 & PAO p & itive & dge not & detec & & & \\
\hline Bit 5 & PA1 & GATI & E EDGE & DET & ( \({ }^{\text {(11 }}\) & ED) \({ }^{1}\) & \\
\hline 1 & PA1 \(n\) & ative & edge det & ected & & & \\
\hline 0 & PA1 \(n\) & ative & edge not & dete & & & \\
\hline Bit 4 & COUN & ER IN & ERRUP & T EN & LE (CI & & \\
\hline 1 & Enable & count & interrup & & & & \\
\hline 0 & Disabl & count & r interru & & & & \\
\hline Bit 3 & PAO I & ERR & PT ENA & BLE & 이E) \({ }^{2}\) & & \\
\hline 1 & Enable & PAO in & terrupt & & & & \\
\hline 0 & Disabl & PAO & terrupt & & & & \\
\hline Bit 2 & PA1 I & ERR & PT ENA & BLE & 1IE) \({ }^{2}\) & & \\
\hline 1 & Enable & PA1 in & terrupt & & & & \\
\hline 0 & Disabl & PA1 i & terrupt & & & & \\
\hline Bit 10 & COUN & ER M & DE CON & TRO & (CMC1 & \& CN & \\
\hline 00 & Interva & Timer & & & & & \\
\hline 01 & Pulse & enera & & & & & \\
\hline 10 & Event & ounte & & & & & \\
\hline 11 & Pulse & idth & easurem & ent & & & \\
\hline
\end{tabular}

Notes: 1. Read only. 2. Read/write.

Figure 3-8. Control Register
edge detecting circuitry is used, A1ED should be cleared by the user program upon initialization and upon completion of the PA1 Negative Edge Detected IRQ processing.

\section*{PAO POSITIVE EDGE DETECTED BIT (AOED)}

The PAO Positive Edge Detected bit (bit 6) is set to a 1 whenever a positive (rising) edge is detected on PAO. This bit is cleared to a 0 by writing to address \(\$ 089\) or by assertion of RES.

The edge detecting circuitry is active regardless of whether PAO is an input or is an output. When PAO is used as an output, AOED will be set when the positive edge is detected during a low-tohigh transition. When PAO is used as an input and the positive edge detecting circuitry is used, AOED should be cleared by the user program upon initialization and upon completion of PAO Positive Edge Detected IRQ processing.

\section*{COUNTER OVERFLOW BIT (CTRO)}

The Counter Overflow bit (bit 7) is set to a 1 whenever the Counter overflow occurs in any of the four counter operating modes. Overflow occurs when the Counter is decremented one count from 0 . This bit is cleared to a 0 by reading from address \(\$ 087\), writing to address \(\$ 088\), or by assertion of \(\overline{\text { RES. }}\)

The CTRO bit should be cleared by the user program upon initialization and upon completion of Counter Overflow IRQ interrupt processing.

When a Counter Overflow occurs, the Upper Count (UC) in address \(\$ 086\), and the Lower Count (LC) in address \(\$ 087\), are loaded with to the values contained in the Upper Latch (UL) in address \(\$ 084\), and in the Lower Latch (LL) in address \$085, respectively.

\subsection*{3.14 PARALLEL INPUT/OUTPUT PORTS}

The R65C10 provides four memory-mapped 8-bit Input/Output (I/O) ports: PA, PB, PC and PD. All 32 I/O lines of the four ports are completely bidirectional. All lines may be used either for input or output in any combination, i.e., there are no line grouping or port association restrictions. A mask option is available to select I/O port operation with or without direction registers. Table 3-1 lists the I/O port and edge detected bit reset addresses.

Table 3-1. I/O Port Addresses
\begin{tabular}{|l|c|}
\hline \multicolumn{1}{|c|}{ Port/Function } & Address \\
\hline Port A Direction Register (Write Only) & \(\$ 090\) \\
Port B Direction Register (Write Only) & \(\$ 091\) \\
Port C Direction Register (Write Only) & \(\$ 092\) \\
Port D Direction Register (Write Only) & \(\$ 093\) \\
Port A Data Register (Read/Write) & \(\$ 080\) \\
Port B Data Register (Read/Write) & \(\$ 081\) \\
Port C Data Register (Read/Write) & \(\$ 082\) \\
Port D Data Register (Read/Write) & \(\$ 083\) \\
Clear PA0 Positive Edge Detected Bit (Write Only) & \(\$ 089\) \\
Clear PA1 Negative Edge Detected Bit (Write Only) & \(\$ 08 A\) \\
\hline
\end{tabular}

\section*{I/O PORT OPERATION WITHOUT DIRECTION REGISTERS}

If direction registers are not selected, the direction of the 32 I/O lines is controlled by writing to the four 8 -bit port data registers located in page zero at addresses \(\$ 80-\$ 83\) (see Figure 3-3). This arrangement provides quick programming access using simple 2-byte zero page address instructions. I/O handling is simplified since programming of direction registers is not required.

\section*{Inputs}

Inputs are enabled by writing a 1 into all l/O port register bit positions that correspond to input lines. A low ( \(\leq 0.8 \mathrm{Vdc}\) ) input level causes a 0 to be read when a read instruction is issued to the port register. A high ( \(\geq 2.0 \mathrm{Vdc}\) ) input level causes a 1 to be read. Assertion of \(\overline{\operatorname{RES}}\) forces all bits in the I/O port registers to 1s, thus initially treating all I/O lines as inputs.

The status of the input lines can be interrogated at any time by reading the I/O port addresses. Note that this will return the actual status of the input lines, not the data written into the I/O port register.

\section*{Outputs}

Outputs are controlled by writing the desired I/O line output states into the corresponding I/O port register bit positions.

A 1 will force a high ( \(\geq 2.4 \mathrm{Vdc}\) ) output while a 0 will force a low ( \(\leq 0.4 \mathrm{Vdc}\) ) output.

\section*{I/O PORT OPERATION WITH DIRECTION REGISTERS}

If direction registers are selected, the direction of all 32 I/O lines is controlled by individual bits in four write-only I/O port direction registers. The direction registers for ports A, B, C and D are located at addresses \(\$ 90, \$ 91, \$ 92\) and \(\$ 93\), respectively. Setting a bit in a direction register to a 1 causes the corresponding I/O line to operate as an output; resetting the bit to a 0 causes the I/O line to be an input. Assertion of \(\overline{R E S}\) clears all direction register bits to 0 s causing all I/O lines to initially be inputs.

\section*{Inputs}

If an I/O line is an input, the state of the corresponding bit in the I/O port data register shows the input logic level: \(1=\) high; \(0=\) low.

\section*{Outputs}

If an I/O line is an output, the state of the corresponding bit written to the port data register determines the output logic level: \(1=\) high; \(0=\) low.

\section*{EDGE DETECTION CAPABILITY}

The Port A PA0 and PA1 circuitry has edge detection capability. Edges detected on these lines are reported in the Control Register and will cause an IRQ if enabled in the Control Register (see Section 3.14). The edge detect timing waveforms are illustrated in Figure 3-9.

\section*{PAO Positive Edge Detection}

In addition to its normal I/O function, an asynchronous positive (rising) edge signal can be detected on PAO. This occurrence will be reported in the PAO Positive Edge Detected bit in the Control Register (CR6). CR6 is cleared by writing to address \(\$ 089\) or by assertion of RES.

\section*{PA1 Negative Edge Detection}

In addition to its normal I/O function, an asynchronous negative (falling) edge signal can be detected on PA1. This occurrence wil be reported in the PA1 Negative Edge Detected bit in the Control Register (CR5). CR5 is cleared by writing to address \$08A or by assertion of RES.

\subsection*{3.15 COUNTER/LATCH}

\section*{GENERAL}

The Counter/Latch consists of a 16 -bit Counter, and a 16 -bit Latch. The Counter resides in two 8-bit registers: address \(\$ 086\) contains the Upper Count value (bits 8-15 of the Counter) and address \(\$ 087\) contains the Lower Count value (bits \(0-7\) of the Counter). The Counter contains the count of either unscaled or prescaled \(\emptyset 2\) clock periods, or external events, depending on Counter mode selected in the Control Register and, for clock driven Counter modes, the Prescaler mode and value selected in the Prescaler Control Register. Table 3-2 lists the addresses associated with Counter/Latch operation.

Table 3-2. Counter/Latch Addresses
\begin{tabular}{|l|c|}
\hline \multicolumn{1}{|c|}{ Function } & Address \\
\hline Write Upper Latch (Write Only) & \(\$ 084\) \\
Write Lower Latch (Write Only) & \(\$ 085\) \\
Read Upper Count (Read Only) & \(\$ 086\) \\
Read Lower Count, Clear Timer Overflow (Read Only) & \(\$ 087\) \\
Write Upper Latch and Transier Latch to Counter, & \(\$ 088\) \\
Clear Counter Overflow (Write Only) & \\
\hline
\end{tabular}

The Latch contains the Counter initialization value. The Latch resides in two 8-bit registers: address \(\$ 084\) contains the Upper Latch value (bits 8-15 of the Latch) and address \(\$ 085\) contains the Lower Latch value (bits \(0-7\) of the Latch). The 16 -bit Latch can hold values from 0 to 65,535 .

The latch registers can be loaded at any time by writing to the Upper Latch address (\$084) and the Lower Latch address (\$085). In each case, the contents of the Accumulator are copied into the applicable Latch register. The Upper Latch and Lower Latch


Figure 3-9. PA0 and PA1 Edge Detection Timing Waveforms
can be loaded independently; it is not required to load both registers at the same time, or sequentially. The Upper Latch can also be loaded by writing to address \(\$ 088\).

The Counter will also be initialized to the Latch value whenever the Counter overflows. When the Counter decrements from 0 , the next Counter value will be the Latch value, not \$FFFF.

Whenever the Counter overflows, the Counter Overflow status bit in the Control Register (CR7) is set to a 1 . This bit is cleared whenever the lower eight bits of the Counter are read from address \(\$ 087\) or by writing to address \(\$ 088\).

\section*{COUNTER/TIMER MODES}

The Counter operates in any of four modes. These modes are selected by the Counter Mode Control bits in the Control Register (see Table 3-3).

The Interval Timer, Pulse Generator, and Pulse Width Measurement modes are internally clocked modes. The Event Counter Mode counts the occurrences of an external event on the CNTR line.

\section*{Interval Timer (Mode 0)}

In the Interval Timer mode, the Counter is initialized to the Latch value by either of two conditions:
1. When the Counter is decremented from 0, the next Counter value is the Latch value, not \$FFFF.
2. When a write operation is performed to the Upper Latch and the Transfer Latch to Counter address (\$088), the Counter is loaded with the Latch value. Note that the contents of the Accumulator are loaded into the Upper Latch before the Latch value is transferred to the Counter.

The Counter value is decremented at the timer clock (TCLK) rate. The 16 -bit Counter can hold from 1 to 65,535 counts. For a 4 MHz internal \(\emptyset 2\) clock and no prescaler selected, the timer range is \(0.25 \mu \mathrm{~s}\) to 16.384 ms . For a 4 MHz internal \(\emptyset 2\) clock and divide-by-128 prescaler selected, the timer range is \(32 \mu \mathrm{~S}\) to 2.097 seconds.

When the Counter decrements from 0 , the Counter Overflow bit in the Control Register (CR7) is set to a 1 at the next counter clock pulse. If the Counter Interrupt Enable bit (CR4) is also set, IRQ will occur. The Counter Overflow bit in the Control Register can be examined in the IRQ interrupt routine to determine that the IRQ was caused by the Counter overflow.

While the timer is operating in the Interval Timer mode, the Counter-Out/Event-In (CNTR) line is held in the high impedance state (output disabled).

A timing diagram of the Interval Timer mode is shown in Figure 3-10.

\section*{Pulse Generator Mode (Mode 1)}

In the Pulse Generator mode, the CNTR line operates as a Counter-Out. When a write is performed to address \(\$ 088\) the CNTR output is initialized high. The Counter is decremented at the TCLK rate. The CNTR line toggles from low to high or from high to low whenever a Counter overflow occurs.

Either a symmetric or an asymmetric output waveform can be output on the CNTR line in this mode. The CNTR output is initialized to the high impedance state (output disabled) by assertion of \(\overline{R E S}\) since the Interval Timer mode is established by \(\overline{R E S}\).

\section*{Event Counter Mode (Mode 2)}

In this mode, the CNTR line is used as an Event-In input, and the Counter will decrement with each rising edge detected on this line. The maximum rate at which this edge can be detected is one-half the system ( \(\emptyset 2\) ) clock rate.

The Counter can count up to 65,535 occurrences before overflowing. As in the other modes, the Counter Overflow bit (CR7) is set to a 1 if the overflow occurs.

Figure \(3-11\) is a timing diagram of the Event Counter mode.

\section*{Pulse Width Measurement Mode (Mode 3)}

This mode allows the accurate measurement of a low pulse duration on the CNTR line. In this mode, CNTR is used in the Event-In capacity. The Counter decrements at the TCLK rate as long as the CNTR line is held in the low state. The Counter is stopped when CNTR is in the high state.

If the CNTR pin is left disconnected, this mode may be selected to stop the Counter since the internal pull-up device (if present) will cause the CNTR input to be in the high ( \(\geq 2.0\) volt) state.

A timing diagram for the Pulse Width Measurement mode is shown in Figure 3-12.

\subsection*{3.16 INTERRUPT LOGIC}

Interrupt logic controls the sequencing of \(\overline{\operatorname{RES}}\) and the two interrupts: \(\overline{\mathrm{NMI}}\), and IRQ.

\section*{\(\overline{\text { RES }}\) Sequencing}
\(\overline{R E S}\) going from low-to-high causes the R65C/1 to set the Interrupt Disable bit in the Processor Status Register (bit 2) and to initiate RES vector fetch at address \$FFC and \$FFD to begin user program execution. All of the I/O ports (PA, PB, PC, and PD) and CNTR are forced to the high (logic 1) state. All bits of the Control Register are cleared to logic 0, causing the Interval Timer Counter Mode (Mode 0) to be selected and causing all interrupt enable bits to be reset. All Prescaler Control Register bits are also reset to 0 causing Prescaler Mode 0 to be selected.


Figure 3-10. Interval Timer (Mode 0) Timing Waveforms


Figure 3-11. Event Counter (Mode 2) Timing Waveforms


Figure 3-12. Pulse Width Measurement (Mode 3) Timing Waveforms

\section*{NMI Sequencing}

At the first operation code fetch following the high-to-low transition of the \(\overline{\mathrm{NMI}}\) input, the interrupt logic forces execution of the Break (BRK) instruction and subsequent execution from the address vector stored at \$FFA and \$FFB. Simultaneous with the execution of the BRK instruction, the Interrupt Disable bit in the Processor Status Register is set to disable an IRQ and bit 1 in the Prescaler Control Register is cleared to select unscaled system clock. Bit 0 of the Prescaler Control Register is unaffected.

\section*{IRQ Sequencing}

The internal IRQ can be generated by any or all of three possible conditions: Counter Overflow, a positive edge detected on PA0, or a negative edge detected on PA1. The IRQ in response to these conditions can be enabled or disabled by setting or resetting the appropriate interrupt enable bits in the Control Register.

The first IRQ condition is Counter Overflow. IRQ will occur whenever both the Counter Interrupt Enable (CR4) and the Counter Overflow (CR7) are logic 1.

The second IRQ condition is detection of a positive edge on PAO. IRQ will occur whenever both the PAO Interrupt Enable (CR3) and the PAO Positive Edge Detected (CR6) are logic 1.

The third IRQ condition is detection of a negative edge on PA1. IRQ will occur whenever both the PA1 Interrupt Enable (CR2) and the PA1 Negative Edge Detected (CR5) are logic 1.

Multiple simultaneous interrupts will cause the IRQ to remain active until all interrupting conditions have been serviced and cleared.

The IRQ interrupt occurs when bit 2 of the Process Status Register is clear (enabling an IRQ), an IRQ enable bit (bit 2, 3 or 4) in the Control Register is set, and the corresponding interrupt bit (bit 5, 6 or 7) in the Control Register is set. Upon IRQ interruption, the BRK instruction is forced and subsequent program execution begins from the address vector stored at \$FFE and \$FFF. Bit 2 of the Processor Status Register is set. Bit 1 in the Prescaler Control Register is cleared to select unscaled system \(\emptyset 2\) clock. Bit 0 of the Prescaler Control Register is unaffected.

\section*{SECTION 4 POWER ON/OFF INITIALIZATION AND OTHER CONSIDERATIONS}

This section describes power turn-on, stop mode and mask option considerations for the R65C10.

\subsection*{4.1 POWER-ON TIMING}

After application of \(V_{C C}\) power to the R65C10, \(\overline{\operatorname{RES}}\) must be held low for at least eight \(\emptyset 2\) clock cycles after \(V_{C C}\) reaches operating range and the internal clock oscillator has stabilized. This stabilization time is dependent upon the input \(\mathrm{V}_{\mathrm{CC}}\) voltage and performance of the crystal or clock input circuit. The clock oscillator output can be monitored on XTLO (Pin 11).

The power turn-on waveforms are illustrated in Figure 4-1.

\subsection*{4.2 STOP MODE}

The Stop mode is an ultra-low-power mode in which the internal oscillator and clock is stopped. This mode is entered by writing to address \$08D and is exited only when \(\overline{R E S}\) is asserted.

While in this mode, the R65C10 is dormant; however, the contents of RAM are preserved. Maximum power dissipation while in the Stop mode is under 4 mW . The oscillator stops with XTLO low.

A mask option is provided to inhibit Stop mode entry. This option is recommended if Stop mode is not used during operation.

\subsection*{4.3 MASK OPTIONS}

Mask options are user selectable options permanently implemented when the R65C10 device is manufactured in response
to a customer order. The options are to be specified on the R65C10 sheet in the R6500/* ROM Code Order Forms (Literature Order No. 2134). The options deal with three basic circuits:
- Input crystal/clock frequency divisor
- I/O port direction registers and internal pull-up resistors
- Stop mode enable/disable

\section*{Input Crystal/Clock Frequency Divisor}

The input clock/crystal frequency divisor can be selected to be either 1 or 2 (see Section 3.11).

\section*{Direction Registers/Pull-up Resistors}

Direction registers can be selected for controlling port input/ output operation (see Section 3.14).

If direction registers are not used, then internal pull-up resistors can be optionally selected. In this case, pull-up resistors can be optionally included for 8 -bit port groups only, i.e., not for individual I/O lines within an 8 -bit port group. In addition, an internal pull-up for the CNTR line is selectable.

If direction registers are included, then internal pull-ups are not allowed.

\section*{Stop Mode Entry Enable}

An option also exists to enable Stop mode use by writting to address 08D. (see Section 4.2).


Figure 4-1. Power Turn-On Timing Detail

\section*{SECTION 5 SYSTEM SPECIFICATIONS}

ABSOLUTE MAXIMUM RATINGS*
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.3 to +7.0 & VdC \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to +7.0 & Vdc \\
\hline Storage Temperature & \(\mathrm{T}_{\mathrm{STG}}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: Stresses exceeding those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{OPERATING CONDITIONS}
\begin{tabular}{|l|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & \(5.0 \mathrm{Vdc} \pm 10 \%\) \\
\hline \begin{tabular}{l} 
Operating Temperature (Ambient) \\
Commercial \\
Industrial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \(\mathrm{T}_{\mathrm{L}}\) to \(\mathrm{T}_{\mathrm{H}}\) \\
\(0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\) \\
\(-40^{\circ} \mathrm{C}\) to \(+85^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}

\section*{ELECTRICAL CHARACTERISTICS}
(Over operating conditions unless otherwise noted)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ \({ }^{1}\) & Max & Units & Test Conditions \\
\hline \begin{tabular}{l}
Input High Voltage \\
All except \(\overline{\mathrm{NMI}}\) and \(\overline{\mathrm{RES}}\) \(\overline{\text { NMI, }} \overline{\text { RES }}\)
\end{tabular} & \(\mathrm{V}_{\mathrm{IH}}\) & \[
\begin{aligned}
& +2.0 \\
& +2.4
\end{aligned}
\] & - & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{Cc}} \\
& \mathrm{~V}_{\mathrm{cc}}
\end{aligned}
\] & V & \(\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}\) \\
\hline Input Low Voltage & \(\mathrm{V}_{\text {IL }}\) & - & - & \(+0.8\) & V & \(\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}\) \\
\hline Input Leakage Current \(\overline{R E S}, \overline{N M I}\) & 1 IN & - & - & \(\pm 2.5\) & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{IN}}=0\) to 5.0 V \\
\hline Output High Voltage & \(\mathrm{V}_{\mathrm{OH}}\) & +2.4 & - & - & V & \[
\begin{aligned}
& V_{C C}=4.5 \mathrm{~V} \\
& I_{\text {LOAD }}=-100 \mu \mathrm{~A}
\end{aligned}
\] \\
\hline Output Low Voltage & \(\mathrm{V}_{\mathrm{OL}}\) & - & - & \(+0.4\) & V & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \\
& \mathrm{I}_{\mathrm{LOAD}}=1.6 \mathrm{~mA}
\end{aligned}
\] \\
\hline Output High Current (Sourcing) & IOH & -100 & - & - & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\text {OUT }}=2.4 \mathrm{~V}\) \\
\hline Output Low Current (Sinking) & \(\mathrm{IOL}^{2}\) & 1.6 & - & - & mA & \(\mathrm{V}_{\text {OUT }}=0.4 \mathrm{~V}\) \\
\hline I/O Port Pull-Up Resistance PAO-PA7, PB0-PB7, PC0-PC7, PD0-PD7, CNTR & \(\mathrm{R}_{\mathrm{L}}\) & 2.0 & 3.2 & 6.0 & Kohm & \\
\hline ```
Input Capacitance
    XTLI, XTLO
    PAO-PA7, PB0-PB7, PC0-PC7,
    PD0-PD7, CNTR
``` & \(\mathrm{C}_{\mathrm{iN}}\) & - & - & \[
\begin{array}{r}
25 \\
7
\end{array}
\] & pF & \[
\begin{aligned}
& T_{A}=25^{\circ} \mathrm{C} \\
& V_{I N}=0 \mathrm{~V} \\
& f=2 \mathrm{MHz}-4 \mathrm{MHz}
\end{aligned}
\] \\
\hline Output Capacitance & \(\mathrm{C}_{\text {OUT }}\) & - & - & 50 & pF & 1 TTL load \\
\hline Input Frequency (f) Crystal Clock Clock & f & \[
\begin{aligned}
& 2.0 \\
& 0.04 \\
& 0.02
\end{aligned}
\] & - & \[
\begin{aligned}
& 8.0 \\
& 8.0 \\
& 4.0
\end{aligned}
\] & \begin{tabular}{l}
MHz \\
MHz \\
MHz
\end{tabular} & \begin{tabular}{l}
\(\div 2\) selected \\
\(\div 2\) selected \\
\(\div 1\) selected
\end{tabular} \\
\hline \begin{tabular}{l}
Power Dissipation \\
Operating \\
Stop Mode
\end{tabular} & \(P_{D}\) & - & \[
\begin{aligned}
& 12 \\
& 1.4
\end{aligned}
\] & \[
\begin{aligned}
& 14 \\
& 1.6
\end{aligned}
\] & \[
\begin{gathered}
\mathrm{mW} / \mathrm{MHz} \\
\mathrm{~mW}
\end{gathered}
\] & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V} \\
& \text { Outputs High } \\
& \text { Frequency }=\text { unscaled } \emptyset 2 \text { clock } \\
& \text { No external clock input }
\end{aligned}
\] \\
\hline
\end{tabular}

\section*{Notes:}
1. \(T_{A}=25^{\circ} \mathrm{C}\) and \(V_{C C}=5.0 \mathrm{~V}\).
2. Negative sign indicates outward current flow, positive indicates inward flow.

\section*{SWITCHING CHARACTERISTICS}
(Over operating conditions unless otherwise noted)


\section*{SWITCHING WAVEFORMS}


\section*{APPENDIX A R65C10 INSTRUCTION SET}

This appendix summarizes the R65C10 instruction set. The basic instructions are listed alphabetically by standard mnemonic in Table A-1. The instruction operation codes (OP Codes) for all valid addressing modes are listed in Table A-2. Also listed in Table A-2 are the number of bytes and number of CPU cycles required in each addressing mode. The effect of instruction execution on the Processor Status Register is also shown.

A matrix of instructions and addressing modes arranged by operation code is shown in Table A-3. For detailed information about CPU instruction execution, consult the R6500 Programming Manual (Order No. 202).

Table A-4 summarizes the differences in operation between the R65C10 CPU and the R6502 CPU.

Table A-1. R65C10 Instruction Set Alphabetic Sequence
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Instruction & Mnemonic & Instruction \\
\hline ADC & Add Memory to Accumulator with Carry & JMP & Jump to New Location \\
\hline AND & "AND" Memory with Accumulator & JSR & Jump to New Location Saving Return Address \\
\hline ASL & Shift Left One Bit (Memory or Accumulator) & LDA & \\
\hline & & LDX & LOAD Index X with Memory \\
\hline BCC & Branch on Carry Clear & LDY & Load Index Y with Memory \\
\hline BCS & Branch on Carry Set & LSR & Shift One Bit Right (Memory or Accumulator) \\
\hline BEQ
BIT & Branch on Result Zero & & \\
\hline BMI & Test Bits in Memory with Accumulator
Branch on Result Minus & NOP & No Operation \\
\hline BNE & Branch on Result not Zero & ORA & "'OR" Memory with Accumulator \\
\hline BPL & Branch on Result Plus & PHA & Push Accumulator on Stack \\
\hline BRK & Force Break & PHP & Push Processor Status on Stack \\
\hline BVC & Branch on Overflow Clear & PLA & Pull Accumulator from Stack \\
\hline BVS & Branch on Overflow Set & PLP & Pull Processor Status from Stack \\
\hline CLC & Clear Carry Flag & ROL & Rotate One Bit Left (Memory or Accumulator) \\
\hline CLD & Clear Decimal Mode & ROR & Rotate One Bit Right (Memory or Accumulator) \\
\hline CLI & Clear Interrupt Disable Bit & RTI & Return from Interrupt \\
\hline CLV & Clear Overflow Flag & RTS & Return from Subroutine \\
\hline CMP & Compare Memory and Accumulator & & \\
\hline CPX & Compare Memory and Index X & SBC & Subtract Memory from Accumulator with borrow \\
\hline CPY & Compare Memory and Index Y & SEC & Set Carry Flag \\
\hline & & SED & Set Decimal Mode \\
\hline & & SEI & Set Interrupt Disable Status \\
\hline DEC & Decrement Memory by One & STA & Store Accumulator in Memory \\
\hline DEX & Decrement Index X by One & STX & Store Index X in Memory \\
\hline DEY & Decrement Index Y by One & STY & Store Index Y in Memory \\
\hline EOR & 'Exclusive-Or'' Memory with Accumulator & TAX & Transfer Accumulator to Index \(X\) \\
\hline -OR & "Exclusive-Or' Memory with Accumulator & TAY & Transfer Accumulator to Index Y \\
\hline & & TSX & Transfer Stack Pointer to Index X \\
\hline INC & Increment Memory by One & TXA & Transfer Index X to Accumulator \\
\hline INX & Increment Index X by One & TXS & Transfer Index X to Stack Register \\
\hline INY & Increment Index Y by One & TYA & Transfer Index Y to Accumulator \\
\hline
\end{tabular}

Table A.2. R65C10 Instruction Set by Address Modes
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{3}{*}{mNEMORIC} & \multirow[b]{3}{*}{operation} & \multicolumn{34}{|c|}{addressing modes} & \multirow[t]{2}{*}{PROCESSOR STATUS
CODES} & \multirow[b]{3}{*}{Mnemonic} \\
\hline & & IMmE & golate & E ABS & Soll & & & 0 Pag & & & ccum & & Plieo & & & 40. \(x_{1}\) & & 01. & & & AGE, \({ }^{\text {a }}\) & & & S \(x\) & & & S. 4 & & lativ & & & IRECT & 2 & PAGE. & & & \\
\hline & & OP & n & OP & \(n\) & - & OP & n & " & OP & n & " OP & n & * & OP & \(n\) & OP & n & * & OP & \(n\) & \(\cdots\) & OP & n & " & OP & \(n\) & OP & ก & * & OP & \(\pi\) & \({ }^{\prime \prime} \mathrm{OP}\) & \(n\) & & \begin{tabular}{|lllllllll|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline\(N\) & \(V\) & 0 & 8 & 0 & 1 & 2 & \(C\) \\
\hline\(N\) & \(V\) & & & & & & &
\end{tabular} & \\
\hline \begin{tabular}{l}
A DC \\
AND \\
ASt \\
BCC \\
BCS
\end{tabular} & \[
\begin{array}{ll}
A+M+C \rightarrow A & \text { (4) (1) } \\
A A M-A & \\
C-1 \\
\text { BRANCHONC }=0 & (1) \\
\text { BRANCH ONC }=1 & \text { (2) }
\end{array}
\] & (1)69 & \[
\begin{array}{l|l}
\hline 2 & 2 \\
2 & 2
\end{array}
\] & 60 & 4
4
6 & [ \(\begin{aligned} & 3 \\ & 3 \\ & 3\end{aligned}\) & 65 & 3
3
5 & 2
2
2 & OA & 2 & 1 & & & & 6 & \begin{tabular}{l|l}
2 & 7 \\
2 & 31
\end{tabular} & 5 & 2 & 75 & \begin{tabular}{l|l}
4 & 2 \\
4 & 2 \\
6 & 2
\end{tabular} & \[
\begin{aligned}
& 2 \\
& 2 \\
& 2
\end{aligned}
\] & \[
\begin{gathered}
70 \\
30 \\
1 \mathrm{E}
\end{gathered}
\] & 4
4
7 & 1
3
3 & \begin{tabular}{l}
79 \\
\\
\hline 9
\end{tabular} & 4 & \begin{tabular}{|c|c}
3 \\
3 & \\
& \\
& \\
\hline 0 \\
80
\end{tabular} & 2 & \[
\begin{aligned}
& 2 \\
& 2
\end{aligned}
\] & & & & & &  & \begin{tabular}{l}
\(A D C\) \\
AND \\
ASL \\
\(B C\) \\
BCS
\end{tabular} \\
\hline \[
\begin{aligned}
& \text { BEO } \\
& B I T \\
& B M I \\
& B N E \\
& B P L
\end{aligned}
\] & \begin{tabular}{l}
BRANCHONZ \(=1 \quad\) (2) \\
AAM \\
BRANCHONN = 1 (2) \\
BRANCHONZ \(=0 \quad\) (2) \\
BRANCHONN \(=0\) (2)
\end{tabular} & & & 2 C & 4 & 3 & 24 & 3 & 2 & & & & & & & & & & & & & & & & & & & \[
\begin{array}{|c|}
\hline F 0 \\
30 \\
00 \\
10 \\
\hline
\end{array}
\] & \[
2
\]
\[
2
\]
\[
2
\]
\[
2
\] & \[
2
\] & & & & & &  & \begin{tabular}{l}
BEO \\
B! \(T\) \\
BMI \\
BNE \\
\(B \mathrm{PL}\)
\end{tabular} \\
\hline \[
\begin{aligned}
& B R K \\
& B \vee C \\
& B \vee S \\
& C L C \\
& C \& D
\end{aligned}
\] & \begin{tabular}{l}
BREAK \\
BRANCHONV \(=0 \quad\) (2) \\
BRANCHONV \(=1\) (2)
\[
\begin{aligned}
& 0 \rightarrow C \\
& 0 \rightarrow 0
\end{aligned}
\]
\end{tabular} & & & & & & & & & & & \[
\begin{gathered}
\hline 00 \\
18 \\
08 \\
\hline
\end{gathered}
\] & \begin{tabular}{l}
2 \\
2
\end{tabular} &  & & & & & & & & & & & & & & 50 & 2 & \[
\begin{aligned}
& 2 \\
& 2
\end{aligned}
\] & & & & & &  & \[
\begin{aligned}
& B R K \\
& B \vee C \\
& B \vee S \\
& C L C \\
& C L D
\end{aligned}
\] \\
\hline \[
\begin{align*}
& \text { CLI } \\
& \text { CLV } \\
& \text { CMP }  \tag{1}\\
& \text { CPX } \\
& \text { CPY }
\end{align*}
\] & \[
\begin{aligned}
& 0-1 \\
& 0 \rightarrow V \\
& A-M \\
& X-M \\
& Y-M
\end{aligned}
\] & \begin{tabular}{l|l}
CS & 2 \\
EO & 2 \\
CO & 2
\end{tabular} & \[
\begin{array}{l|l}
2 & 2 \\
2 & 2 \\
2 & 2 \\
\hline
\end{array}
\] & \[
\begin{array}{l|l|}
2 & \mathrm{CO} \\
2 & \mathrm{EC} \\
2 & \mathrm{CC} \\
\hline
\end{array}
\] & 4 & 3
3
3 & \begin{tabular}{l|} 
C5 \\
E4 \\
C4 \\
\hline
\end{tabular} & \begin{tabular}{l|l|}
3 \\
3 \\
3
\end{tabular} & \begin{tabular}{l}
2 \\
2 \\
2 \\
\hline
\end{tabular} & & & 58
88 & \[
\begin{aligned}
& 2 \\
& 2
\end{aligned}
\] & 1 & \(C_{1}\) & 6 & 201 & 5 & 2 & 05 & 4 & 2 & DO & 4 & 3 & 09 & 4 & 3 & & & & & & & &  & \[
\begin{aligned}
& \text { CLI } \\
& \text { CLV } \\
& \text { CMP } \\
& \text { CPX } \\
& \text { CPY }
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& \text { DEC } \\
& \text { DEX } \\
& \text { DEY } \\
& \text { EOR } \\
& \text { IN }
\end{aligned}
\] & \[
\begin{aligned}
& M-1 \rightarrow M \\
& X-1-X \\
& Y-1-Y \\
& A \forall M=A \\
& M+1 \rightarrow M
\end{aligned}
\] & 49 & 22 &  & 6
4
4
6 & \({ }^{3}\) & \({ }^{\text {C6 }}\) & 5

3
5 & 2
2
2 & & & CA & 2 & 1 & 41 & 6 & 251 & 5 & 2 & D6 & 6 & \[
\begin{aligned}
& 2 \\
& 2 \\
& 2 \\
& 2
\end{aligned}
\] & \[
\left|\begin{array}{c}
\mathrm{DE} \\
50 \\
\mathrm{FE}
\end{array}\right|
\] & 7
4
7
7 & \[
\left[\begin{array}{l}
3 \\
3 \\
3
\end{array}\right.
\] & 59 & 4 & 3 & & & & & & & &  & DEC DEX DEY EOR INC \\
\hline \[
\begin{aligned}
& \text { INX } \\
& \text { INY } \\
& \text { JMP } \\
& \text { JSR } \\
& \text { LDA }
\end{aligned}
\] & \begin{tabular}{l}
\[
\begin{aligned}
& x+1 \rightarrow x \\
& y+1 \rightarrow y
\end{aligned}
\] \\
JUMPTONEWLOC \\
Jump SUB
\[
M \cdot A
\]
\end{tabular} & A9 & 2. 2 & 4 \begin{tabular}{|c|c|}
\(4 C\) \\
20 \\
\(A D\) \\
\hline
\end{tabular} & \begin{tabular}{l}
3 \\
4 \\
4 \\
\hline
\end{tabular} & \begin{tabular}{|l|l|}
3 \\
3 \\
3
\end{tabular} & & 3 & 2 & & & E8 & 2 & \[
\begin{array}{l|}
\hline 1 \\
1
\end{array}
\] & A1 & 6 & \(2 . \mathrm{B}\) & 5 & 2 & B5 & 4 & 2 & 80 & 4 & 3 & B9 & 4 & 3 & & & 6 C & 5 & 3 & & & \(\left.\begin{array}{ccccccc}\text { N } & \cdot & \cdot & \cdot & \cdot & z & \cdot \\ \text { N } & \cdot & \cdot & \cdot & \cdot & z & \cdot \\ \cdot & \cdot & \cdot & \cdot & \cdot & \cdot & \cdot\end{array}\right)\) & \[
\begin{aligned}
& \text { INX } \\
& \text { INY } \\
& \text { JMP } \\
& \text { JSR } \\
& \text { LDA } \\
& \hline
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& \text { LDX } \\
& \text { LDY } \\
& \text { LSA } \\
& \text { NOP } \\
& \text { ORA }
\end{aligned}
\] &  & \[
\begin{array}{|c|}
\mathrm{A}_{2} \\
\mathrm{AO}^{2} \\
09 \\
\hline
\end{array}
\] & \[
\begin{array}{l|l}
2 & 2 \\
2 & 2 \\
& \\
2 & 2 \\
\hline
\end{array}
\] & \[
\begin{array}{l|l|}
\hline 2 & \mathrm{AE} \\
2 & \mathrm{AC} \\
2 & \mathrm{AE} \\
2 & \\
\hline
\end{array}
\] &  & \[
\begin{array}{|l|}
3 \\
3 \\
3 \\
3 \\
\hline
\end{array}
\] & \[
\begin{aligned}
& \mathrm{A} 6 \\
& \mathrm{~A} 4 \\
& \mathrm{A6} \\
& \\
& 05
\end{aligned}
\] & \[
\begin{aligned}
& 3 \\
& 3 \\
& 5 \\
& 3
\end{aligned}
\] & \[
\begin{aligned}
& 2 \\
& 2 \\
& 2 \\
& 2 \\
& \hline
\end{aligned}
\] & 4 A & 2 & \(1{ }^{1}\) EA & 2 & 1 & & 6 & 211 & 5 & 2 & 84 & \[
\left\lvert\, \begin{array}{l|l}
4 \\
6
\end{array}\right.
\] & \[
\begin{aligned}
& 2 \\
& 2 \\
& 2 \\
& 2
\end{aligned}
\] & \[
\left|\begin{array}{c}
\mathrm{BC} \\
5 E \\
10
\end{array}\right|
\] & 4
7
4 & \[
\begin{aligned}
& 3 \\
& 3 \\
& 3 \\
& \hline
\end{aligned}
\] & \[
\begin{gathered}
B E \\
19
\end{gathered}
\] & \[
\begin{aligned}
& 4 \\
& 4
\end{aligned}
\] & & & & & & 86 & 4 & 2 &  & \begin{tabular}{l}
LDX \\
Lor \\
LSR \\
NOP \\
ORA
\end{tabular} \\
\hline \begin{tabular}{l}
PHA \\
PHP \\
PLA \\
PLP \\
ROL
\end{tabular} &  & & & 2 E & 6 & 3 & 26 & 5 & 2 & 2 A & 2 & \[
\begin{aligned}
& 48 \\
& 08 \\
& 68 \\
& 28
\end{aligned}
\] & \[
\left.\begin{aligned}
& 3 \\
& 3 \\
& 4 \\
& 4
\end{aligned} \right\rvert\,
\] & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 1
\end{aligned}
\] & & & & & & 36 & 6 & 2 & 3 E & 7 & 3 & & & & & & & & & & & \begin{tabular}{l}
\[
N \cdot \cdots \cdot \cdot z \cdot
\] \\
(RESTORED)
\[
\mathrm{N} \cdot . \cdot .2 \mathrm{C}
\]
\end{tabular} & \begin{tabular}{l}
PHA \\
PHP \\
\(P L A\) \\
\(P L P\) \\
HOL
\end{tabular} \\
\hline \begin{tabular}{l}
ROR \\
RTI \\
RTS \\
SBC \\
SEC \\
SED
\end{tabular} & \begin{tabular}{l}
- C. 4
\(\square\) RTRNINT \\
RTRNSUB
\[
\begin{aligned}
& A-M-\bar{C} \cdot A \\
& 1 \rightarrow C \\
& 1 \rightarrow D
\end{aligned}
\] \\
(4) (1)
\end{tabular} & E9 & 22 & \({ }_{2}^{6 E}\) & 6 & \({ }_{3}^{3}\) & \({ }_{\text {E5 }} 66\) & \begin{tabular}{|c}
5 \\
3
\end{tabular} & \({ }_{2}^{2}\) & 6 A & 2 & \[
\begin{array}{l|l}
1 & \\
40 \\
60 \\
& \\
38 \\
\mathrm{FB}
\end{array}
\] & \[
\left.\begin{array}{|l|}
6 \\
6 \\
2 \\
2
\end{array} \right\rvert\,
\] &  & E1 & 6 & 2 F & 5 & 2 & \({ }_{\text {F5 }}{ }^{76}\) & 6 & \[
\begin{aligned}
& 2 \\
& 2
\end{aligned}
\] & \[
\left\lvert\, \begin{gathered}
\\
F E \\
F E
\end{gathered}\right.
\] & 4 & \({ }^{3}\) & F9 & 4 & 3 & & & & & & & & \begin{tabular}{l}
N•••••ZC \\
(RESTORED) \\
N v • • • \(z_{\text {(3) }}\)
\end{tabular} &  \\
\hline \[
\begin{aligned}
& \hline \text { STE I } \\
& \text { STA } \\
& \text { STXX } \\
& \text { STYY } \\
& \text { TAX } \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& B \rightarrow 1 \\
& A-M \\
& X-M \\
& Y \rightarrow M \\
& A-X
\end{aligned}
\] & & & 80
\(8 E\)
8 C & 4 & 3
3
3 & 85 & 3
3
3 & 2
2
2 & & & 78
\[
A A
\] & 2 & 1
\[
1
\] & 81 & 6 & 291 & 6 & 2 & 95 & \begin{tabular}{l}
4 \\
4
\end{tabular} & \[
2
\] & 90 & 5 & 3 & 99 & 5 & 3 & & & & & 96 & 4 & 2 & \begin{tabular}{ccccc} 
• & \(\cdot\) & \(\cdot\) & \(\cdot\) & 1 \\
\(\cdot\) & \(\cdot\) & \(\cdot\) & \(\cdot\) & \(\cdot\) \\
\(\cdot\) & \(\cdot\) & \(\cdot\) \\
P & \(\cdot\) & \(\cdot\) & \(\cdot\) & \(\cdot\) \\
N & \(\cdot\) & \(\cdot\) & \(\cdot\) & \(\cdot\) \\
N & \(\cdot\) & \(\cdot\) & \(\cdot\) & \(\cdot\) \\
\hline
\end{tabular} &  \\
\hline \[
\begin{aligned}
& \hline T A Y \\
& T S X \\
& T \times A \\
& T \times S \\
& T Y A \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& A \rightarrow Y \\
& S \rightarrow X \\
& X=A \\
& X \rightarrow S \\
& Y \in A \\
& \hline
\end{aligned}
\] & & & & & & & & & & & AB & 2 & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 1 \\
& 1
\end{aligned}
\] & & & & & & & & & & & & & & & & & & & & & & \(\begin{array}{ccccccc}\text { N } & \cdot & \cdot & \cdot & \cdot & z & \cdot \\ N & \cdot & \cdot & \cdot & \cdot & \cdot & z\end{array} \cdot\) & \begin{tabular}{l} 
TAXY \\
TS X \\
TXA \\
TXS \\
TYA \\
\hline
\end{tabular} \\
\hline \multicolumn{18}{|c|}{(1) ADD I TO N IF PAGE BOUNDARY IS CROSSED
(2) ADD 1 TO N IF BRANCH OCCURS TO SAME PAGE
ADD TO N IF BRANCH OCCURS TO DIFFERENT PAGE
(3) CARRYNOT = BORRON
(4) ADD 1 TO NIF IN DECIMAL MODE} & & Ms & &  & \[
\begin{aligned}
& x \quad x \\
& x \\
& \times y \\
& \text { UMUL } \\
& \text { ORY } \\
& \text { ORY }
\end{aligned}
\] & \begin{tabular}{l}
lat \\
PER \\
PER
\end{tabular} & OR & & & & DORFS
\[
E R
\] & & & \(\wedge\)
\(v\) & E) & DD UBTR ND R xCLUS & \begin{tabular}{l}
CT \\
IVE
\end{tabular} & & \begin{tabular}{l}
M, MEMORY \\
\(M_{0}\) MEMOAY \\
\(n\) NO CYCL \\
* NO BYTES
\end{tabular} & \[
\begin{aligned}
& \text { BIT } 7 \\
& \text { Bit } 6 \\
& \text { ES }
\end{aligned}
\] \\
\hline
\end{tabular}

LSD


NOTES:
\({ }^{\text {a Add }} 1\) to \(N\) if page boundary is crossed.
bAdd 1 to N if branch occurs to same page; add 2 to N if branch occurs to different page.
cAdd 1 to N if in decimal mode.

\footnotetext{
\begin{tabular}{c|c}
0 \\
0 \begin{tabular}{c|c}
0 & BRK \\
Implied \\
1 & 7
\end{tabular} & - OP Code \\
- Addressing Mode \\
- No. of Instruction
\end{tabular}
- No. of Instruction Bytes (\#); No. of Machine Cycles (n)
}

Table A-4. R65C10 Instruction Enhancements
\begin{tabular}{|l|l|l|}
\hline \multicolumn{1}{|c|}{ Function } & \multicolumn{1}{|c|}{ NMOS R6502 Microprocessor } & \multicolumn{1}{c|}{ CMOS R65C10 Microprocessor } \\
\hline Indexed addressing across page boundary. & Extra read of invalid address. & Extra read of last instruction byte. \\
\hline Jump indirect, operand \(=\) XXFF. & Page address does not increment. & \begin{tabular}{l} 
Page address increments and adds one \\
additional cycle.
\end{tabular} \\
\hline \begin{tabular}{l} 
Read/modify/write instructions at effective \\
address.
\end{tabular} & One read and two write cycles. & Two read and one write cycle. \\
\hline Decimal flag. & Indeterminate after reset. & \begin{tabular}{l} 
Initialized to binary mode (D = 0) after reset \\
and interrupts.
\end{tabular} \\
\hline Flags after decimal operation. & Invalid N, V and Z flags. & Valid flag adds one additional cycle. \\
\hline Interrupt after fetch of BRK instruction. & \begin{tabular}{l} 
Interrupt vector is loaded, BRK vector is \\
ignored.
\end{tabular} & BRK is executed, then interrupt is executed. \\
\hline
\end{tabular}

\section*{PACKAGE DIMENSIONS}
40-PIN CERDIP

\begin{tabular}{|c|c|c|c|c|}
\hline & \multicolumn{2}{|c|}{ MILLIMETERS } & \multicolumn{2}{c|}{ INCHES } \\
\cline { 2 - 5 } DIM & MIN & MAX & MIN & MAX \\
\hline A & 5156 & 5258 & 2.030 & 2.070 \\
\hline B & 12.95 & 13.46 & 0.510 & 0.530 \\
\hline C & 406 & 508 & 0160 & 0.200 \\
\hline D & 041 & 0.51 & 0.016 & 0020 \\
\hline F & 1.27 & 1.52 & \multicolumn{2}{|c|}{0.050} \\
\hline G & 2.54 & BSC & \multicolumn{2}{c|}{0.100} \\
\hline H & \multicolumn{2}{|c|}{1.78} & 229 & \multicolumn{2}{c|}{0.070} & 0.090 \\
\hline J & 0.20 & 0.30 & \multicolumn{2}{|c|}{0.008} \\
\hline K & 3.05 & 4.06 & 0012 \\
\hline L & \multicolumn{2}{|c|}{1524} & BSC & \multicolumn{2}{|c|}{0.600} & 0.160 \\
\hline M & \multicolumn{2}{|c|}{\(0^{\circ}\)} & \(10^{\circ}\) & \multicolumn{2}{c|}{\(0^{\circ}\)} & \(10^{\circ}\) \\
\hline N & \multicolumn{2}{|c|}{0.38} & 0.89 & \multicolumn{2}{c|}{0.015} & 0.035 \\
\hline
\end{tabular}

\section*{40-PIN PLASTIC DIP}

\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{ DIM } & \multicolumn{2}{|c|}{ MILLIMETERS } & \multicolumn{2}{c|}{ INCHES } \\
\cline { 2 - 5 } & MIN & MAX & MIN & MAX \\
\hline A & 51.82 & 52.32 & 2.040 & 2.060 \\
\hline B & 13.46 & 13.97 & 0.530 & 0.550 \\
\hline C & 3.56 & 508 & 0.140 & 0.200 \\
\hline D & 0.38 & 0.53 & 0.015 & 0.021 \\
\hline F & \multicolumn{2}{|c|}{1.02} & 1.52 & \multicolumn{2}{|c|}{0.040} \\
\hline G & \multicolumn{2}{|c|}{2.54} & BSC & \multicolumn{2}{c|}{0.100} \\
\hline H & \multicolumn{2}{|c|}{1.65} & 2.16 & \multicolumn{2}{|c|}{0.065} \\
\hline J & 020 & 0.30 & \multicolumn{2}{|c|}{0.008} & 0.012 \\
\hline K & \multicolumn{2}{|c|}{3.30} & 4.32 & \multicolumn{2}{|c|}{0.130} \\
\hline L & \multicolumn{2}{|c|}{15.24} & 0.170 \\
\hline M & \multicolumn{2}{|c|}{\(7^{\circ}\)} & \(10^{\circ}\) & \multicolumn{2}{c|}{\(7^{\circ}\)} \\
\hline N & \multicolumn{2}{|c|}{0.51} & 1.02 & \multicolumn{2}{c|}{0.020} \\
\hline
\end{tabular}
44-PIN PLASTIC LEADED CHIP CARRIER (PLCC)


TOP VIEW


SEATING PLANE


SIDE VIEW


SECTION A-A TYP FOR BOTH AXIS (EXCEPT FOR BEVELED EDGE)
CHAM. 11 PINS EJECTOR PIN MARKS
\(h \times 45^{\circ}\) PER SIDE 4 PLCS BOTTOM OF PACKAGE ONLY (TYPICAL)
\begin{tabular}{|c|c|c|c|c|c|}
\hline & \multicolumn{2}{|c|}{ MILLIMETERS } & \multicolumn{2}{c|}{ INCHES } \\
\cline { 2 - 5 } DIM & MIN & MAX & MIN & MAX \\
\hline A & 4.14 & 4.39 & 0.163 & 0.173 \\
\hline A1 & 1.37 & 1.47 & 0.054 & 0.058 \\
\hline A2 & 2.31 & 246 & 0.091 & 0.097 \\
\hline b & \multicolumn{2}{|c|}{0.457 TYP } & \multicolumn{2}{|c|}{0.018 TYP } \\
\hline D & 17.45 & 17.60 & 0.687 & 0.693 \\
\hline D1 & 16.46 & 16.56 & 0648 & 0.652 \\
\hline D2 & 12.62 & 1278 & 0.497 & 0.503 \\
\hline D3 & \multicolumn{2}{|c|}{15.75 REF } & \multicolumn{2}{|c|}{0.620 REF } \\
\hline e & \multicolumn{2}{|c|}{1.27 BSC } & \multicolumn{2}{|c|}{0.050 BSC } \\
\hline h & \multicolumn{2}{|c|}{1.15 TYP } & \multicolumn{2}{|c|}{0.045 TYP } \\
\hline J & \multicolumn{2}{|c|}{0.25 TYP } & \multicolumn{2}{|c|}{0010 TYP } \\
\hline\(\alpha\) & \multicolumn{2}{|c|}{\(45^{\circ}\) TYP } & \multicolumn{2}{|c|}{\(45^{\circ}\) TYP } \\
\hline R & \multicolumn{2}{|c|}{0.89 TYP } & \multicolumn{2}{|c|}{0.035 TYP } \\
\hline R1 & \multicolumn{2}{|c|}{0.25 TYP } & \multicolumn{2}{|c|}{0.010 TYP } \\
\hline
\end{tabular}
VIEW

\title{
R6500/1 One-Chip Microcomputer
}

\section*{SECTION 1 \\ INTRODUCTION}

\section*{SUMMARY}

The Rockwell R6500/1 microcomputer is a complete 8-bit computer fabricated on a single chip using an N -channel silicon gate MOS process. The R6500/1 complements an established and growing line of R6500 products and has a wide range of microcomputer applications.

The R6500/1 consists of an R6502 Central Processing Unit (CPU), 2048 bytes of Read Only Memory (ROM), 64 bytes of Random Access Memory (RAM) and interface circuitry for peripheral devices.

The innovative architecture and the demonstrated high performance of the R6502 CPU, as well as instruction simplicity, results in system cost-effectiveness and a wide range of computational power. These features make the R6500/1 a leading candidate for microcomputer applications.

To facilitate system and program development for the R6500/1, Rockwell has developed a 64-pin R6500/1E Emulator device, as well as a pin-compatible R6500/1EB Backpack Emulator device. For more information, refer to the data sheets for the R6500/1E (Order No. D51S) and the R6500/1EB (Order No. D60).

This product description is for the reader familiar with the R6502 CPU hardware and programming capabilities. A detailed description of the R6502 CPU hardware is included in the R6500 Microcomputer System Hardware Manual (Document Order No. 201). A description of the instruction capabilities of the R6502 CPU is contained in the R6500 Microcomputer Systems Program ming Manual (Document Order No. 202).

\section*{ORDERING INFORMATION}


\section*{FEATURES}
- Single-chip microcomputer
- R6502 software compatible
- Eight-bit parallel processing
- Decimal or binary arithmetic
- Variable length stack
- True indexing capability
- Thirteen addressing modes
- 1 or 2 MHz clock operation, with the following options:
- External single clock input
- RC time base input
- Crystal time base input
- Single +5 V power supply
- 500 mw operating power
- Separate power pin for RAM with standby power only \(10 \%\) of operating power
- \(2 \mathrm{~K} \times 8\) ROM on chip
- \(64 \times 8\) RAM on chip
- 40-pin DIP and 44-pin PLCC
- 64-pin R6500/1E Emulator part available, with 40 signals identical to production part
- 40-pin R6500/1EB Backback Emulator part available, pin compatible with an R6500/1
- Pipeline architecture
- 32 bidirectional TTL compatible I/O lines
- 1 positive edge sensitive I/O lines
- 1 negative edge sensitive I/O line
- 1 bidirectional TTL compatible counter I/O line
- 16-bit timer/counter
- Four timer/counter modes
- Internal timer
- Pulse generator
- Event counter
- Pulse width measurement
- Three maskable interrupts
- 1 counter overflow
-2 I/O edge detect
- NMI and Reset interrupts

\section*{SECTION 2 INTERFACE REQUIREMENTS}

This section describes the interface requirements for the R6500/1 single chip microcomputer. Figure 2-1 is the Interface Diagram for
the R6500/1. Figure 2-2 shows the pin out configuration and Table 2-1 describes the function of each pin of the R6500/1.


Figure 2-1. R6500/1 Interface Diagram


Figure 2-2. R6500/1 Pin Assignments

Table 2-1. R6500/1 Pin Description
\begin{tabular}{|c|c|c|}
\hline Signal Name & 1/0 & Description \\
\hline VCC & & Power. Main power supply +5 V . \\
\hline VRR & & RAM Retention Power. Separate power pin for RAM. In the event that VCC power is lost, this power retains RAM data +5 V . \\
\hline VSS & & Ground. Signal and power ground (0V). \\
\hline XTLI & 1 & Crystal In. Crystal or clock input for internal clock oscillator. \\
\hline XTLO & 0 & Crystal Out. Crystal output from internal clock oscillator. \\
\hline \(\overline{R E S}\) & 1 & Reset. The Reset input is used to initialize the R6500/1. The signal must not transition from low to high for at least eight cycles after VCC reaches operating range and the internal oscillator has stabilized (see Section 5). \\
\hline \(\overline{\text { NMI }}\) & 1 & Non-Maskable Interrupt. A negative going edge on the Non-Maskable Interrupt signal requests that a nonmaskable interrupt be generated within the CPU. \\
\hline PAO-PA7 & 1/O & Port A. General purpose I/O Port A. \\
\hline PB0-PB7 & 1/0 & Port B. General purpose I/O Port B. \\
\hline PC0-PC7 & \(1 / 0\) & Port C. General purpose I/O Port C. \\
\hline PD0-PD7 & I/O & Port D. General purpose I/O Port D. \\
\hline & & Four 8-bit ports used for either input/output. Each line consists of an active transistor to VSS and an optional passive pull-up to VCC. The two lower bits of the PA port (PAO-PA1) also serve as edge detect inputs with maskable interrupts. \\
\hline CNTR & 1/O & Counter I/O. This line is used as a Counter input/output line. CNTR is an input in the Event Counter and Pulse Width Measurement modes and is an output in the Interval Timer and Pulse Generator modes. It consists of an active transistor to VSS and an optional passive pull-up to VCC. \\
\hline
\end{tabular}

\section*{SECTION 3 SYSTEM ARCHITECTURE}

This section provides a functional description of the R6500/1. A block diagram of the R6500/1 is presented in Figure 3-1.

\subsection*{3.1 INDEX REGISTERS}

There are two 8 -bit index registers, X and Y . Each index register can be used as a base to modify the address data program counter and thus obtain a new address - the sum of the program counter contents and the and the index register contents.

When executing an instruction which specifies indirect addressing, the CPU fetches the op code and the address, and modifies the address from memory by adding the index register to it prior to loading or storing the value of memory.

Indexing greatly simplifies many types of programs, especially those using data tables.

\subsection*{3.2 STACK POINTER}

The Stack Pointer is an 8 -bit register. It is automatically incremented and decremented under control of the microprocessor to perform stack manipulation in response to
either user instructions or the interrupt lines \(\overline{\mathrm{NMI}}\) and \(\overline{\mathrm{RQ}}\). The Stack Pointer must be initialized by the user program.

The stack allows simple implementation of multiple level interrupts, subroutine nesting and simplification of many types of data manipulation. The JSR, BRK, RTI and RTS instructions use the stack and Stack Pointer.

The stack can be envisioned as a deck of cards which may only be accessed from the top. The address of a memory location is stored (or "pushed") onto the stack. Each time data are to be pushed onto the stack, the Stack Pointer is placed on the Address Bus, data are written into the memory location addressed by the Stack Pointer, and the Stack Pointer is decremented by 1. Each time data are read (or "pulled") from the stack, the Stack Pointer is incremented by 1. The Stack Pointer is then placed on the Address Bus, and data are read from the memory location addressed by the Pointer.

\subsection*{3.3 ARITHMETIC AND LOGIC UNIT (ALU)}

All arithmetic and logic operations take place in the ALU, including incrementing and decrementing internal registers


Figure 3-1. R6500/1 Block Diagram
(except the Program Counter). The ALU cannot store data for more than one cycle. If data are placed on the inputs to the ALU at the beginning of a cycle, the result is always gated into one of the storage registers or to external memory during the next cycle.
Each bit of the ALU has two inputs. These inputs can be tied to various internal buses or to a logic zero; the ALU then generates the function (AND, OR, SUM, and so on) using the data on the two inputs.

\subsection*{3.4 ACCUMULATOR}

The accumulator is a general purpose 8 -bit register that stores the results of most arithmetic and logic operations. In addition, the accumulator usually contains one of the two data words used in these operations.

\subsection*{3.5 PROGRAM COUNTER}

The 12-bit Program Counter provides the addresses that are used to step the processor through sequential instructions in a program. Each time the processor fetches an instruction from program memory, the lower (least significant) byte of the Program Counter (PCL) is placed on the low-order bits of the Address Bus and the higher (most significant) byte of the Program Counter (PCH) is placed on the high-order 4 bits of the Address Bus. The Counter is incremented each time an instruction or data is fetched from program memory.

\subsection*{3.6 INSTRUCTION REGISTER AND INSTRUCTION DECODE}

Instructions are fetched from ROM or RAM and gated onto the Internal Data Bus. These instructions are latched into the Instruction Register then decoded along with timing and interrupt signals to generate control signals for the various registers.

\subsection*{3.7 TIMING CONTROLS}

The Timing Control Logic keeps track of the specific instruction cycle being executed. This logic is set to TO each time an instruction fetch is executed and is advanced at the beginning of each Phase One clock pulse for as many cycles as are required to complete the instruction. Each data transfer which takes place between the registers is caused by decoding the contents of both the instruction register and timing control unit.

\subsection*{3.8 INTERRUPT LOGIC}

Interrupt logic controls the sequencing of three interrupts; \(\overline{\mathrm{RES}}\), \(\overline{\mathrm{NMI}}\) and \(\overline{\mathrm{RQ}} . \overline{\mathrm{RQ}}\) is generated by any one of three conditions: Counter Overflow, PA0 Positive Edge Detected, and PA1 Negative Edge Detected.

\subsection*{3.9 CLOCK OSCILLATOR}

The Clock Oscillator provides the basic timing signals used by the R6500/1 CPU. The reference frequency is provided by an external source, and can be from a crystal or clock. The external frequency can vary from 200 kHz to 4 MHz . The internal Phase 2 ( \((2)\) frequency is one-half the external reference frequency.

The on-chip oscillator is designed for a parallel resonant crystal connected between XTLI and XTLO pins. The equivalent oscillator circuit is shown in Figure 3-2.

A parallel resonant crystal is specified by its load capacitance and series resonant resistance. For proper oscillator operation, the load capacitance ( \(\mathrm{C}_{\mathrm{L}}\) ), series resistance \(\left(\mathrm{R}_{\mathrm{S}}\right)\) and the crystal resonant frequency ( F ) must meet the following two relations:
\[
\begin{gathered}
(C+27)=2 C_{L} \quad \text { or } \quad C=2 C_{L}-27 \\
R_{s} \leq R_{s \operatorname{smax}}=\frac{2 \times 10^{6}}{\left(F C_{L}\right)^{2}}
\end{gathered}
\]
where: \(F\) is in \(M H z ; C\) and \(C_{L}\) are in \(\mathrm{PF} ; R\) is in ohms.
To select a parallel resonant crystal for the oscillator, first select the load capacitance from a crystal manufacturer's catalog. Next, calculate \(\mathrm{R}_{\text {smax }}\) based on F and \(\mathrm{C}_{\mathrm{L}}\). The selected crystal must have a \(R_{s}\) less than the \(R_{\text {smax }}\).

For example, if \(\mathrm{C}_{\mathrm{L}}=22 \mathrm{pF}\) for a 4 MHz parallel resonant crystal, then
\[
\begin{aligned}
& \mathrm{C}=(2 \times 22)-27=17 \mathrm{pF} \\
& \text { (use standard value, } 18 \mathrm{pF} \text { ) }
\end{aligned}
\]

The series resistance of the crystal must be less than
\[
R_{\text {smax }}=\frac{2 \times 10^{6}}{(4 \times 22)^{2}}=258 \mathrm{ohms}
\]


Figure 3-2. Clock Oscillator Input Options

\subsection*{3.10 PROCESSOR STATUS REGISTER}

The 8-bit Processor Status Register, shown in Figure 3-3, contains seven status flags. Some of these flags are controlled by the user program; others may be controlled both by the user's program and the CPU. The R6500 instruction
set contains a number of conditional branch instructions which are designed to allow testing of these flags. Each of the eight processor status flags is described in the following sections.

\subsection*{3.10.1 CARRY BIT (C)}

The Carry Bit (C) can be considered as the ninth bit of an arithmetic operation. It is set to logic 1 if a carry from the eighth bit has occurred or cleared to logic 0 if no carry occurred as the result of arithmetic operations.

The Carry Bit may be set or cleared under program control by use of the Set Carry (SEC) or Clear Carry (CLC) instruction, respectively. Other operations which affect the Carry Bit are ADC, ASL, CMP, CPX, CPY, LSR, PLP, ROL, ROR, RTI, and SBC.

\subsection*{3.10.2 ZERO BIT (Z)}

The Zero Bit ( \(Z\) ) is set to logic 1 by the CPU during any data movement or calculation which sets all 8 bits of the result to zero. This bit is cleared to logic 0 when the resultant 8 bits of a data movement or calculation operation are
not all zero. The R6500 instruction set contains no instruction to specifically set or clear the Zero Bit. The Zero Bit is, however, affected by the following instructions: ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TXA, TSX, and TYA.

\subsection*{3.10.3 INTERRUPT DISABLE BIT (I)}

The Interrupt Disable Bit (I) is used to control the servicing of an interrupt request (IRQ). If the I Bit is reset to logic 0 , the \(\overline{\mathrm{RQ}}\) signal will be serviced. If the bit is set to logic 1 , the \(\overline{\mathrm{RQ}}\) signal will be ignored. The CPU will set the Interrupt Disable Bit to logic 1 if a RESET ( \(\overline{\mathrm{RES}}\) ) or NonMaskable Interrupt ( \(\overline{\mathrm{NMI}}\) ) signal is detected.

The I bit is cleared by the Clear Interrupt (CLI) instruction, the Pull Processor Status from Stack (PLP) instruction, or as the result of executing a Return from Interrupt (RTI) instruction (providing the Interrupt Disable Bit was cleared prior to the interrupt). The Interrupt Disable Bit may be set or cleared under program control using a Set Interrupt Disable (SEI) or a Clear Interrupt Disable (CLI) instruction, respectively.


Figure 3-3. Processor Status Register

\subsection*{3.10.4 DECIMAL MODE BIT (D)}

The Decimal Mode Bit (D), is used to control the arithmetic mode of the CPU. When this bit is set to logic 1 , the adder operates as a decimal adder. When this bit is cleared to logic 0 , the adder operates as a straight binary adder. The adder mode is controlled only by the programmer. The Set Decimal Mode (SED) instruction will set the D bit; the Clear Decimal Mode (CLD) instruction will clear it. The PLP and RTI instructions also effect the Decimal Mode Bit.

\section*{CAUTION}

The Decimal Mode Bit will either set or clear in an unpredictable manner upon power application to R6500/1. This bit must be initialized to the desired state by the user program or erroneous results may occur.

\subsection*{3.10.5 BREAK BIT (B)}

The Break Bit (B) is used to determine the condition which caused the \(\overline{\mathrm{RQ}}\) service routine to be entered. If the \(\overline{\mathrm{RQ}}\) service routine was entered because the CPU executed a BRK command, the Break Bit will be set to logic 1. If the \(\overline{I R Q}\) routine was entered as the result of an IRQ signal being generated, the B bit will be cleared to logic 0 . There are no instructions which can set or clear this bit.

\subsection*{3.10.6 OVERFLOW BIT (V)}

The Overflow Bit ( V ) is used to indicate that the result of a signed, binary addition, or subtraction, operation is a value that cannot be contained in seven bits \((-128 \leqslant n \leqslant\) 127). This indicator only has meaning when signed arithmetic (sign and seven magnitude bits) is performed. When the ADC or SBC instruction is performed, the Overflow Bit is set to logic 1 if the polarity of the sign bit (bit 7) is changed because the result exceeds +127 or -128 ; otherwise the bit is cleared to logic 0 . The V bit may also be cleared by the programmer using a Clear Overflow (CLV) instruction.

The Overflow Bit may also be used with the BIT instruction. The BIT instruction which may be used to sample interface devices, allows the overflow flag to reflect the condition of bit 6 in the sampled field. Duriing a BIT instruction the Overflow Bit is set equal to the content of the bit 6 on the data tested with BIT instruction. When used in this mode, the overflow has nothing to do with signed arithmetic, but is just another sense bit for the microprocessor. Instructions which affect the V flag are ADC, BIT, CLV, PLP, RTI and SBC.

\subsection*{3.10.7 NEGATIVE BIT (N)}

The Negative Bit ( N ) is used to indicate that the sign bit (bit 7), in the resulting value of a data movement or data arithmetic operation, is set to logic 1 . If the sign bit is set to logic 1, the resulting value of the data movement or
arithmetic operation is negative; if the sign bit is cleared, the result of the data movement or arithmetic operation s positive. There are no instructions that set or clear the Negative Bit since the Negative Bit represents only the status of a result. The instructions that effect the state of the Negative Bit are: ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TSX, TXA, and TYA.

\subsection*{3.11 \(\mathbf{2 K} \times 8\) ROM}

The R6500/1 2048 byte \(\times 8\)-bit Read Only Memory (ROM) usually contains the user's program instructions and other fixed constants. These program instructions and constants are mask-programmed into the ROM during fabrication of the R6500/1 device. The R6500/1 ROM is memory mapped from 800 to FFF.

\section*{\(3.1264 \times 8\) RAM}

The 64 byte \(\times 8\)-bit Random Access Memory (RAM) contains the user program stack and is used for scratchpad memory during system operation. This RAM is completely static in operation and requires no clock or dynamic refresh. The data contained in RAM is read out nondestructively with the same polarity as the input data. A standby power pin, VRR allows RAM memory to be maintained on \(10 \%\) of the operating power. In the event that VCC power is lost and execution stops, this standby power retains RAM data until execution resumes.

In order to take advantage of zero page addressing capabilities, the R6500/1 RAM is assigned page zero memory address 0 to 03F.

\subsection*{3.13 CONTROL REGISTER}

The Control Register (CR), shown in Figure 3-4, is located at address 08 F . The CR contains five control signals and three status signals.

The control signals are summarized in Table 3-1. The control signals are set to logic 1 by writing logic 1 into the respective bit positions and cleared to logic 0 either by writing logic 0 into the respective bit position or by the occurrence of a \(\overline{\mathrm{RES}}\) signal.

Table 3-1. CR Control Signals
\begin{tabular}{|l|c|}
\hline \multicolumn{1}{|c|}{ Control Signal Name } & \begin{tabular}{c} 
Bit \\
Number
\end{tabular} \\
\hline Counter Mode Control 0 (CMC0) & 0 \\
Counter Mode Control 1 (CMC1) & 1 \\
PA1 Interrupt Enabled (A1IE) & 2 \\
PA0 Interrupt Enabled (AOIE) & 3 \\
Counter Interrupt Enabled (CIE) & 4 \\
\hline
\end{tabular}

The three status signals are summarized in Table 3-2.


Figure 3-4. Control Register (CR)

Table 3-2. CR Status Signals
\begin{tabular}{|l|c|}
\hline \multicolumn{1}{|c|}{ Status Signal Name } & \begin{tabular}{c} 
Bit \\
Number
\end{tabular} \\
\hline PA1 Negative Edge Detected (A1ED) & 5 \\
PAO Positive Edge Detected (A0ED) & 6 \\
Counter Overflow (CTRO) & 7 \\
\hline
\end{tabular}

The status signals are read-only information. The status bits are set to logic 1 by hardware monitoring logic and cleared to logic 0 by the occurrence of \(\overline{R E S}\) signal or by specific address commands. Each of these signals is described in the following sections.

\subsection*{3.13.1 COUNTER MODE CONTROL 0 AND 1}

Counter Mode Control signals CMCO and CMC1 (bits 0 and 1) control the Counter operating modes. The modes of operation and the corresponding configuration of CMCO and CMC1 are summarized in Table 3-3.

These modes are controlled by writing the appropriate bit values into the Counter Mode Control bits.

Table 3-3. Counter Mode Control Selection
\begin{tabular}{|c|c|l|}
\hline \begin{tabular}{c} 
CMC1 \\
(Bit 1)
\end{tabular} & \begin{tabular}{c} 
CMC0 \\
(Bit 0)
\end{tabular} & \multicolumn{1}{|c|}{ Mode } \\
\hline 0 & 0 & Interval Timer \\
0 & 1 & Pulse Generator \\
1 & 0 & Event Counter \\
1 & 1 & Pulse Width Measurement \\
\hline
\end{tabular}

The Counter is set to the Interval Timer Mode (00) when a \(\overline{\mathrm{RES}}\) signal is generated or if the user program stores logic 0 into Bits 0 and 1 of the Control Register. A complete description of each of the Counter modes is given in Section 3.14.1.

\subsection*{3.13.2 PA1 INTERRUPT ENABLE BIT (A1IE)}

If the PA1 Interrupt Enable Bit (CR2) is set to logic 1, an \(\overline{\mathrm{IRQ}}\) interrupt request signal will be generated when the PA1 Negative Edge Detected Bit (CR5) is set.

\subsection*{3.13.3 PAO INTERRUPT ENABLE BIT (AOIE)}

If the PAO Interrupt Enable Bit (CR3) is set to logic 1, the \(\overline{I R Q}\) interrupt request signal will be generated when the PAO Positive Edge Detected Bit (CR6) is set.

\subsection*{3.13.4 COUNTER INTERRUPT ENABLE BIT (CIE)}

If the Counter Interrupt Enable Bit (CR4) is set to logic 1, the \(\overline{\mathrm{RQ}}\) interrupt request signal will be generated when Counter Overflow (CR7) is set.

\subsection*{3.13.5 PA1 NEGATIVE EDGE DETECTED BIT (A1ED)}

The PA1 Negative Edge Detected Bit (CR5) is set to logic 1 whenever a negative (falling) edge is detected on PA1. This bit is cleared to logic 0 by \(\overline{\operatorname{RES}}\) or by writing to address 08A.

The edge detecting circuitry is active when PA1 is used either as an input or as an output. When PA1 is used as an output, A1ED will be set when the negative edge is detected during a logical 1 to 0 transition.

When PA1 is used as an input and the negative edge detecting circuitry is used, A1ED should be cleared by the user program upon initialization and when the PA1 Negative Edge Detected IRQ processing is completed.

\subsection*{3.13.6 PAO POSTIIVE EDGE DETECTED BIT (AOED)}

The PAO Positive Edge Detected Bit (CR6) is set to logic 1 whenever a positive (rising) edge is detected on PAO. The bit is cleared to logic 0 by \(\overline{\text { RES }}\) or by writing to address 089.

The edge detecting circuitry is active when PAO is used either as an input or as an output. When PAO is used as an output, AOED will be set when the positive edge is detected during a logical 0 to 1 transition.

When PAO is used as an input and the positive edge detecting circuitry is used, AOED should be cleared by the user program upon initialization and upon completion of PAO Positive Edge Detected \(\overline{\mathrm{RQ}}\) processing.

\subsection*{3.13.7 COUNTER OVERFLOW BIT (CTRO)}

The Counter Overflow Bit (CR7) is set to logic 1 whenever a counter overflow occurs in any of the four counter operating modes. Overflow occurs when the counter is decremented one count from 0000. This bit is cleared to logic 0 by \(\overline{R E S}\) or by reading from address 087 or writing to address 088.

This bit should be cleared by the user program upon initialization and upon completion of Counter Overflow \(\overline{\mathrm{RQ}}\) interrupt processing.

When a Counter Overflow occurs, the Upper Count (UC) in address 086 and the Lower Count (LC) in address 087 are reset to
the values contained in the Upper Latch (UL) in address 084 and in the Lower Latch (LL) in address 085, respectively. Therefore, it is important to load the Lower Latch value prior to executing the Write to Upper Latch and Transfer Latch to Counter (address 088) in order to prevent an unpredicted reoccurrence of Counter Overflow and, if enabled, an \(\overline{\mathrm{RQ}}\) interrupt request.

\subsection*{3.14 COUNTER/LATCH}

The Counter/Latch consists of a 16 -bit Counter and a 16 -bit Latch. The Counter resides in two 8 -bit registers: address 086 contains the Upper Count value (bits \(8-15\) of the Counter) and address 087 contains the Lower Count value (bits \(0-7\) of the Counter). The Counter contains the count of either \(\varnothing 2\) clock periods or external events depending on which counter mode is selected in the Control Register (Section 3.13.1).

The Latch contains the Counter initialization value. The Latch resides in two 8-bit registers: address 084 contains the Upper Latch value (bits \(8-15\) of the Latch) and address 085 contains the Lower Latch value (bits 0-7 of the Latch). The 16 -bit Latch can hold values from 0 to 65535 .

The Latch registers can be loaded at any time by executing a write to the Upper Latch Address (084) and the Lower Latch Address (085). In each case, the contents of the Accumulator are copied into the applicable Latch register. The Upper Latch and Lower Latch can be loaded independently; it is not required to load both registers at the same time or sequentially. The Upper Latch can also be loaded by writing to address 088.

The Counter can be initialized at any time by writing to address 088. The contents of the Accumulator will be copied into the Upper Latch before the value in the Upper Latch is transferred to the Upper Counter.

The Counter will also be initialized to the Latch value whenever the Counter overflows. When the Counter decrements from 0000, the next Counter value will be the Latch value, not FFFF.

Whenever the Counter overflows, the Counter Overflow Bit (CR7) is set to logic 1. This bit is cleared whenever the lower eight bits of the counter are read from address 087 or by writing to address 088 .

\subsection*{3.14.1 COUNTER MODES}

The Counter operates in any of four modes. These modes are selected by the Counter Mode Control bits in the Control Register.
\begin{tabular}{lcc}
\multicolumn{1}{c}{ Mode } & CMC1 & CMC0 \\
Interval Timer & 0 & 0 \\
Pulse Generator & 0 & 1 \\
Event Counter & 1 & 0 \\
Pulse Width Measurement & 1 & 1
\end{tabular}

The Interval Timer, Pulse Generator, and Pulse Width Measurement Modes are \(\varnothing 2\) clock counter modes. The Event Counter Mode counts the occurrences of an external event on the CNTR line.

\section*{Interval Timer (Mode 0)}

In the Interval Timer mode the Counter is initialized to the Latch value by either of two conditions:
1. When the Counter is decremented from 0000, the next Counter value is the Latch value (not FFFF).
2. When a write operation is performed to the Load Upper Latch and Transfer Latch to counter address (088), the Counter is loaded with the Latch value. Note that the contents of the Accumulator are loaded into the Upper Latch before the Latch value is transferred to the Counter.

The Counter value is decremented by one count at the \(\phi 2\) clock rate. The 16 -bit Counter can hold from 1 to 65535 counts. The

Counter Timer capacity is therefore \(1 \mu \mathrm{~s}\) to 65.535 ms at the 1 \(\mathrm{MHz} \emptyset 2\) clock rate or \(0.5 \mu\) s to 32.768 ms at the \(2 \mathrm{MHz} \phi 2\) clock rate. Time intervals greater than the maximum Counter value can be easily measured by counting \(\overline{\mathrm{RQ}}\) interrupt requests in the counter IRQ interrupt routine.

When the Counter decrements from 0000, the Counter Overilow (CR7) is set to logic 1 at the next \(\emptyset 2\) clock pulse. If the Counter Interrupt enable bit (CR4) is also set, an \(\overline{\mathrm{RQ}}\) interrupt request will be generated. The Counter Overflow bit in the Control Register can be examined in the \(\overline{\mathrm{IRQ}}\) interrupt routine to determine that the \(\overline{\mathrm{RQ}}\) was generated by the Counter Overflow.

While the timer is operating in the Interval Timer Mode, the Counter Out/Event line is held in the high (output disabled) state.

A timing diagram of the Interval Timer Mode is shown in Figure 3-5.


Figure 3-5. Interval Timer (Mode 0) Timing Diagram

\section*{Pulse Generator Mode (Mode 1)}

In the Pulse Generator mode, the Counter Out/Event In line (CNTR) operates as a Counter Out. The CNTR line toggles from low to high or from high to low whenever a Counter Overflow occurs, or a write is performed to address 088.

Either a symmetric or asymmetric output waveform can be
output on the CNTR line in this mode. The CNTR output is initialized high by a \(\overline{\mathrm{RES}}\) since the Interval Timer mode is established by \(\overline{R E S}\).

A one-shot waveform can be easily generated by changing from Mode 1 Pulse Generator to Mode 0 (Interval Timer) after only one occurrence of the output toggle condition.

\section*{Event Counter Mode (Mode 2)}

In this mode the CNTR line is used as an Event Counter. The Counter will decrement with each rising edge detected on this line. The maximum rate at which this edge can be detected is one-half the \(\emptyset 2\) clock rate.

The Counter can count up to 65,535 occurrences before overflowing. As in the other modes, the Counter Overflow bit (CR7) is set to logic 1 if the overflow occurs.

Figure \(3-6\) is a timing diagram of the Event Counter Mode.
Pulse Width Measurement Mode (Mode 3)
This mode allows the accurate measurement of a low pulse duration on the CNTR line. In this mode, CNTR is used in the Event In capacity. The Counter decrements by one
count at the \(\varnothing 2\) clock rate as long as the CNTR line is held in the low state. The Counter is stopped when CNTR is in the high state.

If the CNTR pin is left disconnected, this mode may be selected to stop the Counter since the internal pull-up device will cause the CNTR input to be in the high ( \(>2.0 \mathrm{~V}\) ) state.

A timing diagram for the Pulse Width Measurement Mode is shown in Figure 3-7.

\subsection*{3.15 INPUT/OUTPUT PORTS}

The R6500/1 provides four 8-bit Input/Output (I/O) ports (PA, PB, PC, PD). These 32 I/O lines are completely bidirectional. All lines may be used either for input or output in any combination; that is, there are no line grouping or port association restrictions.


Figure 3-6. Event Counter Mode (Mode 2)


Figure 3-7. Pulse Width Measurement (Mode 3)

The direction of the 32 I/O lines are controlled by four 8 -bit port registers located in page zero. This arrangement provides quick programming access using simple two-byte zero page address instructions. There are no direction registers associated with the I/O ports, which simplifies I/O handling. The I/O addresses are shown in Table 3-4.

Table 3-4. I/O Port Addresses
\begin{tabular}{|c|c|}
\hline Port & Address \\
\hline A & 080 \\
B & 081 \\
C & 082 \\
D & 083 \\
\hline
\end{tabular}

Figure \(3-8\) shows the I/O Port Timings.

\subsection*{3.15.1 INPUTS}

Inputs are enabled by loading logic 1 into all I/O port register bit positions that are to correspond to I/O input lines. A low ( \(<0.8 \mathrm{~V}\) ) input signal will cause a logic 0 to be read when a read instruction is issued to the port register. A high ( \(>2.0 \mathrm{~V}\) ) input will cause a logic 1 to be read. An \(\overline{\text { RES }}\) signal forces all I/O port registers to logic 1 thus initially treating all I/O lines as inputs.

The status of the input lines can be interrogated at any time by reading the \(1 / O\) port addresses. Note that this will return the actual status of the input lines, not the data written into the I/O port registers.

\subsection*{3.15.2 OUTPUTS}

Outputs are controlled by writing the desired I/O line output states into the corresponding I/O port register bit positions. A logic 1 will force a high ( \(>2.4 \mathrm{~V}\) ) output while a logic 0 will force a low ( \(<0.4 \mathrm{~V}\) ) output.

\subsection*{3.15.3 EDGE DETECTION CAPABILITY}

Ports PAO and PA1 have an edge detection capability. Figure 3-9 shows the edge detection timing.

\section*{PAO Positive Edge Detecting Capability}

In addition to its normal I/O function, PAO will detect an asynchronous positive (rising) edge signal and set the PAO Positive Edge Detected signal (CR6) to logic 1. The maximum rate at which this positive edge can be detected is one-half the \(\varnothing 2\) clock rate.

If the PAO Interrupt Enable Bit (CR3) is set, an \(\overline{\mathrm{RQ}}\) interrupt request will also be generated. The PAO Positive Edge Detected signal can be cleared by writing to address 089.


Figure 3-8. I/O Port Timing


Figure 3-9. PA0 and PA1 Edge Detection Timing

\section*{PA1 Negative Edge Detecting Capability}

In addition to its normal I/O function, PA1 will detect an asynchronous negative (falling) edge signal and set the PA1 Negative Edge Detected signal (CR5) to logic 1. The maximum rate at which this negative edge can be detected is one-half the \(\varnothing 2\) clock rate.

If the PA1 Interrupt Enable signal (CR2) is set, an \(\bar{R} \bar{Q}\) interrupt request will also be generated. The PA1 Negative Edge Detected signal may be cleared by writing to address 08A.

\subsection*{3.16 MASK OPTIONS}

An option is provided to delete the internal pull-up resistance from \(\mathrm{PA}, \mathrm{PB}, \mathrm{PC}\) and/or PD ports at mask time. This option is available for 8-bit port groups only, not for individual port lines. This option may by used to aid interface with CMOS drivers, or in order to interface with external pull-up devices.

An option is also provided to delete the internal pull-up resistance on the CNTR line.

\section*{SECTION 4 \\ IRQ INTERRUPT REQUEST GENERATION}

An \(\overline{\mathrm{RQ}}\) interrupt request can be initiated by any or all of three possible sources. These sources are all capable of being enabled or disabled by the use of the appropriate interrupt enabled bits in the Control Register.

The first source of \(\overline{\mathrm{IRQ}}\) is Counter Overflow. The \(\overline{\mathrm{IRQ}}\) interrupt request will be driven low whenever both the Counter Interrupt Enable (CR4) and the Counter Overflow (CR7) are logic 1.

The second source of \(\overline{\mathrm{RQ}}\) is detection of a positive edge on PAO. The \(\overline{\mathrm{RQ}}\) inerrupt request will be driven low whenever both the PAO Interrupt Enable (CR3) and the PAO Positive Edge Detected (CR6) are logic 1.

The third source of \(\overline{\mathrm{IRQ}}\) is detection of a negative edge on PA1. The \(\overline{\mathrm{RQ}}\) interrupt request will be driven low whenever both the PA1 Interrupt Enable (CR2) and the PA1 Negative Edge Detected (CR5) are logic 1.

Multiple simultaneous interrupts will cause the \(\overline{\mathrm{RQ}}\) interrupt request to remain active until all interrupting conditions have been serviced and cleared.

\section*{CAUTION}

If the same data, i.e., the same RAM, counter/latch or I/O addresses, are operated on asynchronously by a normal processing routine and by an interrupt service routine, care must be taken to prevent loss of data due to the interrupt routine altering the data during update of the data by the normal processing routine. This situation can be prevented by disabling the \(\overline{\mathrm{IRQ}}\) interrupt with the SEI instruction before starting the data update in the normal processing and then enabling the interrupt with the CLI instruction upon completion of data update.

\title{
SECTION 5 \\ POWER ON/OFF CONSIDERATIONS
}

\subsection*{5.1 POWER-ON RESET}

The occurrence of \(\overline{\mathrm{RES}}\) going from low to high will cause the R6500/1 to set the Interrupt Mask Bit - bit 2 of the Processor Status Register - and initiate a reset vector fetch at address FFE and FFF to begin user program execution. All of the I/O ports (PA, PB, PC, and PD) and CNTR will be forced to the high (logic 1) state. All bits of the Control Register will be cleared to logic 0 causing the Interval Timer counter mode (mode 00 ) to be selected and causing all interrupt enabled bits to be reset.

\subsection*{5.2 POWER ON/OFF TIMING}

After application of VCC power to the R6500/1, \(\overline{\text { RES }}\) must be held low for at least eight \(\varnothing 2\) clock cycles after VCC reaches operating range and the internal clock oscillator has stabilized. This stabilization time is dependent upon the input VCC voltage and performance of the crystal, clock, or RC network input circuit. The clock oscillator output can be monitored on XTLO (pin 11).

Figure 5-1 illustrates the power turn-on waveforms.

\subsection*{5.3 RAM DATA RETENTION — VRR REQUIREMENTS}

For the RAM to retain data upon loss of VCC, VRR must be supplied within operating range and \(\overline{\text { RES }}\) must be driven
low at least eight \(\phi 2\) clock pulses before VCC falls out of operating range. \(\overline{\operatorname{RES}}\) must then be held low while VCC is out of operating range and until at least eight \(\varnothing 2\) clock cycles after VCC is again within operating range and the internal \(\emptyset 2\) oscillator is stabilzed. VRR must remain within VCC operation range during normal R6500/1 operation. When VCC is out of operating range, VRR must remain within the VRR retention range in order to retain data. Figure 5-2 shows typical waveforms.

\subsection*{5.4 RAM DATA RETENTION OPERATION}

The requirement for R6500/1 RAM data retention and restart operation is application dependent. If R6500/1 RAM data retention is not required during loss of VCC, then VRR can be connected to the same power source as VCC. With this configuration a complete initialization of R6500/1 program variables in RAM is required upon VCC and VRR power application.

If the R6500/1 RAM is to retain data during loss of VCC, the following is required:
1. Connection of VCC and VRR to separate power supplies or to the same primary power supply with isolation diodes and battery or other backup power for VRR.
2. VCC power monitor hardware with power loss and cold/warm start indications to the R6500/1.
3 Power loss detection as well as cold and warm start initialization in the R6500/1 program.


Figure 5-1. Power Turn-On Timing Detail

(4) \(\geqslant 8 \phi 2\) CLOCK PULSES AFTER \(\phi 2\) OSCILLATOR STABILIZATION.
(5) \(\geqslant 8\) \(\phi 2\) CLOCK PULSES.

Figure 5-2. RAM Retention Mode Timing

The power monitor hardware must sense the loss of VCC power in sufficient time to allow the R6500/1 to save required CPU register data in RAM. The power loss indication line can be connected to the \(\overline{\mathrm{NMI}}\) interrupt input in order to cause an immediate R6500/1 interrupt upon power loss detection.

The power monitor hardware should also provide an indication of cold start (initial VCC and VRR power application) or warm start (VCC power re-application while VRR is retained on backup power) provided as input on a data I/O pin.

A level indication is sufficient. The R6500/1 program can then initialize all, or partial, program variables upon initialization then jump to any other starting address as required
depending upon cold/warm start condition.

Upon power loss detection, the R6500/1 should save all required CPU register data in either the stack or dedicated RAM. The stack may be preferred if dedicated RAM is not available. If the program is to restart at the interrupted address, then all CPU registers must be saved, i.e., S, P, PC, A, X, and Y. The stack pointer must be saved in a dedicated RAM address. Note that processor status \(P\) and the program counter, PC , are already saved on the stack by the NMI interrupt R6500/1 hardware processing. If the warm start can be performed at a specific address, then the saving of the register data at power loss detection may not be required. Figure 5-3 shows top level flowcharts of typical power down and power-up processing.


Figure 5-3. Typical R6500/1 Power Loss Recovery Flowcharts

\section*{APPENDIX A - SYSTEM MEMORY MAP}
\begin{tabular}{|c|c|c|}
\hline & & HEX \\
\hline \multicolumn{3}{|l|}{IRQ Vector High} \\
\hline \multicolumn{3}{|l|}{IRQ Vector Low} \\
\hline \multicolumn{3}{|l|}{RES Vector High \(\quad\) FFD} \\
\hline \multicolumn{3}{|l|}{RES Vector Low} \\
\hline \multicolumn{3}{|l|}{NMI Vector High \(\quad\) FFB} \\
\hline \multicolumn{3}{|l|}{NMI Vector Low FFA} \\
\hline \multicolumn{3}{|c|}{\begin{tabular}{l|l} 
User Program & FF9 \\
\\
800
\end{tabular}} \\
\hline \multicolumn{3}{|c|}{R6500/1E User Program \(\quad \left\lvert\, \begin{aligned} & \text { 7FF } \\ & 400\end{aligned}\right.\)} \\
\hline \multicolumn{3}{|c|}{Unassigned 3 FF} \\
\hline \multicolumn{3}{|l|}{Control Register 08} \\
\hline \multicolumn{3}{|c|}{Unassigned} \\
\hline \multicolumn{3}{|l|}{Clear PA1 Neg Edge Detected (Write Only) (1) 08A} \\
\hline \multicolumn{3}{|l|}{Clear PAO Pos Edge Detected (Write Only) 08} \\
\hline \multicolumn{3}{|l|}{} \\
\hline \multicolumn{3}{|l|}{Lower Count (Read Only) (2) 087 \% Input/Output} \\
\hline \multicolumn{3}{|l|}{\begin{tabular}{l|l|l} 
Upper Count (Read Only) & 086
\end{tabular}} \\
\hline \multicolumn{3}{|l|}{Lower Latch (Write Only) 085} \\
\hline Upper Latch (Write Only) & 084 & \\
\hline PORT D & 083 & \\
\hline PORT C & 082 & \\
\hline PORT B & 081 & \\
\hline \multicolumn{3}{|l|}{PORT A 080} \\
\hline \multicolumn{3}{|l|}{Unassigned} \\
\hline User RAM & & RAM \\
\hline
\end{tabular}

Notes:
(1) I/O command only; i.e., no stored data.
(2) Clears Counter Overflow - Bit 7 in Control Register.

\section*{APPENDIX B - R6500 INSTRUCTION SET}

This appendix contains a summary of the R6500 instruction set. For detailed information, consult the R6500 Microcomputer System Programming Manual, Document Order No. 202.

\section*{B. 1 INSTRUCTION SET IN ALPHABETIC SEQUENCE}
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Description & Mnemonic & Description \\
\hline ADC & Add Memory to Accumulator with Carry & LDA & Load Accumulator with Memory \\
\hline AND & "AND" Memory with Accumulator & LDX & Load Index X with Memory \\
\hline ASL & Shift Left One Bit (Memory or Accumulator) & LDY & Load Index Y with Memory \\
\hline & & LSR & Shift One Bit Right (Memory or Accumulator) \\
\hline BCC & Branch on Carry Clear & & \\
\hline BCS & Branch on Carry Set & NOP & No Operation \\
\hline BEQ & Branch on Result Zero & & \\
\hline BIT & Test Bits in Memory with Accumulator & ORA & "OR" Memory with Accumulator \\
\hline BMI & Branch on Result Minus & & \\
\hline BNE & Branch on Result not Zero & PHA & Push Accumulator on Stack \\
\hline BPL & Branch on Result Plus & PHP & Push Processor Status on Stack \\
\hline BRK & Force Break & PLA & Pull Accumulator from Stack \\
\hline BVC & Branch on Overflow Clear & PLP & Pull Processor Status from Stack \\
\hline BVS & Branch on Overflow Set & ROL & Rotate One Bit Left (Memory or Accumulator) \\
\hline CLC & Clear Carry Flag & ROR & Rotate One Bit Right (Memory or Accumulator) \\
\hline CLD & Clear Decimal Mode & RTI & Return from Interrupt \\
\hline CLI & Clear Interrupt Disable Bit & RTS & Return from Subroutine \\
\hline CLV & Clear Overflow Flag & & \\
\hline CMP & Compare Memory and Accumulator & SBC & Subtract Memory from Accumulator with Borrow \\
\hline CPX & Compare Memory and Index \(X\) & SEC & Set Carry Flag \\
\hline CPY & Compare Memory and Index Y & SED & Set Decimal Mode \\
\hline & & SEI & Set Interrupt Disable Status \\
\hline DEC & Decrement Memory by One & STA & Store Accumulator in Memory \\
\hline DEX & Decrement Index \(X\) by One & STX & Store Index X in Memory \\
\hline DEY & Decrement Index Y by One & STY & Store Index \(Y\) in Memory \\
\hline EOR & "Exclusive-Or" Memory with Accumulator & TAX & Transfer Accumulator to Index X \\
\hline & & TAY & Transfer Accumulator to Index Y \\
\hline INC & Increment Memory by One & TSX & Transfer Stack Pointer to Index X \\
\hline INX & Increment Index \(X\) by One & TXA & Transfer Index \(X\) to Accumulator \\
\hline INY & Increment Index Y by One & \[
\begin{aligned}
& \text { TXS } \\
& \text { TYA }
\end{aligned}
\] & Transfer Index X to Stack Register Transfer Index \(Y\) to Accumulator \\
\hline JMP
JSR & Jump to New Location Jump to New Location Saving Return Address & & \\
\hline
\end{tabular}

B2. INSTRUCTION SET SUMMARY TABLE
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multicolumn{2}{|r|}{instructions} & \multicolumn{3}{|l|}{Immediate} & \multicolumn{3}{|l|}{ABSOLIITE} & \multicolumn{3}{|l|}{zeropage} & \multicolumn{3}{|c|}{accum} & \multicolumn{3}{|c|}{IMPLIEO} & \multicolumn{3}{|l|}{(INO. X)} & \multicolumn{3}{|l|}{} & \multicolumn{2}{|l|}{2 Page, x} & \multicolumn{3}{|l|}{} & \multicolumn{2}{|l|}{ABS, Y} & \multicolumn{3}{|l|}{belative} & \multicolumn{2}{|l|}{InOIRECT} & \multicolumn{3}{|r|}{2 Page, y} & \multicolumn{2}{|l|}{processor status CODES} \\
\hline MNEMONIC & operation & OP & n & * & OP & \(n\) & * & OP & \(n\) & " & OP & n & " & OP & n & * & OP & \(n\) & 0 & OP & " & 0 & OP & n 1 & 1 OP & n & \(\cdots\) & OP & \(n\) " & OP & \(\bigcirc\) & * 0 & OP & \(n\) & OP & n & " &  & MNEMONIC \\
\hline \begin{tabular}{l}
A OC \\
AND \\
ASL \\
BCC \\
BCS
\end{tabular} & \[
\begin{array}{lr}
\hline A+M+C \sim A & \text { (4) (1) } \\
A A M \rightarrow A & \text { (1) } \\
C-\sqrt{B}-0 \\
\text { BRANCHONC }=0 & \text { (2) } \\
\text { BRANCHONC }=1 & \text { (2) } \\
\hline
\end{array}
\] & 69
29 & \[
\begin{aligned}
& 2 \\
& 2
\end{aligned}
\] & & \[
\left|\begin{array}{l}
60 \\
20 \\
0 E
\end{array}\right|
\] & 4
4
6 & 3
3
3 & 65
25
06 & 3
3
5 & \[
\left.\begin{aligned}
& 2 \\
& 2 \\
& 2
\end{aligned} \right\rvert\,
\] & 0A & 2 & 1 & & & & & & & & & \[
\begin{array}{l|l}
\hline 2 & 75 \\
2 & 35 \\
& 16
\end{array}
\] & \[
\begin{aligned}
& 75 \\
& 35 \\
& 16
\end{aligned}
\] & \begin{tabular}{l|l|l}
4 & 2 \\
4 & 2 \\
6 & 2
\end{tabular} & \begin{tabular}{|c|c|}
\hline 2 & 70 \\
30 \\
& \\
\hline 15
\end{tabular} & 4
4
7 & 3
3
3 & & \begin{tabular}{l|l|l|}
4 & 3 \\
4 & 3
\end{tabular} & 90 & \[
\begin{aligned}
& 2 \\
& 2
\end{aligned}
\] & 2 & & & & & &  & \begin{tabular}{l}
ADC \\
ANO \\
ASL \\
BCC \\
BCS
\end{tabular} \\
\hline \[
\begin{aligned}
& \text { BEO } \\
& \text { BIT } \\
& \text { BMI } \\
& \text { BNE } \\
& \text { BPL }
\end{aligned}
\] & \begin{tabular}{l}
BRANCHONZ \(=1\) (2) \\
A^M \\
BRANCHONN=1 (2) \\
BFANCHONZ \(=0 \quad\) (2) \\
BRANCHONN=0 (2)
\end{tabular} & & & & 2 C & 4 & 3 & 24 & 3 & 2 & & & & & & & & & & & & & & & & & & & &  & 2 & \[
2
\] & & & & & & \[
M_{1} M_{6} \cdot \cdots \cdot Z
\] & \begin{tabular}{l}
BEO \\
B I T \\
BMI \\
BNE \\
BPL
\end{tabular} \\
\hline \[
\begin{aligned}
& \text { BRK } \\
& \text { BVC } \\
& \text { BVS } \\
& C L C \\
& C L D \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { BREAK } \\
& \text { BRANCH ONV }=0 \quad \text { (2) } \\
& \text { BRANCHONV = } 1 \quad \text { (2) } \\
& 0 \rightarrow C \\
& 0 \rightarrow 0
\end{aligned}
\] & & & & & & & & & & & & & \[
\begin{array}{|c|}
\hline 00 \\
18 \\
08
\end{array}
\] & & \begin{tabular}{l}
1 \\
1 \\
\hline 1
\end{tabular} & & & & & & & & & & & & & & 50
70 & 2 & 2 & & & & & &  & \[
\begin{aligned}
& \text { BRK } \\
& B \vee C \\
& B \vee S \\
& C L C \\
& C L O
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& C L I \\
& C L V \\
& C M P \\
& C P X \\
& C P Y
\end{aligned}
\] & \[
\begin{aligned}
& 0-i \\
& 0 \rightarrow V \\
& A-M \\
& X-M \\
& Y-M
\end{aligned}
\] & c9
E0
CO & 2 & \begin{tabular}{l}
2 \\
2 \\
2 \\
\hline
\end{tabular} & \[
\begin{aligned}
& \mathrm{CD} \\
& \mathrm{EC} \\
& \mathrm{CC}
\end{aligned}
\] & 4 & \[
\begin{aligned}
& 3 \\
& 3 \\
& 3 \\
& \hline
\end{aligned}
\] & C5 & \[
\begin{aligned}
& 3 \\
& 3 \\
& 3
\end{aligned}
\] & \[
\begin{aligned}
& 2 \\
& 2 \\
& 2 \\
& \hline
\end{aligned}
\] & & & & \[
\left|\begin{array}{l}
58 \\
88
\end{array}\right|
\] & 2 & 1 & C1 & 6 & 2 & 01 & 2 & DS & D5 & 42 & 200 & 4 & 3 & 09 & 3 & & & & & & & & &  & \[
\begin{aligned}
& C \mathrm{LI} \\
& C \mathrm{LV} \\
& C M P \\
& C P X \\
& C P Y \\
& \hline
\end{aligned}
\] \\
\hline \[
\begin{align*}
& \text { DEC }  \tag{1}\\
& \text { DEX } \\
& \text { DEY } \\
& \text { EOR } \\
& \text { INC }
\end{align*}
\] & \[
\begin{aligned}
& M-1 \rightarrow M \\
& X-1 \rightarrow X \\
& Y-1 \rightarrow Y \\
& A \forall M \rightarrow A \\
& M+1 \rightarrow M
\end{aligned}
\] & 49 & 2 & 2 & \[
\begin{array}{|c|}
\hline \mathrm{CE} \\
\hline \mathrm{ED} \\
\hline
\end{array}
\] & \[
6
\] & \[
\begin{aligned}
& 3 \\
& 3 \\
& 3 \\
& 3
\end{aligned}
\] &  & \[
\begin{aligned}
& 5 \\
& 3 \\
& 5
\end{aligned}
\] & \[
\begin{aligned}
& 2 \\
& 2 \\
& 2
\end{aligned}
\] & & & & CA & 2 & 1
1 & 41 & 6 & 2 & 51 & 52 & D & \[
\begin{aligned}
& \text { D6 } \\
& 55 \\
& \text { F6 }
\end{aligned}
\] & \[
\begin{array}{l|l}
6 & 2 \\
& \\
4 & 2 \\
6 & 2
\end{array}
\] & \[
\begin{array}{l|l|l|}
\hline 2 & \mathrm{OE} \\
2 & & \\
2 & \mathrm{SO} \\
2 & \mathrm{FE} \\
\hline
\end{array}
\] & 7
4
7 & \[
\begin{array}{|l|}
\hline 3 \\
3 \\
3 \\
3 \\
\hline
\end{array}
\] & 59 & 43 & & & & & & & & & \(\begin{array}{llllllll}N & \cdot & \cdot & \cdot & \cdot & 2 & \cdot \\ N & \cdot & \cdot & \cdot & \cdot & \cdot & 2 & \cdot \\ N & \cdot & . & . & \cdot & 2 & \cdot \\ N & \cdot & \cdot & \cdot & \cdot & \cdot & 2 & \cdot \\ N & \cdot & . & . & . & 2 & \end{array}\) & \begin{tabular}{l}
DEC \\
DEX \\
DEY \\
EOR \\
INC
\end{tabular} \\
\hline \[
\begin{aligned}
& \text { INX } \\
& \text { INY } \\
& \text { JMP } \\
& \text { JSR } \\
& \text { LDA } \\
& \hline
\end{aligned}
\] & \begin{tabular}{l}
\[
\begin{aligned}
& x+1 \rightarrow x \\
& y+1 \rightarrow y
\end{aligned}
\] \\
JUMP TO NEW LOC \\
JUMP SUB
\[
M \cdots A
\]
\end{tabular} & A9 & 2 & 2 & \begin{tabular}{|c|}
\(4 C\) \\
20 \\
\(A D\) \\
\hline
\end{tabular} & \[
\begin{aligned}
& 3 \\
& 6 \\
& 4 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& 3 \\
& 3 \\
& 3 \\
& \hline
\end{aligned}
\] & A5 & 3 & 2 & & & & \[
\left|\begin{array}{l}
E 8 \\
C 8
\end{array}\right|
\] & 2 & \({ }^{1}\) & A1 & 6 & 2 & 81 & 52 & B. & 85 & 42 & 2 BD & 4 & 3 & B9 & 3 & & & & 6C & 5 & 3 & & &  & \[
\begin{aligned}
& \text { INX } \\
& \text { INY } \\
& \text { JMP } \\
& \text { JSR } \\
& \text { LDA } \\
& \hline
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& \text { LDX } \\
& \text { LDY } \\
& \text { LSA } \\
& \text { NOP } \\
& \text { ORA }
\end{aligned}
\] & \begin{tabular}{l}
\(M \rightarrow X\) \\
(1) \\
\(M \cdot Y\) \\
(1)
\[
0 \rightarrow\left[\begin{array}{c}
{[ }
\end{array}\right]-c
\] \\
NO OPERATION
\[
A \vee M \rightarrow A
\]
\end{tabular} & \[
\begin{array}{|c}
A 2 \\
A O \\
A 0 \\
09
\end{array}
\] & 2
2
2 & 2
2
2 & \[
\begin{array}{|c}
\mathrm{AE} \\
\mathrm{AC} \\
\mathrm{AE} \\
\mathrm{OD}
\end{array}
\] & \[
\begin{aligned}
& 4 \\
& 4 \\
& 6 \\
& 4
\end{aligned}
\] & \[
\begin{aligned}
& 3 \\
& 3 \\
& 3 \\
& 3
\end{aligned}
\] & \[
\begin{array}{|c|c|}
\hline A 6 \\
\hline A 4 \\
\hline 46 \\
\hline & \\
\hline
\end{array}
\] & \[
\begin{aligned}
& 3 \\
& 3 \\
& 5 \\
& 3
\end{aligned}
\] & \[
\begin{aligned}
& 2 \\
& 2 \\
& 2 \\
& 2
\end{aligned}
\] & 4 A & 2 & 1 & EA & 2 & 1 & & 6 & 2 & 11 & 2 & & \[
\begin{aligned}
& 84 \\
& 56 \\
& 15 \\
& \hline
\end{aligned}
\] & \[
\begin{array}{l|l}
4 & 2 \\
6 & 2 \\
& 2 \\
4 & 2 \\
\hline
\end{array}
\] & \begin{tabular}{|c|c|}
2 & BC \\
2 & 5 EE \\
2 & \\
2 & \\
\hline 1 DC
\end{tabular} & 4
7
4 & \[
\begin{aligned}
& 3 \\
& 3 \\
& 3
\end{aligned}
\] & \[
\begin{array}{|c}
8 E \\
19 \\
\hline
\end{array}
\] & \(44_{4}^{4} 3\) & & & & & & 86 & 4 & 2 & \[
\left(\begin{array}{ccccccc}
\mathrm{N} & \cdot & \cdot & \cdot & \cdot & \cdot & z
\end{array} \cdot\right.
\] & \[
\begin{aligned}
& \text { LDX } \\
& \text { LDY } \\
& \text { LSR } \\
& \text { NOP } \\
& \text { ORA }
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& \hline \text { PHA } \\
& \text { PHP } \\
& \text { PLA } \\
& \text { PLP } \\
& \text { ROL }
\end{aligned}
\] &  & & & & 2 E & 6 & 3 & 26 & 5 & 2 & 2 A & \({ }_{2}\) & 1 & \[
\left|\begin{array}{l}
48 \\
08 \\
68 \\
28
\end{array}\right|
\] & \[
\left(\left.\begin{array}{l}
3 \\
3 \\
4 \\
4
\end{array} \right\rvert\,\right.
\] & \[
1
\] & & & & & & & 36 & 6.2 & \(2{ }^{2}\) 3E & 7 & 3 & & & & & & & & & & &  & \[
\begin{aligned}
& P H A \\
& P H P \\
& P L A \\
& P L P \\
& H O L \\
& \hline
\end{aligned}
\] \\
\hline \begin{tabular}{l}
ROR \\
A 1 I \\
R T S \\
SBC \\
SEC \\
SED
\end{tabular} & \begin{tabular}{l}
\[
-\mathrm{C}]
\]
\(\qquad\) \\
RTRN INT \\
RTRN SUB
\[
\begin{aligned}
& A-M-\stackrel{\rightharpoonup}{C} \cdot A \\
& 1 \rightarrow C \\
& 1 \rightarrow D
\end{aligned}
\]
\end{tabular} & E9 & 2 & 2 & \[
{ }_{E D}^{6 E}
\] & 6 & \[
\begin{aligned}
& 3 \\
& 3
\end{aligned}
\] & \[
{ }^{66}
\] & \[
\begin{aligned}
& 5 \\
& 3
\end{aligned}
\] & \[
\begin{aligned}
& 2 \\
& 2
\end{aligned}
\] & 6A & 2 & 1 & \[
\begin{aligned}
& 40 \\
& 60 \\
& 38 \\
& 38
\end{aligned}
\] & \[
\begin{aligned}
& 6 \\
& 6 \\
& 2 \\
& 2
\end{aligned}
\] & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 1 \\
& 1
\end{aligned}
\] & E1 & 6 & 2 & F1 & 52 & \[
\int_{2} \int_{F 5}^{76}
\] & \[
\begin{gathered}
76 \\
\text { F5 }
\end{gathered}
\] & \begin{tabular}{l|l|l}
6 & 2 \\
4 & 2
\end{tabular} & \({ }_{2}^{2}{ }^{2} \mathrm{FE}\) & \({ }^{7}\) & \begin{tabular}{l}
3 \\
3
\end{tabular} & F9 & 43 & & & & & & & & & \(\left(\begin{array}{cccccc}N & \cdot & \cdot & \cdot & Z & C \\ \text { (RESTORED) } \\ \cdot & \cdot & \cdot & \cdot & \cdot & \cdot\end{array} \cdot\right.\). & \begin{tabular}{l}
ROR \\
R TI \\
RTS \\
SBC \\
SEC \\
SED
\end{tabular} \\
\hline \[
\begin{aligned}
& \text { SEE } \\
& \text { STA } \\
& \text { STX } \\
& \text { STY } \\
& \text { TAX } \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& A \rightarrow 1 \\
& A \rightarrow M \\
& X \rightarrow M \\
& Y \rightarrow M \\
& A \rightarrow X
\end{aligned}
\] & & & & \(88 \mathrm{8D}\) & 4
4
4 & 3
3
3 & 85
86
84 & 3
3
3 & 2
2
2 & & & & \[
\begin{array}{|c|}
\hline 78 \\
\\
\hline A A \\
\hline
\end{array}
\] & 2 & 1 & 81.6 & 6 & 2 & 91 & 62 & \(2 . \begin{aligned} & 95 \\ & 98\end{aligned}\) & \[
\begin{aligned}
& 95 \\
& 94
\end{aligned}
\] & \begin{tabular}{l|l}
4 & 2 \\
4 & 2
\end{tabular} & \(2{ }^{2} 90\) & 5 & 3 & 99 & 53 & & & & & & 96 & 4 & 2 & \[
\begin{array}{|ccccccc}
\cdot & \cdot & \cdot & \cdot & 1 & \cdot \\
\cdots & \cdot & \cdot & \cdot & \cdot & \cdot & \cdot \\
\cdots & \cdot & \cdot & \cdots & \cdot & \cdot & \cdot \\
\cdot & \cdot & \cdot & \cdot & \cdot & \cdot & \cdot \\
\mathrm{~N} & \cdot & \cdot & \cdot & \cdot & \cdot & z \\
\hline
\end{array}
\] &  \\
\hline \[
\begin{aligned}
& \text { TAY } \\
& \text { TSY } \\
& \text { TXA } \\
& \text { TXA } \\
& \text { TYA } \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& A \rightarrow Y \\
& S \rightarrow X \\
& X \rightarrow A \\
& X \rightarrow S \\
& Y \rightarrow A \\
& \hline
\end{aligned}
\] & & & & & & & & & & & & & \[
\begin{array}{l|}
\hline A B \\
B A \\
8 A \\
9 A \\
98 \\
\hline
\end{array}
\] & \begin{tabular}{l}
2 \\
2 \\
2 \\
2 \\
2
\end{tabular} & \[
\begin{array}{|l|}
\hline 1 \\
1 \\
1 \\
1 \\
1 \\
\hline
\end{array}
\] & & & & & & & & & & & & & & & & & & & & & & \(\begin{array}{ccccccc}\text { N } & \cdots & \cdot & \cdot & \cdot & 2 & \cdot \\ \mathrm{~N} \cdot & \cdot & \cdot & \cdot & \cdot & 2 & \cdot \\ \mathrm{~N} \cdot & \cdot & \cdot & \cdot & \cdot & 2 & \cdot \\ \cdots & \cdot & \cdot & \cdot & \cdot & \cdot & \cdot\end{array}\) & \begin{tabular}{|l|l|}
\hline TA Y \\
IS \\
TXA \\
TXA \\
TY \\
TYA \\
\hline
\end{tabular} \\
\hline \multicolumn{20}{|c|}{\begin{tabular}{l}
(1) ADD 110 N IF PAGE BOUNDARY IS CROSSED \\
(2) ADD 1 TO N IF BHANCH OCCURS TO SAME PACE \\
ADD 2 TO N IF BRANCH OCCURS TO DIFFERENT PAGE \\
(3) CARRYNOT \(=\) BORROW \\
(4) IFINDECIMAL MODF ZFLAGISINVALID ACCUMULATOR MUST BE CHECKED FOR ZERO RESULT
\end{tabular}} & & Ms & \[
\begin{aligned}
& \text { M } \\
& \text { Ms }
\end{aligned}
\] &  &  & \[
\begin{aligned}
& Y \\
& \text { MULAT } \\
& \text { RY PE } \\
& \text { RY PE }
\end{aligned}
\] & & FECK & \[
\begin{aligned}
& \text { CTIVE } \\
& \text { KPOIN }
\end{aligned}
\] & & RESS & & &  &  & DD SUBTR AND R XCLUS & \begin{tabular}{l}
ACT \\
sive
\end{tabular} & & \begin{tabular}{l}
\(M_{7}\) MEMORY \\
\(M_{0}\) MEMORY \\
n NO.CYCL \\
" NO BYtE
\end{tabular} & \begin{tabular}{l}
BIT 7 \\
BIT 6 \\
ES \\
S
\end{tabular} \\
\hline
\end{tabular}

\section*{APPENDIX C - SYSTEM SPECIFICATIONS}

\section*{MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{RR}}\) & -0.3 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to +7.0 & Vdc \\
\hline \begin{tabular}{l} 
Operating Temperature \\
Commercial \\
Industrial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{c}
\(\mathrm{T}_{\mathrm{L}}\) to \(\mathrm{T}_{\mathrm{H}}\) \\
0 to +70 \\
-40 to +85
\end{tabular} & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\mathrm{STG}}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}
( \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%\) for \(\mathrm{R} 6500 / 1, \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%\) for \(\mathrm{R} 6500 / 1 \mathrm{~A}, \mathrm{~V}_{\mathrm{RR}}=\mathrm{V}_{\mathrm{CC}} ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{A}}=0^{\circ}\) to \(70^{\circ} \mathrm{C}\), unless otherwise specified)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ \({ }^{1}\) & Max & Unit & Test Conditions \\
\hline RAM Standby Voltage (Retention Mode) & \(V_{\text {RR }}\) & 3.5 & - & \(\mathrm{V}_{\mathrm{CC}}\) & V & \\
\hline RAM Standby Current (Retention Mode) Commercial Industrial & \(I_{\text {RR }}\) & - & \[
\begin{aligned}
& 10 \\
& 12
\end{aligned}
\] & - & mA & \\
\hline Input High Voltage All Except XTLI XTLI & \(\mathrm{V}_{\mathrm{IH}}\) & \[
\begin{aligned}
& +2.0 \\
& +4.0 \\
& \hline
\end{aligned}
\] & - & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{cc}} \\
& \mathrm{~V}_{\mathrm{CC}} \\
& \hline
\end{aligned}
\] & v & \\
\hline Input Low Voltage & \(\mathrm{V}_{\text {IL }}\) & -0.3 & - & +0.8 & V & \\
\hline Input Leakage Current \(\overline{R E S}, \overline{N M I}\) & \(\mathrm{I}_{\mathrm{N}}\) & - & \(\pm 1.0\) & \(\pm 2.5\) & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\text {IN }}=0\) to 5.0 V \\
\hline Input Low Current & \(1 / 1\) & - & -1.0 & -1.6 & mA & \(\mathrm{V}_{\mathrm{iL}}=0.4 \mathrm{~V}\) \\
\hline Output High Voltage & \(\mathrm{V}_{\mathrm{OH}}\) & +2.4 & - & - & V & \[
\begin{aligned}
& \mathrm{I}_{\mathrm{LOAD}}=-100 \mu \mathrm{~A} \\
& \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}
\end{aligned}
\] \\
\hline Output High Voltage (CMOS) & \(\mathrm{V}_{\mathrm{CMOS}}\) & \(\mathrm{V}_{\mathrm{CC}}-30 \%\) & - & - & V & \(\mathrm{V}_{\text {CC }}=4.75 \mathrm{~V}\) \\
\hline Output Low Voltage & \(\mathrm{V}_{\text {OL }}\) & - & - & \(+0.4\) & v & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\
& \mathrm{I}_{\mathrm{LOAD}}=1.6 \mathrm{~mA}
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& \text { I/O Port Pull-Up Resistance } \\
& \text { PAO-PA7, PBO-PB7, PC0-PC7, } \\
& \text { PDO-PD7, CNTR }
\end{aligned}
\] & \(\mathrm{R}_{\mathrm{L}}\) & 3.0 & 6.0 & 11.5 & Kohm & \\
\hline Output High Current (Sourcing) & \(\mathrm{I}_{\mathrm{OH}}\) & -100 & - & - & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\text {OUT }}=2.4 \mathrm{~V}\) \\
\hline Output Low Current (Sinking) & \(\mathrm{l}_{\mathrm{OL}}\) & 1.6 & - & - & mA & \(\mathrm{V}_{\text {OUT }}=0.4 \mathrm{~V}\) \\
\hline Input Capacitance XTLI, XTLO PA, PB, PC, PD, CNTR & \(\mathrm{C}_{\text {IN }}\) & - & - & \[
\begin{aligned}
& 50 \\
& 10 \\
& \hline
\end{aligned}
\] & pF & \[
\begin{aligned}
& T_{A}=25^{\circ} \mathrm{C} \\
& V_{\mathrm{IN}}=0 \mathrm{~V} \\
& \mathrm{f}=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Output Capacitance (Three-State Off) & \(\mathrm{C}_{\text {OUt }}\) & - & - & 10 & pF & \[
\begin{aligned}
& T_{\mathrm{A}}=25^{\circ} \mathrm{C} \\
& V_{\mathrm{V}}=0 \mathrm{~V} \\
& \mathrm{f}=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Power Dissipation (Outputs High) & \(\mathrm{P}_{\mathrm{D}}\) & - & 600 & 990 & mW & \(\mathrm{V}_{\mathrm{CC}}=+5.5 \mathrm{~V}\) \\
\hline \multicolumn{7}{|l|}{\begin{tabular}{l}
Notes: \\
1. Typical values measured at \(T_{A}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\). \\
2. Negative sign indicates outward current flow, positive indicates inward flow.
\end{tabular}} \\
\hline
\end{tabular}

\section*{AC CHARACTERISTICS}
\(\left(V_{C C}=5 \mathrm{~V} \pm 10 \%\right.\) for R6500/1, \(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%\) for R6500/1A \()\)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Parameter} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min & Max & Min & Max & \\
\hline XTLI Input Clock Cycle Time & \(\mathrm{T}_{\text {cyc }}\) & 0.500 & 5.0 & 0.250 & 5.0 & \(\mu \mathrm{sec}\) \\
\hline Internal Write to Peripheral Data Valid (TTL) & TPDW & 1.0 & & 0.5 & & \(\mu \mathrm{sec}\) \\
\hline Internal Write to Peripheral Data Valid (CMOS) & \(\mathrm{T}_{\text {cmos }}\) & 2.0 & & 1.0 & & \(\mu \mathrm{sec}\) \\
\hline Peripheral Data Setup Time & TPDSU & 400 & & 200 & & nsec \\
\hline Count and Edge Detect Pulse Width & \(\mathrm{T}_{\text {PW }}\) & 1.0 & & 0.5 & & \(\mu \mathrm{sec}\) \\
\hline
\end{tabular}

\section*{PACKAGE DIMENSIONS}

40-PIN PLASTIC DIP

\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{ DIM } & \multicolumn{2}{|c|}{ MILLIMETERS } & \multicolumn{2}{c|}{ INCHES } \\
\cline { 2 - 5 } & MIN & MAX & MIN & MAX \\
\hline A & 5182 & 5232 & 2040 & 2.060 \\
\hline B & 1346 & 13.97 & 0530 & 0.550 \\
\hline C & 356 & 5.08 & 0140 & 0200 \\
\hline D & 038 & 0.53 & 0015 & 0.021 \\
\hline F & \multicolumn{2}{|c|}{1.02} & 1.52 & \multicolumn{2}{|c|}{0.040} \\
\hline G & 254 & 0.060 \\
\hline H & 165 & 2.16 & \multicolumn{2}{|c|}{0.065} & 0.100 \\
\hline
\end{tabular}

\section*{44-PIN PLASTIC LEADED CHIP CARRIER (PLCC)}


TOP VIEW



SIDE VIEW

\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{ DIM } & \multicolumn{2}{|c|}{ MILLIMETERS } & \multicolumn{2}{c|}{ INCHES } \\
\cline { 2 - 5 } & MIN & MAX & MIN & MAX \\
\hline A & 4.14 & 4.39 & 0163 & 0.173 \\
\hline A1 & 1.37 & 147 & 0.054 & 0.058 \\
\hline A2 & 2.31 & 2.46 & 0.091 & 0.097 \\
\hline b & \multicolumn{2}{|c|}{0.457 TYP } & \multicolumn{2}{|c|}{0018 TYP } \\
\hline D & 17.45 & 17.60 & 0.687 & 0.693 \\
\hline D1 & 16.46 & 16.56 & 0.648 & 0.652 \\
\hline D2 & 12.62 & 12.78 & 0.497 & 0.503 \\
\hline D3 & 15.75 REF & \multicolumn{2}{|c|}{0.620 REF } \\
\hline e & \multicolumn{2}{|c|}{1.27 BSC } & \multicolumn{2}{|c|}{0.050 BSC } \\
\hline h & 1.15 TYP & \multicolumn{2}{|c|}{0.045 TYP } \\
\hline J & 0.25 TYP & \multicolumn{2}{|c|}{0.010 TYP } \\
\hline\(\alpha\) & \multicolumn{2}{|c|}{\(45^{\circ}\) TYP } & \multicolumn{2}{|c|}{\(45^{\circ}\) TYP } \\
\hline R & \multicolumn{2}{|c|}{0.89 TYP } & \multicolumn{2}{|c|}{0.035 TYP } \\
\hline R1 & \multicolumn{2}{|c|}{0.25 TYP } & \multicolumn{2}{|c|}{0.010 TYP } \\
\hline
\end{tabular}

SECTION A-A
TYP FOR BOTH AXIS (EXCEPT FOR BEVELED EDGE)

\section*{EJECTOR PIN MARKS}

CHAM. 11 PINS
\(h \times 45^{\circ}\)
3 PLCS

\section*{PER SIDE}

EQUALLY
SPACES
BOTTOM VIEW

\section*{R6500/1E Microprocessor Emulator Device}

\section*{INTRODUCTION}

The R6500/1E device provides all the features of the R6500/1 Microcomputer in a ROMless form suitable for use as an advanced microprocessor complete with 16 -bit counter and 32 I/O lines, and an address and data bus for 4 K of external memory.

To aid in designing R6500/1 microcomputer systems, it may also be used as an emulator device. Device architecture is basically the same as the R6500/1 except that the address, data, and associated control lines are routed off the chip for connection to an external memory.

The functions and operation of the R6500/1E device are identical to the R6500/1 except for minor differences noted in this
document. The R6500/1 Product Description (Order No. 212) contains a description of R6500/1 functions and interface signals.

The R6500/1E device is available in both 64-pin ceramic DIP (R6500/1EC) and 64-pin plastic QUIP (R6500/1EQ).

ORDERING INFORMATION
\begin{tabular}{|c|c|c|c|}
\hline \begin{tabular}{c} 
Part \\
Number
\end{tabular} & \begin{tabular}{c} 
Package \\
Type
\end{tabular} & \begin{tabular}{c} 
Frequency \\
Option
\end{tabular} & \begin{tabular}{c} 
Temperature \\
Range
\end{tabular} \\
\hline R6500/1EC & Ceramic & 1 MHz & \(0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}\) \\
R6500/1EAC & Ceramic & 2 MHz & \(0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}\) \\
R6500/1EQ & Plastic & 1 MHz & \(0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}\) \\
R6500/1EAQ & Plastic & 2 MHz & \(0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}


\section*{R6500/1E Pin Assignments}

\section*{INTERFACE SIGNALS}

All R6500/1 interface signals are available in the R6500/1E microcomputer plus the additional address (12), data (8), and control (4) lines required to extend the address bus and the data bus external to the device. The R6500/1E emulator unique interface signals are shown in Figure 1 and are described in Table 1. While the pin assignments are different in order to accommodate 64-pin DIP and QUIP packages, the interface characteristics of signals common to the R6500/1 are identical.

\section*{SYSTEM ARCHITECTURE}

The architecture of the R6500/1E is identical to the R6500/1 with the following differences:

\section*{EXTERNAL ADDRESSING}

ROM addressing is routed externally in the R6500/1E. The address range for internal ROM in the R6500/1 (\$800-\$FF9) is available externally for connection to ROM or RAM devices(s).

An additional 1024 bytes ( \(\$ 400-\$ 7 F F\) ) are decoded for external memory access. Note that this address range can be used for
debugging with the R6500/1E but cannot be used when the object code is transferred to masked ROM in an R6500/1 (which is restricted to \(\$ 800-\$ F F 9)\).

A memory map of the R6500/1E is shown in Figure 2.

\section*{INTERNAL I/O PORT PULL-UPS}

The R6500/1E has the internal I/O and CNTR port pull-up resistors only. The option to delete the pull-up resistors is not available for the R6500/1E.

\section*{EARLIER I/O PORT INITIALIZATION}

Ports A, B, C, D and the CNTR line in the R6500/1E are initialized to the logic high state two \(\emptyset 2\) clock cycles earlier than in the R6500/1. It is still required, however, that the \(\overline{\text { RES }}\) line be held low for at least eight \(\emptyset 2\) clock cycles after VCC reaches operating range (Figure 3).

\section*{WRITE-ONLY MONITORING}

The R6500/1E allows the user to monitor write operations to the internal RAM and I/O by routing those operations externally as well as internally. Read operations are not routed externally.


Figure 1. R6500/1E Emulator Interface Diagram

Table 1. R6500/1E Emulator Unique Signals Description
\begin{tabular}{|c|c|c|}
\hline \begin{tabular}{l}
Signal \\
Name
\end{tabular} & \begin{tabular}{l}
Pin \\
No.
\end{tabular} & Description \\
\hline R/W & 62 & Read/Write. Read/Write allows the CPU to control the direction of data transfer between the R6500/1E Emulator CPU and external memory. This line is high when reading data from memory and is low when writing data to memory. \\
\hline RDY & 3 & Ready. The Ready input delays execution of any cycle during which the RDY line is low. This allows the user to halt or single step the CPU on all cycles except write cycles. A negative transition to the low state during the \(\emptyset 2\) clock low pulse will halt the CPU with the address lines containing the current address being fetched. If RDY is low during a write cycle, it is ignored until the following read operation. This condition will remain through a subsequent \(\emptyset 2\) clock pulse in which the RDY line is low. This feature allows the CPU to interface with memories having slow access times, such as EPROMS used with the R6500/1E during prototype system development. \\
\hline SYNC & 6 & Sync. The Sync signal is provided to identify cycles in which the CPU is performing OP CODE fetch. SYNC goes high during the \(\emptyset 2\) clock low pulse of an OP CODE fetch and stays high for the remainder of that cycle. If the RDY line is pulled low during the \(\emptyset 2\) clock low pulse in which SYNC went high, the CPU will halt in its current state and will remain in that state until the RDY line goes high. Using this technique, the SYNC signal can be used to control RDY to cause single instruction execution. \\
\hline \(\emptyset 2\) & 1 & Phase 2 (02) clock: Data transfer takes place only during \(\emptyset 2\) clock pulse high. \\
\hline A0-A11 & 25-37 & Address Bus Lines. The address bus buffers on the R6500/1E are push/pull type drivers capable of driging at least 130 pF and one standard TTL load. The address bus always contains known data. The addressing tgechnique involves putting an address on the address bus which is known to be either in program sequence, on the same page in program memory, or at a known point in memory. The I/O address commands are also placed on these lines. \\
\hline DO-D7 & 53-46 & Data Bus Lines. All transfers of instructions and data between the CPU and memory, I/O, and other interfacing circuitry take place on the bidirectional data bus lines. The buffers driving the data bus lines have full three-state capability. Each data bus pin is connected to an input and output buffer, with the output buffer remaining in the floating condition. \\
\hline
\end{tabular}


Figure 2. R6500/1E Memory Map


Figure 3. R6500/1E I/O Port Initialization

\section*{TYPICAL PROGRAM MEMORY INTERCONNECTIONS}

Two typical connections between the R6500/1E and program memory (in this case, type 2716 and 2732 PROMS) are illustrated. Figure 4 shows a connection to a 2 K 2716 PROM. Since the R6500/1 has a 2K ROM capacity, the contents of the PROM could be masked directly into the production R6500/1 ROM.

Figure 5 shows a connection to a 4 K 2732 PROM. Only 3 K bytes ( \(\$ 400-\$ F F F\) ) are enabled. The upper \(2 K\) bytes correspond the production ROM space ( \(\$ 800-\$ F F F\) ) in the R6500/1. The extra 1 K ( \(\$ 400-\$ 7 \mathrm{FF}\) ) allows expanded or additional programs to be used during R6500/1 firmware development. The production program, however, must be reduced to 2K maximum (\$800-\$FFF) before masking into R6500/1 ROM.


Figure 4. R6500/1E Connected to One 2716 PROM (2K Bytes)


Figure 5. R6500/1E Connected to One 2732 PROM (3K Bytes)

\section*{DEVICE TIMING}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Signal} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min. & Max. & Min. & Max. & \\
\hline \(\mathrm{R} / \bar{W}\) setup time from CPU & TRWS & & 300 & & 200 & ns \\
\hline Address setup time from CPU & TADS & & 300 & & 200 & ns \\
\hline Memory read access time & TACC & & 525 & & 225 & ns \\
\hline Data stabilization time & TDSU & 150 & & 75 & & ns \\
\hline Data hold time - Read & THR & 10 & & 10 & & ns \\
\hline Data hold time - Write & THW & 30 & & 30 & & ns \\
\hline Data delay time from CPU & TMDS & & 200 & & 150 & ns \\
\hline RDY setup time & TRDY & 100 & & 50 & & ns \\
\hline SYNC delay time from CPU & TSYNC & & 350 & & 175 & ns \\
\hline Address hold time & THA & 30 & & 30 & & ns \\
\hline \(\mathrm{R} / \bar{W}\) hold time & THRW & 30 & & 30 & & ns \\
\hline Cycle Time & TCYC & 1.0 & 10.0 & 0.5 & 10.0 & \(\mu \mathrm{S}\) \\
\hline
\end{tabular}

\section*{TIMING DIAGRAMS}


\section*{MAXIMUM RATINGS*}
\begin{tabular}{|l|l|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.3 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to +7.0 & Vdc \\
\hline Operating Temperature & \(\mathrm{T}_{\mathrm{A}}\) & 0 to +70 & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\mathrm{STG}}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device atr these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{ELECTRICAL CHARACTERISTICS}
( \(\mathrm{V}_{\mathrm{CC}}=5.0 \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}\) unless otherwise specified)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Characteristic & Symbol & Min & Typ & Max & Unit & Test Conditions \\
\hline RAM Standby Voltage (Retention Mode) & \(\mathrm{V}_{\text {RR }}\) & 3.5 & - & \(\mathrm{V}_{\mathrm{CC}}\) & V & \\
\hline RAM Standby Current (Retention Mode) & \(\mathrm{I}_{\text {RR }}\) & - & 10 & - & mA & \\
\hline Input High Voltage & \(\mathrm{V}_{\mathrm{IH}}\) & +2.4 & - & - & Vdc & \\
\hline Input Low Voltage & \(\mathrm{V}_{\mathrm{IL}}\) & - & - & +0.8 & Vdc & \\
\hline Three-State (Off State) Input Current D0-D7 & \(1_{\text {TSI }}\) & - & - & \(\pm 10\) & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{IN}}=0.4 \text { to } 2.4 \mathrm{~V} \\
& \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}
\end{aligned}
\] \\
\hline Output High Voltage DO-D7, SYNC, AO-A11, R/ \(\bar{W}, ~ \emptyset 2\) & \(\mathrm{V}_{\mathrm{OH}}\) & +2.4 & - & - & Vdc & \[
\begin{aligned}
& \mathrm{I}_{\mathrm{LOAD}}=-100 \mu \mathrm{~A} \\
& \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}
\end{aligned}
\] \\
\hline Output Low Voltage DO-D7, SYNC, AO-A11, R/W, \(\emptyset 2\) & \(\mathrm{V}_{\text {OL }}\) & - & - & +0.6 & Vdc & \[
\begin{aligned}
& \mathrm{I}_{\mathrm{LOAD}}=1.6 \mu \mathrm{~A} \\
& \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}
\end{aligned}
\] \\
\hline Power Dissipation ( \(\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}\) ) & \(\mathrm{P}_{\mathrm{D}}\) & - & 750 & 1200 & \(\mu \mathrm{W}\) & \(\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}\) \\
\hline ```
Input Capacitance
    RDY, PA, PB, PC, PD, CNTR
    DO-D7
    XTLI, XTLO
``` & \(\mathrm{C}_{\text {IN }}\) & - & - & \[
\begin{aligned}
& 10 \\
& 15 \\
& 50
\end{aligned}
\] & pF & \[
\begin{aligned}
& T_{A}=25^{\circ} \mathrm{C} \\
& \mathrm{~V}_{\text {IN }}=0
\end{aligned}
\] \\
\hline Output Capacitance A0-A11, R/ \(\bar{W}\), SYNC \(\emptyset 2\) & \(\mathrm{C}_{\text {OUt }}\) \(\mathrm{C}_{62}\) & - & - & \[
\begin{aligned}
& 12 \\
& 80 \\
& \hline
\end{aligned}
\] & pF & \(\mathrm{f}=1 \mathrm{MHz}\) \\
\hline I/O Port Pull-up Resistance & \(\mathrm{R}_{\mathrm{L}}\) & 3.0 & 6.0 & 11.5 & kohm & \\
\hline
\end{tabular}

\section*{Notes:}
1. Typical values measured at \(T_{A}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\).
2. Negative sign indicates outward current flow, positive indicates inward flow.

\section*{PACKAGE DIMENSIONS}

R6500/1EC 64-PIN DIP CERAMIC


NOTE: PIN NO. 1 IS IN LOWER LEFT CORNER WHEN SYMBOLIZATION IS IN NORMAL ORIENTATION

R6500/1EQ 64-PIN QUIP PLASTIC


\title{
R6500/1EB and R6500/1EAB Backpack Emulator
}

\section*{INTRODUCTION}

The Rockwell R6500/1EB and R6500/1EAB Backpack Emulator is the PROM prototyping version of the 8 -bit, masked-ROM R6500/1 one-chip microcomputer. Like the R6500/1, the backpack device is totally upward/downward compatible with all members of the R6500/1 family. It is designed to accept standard 5-volt, 24-pin EPROMs or ROMs directly, in a socket on top of the Emulator. This packaging concept allows a standard EPROM to be easily removed, reprogrammed, then reinserted as often as desired.

The backpack devices have the same pinouts as the maskedROM R6500/1 microcomputer. These 40 pins are functionally and operationally identical to the pins on the R6500/1, with some minor differences (described herein). The R6500/1 Microcomputer Product Description (Order No. 212) includes a description of the interface signals and their functions. Whereas the masked-ROM R6500/1 provides 2 K bytes of read-only memory, the R6500/1EB will address 3 K bytes of external program memory. This extra memory accommodates program patches, test programs or optional programs during breadboard and prototype development states.

\section*{ORDERING INFORMATION}

\section*{BACKPACK EMULATOR}
\begin{tabular}{|c|c|c|c|}
\hline \begin{tabular}{c} 
Part \\
Number
\end{tabular} & \begin{tabular}{c} 
Memory \\
Capacity
\end{tabular} & \begin{tabular}{c} 
Compatible \\
Memories
\end{tabular} & \begin{tabular}{c} 
Temperature \\
Range and Speed
\end{tabular} \\
\hline R6500/1EB3 & \(3 \mathrm{~K} \times 8\) & 2732 & \(0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}\) \\
1 MHz \\
R6500/1EAB3 & \(3 \mathrm{~K} \times 8\) & \begin{tabular}{c}
2732 A \\
\((250 \mathrm{~ns})\)
\end{tabular} & \begin{tabular}{c}
\(0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}\) \\
2 MHz
\end{tabular} \\
\hline
\end{tabular}

SUPPORT PRODUCTS
\begin{tabular}{|l|l|}
\hline \begin{tabular}{c} 
Part \\
Number
\end{tabular} & \multicolumn{1}{c|}{ Description } \\
\hline RDC-3101 & Low Cost Emulator (LCE) \\
RDC-3030 & PROM Programmer Module \\
RDC-369 & 1- or 2-MHz R6500/1 Personality Module \\
\hline
\end{tabular}

\section*{FEATURES}
- PROM version of the R6500/1
- Completely pin compatible with R6500/1 single-chip microcomputers
- Profile approaches 40 -pin DIP of R6500/1
- Accepts 5 -volt, 24 -pin industry-standard EPROMs -4K memories-2732, 2732A (3K bytes addressable)
- Use as prototyping tool or for low volume production
- 3 K bytes of memory capacity ( 4 K memories)
- \(64 \times 8\) static RAM
- Separate power pin for RAM
- Software compatibility with the R6500 family
- 32 bi-directional TTL compatible I/O lines (4 ports)
- 1 bi-directional TTL compatible counter I/O line
- 16 -bit programmable counter/latch with four modes (interval timer, pulse generator, event counter, pulse width measurement)
- 5 interrupts (reset, non-maskable, two external edge sensitive, counter)
- Crystal or external time base
- Single +5 V power supply


R6500/1EB-R6500/1EAB Backpack Emulator

\section*{CONFIGURATION}

The external memory must always occupy the upper 2 K of available memory (addresses 800 through FFF) for implementation of interrupt vectors. See Memory Map. The Backpack Emulator provides a read block to the external memory where internal RAM or I/O are located in the same addresses as that occupied by external memory.

\section*{EXTERNAL FREQUENCY REFERENCE}

The external frequency reference may be a crystal or a clock. The R6500/1EB and R6500/1EAB divide the input clock by two regardless of the source.

\section*{I/O PORT PULLUPS}

The emulator devices have internal I/O port pullup resistors.

\section*{PRODUCT SUPPORT}

The Backpack Emulator is just one of the products that Rockwell offers to facilitate system and program development for the R6500/1.
The Low Cost Emulator (LCE) with R6500/1 Personality Module supports both hardware and software development. Complete in-circuit user emulation with the R6500/1 Personality Module allows total system test and evaluation. With the optional PROM Programmer, the LCE can also be used to program EPROMs for the development activity. When PROM programs have been finalized, the PROM device can be sent to Rockwell for masking into the 2K ROM of the R6500/1.


\section*{DETAILED MEMORY MAP}
\begin{tabular}{|c|c|c|}
\hline & & HEX \\
\hline \multirow{7}{*}{PROM} & IRQ VECTOR HIGH & FFF \\
\hline & IRQ VECTOR LOW & FFE \\
\hline & RES VECTOR HIGH & FFD \\
\hline & RES VECTOR LOW & FFC \\
\hline & NMI VECTOR HIGH & FFB \\
\hline & NMI VECTOR LOW & FFA \\
\hline & R6500/1 USER PROGRAM & FF9 \\
\hline PROM & R6500/1EB EXTENDED PROGRAM AREA (1) & \[
\begin{aligned}
& 3 F F \\
& 400
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& \hline \text { NOT } \\
& \text { USED }
\end{aligned}
\] & UNASSIGNED & \multirow[b]{2}{*}{08F} \\
\hline \multirow{13}{*}{1/0} & CONTROL REGISTER & \\
\hline & UNASSIGNED & \[
\begin{aligned}
& \text { 08E } \\
& \text { 08B }
\end{aligned}
\] \\
\hline & CLEAR PA1 NEG EDGE DETECTED (2) & \multirow[t]{2}{*}{08A
089} \\
\hline & CLEAR PAO POS EDGE DETECTED (2) & \\
\hline & \begin{tabular}{l}
UPPER LATCH AND TRANSFER \\
LATCH TO COUNTER
\end{tabular} & 088 \\
\hline & LOWER COUNT & 087 \\
\hline & UPPER COUNT & 086 \\
\hline & LOWER LATCH & \multirow[t]{2}{*}{085} \\
\hline & UPPER LATCH & \\
\hline & PORT D & 083 \\
\hline & PORT C & \multirow[t]{3}{*}{\begin{tabular}{l}
082 \\
081 \\
080
\end{tabular}} \\
\hline & PORT B & \\
\hline & PORT A & \\
\hline \[
\begin{array}{|l|}
\hline \text { NOT } \\
\text { USED } \\
\hline
\end{array}
\] & UNASSIGNED & 03F \\
\hline RAM & USER RAM & 000 \\
\hline
\end{tabular}

\section*{NOTES}
(1) Additional 1024 bytes are decoded for external memory addressing by the Backpack Emulator Device. This area can be used during debug, but cannot be used in a masked ROM R6500/1.
(2) I/O command only; i.e., no stored data.
(3) Clears Counter Overflow-Bit 7 in Control Register
(4) CAUTION: The device allows RAM mapping into 040-07F, 100-13F, 140-17F, 200-23F, 240-27F, 300-33F, and 340-37F; as well as 000-03F. The production R6500/1, however allows RAM mapping only at 000-03F.

\section*{RAM MAPPING}

The Backpack Emulator allows RAM mapping into 040-07F, \(100-13 \mathrm{~F}, 140-17 \mathrm{~F}, 200-23 \mathrm{~F}, 240-27 \mathrm{~F}, 300-33 \mathrm{~F}\) and \(340-37 \mathrm{~F}\), as well as 000-03F. The production R6500/1, however, allows RAM mapping only at 000-03F. This means that a write to location 40, for example, will write to location 0 in the Backpack Emulator, and to invalid RAM in the R6500/1 production part.

\section*{I/O PORT INITIALIZATION}

Ports \(\mathrm{A}, \mathrm{B}, \mathrm{C}\), and D and the CNTR line in the Backpack Emulator are initialized to the logic high state two \(\emptyset 2\) clock cycles earlier than in the R6500/1. The RES line to the device must, however, still be held low for at least eight \(\emptyset 2\) clock cycles after \(\mathrm{V}_{\mathrm{CC}}\) reaches operating range. See timing diagram.

\section*{BACKPACK MEMORY SIGNAL DESCRIPTION}
\begin{tabular}{|c|c|c|}
\hline Signal Name & Pin No. & Description \\
\hline D0-D7 & \[
\begin{aligned}
& 9 \mathrm{~S}-11 \mathrm{~S}, \\
& 13 \mathrm{~S}-17 \mathrm{~S}
\end{aligned}
\] & Data Bus Lines. All instruction and data transfers take place on the data bus lines. The buffers driving the data bus lines have full threestate capability. Each data bus pin is connected to an input and an output buffer, with the output buffer remaining in the floating condition. \\
\hline A0-A9 & \[
\begin{aligned}
& 1 \mathrm{~S}-8 \mathrm{~S}, \\
& 23 \mathrm{~S}, 24 \mathrm{~S}
\end{aligned}
\] & Address Bus Lines. The address bus lines are buffered by push/pull type drivers that can drive one standard TTL load. \\
\hline A10 & 19S & Address Bus Line 10. This address line has the same characteristics and functions as Lines A0-A9. \\
\hline \(\overline{\mathrm{CE}}\) & 185 & \(\overline{\mathrm{CE}}\) is active when the address is 400-FFF. This line can drive one TTL load. \\
\hline \(\overline{O E}\) & 20 S & Memory Enable Line. This signal provides the output enable for the memory to place information on the data bus lines. This signal is driven by the \(R / \bar{W}\) signal from the CPU and then inverted by a standard TTL inverter, to form \(\overline{\mathrm{OE}}\). \\
\hline \(V_{C C}\) & 24S & Main Power Supply \(\$ 5 \mathrm{~V}\). This pin is tied directly to pin \(30\left(\mathrm{~V}_{\mathrm{CC}}\right)\). \\
\hline A11 & 215 & Address Bus Line II. This pin is tied to A11. During backup power, power is supplied only to the RAM memory, and not to the PROMs. \\
\hline \(V_{S S}\) & 12S & Signal and Power Ground (zero volts). This pin is tied directly to pin \(12\left(\mathrm{~V}_{\mathrm{SS}}\right)\). \\
\hline
\end{tabular}

Pin Configuration

\section*{READ TIMING CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Signal} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min. & Max. & Min. & Max. & \\
\hline \(\overline{O E}\) setup time from CPU & Toes & - & 300 & - & 150 & ns \\
\hline Address setup time from CPU & \(\mathrm{T}_{\text {ADS }}\) & - & 300 & - & 150 & ns \\
\hline Memory read access time & \(T_{\text {ACC }}\) & - & 525 & - & 250 & ns \\
\hline Data stabilization time & T \({ }_{\text {DSU }}\) & 150 & - & 100 & - & ns \\
\hline Data hold time-Read & \(T_{\text {HR }}\) & 10 & - & 10 & - & ns \\
\hline Address hold time & \(\mathrm{T}_{\text {HA }}\) & 30 & - & 30 & - & ns \\
\hline \(\overline{O E}\) hold time & \(\mathrm{T}_{\text {HoE }}\) & 30 & - & 30 & - & ns \\
\hline Cycle Time & \(\mathrm{T}_{\mathrm{crc}}\) & 1.0 & 10.0 & 0.5 & 10.0 & \(\mu \mathrm{S}\) \\
\hline
\end{tabular}

\section*{READ TIMING WAVEFORMS}

* \(\phi 2\) IS SHOWN FOR REFERENCE ONLY AND IS NOT AVAILABLE EXTERNAL TO THE DEVICE.

I/O PORT INITIALIZATION TIMING


\section*{MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.3 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to +7.0 & Vdc \\
\hline \begin{tabular}{c} 
Operating Temperature \\
Commercial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{c}
\(\mathrm{T}_{\mathrm{L}}\) to \(\mathrm{T}_{\mathrm{H}}\) \\
0 to +70
\end{tabular} & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\text {STG }}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}
\(\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{S S}=0 \mathrm{~V} ; T_{A}=0^{\circ}\right.\) to \(70^{\circ}\), unless otherwise specified)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ \({ }^{1}\) & Max & Unit & Test Conditions \\
\hline Input High Voltage
D0-D7 & \(\mathrm{V}_{\mathrm{IH}}\) & +2.4 & - & - & V & \\
\hline Input Low Voltage D0-D7 & VIL & - & - & +0.8 & V & \\
\hline Input Leakage Current (Three-State Off) D0-D7 & \(\mathrm{I}_{\mathrm{IN}}\) & - & - & \(\pm 10.0\) & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& V_{I N}=0.4 \text { to } 2.4 \mathrm{~V} \\
& V_{C C}=5.25 \mathrm{~V}
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& \text { Output High Voltage (Except XTLO) } \\
& \text { D0-D7, A0-A11, OE }
\end{aligned}
\] & \(\mathrm{V}_{\mathrm{OH}}\) & \(+2.4\) & - & - & V & \[
\begin{aligned}
& \mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A} \\
& V_{S S}=4.75 \mathrm{~V}
\end{aligned}
\] \\
\hline Output Low Voltage
\[
\mathrm{D} 0-\mathrm{D} 7, \mathrm{~A} 0-\mathrm{A} 11, \overline{\mathrm{OE}}
\] & \(\mathrm{V}_{\mathrm{OL}}\) & - & - & \(+0.6\) & V & \[
\begin{aligned}
& \mathrm{I}_{\mathrm{LOAD}}=1.6 \mathrm{~mA} \\
& V_{S S}=4.75 \mathrm{~V}
\end{aligned}
\] \\
\hline I/O Port Pull-Up Resistance & \(\mathrm{R}_{\mathrm{L}}\) & 3.0 & 6.0 & 11.5 & Kohm & \\
\hline Input Capacitance
D0-D7 & \(\mathrm{C}_{\mathrm{IN}}\) & - & - & 15 & pF & \[
\begin{aligned}
& T_{A}=25^{\circ} \mathrm{C} \\
& V_{I N}=0 \mathrm{~V} \\
& f=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Output Capacitance (Three-State Off) A0-A11 & \(\mathrm{C}_{\text {OUT }}\) & - & - & 12 & pF & \[
\begin{aligned}
& T_{A}=25^{\circ} \mathrm{C} \\
& V_{I N}=0 \mathrm{~V} \\
& f=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Power Dissipation (Less EPROM) & \(P_{\text {D }}\) & - & 800 & 1300 & mW & \(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}

\section*{Notes:}
1. Typical values measured at \(T_{A}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\).
2. Negative sign indicates outward current flow, positive indicates inward flow.

\section*{PACKAGE DIMENSIONS}

40-PIN BACKPACK


\title{
R6500/11, R6500/12 and R6500/15 One-Chip Microcomputers
}

\section*{SECTION 1 \\ INTRODUCTION}

\subsection*{1.1 FEATURES}
- Enhanced 6502 CPU
-Four new bit manipulation instructions: Set Memory Bit (SMB)
Reset Memory Bit (RMB)
Branch on Bit Set (BBS)
Branch on Bit Reset (BBR)
-Decimal and binary arithmetic modes
- 13 addressing modes
-True indexing
- 3K-byte mask-programmable ROM (R6500/11, R6500/12)
- 4K-byte mask-programmable ROM (R6500/15)
- 192-byte static RAM
- 32 TTL-compatible I/O lines (R6500/11, R6500/15)
- 56 TTL-compatible I/O lines (R6500/12)
- One 8 -bit port may be tri-stated under software control
- One 8 -bit port with programmable latched input
- Two 16-bit programmable counter/timers, with latches
-Pulse width measurement
-Asymmetrical pulse generation
-Pulse generation
-Interval timer
-Event counter
-Retriggerable interval timer
- Serial port
-Full-duplex asynchronous operation mode
-Selectable 5- to 8-bit characters
-Wake-up feature
-Synchronous shift register mode
-Standard programmable bit rates, programmable up to 62.5 K bits/sec @ 1 MHz
- Ten interrupts
-Four edge-sensitive lines; two positive, two negative
-Reset
—Non-maskable
-Two counter underflows
-Serial data received
-Serial data transmitted
- Bus expandable to 16 K bytes of external memory
- Flexible clock circuitry
\(-2-\mathrm{MHz}\) or \(1-\mathrm{MHz}\) internal operation
- Internal clock with external 2 MHz to 4 MHz series resonant XTAL at two or four times internal frequency
- External clock input divided by one, two or four
- \(1 \mu \mathrm{~s}\) minimum instruction execution time @ 2 MHz
- NMOS-3 silicon gate, depletion load technology
- Single +5 V power supply
- 12 mW stand-by power for 32 bytes of the 192-byte RAM
- 40-pin DIP (R6500/11 and R6500/15)
- 44-pin PLCC (R6500/11 and R6500/15)
- 64-pin QUIP (R6500/12)

\subsection*{1.2 SUMMARY}

These Rockwell microcomputers are complete, highperformance 8 -bit NMOS-3 microcomputers on a single chip, and are compatible with all members of the R6500 family.

The R6500/11 consists of an enhanced 6502 CPU, an internal clock oscillator, 3072 bytes of Read-Only Memory, 192 bytess of Random Access Memory (RAM) and versatile interface circuitry (Figure 1-1). The interface circuitry includes two 16 -bit programmable timer/counters, 32 bidirectional input/output lines (including four edge-sensitive lines and input latching on one 8 -bit port), a full-duplex serial I/O channel, ten interrupts and bus expandability.

The R6500/15 is identical to the R6500/11 except it has 4 K of ROM.

The innovative architecture and the demonstrated high performance of the R6502 CPU, as well as instruction simplicity, results in system cost-effectiveness and a wide range of computational power. These features make either device a leading candidate for microcomputer applications.

The R6500/12 consists of all the features of the R6500/11 plus three additional I/O ports. It is packaged in a 64 pin QUIP.

To allow prototype circuit development, Rockwell offers a PROMcompatible 64-pin extended microprocessor device. This device, the R6511Q, provides all R6500/11 or R6500/15 interface lines, plus the address bus, data bus and control lines to interface with external memory. With the addition of external circuits it can also be used to emulate the R6500/12 (contact Rockwell sales offices listed on the back page for details).

A backpack emulator, the R65/11EB, is available for developing R6500/11 applications. No backpack part is available for the R6500/12.

The R6511Q may also be used as a CPU-RAM-I/O counter device in multichip systems.

Rockwell supports development of R6500/* single chip microcomputer applications with the Rockwell Design Center Low Cost Emulator (LCE) and R6500/* Personality Set. Program assembly can be performed on any user-provided computer using an assembler generating R6500/* machine code. The machine code can then be downloaded via an RS-232-C serial channel to the LCE for program debugging and in-circuit emulation. Complete in-circuit emulation with the R6500/* Personality Set allows total system test and evaluation. Refer to the RDC-3101/2 LCE and RDC-3XX R6500/* Personality Set data sheets, Order Nos. RDC17 and RDC06, respectively, for additional information.
This product description is for the reader familiar with the R6502 CPU hardware and programming capabilities. A detailed description of the R6502 CPU hardware is included in the R6500 Microcomputer System Hardware Manual (Order Number 201). A description of the instruction capabilities of the R6502 CPU is contained in the R6500 Microcomputer System Programming Manual (Order Number 202).

\subsection*{1.3 CUSTOMER OPTIONS}

The R6500/11 microcomputer is available with the following customer specified mask options:
- Option 1 Crystal oscillator
- Option 2 Clock divide-by-2 or divide-by-4
- Option 3 Clock MASTER Mode or SLAVE Mode
- Option 4 Port A with or without internal pull-up resistors
- Option 5 Port B with or without internal pull-up resistors
- Option 6 Port C with or without internal pull-up resistors

All options should be specified on an R6500/11, /12 or /15 order form.

The R6500/12 is available with all of the above options plus:
- Option 7 Port F with or without internal pull-up resistors
- Option 8 Port G with or without internal pull-up resistors

Refer to the R6500/* ROM Code Order Forms (Order Number 2134) for detail option ordering information.


Figure 1-1. R6500/11, R6500/12 and R6500/15 Interface Signals

\section*{SECTION 2 \\ INTERFACE REQUIREMENTS}

This section describes the interface requirements for the single chip microcomputer devices. Figures 2-1 and 2-2 show the
pin assignments and Table 2-1 describes the function of each pin. Figures 2-3 and 2-4 show the package dimensions.


Figure 2-1. R6500/11 and R6500/15 Pin Assignments


Figure 2-2. R6500/12 Pin Assignments

Table 2-1. Pin Descriptions
\begin{tabular}{|c|c|c|}
\hline Signal Name & \begin{tabular}{l}
I/O \\
Pin Number
\end{tabular} & Description \\
\hline \(\mathrm{V}_{\mathrm{Cc}}\) & & Main power supply +5 V . \\
\hline \(V_{\text {RR }}\) & & Separate power pin for RAM. In the event that \(\mathrm{V}_{\text {cc }}\) power is lost, this power retains RAM data. \\
\hline \(\mathrm{V}_{\text {SS }}\) & & Signal and power ground (0V). \\
\hline XTLI & I & Crystal or clock input for internal clock oscillator. Also allows input of X1 clock signal if XTLO is connected to \(\mathrm{V}_{\mathrm{SS}}\) or X 2 or X 4 clock if XTLO is floated. \\
\hline XTLO & 0 & Crystal output from internal clock oscillator. \\
\hline \(\overline{\text { RES }}\) & 1 & The Reset input is used to initialize the device. This signal must not transition from low to high for at least eight cycles after \(V_{C C}\) reaches operating range and the internal oscillator is stabilized. \\
\hline \(\emptyset 2\) & 1 & Clock signal output at internal frequency. \\
\hline \(\overline{\text { NMI }}\) & I & A negative going edge on the Non-Maskable interrupt signal requests that a non-maskable interrupt be generated within the CPU. \\
\hline PA0-PA7 & 1/O & Four 8-bit ports used for either input/output. Each line of Ports A, B and C consists of an active transistor \\
\hline PB0-PB7 & 1/0 & to \(\mathrm{V}_{\mathrm{SS}}\) and an optional passive pull-up to \(\mathrm{V}_{\text {CC }}\). In the abbreviated or multiplexed modes of operation Port C \\
\hline PC0-PC7 & 1/O & has an active pull-up transistor. Port D functions as either an 8 -bit input or 8-bit output port. It has active \\
\hline PD0-PD7 & 1/O & pull-up and pull-down transistors. \\
\hline PE0-PE7 & 0 & For the R6500/12, the 64-pin QUIP version, three additional ports (24 lines) are provided. Each line consists \\
\hline PF0-PF7 & \(1 / 0\) & of an active transistor to \(\mathrm{V}_{\text {SS }}\). PF0-PF7 and PG0-PG7 are bidirectional, and an optional passive pull-up \\
\hline PG0-PG7 & I/O & to \(V_{C C}\) is provided. PEO-PE7 is outputs only with an active pull-up. All ports will source \(100 \mu \mathrm{amps}\) at 2.4 V except port E (PE0-PE7) which will source 1 mA at 1.5 V . \\
\hline
\end{tabular}

\section*{64 PIN PLASTIC QUIP}

\begin{tabular}{|c|c|c|c|c|}
\hline \multirow{2}{*}{ DIM } & \multicolumn{2}{|c|}{ MILLIMETERS } & \multicolumn{2}{c|}{ INCHES } \\
\cline { 2 - 5 } & MIN & MAX & MIN & MAX \\
\hline A & 41.15 & 41.66 & 1.620 & 1.640 \\
\hline B & 17.02 & 17.53 & 0.670 & 0.690 \\
\hline C & 3.05 & 4.56 & 0.120 & 0.180 \\
\hline D & 0.38 & 0.51 & 0.024 & 0.020 \\
\hline F & 1.27 BSC & \multicolumn{2}{|c|}{0.050 BSC } \\
\hline G & 2.54 BSC & 0.100 BSC \\
\hline H & 1.02 & 1.14 & 0.040 & 0.045 \\
\hline J & - & \(7^{\circ}\) & - & \(7^{\circ}\) \\
\hline K & 2.79 & 4.32 & 0.110 & 0.170 \\
\hline L & 18.92 & 19.81 & 0.745 & 0.755 \\
\hline M & 23.37 & 23.62 & 0.920 & 0.930 \\
\hline
\end{tabular}


Figure 2-3. 64-PIN QUIP Dimensions

\section*{PACKAGE DIMENSIONS}

\section*{40-PIN PLASTIC DIP}

\section*{40-PIN PLASTIC DIP}

\begin{tabular}{|c|c|c|c|c|}
\hline & \multicolumn{2}{|c|}{ MILLIMETERS } & \multicolumn{2}{c|}{ INCHES } \\
\cline { 2 - 5 } DIM & MIN & MAX & MIN & MAX \\
\hline A & 51.82 & 52.32 & 2.040 & 2060 \\
\hline B & 13.46 & 1397 & 0.530 & 0550 \\
\hline C & 3.56 & 508 & 0.140 & 0.200 \\
\hline D & 0.38 & 0.53 & 0015 & 0021 \\
\hline F & 102 & 152 & 0040 & 0.060 \\
\hline G & \multicolumn{2}{|c|}{254 BSC } & \multicolumn{2}{c|}{0.100 BSC } \\
\hline H & 165 & 216 & 0.065 & 0085 \\
\hline J & 020 & 0.30 & \multicolumn{2}{|c|}{0.008} \\
\hline K & 330 & 4.32 & 0.012 \\
\hline L & \multicolumn{2}{|c|}{152430} & 0.170 \\
\hline M & \multicolumn{2}{|c|}{\(7^{\circ}\)} & \(10^{\circ}\) & \multicolumn{2}{c|}{0600} & \(7^{\circ}\) & \(10^{\circ}\) \\
\hline N & \multicolumn{2}{|c|}{051} & 1.02 & \multicolumn{2}{c|}{0020} & 0.040 \\
\hline
\end{tabular}

\section*{44-PIN PLASTIC LEADED CHIP CARRIER (PLCC)}


TOP VIEW


SECTION A-A TYP FOR BOTH AXIS (EXCEPT FOR BEVELED EDGE)

SIDE VIEW


CHAM. 11 PINS EJECTOR PIN MARKS
\(h \times 45^{\circ}\) PER SIDE 4 PLCS BOTTOM OF
3 PLCS
\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{DIM} & \multicolumn{2}{|l|}{MILLIMETERS} & \multicolumn{2}{|l|}{INCHES} \\
\hline & MIN & MAX & MIN & MAX \\
\hline A & 4.14 & 4.39 & 0.163 & 0.173 \\
\hline A1 & 1.37 & 1.47 & 0.054 & 0.058 \\
\hline A2 & 2.31 & 2.46 & 0.091 & 0097 \\
\hline \(b\) & \multicolumn{2}{|l|}{0.457 TYP} & \multicolumn{2}{|l|}{0.018 TYP} \\
\hline D & 17.45 & 17.60 & 0.687 & 0.693 \\
\hline D1 & 16.46 & 1656 & 0.648 & 0.652 \\
\hline D2 & 12.62 & 12.78 & 0.497 & 0503 \\
\hline D3 & \multicolumn{2}{|l|}{15.75 REF} & \multicolumn{2}{|l|}{0.620 REF} \\
\hline e & \multicolumn{2}{|l|}{1.27 BSC} & \multicolumn{2}{|l|}{0.050 BSC} \\
\hline h & \multicolumn{2}{|l|}{1.15 TYP} & \multicolumn{2}{|l|}{0.045 TYP} \\
\hline \(J\) & \multicolumn{2}{|l|}{0.25 TYP} & \multicolumn{2}{|l|}{0.010 TYP} \\
\hline \(\alpha\) & \multicolumn{2}{|l|}{\(45^{\circ}\) TYP} & \multicolumn{2}{|l|}{\(45^{\circ}\) TYP} \\
\hline R & \multicolumn{2}{|l|}{0.89 TYP} & \multicolumn{2}{|l|}{0.035 TYP} \\
\hline R1 & \multicolumn{2}{|l|}{025 TYP} & \multicolumn{2}{|l|}{0010 TYP} \\
\hline
\end{tabular}
(TYPICAL)


BOTTOM VIEW

\section*{SECTION 3 SYSTEM ARCHITECTURE}

This section provides a functional description of the devices. Functionally they consist of a CPU, both ROM and RAM memories, four 8 -bit parallel I/O ports (seven in the 64-pin versions), a serial I/O port, dual counter/latch circuits, a mode control register, and an interrupt flag/enable dual register circuit. A block diagram of the system is shown in Figure 3-1.

\section*{NOTE}

Throughout this document, unless specified otherwise, all memory or register address locations are specified in hexadecimal notation.

\subsection*{3.1 CPU LOGIC}

The internal CPU is a standard 6502 configuration with an 8 -bit Accumulator register, two 8-bit Index Registers (X and Y); an 8-bit Stack Pointer register, an ALU, a 16-bit Program Counter, and standard instruction register/decode and internal timing control logic.

\subsection*{3.1.1 Accumulator}

The accumulator is a general purpose 8 -bit register that stores the results of most arithmetic and logic operations. In addition, the accumulator usually contains one of the two data words used in these operations.

\subsection*{3.1.2 Index Registers}

There are two 8 -bit index registers, \(X\) and \(Y\). Each index register can be used as a base to modify the address data program counter and thus obtain a new address-the sum of the program counter contents and the index register contents.

When executing an instruction which specifies indirect addressing, the CPU fetches the op code and the address, and modifies the address from memory by adding the index register to it prior to loading or storing the value of memory.

Indexing greatly simplifies many types of programs, especially those using data tables.

\subsection*{3.1.3 Stack Pointer}

The Stack Pointer is an 8-bit register. It is automatically incremented and decremiented under control of the microprocessor to perform stack manipulation in response to either user instructions, an internal \(\overline{\mathrm{RQ}}\) interrupt, or the external interrupt line \(\overline{\mathrm{NMII}}\). The Stack Pointer must be initialized by the user program.

The stack allows simple implementation of multiple level interrupts, subroutine nesting and simplification of many types of data manipulation. The JSR, BRK, RTI and RTS instructions use the stack and Stack Pointer.

The stack can be envisioned as a deck of cards which may only be accessed from the top. The address of a memory
location is stored (or "pushed") onto the stack. Each time data are to be pushed onto the stack, the Stack Pointer is placed on the Address Bus, data are written into the memory location addressed by the Stack Pointer, and the Stack Pointer is decremented by 1. Each time data are read (or "pulled") from the stack, the Stack Pointer is incremented by 1. The Stack Pointer is then placed on the Address Bus, and data are read from the memory location addressed by the Pointer.

The stack is located on zero page, i.e., memory locations 00FF-0040. After reset, which leaves the Stack Pointer indeterminate, normal usage calls for its initialization at 00FF.

\subsection*{3.1.4 Arithmetic And Logic Unit (ALU)}

All arithmetic and logic operations take place in the ALU, including incrementing and decrementing internal registers (except the Program Counter). The ALU cannot store data for more than one cycle. If data are placed on the inputs to the ALU at the beginning of a cycle, the result is always gated into one of the storage registers or to external memory during the next cycle.

Each bit of the ALU has two inputs. These inputs can be tied to various internal buses or to a logic zero; the ALU then generates the function (AND, OR, SUM, and so on) using the data on the two inputs.

\subsection*{3.1.5 Program Counter}

The 16 -bit Program Counter provides the addresses that are used to step the processor through sequential instructions in a program. Each time the processor fetches an instruction from program memory, the lower (least significant) byte of the Program Counter (PCL) is placed on the low-order bits of the Address Bus and the higher (most significant) byte of the Program Counter ( PCH ) is placed on the high-order 8 bits of the Address Bus. The Counter is incremented each time an instruction or data is fetched from program memory.

\subsection*{3.1.6 Instruction Register and Instruction Decode}

Instructions are fetched from ROM or RAM and gated onto the Internal Data Bus. These instructions are latched into the Instruction Register then decoded along with timing and interrupt signals to generate control signals for the various registers.

\subsection*{3.1.7 Timing Control}

The Timing Control Logic keeps track of the specific instruction cycle being executed. This logic is set to T0 each time an instruction fetch is executed and is advanced at the beginning of each Phase One clock pulse for as many cycles as are required to complete the instruction. Each data transter which takes place between the registers is caused by decoding the contents of both the instruction register and timing control unit.
3-69

Figure 3-1. System Block Diagram

\subsection*{3.1.8 Interrupt Logic}

Interrupt logic controls the sequencing of three interrupts; \(\overline{R E S}, \overline{\mathrm{NMI}}\) and \(\overline{\mathrm{RQ}}\). \(\overline{\mathrm{IRQ}}\) is generated by any one of eight conditions: 2 Counter Overflows, 2 Positive Edge Detects, 2 Negative Edge Detects, and 2 Serial Port Conditions.

\subsection*{3.2 NEW INSTRUCTIONS}

In addition to the standard 6502 instruction set, four instructions have been added to the devices to simplify operations that previously required a read/modify/write operation. In order for these instructions to be equally applicable to any I/O ports, with or without mixed input and output functions, the I/O ports have been designed to read the contents of the specified port data register during the Read cycle of the read/ modify/write operation, rather than I/O pins as in normal read cycles. The added instructions and their format are explained in the following subparagraphs. Refer to Appendix A for the Op Code mnemonic addressing matrix for these added instructions.

\subsection*{3.2.1 Set Memory Bit (SMB m, Addr.)}

This instruction sets to " 1 " one of the 8 -bit data field specified by the zero page address (memory or I/O port). The first byte of the instruction specifies the SMB operation and 1 of 8 bits to be set. The second byte of the instruction designates address ( \(00-\mathrm{FF}\) ) of the byte or l/O port to be operated upon.

\subsection*{3.2.2 Reset Memory Bit (RMB m, Addr.)}

This instruction is the same operation and format as SMB instruction except a reset to " 0 " of the bit results.

\subsection*{3.2.3 Branch On Bit Set Relative (BBS m, Addr, DEST)}

This instruction tests one of 8 bits designated by a three bit immediate field within the first byte of the instruction. The second byte is used to designate the address of the byte to be tested within the zero page address range (memory or I/O ports). The third byte of the instruction is used to specify the 8 bit relative address to which the instruction branches if the bit tested is a " 1 ". If the bit tested is not set, the next sequential instruction is executed.

\subsection*{3.2.4 Branch On Bit Reset Relative (BBR m, Addr, DEST)}

This instruction is the same operation and format as the BBS instruction except that a branch takes place if the bit tested is a " 0 ".

\subsection*{3.3 READ-ONLY-MEMORY (ROM)}

In the R6500/11 or R6500/12 the ROM consists of 3072 bytes (3K) of mask programmable memory with an address space from F400 to FFFF. ROM locations FFFA through FFFF are assigned for interrupt and reset vectors.

In the R6500/15 the ROM consists of 4096 bytes ( 4 K ) of mask programmable memory with an address space from FOOO to FFFF. ROM locations FFFA through FFFF are assigned for interrupt and reset vectors.

\subsection*{3.4 RANDOM ACCESS MEMORY (RAM)}

The RAM consists of 192 bytes of read/write memory with an assigned page zero address of 0040 through 00FF. The R6500/11 provides a separate power pin ( \(V_{\text {RR }}\) ) which may be used for standby power for 32 bytes located at 0040-005F. In the event of the loss of \(V_{c c}\) power, the lowest 32 bytes of RAM data will be retained if standby power is supplied to the \(V_{\text {RA }}\) pin. If the RAM data retention is not required then \(V_{\text {RR }}\) must be connected to \(V_{C C}\). During operation \(V_{R R}\) must be at the \(V_{c c}\) level.

For the RAM to retain data upon loss of \(V_{C C}, V_{R R}\) must be supplied within operating range and RES must be driven low at least eight \(\emptyset 2\) clock pulses before \(\mathrm{V}_{\mathrm{cc}}\) falls out of operating range. \(\overline{\text { RES }}\) must then be held low while \(V_{c c}\) is out of operating range and until at least eight \(\emptyset 2\) clock cycles after \(\mathrm{V}_{\mathrm{cc}}\) is again within operating range and the internal \(\emptyset 2\) oscillator is stabilized. \(V_{R R}\) must remain within \(V_{C C}\) operating range during normal operation. When \(\mathrm{V}_{\mathrm{cc}}\) is out of operating range, \(V_{\text {RA }}\) must remain within the \(V_{R R}\) retention range in order to retain data. Figure 3.2 shows typical waveforms.
\[
\begin{aligned}
& \text { RAM OPERATING MODE RAM RETENTION MODE } \\
& 1 \text { INITIAL APPLICATION OF } V_{C C} \text { AND } V_{\text {RR }} \text {. } \\
& 2 \text { LOSS OF V }{ }_{\text {CC }} \text {, RAM ON STANDBY POWER. } \\
& 3 \text { REAPPLICATION OF } V_{C C} \text {. } \\
& 4>8 \mathbf{~} 2 \text { CLOCK PULSES AFTER OSCILLATOR STABILIZATION. } \\
& 5>8 \text { ¢ CLOCK PULSES. }
\end{aligned}
\]

Figure 3-2. Data Retention Timing

\subsection*{3.5 CLOCK OSCILLATOR}

Customer selectable mask options are available for controlling the device timing. It can be ordered with a crystal oscillator, a divide-by-2 or divide-by-4 countdown network and for clock master mode or clock slave mode operation.

\section*{Note:}

For 2 MHz internal operations the divide-by-two option must be specified.

The on-chip oscillator is designed for a parallel resonant crystal connected between XTLI and XTLO pins. The equivalent oscillator circuit is shown in Figure 3-3a.

A parallel resonant crystal is specified by its load capacitance and series resonant resistance. For proper oscillator operation, the load capacitance \(\left(\mathrm{C}_{\mathrm{L}}\right)\), series resistance \(\left(\mathrm{R}_{\mathrm{S}}\right)\) and the crystal resonant frequency ( \(F\) ) must meet the following two relations:
\[
\begin{gathered}
(C+27)=2 C_{\mathrm{L}} \quad \text { or } \quad \mathrm{C}=2 \mathrm{C}_{\mathrm{L}}-27 \mathrm{pF} \\
\mathrm{R}_{\mathrm{s}} \leq \mathrm{R}_{\mathrm{smax}}=\frac{2 \times 10^{6}}{\left(\mathrm{FC}_{\mathrm{L}}\right)^{2}}
\end{gathered}
\]
where: F is in MHz ; C and \(\mathrm{C}_{\mathrm{L}}\) are in \(\mathrm{pF} ; \mathrm{R}\) is in ohms.z

To select a parallel resonant crystal for the oscillator, first select the load capacitance from a crystal manufacturer's catalog. Next, calculate \(R_{\text {smax }}\) based on \(F\) and \(C_{L}\). The selected crystal must have a \(R_{s}\) less than the \(R_{\text {smax }}\).

A. CRYSTAL INPUT

B. CLOCK INPUTS

For example, if \(C_{L}=22 \mathrm{pF}\) for a 4 MHz parallel resonant crystal, then
\[
\begin{aligned}
& \mathrm{C}=(2 \times 22)-27=17 \mathrm{pF} \\
& \text { (use standard value of } 18 \mathrm{pF} \text { ) }
\end{aligned}
\]

The series resistance of the crystal must be less than
\[
R_{\text {smax }}=\frac{2 \times 10^{6}}{(4 \times 22)^{2}}=258 \text { ohms }
\]

Internal timing can also be controlled by driving the XTLI pin with an external frequency source. Figure 3-3b shows typical connections. If XTLO is left floating, the external source is divided by the internal countdown network. However, if XTLO is tied to \(\mathrm{V}_{\mathrm{SS}}\), the internal countdown network is bypassed causing the chip to operate at the frequency of the external source.

The operation described above assumed a CLOCK MASTER MODE mask option. In this mode a frequence souce (crystal or external source) must be applied to the XTLI and XTLO pins. \(\emptyset 2\) is a buffered output signal which closely approximates the internal timing. When a common external source is used to drive multiple devices the internal timing between devices as well as their \(\emptyset 2\) outputs will be skewed in time. If skewing represents a system problem it can be avoided by the Master/Slave connection and options shown in Figure 3-4.

One device is operated in the CLOCK MASTER MODE and a second in the CLOCK SLAVE MODE. Mask options in the SLAVE unit convert the \(\emptyset 2\) signal into a clock input pin which is tightly coupled to the internal timing generator. As a result the internal timing of the MASTER and SLAVE units are synchronized with minimum skew. If the \(\emptyset 2\) signal to the SLAVE unit is inverted, the MASTER and SLAVE UNITS WILL OPERATE OUT OF PHASE. This approach allows the two devices to share external memory using cycle stealing techniques.

Figure 3-4. Master/Slave Connections


\subsection*{3.6 MODE CONTROL REGISTER (MCR)}

The Mode Control Register contains control bits for the multifunction I/O ports and mode select bits for Counter A and Counter B. Its setting, along with the setting of the Serial Communications Control Register (SCCR), determines the basic configuration of the device in any application. Initializing this register is one of the first actions of any software program. The Mode Control Register bit assignment is shown in Figure 3-5.


Figure 3-5. Mode Control Register
The use of Counter A Mode Select is shown in Section 6.1.
The use of Counter B Mode Select is shown in Section 6.2.
The use of Port B Latch Enable is shown in Section 4.4.
The use of Port D in Tri-State Enable is shown in Section 4.6.

The use of Bus Mode Select is shown in Section 4.5 and 4.6.

\subsection*{3.7 INTERRUPT FLAG REGISTER (IFR) AND INTERRUPT ENABLE REGISTER (IER)}

An \(\overline{R Q}\) interrupt request can be initiated by any or all of eight possible sources. These sources are all capable of being enabled or disabled by the use of the appropriate interrupt enabled bits in the Interrupt Enable Register (IER). Multiple simultaneous interrupts will cause the \(\overline{\mathrm{IRQ}}\) interrupt request to remain active until all interrupting conditions have been serviced and cleared.

The Interrupt Flag Register contains the information that indicates which I/O or counter needs attention. The contents of the Interrupt Flag Register may be examined at any time by reading at address: 0011. Edge detect IFR bits may be cleared by executing a RMB instruction at address location 0010. The RMB X, (0010) instruction reads FF, modifies bit \(X\) to a " 0 ", and writes the modified value at address location 0011. In this way IFR bits set to a " 1 " after the read cycle of a Read-Modify-Write instruction (such as RMB) are protected from being cleared. A logic "1" is ignored when writing to edge detect IFR bits.

Each IFR bit has a corresponding bit in the Interrupt Enable Register which can be set to a "1" by writing a "1" in the respective bit position at location 0012. Individual IER bits may be cleared by writing a " 0 " in the respective bit position, or by RES. If set to a " 1 ", an IRQ will be generated when the corresponding IFR bit becomes true. The Interrupt Flag Register and Interrupt Enable Register bit assignments are shown in Figure 3-6 and the functions of each bit are explained in Table 3-1.


Figure 3-6. Interrupt Enable and Flag Registers

Table 3-1. Interrupt Flag Register Bit Codes
\begin{tabular}{|c|c|}
\hline \[
\begin{gathered}
\text { BIT } \\
\text { CODE }
\end{gathered}
\] & FUNCTION \\
\hline IFR 0: & PAO Positive Edge Detect Flag-Set to a " 1 " when a positive going edge is detected on PAO. Cleared by RMB 0 (0010) instruction or by \(\overline{\text { RES }}\). \\
\hline IFR 1: & PA1 Positive Edge Detect Flag-Set to a 1 when a positive going edge is detected on PA1. Cleared by RMB 1 (0010) instruction or by \(\overline{\text { RES. }}\) \\
\hline IFR 2: & PA2 Negative Edge Detect Flag-Set to a 1 when a negative going edge is detected on PA2. Cleared by RMB \(2(0010)\) instruction or by \(\overline{\text { RES }}\). \\
\hline IFR 3: & PA3 Negative Edge Detect Flag-Set to 1 when a negative going edge is detected on PA3. Cleared by RMB 3 (0010) instruction or by \(\overline{R E S}\). \\
\hline IFR 4: & Counter A Underflow Flag-Set to a 1 when Counter A underflow occurs. Cleared by reading the Lower Counter \(A\) at location 0018, by writing to address location 001A, or by RES. \\
\hline IFR 5: & Counter B Underflow Flag-Set to a 1 when Counter B underflow occurs. Cleared by reading the Lower Counter B at location 001C, by writing to address location 001E, or by \(\overline{\text { RES }}\). \\
\hline IFR 6: & Receiver Interrupt Flag-Set to a 1 when any of the Serial Communication Status Register bits 0 through 3 is set to a 1 . Cleared when the Receiver Status bits (SCSR 0-3) are cleared or by RES. \\
\hline IFR 7: & Transmitter Interrupt Flag-Set to a 1 when SCSR 6 is set to a 1 while SCSR 5 is a 0 or SCSR 7 is set to a 1 . Cleared when the Transmitter Status bits (SCSR \(6 \& 7\) ) are cleared or by RES. \\
\hline
\end{tabular}

\subsection*{3.8 PROCESSOR STATUS REGISTER}

The 8-bit Processor Status Register, shown in Figure 3-7, contains seven status flags. Some of these flags are controlled by the user program; others may be controlled both by the user's program and the CPU. The R6502 instruction set contains a number of conditional branch instructions which are designed to allow testing of these flags. Each of the eight processor status flags is described in the following sections.

\subsection*{3.8.1 Carry Bit (C)}

The Carry Bit (C) can be considered as the ninth bit of an arithmetic operation. It is set to logic 1 if a carry from the eighth bit has occurred or cleared to logic 0 if no carry occurred as the result of arithmetic operations.

The Carry Bit may be set or cleared under program control by use of the Set Carry (SEC) or Clear Carry (CLC) instruction, respectively. Other operations which affect the Carry Bit are ADC, ASL, CMP, CPX, CPY, LSR, PLP, ROL, ROR, RTI, and SBC.

\subsection*{3.8.2 Zero Bit (Z)}

The Zero Bit \((Z)\) is set to logic 1 by the CPU during any data movement or calculation which sets all 8 bits of the result to
zero. This bit is cleared to logic 0 when the resultant 8 bits of a data movement or calculation operation are not all zero. The R6500 instruction set contains no instruction to specifically set or clear the Zero Bit. The Zero Bit is, however, affected by the following instructions; ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, 'LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TXA, TSX, and TYA.

\subsection*{3.8.3 Interrupt Disable Bit (I)}

The interrupt Disable Bit (I) is used to control the servicing of an interrupt request ( \(\overline{\mathrm{IRQ}})\). If the I Bit is reset to logic 0 , the \(\overline{\mathrm{RQ}}\) signal will be serviced. If the bit is set to logic 1 , the \(\overline{\mathrm{IRQ}}\) signal will be ignored. The CPU will set the Interrupt Disable Bit to logic 1 if a RESET ( \(\overline{\mathrm{RES}}\) ), \(\overline{\mathrm{RQ}}\), or Non-Maskable interrupt ( \(\overline{\mathrm{NMI}}\) ) signal is detected.

The I bit is cleared by the Clear Interrupt Mask Instruction (CLI) and is set by the Set Interrupt Mask Instruction (SEI). This bit is set by the BRK Instruction. The Return from Interrupt (RTI) and Pull Processor Status (PLP) instructions will also affect the I bit.


Figure 3-7. Processor Status Register

\subsection*{3.8.4 Decimal Mode Bit (D)}

The Decimal Mode Bit (D), is used to control the arithmetic mode of the CPU. When this bit is set to logic 1 , the adder operates as a decimal adder. When this bit is cleared to logic 0 , the adder operates as a straight binary adder. The adder mode is controlled only by the programmer. The Set Decimal Mode (SED) instruction will set the D bit; the Clear Decimal Mode (CLD) instruction will clear it. The PLP and RTI instructions also effect the Decimal Mode Bit.

\section*{CAUTION}

The Decimal Mode Bit will either set or clear in an unpredictable manner upon power application. This bit must be initialized to the desired state by the user program or erroneous results may occur.

\subsection*{3.8.5 Break Bit (B)}

The Break Bit ( \(B\) ) is used to determine the condition which caused the \(\overline{\mathrm{RQ}}\) service routine to be entered. If the \(\overline{\mathrm{RQ}}\) service routine was entered because the CPU executed a BRK command, the Break Bit will be set to logic 1. If the IRQ routine was entered as the result of an \(\overline{\operatorname{RQ}}\) signal being generated, the B bit will be cleared to logic 0 . There are no instructions which can set or clear this bit.

\subsection*{3.8.6 Overflow Bit (V)}

The Overflow Bit ( \(V\) ) is used to indicate that the result of a signed, binary addition, or subtraction, operation is a value that cannot be contained in seven bits ( \(-128 \leqslant n \leqslant 127\) ).

This indicator only has meaning when signed arithmetic (sign and seven magnitude bits) is performed. When the ADC or SBC instruction is performed, the Overflow Bit is set to logic 1 if the polarity of the sign bit (bit 7 ) is changed because the result exceeds +127 or -128 ; otherwise the bit is cleared to logic 0 . The V bit may also be cleared by the programmer using a Clear Overflow (CLV) instruction.

The Overflow Bit may also be used with the BIT instruction. The BIT instruction which may be used to sample interface devices, allows the overflow flag to reflect the condition of bit 6 in the sampled field. During a BIT instruction the Overflow Bit is set equal to the content of the bit 6 on the data tested with BIT instruction. When used in this mode, the overflow has nothing to do with signed arithmetic, but is just another sense bit for the microprocessor. Instructions which affect the V flag are ADC, BIT, CLV, PLP, RTI and SBC.

\subsection*{3.8.7 Negative Bit ( \(N\) )}

The Negative Bit \((\mathrm{N})\) is used to indicate that the sign bit (bit 7), in the resulting value of a data movement or data arithmetic operation, is set to logic 1 . If the sign bit is set to logic 1 , the resulting value of the data movement or arithmetic operation is negative; if the sign bit is cleared, the result of the data movement or arithmetic operation is positive. There are no instructions that set or clear the Negative Bit since the Negative Bit represents only the status of a result. The instructions that effect the state of the Negative Bit are: ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TSX, TXA, and TYA.

\section*{SECTION 4 PARALLEL INPUT/OUTPUT PORTS}

The R6500/11 or R6500/15 has 32 I/O lines grouped into four 8 -bit ports (PA, PB, PC, and PD). Ports A through C may be used either for input or output individually or in groups of any combination. Port D may be used as all inputs or all outputs.

The R6500/12, a 64-pin QUIP device, has three additional ports: PE, PF and PG. PE is outputs only; PF and PG are bidirectional.

Multifunction I/O's such as Port A and Port C are protected from normal port I/O instructions when they are programmed to perform a multiplexed function.

Internal pull-up resistors (FET's with an impedance range of \(3 \mathrm{~K} \leqslant \mathrm{Rpu} \leqslant 12 \mathrm{~K}\) ohm) may be provided on all port pins except Port D and E as a mask option.

The direction of the I/O lines are controlled by four 8-bit port registers located in page zero. This arrangement provides quick programming access using simple two-byte zero page address instructions. There are no direction registers associated with the I/O ports, which simplifies I/O handling. The I/O addresses are shown in Table 4-1. Section E. 6 shows the I/O Port Timing.

Table 4-1. I/O Port Addresses
\begin{tabular}{|cc|}
\hline Port & Address \\
\hline A & 0000 \\
B & 0001 \\
C & 0002 \\
D & 0003 \\
E & 0004 \\
F & 0005 \\
G & 0006 \\
\hline
\end{tabular}

\subsection*{4.1 INPUTS}

Inputs for Ports A, B, and C and also Ports F and G of the R6500/12 are enabled by loading logic 1 into all I/O port register bit positions that are to correspond to I/O input lines. A low ( \(<0.8 \mathrm{~V}\) ) input signal will cause a logic 0 to be read when a read instruction is issued to the port register. A high ( \(>2.0 \mathrm{~V}\) ) input will cause a logic 1 to be read. An RES signal forces all I/O port registers to logic 1 thus initially treating all I/O lines as inputs.

Port D may only be all inputs or all outputs. All inputs is selected by setting bit 5 of the Mode Control Register (MCR5) to a " 0 ".

The status of the input lines can be interrogated at any time by reading the \(/ / O\) port addresses. Note that this will return the actual status of the input lines, not the data written into the I/O port registers.

Read/Modify/Write instructions can be used to modify the operation of PA, PB, PC, \& PD and also ports PF and PG of the R6500/12. During the Read cycle of a Read/Modify/ Write instruction the Port I/O register is read. For all other read instructions the port input lines are read. Read/Modify/ Write instructions are: ASL, DEC, INC, LSR, RMB, ROL, ROR, and SMB.

\subsection*{4.2 OUTPUTS}

Outputs for Ports A thru D and Ports E thru G of the R6500/12 are controlled by writing the desired I/O line output states into the corresponding I/O port register bit positions. A logic 1 will force a high ( \(>2.4 \mathrm{~V}\) ) output while a logic 0 will force a low ( \(<0.4 \mathrm{~V}\) ) output.

Port D all outputs is selected by setting MCR5 to a " 1 ".
Port E is always all outputs.

\subsection*{4.3 PORT A (PA)}

Port A can be programmed via the Mode Control Register (MCR) and the Serial Communications Control Register (SCCR) as a standard parallel 8 -bit, bit independent, l/O port or as serial channel I/O lines, counter I/O lines, or an input data strobe for the Port B input latch option. Table 4-2 tabulates the control and usage of Port \(A\).

In addition to their normal I/O functions, PAO and PA1 can detect positive going edges, and PA2 and PA3 can detect negative going edges. A proper transition on these pins will set a corresponding status bit in the IFR and generate an interrupt request if the respective Interrupt Enable Bit is set The maximum rate at which an edge can be detected is onehalf the 02 clock rate. Edge detection timing is shown in Section E. 5 .

Table 4-2. Port A Control \& Usage


\subsection*{4.4 PORT B (PB)}

Port \(B\) can be programmed as an 8 bit, bit independent \(I / O\) port. It has a latched input capability which may be enabled or disabled via the Mode Control Register (MCR). Table 4-3 tabulates the control and usage of Port B. An Input Data Strobe signal must be provided thru PAO when Port B is programmed to be used with latched input option. Input data latch timing for Port B is shown in Section E.5.

Table 4-3. Port B Control \& Usage
\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[b]{4}{*}{Pin Name} & \multicolumn{2}{|c|}{I/O Mode} & \multicolumn{2}{|c|}{Latch Mode} \\
\hline & \multicolumn{2}{|r|}{MCR4 \(=0\)} & \multicolumn{2}{|r|}{\begin{tabular}{l}
\[
\text { MCR4 }=1
\] \\
(2)
\end{tabular}} \\
\hline & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} \\
\hline & Name & Type (1) & Name & Type \\
\hline PB0 & PBO & I/O & PBO & INPUT \\
\hline PB1 & PB1 & I/O & PB1 & INPUT \\
\hline PB2 & PB2 & \(1 / 0\) & PB2 & INPUT \\
\hline PB3 & PB3 & 1/0 & PB3 & INPUT \\
\hline PB4 & PB4 & 1/O & PB4 & INPUT \\
\hline PB5 & PB5 & 1/0 & PB5 & INPUT \\
\hline PB6 & PB6 & I/O & PB6 & INPUT \\
\hline PB7 & PB7 & I/O & PB7 & INPUT \\
\hline
\end{tabular}
(1) Resistive pull-up, active buffer pull down
(2) Input data is stored in port B latch by PAO pulse

\subsection*{4.5 PORT C (PC)}

Port C can be programmed as an I/O port and in conjunction with Port D, as an abbreviated bus, or as a multiplexed bus. When used in the abbreviated or multiplexed bus modes, PC0-PC7 function as A0-A3, A12, R/W, A13, and EMS, respectively, as shown in Table 4-4. EMS (External Memory Select) is asserted (low) whenever the internal processor accesses memory area between 0100 and 3FFF. (See Memory Map, Appendix B). The leading edge of EMS may be used to strobe the eight address lines multiplexed on Port D in the Multiplexed Bus Mode. See Appendix E. 3 through E. 5 for Port C timing.

\subsection*{4.6 PORT D (PD)}

Port D can be programmed as an I/O Port, an 8-bit tri-state data bus, or as a multiplexed bus. Mode selection for Port \(D\) is made by the Mode Control Register (MCR). The Port D
output drivers can be selected as tri-state drivers by setting bit 5 of the MCR to 0 (zero). Table 4-5 shows the necessary settings for the MCR to achieve the various modes for Port \(D\). When Port \(D\) is selected to operate in the Abbreviated Mode PDO-PD7 serves as data register bits D0-D7. When Port D is selected to operate in the Multiplexed Mode data bits D0 through D7 are time multiplexed with address bits A4 through A11, respectively. Refer to the Memory Maps (Appendix C) for Abbreviated and Multiplexed memory assignments. See Appendix E. 3 through E. 5 for Port D timing.

\subsection*{4.7 PORT E, PORT F AND PORT G (PE, PF \& PG R6500/12 ONLY}

Port E only operates in the Output mode. It provides a Darlington output that can source current at the high (1) level. Port F and Port G operate identically and can be programmed as bidirectional I/O ports. They have standard output capability. See Appendix E. 5 for Port E, F \& Port G timing.

\subsection*{4.8 BUS MODES}

In the Abbreviated Bus Mode, Port C and Port D are automatically transformed into an abbreviated address bus and control signals (Port C) and a bidirectional data bus (Port D). 64 Peripheral addresses can be selected. In general usage, these 64 addresses would be distributed to several external I/O devices such as R6522 and R6520, etc., each of which may contain more than one unique address.

In the Multiplexed Bus Mode, the operation is similar to the Abbreviated Mode except that a full 16 K of external addresses are provided. Port C provides the lower addresses and control signals. Port D multiplexes functions. During the first half of the cycle it contains the remaining necessary 8 address bits for 16 K ; during the second half of the cycle it contains a bidirectional data bus. The address bits appearing on Port D must be latched into an external holding register. The leading edge of \(\overline{\mathrm{EMS}}\), which indicates that the bus function is active, may be used for this purpose.

MCR5 must be a logic 1 in the Abbreviated and Multiplexed Bus Modes.

Figures 4-1a through 4-1c show the possible configurations of the four bus modes.

A. NORMAL BUS MODE


Figure 4-1. Bus Mode Configurations

Table 4-4. Port C Control and Usage
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{4}{*}{Pin Name} & \multicolumn{2}{|c|}{I/O Mode} & \multicolumn{2}{|c|}{Abbreviated Mode} & \multicolumn{2}{|c|}{Multiplexed Mode} \\
\hline & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=0 \\
& \text { MCR6 }=\mathrm{X}
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=0
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=1
\end{aligned}
\]} \\
\hline & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} \\
\hline & Name & \begin{tabular}{l}
Type \\
(1)
\end{tabular} & Name & \begin{tabular}{l}
Type \\
(2)
\end{tabular} & Name & \begin{tabular}{l}
Type \\
(2)
\end{tabular} \\
\hline PC0 & PCO & I/O & A0 & OUTPUT & A0 & OUTPUT \\
\hline PC 1 & PC1 & 1/0 & A1 & OUTPUT & A1 & OUTPUT \\
\hline PC2 & PC2 & 1/0 & A2 & OUTPUT & A2 & OUTPUT \\
\hline PC3 & РС3 & 1/0 & A3 & OUTPUT & A3 & OUTPUT \\
\hline PC4 & PC4 & 1/0 & A12 & OUTPUT & A12 & OUTPUT \\
\hline PC5 & PC5 & 1/0 & R/W & OUTPUT & \(\mathrm{R} \overline{\mathrm{W}}\) & OUTPUT \\
\hline PC6 & PC6 & 1/0 & A13 & OUTPUT & A13 & OUTPUT \\
\hline PC7 & PC7 & \(1 / 0\) & EMS & OUTPUT & EMS & OUTPUT \\
\hline \multicolumn{7}{|l|}{\begin{tabular}{l}
(1) Resistive Pull-Up, Active Buffer Pull-Down \\
(2) Active Buffer Pull-Up and Pull-Down
\end{tabular}} \\
\hline
\end{tabular}

Table 4-5. Port D Control and Usage
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{5}{*}{\[
\begin{aligned}
& \text { Pin } \\
& \text { Name }
\end{aligned}
\]} & \multicolumn{4}{|c|}{1/O Modes} & \multicolumn{2}{|r|}{Abbreviated Mode} & \multicolumn{4}{|c|}{Multiplexed Mode} \\
\hline & \multicolumn{2}{|r|}{\[
\begin{aligned}
& \text { MCR7 }=0 \\
& \text { MCR6 }=0 \\
& \text { MCR5 }=0
\end{aligned}
\]} & \multicolumn{2}{|r|}{\[
\begin{aligned}
& \text { MCR7 }=0 \\
& \text { MCR6 }=\mathrm{x} \\
& \text { MCR5 }=1
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=0 \\
& \text { MCR5 }=1
\end{aligned}
\]} & \multicolumn{4}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR5 }=1 \\
& \text { MCR5 }=1
\end{aligned}
\]} \\
\hline & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} \\
\hline & \multirow[b]{2}{*}{Name} & \multirow[b]{2}{*}{Type (1)} & \multirow[b]{2}{*}{Name} & \multirow[b]{2}{*}{Type (2)} & \multirow[b]{2}{*}{Name} & \multirow[b]{2}{*}{Type (3)} & \multicolumn{2}{|c|}{Phase 1} & \multicolumn{2}{|c|}{Phase 2} \\
\hline & & & & & & & Name & Type (2) & Name & Type (3) \\
\hline PDO & PDO & INPUT & PDO & OUTPUT & DATAO & \(1 / 0\) & A4 & OUTPUT & DATAO & 110 \\
\hline PD1 & PD1 & INPUT & PD1 & OUTPUT & DATA1 & I/O & A5 & OUTPUT & DATA1 & \(1 / 0\) \\
\hline PD2 & PD2 & INPUT & PD2 & OUTPUT & DATA2 & I/O & A6 & OUTPUT & DATA2 & \(1 / 0\) \\
\hline PD3 & PD3 & INPUT & PD3 & OUTPUT & DATA3 & I/O & A7 & OUTPUT & DATA3 & \(1 / 0\) \\
\hline PD4 & PD4 & INPUT & PD4 & OUTPUT & DATA4 & I/O & A8 & OUTPUT & DATA4 & \(1 / 0\) \\
\hline PD5 & PD5 & INPUT & PD5 & OUTPUT & DATA5 & I/O & A9 & OUTPUT & DATA5 & \(1 / 0\) \\
\hline PD6 & PD6 & INPUT & PD6 & OUTPUT & DATA6 & I/O & A10 & OUTPUT & DATA6 & \(1 / 0\) \\
\hline PD7 & PD7 & INPUT & PD7 & OUTPUT & DATA7 & 1/0 & A11 & OUTPUT & DATA7 & \(1 / 0\) \\
\hline \multicolumn{11}{|l|}{\multirow[t]{2}{*}{\begin{tabular}{l}
(1) Tri-State Buffer is in High Impedance Mode \\
(2) Tri-State Buffer is in Active Mode \\
(3) Tri-State Buffer is in Active Mode Only During the Phase 2 Portion of a Write Cycle
\end{tabular}}} \\
\hline & & & & & & & & & & \\
\hline
\end{tabular}

\section*{SECTION 5 SERIAL INPUT/OUTPUT CHANNEL}

The device provides a full duplex Serial I/O channel with programmable bit rates and operating modes. The serial I/O functions are controlled by the Serial Communication Control Register (SCCR). The SCCR bit assignment is shown in Figure 5-1. The serial bit rate is determined by Counter A for all modes except the Receiver Shift Register (RCVR S/R) mode for which an external shift clock must be provided. The maximum data rate using the internal clock is 62.5 K bits per second (@ \(\emptyset 2=1 \mathrm{MHz}\) ). The transmitter (XMTR) and receiver (RCVR) can be independently programimed to operate in different modes and can be independently enabled or disabled.


Figure 5-1. Serial Communication Control Register
Except for the Receiver Shift Register Mode (RCVR S/R), all XMTR and RCVR bit rates will occur at one sixteenth of the Counter A interval timer rate. Counter A is forced into an interval timer mode whenever the serial I/O is enabled in a mode requiring an internal clock.

Whenever Counter A is required as a timing source it must be loaded with the hexadecimal code that selects the data rate for the serial I/O Port. Refer to Counter A (paragraph 6.1 ) for a table of hexadecimal values to represent the desired data rate.

\subsection*{5.1 TRANSMITTER OPERATION (XTMR)}

The XTMR operation and the transmitter related control/ status functions are enabled by bit 7 of the Serial Communications Control Register (SCCR). The transmitter, when in the Asynchronous (ASYN) mode, automatically adds a start bit, one or two stop bits, and, when enabled, a parity bit to the transmitted data. A word of transmitted data (in asynchronous parity mode) can have \(5,6,7\), or 8 bits of data. The nine data modes are in Figure 5-2. When parity is disabled, the \(5,6,7\) or 8 bits of data are terminated with two stop bits.


Figure 5-2. Transmitted Data Modes
In the S/R mode, eight data bits are always shifted out. Bits/ character and parity control bits are ignored. The serial data is shifted out via the SO output (PA6) and the shift clock is available at the CA (PA4) pin. When the transmitter underruns in the S/R mode the SO output and shift clock are held in a high state.

The XMTR Interrupt Flag bit (IFR7) is controlled by Serial Communication Status Register bits SCSR5, SCSR6 and SCSR7.
\[
\text { IFR7 }=\text { SCSR6 }(\overline{\text { SCSR5 }}+\text { SCSR7 })
\]

\subsection*{5.2 RECEIVER OPERATION (RCVR)}

The receiver and its selected control and status functions are enabled when SCCR-6 is set to a "1." In the ASYN mode, data format must have a start bit, appropriate number of data bits, a parity bit (if enabled) and one stop bit. Refer to paragraph 5.1 for a diagram of bit allocations. The receiver bit period is divided into 8 sub-intervals for internal synchronization. The receiver bit stream is synchronized by the start bit and a strobe signal is generated at the approximate center of each incoming bit. Refer to Figure 5-3 for ASYN Receive Data Timing. The character assembly process does not start if the start bit signal is less than one-nalf the bit time after a low level is detected on the Receive Data Input. Framing error, over-run, and parity error conditions or a RCVR Data Register Full will set the appropriate status bits, and any of the above conditions will cause an Interrupt Request if the Receiver Interrupt Enable bit is set to logic 1.


Figure 5-3. ASYN Receive Data Timing
In the S/R mode, an external shift clock must be provided at CA (PA4) pin along with 8 bits of serial data (LSB first) at the SI input (PA7). The maximum data rate using an external shift clock is one-eighth the internal clock rate. Refer to Figure 5-4 for S/R Mode Timing.


Figure 5-4. S/R Mode Timing
A RCVR interrupt (IFR6) is generated whenever any of SCSRO-3 are true.

\subsection*{5.3 SERIAL COMMUNICATION STATUS REGISTER (SCSR)}

The Serial Communication Status Register (SCSR) holds information on various communication error conditions, status of the transmitter and receiver data registers, a transmitter end-of-transmission condition, and a receiver idle line condition (Wake-Up Feature). The SCSR bit assignment is shown in Figure 5-5. Bit assignments and functions of the SCSR are as follows:

SCSRO: Receiver Data Register Full -Set to a logic 1 when a character is transferred from the Receiver Shift Register to the Receiver Data Register. This bit is cleared by reading the Receiver Data Register, or by \(\overline{\text { RES }}\) and is disabled if SCCR6 \(=0\). The SCSR 0 bit will not be set to a logic 1 if the received data contains an error condition, instead, a corresponding error bit will be set to a logic 1 .

SCSR1: Over-Run Error-Set to a logic 1 when a new character is transferred from the Receiver Shift Register, with the last character still in the Receiver Data Register. This bit is cleared by reading the Receiver Data Register, or by \(\overline{\text { RES }}\).

SCSR2: Parity Error-Set to logic 1 when the RCVR is in the ASYN Mode, Parity Enable bit is set, and the
received data has a parity error. This bit is cleared by reading the Receiver Data Register or by \(\overline{\text { RES }}\).
SCSR3: Framing Error-Set to a logic 1 when the received data contains a zero bit after the last data or parity bit in the stop bit slot. Cleared by reading the Receiver Data Register or by RES. (ASYN Mode only).
SCSR4: Wake-Up-Set to a logic 1 by writing a " 1 " in bit 4 of address: 0016. The Wake-Up bit is cleared by \(\overline{\mathrm{RES}}\) or when the receiver detects a string of ten consecutive 1's. When the Wake-Up bit is set SCSR0 through SCSR3 are inhibited.
SCSR5: End of Transmission-Set to a logic 1 by writing a " 1 " in bit position 5 of address: 0016. The End of Transmission bit is cleared by RES or upon writing a new data word into the Transmitter Data Register. When the End-of-Transmission bit is true the Transmitter Register Empty bit is disabled until a Transmitter Under-Run occurs.
SCSR6: Transmitter Data Register Empty-Set to a logic 1 when the contents of the Transmitter Data Register is transferred to the Transmitter Shift Register. Cleared upon writing new data into the Transmit Data Register. This bit is initialized to a logic 1 by RES.
SCSR7: Transmitter Under-Run-Set to a logic 1 when the last data bit is transmitted if the transmitter is in a S/R Mode or when the last stop bit is transmitted if the XMTR is in the ASYN Mode while the Transmitter Data Register Empty Bit is set. Cleared by a transfer of new data into the Transmitter Shift Register, or by RES.


Figure 5-5. SCSR Bit Allocation

\subsection*{5.4 WAKE-UP FEATURE}

In a multi-distributed microprocesso or microcomputer applications, a destination address is usualiy included at the beginning of the message. The Wake-Up Feature allows non-selected CPU's to ignore the remainder of the message until the beginning of the next message by setting the WakeUp bit. As long as the Wake-Up flag is true, the Receiver Data Register Full Flag remains false. The Wake-Up bit is automatically cleared when the receiver detects a string of eleven consecutive 1's which indicates an idle transmit line. When the next byte is received, the Receiver Data Register Full Flag signals the CPU to wake-up and read the received data.

\section*{SECTION 6 COUNTER/TIMERS}

The device contains two 16 -bit counters (Counter A and Counter B) and three 16 -bit latches associated with the counters. Counter A has one 16 -bit latch and Counter B has two 16 -bit latches. Each counter can be independently programmed to operate in one of four modes:

\section*{Counter A}
- Pulse width measurement
- Pulse Generation
- Interval Timer
- Event Counter

\section*{Counter B}
- Retriggerable Interval Counter
- Asymmetrical Pulse Generation
- Interval Timer
- Event Counter

Operating modes of Counter A and Counter B are controlled by the Mode Control Register. All counting begins at the initialization value and decrements. When modes are selected requiring a counter input/output line, PA4 is automatically selected for Counter A and PA5 is automatically selected for Counter B (see Table 4.2).

\subsection*{6.1 COUNTER A}

Counter A consists of a 16 -bit counter and a 16 -bit latch organized as follows: Lower Counter A (LCA), Upper Counter A (UCA), Lower Latch A (LLA), and Upper Latch A (ULA). The counter contains the count of either \(\phi 2\) clock pulses or external events, depending on the counter mode selected. The contents of Counter A may be read any time by executing a read at location 0019 for the Upper Counter A and at location 001 A or location 0018 for the Lower Counter A. A read at location 0018 also clears the Counter A Underflow Flag (IFR4).

The 16 -bit latch contains the counter initialization value, and can be loaded at any time by executing a write to the Upper Latch A at location 0019 and the Lower Latch A at location 0018. In either case, the contents of the accumulator are copied into the applicable latch register.

Counter A can be started at any time by writing to address: 001 A . The contents of the accumulator will be copied into the


Figure 6-1. Interval Timer Timing Diagram

Upper Latch A before the contents of the 16-bit latch are transferred to Counter A. Counter \(A\) is set to the latch value whenever Counter A underflows. When Counter A decrements from 0000 the next counter value will be the latch value, not FFFF, and the Counter A Underflow Flag (IFR 4) will be set to " 1 ". This bit may be cleared by reading the Lower Counter A at location 0018, by writing to address location 001A, or by RES.

Counter A operates in any of four modes. These modes are selected by the Counter A Mode Control bits in the Control Register.
\begin{tabular}{|c|c|l|}
\hline \begin{tabular}{c} 
MCR1 \\
(bit 1)
\end{tabular} & \begin{tabular}{l} 
MCR0 \\
(bit 0)
\end{tabular} & \multicolumn{1}{|c|}{ Mode } \\
\hline 0 & 0 & Interval Timer \\
0 & 1 & Pulse Generation \\
1 & 0 & Event Counter \\
1 & 1 & Pulse Width Measurement \\
\hline
\end{tabular}

The Interval Timer, Pulse Generation, and Pulse Width Measurement Modes are \(\phi 2\) clock counter modes. The Event Counter Mode counts the occurrences of an external event on the CNTR line.

The Counter is set to the Interval Timer Mode (00) when a \(\overline{R E S}\) signal is generated.

\subsection*{6.1.1 Interval Timer}

In the Interval Timer mode the Counter is initialized to the Latch value by either of two conditions:
1. When the Counter is decremented from 0000 , the next Counter value is the Latch value (not FFFF).
2. When a write operation is performed to the Load Upper Latch and Transfer Latch to Counter address 001A, the Counter is loaded with the Latch value. Note that the contents of the Accumulator are loaded into the Upper Latch before the Latch value is transferred to the Counter.

The Counter value is decremented by one count at the \(\emptyset 2\) clock rate. The 16 -bit Counter can hold from 1 to 65535 counts. The Counter Timer capacity is therefore \(1 \mu \mathrm{~s}\) to 65.535 ms at the \(1 \mathrm{MHz} \phi 2\) clock rate or \(0.5 \mu \mathrm{~s}\) to 32.767 ms at the \(2 \mathrm{MHz} \emptyset 2\) clock rate. Time intervals greater than the maximum Counter value can be easily measured by counting \(\overline{\mathrm{IRQ}}\) interrupt requests in the counter \(\overline{\mathrm{RQ}}\) interrupt routine.

When Counter A decrements from 0000, the Counter A Underflow (IFR4) is set to logic 1 . If the Counter A Interrupt Enable Bit (IER4) is also set, an \(\overline{\operatorname{RQ}}\) interrupt request will be generated. The Counter A Underflow bit in the Interrupt Flag Register can be examined in the \(\overline{\mathrm{RQ}}\) interrupt routine to determine that the \(\overline{\mathrm{RQ}}\) was generated by the Counter A Underflow.

While the timer is operating in the Interval Timer Mode, PA4 operates as a PA I/O bit.

A timing diagram of the Interval Timer Mode is shown in Figure 6-1.

\subsection*{6.1.2 Pulse Generation Mode}

In the Pulse Generation mode, the CA line operates as a Counter Output. The line toggles from low to high or from high to low whenever a Counter A Underflow occurs, or a write is performed to address 001A.

The normal output waveform is a symmetrical square-wave. The CA output is initialized high when entering the mode and transitions low when writing to 001A.

Asymmetric waveforms can be generated if the value of the latch is changed after each counter underflow.

A one-shot waveform can be generated by changing from Pulse Generation to Interval Timer mode after only one occurrence of the output toggle condition.

\subsection*{6.1.3 Event Counter Mode}

In this mode the CA is used as an Event Input line, and the Counter will decrement with each rising edge detected on this line. The maximum rate at which this edge can be detected is one-half the \(\phi 2\) clock rate.

The Counter can count up to 65,535 occurrences before underflowing. As in the other modes, the Counter A Underflow bit (IER4) is set to logic 1 if the underflow occurs.

Figure 6.2 is a timing diagram of the Event Counter Mode.


Figure 6-2. Event Counter Mode

\subsection*{6.1.4 Pulse Width Measurement Mode}

This mode allows the accurate measurement of a low pulse duration on the CA line. The Counter decrements by one count at the \(\varnothing 2\) clock rate as long as the CA line is held in the low state. The Counter is stopped when CA is in the high state.

The Counter A underflow flag will be set only when the count in the timer reaches zero. Upon reaching zero the timer will be loaded with the latch value and continue counting down as long as the CA pin is held low. After the counter is stopped by a high level on CA, the count will hold as long as CA remains high. Any further low levels on CA will again cause the counter to count down from its present value. The state of the CA line can be determined by testing the state of PA4.

A timing diagram for the Pulse Width Measurement Mode is shown in Figure 6.3.


Figure 6-3. Pulse Width Measurement

\subsection*{6.1.5 Serial I/O Data Rate Generation}

Counter A also provides clock timing for the Serial I/O which establishes the data rate for the Serial I/O port. When the Serial I/O is enabled, Counter A is forced to operate at the internal clock rate. Counter \(A\) is not required for the RCVR S/R mode. The Counter I/O (PA4) may also be required to support the Serial I/O (see Table 4-2).

Table 6-1 identifies the values to be loaded in Counter A for selecting standard data rates with a \(\phi 2\) clock rate of 1 MHz and 2 MHz . Although Table 6-1 identifies only the more common data rates, any data rate from 1 to 62.5 K bps can be selected by using the formula:
\[
N=\frac{\phi 2}{16 \times \mathrm{bps}}-1
\]
where
\(\mathrm{N} \quad=\) decimal value to be loaded into Counter A using its hexadecimal equivalent.
\(\phi 2=\) the clock frequency ( 1 MHz or 2 MHz )
\(\mathrm{bps}=\) the desired data rate.

\section*{NOTE}

In Table 6-1 you will notice that the standard data rate and the actual data rate may be slightly different. Transmitter and receiver errors of \(1.5 \%\) or less are acceptable. A revised clock rate is included in Table 6-1 for those baud rates which fall outside this limit.

Table 6-1. Counter A Values for Baud Rate Selection
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{Standard Baud Rate} & \multicolumn{2}{|l|}{Hexadecimal Value} & \multicolumn{2}{|l|}{\begin{tabular}{l}
Actual \\
Baud \\
Rate \\
At
\end{tabular}} & \multicolumn{2}{|l|}{Clock Rate Needed To Get Standard Baud Rate} \\
\hline & 1 MHz & 2 MHz & 1 MHz & 2 MHz & 1 MHz & 2 MH \\
\hline 50 & 04E1 & 09C3 & 50.00 & 50.00 & 1.0000 & 2.0000 \\
\hline 75 & 0340 & 0682 & 75.03 & 74.99 & 1.0000 & 2.0000 \\
\hline 110 & 0237 & 046F & 110.04 & 110.04 & 1.0000 & 2.0000 \\
\hline 150 & 01A0 & 0340 & 149.88 & 150.06 & 1.0000 & 2.0000 \\
\hline 300 & OOCF & 0140 & 300.48 & 299.76 & 1.0000 & 2.0000 \\
\hline 600 & 0067 & 00CF & 600.96 & 600.96 & 1.0000 & 2.0000 \\
\hline 1200 & 0033 & 0067 & 1201.92 & 1201.92 & 1.0000 & 2.0000 \\
\hline 2400 & 0019 & 0033 & 2403.85 & 2403.85 & 1.0000 & 2.0000 \\
\hline 3600 & 0010 & 0021 & 3676.47 & 3676.47 & 0.9792 & 1.9584 \\
\hline 4800 & 000C & 0019 & 4807.69 & 4807.69 & 1.0000 & 2.0000 \\
\hline 7200 & 0008 & 0010 & 6944.44 & 7352.94 & 1.0368 & 1.9584 \\
\hline 9600 & 0006 & 000C & 8928.57 & 9615.38 & 1.0752 & 2.000 \\
\hline
\end{tabular}

\subsection*{6.2 COUNTER B}

Counter B consists of a 16-bit counter and two 16-bit latches organized as follows: Lower Counter B (LCB), Upper Counter B (UCB), Lower Latch B (LLB), Upper Latch B (ULB), Lower Latch C (LLC), and Upper Latch C (ULC). Latch C is used only in the asymmetrical pulse generation mode. The counter contains the count of either \(\emptyset 2\) clock pulses or external events depending on the counter mode selected. The contents of Counter B may be read any time by executing a read at location 001D for the Upper Counter B and at location 001 E or 001 C for the Lower Counter B. A read at location 001C also clears the Counter B Underflow Flag.

Latch B contains the counter initialization value, and can be loaded at any time by executing a write to the Upper Latch \(B\) at location 001D and the Lower Latch \(B\) at location 001C. In each case, the contents of the accumulator are copied into the applicable latch register.

Counter B can be initialized at any time by writing to address: 001 E . The contents of the accumulator is copied into the Upper Latch B before the value in the 16 -bit Latch B is transferred to Counter B. Counter B will also be set to the latch value and the Counter B Underflow Flag bit (IFR5) will be set to a "1" whenever Counter B underflows by decrementing from 0000 .

IFR 5 may be cleared by reading the Lower Counter \(B\) at location 001C, by writing to address location 001E, or by RES.

Counter B operates in the same manner as Counter A in the Interval Timer and Event Counter modes. The Pulse Width Measurement Mode is replaced by the Retriggerable Interval Timer mode and the Pulse Generation mode is replaced by the Asymmetrical Pulse Generation Mode.

\subsection*{6.2.1 Retriggerable Interval Timer Mode}

When operating in the Retriggerable Interval Timer mode, Counter B is initialized to the latch value by writing to address 001 E , by a Counter B underflow, or whenever a positive edge occurs on the CB pin (PA5). The Counter B interrupt flag will be set if the counter underflows before a positive edge occurs on the CB line. Figure 6-4 illustrates the operation.


Figure 6-4. Counter B Retriggerable Interval Timer Mode

\subsection*{6.2.2 Asymmetrical Pulse Generation Mode}

Counter B has a special Asymmetrical Pulse Generation Mode whereby a pulse train with programmable pulse width and period can be generated without the processor intervention once the latch values are initialized.

In this mode, the 16 -bit Latch \(B\) is initialized with a value which corresponds to the duration between pulses (referred to as \(D\) in the following descriptions). The 16 -bit Latch \(C\) is initialized with a value which corresponds to the desired pulse width (referred to as \(P\) in the following descriptions). The initialization sequence for Latch B and C and the starting of a counting sequence are as follows:
1. The lower 8 bits of \(P\) are loaded into LLB by writing to address 001C, and the upper 8 bits of \(P\) are loaded into ULB and the full 16 bits are transferred to Latch C by writing to address location 001D. At this point both Latch \(B\) and Latch \(C\) contain the value of \(P\).
2. The lower 8 bits of \(D\) are loaded into LLB by writing to address 001 C , and the upper 8 bits of \(D\) are loaded into ULB by writing to address location 001E. Writing to address location 001E also causes the contents of the 16 -bit Latch B to be downloaded into the Counter \(B\) and causes the CB output to go low as shown in Figure 6-5.
3. When the Counter B underflow occurs the contents of the Latch C is loaded into the Counter B, and the CB output toggles to a high level and stays high until another underflow occurs. Latch B is then down-loaded and the CB output toggles to a low level repeating the whole process.

\section*{SECTION 7 \\ POWER ON/INITIALIZATION CONSIDERATIONS}

\subsection*{7.1 POWER-ON TIMING}

After applications of \(V_{C C}\) and \(V_{R R}\) power to the device, \(\overline{R E S}\) must be held low for at least eight \(\emptyset 2\) clock cycles after \(V_{c c}\) reaches operating range and the interal oscillator has stabilized. This stabilization time is dependent upon the input \(\mathrm{V}_{\mathrm{Cc}}\) voltage and performance of the internal oscillator. The clock can be monitored at \(\emptyset 2\) (pin 3). Figure 7-1 illustrates the power turn-on waveforms. Clock stabilization time is typically 20 ms .


Figure 7-1. Power Turn-on Timing Detail

\subsection*{7.2 POWER-ON RESET}

The occurrence of \(\overline{\operatorname{RES}}\) going from low to high will cause the device to set the Interrupt Mask Bit - bit 2 of the Processor Status Register - and initiate a reset vector fetch at address FFFC and FFFD to begin user program execution. All of the I/O ports (PA, PB, PC, PD) will be forced to the high (logic 1) state. All bits of the Control Register will be cleared to logic 0 causing the Interval Timers counter mode (mode 00) to be selected and causing all interrupt enabled bits to be reset.


Figure 6-5. Counter B Pulse Generation

\subsection*{7.3 RESET ( \(\overline{\operatorname{RES}}\) ) CONDITIONING}

When \(\overline{\mathrm{RES}}\) is driven from low to high the device is put in a reset state causing the registers and I/O ports to be configured as shown in Table 7-1. All RAM and other CPU registers will initialize in a random, non-repeatable data pattern.

Table 7.1 \(\overline{R E S}\) Initialization of I/O Ports and Registers
\begin{tabular}{|l|c|cccccccc|}
\hline & Add. & \multicolumn{7}{|c|}{ Bit No. } \\
\cline { 3 - 8 } & (Hex.) & \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline Registers & & & & & & & & & \\
Processor Status & - & - & - & - & - & - & 1 & - & - \\
Int. Flag (IFR) & 11 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
Int. Enable (IER) & 12 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
Mode Control (MCR) & 14 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
Ser. Com. Control (SCCR) & 15 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
Ser. Com. Status (SCSR) & 16 & 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 \\
Ports & & & & & & & & & \\
PA Latch & 0 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\
PB Latch & 1 & \(\mathbf{1}\) & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\
PC Latch & 2 & \(\mathbf{1}\) & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\
PD Latch & 3 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\
\hline
\end{tabular}

\subsection*{7.4 INITIALIZATION}

Any initialization process for the device should include a \(\overline{R E S}\), as indicated in the preceding paragraphs. After stabilization of the internal clock (if a power on situation) an initialization subroutine should be executed to perform (as a minimum) the following functions:
1. The Stack Pointer should be set
2. Clear or Set Decimal Mode
3. Set or Clear Carry Flag
4. Set up Mode Controls as required
5. Clear Interrupts

A typical initialization subroutine could be as follows:
\begin{tabular}{ll} 
LDX & Load stack pointer starting address into \(X\) \\
& \begin{tabular}{l} 
Register
\end{tabular} \\
TXS & Transfer \(\times\) Register value to Stack Pointer \\
CLD & Clear Decimal Mode \\
SEC & Set Carry Flag \\
\(\ldots\). & Set-up Mode Control and \\
\(\ldots\). & special function \\
\(\ldots\). & registers as required \\
CLI & Clear Interrupts
\end{tabular}

\title{
APPENDIX A \\ ENHANCED R6502 INSTRUCTION SET
}

\begin{abstract}
This appendix summarizes the R6500/11. R6500/12 and R6500/15 instruction set. For detailed information, consult the R6500 Microcomputer System Programming Manual (Order No. 202). Four new bit access instructions are added to enhance the standard 6502 instruction set.
\end{abstract}

Table A. 1 R6500/11, R6500/12 and R6500/15 Instruction Set in Alphabetic Sequence
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Instruction & Mnemonic & Instruction \\
\hline ADC & Add Memory to Accumulator with Carry & LDA & Load Accumulator with Memory \\
\hline AND & "AND" Memory with Accumulator & LDX & Load Index \(X\) with Memory \\
\hline ASL & Shift Left One Bit (Memory or Accumulator) & LDY & Load Index Y with Memory \\
\hline & & LSR & Shift One Bit Right (Memory or \\
\hline *BBR & Branch on Bit Reset Relative & & Accumulator) \\
\hline *BBS & Branch on Bit Set Relative & & \\
\hline BCC & Branch on Carry Clear & NOP & No Operation \\
\hline BCS & Branch on Carry Set & & \\
\hline BEQ & Branch on Result Zero & ORA & "OR'' Memory with Accumulator \\
\hline BIT & Test Bits in Memory with Accumulator & & \\
\hline BMI & Branch on Result Minus & PHA & Push Accumulator on Stack \\
\hline BNE & Branch on Result not Zero & PHP & Push Processor Status on Stack \\
\hline BPL & Branch on Result Plus & PLA & Pull Accumulator from Stack \\
\hline BRK & Force Break & PLP & Pull Processor Status from Stack \\
\hline BVC & Branch on Overflow Clear & & \\
\hline BVS & Branch on Overflow Set & *RMB & Reset Memory Bit \\
\hline & & ROL & Rotate One Bit Left (Memory or \\
\hline CLC & Clear Carry Flag & & Accumulator) \\
\hline CLD & Clear Decimal Mode & ROR & Rotate One Bit Right (Memory or \\
\hline CLI & Clear Interrupt Disable Bit & & Accumulator) \\
\hline CLV & Clear Overflow Flag & RTI & Return from Interrupt \\
\hline CMP & Compare Memory and Accumulator & RTS & Return from Subroutine \\
\hline CPX & Compare Memory and Index \(X\) & & \\
\hline CPY & Compare Memory and Index \(Y\) & SBC & Subtract Memory from Accumulator with Borrow \\
\hline DEC & Decrement Memory by One & SEC & Set Carry Flag \\
\hline DEX & Decrement Index \(X\) by One & SED & Set Decimal Mode \\
\hline DEY & Decrement Index \(Y\) by One & SEI & Set Interrupt Disable Status \\
\hline & & *SMB & Set Memory Bit \\
\hline EOR & "Exclusive-Or' Memory with & STA & Store Accumulator in Memory \\
\hline & Accumulator & STX & Store Index X in Memory \\
\hline & & STY & Store Index Y in Memory \\
\hline INC & Increment Memory by One & & \\
\hline INX & Increment Index X by One & TAX & Transfer Accumulator to Index X \\
\hline INY & Increment Index X by One & TAY & Transfer Accumulator to Index Y \\
\hline & & TSX & Transfer Stack Pointer to Index X \\
\hline JMP & Jump to New Location & TXA & Transfer Index X to Accumulator \\
\hline JSR & Jump to New Location Saving Return & TXS & Transfer Index X to Stack Register \\
\hline \multicolumn{4}{|l|}{\begin{tabular}{l}
Notes: \\
* Instructions added to this standard 6502 instruction set.
\end{tabular}} \\
\hline
\end{tabular}


Table A. 3 R6500/11, R6500/12 and R6500/15 Instruction Operation Code Matrix


MSD \(=\) Most Significant Digit
LSD \(=\) Least Significant Digit
*Add 1 to N if page boundary is crossed.
**Add 1 to \(N\) if branch occurs to same page; add 2 to N if branch occurs to different page.

\section*{APPENDIX B \\ KEY REGISTER SUMMARY}


CPU Registers


Mode Control Register


Interrupt Enable and Flag Registers


Serial Communications Status Register

\title{
APPENDIX C ADDRESS ASSIGNMENTS/MEMORY MAPS/PIN FUNCTIONS
}

\section*{C. 1 I/O AND INTERNAL REGISTER ADDRESSES}
\begin{tabular}{|c|c|c|}
\hline \begin{tabular}{l}
ADDRESS \\
(HEX)
\end{tabular} & READ & WRITE \\
\hline \[
\begin{array}{r}
001 F \\
1 \mathrm{E} \\
1 \mathrm{D} \\
1 \mathrm{C}
\end{array}
\] & \begin{tabular}{l}
Lower Counter B \\
Upper Counter B \\
Lower Counter B, CLR Flag
\end{tabular} & Upper Latch B, Cntr B↔Latch B, CLR Flag Upper Latch B, Latch C \(\leftarrow\) Latch B Lower Latch B. \\
\hline \[
\begin{aligned}
& 1 B \\
& 1 A \\
& 19 \\
& 18
\end{aligned}
\] & \begin{tabular}{l}
Lower Counter A \\
Upper Counter A \\
Lower Counter A, CLR Flag
\end{tabular} & Upper Latch A, Cntr A \(\leftarrow\) Latch A, CLR Flag Upper Latch A Lower Latch A \\
\hline \[
\begin{aligned}
& 17 \\
& 16 \\
& 15 \\
& 14
\end{aligned}
\] & Serial Receiver Data Register Serial Comm. Status Register Serial Comm. Control Register Mode Control Register & \begin{tabular}{l}
Serial Transmitter Data Register \\
Serial Comm. Status Reg. Bits 4 \& 5 only \\
Serial Comm. Control Register \\
Mode Control Register
\end{tabular} \\
\hline \[
\begin{array}{r}
13 \\
12 \\
11 \\
0010
\end{array}
\] & Interrupt Enable Register Interrupt Flag Register Read FF & \begin{tabular}{l}
Interrupt Enable Register \\
Clear Int Flag (Bits 0-3 only, Write 0's only)
\end{tabular} \\
\hline \[
\begin{aligned}
& O F \\
& O E \\
& O D \\
& O C
\end{aligned}
\] &  &  \\
\hline \[
\begin{aligned}
& O B \\
& O A \\
& 09 \\
& 08
\end{aligned}
\] &  & -ー
-—
-ー \\
\hline \[
\begin{aligned}
& 07 \\
& 06 \\
& 05 \\
& 04
\end{aligned}
\] & \[
\begin{aligned}
& \text { Port G * } \\
& \text { Port F * } \\
& \text { Port E * }
\end{aligned}
\] & \begin{tabular}{l}
Port G* \\
Port F* \\
Port E*
\end{tabular} \\
\hline \[
\begin{array}{r}
03 \\
02 \\
01 \\
0000
\end{array}
\] & \begin{tabular}{l}
Port D \\
Port C \\
Port B \\
Port A
\end{tabular} & \begin{tabular}{l}
Port D \\
Port C \\
Port B \\
Port A
\end{tabular} \\
\hline
\end{tabular}

NOTE *R6500/12Q only.

\section*{C. 2 ABBREVIATED MODE MEMORY MAP}


\section*{C. 3 MULTIPLEXED MODE MEMORY MAP}


\section*{C. 4 MULTIPLE FUNCTION PIN ASSIGNMENTS—PORT C AND PORT D}
\begin{tabular}{|c|c|c|c|}
\hline PIN NUMBER & I/O PORT FUNCTION & ABBREVIATED PORT FUNCTION & MULTIPLEXED PORT FUNCTION \\
\hline 4 & PCO & AO & AO \\
\hline 5 & PC1 & A1 & A1 \\
\hline 6 & PC2 & A2 & A2 \\
\hline 7 & PC3 & A3 & A3 \\
\hline 8 & PC4 & A12 & A12 \\
\hline 9 & PC5 & R/W & R/W \\
\hline 10 & PC6 & A13 & A13 \\
\hline 11 & PC7 & EMS & EMS \\
\hline 19 & PDO & D0 & A4/D0 \\
\hline 18 & PD1 & D1 & A5/D1 \\
\hline 17 & PD2 & D2 & A6/D2 \\
\hline 16 ' & PD3 & D3 & A7/D3 \\
\hline 15 & PD4 & D4 & A8/D4 \\
\hline 14 & PD5 & D5 & A9/D5 \\
\hline 13 & PD6 & D6 & A10/D6 \\
\hline 12 & PD7 & D7 & A11/D7 \\
\hline
\end{tabular}

\section*{APPENDIX D ELECTRICAL SPECIFICATIONS}

\section*{MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}} \& \mathrm{~V}_{\mathrm{RR}}\) & -0.3 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\text {IN }}\) & -0.3 to +7.0 & Vdc \\
\hline \begin{tabular}{l} 
Operating Temperature \\
Commercial \\
Industrial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \(\mathrm{T}_{\mathrm{L}}\) to \(\mathrm{T}_{\mathrm{H}}\) & \({ }^{\circ} \mathrm{C}\) \\
0 to +70 \\
-40 to +85 & \\
\hline Storage Temperature & & \(\mathrm{T}_{\text {STG }}\) & -55 to +150 \\
\hline
\end{tabular}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}
\(\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{R R}=V_{C C} ; V_{S S}=0 V ; T_{A}=0^{\circ}\right.\) to \(70^{\circ}\), unless otherwise specified)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min. & Typ. \({ }^{1}\) & Max. & Unit & Test Conditions \\
\hline RAM Standby Voltage (Retention Mode) & \(V_{\text {RR }}\) & 3.0 & & \(\mathrm{V}_{\mathrm{CC}}\) & V & \\
\hline RAM Standby Current (Retention Mode) Commercial Industrial & \(\mathrm{I}_{\text {RR }}\) & - & \[
\begin{gathered}
4 \\
5.2
\end{gathered}
\] & - & mA & \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) \\
\hline \begin{tabular}{l}
Input High Voltage \\
All Except XTLI and \(\emptyset 2\) in Slave Option XTLI and \(\emptyset 2\) in Slave Option
\end{tabular} & \(\mathrm{V}_{\mathrm{IH}}\) & \[
\begin{aligned}
& +2.0 \\
& +4.0
\end{aligned}
\] & - & \begin{tabular}{l}
\(V_{C C}\) \\
\(V_{C C}\)
\end{tabular} & V & \\
\hline Input Low Voltage & \(\mathrm{V}_{\text {IL }}\) & -0.3 & - & +0.8 & V & \\
\hline Input Leakage Current RES, NMI & \(\mathrm{I}_{\mathrm{IN}}\) & - & - & \(\pm 10.0\) & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{IN}}=0\) to 5.0 V \\
\hline Input Low Current \(\mathrm{PA}, \mathrm{PB}, \mathrm{PC}, \mathrm{PD}, \mathrm{PF}^{3}\), and \(\mathrm{PG}^{3}\) & \(\mathrm{I}_{\text {L }}\) & - & -1.0 & -1.6 & mA & \(\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V}\) \\
\hline Output High Voltage (Except XTLO) & \(\mathrm{V}_{\mathrm{OH}}\) & \(+2.4\) & - & \(\mathrm{V}_{\mathrm{Cc}}\) & V & \(\mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A}\) \\
\hline Darlington Current Drive, \(\mathrm{PE}^{3}\) & \(\mathrm{IOH}^{\text {r }}\) & -1.0 & - & - & mA & \(\mathrm{V}_{\mathrm{OH}}=1.5 \mathrm{~V}\) \\
\hline Output Low Voltage & \(\mathrm{V}_{\mathrm{OL}}\) & - & - & \(+0.4\) & V & \(\mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA}\) \\
\hline ```
I/O Port Pull-Up Resistance
    PA0 - PA7, PB0 - PB7, PC0 - PC7,
    PFO - PF73 & PG0 - PG73
``` & \(\mathrm{R}_{\mathrm{L}}\) & 3.0 & 6.0 & 11.5 & Kohm & \\
\hline Output Leakage Current (Three-State Off) & lout & - & - & \(\pm 10\) & \(\mu \mathrm{A}\) & \\
\hline ```
Input Capacitance
    XTLI, XTLO
    PA, PB, PC, PD, PF3, PG3
``` & \(\mathrm{Cl}_{\text {IN }}\) & - & - & \[
\begin{aligned}
& 50 \\
& 10 \\
& \hline
\end{aligned}
\] & pF & \[
\begin{aligned}
& T_{A}=25^{\circ} \mathrm{C} \\
& V_{1 \mathrm{~N}}=0 \mathrm{~V} \\
& \mathrm{f}=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Output Capacitance (Three-State Off) & \(\mathrm{C}_{\text {OUT }}\) & - & - & 10 & pF & \[
\begin{aligned}
& T_{A}=25^{\circ} \mathrm{C} \\
& V_{I N}=0 \mathrm{~V} \\
& f=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Power Dissipation (Outputs High) & \(P_{\text {D }}\) & - & - & 1000 & mW & \(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\) \\
\hline \multicolumn{7}{|l|}{\begin{tabular}{l}
Notes: \\
1. Typical values measured at \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\). \\
2. Negative sign indicates outward current flow, positive indicates inward flow. \\
3. R6500/12Q only.
\end{tabular}} \\
\hline
\end{tabular}

\section*{APPENDIX E}

TIMING REQUIREMENTS AND CHARACTERISTICS

\section*{E. 1 GENERAL NOTES}
1. \(\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \pm 5 \%, 0^{\circ} \mathrm{C} \leqslant \mathrm{TA} \leqslant 70^{\circ} \mathrm{C}\)
2. A valid \(V_{c c}-\overline{\text { RES }}\) sequence is required before proper operation is achieved.
3. All timing reference levels are 0.8 V and 2.0 V , unless otherwise specified.
4. All time units are nanoseconds, unless otherwise specified.
5. All capacitive loading is 130 pF maximum, except as noted below:
\begin{tabular}{ll} 
PA, PB & -50 pF maximum \\
PC (I/O Modes Only) & -50 pF maximum \\
PC ( \(A_{B B}\) and Mux Mode) & -130 pF maximum \\
PC6, PC7 (Full Address Mode) & -130 pF maximum
\end{tabular}

\section*{E. 2 CLOCK TIMING}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Symbol} & \multirow[b]{2}{*}{Parameter} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} & \multirow[b]{2}{*}{Units} \\
\hline & & Min & Max & Min & Max & \\
\hline \(\mathrm{T}_{\mathrm{CYC}}\) & Cycle Time & 1.0 & 10 & 0.5 & 10 & \(\mu \mathrm{S}\) \\
\hline \(\mathrm{T}_{\text {PWX1 }}\) & \begin{tabular}{l}
XTLI Input Clock \\
Pulse Width \\
XTLO = VSS
\end{tabular} & \[
\begin{aligned}
& 500 \\
& \pm 25
\end{aligned}
\] & - & \[
\begin{aligned}
& 250 \\
& \pm 10
\end{aligned}
\] & - & ns \\
\hline \(\mathrm{T}_{\text {PW02 }}\) & Output Clock Pulse Width at Minimum \(\mathrm{T}_{\mathrm{CYC}}\) & \(T_{P W \times 1}\) & \[
\begin{gathered}
T_{P W \times 1} \\
+0 \\
-25
\end{gathered}
\] & \(\mathrm{T}_{\text {PWX1 }}\) & \[
\begin{gathered}
T_{P W \times 1} \\
+0 \\
-20
\end{gathered}
\] & ns \\
\hline \(T_{R}, T_{F}\) & Output Clock Rise, Fall Time & - & 25 & - & 15 & ns \\
\hline \(\mathrm{T}_{\text {IR }}, \mathrm{T}_{\text {IF }}\) & Input Clock Rise Fall Time & - & 10 & - & 10 & ns \\
\hline
\end{tabular}


\section*{E. 3 ABBREVIATED MODE TIMING-PC AND PD}
\((\) MCR \(5=1\), MCR \(6=0\), MCR \(7=1)\)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Symbol} & \multirow[b]{2}{*}{Parameter} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|r|}{2 MHz} & \multirow[b]{2}{*}{Units} \\
\hline & & Min & Max & Min & Max & \\
\hline \(\mathrm{T}_{\text {PCRS }}\) & (PC5) R/W Setup Time & - & 225 & - & 140 & ns \\
\hline \(\mathrm{T}_{\text {PCAS }}\) & (PC0-PC4, PC6) Address Setup Time & - & 225 & - & 140 & ns \\
\hline \(\mathrm{T}_{\text {PBSU }}\) & (PD) Data Setup Time & 50 & - & 35 & - & ns \\
\hline \(\mathrm{T}_{\text {PBHR }}\) & (PD) Data Read Hold Time & 10 & - & 10 & - & ns \\
\hline T PBHW & (PD) Data Write Hold Time & 30 & - & 30 & - & ns \\
\hline \(\mathrm{T}_{\text {PBDD }}\) & (PD) Data Output Delay & - & 175 & - & 150 & ns \\
\hline \(\mathrm{T}_{\text {PCHA }}\) & (PC0-PC4, PC6) Address Hold Time & 30 & - & 30 & - & ns \\
\hline \(\mathrm{T}_{\text {PCHR }}\) & (PC5) R/W Hold Time & 30 & - & 30 & - & ns \\
\hline \(\mathrm{T}_{\text {PCHV }}\) & (PC7) EMS Hold Time & 10 & - & 10 & - & ns \\
\hline \(\mathrm{T}_{\text {ESU }}\) & (PC7) EMS Setup Time & - & 350 & - & 210 & ns \\
\hline \(\mathrm{T}_{\text {PCVP }}\) & (PC7) EMS Stabilization Time & 30 & - & 30 & - & ns \\
\hline \multicolumn{7}{|l|}{NOTE 1: Values assume PC0-PC4, PC6 and PC7 have the same capacitive load.} \\
\hline
\end{tabular}

\section*{E.3.1 Abbreviated Mode Timing Diagram}


\section*{E. 4 MULTIPLEXED MODE TIMING-PC AND PD}
(MCR \(5=1\), MCR \(6=1\), MCR \(7=1\) )
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Symbol} & \multirow[b]{2}{*}{Parameter} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|r|}{2 MHz} & \multirow[b]{2}{*}{Units} \\
\hline & & Min & Max & Min & Max & \\
\hline \(\mathrm{T}_{\text {PCRS }}\) & (PC5) R/W Setup Time & - & 225 & - & 140 & ns \\
\hline \(\mathrm{T}_{\text {PCAS }}\) & (PC0-PC4, PC6) Address Setup Time & - & 225 & - & 140 & ns \\
\hline \(\mathrm{T}_{\text {PBAS }}\) & (PD) Address Setup Time & - & 225 & - & 140 & ns \\
\hline \(\mathrm{T}_{\text {PBSU }}\) & (PD) Data Setup Time & 50 & - & 35 & - & ns \\
\hline \(\mathrm{T}_{\text {PBHR }}\) & (PD) Data Read Hold Time & 10 & - & 10 & - & ns \\
\hline T \({ }_{\text {PBHW }}\) & (PD) Data Write Hold Time & 30 & - & 30 & - & ns \\
\hline \(\mathrm{T}_{\text {PBDD }}\) & (PD) Data Output Delay & - & 175 & - & 150 & ns \\
\hline TPCHA & (PC0-PC4, PC6) Address Hold Time & 30 & - & 30 & - & ns \\
\hline TPBHA & (PD) Address Hold Time & 10 & 100 & 10 & 80 & ns \\
\hline \(\mathrm{T}_{\text {PCHR }}\) & (PC5) R/W Hold Time & 30 & - & 30 & - & ns \\
\hline \(\mathrm{T}_{\mathrm{PCHV}}\) & (PC7) EMS Hold Time & 10 & - & 10 & - & ns \\
\hline \(\mathrm{T}_{\text {PCVD }}{ }^{(1)}\) & (PC7) Address to EMS Delay Time & 30 & - & 30 & - & ns \\
\hline TPCVP & (PC7) EMS Stabilization Time & 30 & - & 30 & - & ns \\
\hline \(\mathrm{T}_{\text {ESU }}\) & (PC7) EMS Setup Time & - & 350 & - & 210 & ns \\
\hline \multicolumn{7}{|l|}{NOTE 1: Values assume PD0-PD7 and PC7 have the same capacitive load.} \\
\hline
\end{tabular}

\section*{E.4.1 Multiplex Mode Timing Diagram}


\section*{E. 5 I/O, EDGE DETECT, COUNTERS, AND SERIAL I/O TIMING}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Symbol} & \multirow[b]{2}{*}{Parameter} & \multicolumn{2}{|l|}{1 MHz} & \multicolumn{2}{|l|}{2 MHz} & \multirow[b]{2}{*}{Units} \\
\hline & & Min & Max & Min & Max & \\
\hline \[
\begin{gathered}
\mathrm{T}_{\text {PDW }}{ }^{(1)} \\
\mathrm{T}_{\text {CMOS }}{ }^{(1)} \\
\mathrm{T}_{\text {PDDW }} \\
\hline
\end{gathered}
\] & Internal Write to Peripheral Data Valid PA, PB, PC, PE, PF, PG, TTL PA, PB, PC, PE, PF, PG, CMOS PD & - & \[
\begin{array}{|r}
500 \\
1000 \\
175
\end{array}
\] & - & \[
\begin{array}{|r}
500 \\
1000 \\
150
\end{array}
\] & ns \\
\hline \(T_{\text {PDSU }}\) TPDSU & Peripheral Data Setup Time
\[
\mathrm{PA}, \mathrm{~PB}, \mathrm{PC}, \mathrm{PF}, \mathrm{PG}
\]
PD & \[
\begin{array}{r}
200 \\
50
\end{array}
\] & - & \[
\begin{array}{r}
200 \\
50
\end{array}
\] & - & ns \\
\hline \(\mathrm{T}_{\text {PHR }}\) \(T_{\text {PHR }}\) & \begin{tabular}{l}
Peripheral Data Hold Time
\[
\mathrm{PA}, \mathrm{~PB}, \mathrm{PC}, \mathrm{PF}, \mathrm{PG}
\] \\
PD
\end{tabular} & \[
\begin{aligned}
& 75 \\
& 10
\end{aligned}
\] & - & \[
\begin{aligned}
& 75 \\
& 10
\end{aligned}
\] & - & ns \\
\hline \(\mathrm{T}_{\text {EPW }}\) & PA0-PA3 Edge Detect Pulse Width & \(\mathrm{T}_{\mathrm{CYC}}\) & - & \(\mathrm{T}_{\mathrm{CYC}}\) & - & ns \\
\hline \(\mathrm{T}_{\mathrm{CPW}}\)
\[
T_{C D^{(1)}}
\] & \begin{tabular}{l}
Counters A and B \\
PA4, PA5 Input Pulse Width PA4, PA5, Output Delay
\end{tabular} & \(\mathrm{T}_{\text {crc }}\) & \(\overline{500}\) & \(\mathrm{T}_{\mathrm{CYC}}\) & \(\overline{500}\) & ns \\
\hline \(T_{\text {PBLW }}\) \(T_{\text {PLSU }}\) \(T_{\text {PBLH }}\) & Port B Latch Mode PAO Strobe Pulse Width PB Data Setup Time PB Data Hold Time & \[
\begin{gathered}
T_{\text {CYC }} \\
175 \\
30
\end{gathered}
\] & - & \[
\begin{gathered}
T_{\mathrm{CYC}} \\
150 \\
30
\end{gathered}
\] & - & ns \\
\hline & Serial I/O & & & & & ns \\
\hline \(\mathrm{T}_{\text {PDW }}{ }^{(1)}\) & PA6 XMTR TTL & - & 500 & - & 500 & \\
\hline \(\mathrm{T}_{\text {CMOS }}{ }^{(1)}\) & PA6 XMTR CMOS & T & 1000 & - & 1000 & \\
\hline \(\mathrm{T}_{\text {CPW }}\) & PA4 RCVR S/R Clock Width & \(4 \mathrm{~T}_{\mathrm{CYC}}\) & - & \(4 \mathrm{~T}_{\mathrm{CYC}}\) & - & \\
\hline \(\mathrm{T}_{\mathrm{PDW}}{ }^{(1)}\) & PA4 XMTR Clock-S/R Mode (TTL) & - & 500 & & 500 & \\
\hline \(\mathrm{T}_{\text {CMOS }}{ }^{(1)}\) & PA4 XMTR Clock-S/R Mode (CMOS) & - & 1000 & - & 1000 & \\
\hline \multicolumn{7}{|l|}{NOTE 1: Maximum Load Capacitance: 50pF Passive Pull-Up Required.} \\
\hline
\end{tabular}

\section*{E.5.1 I/O, Edge Detect, Counter, and Serial I/O Timing}


\section*{R65/11EB and R65/11EAB Backpack Emulator}

\section*{INTRODUCTION}

The Rockwell R65/11EB and R65/11EAB Backpack Emulator are PROM prototyping versions of the 8-bit, masked-ROM R6500/11 and R6500/15 one-chip microcomputers. Like the R6500/11, the backpack device is totally upward/downward compatible with all members of the R6500/11 family. It is designed to accept standard 5 -volt, 24-pin EPROMs or ROMs directly, in a socket on top of the Emulator. This packaging concept allows a standard EPROM to be easily removed, re-programmed, then reinserted as often as desired.

The backpack devices have the same pinouts as the maskedROM R6500/11 and R6500/15 microcomputers. These 40 pins are functionally and operationally identical to the pins on the R6500/11. The R6500/11 Microcomputer Product Description (Order No. 2119) includes a description of the interface signals and their functions. Whereas the masked-ROM R6500/11 provides 3 K bytes of read-only memory, the R65/11EB will address 4 K bytes of external program memory. This extra memory accommodates program patches, test programs or optional programs during breadboard and prototype development states.

\section*{ORDERING INFORMATION}

BACKPACK EMULATOR
\begin{tabular}{|c|c|c|c|}
\hline \begin{tabular}{c} 
Part \\
Number
\end{tabular} & \begin{tabular}{c} 
Memory \\
Capacity
\end{tabular} & \begin{tabular}{c} 
Compatible \\
Memories
\end{tabular} & \begin{tabular}{c} 
Temperature \\
Range and Speed
\end{tabular} \\
\hline R65/11EB & \(4 \mathrm{~K} \times 8\) & 2732 & \(0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}\) \\
1 MHz \\
R65/11EAB & \(4 \mathrm{~K} \times 8\) & 2732 A & \begin{tabular}{c}
\(0^{\circ} \mathrm{C} \mathrm{to} 70^{\circ} \mathrm{C}\) \\
2 MHz
\end{tabular} \\
\hline
\end{tabular}

\section*{SUPPORT PRODUCTS}
\begin{tabular}{|c|l|}
\hline \begin{tabular}{c} 
Part \\
Number
\end{tabular} & \multicolumn{1}{|c|}{ Description } \\
\hline RDC-3101 & Low Cost Emulator (LCE) Development System \\
RDC-3030 & LCE PROM Programmer Module \\
RDC-309 & 1 or 2-MHz R6500/11 Personality Module \\
\hline
\end{tabular}

\section*{FEATURES}
- PROM version of the R6500/11 and R6500/15
- Completely pin compatible with R6500/11 single-chip microcomputers
- Profile approaches 40 -pin DIP of R6500/11
- Accepts 5 volt, 24-pin industry-standard EMPROMS-4K memories-2732, 2732A (4K bytes addressable)
- Use as prototyping tool or for low volume production
- 4 K bytes of memory capacity
- \(192 \times 8\) static RAM
- Separate power pin for 32 bytes of RAM
- Software compatibility with the R6500 family
- 32 bi-directional TTL compatible I/O lines (4 ports)
- Two 16-bit programmable counter/latches with six modes (interval timer, pulse generator, event counter, pulse width measurement, asymmetrical pulse generator, and retriggerable interval timer)
- 10 interrupts (reset, non-maskable, four external edge sensitive, 2 counters, serial data received, serial data transmitted)
- Crystal or external time base
- Single +5 V power supply

Note: R6500/11 describes both R6500/11 and R6500/15.


R65/11EB Backpack Emulator

\section*{CONFIGURATIONS}

The Backpack Emulator is available in two different versions, to accommodate 1 MHz and 2 MHz speeds. Both versions provide 192 bytes of RAM and I/O, as well as 24 signals to support the external memory "backpack" socket.

The emulator will relocate the EPROM address space to FXXX (see Memory Map). EPROM addresses FFA through FFF must contain the interrupt vectors.

\section*{EXTERNAL FREQUENCY REFERENCE}

The external frequency reference may be a crystal or a clock. The R65/11EB and R65/11EAB divide the input clock by two regardless of the source.

\section*{I/O PORT PULLUPS}

The devices have internal I/O port pull-up resistors on ports A, B, \& C. Port D has push-pull drivers.

\section*{MODE CONTROL REGISTER}

Bit 6 of the MODE CONTROL REGISTER (MCR6) must be set to 1 if Bit 7 (MCR7) is set to \(\emptyset\). (R65/11EB and R65/11EAB only).

\section*{PRODUCT SUPPORT}

The Backpack Emulator is just one of the products that Rockwell offers to facilitate system and program development for the R6500/11.

The Low Cost Emulator (LCE) Development System with R6500/11 Personality Module supports both hardware and software development. Complete in-circuit user emulation with the R6500/11 Personality Module allows total system test and evaluation. With the optional PROM Programmer, the LCE can also be used to program EPROMs for the development activity. When PROM programs have been finalized, the PROM device can be sent to Rockwell for masking into the 3 K ROM of the R6500/11 or the 4 K ROM of the R6500/15.


R65/11EB Interface Diagram
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline XTLO & \(\square^{1}\) & A7 & \({ }_{15}\) & 24s & P cc & 40 & \(V_{\text {SS }}\) \\
\hline XTLI & \(\square 2\) & A6 - & 2s & 23s & - 48 & 39 & \(\mathrm{V}_{\mathrm{RR}}\) \\
\hline ø2 & 3 & A5 & 3s & 22s & \(\square \mathrm{A} 9\) & 38 & PB0 \\
\hline PCO & - 4 & A4 & 4s & 21 s & -A11 & 37 & PB1 \\
\hline PC1 & - 5 & A3 & 5 s & 20 s & \(\overline{O E}\) & 36 & PB2 \\
\hline PC2 & - 6 & A2 & 6 s & 19s & - A10 & 35 & PB3 \\
\hline PC3 & C 7 & A1 1 & 7s & 18s & PCE & 34 & PB4 \\
\hline PC4 & -8 & A0 0 & 8s & 17s & -D7 & 33 & PB5 \\
\hline PC5 & \(\square 9\) & D0 & 9s & 16s & -D6 & 32 & PB6 \\
\hline PC6 & \(\square 10\) & D1 & 10s & 15s & -D5 & 31 & PB7 \\
\hline PC7 & -11 & D2 & 11s & 14s & -D4 & 30 & PAO \\
\hline PD7 & -12 & \(\mathrm{V}_{5 S}{ }^{\text {C }}\) & 12s & 13s & D3 & 29 & PA1 \\
\hline PD6 & \(\square 13\) & & & & & 28 & PA2 \\
\hline PD5 & -14 & & 24-PIN & CKE & & 27 & PA3 \\
\hline PD4 & \(\square 15\) & & & & & 26 & PA4 \\
\hline PD3 & -16 & & & & & 25 & PA5 \\
\hline PD2 & -17 & & & & & 24 & PA6 \\
\hline PD1 & \(\square 18\) & & & & & 23 & PA7 \\
\hline PDO & \(\square 19\) & & & & & 22 & NMI \\
\hline RES & \(\square 20\) & & & & & 21 & \(\mathrm{V}_{\mathrm{cc}}\) \\
\hline
\end{tabular}

Pin Configuration

BACKPACK MEMORY SIGNAL DESCRIPTION
\begin{tabular}{|c|c|c|}
\hline \begin{tabular}{l}
Signal \\
Name
\end{tabular} & Pin No. & Description \\
\hline D0-D7 & \[
\begin{aligned}
& 9 \mathrm{~S}-11 \mathrm{~S}, \\
& \text { 13S-17S }
\end{aligned}
\] & Data Bus Lines. All instruction and data transfers take place on the data bus lines. The buffers driving the data bus lines have full three-state capability. Each data bus pin is connected to an input and an output buffer, with the output buffer remaining in the floating condition. \\
\hline A0-A7 & 1S-8A, & Address Bus Lines. The address bus lines are \\
\hline A8, A9 & 23S, 24 S & buffered by push/pull type drivers that can \\
\hline A10 & 19 S & drive one standard TTL load. \\
\hline A11 & 215 & \\
\hline \(\overline{C E}\) & 18 S & Chip Enable. \(\overline{\mathrm{CE}}\) is active when the address is \(8000-F F F F\). This line can drive one TTL load. \\
\hline \(\overline{O E}\) & 20S & Memory Enable Line. This signal provides the output enable for the memory to place information on the data bus lines. This signal is driven by an inverted R/W signal from the CPU. It can drive 1 TTL load. \\
\hline \(\mathrm{V}_{\mathrm{CC}}\) & 24 S & Main Power Supply +5 V . This pin is tied directly to pin \(21\left(V_{\mathrm{CC}}\right)\). \\
\hline \(V_{S S}\) & 12 S & Signal and Power Ground (zero volts). This pin is tied directly to pin \(40\left(\mathrm{~V}_{\mathrm{SS}}\right)\). \\
\hline
\end{tabular}

\section*{I/O AND INTERNAL REGISTER ADDRESSES}
\begin{tabular}{|c|c|c|}
\hline Address (Hex) & Read & Write \\
\hline \[
\begin{array}{r}
001 \mathrm{~F} \\
1 \mathrm{E} \\
1 \mathrm{D} \\
1 \mathrm{C}
\end{array}
\] & \begin{tabular}{l}
Lower Counter B \\
Upper Counter B \\
Lower Counter B, CLR Flag
\end{tabular} & Upper Latch B, Cntr B - Latch B, CLR Flag Upper Latch B, Latch C-Latch B Lower Latch B \\
\hline \[
\begin{aligned}
& 1 B \\
& 1 \mathrm{~A} \\
& 19 \\
& 18
\end{aligned}
\] & \begin{tabular}{l}
Lower Counter A \\
Upper Counter A \\
Lower Conter A, CLR Flag
\end{tabular} & \begin{tabular}{l}
Upper Latch A, Cntr A - Latch A, CLR Flag \\
Upper Latch A \\
Lower Latch A
\end{tabular} \\
\hline \[
\begin{aligned}
& 17 \\
& 16 \\
& 15 \\
& 14
\end{aligned}
\] & Serial Receiver Data Register Serial Comm. Status Register Serial Comm. Control Register Mode Control Register & \begin{tabular}{l}
Serial Transmitter Data Register \\
Serial Comm. Status Reg. Bits 4 \& 5 only \\
Serial Comm. Control Register \\
Mode Control Register
\end{tabular} \\
\hline \[
\begin{array}{r}
13 \\
12 \\
11 \\
0010
\end{array}
\] & Interrupt Enable Register Interrupt Flag Register Read FF & \begin{tabular}{l}
Interrupt Enable Register \\
Clear Int Flag (Bits 0-3 only, Write O's only)
\end{tabular} \\
\hline 04 thru 0F & - - & - - \\
\hline \[
\begin{array}{r}
03 \\
02 \\
01 \\
0000
\end{array}
\] & \begin{tabular}{l}
Port D \\
Port C \\
Port B \\
Port A
\end{tabular} & \begin{tabular}{l}
Port D \\
Port C \\
Port B \\
Port A
\end{tabular} \\
\hline
\end{tabular}

\section*{READ TIMING CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Signal} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min. & Max. & Min. & Max. & \\
\hline \(\overline{\mathrm{OE}}\) and \(\overline{\mathrm{CE}}\) setup time from CPU & ToES & - & 225 & - & 140 & ns \\
\hline Address setup time from CPU & \(\mathrm{T}_{\text {ADS }}\) & - & 150 & - & 75 & ns \\
\hline Memory read access time & \(\mathrm{T}_{\text {ACC }}\) & - & 700 & - & 315 & ns \\
\hline Data set up time & \(\mathrm{T}_{\text {DSU }}\) & 50 & - & 35 & - & ns \\
\hline Data hold time-Read & \(\mathrm{T}_{\mathrm{HR}}\) & 10 & - & 10 & - & ns \\
\hline Address hold time & \(\mathrm{T}_{\mathrm{HA}}\) & 30 & - & 30 & - & ns \\
\hline \(\overline{\mathrm{OE}}\) and \(\overline{\mathrm{CE}}\) hold time & \(\mathrm{T}_{\text {HoE }}\) & 30 & - & 30 & - & ns \\
\hline Cycle Time & \(\mathrm{T}_{\mathrm{CYC}}\) & 1.0 & 10.0 & 0.5 & 10.0 & \(\mu \mathrm{S}\) \\
\hline
\end{tabular}

\section*{READ TIMING WAVEFORMS}



\section*{ELECTRICAL CHARACTERISTICS}
\(\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{S S}=0, T_{A}=0^{\circ} \mathrm{C}\right.\) to \(70^{\circ} \mathrm{C}\), unless otherwise stated)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Characteristic & Symbol & Min & Typ & Max & Unit & Test Conditions \\
\hline Input High Threshold Voltage D0-D7 & \(V_{\text {IHT }}\) & +2.0 & - & - & Vdc & \\
\hline Input Low Threshold Voltage
D0-D7 & \(\mathrm{V}_{\text {ILT }}\) & - & - & +0.8 & Vdc & \\
\hline Three-State (Off State) Input Current D0-D7 & \(\mathrm{I}_{\text {TSI }}\) & - & - & \(\pm 10\) & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} \\
& \mathrm{~V}_{\mathrm{IN}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V}
\end{aligned}
\] \\
\hline Output High Voltage D0-D7, A0-A11, \(\overline{O E}, \overline{C E}\) & \(\mathrm{V}_{\mathrm{OH}}\) & \(+2.4\) & - & - & Vdc & \[
\begin{aligned}
& \mathrm{V}_{C C}=4.75 \mathrm{~V} \\
& \mathrm{I}_{\text {LOAD }}=100 \mu \mathrm{~A}
\end{aligned}
\] \\
\hline Output Low Voltage D0-D7, A0-A11 \(\overline{O E}, \overline{C E}\) & \(\mathrm{V}_{\mathrm{OL}}\) & - & - & \(+0.4\) & Vdc & \[
\begin{aligned}
& \mathrm{V}_{C C}=4.75 \mathrm{~V} \\
& \mathrm{I}_{\mathrm{LOAD}}=1.6 \mathrm{~mA}
\end{aligned}
\] \\
\hline Power Dissipation (less EPROM) & \(\mathrm{P}_{\mathrm{D}}\) & - & 0.80 & 1.20 & W & \\
\hline Output Capacitance (High Impendance State) DO-D7 & \(\mathrm{C}_{\text {OUT }}\) & - & - & 10 & pF & \[
\begin{aligned}
& \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\
& \mathrm{~V}_{\text {IN }}=0 \mathrm{~V}
\end{aligned}
\] \\
\hline Input Capacitance & \(\mathrm{C}_{\text {IN }}\) & - & - & 10 & pF & \(\mathrm{f}=1 \mathrm{MHz}\) \\
\hline I/O Port Pull-up Resistance & \(\mathrm{R}_{\mathrm{L}}\) & 3.0 & 6.0 & 11.5 & kohm & \\
\hline
\end{tabular}


\section*{R6501 One-Chip Microprocessor}

\section*{SECTION 1 \\ INTRODUCTION}

\section*{SUMMARY}

The Rockwell R6501 is a complete, high performance 8 -bit NMOS-3 microcomputer on a single chip and is compatible with all members of the R6500 family.

The R6501 consists of an enhanced 6502 CPU, an internal clock oscillator, 192 bytes of Random Access Memory (RAM), and versatile interface circuitry. The interface circuitry includes two-16-bit programmable timer/counters, 32 bidirectional input/output lines (including four edge-sensitive lines and input latching on one 8-bit port), a full-duplex serial I/O channel, ten interrupts, and bus expandability.
The innovative architecture and the demonstrated high performance of the R6502 CPU, as well as instruction simplicity, results in system cost-effectiveness and a wide range of computational power. These features make the R6501 a leading candidate for microcomputer application.
Rockwell supports development of the R6501 with the Low Cost Emulator (LCE) Development System and the R6500/* Family of Personality Modules. Complete in-circuit emulation with the R6500/* Family of Personality Modules allows total system test and evaluation.
This product description assumes that the reader is familiar with the R6502 CPU hardware and programming capabilities. A detailed description of the R6502 CPU hardware is included in the R6500 Microcomputer System Hardware Manual (Document Order No. 201). A description of the instruction capabilities of the R6502 CPU is contained in the R6500 Microcomputer System Programming Manual (Document Order No. 202).
ORDERING INFORMATION

\section*{Part Number:}

R6501

Temperature Range ( \(\mathrm{T}_{\mathrm{L}}\) to \(\mathrm{T}_{\mathrm{H}}\) ): No Letter \(=0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}\) (Commercial)
\[
\mathrm{E}=-40^{\circ} \mathrm{Cto}+85^{\circ} \mathrm{C}
\] (Industrial)
Package
\(J=68\)-Pin Plastic Leaded Chip Carrier (PLCC)
\(Q=64-\) Pin Plastic QUIP
Frequency
No Letter \(=1 \mathrm{MHz}\) Operation
\(\mathrm{A}=2 \mathrm{MHz}\) Operation

\section*{FEATURES}
- Enhanced 6502 CPU
-Four new bit manipulation instructions
- Set Memory Bit (SMB)
- Reset Memory Bit (RMB)
- Branch on Bit Set (BBS)
- Branch on Bit Reset (BBR)
-Decimal and binary arithmetic modes
-13 addressing modes
-True indexing
- 192-byte static RAM
- 32 bidirectional, TTL-compatible I/O lines (four ports)
-One 8-bit port may be tri-stated under software control
-One 8 -bit port may have latched inputs under software control
-Internal pull-up resistors on parts PA, PB, and PC
- Two 16-bit programmable counter/tinıers, with latches
-Pulse width measurement
-Asymmetrical pulse generation
-Pulse generation
-Interval timer
-Event counter
-Retriggerable interval timer
- Serial port
-Full-duplex asynchronous operation mode
-Selectable 5- to 8-bit characters
-Wake-up feature
-Synchronous shift register mode
-Standard programmable bit rates programmable up to 62.5 K bits/sec @ 1 MHz
- Ten interrupts
-Four edge-sensitive lines; two positive, two negative
-Reset and non-maskable interrupt
-Two counter underflows
-Serial data received and serial data transmitted
- Bus expandable to 64 K bytes of external memory
- Flexible clock circuitry
-2 MHz (R6501A) or 1 MHz (R6501) internal operation
-Crystal or clock input
- \(1 \mu \mathrm{~s}\) minimum instruction execution time at 2 MHz
- Single +5 V power supply
- 12 mW stand-by power for 32 bytes of the 192-byte RAM
- Available in 64-pin plastic QUIP and 68-pin PLCC packages

\section*{SECTION 2 INTERFACE REQUIREMENTS}

This section describes the interface requirements for the R6501. Figure 2-1 and 2-2 show the Interface Diagram and the pin out configuration for both devices. Table 2-1 describes the
function of each pin. Figure 3-1 has a detailed block diagram of the R6501 ports which illustrates the internal function of the device.


MULTIPLEXED FUNCTIONS PINS (Software Selectable)

Figure 2-1. R6501 Interface Diagram


Figure 2-2. R6501 Pin Assignments

Table 2-1. R6501 Pin Descriptions
\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Signal Name} & \multirow[b]{2}{*}{1/0} & \multicolumn{2}{|c|}{Pin No.} & \multirow[b]{2}{*}{Description} \\
\hline & & 64-Pin QUIP & 68-Pin PLCC & \\
\hline \(\mathrm{V}_{\mathrm{cc}}\) & 1 & 21 & 22 & POWER. Main power supply. +5 V . \\
\hline \(V_{\text {RR }}\) & 1 & 43 & 46 & RAM RETENTION POWER. Separate power pin for RAM. In the event that \(\mathrm{V}_{\mathrm{C}}\) power is off, this power retains RAM data. +5 V . \\
\hline \(V_{S S}\) & & 44 & 48 & GROUND. Signal and power ground (OV). \\
\hline XTLI & 1 & 42 & 45 & CRYSTAL IN. Crystal or clock input for internal clock oscillator. Allows input of X 1 clock signal if XTLO is connected to \(\mathrm{V}_{\mathrm{SS}}\), or of \(\mathrm{X} 4(\mathrm{R} 6501\) ) or \(\mathrm{X} 2(\mathrm{R} 6501 \mathrm{~A})\) clock if XTLO is floated. \\
\hline XTLO & 0 & 41 & 44 & CRYSTAL OUT. Crystal output from internal clock oscillator. \\
\hline \(\overline{\mathrm{RES}}\) & 1 & 6 & 7 & RESET. The Reset input is used to initialize the device. This signal must not transition from low to high for at least eight cycles after \(\mathrm{V}_{C C}\) reaches operating range and the internal oscillator has stabilized. \\
\hline \(\emptyset 2\) & 0 & 45 & 49 & PHASE 2 CLOCK. Clock signal output at internal frequency. \\
\hline \(\overline{\mathrm{NMI}}\) & 1 & 23 & 25 & NON-MASKABLE INTERRUPT. A negative going edge on the Non-Maskable Interrupt signal requests that a non-maskable interrupt be generated with the CPU. \\
\hline PAO-PA7 & I/O & 39-32 & 42-35 & PORT A. General purpose I/O Port A. \\
\hline PB0-PB7 & I/O & 31-24 & 34-30, 28-26 & PORT B. General purpose I/O Port B. \\
\hline PC0-PC7 & I/O & 54-61 & 58-65 & PORT C. General purpose I/O Port C. \\
\hline PD0-PD7 & I/O & 62-64, 1-5 & 66, 67, 1-6 & PORT D. General purpose I/O Port D. \\
\hline & & & & Four 8-bit ports used for either input/output. Each line of Ports A, B and C consists of an active transistor to \(\mathrm{V}_{\mathrm{SS}}\) and a passive pull-up to \(\mathrm{V}_{\mathrm{CC}}\). Port \(D\) functions as either an 8 -bit input or an 8 -bit output port. It has active pull-up and pull-down transistors. \\
\hline A0-A12, A15 & 0 & 20-8,7 & 21-9, 8 & ADDRESS LINES. Fourteen address lines used to address a complete 65 K external address space. Note: A13 and A14 are sourced through PC6 and PC7 when in the Full Address Mode. \\
\hline DB0-DB7 & I/O & 53-46 & 57-50 & DATA LINES. Eight bidirectional data bus lines used to transmit data to and from external memory. \\
\hline SYNC & 0 & 22 & 24 & SYNC. SYNC is a positive going signal for the full clock cycle whenever the CPU is performing an OP CODE fetch. \\
\hline \(\mathrm{R} / \bar{W}\) & 0 & 40 & 43 & READ/WRITE. Controls the direction of data transfer between the CPU and the external 65 K address space. The signal is high when reading and low when writing. \\
\hline
\end{tabular}

\title{
SECTION 3 SYSTEM ARCHITECTURE
}

This section provides a functional description of the R6501. Functionally the R6501 consists of a CPU, RAM, four 8 -bit parallel I/O ports, a serial I/O port, dual counter/latch circuits, a mode control register, and an interrupt flag/enable dual register circuit. a block diagram of the system is shown in Figure 3-1.

\section*{NOTE}

Throughout this document, unless specified otherwise, all memory or register address locations are specified in hexadecimal notation.

\subsection*{3.1 CPU LOGIC}

The R6501 internal CPU is a standard 6502 configuration with an 8-bit Accumulator register, two 8-bit Index Registers (X and Y); an 8-bit Stack Pointer register, an ALU, a 16-bit Program Counter, and standard instruction register/decode and internal timing control logic.

\subsection*{3.1.1 Accumulator}

The accumulator is a general purpose 8 -bit register that stores the results of most arithmetic and logic operations. In addition, the accumulator usually contains one of the two data words used in these operations.

\subsection*{3.1.2 Index Registers}

There are two 8 -bit index registers, X and Y . Each index register can be used as a base to modify the address data program counter and thus obtain a new address-the sum of the program counter contents and the index register contents.

When executing an instruction which specifies indirect addressing, the CPU fetches the op code and the address and modifies the address from memory by adding the index register to it prior to loading or storing the value of memory.

Indexing greatly simplifies many types of programs, especially those using data tables.

\subsection*{3.1.3 Stack Pointer}

The Stack Pointer is an 8 -bit register. It is automatically incremented and decremented under control of the microprocessor to perform stack manipulation in response to either user instructions, an internal \(\overline{\mathrm{RQ}}\) interrupt, or the external interrupt line \(\overline{\mathrm{NM}}\). The Stack Pointer must be initialized by the user program.

The stack allows simple implementation of multiple level interrupts, subroutine nesting and simplification of many types of data manipulation. The JSR, BRK, RTI and RTS instructions use the stack and Stack Pointer.

The stack can be envisioned as a deck of cards which may be accessed only from the top. The address of a memory
location is stored (or "pushed") onto the stack. Each time data are to be pushed onto the stack, the Stack Pointer is placed on the Address Bus, data are written into the memory location addressed by the Stack Pointer, and the Stack Pointer is decremented by 1. Each time data are read (or "pulled") from the stack, the Stack Pointer is incremented by 1. The Stack Pointer is then placed on the Address Bus and data are read from the memory location addressed by the Pointer.

The stack is located on zero page, i.e., memory locations 00FF-0040. After reset, which leaves the Stack Pointer indeterminate, normal usage calls for its initialization at 00FF.

\subsection*{3.1.4 Arithmetic And Logic Unit (ALU)}

All arithmetic and logic operations take place in the ALU, including incrementing and decrementing internal registers (except the Program Counter). The ALU cannot store data for more than one cycle. If data are placed on the inputs to the ALU at the beginning of a cycle, the result is always gated into one of the storage registers or to external memory during the next cycle.

Each bit of the ALU has two inputs. These inputs can be tied to various internal buses or to a logic zero; the ALU then generates the function (AND, OR, SUM, and so on) using the data on the two inputs.

\subsection*{3.1.5 Program Counter}

The 16 -bit Program Counter provides the addresses that are used to step the processor through sequential instructions in a program. Each time the processor fetches an instruction from program memory, the lower (least significant) byte of the Program Counter (PCL) is placed on the low-order bits of the Address Bus and the higher (most significant) byte of the Program Counter \((\mathrm{PCH})\) is placed on the high-order 8 bits of the Address Bus. The Counter is incremented each time an instruction or data is fetched from program memory.

\subsection*{3.1.6 Instruction Register and Instruction Decode}

Instructions are fetched from ROM or RAM and gated onto the Internal Data Bus. These instructions are latched into the Instruction Register, then decoded along with timing and interrupt signals to generate control signals for the various registers.

\subsection*{3.1.7 Timing Control}

The Timing Control Logic keeps track of the specific instruction cycle being executed. This logic is set to TO each time an instruction fetch is executed and is advanced at the beginning of each Phase One clock pulse for as many cycles as are required to complete the instruction. Each data transfer which takes place between the registers is caused by decoding the contents of both the instruction register and timing control unit.


\subsection*{3.1.8 Interrupt Logic}

Interrupt logic controls the sequencing of three interrupts; \(\overline{\mathrm{RES}}\), \(\overline{\mathrm{NMI}}\) and \(\overline{\mathrm{RQ}} . \overline{\mathrm{IRQ}}\) is generated by any one of eight conditions: 2 Counter Overflows, 2 Positive Edge Detects, 2 Negative Edge Detects, and 2 Serial Port Conditions.

\subsection*{3.2 NEW INSTRUCTIONS}

In addition to the standard R6502 instruction set, four new bit manipulation instructions have been added to the R6501. The added instructions and their format are explained in the following paragraphs. Refer to Appendix A for the Op Code mnemonic addressing matrix for these added instructions. The four added instructions do not impact the CPU processor status register.

\subsection*{3.2.1 Set Memory Bit SMB m, Addr.)}

This instruction sets to " 1 " one of the 8 -bit data field specified by the zero page address (memory or I/O port). The first byte of the instruction specifies the SMB operation and one of eight bits to be set. The second byte of the instruction designates address \((0-255)\) of the byte to be operated upon.

\subsection*{3.2.2 Reset Memory Bit (RMB m, Addr.)}

This instruction is the same operation and format as SMB instruction except a reset to " 0 " of the bit results.

\subsection*{3.2.3 Branch On Bit Set Relative (BBS m, Addr, DEST)}

This instruction tests one of eight bits designated by a 3-bit immediate field within the first byte of the instruction. The second byte is used to designate the address of the byte to be tested within the zero page address range (memory or I/O ports). The third byte of the instruction is used to specify the 8 -bit relative address to which the instruction branches if the bit tested is a " 1 ". If the bit tested is not set, the next sequential instruction is executed.

\subsection*{3.2.4 Branch On Bit Reset Relative (BBR m, Addr, DEST)}

This instruction is the same operation and format as the BBS instruction except that a branch takes place if the bit tested is a " 0 ".

\subsection*{3.3 READ-ONLY-MEMORY (ROM)}

The R6501 has no ROM and its Reset vector is at FFFC.

\subsection*{3.4 RANDOM ACCESS MEMORY (RAM)}

The RAM consists of 192 bytes of read/write memory with an assigned page zero address of 0040 through 00FF. The R6501 provides a separate power pin ( \(V_{\text {RR }}\) ) which may be used for standby power for 32 bytes located at 0040-005F. In the event of the loss of \(V_{C C}\) power, the lowest 32 bytes of RAM data will be retained if standby power is supplied to the \(V_{R R}\) pin. If the RAM data retention is not required then \(V_{R R}\) must be connected to \(\mathrm{V}_{\mathrm{CC}}\). During operation \(\mathrm{V}_{\mathrm{RR}}\) must be at the \(\mathrm{V}_{\mathrm{CC}}\) level.

For the RAM to retain data upon loss of \(\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{RR}}\) must be supplied within operating range and \(\overline{\mathrm{RES}}\) must be driven low at least eight \(\emptyset 2\) clock pulses before \(\mathrm{V}_{\mathrm{CC}}\) falls out of operating range. \(\overline{\operatorname{RES}}\) must then be held low while \(V_{C C}\) is out of operating range and until at least eight \(\emptyset 2\) clock cycles after \(V_{c c}\) is again within operating range and the internal \(\emptyset 2\) oscillator is stabilized. \(\mathrm{V}_{\mathrm{RR}}\) must remain within \(\mathrm{V}_{\mathrm{CC}}\) operating range during normal operation. When \(\mathrm{V}_{\mathrm{CC}}\) is out of operating range, \(\mathrm{V}_{\mathrm{RR}}\) must remain within the \(V_{R R}\) retention range in order to retain data. Figure 3.2 shows typical waveforms.


Figure 3-2. Data Retention Timing

\subsection*{3.5 CLOCK OSCILLATOR}

The R6501 has been configured for a crystal oscillator, a countdown network, and for Master Mode Operation.
A reference frequency can be generated with the on-chip oscillator using either an external crystal or an external oscillator. The oscillator reference frequency passes through an internal countdown network to obtain the internal operating frequency.
The on-chip oscillator is designed for a parallel resonant crystal connected between XTLI and XTLO pins. The equivalent oscillator circuit is shown in Figure 3-3a.
A parallel resonant crystal is specified by its load capacitance and series resonant resistance. For proper oscillator operation, the load capacitance \(\left(\mathrm{C}_{\mathrm{L}}\right)\), series resistance \(\left(\mathrm{R}_{\mathrm{S}}\right)\) and the crystal resonant frequency ( F ) must meet the following two relations:
\[
\begin{gathered}
(C+27)=2 C_{L} \quad \text { or } \quad C=2 C_{L}-27 p F \\
R_{s} \leq R_{s \operatorname{smax}}=\frac{2 \times 10^{6}}{\left(F C_{L}\right)^{2}}
\end{gathered}
\]
where: \(F\) is in \(M H z ; C\) and \(C_{L}\) are in \(\mathrm{PF} ; R\) is in ohms.
To select a parallel resonant crystal for the oscillator, first select the load capacitance from a crystal manufacturer's catalog. Next, calculate \(\mathrm{R}_{\text {smax }}\) based on F and \(\mathrm{C}_{\mathrm{L}}\). The selected crystal must have a \(\mathrm{R}_{\mathrm{s}}\) less than the \(\mathrm{R}_{\text {smax }}\).
For example, if \(\mathrm{C}_{\mathrm{L}}=22 \mathrm{pF}\) for a 4 MHz parallel resonant crystal, then
\[
\mathrm{C}=(2 \times 22)-27=17 \mathrm{pF} \text { (use standard value of } 18 \mathrm{pF} \text { ) }
\]

The series resistance of the crystal must be less than
\[
R_{\text {smax }}=\frac{2 \times 10^{6}}{(4 \times 22)^{2}}=258 \text { ohms }
\]

Internal timing can also be controlled by driving the XTLI pin with an external frequency source. Figure 3-3b shows typical connections. If XTLO is left floating, the external source is divided by the internal countdown network. However, if XTLO is tied to \(\mathrm{V}_{\mathrm{SS}}\), the internal countdown network is bypassed causing the chip to operate at the frequency of the external source.

A. CRYSTAL INPUT

\(1-2 \mathrm{MHz}\)

B. CLOCK INPUTS

Figure 3-3. Clock Oscillator Input Options

\subsection*{3.6 MODE CONTROL REGISTER (MCR)}

The Mode Control Register contains control bits for the multifunction I/O ports and mode select bits for Counter A and Counter B. Its setting, along with the setting of the Serial Communications Control Register (SCCR), determines the basic configuration of the R6501 in any application. Initializing this register is one of the first actions of any software program. The Mode control Register bit assignment is shown in Figure 3-4.

\subsection*{3.7 INTERRUPT FLAG REGISTER (IFR) AND INTERRUPT ENABLE REGISTER (IER)}
\(\mathrm{An} \overline{\mathrm{RQ}}\) interrupt request can be initiated by any or all of eight possible sources. These sources are all capable of being enabled or disabled by the use of the appropriate interrupt enabled bits in the Interrupt Enable Register (IER). Multiple
simultaneous interrupts cause the \(\overline{\mathrm{RQ}}\) interrupt request to remain active until all interrupting conditions have been serviced and cleared.

The Interrupt Flag Register contains the information that indicates which I/O or counter needs attention. The contents of the Interrupt Flag Register may be examined at any time by reading at address: 0011. Edge detect IFR bits may be cleared by executing a RMB instruction at address location 0010. The RMB X, (0010) instruction reads FF, modifies bit \(X\) to a " 0 ", and writes the modified value at address location 0011. In this way IFR bits set to a "1". after the read cycle of a Read-Modify-Write instruction (such as RMB) are protected from being cleared. A logic " 1 " is ignored when writing to edge detect IFR bits.

Each IFR bit has a corresponding bit in the Interrupt Enable Register which can be set to a " 1 " by writing a "1" in the respective bit position at location 0012. Individual IER bits may be cleared by writing a " 0 " in the respective bit position, or by RES. If set to a " 1 ", an IRQ will be generated when the corresponding IFR bit becomes true. The Interrupt Flag Register and Interrupt Enable Register bit assignments are shown in Figure 3-5 and the functions of each bit are explained in Table 3-1.


Figure 3-4. Mode Control Register

The use of Counter A Mode Select is shown in Section 6.1.
The use of Counter B Mode Select is shown in Section 6.2.
The use of Port B Latch Enable is shown in Section 4.4
The use of Port D in Tri-State Enable is shown in Section 4.6.
The use of Bus Mode Select is shown in Section 4.5 and 4.6.


Figure 3-5. Interrupt Enable and Flag Registers

\subsection*{3.8 PROCESSOR STATUS REGISTER}

The 8-bit Processor Status Register, shown in Figure 3-6, contains seven status flags. Some of these flags are controlled by the user program; others may be controlied both by the user's program and the CPU. The R6502 instruction set contains a number of conditional branch instructions which are designed to allow testing of these flags. Each of the eight processor status flags is described in the following sections.

\subsection*{3.8.1 Carry Bit (C)}

The Carry Bit (C) can be considered as the ninth bit of an arithmetic operation. It is set to logic 1 if a carry from the eighth bit has occurred or cleared to logic 0 if no carry occurred as the result of arithmetic operations.

The Carry Bit may be set or cleared under program control by use of the Set Carry (SEC) or Clear Carry (CLC) instruction, respectively. Other operations which affect the Carry Bit are ADC, ASL, CMP, CPX, CPY, LSR, PLP, ROL, ROR, RTI, and SBC.


Figure 3-6. Processor Status Register

Table 3-1. Interrupt Flag Register Bit Codes
\begin{tabular}{|c|c|}
\hline \begin{tabular}{l}
Bit \\
Code
\end{tabular} & Function \\
\hline IFR 0: & PA0 Positive Edge Detect Flag-Set to a "1" when a positive going edge is detected on PA0. Cleared by RMB O (0010) instruction or by \(\overline{\text { RES. }}\). \\
\hline IFR 1: & PA1 Positive Edge Detect Flag-Set to a 1 when a positive going edge is detected on PA1. Cleared by RMB 1 (0010) instruction or by \(\overline{\text { RES. }}\) \\
\hline IFR 2: & PA2 Negative Edge Detect Flag-Set to a 1 when a negative going edge is detected on PA2. Cleared by RMB 2 (0010) instruction or by RES. \\
\hline IFR 3: & PA3 Negative Edge Detect Flag-Set to 1 when a negative going edge is detected on PA3. Cleared by RMB 3 (0010) instruction or by \(\overline{\text { RES. }}\) \\
\hline IFR 4: & Counter A Underflow Flag-Set to a 1 when Counter A underflow occurs. Cleared by reading the Lower Counter A at location 0018, by writing to address location 001A, or by \(\overline{\operatorname{RES}}\). \\
\hline IFR 5: & Counter B Underflow Flag-Set to a 1 when Counter B underflow occurs. Cleared by reading the Lower Counter \(B\) at location 001C, by writing to address location 001E, or by \(\overline{\operatorname{RES}}\). \\
\hline IFR 6: & Receiver Interrupt Flag-Set to a 1 when any of the Serial Communication Status Register bits 0 through 3 is set to a 1 . Cleared when the Receiver Status bits (SCSR 0-3) are cleared or by RES. \\
\hline IFR 7: & Transmitter Interrupt Flag-Set to a 1 when SCSR 6 is set to a 1 while SCSR 5 is a 0 or SCSR 7 is set to a 1 . Cleared when the Transmitter Status bits (SCSR \(6 \& 7\) ) are cleared or by \(\overline{\mathrm{RES}}\). \\
\hline
\end{tabular}

\subsection*{3.8.2 Zero Bit (Z)}

The Zero Bit \((Z)\) is set to logic 1 by the CPU during any data movement or calculation which sets all 8 bits of the result to zero. This bit is cleared to logic 0 when the resultant 8 bits of a data movement or calculation operation are not all zero. The R6500 instruction set contains no instruction to specifically set or clear the Zero Bit. The Zero Bit is, however, affected by the following instructions; ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TXA, TSX, and TYA.

\subsection*{3.8.3 Interrupt Disable Bit (I)}

The Interrupt Disable Bit (I) is used to control the servicing of an interrupt request ( \(\overline{\mathrm{IRQ})}\). If the I Bit is reset to logic 0 , the \(\overline{\mathrm{IRQ}}\) signal will be serviced. If the bit is set to logic 1 , the \(\overline{\operatorname{IRQ}}\) signal will be ignored. The CPU will set the Interrupt Disable Bit to logic 1 if a RESET ( \(\overline{\operatorname{RES}}\) ), \(\overline{\mathrm{RQ}}\), or Non-Maskable Interrupt ( \(\overline{\mathrm{NMI}}\) ) signal is detected.

The I bit is cleared by the Clear Interrupt Mask Instruction (CLI) and is set by the Set Interrupt Mask Instruction (SEI). This bit is set by the BRK Instruction. The Return from Interrupt (RTI) and Pull Processor Status (PLP) instructions will also affect the I bit.

\subsection*{3.8.4 Decimal Mode Bit (D)}

The Decimal Mode Bit (D) is used to control the arithmetic mode of the CPU. When this bit is set to logic 1, the adder operates as a decimal adder. When this bit cleared to logic 0 , the adder operates as a staight binary adder. The adder mode is controlled only by the programmer. The Set Decimal Mode (SED) instruction will set the D bit; the Clear Decimal Mode (CLD) instruction clears it. The PLP and RTI instructions also affect the Decimal Mode Bit.

\section*{CAUTION}

The Decimal Mode Bit will either set or clear in an unpredictable manner upon power application. This bit must be initialized to the desired state by the user program or erroneous results may occur.

\subsection*{3.8.5 Break Bit (B)}

The Break Bit \((\mathrm{B})\) is used to determine the condition which caused the \(\overline{\mathrm{R} Q}\) service routine to be entered. If the \(\overline{\mathrm{RQ}}\) service routine was entered because the CPU executed a BRK command, the Break Bit will be set to logic 1 . If the \(\overline{\mathrm{RQ}}\) routine was entered as the result of an \(\overline{\mathrm{RQ}}\) signal being generated, the B bit will be cleared to logic 0 . There are no instructions which can set or clear this bit.

\subsection*{3.8.6 Overflow Bit (V)}

The Overflow Bit (V) is used to indicate that the result of a signed, binary addition, or subtraction, operation is a value that cannot be contained in seven bits ( \(-128 \leqslant n \leqslant 127\) ). This indicator only has meaning when signed arithmetic (sign and seven magnitude bits) is performed. When the ADC or SBC instruction is performed, the Overflow Bit is set to logic 1 if the polarity of the sign bit (bit 7 ) is changed because the result exceeds +127 or -128 ; otherwise the bit is cleared to logic 0 . The V bit may also be cleared by the programmer using a Clear Overflow (CLV) instruction.

The Overflow Bit may also be used with the BIT instruction. The BIT instruction-which may be used to sample interface devices-allows the overflow flag to reflect the condition of bit 6 in the sampled field. During a BIT instruction the Overflow Bit is set equal to the content of the bit 6 on the data tested with BIT instruction. When used in this mode, the overflow has nothing to do with signed arithmetic, but is just another sense bit for the microprocessor. Instructions affecting the \(V\) flag are ADC, BIT, CLV, PLP, RTI and SBC.

\subsection*{3.8.7 Negative Bit ( N )}

The Negative Bit \((\mathrm{N})\) is used to indicate that the sign bit (bit 7) in the resulting value of a data movement or data arithmetic operation is set to logic 1 . If the sign bit is set to logic 1 , the resulting value of the data movement or arithmetic operation is negative; if the sign bit is cleared, the result of the data movement or arithmetic operation is positive. There are no instructions that set or clear the Negative Bit since the Negative Bit represents only the status of a result. The instructions that effect the state of the Negative Bit are: ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TSX, TXA, and TYA.

\title{
SECTION 4 PARALLEL INPUT/OUTPUT PORTS \& BUS MODES
}

The devices have \(32 \mathrm{I} / \mathrm{O}\) lines grouped into four 8 -bit ports (PA, PB, PC, and PD). Ports A through C may be used either for input or output individually or in groups of any combination. Port D may be used as all inputs or all outputs.

Multifunction I/O's such as Port A and Port C are protected from normal port I/O instructions when they are programmed to perform a multiplexed function.

Internal pull-up resistors (FET's with an impedance range of \(3 K \leqslant R_{L} \leqslant 12 \mathrm{~K}\) ohm) are provided on all port pins except Port D.

The direction of the \(32 \mathrm{I} / \mathrm{O}\) lines is controlled by four 8 -bit port registers located in page zero. This arrangement provides quick programming access using simple two-byte zero page address instructions. There are no direction registers associated with the I/O ports, thus simplifying I/O handling. The I/O addresses are shown in Table 4-1. Appendix E. 4 shows the I/O Port Timing.

Table 4-1. I/O Port Addresses
\begin{tabular}{|c|c|}
\hline Port & Address \\
\hline A & 0000 \\
B & 0001 \\
C & 0002 \\
D & 0003 \\
\hline
\end{tabular}

\subsection*{4.1 INPUTS}

Inputs for Ports A, B, and C are enabled by loading logic 1 into all I/O port register bit positions that are to correspond to \(/ / O\) input lines. A low \((<0.8 \mathrm{~V})\) input signal will cause a logic 0 to be read when a read instruction is issued to the port register. A high ( \(>2.0 \mathrm{~V}\) ) input will cause a logic 1 to be read. An RES signal forces all I/O port registers to logic 1 thus initially treating all I/O lines as inputs.

Port D may only be all inputs or all outputs. All inputs is selected by setting bit 5 of the Mode Control Register (MCR5) to a " 0 ".

The status of the input lines can be interrogated at any time by reading the I/O port addresses. Note that this will return the actual status of the input lines, not the data written into the I/O port registers.

Read/Modify/Write instructions can be used to modify the operation of PA, PB, PC, \& PD. During the Read cycle of a Read/Modify/Write instruction the Port I/O register is read. For all other read instructions the port input lines are read. Read/Modify/Write instructions are: ASL, DEC, INC, LSR, RMB, ROL, ROR, and SMB.

\subsection*{4.2 OUTPUTS}

Outputs for Ports A thru D are controlled by writing the desired I/O line output states into the corresponding I/O port register bit positions. A logic 1 will force a high ( \(>2.4 \mathrm{~V}\) ) output while a logic 0 will force a low ( \(<0.4 \mathrm{~V}\) ) output.

Port D all outputs is selected by setting MCR5 to a " 1 ".

\subsection*{4.3 Port A (PA)}

Port A can be programmed via the Mode Control Register (MCR) and the Serial Communications Control Register (SCCR) as a standard parallel 8-bit, bit independent, I/O port or as serial channel I/O lines, counter I/O lines, or an input data strobe for the Port B input latch option. Table 4-2 tabulates the control and usage of Port A.

In addition to their normal I/O functions, PAO and PA1 can detect positive going edges and PA2 and PA3 can detect negative going edges. A proper transition on these pins will set a corresponding status bit in the IFR and generate an interrupt request if the respective Interrupt Enable Bit is set. The maximum rate at which an edge can be detected is onehalf the \(\phi 2\) clock rate. Edge detection timing is shown in Appendix E. 3 .

Table 4-2. Port A Control and Usage


\subsection*{4.4 PORT B (PB)}

Port B can be programmed as an 8-bit, bit-independent I/O port. It has a latched input capability which may be enabled or disabled via the Mode Control Register (MCR). Table 4-3 tabulates the control and usage of Port B. An Input Data Strobe signal must be provided thru PAO when Port B is programmed to be used with latched input option. Input data latch timing for Port B is shown in Appendix E.5.

Table 4-3. Port B Control \& Usage
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{2}{|l|}{\multirow[t]{2}{*}{}} & \multicolumn{2}{|c|}{I/O Mode} & \multicolumn{2}{|c|}{Latch Mode} \\
\hline & & \multicolumn{2}{|l|}{MCR4 \(=0\)} & \multicolumn{2}{|r|}{\begin{tabular}{l}
\[
\text { MCR4 }=1
\] \\
(2)
\end{tabular}} \\
\hline \multirow[b]{2}{*}{\[
\begin{gathered}
\text { Pin } \\
\#
\end{gathered}
\]} & \multirow[b]{2}{*}{\begin{tabular}{l}
Pin \\
Name
\end{tabular}} & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} \\
\hline & & Name & \begin{tabular}{l}
Type \\
(1)
\end{tabular} & Name & Type \\
\hline 31 & PB0 & PB0 & I/O & PB0 & INPUT \\
\hline 30 & PB1 & PB1 & 1/0 & PB1 & INPUT \\
\hline 29 & PB2 & PB2 & I/O & PB2 & INPUT \\
\hline 28 & PB3 & PB3 & 1/0 & PB3 & INPUT \\
\hline 27 & PB4 & PB4 & 1/0 & PB4 & INPUT \\
\hline 26 & PB5 & PB5 & 1/0 & PB5 & INPUT \\
\hline 25 & PB6 & PB6 & 1/O & PB6 & INPUT \\
\hline 24 & PB7 & PB7 & 1/O & PB7 & INPUT \\
\hline \multicolumn{6}{|l|}{\begin{tabular}{l}
(1) Resistive Pull-Up, Active Buffer Pull-Down \\
(2) Input data is stored in Port B latch by PAO Pulse
\end{tabular}} \\
\hline
\end{tabular}

\subsection*{4.5 PORT C (PC)}

Port C can be programmed as an I/O port, as part of the full address bus, and, in conjunction with Port D , as an abbreviated bus, or as a multiplexed bus. When operating in the Full Address Mode PC6 and PC7 serve as A13 and A14 with PCO-PC5 operating as normal I/O pins. When used in the abbreviated or multiplexed bus modes, PC0-PC7 function as A0-A3, A12, R/W, A13, and EMS, respectively, as shown in Table 4-4. EMS (External Memory Select) is asserted (low) whenever the internal processor accesses memory area between 0100 and 3FFF. (See Memory Map, Appendix B). The leading edge of EMS may be used to strobe the eight address lines multiplexed on Port D in the Multiplexed Bus Mode. See Appendices E. 3 through E. 5 for Port C timing.

\subsection*{4.6 PORT D (PD)}

Port D can be programmed as an I/O Port, an 8-bit tri-state data bus, or as a multiplexed bus. Mode selection for Port D is made by the Mode Control Register (MCR). The Port D output drivers can be selected as tri-state drivers by setting bit 5 of the MCR to 1 (one). Table \(4-5\) shows the necessary settings for the MCR to achieve the various modes for Port D. When Port D is
selected to operate in the Abbreviated Mode PDO-PD7 serves as data register bits D0-D7. When Port D is selected to operate in the Multiplexed Mode data bits D0 through D7 are time multiplexed with address bits A4 through A11, respectively. Refer to the Memory Maps (Appendix C) for Abbreviated and Multiplexed memory assignments. See Appendices E. 3 through E. 5 for Port D timing.

\subsection*{4.7 BUS MODES}

A special attribute of Port C and Port D is their capability to be configured via the Mode Control Register (see Section 3.6) into four different modes.

In the Full Address Mode, the separate address and data bus are used in conjunction with PC6 and PC7, which automatically provide A13 and A14. The remaining ports perform the normal I/O function.

In the I/O Bus Mode all ports serve as I/O. The address and data bus are still functional but without A13 and A14. Since the internal RAM and registers are in the 00XX location, A15 can be used for chip select and A0-A12 used for selecting 8 K of external memory.

In the Abbreviated Bus Mode, the address and data lines can be used as in the I/O Bus Mode to emulate the R6500/11. Port C and Port D are automatically transformed into an abbreviated address bus and control signals (Port C) and a bidirectional data bus (Port D). 64 Peripheral addresses can be selected. In general usage, these 64 addresses would be distributed to several external I/O devices such as R6522 and R6520, etc., each of which may contain more than one unique address.

In the Multiplexed Bus Mode, the operation is similar to the Abbreviated Mode except that a full 16K of external addresses are provided. Port C provides the lower addresses and control signals. Port D multiplexes functions. During the first half of the cycle it contains the remaining necessary 8 address bits for 16K; during the second half of the cycle it contains a bidirectional data bus. The address bits appearing on Port D must be latched into an external holding register. The leading edge of EMS which indicates that the bus function is active, may be used for this purpose.

MCR5 must be a logic 1 in the Abbreviated and Multiplexed Bus Modes.

Figures 4-1a through 4-1d show the possible configurations of the four bus modes. Figure \(4-2\) shows a memory map of the part as a function of the Bus Mode and further shows which adddresses are active or inactive on each of the three possible buses.

Table 4-4. Port C Control \& Usage
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{} & \multicolumn{2}{|c|}{Full Address Mode} & \multicolumn{2}{|r|}{Normal Mode} & \multicolumn{2}{|c|}{Abbreviated Mode} & \multicolumn{2}{|c|}{Multiplexed Mode} \\
\hline & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=0 \\
& \text { MCR6 }=0
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=0 \\
& \text { MCR6 }=1
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=0
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=1
\end{aligned}
\]} \\
\hline & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} \\
\hline Pin Name & Name & Type & Name & \begin{tabular}{l}
Type \\
(1)
\end{tabular} & Type Name & (2) & Type Name & (2) \\
\hline PC0 & PC0 & I/O (1) & PC0 & 1/0 & A0 & OUTPUT & AO & OUTPUT \\
\hline PC1 & PC1 & I/O (1) & PC1 & 1/0 & A1 & OUTPUT & A1 & OUTPUT \\
\hline PC2 & PC2 & I/O (1) & PC2 & 1/0 & A2 & OUTPUT & A2 & OUTPUT \\
\hline PC3 & PC3 & I/O (1) & PC3 & 1/0 & A3 & OUTPUT & A3 & OUTPUT \\
\hline PC4 & PC4 & I/O (1) & PC4 & 1/0 & A12 & OUTPUT & A12 & OUTPUT \\
\hline PC5 & PC5 & 1/O (1) & PC5 & 1/O & \(R \bar{W}\) & OUTPUT & RWW & OUTPUT \\
\hline PC6 & A13 & OUTPUT (2) & PC6 & I/O & A13 & OUTPUT & A13 & OUTPUT \\
\hline PC7 & A14 & OUTPUT (2) & PC7 & I/O & EMS & OUTPUT & \(\overline{\text { EMS }}\) & OUTPUT \\
\hline
\end{tabular}
(1) Resistive Pull-Up, Active Buffer Pull-Down
(2) Active Buffer Pull-Up and Pull-Down

Table 4-5. Port D Control \& Usage

(1) Tri-State Buffer is in High Impedance Mode
(2) Tri-State Buffer is in Active Mode
(3) Tri-State Buffer is in Active Mode only during the phase 2 portion of a Write Cycle

A. FULL ADDRESS MODE

B. NORMAL BUS MODE

D. MULTIPLEXED BUS MODE

Figure 4-1. R6501 Bus Mode Configurations


Figure 4-2. R6501 Memory Map

\section*{SECTION 5 SERIAL INPUT/OUTPUT CHANNEL}

The device provides a full duplex Serial I/O channel with programmable bit rates and operating modes. The serial I/O functions are controlled by the Serial Communication Control Register (SCCR). The SCCR bit assignment is shown in Figure 5-1. The serial bit rate is determined by Counter A for all modes except the Receiver Shift Register (RCVR S/R) mode for which an external shift clock must be provided. The maximum data rate using the internal clock is 62.5 K bits per second (at \(\phi 2=1 \mathrm{MHZ}\) ). The transmitter (XMTR) and receiver (RCVR) can be independently programmed to operate in different modes and can be independently enabled or disabled.


Figure 5-1. Serial Communication Control Register

Except for the Receiver Shift Register Mode (RCVR S/R), all XMTR and RCVR bit rates will occur at one sixteenth of the Counter A interval timer rate. Counter A is forced into an interval timer mode whenever the serial I/O is enabled in a mode requiring an internal clock.

Whenever Counter \(A\) is required as a timing source it must be loaded with the hexadecimal code that selects the data rate for the serial I/O Port. Refer to Counter A (paragraph 6.1) for a table of hexadecimal values to represent the desired data rate.

\subsection*{5.1 TRANSMITTER OPERATION (XTMR)}

The XTMR operation and the transmitter related control/ status functions are enabled by bit 7 of the Serial Communications Control Register (SCCR). The transmitter, when in the Asynchronous (ASYN) mode, automatically adds a start bit, one or two stop bits, and, when enabled, a parity bit to the transmitted data. A word of transmitted data (in asynchronous parity mode) can have \(5,6,7\), or 8 bits of data. The nine data modes are shown in Figure 5-2. When parity is disabled, the \(5,6,7\) or 8 bits of data are terminated with two stop bits.


Figure 5-2. SIO Data Modes
In the S/R mode, eight data bits are always shifted out. Bits/ character and parity control bits are ignored. The serial data is shifted out via the SO output (PA6) and the shift clock is available at the CA (PA4) pin. When the transmitter underruns in the S/R mode the SO output and shift clock are held in a high state.

The XMTR Interrupt Flag bit (IFR7) is controlled by Serial Communication Status Register bits SCSR5, SCSR6 and SCSR7.
\[
\text { IFR7 }=\text { SCSR6 }(\overline{\text { SCSR5 }}+\text { SCSR7 })
\]

\subsection*{5.2 RECEIVER OPERATION (RCVR)}

The receiver and its selected control and status functions are enabled when SCCR-6 is set to a "1." In the ASYN mode, data format must have a start bit, the appropriate number of data bits, a parity bit (if enabled), and one stop bit. Refer to paragraph 5.1 for a diagram of bit allocations. The receiver bit period is divided into 8 sub-intervals for internal synchronization. The receiver bit stream is synchronized by the start bit and a strobe signal is generated at the approximate center of each incoming bit. Refer to Figure 5-3 for ASYN Receive Data Timing. The character assembly process does not start if the start bit signal is less than one-half the bit time after a low level is detected on the Receive Data Input. Framing error, over-run, and parity error conditions or a RCVR Data Register Full will set the appropriate status bits. Any of the above conditions will cause an Interrupt Request if the Receiver Interrupt Enable bit is set to logic 1.


Figure 5-3. ASYN Receive Data Timing
In the S/R mode, an external shift clock must be provided at CA (PA4) pin along with 8 bits of serial data (LSB first) at the SI input (PA7). The maximum data rate using an external shift clock is one-eighth the internal clock rate. Refer to Figure 5-4 for S/R Mode Timing.


Figure 5-4. S/R Mode Timing
A RCVR interrupt (IFR6) is generated whenever any of SCSRO-3 are true.

\subsection*{5.3 SERIAL COMMUNICATION STATUS REGISTER (SCSR)}

The Serial Communication Status Register (SCSR) holds information on various communication error conditions, status of the transmitter and receiver data registers, a transmitter end-of-transmission condition, and a receiver idle line condition (Wake-Up Feature). The SCSR bit assignment is shown in Figure 5-5. Bit assignments and functions of the SCSR are as follows:

SCSR 0: Receiver Data Register Full-Set to a logic 1 when a character is transferred from the Receiver Shift Register to the Receiver Data Register. This bit is cleared by reading the Receiver Data Register, or by \(\overline{\text { RES }}\) and is disabled if SCCR \(6=0\). The SCSR 0 bit will not be set to a logic 1 if the received data contains an error condition; instead, a corresponding error bit will be set to a logic 1 .

SCSR 1: Over-Run Error-Set to a logic 1 when a new character is transferred from the Receiver Shift Register with the last character still in the Receiver Data Register. This bit is cleared by reading the Receiver Data Register or by RES.

SCSR 2: Parity Error-Set to logic 1 when the RCVR is in the ASYN Mode, Parity Enable bit is set, and the
received data has a parity error. This bit is cleared by reading the Receiver Data Register or by RES.
SCSR 3: Framing Error-Set to a logic 1 when the received data contains a zero bit after the last data or parity bit in the stop bit slot. Cleared by reading the Receiver Data Register or by RES (ASYN Mode only).
SCSR 4: Wake-Up-Set to a logic 1 by writing a " 1 " in bit 4 of address: 0016. The Wake-Up bit is cleared by \(\overline{\text { RES }}\) or when the receiver detects a string of ten consecutive 1 's. When the Wake-Up bit is set SCSRO through SCSR3 are inhibited.
SCSR 5: End of Transmission-Set to a logic 1 by writing a " 1 " in bit position 5 of address: 0016. The End of Transmission bit is cleared by \(\overline{\text { RES }}\) or upon writing a new data word into the Transmitter Data Register. When the End-of-Transmission bit is true the Transmitter Register Empty bit is disabled until a Transmitter Under-Run occurs.
SCSR 6: Transmitter Data Register Empty—Set to a logic 1 when the contents of the Transmitter Data Register are transferred to the Transmitter Shift Register. Cleared upon writing new data into the Transmit Data Register. This bit is initialized to a logic 1 by \(\overline{\mathrm{RES}}\).
SCSR 7: Transmitter Under-Run-Set to a logic 1 when the last data bit is transmitted if the transmitter is in a S/R Mode or when the last stop bit is transmitted if the XMTR is in the ASYN Mode while the Transmitter Data Register Empty Bit is set. Cleared by a transfer of new data into the Transmitter Shift Register or by \(\overline{\text { RES }}\).


Figure 5-5. SCSR Bit Allocations

\subsection*{5.4 WAKE-UP FEATURE}

In a multi-distributed microprocessor or microcomputer appliations, a destination address is usually included at the beginning of the message. The Wake-Up Feature allows non-selected CPU's to ignore the remainder of the message until the beginning of the next message by setting the Wake-Up bit. As long as the Wake-Up flag is true, the Receiver Data Register Full Flag remains false. The Wake-Up bit is automatically cleared when the receiver detects a string of eleven consecutive 1 's which indicates an idle transmit line. When the next byte is received, the Receiver Data Register Full Flag signals the CPU to wake-up and read the received data.

\section*{SECTION 6 COUNTER/TIMERS}

The device contains two 16 -bit counters (Counter A and Counter B) and three 16 -bit latches associated with the counters. Counter A has one 16-bit latch and Counter B has two 16 -bit latches. Each counter can be independently programmed to operate in one of four modes:
```

    Counter A
    - Pulse width
    measurement
    - Pulse Generation
- Interval Timer
- Event Counter

```

Counter B
- Retriggerable Interval Counter
- Asymmetrical Pulse Generation
- Interval Timer
- Event Counter

Operating modes of Counter A and Counter B are controlled by the Mode Control Register. All counting begins at the initialization value and decrements. When modes are selected requiring a counter input/output line, PA4 is automatically selected for Counter A and PA5 is automatically selected for Counter B (see Table 4.2).

\subsection*{6.1 COUNTER A}

Counter A consists of a 16-bit counter and a 16-bit latch organized as follows: Lower Counter A (LCA), Upper Counter A (UCA), Lower Latch A (LLA), and Upper Latch A (ULA). The counter contains the count of either \(\emptyset 2\) clock pulses or external events, depending on the counter mode selected. The contents of Counter A may be read any time by executing a read at location 0019 for the Upper Counter A and at location 001 A or location 0018 for the Lower Counter A. A read at location 0018 also clears the Counter A Underflow Flag (IFR4).

The 16 -bit latch contains the counter initialization value and can be loaded at any time by executing a write to the Upper Latch A at location 0019 and the Lower Latch A at location 0018. In either case, the contents of the accumulator are copied into the applicable latch register.

Counter A can be started at any time by writing to address: 001 A . The contents of the accumulator will be copied into the


Figure 6-1. Interval Timer Timing Diagram

Upper Latch A before the contents of the 16-bit latch are transferred to Counter \(A\). Counter \(A\) is set to the latch value whenever Counter A underflows. When Counter A decrements from 0000 the next counter value will be the latch value-not FFFF-and the Counter A Underflow Flag (IFR \(4)\) will be set to "1". This bit may be cleared by reading the Lower Counter A at location 0018, by writing to address location 001A, or by RES.

Counter A operates in any of four modes. These modes are selected by the Counter A Mode Control bits in the Control Register.
\begin{tabular}{|c|c|l|}
\hline \begin{tabular}{c} 
MCR1 \\
(bit 1)
\end{tabular} & \begin{tabular}{c} 
MCR0 \\
(bit 0)
\end{tabular} & \multicolumn{1}{|c|}{ Mode } \\
\hline 0 & 0 & Interval Timer \\
0 & 1 & Pulse Generation \\
1 & 0 & Event Counter \\
1 & 1 & Pulse Width Measurement \\
\hline
\end{tabular}

The Interval Timer, Pulse Generation, and Pulse Width Measurement Modes are \(\phi 2\) clock counter modes. The Event Counter Mode counts the occurrences of an external event on the CNTR line.

The Counter is set to the Interval Timer Mode (00) when a \(\overline{R E S}\) signal is generated.

\subsection*{6.1.1 Interval Timer}

In the Interval Timer mode the Counter is initialized to the Latch value by either of two conditions:
1. When the Counter is decremented from 0000, the next Counter value is the Latch value (not FFFF).
2. When a write operation is performed to the Load Upper Latch and Transfer Latch to Counter address 001A, the Counter is loaded with the Latch value. Note that the contents of the Accumulator are loaded into the Upper Latch before the Latch value is transferred to the Counter.

The Counter value is decremented by one count at the 02 clock rate. The 16 -bit Counter can hold from 1 to 65535 counts. The Counter Timer capacity is therefore \(1 \mu \mathrm{~s}\) to 65.535 ms at the \(1 \mathrm{MHz} \emptyset 2\) clock rate or \(0.5 \mu \mathrm{~s}\) to 32.767 ms at the \(2 \mathrm{MHz} \emptyset 2\) clock rate. Time intervals greater than the maximum Counter value can be easily measured by counting \(\overline{\mathrm{IRQ}}\) interrupt requests in the counter \(\overline{\mathrm{R} Q}\) interrupt routine.

When Counter A decrements from 0000, the Counter A Underflow (IFR4) is set to logic 1. If the Counter A Interrupt Enable Bit (IER4) is also set, an \(\overline{\mathrm{RQ}}\) interrupt request will be generated. The Counter A Underflow bit in the Interrupt Flag Register can be examined in the \(\overline{\mathrm{IRQ}}\) interrupt routine to determine that the \(\overline{\mathrm{RQ}}\) was generated by the Counter A Underflow.

While the timer is operating in the Interval Timer Mode, PA4 operates as a PA I/O bit.

A timing diagram of the Interval Timer Mode is shown in Figure 6-1.

\subsection*{6.1.2 Pulse Generation Mode}

In the Pulse Generation mode, the CA line operates as a Counter Output. The line toggles from low to high or from high to low whenever a Counter A Underflow occurs or a write is performed to address 001 A .

The normal output waveform is a symmetrical square-wave. The CA output is initialized high when entering the mode and transitions low when writing to 001A.

Asymmetric waveforms can be generated if the value of the latch is changed after each counter underflow.

A one-shot waveform can be generated by changing from Pulse Generation to Interval Timer mode after only one occurrence of the output toggle condition.

\subsection*{6.1.3 Event Counter Mode}

In this mode the CA is used as an Event Input line, and the Counter will decrement with each rising edge detected on this line. The maximum rate at which this edge can be detected is one-half the \(\phi 2\) clock rate.

The Counter can count up to 65,535 occurrences before underflowing. As in the other modes, the Counter A Underflow bit (IER4) is set to logic 1 if the underflow occurs.

Figure 6.2 is a timing diagram of the Event Counter Mode.


Figure 6-2. Event Counter Mode

\subsection*{6.1.4 Pulse Width Measurement Mode}

This mode allows the accurate measurement of a low pulse duration on the CA line. The Counter decrements by one count at the \(\emptyset 2\) clock rate as long as the CA line is held in the low state. The Counter is stopped when CA is in the high state.

The Counter A underflow flag will be set only when the count in the timer reaches zero. Upon reaching zero the timer will be loaded with the latch value and continue counting down as long as the CA pin is held low. After the counter is stopped by a high level on CA, the count will hold as long as CA remains high. Any further low levels on CA will again cause the counter to count down from its present value. The state of the CA line can be determined by testing the state of PA4.

A timing diagram for the Pulse Width Measurement Mode is shown in Figure 6.3.


6-3. Pulse Width Measurement

\subsection*{6.1.5 Serial I/O Data Rate Generation}

Counter A also provides clock timing for the Serial I/O which establishes the data rate for the Serial I/O port. When the Serial I/O is enabled, Counter \(A\) is forced to operate at the internal clock rate. Counter \(A\) is not required for the RCVR S/R mode. The Counter I/O (PA4) may also be required to support the Serial I/O (see Table 4-2).

Table 6-1 identifies the values to be loaded in Counter \(A\) for selecting standard data rates with a \(\phi 2\) clock rate of 1 MHz and 2 MHz . Although Table 6-1 identifies only the more common data rates, any data rate from 1 to 62.5 K bps can be selected by using the formula:
\[
N=\frac{\phi 2}{16 \times b p s}-1
\]
where
\(\mathrm{N}=\) decimal value to be loaded into Counter A using its hexadecimal equivalent.
\(\phi 2=\) the clock frequency ( 1 MHz or 2 MHz )
\(\mathrm{bps}=\) the desired data rate.

\section*{NOTE}

In Table 6-1 you will notice that the standard data rate and the actual data rate may be slightly different. Transmitter and receiver errors of \(1.5 \%\) or less are acceptable. A revised clock rate is included in Table 6-1 for those baud rates which fall outside this limit.

Table 6-1. Counter A Values for Baud Rate Selection
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{\[
\begin{array}{|c|}
\hline \text { STANDARD } \\
\text { BAUD } \\
\text { RATE } \\
\hline
\end{array}
\]} & \multicolumn{2}{|l|}{HEXADECIMAL VALUE} & \multicolumn{2}{|l|}{\begin{tabular}{l}
03 \\
ACTUAL BAUD RATE AT
\end{tabular}} & \multicolumn{2}{|l|}{CLOCK RATE NEEDED TO GET STANDARD BAUD RATE} \\
\hline & 1 MHz & 2 MHz & 1 MHz & 2 MHz & 1 MHz & 2 MHz \\
\hline 50 & 04E1 & 09C3 & 50.00 & 50.00 & 1.0000 & 2.0000 \\
\hline 75 & 0340 & 0682 & 75.03 & 74.99 & 1.0000 & 2.0000 \\
\hline 110 & 0237 & 046F & 110.04 & 110.04 & 1.0000 & 2.0000 \\
\hline 150 & 01A0 & 0340 & 149.88 & 150.06 & 1.0000 & 2.0000 \\
\hline 300 & 00CF & 0140 & 300.48 & 299.76 & 1.0000 & 2.0000 \\
\hline 600 & 0067 & 00CF & 600.96 & 600.96 & 1.0000 & 2.0000 \\
\hline 1200 & 0033 & 0067 & 1201.92 & 1201.92 & 1.0000 & 2.0000 \\
\hline 2400 & 0019 & 0033 & 2403.85 & 2403.85 & 1.0000 & 2.0000 \\
\hline 3600 & 0010 & 0021 & 3676.47 & 3676.47 & 0.9792 & 1.9584 \\
\hline 4800 & 000C & 0019 & 4807.69 & 4807.69 & 1.0000 & 2.0000 \\
\hline 7200 & 0008 & 0010 & 6944.44 & 7352.94 & 1.0368 & 1.9584 \\
\hline 9600 & 0006 & 000C & 8928.57 & 9615.38 & 1.0752 & 2.0000 \\
\hline
\end{tabular}

\subsection*{6.2 COUNTER B}

Counter B consists of a 16-bit counter and two 16-bit latches organized as follows: Lower Counter B (LCB), Upper Counter B (UCB), Lower Latch B (LLB), Upper Latch B (ULB), Lower Latch C (LLC), and Upper Latch C (ULC). Latch C is used only in the asymmetrical pulse generation mode. The counter contains the count of either 02 clock pulses or external events depending on the counter mode selected. The contents of Counter B may be read any time by executing a Read at location 001D for the Upper Counter B and at location 001 E or 001 C for the Lower Counter B. A Read at location 001 C also clears the Counter B Underflow Flag.

Latch \(B\) contains the counter initialization value and can be loaded at any time by executing a Write to the Upper Latch \(B\) at location 001D and the Lower Latch \(B\) at location 001C. In each case, the contents of the accumulator are copied into the applicable latch register.

Counter B can be initialized at any time by writing to address: 001 E . The contents of the accumulator is copied into the Upper Latch \(B\) before the value in the 16 -bit Latch \(B\) is transferred to Counter B. Counter B will also be set to the latch value and the Counter B Underflow Flag bit (IFR5) will be set to a " 1 " whenever Counter B underflows by decrementing from 0000.

IFR 5 may be cleared by reading the Lower Counter B at location 001 C , by writing to address location 001 E , or by RES.

Counter B operates in the same manner as Counter A in the Interval Timer and Event Counter modes. The Pulse Width Measurement Mode is replaced by the Retriggerable Interval Timer mode and the Pulse Generation mode is replaced by the Asymmetrical Pulse Generation Mode. Mode Control Register bits MCR2 and MCR3 select the four Counter B modes in a similar manner and coding as MCRO and MCR1 select the modes of Counter A.

\subsection*{6.2.1 Retriggerable Interval Timer Mode}

When operating in the Retriggerable Interval Timer mode, Counter B is initialized to the latch value by writing to address 001E, by a Counter \(B\) underflow, or whenever a positive edge occurs on the CB pin (PA5). The Counter B interrupt flag will be set if the counter underflows before a positive edge occurs on the \(C B\) line. Figure 6-4 illustrates the operation.


Figure 6-4. Counter B Retriggerable Interval Timer Mode

\subsection*{6.2.2 Asymmetrical Pulse Generation Mode}

Counter B has a special Asymmetrical Pulse Generation Mode whereby a pulse train with programmable pulse width and period can be generated without the processor intervention once the latch values are initialized.

In this mode, the 16 -bit Latch B is initialized with a value which corresponds to the duration between pulses (referred to as \(D\) in the following descriptions). The 16 -bit Latch \(C\) is initialized with a value corresponding to the desired pulse width (referred to as P in the following descriptions). The initialization sequence for Latch B and C and the starting of a counting sequence are as follows:
1. The lower 8 bits of \(P\) are loaded into LLB by writing to address 001C; the upper 8 bits of P are loaded into ULB and the full 16 bits are transferred to Latch C by writing to address location 001D. At this point both Latch \(B\) and Latch \(C\) contain the value of \(P\).
2. The lower 8 bits of \(D\) are loaded into LLB by writing to address 001 C ; the upper 8 bits of D are loaded into ULB by writing to address location 001E. Writing to address location 001E also causes the contents of the 16-bit Latch \(B\) to be downloaded into the Counter \(B\) and the CB output to go low as shown in Figure 6-5.
3. When Counter \(B\) underflow occurs the contents of the Latch C are loaded into the Counter B and the CB output toggles to a high level, staying high until another underflow occurs. Latch \(B\) is then down-loaded and the CB output toggles to a low level repeating the whole process.

\section*{SECTION 7 \\ POWER ON/INITIALIZATION CONSIDERATIONS}

\subsection*{7.1 POWER ON TIMING}

After application of \(V_{c C}\) and \(V_{\text {RR }}\) power to the device, \(\overline{\text { RES }}\) must be held low for at least eight \(\varnothing 2\) clock cycles after \(V_{c c}\) reaches operating range and the internal oscillator has stabilized. This stabilization time is dependent upon the input \(\mathrm{V}_{\mathrm{cc}}\) voltage and performance of the internal oscillator. The clock can be monitored at \(\phi 2\) (pin 3). Figure 7-1 illustrates the power turn-on waveforms. Clock stabilization time is typically 20 ms .


Figure 7-1. Power Turn-On Timing Detail

\subsection*{7.2 POWER-ON RESET}

When \(\overline{\text { RES }}\) goes from low to high, the device sets the Interrupt Mask Bit-bit 2 of the Processor Status Registerand initiates a reset vector fetch at address FFFC and FFFD to begin user program execution. All of the I/O ports (PA, PB, PC, PD) will be forced to the high (logic 1) state. All bits of the Control Register will be cleared to logic 0 causing the Interval Timers counter mode (mode 00) to be selected and all interrupt enabled bits to be reset.


Figure 6-5. Counter B Pulse Generation

\subsection*{7.3 RESET ( \(\overline{\mathrm{RES}})\) CONDITIONING}

When \(\overline{\mathrm{RES}}\) is driven from low to high the device is put in a reset state causing the registers and \(1 / \mathrm{O}\) ports to be configured as shown in Table 7-1.

Table 7-1. \(\overline{R E S}\) Initialization of I/O Ports and Registers
\begin{tabular}{|l|cccccccc|}
\hline & \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline REGISTERS & & & & & & & & \\
\(\quad\) Processor Status & - & - & - & - & - & 1 & - & - \\
Mode Control (MCR) & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
Int. Enable (IER) & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
Int. Flag (IFR) & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
Ser. Com. Control (SCCR) & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
Ser. Com. Status (SCSR) & 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 \\
PORTS & & & & & & & & \\
PA Latch & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\
PB Latch & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\
PC Latch & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\
PD Latch & 1 & \(\mathbf{1}\) & 1 & 1 & 1 & 1 & 1 & 1 \\
\hline
\end{tabular}

All RAM and other CPU registers will initialize in a random, non-repeatable data pattern.

\subsection*{7.4 INITIALIZATION}

Any initialization process for the device should include a \(\overline{\mathrm{RES}}\), as indicated in the preceeding paragraphs. After stabilization of the internal clock (if a power on situation) an initialization routine should be executed to perform (as a minimum) the following functions:
1. The Stack Pointer should be set
2. Clear or Set Decimal Mode
3. Set or Clear Carry Flag
4. Set up Mode Controls as required
5. Clear Interrupts

A typical initialization subroutine could be as follows:
LDX Load stack pointer starting address into X Register
TXS Transfer X Register value to Stack Pointer
CLD Clear Decimal Mode
SEC Set Carry Flag
. . . . Set-up Mode Control and
... . special function registers
\(\ldots\) and clear RAM as required
CLI Clear Interrupts
\begin{tabular}{ll} 
LDX & \begin{tabular}{l} 
Load stack pointer starting address into \\
X Register
\end{tabular} \\
TXS & Transfer X Register value to Stack Pointer \\
CLD & Clear Decimal Mode \\
SEC & Set Carry Flag \\
\(\ldots\). & Set-up Mode Control and \\
\(\ldots\). & special function registers \\
\(\ldots \mathrm{CLI}\) & \begin{tabular}{l} 
and clear RAM as required \\
Clear Interrupts
\end{tabular}
\end{tabular}

\title{
APPENDIX A ENHANCED R6502 INSTRUCTION SET
}

\begin{abstract}
This appendix contains a summary of the Enhanced R6502 instruction set. For detailed information, consult the R6502 Microcomputer System Programming Manual, (Order No. 202). The four instructions notated with a * are added instructions to enhance the standard 6502 instruction set.
\end{abstract}

\section*{A. 1 INSTRUCTION SET IN ALPHABETIC SEQUENCE}
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Description & Mnemonic & Description \\
\hline ADC & Add Memory to Accumulator with Carry & LDA & Load Accumulator with Memory \\
\hline AND & "AND" Memory with Accumulator & LDX & Load Index X with Memory \\
\hline ASL & Shift Left One Bit (Memory or Accumulator) & LDY & Load Index Y with Memory \\
\hline *BBR & Branch on Bit Reset Relative & LSR & Shift One Bit Right (Memory or Accumulator) \\
\hline *BBS & Branch on Bit Set Relative & NOP & \\
\hline BCC & Branch on Carry Clear & NOP & No Operation \\
\hline BCS & Branch on Carry Set & & \\
\hline BEQ & Branch on Result Zero & ORA & "OR" Memory with Accumulator \\
\hline BIT & Test Bits in Memory with Accumulator & & \\
\hline BMI & Branch on Result Minus & PHA & Push Accumulator on Stack \\
\hline BNE & Branch on Result not Zero & PHP & Push Processor Status on Stack \\
\hline BPL & Branch on Result Plus & PLA & Pull Accumulator from Stack \\
\hline BRK & Force Break & PLP & Pull Processor Status from Stack \\
\hline BVC & Branch on Overflow Clear & & \\
\hline BVS & Branch on Overflow Set & *RMB & Reset Memory Bit \\
\hline & & ROL & Rotate One Bit Left (Memory or Accumulator) \\
\hline CLC & Clear Carry Flag & ROR & Rotate One Bit Right (Memory or Accumulator) \\
\hline CLD & Clear Decimal Mode & RTI & Return from Interrupt \\
\hline CLI & Clear Interrupt Disable Bit & RTS & Return from Subroutine \\
\hline CLV & Clear Overflow Flag & & \\
\hline CMP & Compare Memory and Accumulator & & \\
\hline CPX & Compare Memory and Index X & SBC & Subtract Memory from Accumulator with Borrow Set Carry Flag \\
\hline CPY & Compare Memory and Index Y & SED & Set Decimal Mode \\
\hline DEC & Decrement Memory by One & SEI & Set Interrupt Disable Status \\
\hline DEX & Decrement Index X by One & *SMB & Set Memory Bit \\
\hline DEY & Decrement Index \(Y\) by One & STA & Store Accumulator in Memory \\
\hline & & STX & Store Index X in Memory \\
\hline EOR & "Exclusive-Or" Memory with Accumulator & STY & Store Index Y in Memory \\
\hline INC & Increment Memory by One & TAX & Transfer Accumulator to Index X \\
\hline INX & Increment Index \(X\) by One & TAY & Transfer Accumulator to Index \(Y\) \\
\hline INY & Increment Index Y by One & TSX & Transfer Stack Pointer to Index X \\
\hline & & TXA & Transfer Index X to Accumulator \\
\hline JMP & Jump to New Location & TXS & Transfer Index \(X\) to Stack Register \\
\hline JSR & Jump to New Location Saving Return Address & TYA & Transfer Index \(Y\) to Accumulator \\
\hline
\end{tabular}


\section*{A. 3 INSTRUCTION CODE MATRIX}


\footnotetext{
*Add 1 to N if page boundary is crossed.
**Add 1 to N if branch occurs to same page;
add 2 to N if branch occurs to different page.
}

\section*{APPENDIX B KEY REGISTER SUMMARY}


CPU Registers


Mode Control Register


Serial Communications Control Register


Processor Status Register


Interrupt Enable and Flag Registers


Serial Communications Status Register

\section*{APPENDIX C ADDRESS ASSIGNMENTS/MEMORY MAPS/PIN FUNCTIONS}

\section*{C. 1 I/O AND INTERNAL REGISTER ADDRESSES}
\begin{tabular}{|c|c|c|}
\hline \begin{tabular}{l}
ADDRESS \\
(HEX)
\end{tabular} & READ & WRITE \\
\hline \[
\begin{array}{r}
001 F \\
1 E \\
1 D \\
1 C
\end{array}
\] & \begin{tabular}{l}
Lower Counter B \\
Upper Counter B \\
Lower Counter B, CLR Flag
\end{tabular} & Upper Latch B, Cntr B↔-Latch B, CLR Flag Upper Latch B, Latch C \(\leftarrow\) Latch B Lower Latch B. \\
\hline \[
\begin{aligned}
& 1 B \\
& 1 A \\
& 19 \\
& 18
\end{aligned}
\] & \begin{tabular}{l}
Lower Counter A \\
Upper Counter A \\
Lower Counter A, CLR Flag
\end{tabular} & Upper Latch A, Cntr A Latch A, CLR Flag Upper Latch A Lower Latch A \\
\hline \[
\begin{aligned}
& 17 \\
& 16 \\
& 15 \\
& 14
\end{aligned}
\] & Serial Receiver Data Register Serial Comm. Status Register Serial Comm. Control Register Mode Control Register & \begin{tabular}{l}
Serial Transmitter Data Register \\
Serial Comm. Status Reg. Bits 4 \& 5 only \\
Serial Comm. Control Register \\
Mode Control Register
\end{tabular} \\
\hline \[
\begin{array}{r}
13 \\
12 \\
11 \\
0010
\end{array}
\] & Interrupt Enable Register Interrupt Flag Register Read FF & \begin{tabular}{l}
Interrupt Enable Register \\
Clear Int Flag (Bits 0-3 only, Write 0's only)
\end{tabular} \\
\hline \[
\begin{aligned}
& O F \\
& O E \\
& O D \\
& O C
\end{aligned}
\] & \multicolumn{2}{|l|}{\multirow{3}{*}{\begin{tabular}{l}
RESERVED \\
These addresses are reserved and are used by the CPU during Read and Write operation over the external Data Bus (DO-D7).
\end{tabular}}} \\
\hline \[
\begin{aligned}
& 0 B \\
& 0 A \\
& 09 \\
& 08
\end{aligned}
\] & & \\
\hline \[
\begin{aligned}
& 07 \\
& 06 \\
& 05 \\
& 04
\end{aligned}
\] & & \\
\hline \[
\begin{array}{r}
03 \\
02 \\
01 \\
0000
\end{array}
\] & \begin{tabular}{l}
Port D \\
Port C \\
Port B \\
Port A
\end{tabular} & \begin{tabular}{l}
Port D \\
Port C \\
Port B \\
Port A
\end{tabular} \\
\hline
\end{tabular}

\section*{C. 2 FULL ADDRESS MODE MEMORY MAP—R6501}


\section*{C. 3 MULTIPLE FUNCTION PIN ASSIGNMENTS—PORT C AND PORT D}
\begin{tabular}{|c|c|c|c|}
\hline FULL ADDRESS MODE & I/O PORT FUNCTION & ABBREV & MUX \\
\hline \[
\begin{aligned}
& \text { PC0 } \\
& \text { PC1 } \\
& \text { PC2 } \\
& \text { PC3 }
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{PCO} \\
& \mathrm{PC} 1 \\
& \mathrm{PC} 2 \\
& \mathrm{PC} 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { A0 } \\
& \text { A1 } \\
& \text { A2 } \\
& \text { A3 }
\end{aligned}
\] & \[
\begin{aligned}
& \text { A0 } \\
& \text { A1 } \\
& \text { A2 } \\
& \text { A3 }
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& \text { PC4 } \\
& \text { PC5 } \\
& \text { A13 } \\
& \text { A14 }
\end{aligned}
\] & \[
\begin{aligned}
& \text { PC4 } \\
& \text { PC5 } \\
& \text { PC6 } \\
& \text { PC7 }
\end{aligned}
\] & \begin{tabular}{l}
A12 \\
R/W \\
A13 \\
EMS
\end{tabular} & \begin{tabular}{l}
A12 \\
R/W \\
A13 \\
EMS
\end{tabular} \\
\hline \[
\begin{aligned}
& \text { PDO } \\
& \text { PD1 } \\
& \text { PD2 } \\
& \text { PD3 }
\end{aligned}
\] & \begin{tabular}{l}
PDO \\
PD1 \\
PD2 \\
PD3
\end{tabular} & \[
\begin{aligned}
& \text { D0 } \\
& \text { D1 } \\
& \text { D2 } \\
& \text { D3 }
\end{aligned}
\] & \[
\begin{aligned}
& \text { A4/D0 } \\
& \text { A5/D1 } \\
& \text { A6/D2 } \\
& \text { A7/D3 }
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& \text { PD4 } \\
& \text { PD5 } \\
& \text { PD6 } \\
& \text { PD7 }
\end{aligned}
\] & \begin{tabular}{l}
PD4 \\
PD5 \\
PD6 \\
PD7
\end{tabular} & \begin{tabular}{l}
D4 \\
D5 \\
D6 \\
D7
\end{tabular} & \begin{tabular}{l}
A8/D4 \\
A9/D5 \\
A10/D6 \\
A11/D7
\end{tabular} \\
\hline
\end{tabular}

\section*{APPENDIX D ELECTRICAL SPECIFICATIONS}

\section*{MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}} \& \mathrm{~V}_{\mathrm{RR}}\) & -0.3 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to +7.0 & Vdc \\
\hline \begin{tabular}{l} 
Operating Temperature Range, \\
Commercial \\
Industrial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{c}
\(\mathrm{T}_{\mathrm{L}}\) to \(\mathrm{T}_{\mathrm{H}}\) \\
0 to +70 \\
-40 to +85
\end{tabular} & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature Range & \(\mathrm{T}_{\mathrm{STG}}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}
\(\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{R R}=V_{C C} ; V_{S S}=0 V ; T_{A}=T_{L}\right.\) to \(T_{H}\), unless otherwise specified)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ \({ }^{1}\) & Max & Unit & Test Conditions \\
\hline RAM Standby Voltage (Retention Mode) & \(\mathrm{V}_{\text {RR }}\) & 3.0 & & \(\mathrm{V}_{\mathrm{CC}}\) & V & \\
\hline RAM Standby Current (Retention Mode) & \(I_{\text {RR }}\) & - & 4 & - & mA & \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) \\
\hline \begin{tabular}{l}
Input High Voltage \\
All Except XTLI XTLI
\end{tabular} & \(\mathrm{V}_{\mathrm{IH}}\) & \[
\begin{aligned}
& +2.0 \\
& +4.0
\end{aligned}
\] & - & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{cc}} \\
& \mathrm{v}_{\mathrm{cc}}
\end{aligned}
\] & V & \\
\hline Input Low Voltage & \(\mathrm{V}_{\text {IL }}\) & -0.3 & - & +0.8 & V & \\
\hline Input Leakage Current RES, \(\overline{\text { NMI }}\) & IN & - & - & \(\pm 10.0\) & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{IN}}=0\) to 5.0 V \\
\hline Input Low Current PA, PB, PC, PD & IIL & - & -1.0 & -1.6 & mA & \(\mathrm{V}_{\text {IL }}=0.4 \mathrm{~V}\) \\
\hline Output High Voltage (Except XTLO) & \(\mathrm{V}_{\mathrm{OH}}\) & +2.4 & - & \(\mathrm{V}_{\mathrm{CC}}\) & V & \(\mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A}\) \\
\hline Output Low Voltage & \(\mathrm{V}_{\mathrm{OL}}\) & - & - & +0.4 & V & \(\mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA}\) \\
\hline I/O Port Pull-Up Resistance PAO-PA7, PB0-PB7, PC0-PC7 & \(\mathrm{R}_{\mathrm{L}}\) & 3.0 & 6.0 & 11.5 & Kohm & \\
\hline Output Leakage Current (Three-State Off) & I OUT & - & - & \(\pm 10\) & \(\mu \mathrm{A}\) & \\
\hline Input Capacitance XTLI, XTLO All Others & \(\mathrm{C}_{\mathrm{IN}}\) & - & - & \[
\begin{aligned}
& 50 \\
& 10
\end{aligned}
\] & pF & \[
\begin{aligned}
& T_{A}=25^{\circ} \mathrm{C} \\
& V_{\text {IN }}=0 \mathrm{~V} \\
& f=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Output Capacitance (Three-State Off) & Cout & - & - & 10 & pF & \[
\begin{aligned}
& T_{A}=25^{\circ} \mathrm{C} \\
& V_{\text {IN }}=0 \mathrm{~V} \\
& \mathrm{f}=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Power Dissipation (Outputs High) & \(P_{\text {D }}\) & - & 750 & 1100 & mW & \(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\) \\
\hline \multicolumn{7}{|l|}{\begin{tabular}{l}
Notes: \\
1. Typical values measured at \(T_{A}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\). \\
2. Negative sign indicates outward current flow, positive indicates inward flow.
\end{tabular}} \\
\hline
\end{tabular}

\section*{APPENDIX E \\ TIMING REQUIREMENTS AND CHARACTERISTICS}

\section*{E. 1 GENERAL NOTES}
1. \(\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \pm 5 \%, 0^{\circ} \mathrm{C} \leqslant \mathrm{TA} \leqslant 70^{\circ} \mathrm{C}\)
2. A valid \(V_{c c}-\overline{\text { RES }}\) sequence is required before proper operation is achieved.
3. All timing reference levels are 0.8 V and 2.0 V , unless otherwise specified.
4. All time units are nanoseconds, unless otherwise specified.
5. All capacitive loading is 130pf maximum, except as noted below:

PA, PB
PC (I/O Modes Only) \(\quad-50 \mathrm{pF}\) maximum
PC (ABB and Mux Mode) - 130pF maximum PC6, PC7 (Full Address Mode) - 130pF maximum

\section*{E. 2 CLOCK TIMING}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{SYMBOL} & \multirow[b]{2}{*}{PARAMETER} & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} \\
\hline & & MIN & max & MIN & MAX \\
\hline \(\mathrm{T}_{\mathrm{crc}}\) & Cycle Time & 1000 & \(10 \mu \mathrm{~s}\) & 500 & \(10 \mu \mathrm{~s}\) \\
\hline \(\mathrm{T}_{\text {Pwx1 }}\) & XTLI Input Clock Pulse Width XTLO = VSS & \[
\begin{gathered}
500 \\
\pm 25
\end{gathered}
\] & - & \[
\begin{array}{r}
250 \\
\pm 10
\end{array}
\] & - \\
\hline \(\mathrm{T}_{\text {Pwoz }}\) & Output Clock Pulse Width at Minimum \(\mathrm{T}_{\mathrm{crc}}\) & \(\mathrm{T}_{\text {Pwx }}\) & \[
\begin{aligned}
& \mathrm{T}_{\mathrm{PWx} \times 1} \\
& \pm 25
\end{aligned}
\] & \(\mathrm{T}_{\text {Pwx }}\) & \[
\begin{aligned}
& T_{p w x 1} \\
& \pm 20
\end{aligned}
\] \\
\hline \(\mathrm{T}_{\mathrm{R}}, \mathrm{T}_{\mathrm{F}}\) & Output Clock Rise, Fall Time & - & 25 & - & 15 \\
\hline \(\mathrm{T}_{\text {IR }}, \mathrm{T}_{\text {IF }}\) & Input Clock Rise, Fall Time & - & 10 & - & 10 \\
\hline
\end{tabular}


\section*{E. 3 ABBREVIATED MODE TIMING-PC AND PD}
\((\) MCR \(5=1\), MCR \(6=0\), MCR \(7=1)\)
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{SYMBOL} & \multirow{2}{*}{PARAMETER} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|r|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline \(T_{\text {PCRS }}\) & (PC5) R/W Setup Time & - & 225 & - & 140 \\
\hline \(T_{\text {PCAS }}\) & (PC0-PC4, PC6) Address Setup Time & - & 225 & - & 140 \\
\hline \(\mathrm{T}_{\text {PbSU }}\) & (PD) Data Setup Time & 50 & - & 35 & - \\
\hline \(\mathrm{T}_{\text {PBHR }}\) & (PD) Data Read Hold Time & 10 & - & 10 & - \\
\hline \(\mathrm{T}_{\text {pBHW }}\) & (PD) Data Write Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {Pbod }}\) & (PD) Data Output Delay & - & 175 & - & 150 \\
\hline \(\mathrm{T}_{\text {PCHA }}\) & (PC0-PC4, PC6) Address Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {PCHR }}\) & (PC5) R/W Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {PCHV }}\) & (PC7) EMS Hold Time & 10 & - & 10 & - \\
\hline \(T_{\text {PCVP }}\) & (PC7) EMS Stabilization Time & 30 & - & 30 & - \\
\hline Tesu & EMS Setup Time & - & 350 & - & 210 \\
\hline
\end{tabular}

\section*{E.3.1 Abbreviated Mode Timing Diagram}


\section*{E. 4 MULTIPLEXED MODE TIMING-PC AND PD}
\((\) MCR \(5=1\), MCR \(6=1\), MCR \(7=1)\)
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{SYMBOL} & \multirow{2}{*}{PARAMETER} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|r|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline \(\mathrm{T}_{\text {PCRS }}\) & (PC5) R/W Setup Time & - & 225 & - & 140 \\
\hline \(T_{\text {PCAS }}\) & (PC0-PC4, PC6) Address Setup Time & - & 225 & - & 140 \\
\hline \(T_{\text {PBAS }}\) & (PD) Address Setup Time & - & 225 & - & 140 \\
\hline \(\mathrm{T}_{\text {PBSU }}\) & (PD) Data Setup Time & 50 & - & 35 & - \\
\hline \(\mathrm{T}_{\text {PBHR }}\) & (PD) Data Read Hold Time & 10 & - & 10 & - \\
\hline \(\mathrm{T}_{\text {PBHW }}\) & (PD) Data Write Hold Time & 30 & - & 30 & - \\
\hline \(T_{\text {PBdD }}\) & (PD) Data Output Delay & - & 175 & - & 150 \\
\hline \(T_{\text {PCHA }}\) & (PC0-PC4, PC6) Address Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {PBHA }}\) & (PD) Address Hold Time & 10 & 100 & 10 & 80 \\
\hline \(\mathrm{T}_{\text {PCHR }}\) & (PC5) R/W Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {PCHV }}\) & (PC7) EMS Hold Time & 10 & - & 10 & - \\
\hline \(\mathrm{T}_{\text {PCVD }}{ }^{\text {(1) }}\) & (PC7) Address to EMS Delay Time & 30 & & 30 & \\
\hline \(\mathrm{T}_{\text {PGVP }}\) & (PC7) \(\overline{\mathrm{EMS}}\) Stabilization Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {ESU }}\) & EMS Setup Time & - & 350 & - & 210 \\
\hline \multicolumn{6}{|l|}{NOTE 1: Values assume PC0-PC4, PC6 and PC7 have the same capactive load.} \\
\hline
\end{tabular}

\section*{E.4.1 Multiplex Mode Timing Diagram}


\section*{E. 5 I/O, EDGE DETECT, COUNTERS, AND SERIAL I/O TIMING}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{SYMBOL} & \multirow{2}{*}{PARAMETER} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|r|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline \begin{tabular}{l}
Tpow \\
Tcmos \\
\(T_{\text {poow }}\)
\end{tabular} & \begin{tabular}{l}
Internal Write to Peripheral Data Valid \\
PA, PB, PC TTL \\
PA, PB, PC CMOS \\
PD
\end{tabular} & - & \[
\begin{array}{r}
500 \\
1000 \\
175
\end{array}
\] & - & \[
\begin{array}{r}
500 \\
1000 \\
150
\end{array}
\] \\
\hline \[
\begin{aligned}
& T_{\text {Posu }} \\
& T_{\text {PoSU }}
\end{aligned}
\] & Peripheral Data Setup Time PA, PB, PC PD & \[
\begin{array}{r}
200 \\
50
\end{array}
\] & - & \[
\begin{array}{r}
200 \\
50
\end{array}
\] & - \\
\hline \[
\left\lvert\, \begin{aligned}
& T_{\text {PHR }} \\
& T_{\text {PHR }}
\end{aligned}\right.
\] & Peripheral Data Hold Time PA, PB, PC PD & \[
\begin{aligned}
& 75 \\
& 10
\end{aligned}
\] & - & 75
10 & - \\
\hline \(\mathrm{T}_{\text {EPW }}\) & PAO-PA3 Edge Detect Pulse Width & \(\mathrm{T}_{\mathrm{crc}}\) & - & Tcrc & - \\
\hline \[
\begin{aligned}
& T_{C P W} \\
& T_{C D}{ }^{\prime \prime \prime}
\end{aligned}
\] & \begin{tabular}{l}
Counters \(A\) and \(B\) \\
PA4, PA5 Input Pulse Width PA4, PA5 Output Delay
\end{tabular} & \(\mathrm{T}_{\mathrm{crc}}\) & \[
\overline{500}
\] & \(\mathrm{T}_{\mathrm{crc}}\) & \(\overline{500}\) \\
\hline \begin{tabular}{l}
\(T_{\text {pBLW }}\) \\
TPLSU \\
\(T_{\text {PBLH }}\)
\end{tabular} & Port B Latch Mode PAO Strobe Pulse Width PB Data Setup Time PB Data Hold Time & \[
\begin{array}{r}
T_{\text {crc }} \\
175 \\
30
\end{array}
\] & - & \[
\begin{gathered}
T_{\text {crc }} \\
150 \\
30
\end{gathered}
\] & - \\
\hline & Serial 1/0 & & & & \\
\hline \(T_{\text {Pow }}{ }^{(1)}\) & PAG XMTR TTL & - & 500 & - & 500 \\
\hline \(\mathrm{T}_{\text {cmos }}{ }^{\prime \prime \prime}\) & PA6 XMTR CMOS & - & 1000 & - & 1000 \\
\hline \(T_{\text {cpw }}\) & PA4 RCVR S/R Clock Width & \(4 \mathrm{~T}_{\text {crc }}\) & - & \(4 \mathrm{~T}_{\text {crc }}\) & - \\
\hline Tpow \({ }^{\text {'1 }}\) & PA4 XMTR Clock-S/R Mode (TTL) & - & 500 & - & 500 \\
\hline \(\mathrm{T}_{\text {cmos }{ }^{\text {s] }}}\) & PA4 XMTR Clock-S/R Mode (CMOS) & - & 1000 & - & 1000 \\
\hline
\end{tabular}

NOTE 1: Maximum Load Capacıtance: 50 pF
Passive Pull-Up Required

\section*{E.5.1 I/O, Edge Detect, Counter, and Serial I/O Timing}


\section*{E. 6 MICROPROCESSOR TIMING (D0-D7, A0-A12, A15, SYNC, R/W)}
\begin{tabular}{|l|l|c|c|c|c|}
\hline \multirow{2}{*}{ SYMBOL } & \multicolumn{2}{|c|}{ PARAMETER } & \multicolumn{2}{|c|}{ 1 MHz } & \multicolumn{2}{c|}{\(2 \mathbf{M H z}\)} \\
\cline { 3 - 6 } & & MIN & MAX & MIN & MAX \\
\hline\(T_{\text {RWS }}\) & R/W Setup Time & - & 225 & - & 140 \\
\hline\(T_{\text {ADS }}\) & \begin{tabular}{l} 
AO-A12, A15 Setup \\
Time
\end{tabular} & - & 150 & - & 75 \\
\hline\(T_{\text {DSU }}\) & D0-D7 Data Setup Time & 50 & - & 35 & - \\
\hline\(T_{\text {HR }}\) & D0-D7 Read Hold Time & 10 & - & 10 & - \\
\hline\(T_{\text {HW }}\) & D0-D7 Write Hold Time & 30 & - & 30 & - \\
\hline\(T_{\text {MOS }}\) & \begin{tabular}{l} 
D0-D7 Write Output \\
Delay
\end{tabular} & - & 175 & - & 130 \\
\hline\(T_{\text {SYM }}\) & SYNC Setup & - & 225 & - & 175 \\
\hline\(T_{\text {HA }}\) & A0-A12, A15 Hold Time & 30 & - & 30 & - \\
\hline\(T_{\text {HRW }}\) & R/W Hold Time & 30 & - & 30 & - \\
\hline\(T_{\text {ACC }}\) & \begin{tabular}{l} 
External Memory Access \\
Time \(T_{\text {ACC }}=T_{\text {CYC }}-T_{F}-\) \\
\(T_{\text {ADS }}-T_{\text {DSU }}\)
\end{tabular} & - & \(T_{\text {ACC }}\) & - & \(T_{\text {ACC }}\) \\
\hline\(T_{\text {SYH }}\) & SYNC Hold Time & 30 & - & 30 & - \\
\hline
\end{tabular}

\section*{E.6.1 Microprocessor Timing Diagram}


\section*{64-PIN PLASTIC QUAD IN-LINE PACKAGE (QUIP)}

\begin{tabular}{|c|c|c|c|c|}
\hline \multirow{2}{*}{ DIM } & \multicolumn{2}{|c|}{ MILLIMETERS } & \multicolumn{2}{c|}{ INCHES } \\
\cline { 2 - 5 } & MIN & MAX & MIN & MAX \\
\hline A & 4110 & 4161 & 1618 & 1638 \\
\hline B & 1702 & 17.23 & 0670 & 0690 \\
\hline C & 356 & 458 & 0140 & 0180 \\
\hline D & 048 & 056 & 0018 & 0022 \\
\hline E1 & \multicolumn{2}{|c|}{1905 BSC } & \multicolumn{2}{|c|}{0750 BSC } \\
\hline E2 & \multicolumn{2}{|c|}{2350 BSC } & \multicolumn{2}{|c|}{0925 BSC } \\
\hline G & \multicolumn{2}{|c|}{127 BSC } & \multicolumn{2}{|c|}{0050 BSC } \\
\hline J & \multicolumn{2}{|c|}{018} & 033 & 0007 \\
\hline K1 & 292 & 318 & 0013 \\
\hline K2 & 483 & 534 & 0115 & 0125 \\
\hline
\end{tabular}


\section*{68-PIN PLASTIC CHIP CARRIER (PCC)}


TOP VIEW


TYP FOR BOTH AXIS (EXCEPT FOR BEVELED EDGE)

\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{DIM} & \multicolumn{2}{|l|}{MILLIMETERS} & \multicolumn{2}{|c|}{INCHES} \\
\hline & MIN & MAX & MIN & MAX \\
\hline A & 3.683 & 3.785 & . 145 & . 149 \\
\hline A1 & 1.829 & 1.930 & . 072 & . 076 \\
\hline A2 & 1.803 & 1.905 & . 071 & . 075 \\
\hline A3 & 1.372 & 1.473 & . 054 & . 058 \\
\hline A4 & 2.311 & 2.464 & . 091 & . 097 \\
\hline A5 & 0.203 & 0.305 & . 008 & . 012 \\
\hline b & \multicolumn{2}{|l|}{0.457 TYP} & \multicolumn{2}{|r|}{. 018 TYP} \\
\hline D & 25.02 & 25.27 & . 985 & . 995 \\
\hline D1 & 24.00 & 24.26 & . 945 & . 955 \\
\hline D2 & 20.19 & 20.45 & . 795 & . 805 \\
\hline D3 & 23.24 & 23.50 & . 915 & . 925 \\
\hline D4 & 20.96 & 21.21 & . 825 & . 835 \\
\hline D5 & 22.23 & 22.48 & . 875 & . 885 \\
\hline e & \multicolumn{2}{|r|}{1.27 BSC} & \multicolumn{2}{|r|}{. 050 BSC} \\
\hline h & \multicolumn{2}{|l|}{0.254 TYP} & \multicolumn{2}{|r|}{. 010 TYP} \\
\hline \(J\) & \multicolumn{2}{|r|}{1.143 TYP} & \multicolumn{2}{|r|}{. 045 TYP} \\
\hline \(\boldsymbol{\alpha}\) & \multicolumn{2}{|c|}{\(4^{\circ} \mathrm{TYP}\)} & \multicolumn{2}{|c|}{\(4{ }^{\circ}\) TYP} \\
\hline \(\alpha 1\) & \multicolumn{2}{|r|}{\(10^{\circ}\) TYP} & \multicolumn{2}{|c|}{\(10^{\circ}\) TYP} \\
\hline \(\alpha 2\) & \multicolumn{2}{|r|}{\(45^{\circ}\) TYP} & \multicolumn{2}{|c|}{\(45^{\circ}\) TYP} \\
\hline R & \multicolumn{2}{|l|}{0.889 TYP} & \multicolumn{2}{|r|}{. 035 TYP} \\
\hline R1 & \multicolumn{2}{|l|}{0.254 TYP} & \multicolumn{2}{|r|}{. 010 TYP} \\
\hline
\end{tabular}


\title{
R6511Q One-Chip Microprocessor and R6500/13 One-Chip Microcomputer
}

\section*{SECTION 1 \\ INTRODUCTION}

\subsection*{1.1 FEATURES}
- Enhanced 6502 CPU
-Four new bit manipulation instructions
- Set Memory Bit (SMB)
- Reset Memory Bit (RMB)
- Branch on Bit Set (BBS)
- Branch on Bit Reset (BBR)
-Decimal and binary arithmetic modes
- 13 addressing modes
-True indexing
- 256-byte mask-programmable ROM or no ROM*
- 192-byte static RAM
- 32 bidirectional, TTL-compatible I/O lines (four ports)
- One 8-bit port may be tri-stated under software control
- One 8 -bit port may have latched inputs under software control
- Two 16-bit programmable counter/timers, with latches
-Pulse width measurement
-Asymmetrical pulse generation
-Pulse generation
- Interval timer
-Event counter
-Retriggerable interval timer
- Serial port
-Full-duplex asynchronous operation mode
-Selectable 5- to 8 -bit characters
-Wake-up feature
-Synchronous shift register mode
-Standard programmable bit rates programmable up to 62.5 K bits \(/ \mathrm{sec} @ 1 \mathrm{MHz}\)
- Ten interrupts
-Four edge-sensitive lines; two positive, two negative
-Reset
-Non-maskable
-Two counter underflows
-Serial data received
-Serial data transmitted
- Bus expandable to 64 K bytes of external memory
*R6511Q has no ROM.
- Flexible clock circuitry
\(-2-\mathrm{MHz}\) or \(1-\mathrm{MHz}\) internal operation
-Internal clock with external XTAL at two or four times internal frequency
-External clock input divided by one, two or four
- \(1 \mu \mathrm{~s}\) minimum instruction execution time @ 2 MHz
- NMOS-3 silicon gate, depletion load technology
- Single +5 V power supply
- 12 mW stand-by power for 32 bytes of the 192-byte RAM
- 64-pin QUIP

\section*{NOTE}

This document uses the term R6500/13 to describe both parts. See section 1.3 for a description of the options available when using the R6500/13 and the fixed features of the R6511Q.

\subsection*{1.2 SUMMARY}

The Rockwell R6500/13 is a complete, high-performance 8 -bit NMOS-3 microcomputer on a single chip and is compatible with all members of the R6500 family.

The R6500/13 consists of an enhanced 6502 CPU, an internal clock oscillator, an optional 256 bytes of Read-Only Memory, 192 bytes of Random Access Memory (RAM) and versatile interface circuitry. The interface circuitry includes two 16-bit programmable timer/counters, 32 bidirectional input/output lines (including four edge-sensitive lines and input latching on one 8 -bit port), a full-duplex serial I/O channel, ten interrupts and bus expandability.

The innovative architecture and the demonstrated high performance of the R6502 CPU, as well as instruction simplicity, results in system cost-effectiveness and a wide range of computational power. These features make the R6500/13 a leading candidate for microcomputer applications.

The R6511Q contains all the features of the R6500/13 except it has no ROM and is thus intended as a high feature microprocessor with full 65 K address bus.

\section*{R6511Q Microprocessor and R6500/13 Microcomputer}

To allow prototype circuit development, Rockwell offers a PROM-compatible 64-pin extended microprocessor device. This device, the R6511Q, provides all R6500/11 interface lines, plus the address bus, data bus and control lines to interface with external memory. The R6511Q also can be used to emulate the R6500/13. With the addition of external circuits it can also emulate the R6500/12.

Rockwell supports development of the R6500/13 with the Low Cost Emulator (LCE) Development System and the R6500/* Family of Personality Modules. Complete in-circuit emulation with the R6500/* Family of Personality Modules allows total system test and evaluation.

This product description assumes that the reader is familiar with the R6502 CPU hardware and programming capabilities. A detailed description of the R6502 CPU hardware is included in the R6500 Microcomputer System Hardware Manual (Document Number 29650N31). A description of the instruction capabilities of the R6502 CPU is contained in the R6500 Microcomputer System Programming Manual (Document Number 29650N30).

\subsection*{1.3 CUSTOMER OPTIONS}

The R6500/13 microcomputer is available with the following customer specified mask options.
- Option 1 Crystal or RC oscillator
- Option 2 Clock divide by 2 or 4
- Option 3 Clock MASTER Mode or SLAVE Mode
- Option 4 with or without a 256 byte ROM
- Option 5 Reset Vector at FFFC or 7FFF
- Option 6 Port A with or without internal pull-up resistors
- Option 7 Port B with or without internal pull-up resistors
- Option 8 Port C with or without internal pull-up resistors

All options should be specified on an R6500/13 order form.
The R6511Q has no customer specified mask options. It has the following characteristics.
- Crystal Oscillator
- Clock Divide by 2
- Clock MASTER Mode
- Without ROM
- Reset Vector at FFFC
- No internal pull-up resistors on any Port (PA, PB, or PC)



64 PIN QUIP

Figure 2-1. Mechanical Outline \& Pin Out Configuration

\section*{SECTION 2 \\ INTERFACE REQUIREMENTS}

This section describes the interface requirements for the R6511Q and R6500/13. Figure 2-1 and 2-2 show the Interface Diagram and the pin out configuration for both devices. Table 2-1 describes the function of each pin. Figure 3-1 has a detailed block diagram of the R6500/13 ports which illustrates the internal function of the device.


Figure 2-2. Interface Diagram

Table 2-1. R6500/13 Pin Descriptions
\begin{tabular}{|c|c|c|}
\hline Signal Name & Pin No. & Description \\
\hline \(V_{c c}\) & 21 & Main power supply +5 V \\
\hline \(V_{\text {RR }}\) & 43 & Separate power pin for RAM. In the event that \(\mathrm{V}_{\mathrm{cc}}\) power is off, this power retains RAM data. \\
\hline \(\mathrm{V}_{\text {ss }}\) & 44 & Signal and power ground (0V) \\
\hline XTLI & 42 & Crystal or clock input for internal clock oscillator. Also allows input of X1 clock signal if XTLO is connected to \(\mathrm{V}_{\mathrm{ss}}\), or X2 or X4 clock if XTLO is floated. \\
\hline XTLO & 41 & Crystal output from internal clock oscillator. \\
\hline \(\overline{\mathrm{RES}}\) & 6 & The Reset input is used to initialize the device. This signal must not transition from low to high for at least eight cycles after \(\mathrm{V}_{\mathrm{cc}}\) reaches operating range and the internal oscillator has stabilized. \\
\hline \(\phi 2\) & 45 & Clock signal output at internal frequency. \\
\hline \(\overline{\mathrm{NMI}}\) & 23 & A negative going edge on the Non-Maskable interrupt signal requests that a nonmaskable interrupt be generated with the CPU. \\
\hline PA0-PA7 & 39-32 & Four 8-bit ports used for \\
\hline PB0-PB7 & 31-24 & either input/output. Each line \\
\hline PC0-PC7 & 54-61 & of Ports A, B and C consists \\
\hline PD0-PD7 & \[
\begin{gathered}
62-64, \\
1-5
\end{gathered}
\] & of an active transistor to \(\mathrm{V}_{\mathrm{ss}}\) and an optional passive pullup to \(\mathrm{V}_{\mathrm{cc}}\). In the abbreviated or multiplexed modes of operation Port \(C\) has an active pull-up transistor. Port D functions as either an 8 -bit input or 8-bit output port. It has active pull-up and pulldown transistors. \\
\hline A0-A12, A15 & 20-7 & Fourteen address lines used to address a complete 65K external address space. Note: A13 \& A14 are sourced through PC6 \& PC7 when in the Full Address Mode. \\
\hline DB0-DB7 & 53-46 & Eight bidirectional data bus lines used to transmit data to and from external memory. \\
\hline SYNC & 22 & SYNC is a positive going signal for the full clock cycle whenever the CPU is performing an OP CODE fetch. \\
\hline R/W & 40 & Controls the direction of data transfer between the CPU and the external 65 K address space. The signal is high when reading and low when writing. \\
\hline
\end{tabular}

\section*{SECTION 3 SYSTEM ARCHITECTURE}

This section provides a functional description of the R6500/ 13. Functionally the R6500/13 consists of a CPU, both RAM and optional ROM memories, four 8-bit parallel I/O ports, a serial I/O port, dual counter/latch circuits, a mode control register, and an interrupt flag/enable dual register circuit. A block diagram of the system is shown in Figure 3-1.

\section*{NOTE}

Throughout this document, unless specified otherwise, all memory or register address locations are specified in hexadecimal notation.

\subsection*{3.1 CPU LOGIC}

The R6500/13 internal CPU is a standard 6502 configuration with an 8 -bit Accumulator register, two 8 -bit Index Registers ( X and Y ); an 8 -bit Stack Pointer register, an ALU, a 16 -bit Program Counter, and standard instruction register/decode and internal timing control logic.

\subsection*{3.1.1 Accumulator}

The accumulator is a general purpose 8 -bit register that stores the results of most arithmetic and logic operations. In addition, the accumulator usually contains one of the two data words used in these operations.

\subsection*{3.1.2 Index Registers}

There are two 8 -bit index registers, X and Y . Each index register can be used as a base to modify the address data program counter and thus obtain a new address-the sum of the program counter contents and the index register contents.

When executing an instruction which specifies indirect addressing, the CPU fetches the op code and the address and modifies the address from memory by adding the index register to it prior to loading or storing the value of memory.

Indexing greatly simplifies many types of programs, especially those using data tables.

\subsection*{3.1.3 Stack Pointer}

The Stack Pointer is an 8 -bit register. It is automatically incremented and decremented under control of the microprocessor to perform stack manipulation in response to either user instructions, an internal \(\overline{\mathrm{RQ}}\) interrupt, or the external interrupt line \(\overline{\mathrm{NMI}}\). The Stack Pointer must be initialized by the user program.

The stack allows simple implementation of multiple level interrupts, subroutine nesting and simplification of many types of data manipulation. The JSR, BRK, RTI and RTS instructions use the stack and Stack Pointer.

The stack can be envisioned as a deck of cards which may be accessed only from the top. The address of a memory
location is stored (or "pushed") onto the stack. Each time data are to be pushed onto the stack, the Stack Pointer is placed on the Address Bus, data are written into the memory location addressed by the Stack Pointer, and the Stack Pointer is decremented by 1 . Each time data are read (or "pulled") from the stack, the Stack Pointer is incremented by 1. The Stack Pointer is then placed on the Address Bus and data are read from the memory location addressed by the Pointer.

The stack is located on zero page, i.e., memory locations 00FF-0040. After reset, which leaves the Stack Pointer indeterminate, normal usage calls for its initialization at 00FF.

\subsection*{3.1.4 Arithmetic And Logic Unit (ALU)}

All arithmetic and logic operations take place in the ALU, including incrementing and decrementing internal registers (except the Program Counter). The ALU cannot store data for more than one cycle. If data are placed on the inputs to the ALU at the beginning of a cycle, the result is always gated into one of the storage registers or to external memory during the next cycle.

Each bit of the ALU has two inputs. These inputs can be tied to various internal buses or to a logic zero; the ALU then generates the function (AND, OR, SUM, and so on) using the data on the two inputs.

\subsection*{3.1.5 Program Counter}

The 16 -bit Program Counter provides the addresses that are used to step the processor through sequential instructions in a program. Each time the processor fetches an instruction from program memory, the lower (least significant) byte of the Program Counter ( PCL ) is placed on the low-order bits of the Address Bus and the higher (most significant) byte of the Program Counter \((\mathrm{PCH})\) is placed on the high-order 8 bits of the Address Bus. The Counter is incremented each time an instruction or data is fetched from program memory.

\subsection*{3.1.6 Instruction Register and Instruction Decode}

Instructions are fetched from ROM or RAM and gated onto the Internal Data Bus. These instructions are latched into the Instruction Register, then decoded along with timing and interrupt signals to generate control signals for the various registers.

\subsection*{3.1.7 Timing Control}

The Timing Control Logic keeps track of the specific instruction cycle being executed. This logic is set to T0 each time an instruction fetch is executed and is advanced at the beginning of each Phase One clock pulse for as many cycles as are required to complete the instruction. Each data transfer which takes place between the registers is caused by decoding the contents of both the instruction register and timing control unit.


\subsection*{3.1.8 Interrupt Logic}

Interrupt logic controls the sequencing of three interrupts; \(\overline{\mathrm{RES}}, \overline{\mathrm{NMI}}\) and \(\overline{\mathrm{IRQ}} . \overline{\mathrm{IRQ}}\) is generated by any one of eight conditions: 2 Counter Overflows, 2 Positive Edge Detects, 2 Negative Edge Detects, and 2 Serial Port Conditions.

\subsection*{3.2 NEW INSTRUCTIONS}

In addition to the standard R6502 instruction set, four new bit manipulation instructions have been added to the R6500/ 13. The added instructions and their format are explained in the following paragraphs. Refer to Appendix A for the Op Code mnemonic addressing matrix for these added instructions. The four added instructions do not impact the CPU processor status register.

\subsection*{3.2.1 Set Memory Bit (SMB m, Addr.)}

This instruction sets to " 1 " one of the 8 -bit data field specified by the zero page address (memory or I/O port). The first byte of the instruction specifies the SMB operation and one of eight bits to be set. The second byte of the instruction designates address (0-255) of the byte to be operated upon.

\subsection*{3.2.2 Reset Memory Bit (RMB m, Addr.)}

This instruction is the same operation and format as SMB instruction except a reset to " 0 " of the bit results.

\subsection*{3.2.3 Branch On Bit Set Relative (BBS m, Addr, DEST)}

This instruction tests one of eight bits designated by a 3-bit immediate field within the first byte of the instruction. The second byte is used to designate the address of the byte to be tested within the zero page address range (memory or \(\mathrm{I} / \mathrm{O}\) ports). The third byte of the instruction is used to specify the 8 -bit relative address to which the instruction branches if the bit tested is a " 1 ". If the bit tested is not set, the next sequential instruction is executed.

\subsection*{3.2.4 Branch On Bit Reset Relative (BBR m, Addr, DEST)}

This instruction is the same operation and format as the BBS instruction except that a branch takes place if the bit tested is a " 0 ".

\subsection*{3.3 READ-ONLY-MEMORY (ROM)}

The optional ROM consists of 256 bytes mask programmable memory with an address space from 7F00 to 7FFF. ROM locations FFFA to FFFF are assigned for interrupt vectors. The reset vector can be optionally at 7FFE or FFFC.

The R6511Q has no ROM and its Reset vector is at FFFC.

\subsection*{3.4 RANDOM ACCESS MEMORY (RAM)}

The RAM consists of 192 bytes of read/write memory with an assigned page zero address of 0040 through 00FF. The R6500/13 provides a separate power pin ( \(\mathrm{V}_{\mathrm{RB}}\) ) which may be used for standby power for 32 bytes located at 0040-005F. In the event of the loss of \(\mathrm{V}_{\mathrm{cc}}\) power, the lowest 32 bytes of RAM data will be retained if standby power is supplied to the \(V_{R R}\) pin. If the RAM data retention is not required then \(V_{R R}\) must be connected to \(\mathrm{V}_{\mathrm{Cc}}\). During operation \(\mathrm{V}_{\mathrm{RR}}\) must be at the \(\mathrm{V}_{\mathrm{cc}}\) level.

For the RAM to retain data upon loss of \(\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{RR}}\) must be supplied within operating range and \(\overline{\text { RES }}\) must be driven low at least eight \(\varnothing 2\) clock pulses before \(V_{c c}\) falls out of operating range. \(\overline{\text { RES }}\) must then be held low while \(V_{c c}\) is out of operating range and until at least eight \(\emptyset 2\) clock cycles after \(V_{c c}\) is again within operating range and the internal \(\emptyset 2\) oscillator is stabilized. \(V_{R R}\) must remain within \(V_{C C}\) operating range during normal operation. When \(\mathrm{V}_{\mathrm{cc}}\) is out of operating range, \(V_{R R}\) must remain within the \(V_{R R}\) retention range in order to retain data. Figure 3.2 shows typical waveforms.


Figure 3-2. Data Retention Timing

\section*{R6511Q Microprocessor and R6500/13 Microcomputer}

\subsection*{3.5 CLOCK OSCILLATOR}

The R6511Q has been configured for a crystal oscillator, a divide by 2 countdown network, and for Master Mode Operation.

Three customer selectable mask options are available for controlling the R6500/13 timing. The R6500/13 can be ordered with a crystal oscillator, a divide by 2 or divide by 4 countdown network and for clock master mode or clock slave mode operation.

For 2 MHz interval operation the divide-by-2 options must be specified.

The on-chip oscillator is designed for a parallel resonant crystal connected between XTLI and XTLO pins. The equivalent oscillator circuit is shown in Figure 3-3.

A parallel resonant crystal is specified by its load capacitance and series resonant resistance. For proper oscillator operation, the load capacitance \(\left(\mathrm{C}_{\mathrm{L}}\right)\), series resistance \(\left(\mathrm{R}_{\mathrm{S}}\right)\) and the crystal resonant frequency ( F ) must meet the following two relations:
\[
\begin{gathered}
(C+27)=2 C_{L} \quad \text { or } \quad C=2 C_{L}-27 \mathrm{pF} \\
R_{s} \leq R_{s m a x}=\frac{2 \times 10^{6}}{\left(F C_{L}\right)^{2}}
\end{gathered}
\]
where: \(F\) is in \(M H z ; C\) and \(C_{L}\) are in \(p F ; R\) is in ohms.
To select a parallel resonant crystal for the oscillator, first select the load capacitance from a Crystal Manufacturer's catalog. Next, calculate \(R_{\text {smax }}\) based on \(F\) and \(\mathrm{C}_{\mathrm{L}}\). The selected crystal must have a \(R_{s}\) less than the \(R_{\text {smax }}\).


Figure 3-3. Clock Oscillator Input Options

For example, if \(\mathrm{C}_{\mathrm{L}}=22 \mathrm{pF}\) for a 4 MHz parallel resonant crystal, then
\[
\begin{aligned}
& \mathrm{C}=(2 \times 22)-27=17 \mathrm{pF} \\
& \text { (use standard value of } 18 \mathrm{pF} \text { ) }
\end{aligned}
\]

The series resistance of the crystal must be less than
\[
R_{\text {smax }}=\frac{2 \times 10^{6}}{(4 \times 22)^{2}}=258 \mathrm{ohms}
\]

Internal timing can also be controlled by driving the XTLI pin with an external frequency source. Figure 3-3b shows typical connections. If XTLO is left floating, the external source is divided by the internal countdown network. However, if XTLO is tied to \(\mathrm{V}_{\mathrm{ss}}\), the internal countdown network is bypassed causing the chip to operate at the frequency of the external source.

The operation described above assumed a CLOCK MASTER MODE mask option. In this mode a frequence source (crystal or external source) must be applied to the XTLI and XTLO pins.

Q2 is a buffered output signal which closely approximates the interal timing. When a common external source is used to drive multiple devices the internal timing between devices as well as their \(\emptyset 2\) outputs will be skewed in time. If skewing represents a system problem it can be avoided by the Master/Slave connection and options shown in Figure 3-4.

One R6500/13 is operated in the CLOCK MASTER MODE and a second in the CLOCK SLAVE MODE. Mask options in the SLAVE unit convert to \(\emptyset 2\) signal into a clock input pin which is tightly coupled to the internal timing generator. As a result the internal timing of the MASTER and SLAVE units are synchronized with minimum skew. If the \(\emptyset 2\) signal to the SLAVE unit is inverted, the MASTER and SLAVE UNITS WILL OPERATE OUT OF PHASE. This approach allows the two devices to share external memory using cycle stealing techniques.


Figure 3-4. Master/Slave Connections

\subsection*{3.6 MODE CONTROL REGISTER (MCR)}

The Mode Control Register contains control bits for the multifunction I/O ports and mode select bits for Counter A and Counter B. Its setting, along with the setting of the Serial Communications Control Register (SCCR), determines the basic configuration of the R6500/13 in any application. Initializing this register is one of the first actions of any software program. The Mode Control Register bit assignment is shown in Figure 3-5.


Figure 3-5. Mode Control Register

The use of Counter A Mode Select is shown in Section 6.1.
The use of Counter B Mode Select is shown in Section 6.2.

The use of Port B Latch Enable is shown in Section 4.4.
The use of Port D in Tri-State Enable is shown in Section 4.6.

The use of Bus Mode Select is shown in Section 4.5 and 4.6

\subsection*{3.7 INTERRUPT FLAG REGISTER (IFR) AND INTERRUPT ENABLE REGISTER (IER)}

An \(\overline{\mathrm{IRQ}}\) interrupt request can be initiated by any or all of eight possible sources. These sources are all capable of being enabled or disabled by the use of the appropriate interrupt enabled bits in the Interrupt Enable Register (IER). Multiple simultaneous interrupts cause the \(\overline{\mathrm{RQ}}\) interrupt request to remain active until all interrupting conditions have been serviced and cleared.

The Interrupt Flag Register contains the information that indicates which I/O or counter needs attention. The contents of the Interrupt Flag Register may be examined at any time by reading at address: 0011. Edge detect IFR bits may be cleared by executing a RMB instruction at address location 0010. The RMB X, (0010) instruction reads FF, modifies bit \(X\) to a " 0 ", and writes the modified value at address location 0011. In this way IFR bits set to a " 1 " after the read cycle of a Read-Modify-Write instruction (such as RMB) are protected from being cleared. A logic " 1 " is ignored when writing to edge detect IFR bits.

Each IFR bit has a corresponding bit in the Interrupt Enable Register which can be set to a "1" by writing a " 1 " in the respective bit position at location 0012 . Individual IER bits may be cleared by writing a " 0 " in the respective bit position, or by \(\overline{\text { RES. If set to a " } 1 \text { ", an IRQ will be generated when the }}\) corresponding IFR bit becomes true. The Interrupt Flag Register and Interrupt Enable Register bit assignments are shown in Figure 3-6 and the functions of each bit are explained in Table 3-1.

R6511Q Microprocessor and R6500/13 Microcomputer


Figure 3-6. Interrupt Enable and Flag Registers

Table 3-1. Interrupt Flag Register Bit Codes
\begin{tabular}{|c|c|}
\hline \begin{tabular}{l}
Bit \\
Code
\end{tabular} & Function \\
\hline IFR 0: & PAO Positive Edge Detect Flag-Set to a " 1 " when a positive going edge is detected on PA0. Cleared by RMB O (0010) instruction or by RES. \\
\hline IFR 1: & PA1 Positive Edge Detect Flag-Set to a 1 when a positive going edge is detected on PA1. Cleared by RMB 1 (0010) instruction or by \(\overline{\text { RES. }}\) \\
\hline IFR 2: & PA2 Negative Edge Detect Flag-Set to a 1 when a negative going edge is detected on PA2. Cleared by RMB 2 (0010) instruction or by \(\overline{\text { RES. }}\) \\
\hline IFR 3: & PA3 Negative Edge Detect Flag-Set to 1 when a negative going edge is detected on PA3. Cleared by RMB 3 (0010) instruction or by RES. \\
\hline IFR 4: & Counter A Underflow Flag-Set to a 1 when Counter A underflow occurs. Cleared by reading the Lower Counter A at location 0018, by writing to address location 001A, or by RES. \\
\hline IFR 5: & Counter B Underflow Flag-Set to a 1 when Counter B underflow occurs. Cleared by reading the Lower Counter B at location 001C, by writing to address location 001E, or by RES. \\
\hline IFR 6: & Receiver Interrupt Flag-Set to a 1 when any of the Serial Communication Status Register bits 0 through 3 is set to a 1. Cleared when the Receiver Status bits (SCSR 0-3) are cleared or by RES. \\
\hline IFR 7: & Transmitter Interrupt Flag-Set to a 1 when SCSR 6 is set to a 1 while SCSR 5 is a 0 or SCSR 7 is set to a 1 . Cleared when the Transmitter Status bits (SCSR \(6 \& 7\) ) are cleared or by RES. \\
\hline
\end{tabular}

\subsection*{3.8 PROCESSOR STATUS REGISTER}

The 8-bit Processor Status Register, shown in Figure 3-7, contains seven status flags. Some of these flags are controlled by the user program; others may be controlled both by the user's program and the CPU. The R6502 instruction set contains a number of conditional branch instructions which are designed to allow testing of these flags. Each of the eight processor status flags is described in the following sections.

\subsection*{3.8.1 Carry Bit (C)}

The Carry Bit (C) can be considered as the ninth bit of an arithmetic operation. It is set to logic 1 if a carry from the eighth bit has occurred or cleared to logic 0 if no carry occurred as the result of arithmetic operations.

The Carry Bit may be set or cleared under program control by use of the Set Carry (SEC) or Clear Carry (CLC) instruction, respectively. Other operations which affect the Carry Bit are ADC, ASL, CMP, CPX, CPY, LSR, PLP, ROL, ROR, RTI, and SBC.

\subsection*{3.8.2 Zero Bit (Z)}

The Zero Bit ( \(Z\) ) is set to logic 1 by the CPU during any data movement or calculation which sets all 8 bits of the result to
zero. This bit is cleared to logic 0 when the resultant 8 bits of a data movement or calculation operation are not all zero. The R6500 instruction set contains no instruction to specifically set or clear the Zero Bit. The Zero Bit is, however, affected by the following instructions; ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TXA, TSX, and TYA.

\subsection*{3.8.3 Interrupt Disable Bit (I)}

The Interrupt Disable Bit \((\mathrm{I})\) is used to control the servicing of an interrupt request ( \(\overline{\mathrm{RQ}})\). If the I Bit is reset to logic 0 , the \(\overline{\mathrm{RQ}}\) signal will be serviced. If the bit is set to logic 1 , the \(\overline{\mathrm{RQ}}\) signal will be ignored. The CPU will set the Interrupt Disable Bit to logic 1 if a RESET ( \(\overline{\mathrm{RES}}\) ), \(\overline{\mathrm{RQ}}\), or Non-Maskable Interrupt ( \(\overline{\mathrm{NMI}}\) ) signal is detected.

The I bit is cleared by the Clear Interrupt Mask Instruction (CLI) and is set by the Set Interrupt Mask Instruction (SEI). This bit is set by the BRK Instruction. The Return from Interrupt (RTI) and Pull Processor Status (PLP) instructions will also affect the I bit.


Figure 3-7. Processor Status Register

\section*{R6511Q Microprocessor and R6500/13 Microcomputer}

\subsection*{3.8.4 Decimal Mode Bit (D)}

The Decimal Mode Bit ( D ) is used to control the arithmetic mode of the CPU. When this bit is set to logic 1 , the adder operates as a decimal adder. When this bit is cleared to logic 0 , the adder operates as a straight binary adder. The adder mode is controlled only by the programmer. The Set Decimal Mode (SED) instruction will set the D bit; the Clear Decimal Mode (CLD) instruction clears it. The PLP and RTI instructions also affect the Decimal Mode Bit.

\section*{CAUTION}

The Decimal Mode Bit will either set or clear in an unpredictable manner upon power application. This bit must be initialized to the desired state by the user program or erroneous results may occur.

\subsection*{3.8.5 Break Bit (B)}

The Break Bit ( B ) is used to determine the condition which caused the \(\overline{\mathrm{RQ}}\) service routine to be entered. If the \(\overline{\mathrm{RQ}}\) service routine was entered because the CPU executed a BRK command, the Break Bit will be set to logic 1. If the \(\overline{\mathrm{IRQ}}\) routine was entered as the result of an \(\overline{\mathrm{R} Q}\) signal being generated, the \(B\) bit will be cleared to logic 0 . There are no instructions which can set or clear this bit.

\subsection*{3.8.6 Overflow Bit (V)}

The Overflow Bit (V) is used to indicate that the result of a signed, binary addition, or subtraction, operation is a value that cannot be contained in seven bits \((-128 \leqslant n \leqslant 127)\).

This indicator only has meaning when signed arithmetic (sign and seven magnitude bits) is performed. When the ADC or SBC instruction is performed, the Overflow Bit is set to logic 1 if the polarity of the sign bit (bit 7 ) is changed because the result exceeds +127 or -128 ; otherwise the bit is cleared to logic 0 . The V bit may also be cleared by the programmer using a Clear Overflow (CLV) instruction.

The Overflow Bit may also be used with the BIT instruction. The BIT instruction-which may be used to sample interface devices-allows the overflow flag to reflect the condition of bit 6 in the sampled field. During a BIT instruction the Overflow Bit is set equal to the content of the bit 6 on the data tested with BIT instruction. When used in this mode, the overflow has nothing to do with signed arithmetic, but is just another sense bit for the microprocessor. Instructions affecting the \(V\) flag are ADC, BIT, CLV, PLP, RTI and SBC.

\subsection*{3.8.7 Negative Bit ( N )}

The Negative Bit \((\mathrm{N})\) is used to indicate that the sign bit (bit 7) in the resulting value of a data movement or data arithmetic operation is set to logic 1 . If the'sign bit is set to logic 1 , the resulting value of the data movement or arithmetic operation is negative; if the sign bit is cleared, the result of the data movement or arithmetic operation is positive. There are no instructions that set or clear the Negative Bit since the Negative Bit represents only the status of a result. The instructions that effect the state of the Negative Bit are: ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TSX, TXA, and TYA.

\section*{SECTION 4 PARALLEL INPUT/OUTPUT PORTS \& BUS MODES}

The devices have \(321 / O\) lines grouped into four 8 -bit ports (PA, PB, PC, and PD). Ports A through C may be used either for input or output individually or in groups of any combination. Port D may be used as all inputs or all outputs.

Multifunction I/O's such as Port A and Port C are protected from normal port I/O instructions when they are programmed to perform a multiplexed function.

Internal pull-up resistors (FET's with an impedance range of \(3 \mathrm{~K} \leq \mathrm{R}_{\mathrm{L}} \leq 12 \mathrm{~K}\) ohm) are optional on all port pins except Port D (R6500/13 only).

The direction of the \(321 / O\) lines are controlled by four 8 -bit port registers located in page zero. This arrangement provides quick programming access using simple two-byte zero page address instructions. There are no direction registers associated with the I/O ports, thus simplifying I/O handling. The 1/O addresses are shown in Table 4-1. Appendix E. 6 shows the I/O Port Timing.

Table 4-1. I/O Port Addresses
\begin{tabular}{|c|c|}
\hline Port & Address \\
\hline A & 0000 \\
B & 0001 \\
C & 0002 \\
D & 0003 \\
\hline
\end{tabular}

\subsection*{4.1 INPUTS}

Inputs for Ports A, B, and C are enabled by loading logic 1 into all I/O port register bit positions that are to correspond to I/O input lines. A low ( \(<0.8 \mathrm{~V}\) ) input signal will cause a logic 0 to be read when a read instruction is issued to the port register. A high ( \(>2.0 \mathrm{~V}\) ) input will cause a logic 1 to be read. An \(\overline{R E S}\) signal forces all I/O port registers to logic 1 thus initially treating all I/O lines as inputs.

Port D may only be all inputs or all outputs. All inputs is selected by setting bit 5 of the Mode Control Register (MCR5) to a " 0 ".

The status of the input lines can be interrogated at any time by reading the I/O port addresses. Note that this will return the actual status of the input lines, not the data written into the \(1 / O\) port registers.

Read/Modify/Write instructions can be used to modify the operation of PA, PB, PC, \& PD. During the Read cycle of a Read/Modify/Write instruction the Port I/O register is read. For all other read instructions the port input lines are read. Read/Modify/Write instructions are: ASL, DEC, INC, LSR, RMB, ROL, ROR, and SMB.

\subsection*{4.2 OUTPUTS}

Outputs for Ports A thru D are controlled by writing the desired I/O line output states into the corresponding I/O port register bit positions. A logic 1 will force a high ( \(>2.4 \mathrm{~V}\) ) output while a logic 0 will force a low ( \(<0.4 \mathrm{~V}\) ) output.

Port D all outputs is selected by setting MCR5 to a " 1 ".

\subsection*{4.3 Port A (PA)}

Port A can be programmed via the Mode Control Register (MCR) and the Serial Communications Control Register (SCCR) as a standard parallel 8-bit, bit independent, l/O port or as serial channel I/O lines, counter I/O lines, or an input data strobe for the Port B input latch option. Table 4-2 tabulates the control and usage of Port \(A\).

In addition to their normal I/O functions, PAO and PA1 can detect positive going edges and PA2 and PA3 can detect negative going edges. A proper transition on these pins will set a corresponding status bit in the IFR and generate an interrupt request if the respective Interrupt Enable Bit is set. The maximum rate at which an edge can be detected is onehalf the \(\varnothing 2\) clock rate. Edge detection timing is shown in Appendix E.5.

Table 4-2. Port A Control \& Usage


\section*{R6511Q Microprocessor and R6500/13 Microcomputer}

\subsection*{4.4 PORT B (PB)}

Port B can be programmed as an 8 -bit, bit-independent I/O port. It has a latched input capability which may be enabled or disabled via the Mode Control Register (MCR). Table 4-3 tabulates the control and usage of Port B. An Input Data Strobe signal must be provided thru PAO when Port B is programmed to be used with latched input option. Input data latch timing for Port B is shown in Appendix E.5.

Table 4-3. Port B Control \& Usage
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{2}{|l|}{\multirow[t]{2}{*}{}} & \multicolumn{2}{|c|}{I/O Mode} & \multicolumn{2}{|c|}{\begin{tabular}{l}
Latch \\
Mode
\end{tabular}} \\
\hline & & \multicolumn{2}{|l|}{MCR4 \(=0\)} & \multicolumn{2}{|r|}{\begin{tabular}{l}
\[
\text { MCR4 }=1
\] \\
(2)
\end{tabular}} \\
\hline \multirow[b]{2}{*}{\[
\begin{gathered}
\text { Pin } \\
\#
\end{gathered}
\]} & \multirow[b]{2}{*}{Pin Name} & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} \\
\hline & & Name & \begin{tabular}{l}
Type \\
(1)
\end{tabular} & Name & Type \\
\hline 31 & PBO & PBO & 1/0 & PBO & INPUT \\
\hline 30 & PB1 & PB1 & \(1 / 0\) & PB1 & INPUT \\
\hline 29 & PB2 & PB2 & I/O & PB2 & INPUT \\
\hline 28 & PB3 & PB3 & 110 & РВ3 & INPUT \\
\hline 27 & PB4 & PB4 & 1/0 & PB4 & INPUT \\
\hline 26 & PB5 & PB5 & 1/0 & PB5 & INPUT \\
\hline 25 & PB6 & PB6 & \(1 / 0\) & PB6 & INPUT \\
\hline 24 & PB7 & PB7 & 1/O & PB7 & INPUT \\
\hline
\end{tabular}
(1) Resistive Pull-Up, Active Buffer Pull-Down
(2) Input data is stored in Port B latch by PAO Pulse

\subsection*{4.5 PORT C (PC)}

Port C can be programmed as an I/O port, as part of the full address bus, and, in conjunction with Port D, as an abbreviated bus, or as a multiplexed bus. When operating in the Full Address Mode PC6 and PC7 serve as A13 and A14 with PCO-PC5 operating as normal I/O pins. When used in the abbreviated or multiplexed bus modes, PC0-PC7 function as A0-A3, A12, R/W, A13, and EMS, respectively, as shown in Table 4-4. EMS (External Memory Select) is asserted (low) whenever the internal processor accesses memory area between 0100 and 3FFF. (See Memory Map, Appendix B). The leading edge of EMS may be used to strobe the eight address lines multiplexed on Port D in the Multiplexed Bus Mode. See Appendices E. 3 through E. 5 for Port C timing.

\subsection*{4.6 PORT D (PD)}

Port D can be programmed as an I/O Port, an 8-bit tri-state data bus, or as a multiplexed bus. Mode selection for Port D is made by the Mode Control Register (MCR). The Port D output drivers can be selected as tri-state drivers by setting bit 5 of the MCR to 1 (one). Table \(4-5\) shows the necessary settings for the MCR to achieve the various modes for Port D. When Port D is
selected to operate in the Abbreviated Mode PD0-PD7 serves as data register bits D0-D7. When Port D is selected to operate in the Multiplexed Mode data bits D0 through D7 are time multiplexed with address bits A4 through A11, respectively. Refer to the Memory Maps (Appendix C) for Abbreviated and Multiplexed memory assignments. See Appendices E. 3 through E. 5 for Port D timing.

\subsection*{4.7 BUS MODES}

A special attribute of Port C and Port D is their capability to be configured via the Mode Control Register (see Section 3.6) into four different modes.

In the Full Address Mode, the separate address and data bus are used in conjunction with PC6 and PC7, which automatically provide A13 and A14. The remaining ports perform the normal I/O function.

In the I/O Bus Mode all ports serve as I/O. The address and data bus are still functional but without A13 and A14. Since the internal RAM and registers are in the 00XX location, A15 can be used for chip select and A0-A12 used for selecting 8 K of external memory. Thus, the device can be used to emulate the R6500/11 in the Normal Bus Mode.

In the Abbreviated Bus Mode, the address and data lines can be used as in the I/O Bus Mode to emulate the R6500/11. Port C and Port D are automatically transformed into an abbreviated address bus and control signals (Port C) and a bidirectional data bus (Port D). 64 Peripheral addresses can be selected. In general usage, these 64 addresses would be distributed to several external I/O devices such as R6522 and R6520, etc., each of which may contain more than one unique address.

In the Multiplexed Bus Mode, the operation is similar to the Abbreviated Mode except that a full 16K of external addresses are provided. Port C provides the lower addresses and control signals. Port D multiplexes functions. During the first half of the cycle it contains the remaining necessary 8 address bits for 16 K ; during the second half of the cycle it contains a bidirectional data bus. The address bits appearing on Port D must be latched into an external holding register. The leading edge of \(\overline{E M S}\), which indicates that the bus function is active, may be used for this purpose.

MCR5 must be a logic 1 in the Abbreviated and Multiplexed Bus Modes.

Figures 4-1a through 4-1d show the possible configurations of the four bus modes. Figure 4-2 shows a memory map of the part as a function of the Bus Mode and further shows which adddresses are active or inactive on each of the three possible buses.

R6511Q Microprocessor and R6500/13 Microcomputer
Table 4-4. Port C Control \& Usage
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{4}{*}{\[
\begin{gathered}
\text { Pin } \\
\#
\end{gathered}
\]} & & \multicolumn{2}{|c|}{Full Address Mode} & \multicolumn{2}{|l|}{Normal Mode} & \multicolumn{2}{|r|}{Abbreviated Mode} & \multicolumn{2}{|c|}{Multiplexed Mode} \\
\hline & & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=0 \\
& \text { MCR6 }=0
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=0 \\
& \text { MCR6 }=1
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=0
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=1
\end{aligned}
\]} \\
\hline & \multirow[b]{2}{*}{Pin Name} & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} \\
\hline & & Name & Type & Name & \begin{tabular}{l}
Type \\
(1)
\end{tabular} & Name & \begin{tabular}{l}
Type \\
(2)
\end{tabular} & Name & \begin{tabular}{l}
Type \\
(2)
\end{tabular} \\
\hline 54 & PCO & PC0 & I/O (1) & PCO & I/O & AO & OUTPUT & A0 & OUTPUT \\
\hline 55 & PC1 & PC1 & I/O (1) & PC1 & 1/0 & A1 & OUTPUT & A1 & OUTPUT \\
\hline 56 & PC2 & PC2 & I/O (1) & PC2 & \(1 / 0\) & A2 & OUTPUT & A2 & OUTPUT \\
\hline 57 & PC3 & PC3 & I/O (1) & PC3 & \(1 / 0\) & А3 & OUTPUT & A3 & OUTPUT \\
\hline 58 & PC4 & PC4 & I/O (1) & PC4 & 1/0 & A12 & OUTPUT & A12 & OUTPUT \\
\hline 59 & PC5 & PC5 & \(1 / \mathrm{O}\) (1) & PC5 & I/O & RW & OUTPUT & RW & OUTPUT \\
\hline 60 & PC6 & A13 & OUTPUT (2) & PC6 & 1/0 & A13 & OUTPUT & A13 & OUTPUT \\
\hline 61 & PC7 & A14 & OUTPUT (2) & PC7 & 1/0 & EMS & OUTPUT & EMS & OUTPUT \\
\hline \multicolumn{10}{|l|}{\begin{tabular}{l}
(1) Resistive Pull-Up, Active Buffer Pull-Down \\
(2) Active Buffer Pull-Up and Pull-Down
\end{tabular}} \\
\hline
\end{tabular}

Table 4-5. Port D Control \& Usage
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{5}{*}{\[
\begin{gathered}
\text { Pin } \\
\#
\end{gathered}
\]} & \multirow[b]{5}{*}{\begin{tabular}{l}
Pin \\
Name
\end{tabular}} & \multicolumn{4}{|c|}{Normal Modes} & \multicolumn{2}{|l|}{\multirow[t]{2}{*}{Abbreviated Mode
\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=0 \\
& \text { MCR5 }=1
\end{aligned}
\]}} & \multicolumn{4}{|c|}{Multiplexed Mode} \\
\hline & & \multicolumn{2}{|r|}{\multirow[t]{2}{*}{\[
\begin{aligned}
& \text { MCR7 }=0 \\
& \text { MCR6 }=\mathrm{X} \\
& \text { MCR5 }=0 \\
& \hline \text { Signal }
\end{aligned}
\]}} & \multicolumn{2}{|r|}{\multirow[t]{2}{*}{\[
\begin{aligned}
& \text { MCR7 }=0 \\
& \text { MCR6 }=x \\
& \text { MCR5 }=1 \\
& \text { Signal }
\end{aligned}
\]}} & & & \multicolumn{4}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=1 \\
& \text { MCR5 }=1
\end{aligned}
\]} \\
\hline & & & & & & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} \\
\hline & & \multirow[b]{2}{*}{Name} & \multirow[t]{2}{*}{\begin{tabular}{l}
Type \\
(1)
\end{tabular}} & \multirow[b]{2}{*}{Name} & \multirow[t]{2}{*}{\begin{tabular}{l}
Type \\
(2)
\end{tabular}} & \multirow[b]{2}{*}{Name} & \multirow[t]{2}{*}{Type (3)} & \multicolumn{2}{|c|}{02 Low} & \multicolumn{2}{|c|}{02 High} \\
\hline & & & & & & & & Name & Type (2) & Name & Type (3) \\
\hline 62 & PDO & PDO & INPUT & PDO & OUTPUT & DATAO & \(1 / 0\) & A4 & OUTPUT & DATAO & I/O \\
\hline 63 & PD1 & PD1 & INPUT & PD1 & OUTPUT & DATA1 & \(1 / 0\) & A5 & OUTPUT & DATA1 & I/O \\
\hline 64 & PD2 & PD2 & INPUT & PD2 & OUTPUT & DATA2 & \(1 / 0\) & A6 & OUTPUT & DATA2 & \(1 / 0\) \\
\hline 1 & PD3 & PD3 & INPUT & PD3 & OUTPUT & DATA3 & \(1 / 0\) & A7 & OUTPUT & DATA3 & \(1 / 0\) \\
\hline 2 & PD4 & PD4 & INPUT & PD4 & OUTPUT & DATA4 & \(1 / 0\) & A8 & OUTPUT & DATA4 & 1/0 \\
\hline 3 & PD5 & PD5 & INPUT & PD5 & OUTPUT & DATA5 & \(1 / 0\) & A9 & OUTPUT & DATA5 & 1/0 \\
\hline 4 & PD6 & PD6 & INPUT & PD6 & OUTPUT & DATA6 & \(1 / 0\) & A10 & OUTPUT & DATA6 & I/O \\
\hline 5 & PD7 & PD7 & INPUT & PD7 & OUTPUT & DATA7 & \(1 / 0\) & A11 & OUTPUT & DATA7 & 1/O \\
\hline \multicolumn{12}{|l|}{\begin{tabular}{l}
(1) Tri-State Buffer is in High Impedance Mode \\
(2) Tri-State Buffer is in Active Mode \\
(3) Tri-State Buffer is in Active Mode only during the phase 2 portion of a Write Cy
\end{tabular}} \\
\hline
\end{tabular}


Figure 4-1. Bus Mode Configurations


Figure 4-2. Memory Map

\section*{SECTION 5 SERIAL INPUT/OUTPUT CHANNEL}

The device provides a full duplex Serial I/O channel with programmable bit rates and operating modes. The serial I/O functions are controlled by the Serial Communication Control Register (SCCR). The SCCR bit assignment is shown in Figure 5-1. The serial bit rate is determined by Counter A for all modes except the Receiver Shift Register (RCVR S/R) mode for which an external shift clock must be provided. The maximum data rate using the internal clock is 62.5 K bits per second (at \(\emptyset 2=1 \mathrm{MHZ}\) ). The transmitter (XMTR) and receiver (RCVR) can be independently programmed to operate in different modes and can be independently enabled or disabled.


Figure 5-1. Serial Communication Control Register
Except for the Receiver Shift Register Mode (RCVR S/R), all XMTR and RCVR bit rates will occur at one sixteenth of the Counter A interval timer rate. Counter A is forced into an interval timer mode whenever the serial I/O is enabled in a mode requiring an internal clock.

Whenever Counter \(A\) is required as a timing source it must be loaded with the hexadecimal code that selects the data rate for the serial I/O Port. Refer to Counter A (paragraph 6.1) for a table of hexadecimal values to represent the desired data rate.

\subsection*{5.1 TRANSMITTER OPERATION (XTMR)}

The XTMR operation and the transmitter related control/ status functions are enabled by bit 7 of the Serial Communications Control Register (SCCR). The transmitter, when in the Asynchronous (ASYN) mode, automatically adds a start bit, one or two stop bits, and, when enabled, a parity bit to the transmitted data. A word of transmitted data (in asynchronous parity mode) can have \(5,6,7\), or 8 bits of data. The nine data modes are shown in Figure 5-2. When parity is disabled, the 5, 6, 7 or 8 bits of data are terminated with two stop bits.
 above conditions will cause an Interrupt Request if the Receiver Interrupt Enable bit is set to logic 1.

Figure 5-2. SIO Data Modes
In the \(\mathrm{S} / \mathrm{R}\) mode, eight data bits are always shifted out. Bits/ character and parity control bits are ignored. The serial data is shifted out via the SO output (PA6) and the shift clock is available at the CA (PA4) pin. When the transmitter underruns in the S/R mode the SO output and shift clock are held in a high state.

The XMTR Interrupt Flag bit (IFR7) is controlled by Serial Communication Status Register bits SCSR5, SCSR6 and SCSR7.
\[
\text { IFR7 }=\text { SCSR6 }(\overline{\text { SCSR5 }}+\text { SCSR7 })
\]

\subsection*{5.2 RECEIVER OPERATION (RCVR)}

The receiver and its selected control and status functions are enabled when SCCR-6 is set to a "1." In the ASYN mode, data format must have a start bit, the appropriate number of data bits, a parity bit (if enabled), and one stop bit. Refer to paragraph 5.1 for a diagram of bit allocations. The receiver bit period is divided into 8 sub-intervals for internal synchronization. The receiver bit stream is synchronized by the start
bit and a strobe signal is generated at the approximate center nization. The receiver bit stream is synchronized by the start
bit and a strobe signal is generated at the approximate center of each incoming bit. Refer to Figure 5-3 for ASYN Receive of each incoming bit. Refer to Figure \(5-3\) for ASYN Receive
Data Timing. The character assembly process does not start if the start bit signal is less than one-half the bit time after a if the start bit signal is less than one-half the bit time after a
low level is detected on the Receive Data Input. Framing error, over-run, and parity error conditions or a RCVR Data error, over-run, and parity error conditions or a RCVR Data
Register Full will set the appropriate status bits. Any of the



Figure 5-3. ASYN Receive Data Timing
In the \(\mathrm{S} / \mathrm{R}\) mode, an external shift clock must be provided at CA (PA4) pin along with 8 bits of serial data (LSB first) at the SI input (PA7). The maximum data rate using an external shift clock is one-eighth the internal clock rate. Refer to Figure 5-4 for S/R Mode Timing.


Figure 5-4. S/R Mode Timing
A RCVR interrupt (IFR6) is generated whenever any of SCSRO-3 are true.

\subsection*{5.3 SERIAL COMMUNICATION STATUS REGISTER (SCSR)}

The Serial Communication Status Register (SCSR) holds information on various communication error conditions, status of the transmitter and receiver data registers, a transmitter end-of-transmission condition, and a receiver idle line condition (Wake-Up Feature). The SCSR bit assignment is shown in Figure 5-5. Bit assignments and functions of the SCSR are as follows:

SCSR 0: Receiver Data Register Full-Set to a logic 1 when a character is transferred from the Receiver Shift Register to the Receiver Data Register. This bit is cleared by reading the Receiver Data Register, or by \(\overline{\text { RES }}\) and is disabled if SCCR \(6=0\). The SCSR 0 bit will not be set to a logic 1 if the received data contains an error condition; instead, a corresponding error bit will be set to a logic 1 .

SCSR 1: Over-Run Error-Set to a logic 1 when a new character is transferred from the Receiver Shift Register with the last character still in the Receiver Data Register. This bit is cleared by reading the Receiver Data Register or by RES.

SCSR 2: Parity Error-Set to logic 1 when the RCVR is in the ASYN Mode, Parity Enable bit is set, and the
received data has a parity error. This bit is cleared by reading the Receiver Data Register or by RES.
SCSR 3: Framing Error-Set to a logic 1 when the received data contains a zero bit after the last data or parity bit in the stop bit slot. Cleared by reading the Receiver Data Register or by RES (ASYN Mode only).
SCSR 4: Wake-Up—Set to a logic 1 by writing a " 1 " in bit 4 of address: 0016. The Wake-Up bit is cleared by \(\overline{\text { RES }}\) or when the receiver detects a string of ten consecutive 1's. When the Wake-Up bit is set SCSR0 through SCSR3 are inhibited.
SCSR 5: End of Transmission-Set to a logic 1 by writing a " 1 " in bit position 5 of address: 0016. The End of Transmission bit is cleared by \(\overline{\operatorname{RES}}\) or upon writing a new data word into the Transmitter Data Register. When the End-of-Transmission bit is true the Transmitter Register Empty bit is disabled until a Transmitter Under-Run occurs.
SCSR 6: Transmitter Data Register Empty—Set to a logic 1 when the contents of the Transmitter Data Register are transferred to the Transmitter Shift Register. Cleared upon writing new data into the Transmit Data Register. This bit is initialized to a logic 1 by \(\overline{\mathrm{RES}}\).
SCSR 7: Transmitter Under-Run-Set to a logic 1 when the last data bit is transmitted if the transmitter is in a S/R Mode or when the last stop bit is transmitted if the XMTR is in the ASYN Mode while the Transmitter Data Register Empty Bit is set. Cleared by a transfer of new data into the Transmitter Shift Register or by \(\overline{\text { RES }}\).


Figure 5-5. SCSR Bit Allocations

\subsection*{5.4 WAKE-UP FEATURE}

In a multi-distributed microprocessor or microcomputer applications, a destination address is usually included at the beginning of the message. The Wake-Up Feature allows non-selected CPU's to ignore the remainder of the message until the beginning of the next message by setting the WakeUp bit. As long as the Wake-Up flag is true, the Receiver Data Register Full Flag remains false. The Wake-Up bit is automatically cleared when the receiver detects a string of 11 consecutive 1's which indicates an idle transmit line. When the next byte is received, the Receiver Data Register Full Flag signals the CPU to wake-up and read the received data.

\section*{SECTION 6 COUNTER/TIMERS}

The device contains two 16-bit counters (Counter A and Counter B) and three 16 -bit latches associated with the counters. Counter A has one 16 -bit latch and Counter B has two 16 -bit latches. Each counter can be independently programmed to operate in one of four modes:

\section*{Counter A}
- Pulse width measurement
- Pulse Generation
- Interval Timer
- Event Counter

Counter B
- Retriggerable Interval Counter
- Asymmetrical Pulse Generation
- Interval Timer
- Event Counter

Operating modes of Counter A and Counter B are controlled by the Mode Control Register. All counting begins at the initialization value and decrements. When modes are selected requiring a counter input/output line, PA4 is automatically selected for Counter A and PA5 is automatically selected for Counter B (see Table 4.2).

\subsection*{6.1 COUNTER A}

Counter A consists of a 16 -bit counter and a 16 -bit latch organized as follows: Lower Counter A (LCA), Upper Counter A (UCA), Lower Latch A (LLA), and Upper Latch A (ULA). The counter contains the count of either \(\emptyset 2\) clock pulses or external events, depending on the counter mode selected. The contents of Counter A may be read any time by executing a read at location 0019 for the Upper Counter A and at location 001A or location 0018 for the Lower Counter A. A read at location 0018 also clears the Counter A Underflow Flag (IFR4).

The 16 -bit latch contains the counter initialization value and can be loaded at any time by executing a write to the Upper Latch A at location 0019 and the Lower Latch A at location 0018. In either case, the contents of the accumulator are copied into the applicable latch register.

Counter A can be started at any time by writing to address: 001 A . The contents of the accumulator will be copied into the


Figure 6-1. Interval Timer Timing Diagram

Upper Latch A before the contents of the 16 -bit latch are transferred to Counter \(A\). Counter \(A\) is set to the latch value whenever Counter A underflows. When Counter A decrements from 0000 the next counter value will be the latch value-not FFFF-and the Counter A Underflow Flag (IFR 4) will be set to " 1 ". This bit may be cleared by reading the Lower Counter A at location 0018, by writing to address location 001A, or by RES.

Counter A operates in any of four modes. These modes are selected by the Counter A Mode Control bits in the Control Register.
\begin{tabular}{|c|c|l|}
\hline \begin{tabular}{c} 
MCR1 \\
(bit 1)
\end{tabular} & \begin{tabular}{c} 
MCR0 \\
(bit 0)
\end{tabular} & \multicolumn{1}{c|}{ Mode } \\
\hline 0 & 0 & Interval Timer \\
0 & 1 & Pulse Generation \\
1 & 0 & Event Counter \\
1 & 1 & Pulse Width Measurement \\
\hline
\end{tabular}

The Interval Timer, Pulse Generation, and Pulse Width Measurement Modes are \(\phi 2\) clock counter modes. The Event Counter Mode counts the occurrences of an external event on the CNTR line.

The Counter is set to the Interval Timer Mode (00) when a \(\overline{\mathrm{RES}}\) signal is generated.

\subsection*{6.1.1 Interval Timer}

In the Interval Timer mode the Counter is initialized to the Latch value by either of two conditions:
1. When the Counter is decremented from 0000, the next Counter value is the Latch value (not FFFF).
2. When a write operation is performed to the Load Upper Latch and Transfer Latch to Counter address 001A, the Counter is loaded with the Latch value. Note that the contents of the Accumulator are loaded into the Upper Latch before the Latch value is transferred to the Counter.

The Counter value is decremented by one count at the 02 clock rate. The 16 -bit Counter can hold from 1 to 65535 counts. The Counter Timer capacity is therefore \(1 \mu \mathrm{~s}\) to 65.535 ms at the \(1 \mathrm{MHz} \phi 2\) clock rate or \(0.5 \mu \mathrm{~s}\) to 32.767 ms at the \(2 \mathrm{MHz} \emptyset 2\) clock rate. Time intervals greater than the maximum Counter value can be easily measured by counting \(\overline{\mathrm{IRQ}}\) interrupt requests in the counter \(\overline{\mathrm{IRQ}}\) interrupt routine.

When Counter A decrements from 0000, the Counter A Underflow (IFR4) is set to logic 1. If the Counter A Interrupt Enable Bit (IER4) is also set, an \(\overline{\operatorname{RQ}}\) interrupt request will be generated. The Counter A Underflow bit in the Interrupt Flag Register can be examined in the \(\overline{\mathrm{RQ}}\) interrupt routine to determine that the \(\overline{\mathrm{RQ}}\) was generated by the Counter \(A\) Underflow.

\section*{R6511Q Microprocessor and R6500/13 Microcomputer}

While the timer is operating in the Interval Timer Mode, PA4 operates as a PA I/O bit.

A timing diagram of the Interval Timer Mode is shown in Figure 6-1.

\subsection*{6.1.2 Pulse Generation Mode}

In the Pulse Generation mode, the CA line operates as a Counter Output. The line toggles from low to high or from high to low whenever a Counter A Underflow occurs or a write is performed to address 001A.

The normal output waveform is a symmetrical square-wave. The CA output is initialized high when entering the mode and transitions low when writing to 001A.

Asymmetric waveforms can be generated if the value of the latch is changed after each counter underflow.

A one-shot waveform can be generated by changing from Pulse Generation to Interval Timer mode after only one occurrence of the output toggle condition.

\subsection*{6.1.3 Event Counter Mode}

In this mode the CA is used as an Event Input line, and the Counter will decrement with each rising edge detected on this line. The maximum rate at which this edge can be detected is one-half the \(\phi 2\) clock rate.

The Counter can count up to 65,535 occurrences before underflowing. As in the other modes, the Counter A Underflow bit (IER4) is set to logic 1 if the underflow occurs.

Figure 6.2 is a timing diagram of the Event Counter Mode.


Figure 6-2. Event Counter Mode

\subsection*{6.1.4 Pulse Width Measurement Mode}

This mode allows the accurate measurement of a low pulse duration on the CA line. The Counter decrements by one count at the 02 clock rate as long as the CA line is held in the low state. The Counter is stopped when CA is in the high state.

The Counter A underflow flag will be set only when the count in the timer reaches zero. Upon reaching zero the timer will be loaded with the latch value and continue counting down as long as the CA pin is held low. After the counter is stopped by a high level on CA, the count will hold as long as CA remains high. Any further low levels on CA will again cause the counter to count down from its present value. The state of the CA line can be determined by testing the state of PA4.

A timing diagram for the Pulse Width Measurement Mode is shown in Figure 6.3.


Figure 6-3. Pulse Width Measurement

\subsection*{6.1.5 Serial I/O Data Rate Generation}

Counter A also provides clock timing for the Serial I/O which establishes the data rate for the Serial I/O port. When the Serial I/O is enabled, Counter A is forced to operate at the internal clock rate. Counter \(A\) is not required for the RCVR S/R mode. The Counter I/O (PA4) may also be required to support the Serial I/O (see Table 4-2).

Table 6-1 identifies the values to be loaded in Counter A for selecting standard data rates with a \(\phi 2\) clock rate of 1 MHz and 2 MHz . Although Table 6-1 identifies only the more common data rates, any data rate from 1 to 62.5 K bps can be selected by using the formula:
\[
N=\frac{\phi 2}{16 \times b p s}-1
\]
where
\(\mathrm{N} \quad=\) decimal value to be loaded into Counter A using its hexadecimal equivalent.
\(\phi_{2}=\) the clock frequency ( 1 MHz or 2 MHz )
bps \(=\) the desired data rate .

\section*{NOTE}

In Table 6-1 you will notice that the standard data rate and the actual data rate may be slightly different. Transmitter and receiver errors of \(1.5 \%\) or less are acceptable. A revised clock rate is included in Table 6-1 for those baud rates which fall outside this limit.

Table 6-1. Counter A Values for Baud Rate Selection
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{Standard Baud Rate} & \multicolumn{2}{|l|}{Hexadecimal Value} & \multicolumn{2}{|l|}{Actual Baud Rate At} & \multicolumn{2}{|l|}{Clock Rate Needed To Get Standard Baud Rate} \\
\hline & 1 MHz & 2 MHz & 1 MHz & 2 MHz & 1 MHz & 2 MHz \\
\hline 50 & 04E1 & 09C3 & 50.00 & 50.00 & 1.0000 & 2.0000 \\
\hline 75 & 0340 & 0682 & 75.03 & 74.99 & 1.0000 & 2.0000 \\
\hline 110 & 0237 & 046F & 110.04 & 110.04 & 1.0000 & 2.0000 \\
\hline 150 & 01A0 & 0340 & 149.88 & 150.06 & 1.0000 & 2.0000 \\
\hline 300 & OOCF & 01A0 & 300.48 & 299.76 & 1.0000 & 2.0000 \\
\hline 600 & 0067 & 00CF & 600.96 & 600.96 & 1.0000 & 2.0000 \\
\hline 1200 & 0033 & 0067 & 1201.92 & 1201.92 & 1.0000 & 2.0000 \\
\hline 2400 & 0019 & 0033 & 2403.85 & 2403.85 & 1.0000 & 2.0000 \\
\hline 3600 & 0010 & 0021 & 3676.47 & 3676.47 & 0.9792 & 1.9584 \\
\hline 4800 & 000C & 0019 & 4807.69 & 4807.69 & 1.0000 & 2.0000 \\
\hline 7200 & 0008 & 0010 & 6944.44 & 7352.94 & 1.0368 & 1.9584 \\
\hline 9600 & 0006 & 000C & 8928.57 & 9615.38 & 1.0752 & 2.0000 \\
\hline
\end{tabular}

\subsection*{6.2 COUNTER B}

Counter B consists of a 16-bit counter and two 16-bit latches organized as follows: Lower Counter B (LCB), Upper Counter B (UCB), Lower Latch B (LLB), Upper Latch B (ULB), Lower Latch C (LLC), and Upper Latch C (ULC). Latch C is used only in the asymmetrical pulse generation mode. The counter contains the count of either \(\emptyset 2\) clock pulses or external events depending on the counter mode selected. The contents of Counter B may be read any time by executing a Read at location 001D for the Upper Counter B and at location 001E or 001C for the Lower Counter B. A Read at location 001C also clears the Counter B Underflow Flag.

Latch B contains the counter initialization value and can be loaded at any time by executing a Write to the Upper Latch \(B\) at location 001D and the Lower Latch \(B\) at location 001C. In each case, the contents of the accumulator are copied into the applicable latch register.

Counter B can be initialized at any time by writing to address: 001 E . The contents of the accumulator is copied into the Upper Latch B before the value in the 16-bit Latch B is transferred to Counter B. Counter B will also be set to the latch value and the Counter B Underflow Flag bit (IFR5) will be set to a " 1 " whenever Counter B underflows by decrementing from 0000.

IFR 5 may be cleared by reading the Lower Counter B at location 001C, by writing to address location 001E, or by RES.

Counter B operates in the same manner as Counter A in the Interval Timer and Event Counter modes. The Pulse Width Measurement Mode is replaced by the Retriggerable Interval Timer mode and the Pulse Generation mode is replaced by the Asymmetrical Pulse Generation Mode. Mode Control Register bits MCR2 and MCR3 select the four Counter B modes in a similar manner and coding as MCRO and MCR1 select the modes of Counter A.

\subsection*{6.2.1 Retriggerable Interval Timer Mode}

When operating in the Retriggerable Interval Timer mode, Counter B is initialized to the latch value by writing to address 001E, by a Counter B underflow, or whenever a positive edge -occurs on the CB pin (PA5). The Counter B interrupt flag will be set if the counter underflows before a positive edge occurs on the CB line. Figure 6-4 illustrates the operation.


Figure 6-4. Counter B. Retriggerable Interval Timer Mode

\subsection*{6.2.2 Asymmetrical Pulse Generation Mode}

Counter B has a special Asymmetrical Pulse Generation Mode whereby a pulse train with programmable pulse width and period can be generated without the processor intervention once the latch values are initialized.

In this mode, the 16 -bit Latch \(B\) is initialized with a value which corresponds to the duration between pulses (referred to as \(D\) in the following descriptions). The 16 -bit Latch \(C\) is initialized with a value corresponding to the desired pulse width (referred to as \(P\) in the following descriptions). The initialization sequence for Latch B and C and the starting of a counting sequence are as follows:
1. The lower 8 bits of \(P\) are loaded into LLB by writing to address 001 C ; the upper 8 bits of \(P\) are loaded into ULB and the full 16 bits are transferred to Latch C by writing to address location 001D. At this point both Latch \(B\) and Latch \(C\) contain the value of \(P\).
2. The lower 8 bits of \(D\) are loaded into LLB by writing to address 001C; the upper 8 bits of \(D\) are loaded into ULB by writing to address location 001E. Writing to address location 001E also causes the contents of the 16-bit Latch B to be downloaded into the Counter B and the CB output to go low as shown in Figure 6-5.
3. When Counter \(B\) underflow occurs the contents of the Latch C are loaded into the Counter B and the CB output toggles to a high level, staying high until another underflow occurs. Latch \(B\) is then down-loaded and the CB output toggles to a low level repeating the whole process.

\subsection*{7.1 POWER ON TIMING}

After application of \(\mathrm{V}_{\mathrm{CC}}\) and \(\mathrm{V}_{\mathrm{RB}}\) power to the device, \(\overline{\mathrm{RES}}\) must be held low for at least eight \(\phi 2\) clock cycles after \(\mathrm{V}_{\mathrm{cc}}\) reaches operating range and the internal oscillator has stabilized. This stabilization time is dependent upon the input \(\mathrm{V}_{\mathrm{cc}}\) voltage and performance of the internal oscillator. The clock can be monitored at \(\phi 2\) (pin 3). Figure 7-1 illustrates the power turn-on waveforms. Clock stabilization time is typically 20 ms .


Figure 7-1. Power Turn-On Timing Detail

\subsection*{7.2 POWER-ON RESET}

When \(\overline{\operatorname{RES}}\) goes from low to high, the device sets the Interrupt Mask Bit-bit 2 of the Processor Status Registerand initiates a reset vector fetch at address FFFC and FFFD (or optionally 7FFE and 7FFF) to begin user program execution. All of the I/O ports (PA, PB, PC, PD) will be forced to the high (logic 1) state. All bits of the Control Register will be cleared to logic 0 causing the Interval Timers counter mode (mode 00 ) to be selected and all interrupt enabled bits to be reset.


Figure 6-5. Counter B Pulse Generation

\subsection*{7.3 RESET ( \(\overline{\mathrm{RES}})\) CONDITIONING}

When \(\overline{\mathrm{RES}}\) is driven from low to high the device is put in a reset state causing the registers and I/O ports to be configured as shown in Table 7-1.

Table 7-1. \(\overline{R E S}\) Initialization of I/O Ports and Registers
\begin{tabular}{|l|cccccccc|}
\hline \multicolumn{1}{|c|}{ Bit No. } & \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline REGISTERS & & & & & & & & \\
\(\quad\) Processor Status & \(\mathbf{0}\) & \(\mathbf{-}\) & \(\mathbf{-}\) & - & - & 1 & - & - \\
Mode Control (MCR) & 0 & 0 & 0 & 0 & \(\mathbf{0}\) & 0 & 0 & 0 \\
Int. Enable (IER) & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
Int. Flag (IFR) & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
Ser. Com. Control (SCCR) & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
Ser. Com. Status (SCSR) & 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 \\
PORTS & & & & & & & & \\
PA Latch & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\
PB Latch & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\
PC Latch & 1 & \(\mathbf{1}\) & 1 & 1 & 1 & 1 & 1 & 1 \\
PD Latch & \(\mathbf{1}\) & \(\mathbf{1}\) & \(\mathbf{1}\) & \(\mathbf{1}\) & 1 & 1 & 1 & 1 \\
\hline
\end{tabular}

All RAM and other CPU registers will initialize in a random, non-repeatable data pattern.

\subsection*{7.4 INITIALIZATION}

Any initialization process for the device should include a RES, as indicated in the preceeding paragraphs. After stabilization of the internal clock (if a power on situation) an initialization subroutine should be executed to perform (as a minimum) the following functions:
1. The Stack Pointer should be set
2. Clear or Set Decimal Mode
3. Set or Clear Carry Flag
4. Set up Mode Controls as required
5. Clear Interrupts

A typical initialization subroutine could be as follows:
\begin{tabular}{ll} 
LDX & \begin{tabular}{l} 
Load stack pointer starting address into \\
X Register
\end{tabular} \\
TXS & Transfer X Register value to Stack Pointer \\
CLD & Clear Decimal Mode \\
SEC & Set Carry Flag \\
\(\ldots\). & Set-up Mode Control and \\
\(\ldots\). & special function registers \\
\(\ldots\). & and clear RAM as required \\
CLI & Clear Interrupts
\end{tabular}

\title{
APPENDIX A \\ ENHANCED R6502 INSTRUCTION SET
}

This appendix contains a summary of the Enhanced R6502 instruction set. For detailed information, consult the R6502 Microcomputer System Programming Manual, Document 29650 N30. The four instructions notated with a * are added instructions to enhance the standard 6502 instruction set.

\section*{A. 1 INSTRUCTION SET IN ALPHABETIC SEQUENCE}
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Instruction & Mnemonic & Instruction \\
\hline ADC & Add Memory to Accumulator with Carry & LDA & Load Accumulator with Memory \\
\hline AND & "AND" Memory with Accumulator & LDX & Load Index X with Memory \\
\hline \multirow[t]{2}{*}{ASL} & \multirow[t]{2}{*}{Shift Left One Bit (Memory or Accumulator)} & LDY & Load Index Y with Memory \\
\hline & & \multirow[t]{3}{*}{LSR} & Shift One Bit Right (Memory or \\
\hline *BBR & Branch on Bit Reset Relative & & Accumulator) \\
\hline *BBS & Branch on Bit Set Relative & & \\
\hline BCC & Branch on Carry Clear & NOP & No Operation \\
\hline BCS & Branch on Carry Set & & \\
\hline BEQ & Branch on Result Zero & ORA & "OR" Memory with Accumulator \\
\hline BIT & Test Bits in Memory with Accumulator & & \\
\hline BMI & Branch on Result Minus & PHA & Push Accumulator on Stack \\
\hline BNE & Branch on Result not Zero & PHP & Push Processor Status on Stack \\
\hline BPL & Branch on Result Plus & PLA & Pull Accumulator from Stack \\
\hline BRK & Force Break & PLP & Pull Processor Status from Stack \\
\hline BVC & Branch on Overflow Clear & & \\
\hline \multirow[t]{2}{*}{BVS} & \multirow[t]{2}{*}{Branch on Overflow Set} & *RMB & Reset Memory Bit \\
\hline & & ROL & Rotate One Bit Left (Memory or \\
\hline CLC & Clear Carry Flag & & Accumulator) \\
\hline CLD & Clear Decimal Mode & ROR & Rotate One Bit Right (Memory or \\
\hline CLI & Clear Interrupt Disable Bit & & Accumulator) \\
\hline CLV & Clear Overflow Flag & RTI & Return from Interrupt \\
\hline CMP & Compare Memory and Accumulator & RTS & Return from Subroutine \\
\hline CPX & Compare Memory and Index \(X\) & & \\
\hline CPY & Compare Memory and Index Y & SBC & Subtract Memory from Accumulator with Borrow \\
\hline DEC & Decrement Memory by One & SEC & Set Carry Flag \\
\hline DEX & Decrement Index X by One & SED & Set Decimal Mode \\
\hline \multirow[t]{2}{*}{DEY} & \multirow[t]{2}{*}{Decrement Index Y by One} & SEI & Set Interrupt Disable Status \\
\hline & & *SMB & Set Memory Bit \\
\hline \multirow[t]{3}{*}{EOR} & "Exclusive-Or" Memory with & STA & Store Accumulator in Memory \\
\hline & \multirow[t]{2}{*}{Accumulator} & STX & Store Index X in Memory \\
\hline & & STY & Store Index \(Y\) in Memory \\
\hline INC & Increment Memory by One & & \\
\hline INX & Increment Index X by One & TAX & Transfer Accumulator to Index X \\
\hline INY & Increment Index X by One & TAY & Transfer Accumulator to Index Y \\
\hline & & TSX & Transfer Stack Pointer to Index X \\
\hline JMP & Jump to New Location & TXA & Transfer Index X to Accumulator \\
\hline JSR & Jump to New Location Saving Return Address & TXS TYA & Transfer Index X to Stack Register Transfer Index \(Y\) to Accumulator \\
\hline
\end{tabular}


\section*{A. 3 INSTRUCTION CODE MATRIX}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline - & SD & 1 & 2 & 3 & 4 & 5 & 6 & 7 & 8 & 9 & A & B & C & D & E & F & \\
\hline \(\sum{ }_{0}\) & BRK Implied 17 & \[
\begin{gathered}
\text { ORA } \\
\text { (INE, X) } \\
266
\end{gathered}
\] & & & & \[
\begin{aligned}
& \text { ORA } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { ASL } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & \[
\begin{aligned}
& \text { RMBO } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & PrfP Implied 13 & \[
\begin{aligned}
& \text { ORA } \\
& \text { IMM } \\
& 22
\end{aligned}
\] & \begin{tabular}{l}
ASL \\
Accum \\
12
\end{tabular} & & & \begin{tabular}{l}
ORA ABS \\
34
\end{tabular} & \[
\begin{aligned}
& \text { ASL } \\
& \text { ABS } \\
& 36
\end{aligned}
\] & \[
\begin{gathered}
\mathrm{BBRO} \\
\mathrm{ZP} \\
3 \quad 5^{\prime *}
\end{gathered}
\] & 0 \\
\hline 1 & \begin{tabular}{l}
BPL \\
Relative 2 2**
\end{tabular} &  & & & & \[
\begin{aligned}
& \text { ORA } \\
& \text { ZP, X } \\
& 24
\end{aligned}
\] & \[
\begin{gathered}
\hline \text { ASL } \\
\text { ZP, } \mathrm{X} \\
2 \quad 6 \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
\text { RMB1 } \\
\text { ZP } \\
2 \quad 5
\end{gathered}
\] & \[
\begin{array}{|c|}
\hline \text { CLC } \\
\text { Implied } \\
12 \\
\hline
\end{array}
\] &  & & & & \[
\begin{aligned}
& \text { ORA } \\
& \begin{array}{c}
\text { ABS, } X \\
344^{*}
\end{array}
\end{aligned}
\] &  & \[
\begin{array}{|c|}
\hline \text { BBR1 } \\
\text { ZP } \\
3 \quad 5 *
\end{array}
\] & 1 \\
\hline 2 & \begin{tabular}{c} 
JSR \\
Absolute \\
3 \\
\hline
\end{tabular} &  & & & \[
\begin{aligned}
& \mathrm{BIT} \\
& \mathrm{ZP} \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { AND } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{ROL} \\
& \mathrm{ZP} \\
& 2 \quad 5
\end{aligned}
\] & \[
\begin{aligned}
& \text { RMB2 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & PLP Implied 1.4 & \[
\begin{aligned}
& \text { AND } \\
& \text { IMM } \\
& 22
\end{aligned}
\] & ROL Accum 12 & & \begin{tabular}{l}
BIT \\
ABS \\
34
\end{tabular} & \begin{tabular}{l}
AND \\
ABS \\
34
\end{tabular} & \[
\begin{aligned}
& \text { ROL } \\
& \text { ABS } \\
& 3 \quad 6
\end{aligned}
\] & \[
\begin{aligned}
& \text { BBR2 } \\
& \text { ZP } \\
& 35^{* *}
\end{aligned}
\] & 2 \\
\hline 3 &  & AND
(IND, Y)
\(25^{\circ}\) & & & & \[
\begin{gathered}
\text { AND } \\
\text { ZP, } X \\
2 \quad 4 \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
\mathrm{ROL} \\
\mathrm{ZP}, \mathrm{x} \\
2 \quad 6 \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
\text { RMB3 } \\
\text { ZP } \\
2 \quad 5 \\
\hline
\end{gathered}
\] & SEC Implied 12 &  & & & & \[
\begin{aligned}
& \text { AND } \\
& \begin{array}{c}
\text { ABS, } X \\
3 \\
3
\end{array}
\end{aligned}
\] & \[
\begin{gathered}
\mathrm{ROL} \\
\mathrm{ABS}, \mathrm{x} \\
3 \quad 7
\end{gathered}
\] & \[
\begin{gathered}
\text { BBR3 } \\
\text { ZP } \\
3 \quad 5^{*}
\end{gathered}
\] & 3 \\
\hline 4 & RTI Implied 16 & \[
\begin{gathered}
\text { EOR } \\
\text { (IND, X) } \\
266
\end{gathered}
\] & & & & \[
\begin{aligned}
& \text { EOR } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { LSR } \\
& \text { ZP } \\
& 2 \quad 5 \\
& \hline
\end{aligned}
\] & \[
\begin{gathered}
\text { RMB4 } \\
\text { ZP } \\
2 \quad 5 \\
\hline
\end{gathered}
\] & PHA Implied 13 & \[
\begin{aligned}
& \text { EOR } \\
& \text { IMM } \\
& 2 \quad 2 \\
& \hline
\end{aligned}
\] & LSR Accum 12 & & \[
\begin{aligned}
& \text { JMP } \\
& \text { ABS } \\
& 3 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { EOR } \\
& \text { ABS } \\
& 34
\end{aligned}
\] & \[
\begin{aligned}
& \text { LSR } \\
& \text { ABS } \\
& 3 \quad 6 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { BBR4 } \\
& \text { ZP } \\
& 3 \quad 5 * \\
& \hline
\end{aligned}
\] & 4 \\
\hline 5 &  &  & & & & \[
\begin{gathered}
\text { EOR } \\
\text { ZP, X } \\
24
\end{gathered}
\] & \[
\begin{gathered}
\text { LSR } \\
\text { ZP, X } \\
26
\end{gathered}
\] & \[
\begin{aligned}
& \text { RMB5 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & \[
\begin{aligned}
& \text { CLI } \\
& \text { Implied }
\end{aligned}
\]
\[
12
\] & \[
\begin{aligned}
& \text { EOR } \\
& \text { ABS, Y } \\
& 344^{*}
\end{aligned}
\] & & & & \[
\begin{aligned}
& \text { EOR } \\
& \text { ABS, } X \\
& 3 \quad 4^{*}
\end{aligned}
\] & \[
\begin{aligned}
& \text { LSR } \\
& \text { ABS, } X \\
& 37
\end{aligned}
\] & \[
\begin{aligned}
& \text { BBR5 } \\
& \text { ZP } \\
& 3^{* * *}
\end{aligned}
\] & 5 \\
\hline 6 & RTS Implied 16 &  & & & & \[
\begin{aligned}
& \text { ADC } \\
& Z \mathrm{ZP} \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { ROR } \\
& \text { ZP } \\
& 25
\end{aligned}
\] & \[
\begin{aligned}
& \text { RMB6 } \\
& Z P \\
& 2 \quad 5
\end{aligned}
\] & \[
\begin{gathered}
\text { PLA } \\
\text { Implied } \\
144
\end{gathered}
\] & \[
\begin{aligned}
& \text { ADC } \\
& \text { IMM } \\
& 22
\end{aligned}
\] & ROR Accum 12 & & \[
\left. \right\rvert\,
\] & ADC ABS 34 & \[
\begin{aligned}
& \text { ROR } \\
& \text { ABS } \\
& 36
\end{aligned}
\] & \[
\begin{gathered}
\text { BBR6 } \\
\text { ZP } \\
5^{* *}
\end{gathered}
\] & 6 \\
\hline 7 & \begin{tabular}{l}
BVS \\
Relative \\
2 2**
\end{tabular} & \[
\begin{array}{|c|}
\hline \text { ADC } \\
(\text { IND, Y) } \\
2 \quad 5^{*} \\
\hline
\end{array}
\] & & & & ADC ZP, X
\(\qquad\) & \[
\begin{gathered}
\text { ROR } \\
\text { ZP, } x \\
26
\end{gathered}
\] & \[
\begin{aligned}
& \text { RMB7 } \\
& \text { ZP } \\
& 25
\end{aligned}
\] & SEI Implied 12 & \[
\begin{gathered}
A D C \\
A B S, Y \\
344^{*}
\end{gathered}
\] & & & & ADC ABS, \(X\) 3 4* &  & \[
\begin{aligned}
& \text { BBR7 } \\
& \text { ZP } \\
& 3 \text { 5** }
\end{aligned}
\] & 7 \\
\hline 8 & &  & & & \[
\begin{aligned}
& \text { STY } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { STA } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { STX } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { SMBO } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & DEY Implied 12 & & TXA Implied 12 & & \[
\begin{aligned}
& \text { STY } \\
& \text { ABS } \\
& 34
\end{aligned}
\] & \[
\begin{aligned}
& \text { STA } \\
& \text { ABS } \\
& 34
\end{aligned}
\] & \[
\begin{aligned}
& \text { STX } \\
& \text { ABS } \\
& 34
\end{aligned}
\] & \[
\begin{aligned}
& \text { BBSO } \\
& \text { ZP } \\
& 3 \quad 5^{* *}
\end{aligned}
\] & 8 \\
\hline 9 &  & \[
\begin{gathered}
\text { STA } \\
\text { (IND, Y) } \\
266
\end{gathered}
\] & & & \[
\begin{gathered}
\text { STY } \\
\text { ZP, } X \\
2 \quad 4 \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
\text { STA } \\
\text { ZP, X } \\
24 \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
\text { STX } \\
Z P, Y \\
2 \quad 4 \\
\hline
\end{gathered}
\] & \[
\begin{aligned}
& \text { SMB1 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & TYA Implied 12 &  &  & & & STA ABS, \(X\) 35 & & \[
\begin{array}{|c|}
\hline \text { BBS1 } \\
\text { ZP } \\
3 \quad 5 " \\
\hline
\end{array}
\] & 9 \\
\hline A & \[
\begin{aligned}
& \text { LDY } \\
& \text { IMM } \\
& 22
\end{aligned}
\] & \[
\begin{array}{|c|}
\hline \text { LDA } \\
(\text { IND, X) } \\
26
\end{array}
\] & \[
\begin{aligned}
& \text { LDX } \\
& \text { IMM } \\
& 22
\end{aligned}
\] & & \[
\begin{aligned}
& \text { LDY } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { LDA } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { LDX } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { SMB2 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & TAY Implied 12 & \[
\begin{aligned}
& \text { LDA } \\
& \text { IMM } \\
& 22
\end{aligned}
\] & TAX
Implied
\(1 \quad 2\) & & \[
\begin{aligned}
& \text { LDY } \\
& \text { ABS } \\
& 34
\end{aligned}
\] & \[
\begin{aligned}
& \text { LDA } \\
& \text { ABS } \\
& 34
\end{aligned}
\] & \[
\begin{aligned}
& \text { LDX } \\
& \text { ABS } \\
& 3 \quad 4
\end{aligned}
\] & \[
\begin{array}{|c|c|}
\text { BBS2 } \\
\text { ZP } \\
3 & 5{ }^{\prime \prime}
\end{array}
\] & A \\
\hline B & \begin{tabular}{l}
BCS \\
Relative 2 2**
\end{tabular} & \[
\begin{array}{|c}
\text { LDA } \\
(\text { IND }), Y \\
2 \quad 5^{*}
\end{array}
\] & & & \[
\begin{aligned}
& \text { LDY } \\
& \text { ZP, } x \\
& 24
\end{aligned}
\] & \[
\begin{aligned}
& \text { LDA } \\
& \text { ZP, } \mathrm{X} \\
& 24
\end{aligned}
\] & \[
\begin{aligned}
& \text { LDX } \\
& \text { ZP, Y } \\
& 24
\end{aligned}
\] & \[
\begin{aligned}
& \text { SMB3 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & CLV Implied 12 &  & TSX Implied 12 & &  &  &  & \[
\begin{array}{|c}
\hline \text { BBS3 } \\
\text { ZP } \\
3 \quad 5 * * \\
\hline
\end{array}
\] & B \\
\hline C & \[
\begin{aligned}
& \text { CPY } \\
& \text { IMM } \\
& 22
\end{aligned}
\] & \[
\begin{gathered}
\text { CMP } \\
(\text { IND, } \mathrm{X}) \\
26
\end{gathered}
\] & & & \[
\begin{aligned}
& \text { CPY } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { CMP } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { DEC } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & \[
\begin{aligned}
& \text { SMB4 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & INY Implied 12 & \[
\begin{aligned}
& \text { CMP } \\
& \text { IMM } \\
& 22
\end{aligned}
\] & \[
\begin{array}{|c|}
\hline \text { DEX } \\
\text { Implied } \\
1 \quad 2
\end{array}
\] & & \begin{tabular}{l}
CPY \\
ABS \\
34
\end{tabular} & \[
\begin{aligned}
& \text { CMP } \\
& \text { ABS } \\
& 3 \quad 4
\end{aligned}
\] & \[
\begin{aligned}
& \text { DEC } \\
& \text { ABS } \\
& 36
\end{aligned}
\] & \[
\begin{gathered}
\text { BBS4 } \\
\text { ZP } \\
3 \quad 5^{* *}
\end{gathered}
\] & C \\
\hline D & BNE Relative 2 2** & \[
\left.\begin{array}{|c}
\text { CMP } \\
\text { (IND), Y } \\
25^{*}
\end{array} \right\rvert\,
\] & & & & \[
\begin{aligned}
& \text { CMP } \\
& \text { ZP, X } \\
& 24
\end{aligned}
\] & \[
\begin{gathered}
\hline \text { DEC } \\
\text { ZP, } X \\
2 \quad 6 \\
\hline
\end{gathered}
\] & \[
\begin{aligned}
& \text { SMB5 } \\
& \text { ZP } \\
& 2 \quad 5 \\
& \hline
\end{aligned}
\] & CLD Implied 12 &  & & & & \[
\begin{gathered}
\text { CMP } \\
\text { ABS, } x \\
3 \quad 4^{*}
\end{gathered}
\] &  & \[
\begin{array}{|c}
\hline \text { BBS5 } \\
\text { ZP } \\
3 \quad 5^{*} \\
\hline
\end{array}
\] & D \\
\hline E & \[
\begin{aligned}
& \text { CPX } \\
& \text { IMM } \\
& 22
\end{aligned}
\] & \[
\begin{array}{|c|}
\hline \text { SBC } \\
(\text { IND, } X) \\
26
\end{array}
\] & & & \[
\begin{aligned}
& C P X \\
& Z P \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{SBC} \\
& \mathrm{ZP} \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { INC } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & \[
\begin{aligned}
& \text { SMB6 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & INX Implied 12 & \[
\begin{aligned}
& \text { SBC } \\
& \text { IMM } \\
& 22
\end{aligned}
\] & NOP Implied 12 & & \[
\begin{aligned}
& C P X \\
& \text { ABS } \\
& 3 \quad 4
\end{aligned}
\] & \[
\begin{aligned}
& \text { SBC } \\
& \text { ABS } \\
& 3 \quad 4
\end{aligned}
\] & \[
\begin{aligned}
& \text { INC } \\
& \text { ABS }
\end{aligned}
\]
\[
36
\] & \[
\begin{array}{|c}
\text { BBS6 } \\
\text { ZP } \\
3 \quad 5^{* *}
\end{array}
\] & E \\
\hline F & \begin{tabular}{l}
BEQ \\
Relative 2 2**
\end{tabular} & SBC
\begin{tabular}{cc}
2 \\
(IND), Y \\
2 & \(5^{*}\)
\end{tabular}\(|\) & & & & \[
\begin{gathered}
\text { SBC } \\
\text { ZP, X } \\
24 \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
\text { INC } \\
\text { ZP, X } \\
26
\end{gathered}
\] & \[
\begin{aligned}
& \text { SMB7 } \\
& \text { ZP } \\
& 2 \quad 5 \\
& \hline
\end{aligned}
\] & SED Implied 12 &  & & & & SBC ABS, \(X\) 3 4* &  & \[
\begin{array}{|c}
\mathrm{BBS7} \\
\mathrm{ZP} \\
3 \quad 5^{*}
\end{array}
\] & F \\
\hline & 0 & 1 & 2 & 3 & 4 & 5 & 6 & 7 & 8 & 9 & A & B & C & D & E & F & \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|}
\hline \multicolumn{2}{|r|}{0} & \\
\hline & BRK & -OP Code \\
\hline 0 & Implied & -Addressing Mode \\
\hline & 17 & -Instruction Bytes; Machine Cycles \\
\hline
\end{tabular}

\footnotetext{
*Add 1 to N if page boundary is crossed.
**Add 1 to N if branch occurs to same page; add 2 to N if branch occurs to different page.
}

\section*{APPENDIX B KEY REGISTER SUMMARY}


CPU Registers


Serial Communications Control Register


Processor Status Register


Interrupt Enable and Flag Registers


Serial Communications Status Register

\section*{APPENDIX C \\ ADDRESS ASSIGNMENTS/MEMORY MAPS/PIN FUNCTIONS}

\section*{C. 1 I/O AND INTERNAL REGISTER ADDRESSES}
\begin{tabular}{|c|c|c|}
\hline \begin{tabular}{l}
ADDRESS \\
(HEX)
\end{tabular} & READ & WRITE \\
\hline \[
\begin{array}{r}
001 \mathrm{~F} \\
1 \mathrm{E} \\
1 \mathrm{D} \\
1 \mathrm{C}
\end{array}
\] & \begin{tabular}{l}
Lower Counter B \\
Upper Counter B Lower Counter B, CLR Flag
\end{tabular} & Upper Latch B, Cntr B \(\leftarrow\) Latch B, CLR Flag Upper Latch B, Latch C \(\leftarrow\) Latch B Lower Latch B. \\
\hline \[
\begin{aligned}
& 1 B \\
& 1 \mathrm{~A} \\
& 19 \\
& 18
\end{aligned}
\] & \begin{tabular}{l}
Lower Counter A \\
Upper Counter A \\
Lower Counter A, CLR Flag
\end{tabular} & Upper Latch A, Cntr A \(\leftarrow\) Latch A, CLR Flag Upper Latch A Lower Latch A \\
\hline \[
\begin{aligned}
& 17 \\
& 16 \\
& 15 \\
& 14
\end{aligned}
\] & Serial Receiver Data Register Serial Comm. Status Register Serial Comm. Control Register Mode Control Register & \begin{tabular}{l}
Serial Transmitter Data Register \\
Serial Comm. Status Reg. Bits 4 \& 5 only \\
Serial Comm. Control Register \\
Mode Control Register
\end{tabular} \\
\hline \[
\begin{array}{r}
13 \\
12 \\
11 \\
0010
\end{array}
\] & Interrupt Enable Register Interrupt Flag Register Read FF & \begin{tabular}{l}
Interrupt Enable Register \\
Clear Int Flag (Bits 0-3 only, Write 0's only)
\end{tabular} \\
\hline \[
\begin{aligned}
& O F \\
& O E \\
& O D \\
& O C
\end{aligned}
\] & \multicolumn{2}{|l|}{\multirow{3}{*}{\begin{tabular}{l}
RESERVED \\
These addresses are reserved and are used by the CPU during Read and Write operation over the external Data Bus (D0-D7).
\end{tabular}}} \\
\hline \[
\begin{aligned}
& 0 B \\
& 0 A \\
& 09 \\
& 08
\end{aligned}
\] & & \\
\hline \[
\begin{aligned}
& 07 \\
& 06 \\
& 05 \\
& 04
\end{aligned}
\] & & \\
\hline \[
\begin{array}{r}
03 \\
02 \\
01 \\
0000
\end{array}
\] & \begin{tabular}{l}
Port D \\
Port C \\
Port B \\
Port A
\end{tabular} & \begin{tabular}{l}
Port D \\
Port C \\
Port B \\
Port A
\end{tabular} \\
\hline
\end{tabular}

\section*{C. 2 FULL ADDRESS MODE MEMORY MAP R6511Q OR R6500/13}

\section*{C. 3 FULL ADDRESS MODE MEMORY MAP R6500/13 ONLY}

C. 4 MULTIPLE FUNCTION PIN ASSIGNMENTS—PORT C AND PORT D
\begin{tabular}{|c|c|c|c|c|}
\hline PIN NUMBER & FULL ADDRESS MODE & I/O PORT FUNCTION & ABBREVIATED PORT FUNCTION & MULTIPLEXED PORT FUNCTION \\
\hline 54 & PCO & PCO & AO & AO \\
\hline 55 & PC1 & PC1 & A1 & A1 \\
\hline 56 & PC2 & PC2 & A2 & A2 \\
\hline 57 & PC3 & PC3 & A3 & A3 \\
\hline 58 & PC4 & PC4 & A12 & A12 \\
\hline 59 & PC5 & PC5 & R/W & R/W \\
\hline 60 & A13 & PC6 & A13 & A13 \\
\hline 61 & A14 & PC7 & EMS & EMS \\
\hline 62 & PDO & PDO & D0 & A4/D0 \\
\hline 63 & PD1 & PD1 & D1 & A5/D1 \\
\hline 64 & PD2 & PD2 & D2 & A6/D2 \\
\hline 1 & PD3 & PD3 & D3 & A7/D3 \\
\hline 2 & PD4 & PD4 & D4 & A8/D4 \\
\hline 3 & PD5 & PD5 & D5 & A9/D5 \\
\hline 4 & PD6 & PD6 & D6 & A10/D6 \\
\hline 5 & PD7 & PD7 & D7 & A11/D7 \\
\hline
\end{tabular}

\title{
APPENDIX D ELECTRICAL SPECIFICATIONS
}

MAXIMUM RATINGS*
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}} \& \mathrm{~V}_{\mathrm{RR}}\) & -0.3 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to +7.0 & Vdc \\
\hline \begin{tabular}{l} 
Operating Temperature \\
Commercial \\
Industrial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{c}
\(\mathrm{T}_{\mathrm{L}}\) to \(\mathrm{T}_{\mathrm{H}}\) \\
0 to +70 \\
-40 to +85
\end{tabular} & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\mathrm{STG}}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}
\(\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{RR}}=\mathrm{V}_{\mathrm{CC}} ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{A}}=0^{\circ}\right.\) to \(70^{\circ}\), unless otherwise specified)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ \({ }^{1}\) & Max & Unit & Test Conditions \\
\hline RAM Standby Voltage (Retention Mode) & \(\mathrm{V}_{\text {RR }}\) & 3.0 & & \(\mathrm{V}_{\mathrm{cc}}\) & V & \\
\hline RAM Standby Current (Retention Mode) Commercial Industrial & \(\mathrm{I}_{\mathrm{RR}}\) & - & \[
\begin{aligned}
& 4 \\
& 5.2
\end{aligned}
\] & - & mA & \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) \\
\hline \begin{tabular}{l}
Input High Voltage \\
All Except XTLI and \(\emptyset 2\) in Slave Option XTLI and \(\emptyset 2\) in Slave Option
\end{tabular} & \(\mathrm{V}_{\mathrm{IH}}\) & \[
\begin{aligned}
& +2.0 \\
& +4.0
\end{aligned}
\] & - & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{cc}} \\
& \mathrm{v}_{\mathrm{cc}} \\
& \hline
\end{aligned}
\] & V & \\
\hline Input Low Voltage & \(\mathrm{V}_{\text {IL }}\) & -0.3 & - & +0.8 & V & \\
\hline Input Leakage Current \(\overline{R E S}, \overline{\text { NMI }}\) & \(\mathrm{I}_{\mathrm{N}}\) & - & - & \(\pm 10.0\) & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{IN}}=0\) to 5.0 V \\
\hline Input Low Current PA, PB, PC, PD & \(I_{\text {IL }}\) & - & -1.0 & -1.6 & mA & \(\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V}\) \\
\hline Output High Voltage (Except XTLO) & \(\mathrm{V}_{\mathrm{OH}}\) & +2.4 & - & \(\mathrm{V}_{\mathrm{Cc}}\) & V & \(\mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A}\) \\
\hline Output Low Voltage & \(\mathrm{V}_{\mathrm{OL}}\) & - & - & +0.4 & V & \(\mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA}\) \\
\hline \[
\begin{aligned}
& \text { I/O Port Pull-Up Resistance } \\
& \text { PA0-PA7, PB0-PB7, PC0-PC7 }
\end{aligned}
\] & \(\mathrm{R}_{\mathrm{L}}\) & 3.0 & 6.0 & 11.5 & Kohm & \\
\hline Output Leakage Current (Three-State Off) & Iout & - & - & \(\pm 10\) & \(\mu \mathrm{A}\) & \\
\hline Input Capacitance XTLI, XTLO All Others & \(\mathrm{C}_{\text {IN }}\) & - & - & \[
\begin{aligned}
& 50 \\
& 10
\end{aligned}
\] & pF & \[
\begin{aligned}
& T_{A}=25^{\circ} \mathrm{C} \\
& V_{\mathrm{IN}}=0 \mathrm{~V} \\
& \mathrm{f}=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Output Capacitance (Three-State Off) & \(\mathrm{C}_{\text {OUT }}\) & - & - & 10 & pF & \[
\begin{aligned}
& \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\
& \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\
& \mathrm{f}=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Power Dissipation (Outputs High) Commercial Industrial & \(\mathrm{P}_{\mathrm{D}}\) & - & \[
\begin{array}{r}
750 \\
-
\end{array}
\] & \[
\begin{aligned}
& 1100 \\
& 1200
\end{aligned}
\] & mW & \(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}

\section*{Notes:}
1. Typical values measured at \(T_{A}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\).
2. Negative sign indicates outward current flow, positive indicates inward flow.

\section*{APPENDIX E \\ TIMING REQUIREMENTS AND CHARACTERISTICS}

\section*{E. 1 GENERAL NOTES}
1. \(\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \pm 5 \%, 0^{\circ} \mathrm{C} \leqslant T A \leqslant 70^{\circ} \mathrm{C}\)
2. A valid \(\mathrm{V}_{\mathrm{Cc}} / \overline{\mathrm{RES}}\) sequence is required before proper operation is achieved.
3. All timing reference levels are 0.8 V and 2.0 V , unless otherwise specified.
4. All time units are nanoseconds, unless otherwise specified.
5. All capacitive loading is 130 pf maximum, except as noted below:
\[
\begin{array}{lll}
\text { PA, PB } & \text { - } & \text { 50pf maximum } \\
\text { PC (I/O Modes Only) } & -50 p f \text { maximum } \\
\text { PC (ABB and Mux Mode) } & -130 \mathrm{pf} \text { maximum } \\
\text { PC6, PC7 (Full Address Mode) } & -130 \mathrm{pf} \text { maximum }
\end{array}
\]

\section*{E. 2 CLOCK TIMING}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{SYMBOL} & \multirow[b]{2}{*}{PARAMETER} & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline Tcrc & Cycle Time & 1000 & \(10 \mu \mathrm{~s}\) & 500 & \(10 \mu \mathrm{~s}\) \\
\hline \(\mathrm{T}_{\text {Pwx1 }}\) & XTLI Input Clock Pulse Width XTLO = VSS & \[
\begin{aligned}
& 500 \\
& \pm 25
\end{aligned}
\] & - & \[
\begin{aligned}
& 250 \\
& \pm 10
\end{aligned}
\] & - \\
\hline \(\mathrm{T}_{\text {Pwoz }}\) & Output Clock Pulse Width at Minimum \(\mathrm{T}_{\mathrm{crc}}\) & \(\mathrm{T}_{\text {Pwx }}\) & \[
\begin{aligned}
& \mathrm{T}_{\mathrm{pwx} 1} \\
& \pm 25
\end{aligned}
\] & \(\mathrm{T}_{\text {Pwx } 1}\) & \[
\begin{aligned}
& T_{P w \times 1} \\
& \pm 20
\end{aligned}
\] \\
\hline \(\mathrm{T}_{\mathrm{B}}, \mathrm{T}_{\mathrm{F}}\) & Output Clock Rise, Fall Time & - & 25 & - & 15 \\
\hline \(\mathrm{T}_{\text {IR }}, \mathrm{T}_{\text {IF }}\) & Input Clock Rise, Fall Time & - & 10 & - & 10 \\
\hline
\end{tabular}
6. Example of External Chip Select (Multiplexed Bus)


Note that both EMS and Phase \(2\left(\phi_{2}\right)\) must be used to correctly enable the chip selects in the multiplexed or abbreviated bus modes.


\section*{R6511Q Microprocessor and R6500/13 Microcomputer}

\section*{E. 3 ABBREVIATED MODE TIMING-PC AND PD}
(MCR \(5=1\), MCR \(6=0\), MCR \(7=1\) )
\begin{tabular}{|l|l|c|c|c|c|}
\hline \multirow{2}{*}{ SYMBOL } & \multirow{2}{|c|}{ PARAMETER } & \multicolumn{2}{|c|}{\(\mathbf{1}\) MHz } & \multicolumn{2}{|c|}{\(\mathbf{2 ~ M H z}\)} \\
\cline { 3 - 6 } & & MIN & MAX & MIN & MAX \\
\hline\(T_{\text {PCRS }}\) & (PC5) R/W Setup Time & - & 225 & - & 140 \\
\hline\(T_{\text {PCAS }}\) & (PC0-PC4, PC6) Address Setup Time & - & 225 & - & 140 \\
\hline\(T_{\text {PBSU }}\) & (PD) Data Setup Time & 50 & - & 35 & - \\
\hline\(T_{\text {PBHR }}\) & (PD) Data Read Hold Time & 10 & - & 10 & - \\
\hline\(T_{\text {PBHW }}\) & (PD) Data Write Hold Time & 30 & - & 30 & - \\
\hline\(T_{\text {PBOD }}\) & (PD) Data Output Delay & - & 175 & - & 150 \\
\hline\(T_{\text {PCHA }}\) & (PC0-PC4, PC6) Address Hold Time & 30 & - & 30 & - \\
\hline\(T_{\text {PCHR }}\) & (PC5) R/W Hold Time & 30 & - & 30 & - \\
\hline\(T_{\text {PCHV }}\) & (PC7) EMS Hold Time & 10 & - & 10 & - \\
\hline\(T_{\text {PCVP }}\) & (PC7) EMS Stabilization Time & 30 & - & 30 & - \\
\hline\(T_{\text {ESU }}\) & \(\overline{E M S}\) Setup Time & - & 350 & - & 210 \\
\hline
\end{tabular}

\section*{E.3.1 Abbreviated Mode Timing Diagram}


\section*{R6511Q Microprocessor and R6500/13 Microcomputer}

\section*{E. 4 MULTIPLEXED MODE TIMING—PC AND PD}
(MCR \(5=1\), MCR \(6=1\), MCR \(7=1\) )
\begin{tabular}{|l|l|c|c|c|c|}
\hline \multirow{2}{*}{ SYMBOL } & \multicolumn{1}{|c|}{ PARAMETER } & \multicolumn{2}{|c|}{\(\mathbf{1} \mathbf{M H z}\)} & \multicolumn{2}{|c|}{\(\mathbf{2 ~ M H z}\)} \\
\cline { 3 - 6 } & & MIN & MAX & MIN & MAX \\
\hline\(T_{\text {PCRS }}\) & (PC5) R/W Setup Time & - & 225 & - & 140 \\
\hline\(T_{\text {PCAS }}\) & (PC0-PC4, PC6) Address Setup Time & - & 225 & - & 140 \\
\hline\(T_{\text {PBAS }}\) & (PD) Address Setup Time & - & 225 & - & 140 \\
\hline\(T_{\text {PBSU }}\) & (PD) Data Setup Time & 50 & - & 35 & - \\
\hline\(T_{\text {PBHR }}\) & (PD) Data Read Hold Time & 10 & - & 10 & - \\
\hline\(T_{\text {PBHW }}\) & (PD) Data Write Hold Time & 30 & - & 30 & - \\
\hline\(T_{\text {PBDD }}\) & (PD) Data Output Delay & - & 175 & - & 150 \\
\hline\(T_{\text {PCHA }}\) & (PC0-PC4, PC6) Address Hold Time & 30 & - & 30 & - \\
\hline\(T_{\text {PBHA }}\) & (PD) Address Hold Time & 10 & 100 & 10 & 80 \\
\hline\(T_{\text {PCHR }}\) & (PC5) R/W Hold Time & 30 & - & 30 & - \\
\hline\(T_{\text {PCHV }}\) & (PC7) \(\overline{\text { EMS Hold Time }}\) & 10 & - & 10 & - \\
\hline\(T_{\text {PCVD }}{ }^{\text {(1) }}\) & (PC7) Address to EMS Delay Time & 30 & & 30 & \\
\hline\(T_{\text {PCVP }}\) & (PC7) \(\overline{\text { EMS Stabilization Time }}\) & 30 & - & 30 & - \\
\hline\(T_{\text {ESU }}\) & EMS Setup Time & - & 350 & - & 210 \\
\hline NOTE 1: Values assume PC0-PC4, PC6 and PC7 have the same capacitive load. & \\
\hline
\end{tabular}

\section*{E.4.1 Multiplex Mode Timing Diagram}


R6511Q Microprocessor and R6500/13 Microcomputer

\section*{E. 5 I/O, EDGE DETECT, COUNTERS, AND SERIAL I/O TIMING}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{SYMBOL} & \multirow[b]{2}{*}{PARAMETER} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline \begin{tabular}{l}
\(T_{\text {pow }}{ }^{11)}\) \\
\(T_{\text {cmos }}{ }^{\text {(1) }}\) \\
\(T_{\text {Poow }}\)
\end{tabular} & \begin{tabular}{l}
Internal Write to Peripheral Data Valid PA, PB, PC TTL \\
PA, PB, PC CMOS PD
\end{tabular} & - & \[
\begin{array}{r}
500 \\
1000 \\
175
\end{array}
\] & - & \[
\begin{array}{r}
500 \\
1000 \\
150 \\
\hline
\end{array}
\] \\
\hline \[
\begin{aligned}
& \mathrm{T}_{\text {Posu }} \\
& \mathrm{T}_{\text {PDSU }}
\end{aligned}
\] & Perıpheral Data Setup Time PA, PB, PC PD & \[
\begin{array}{r}
200 \\
50 \\
\hline
\end{array}
\] & - & \[
\begin{array}{r}
200 \\
50 \\
\hline
\end{array}
\] & - \\
\hline \[
\begin{aligned}
& \mathrm{T}_{\text {PHR }} \\
& \mathrm{T}_{\text {PH }}
\end{aligned}
\] & Peripheral Data Hold Time \(P A, P B, P C\) PD & \[
\begin{aligned}
& 75 \\
& 10
\end{aligned}
\] & - & \[
\begin{aligned}
& 75 \\
& 10
\end{aligned}
\] & 二 \\
\hline \(\mathrm{T}_{\text {EPW }}\) & PA0-PA3 Edge Detect Pulse Width & Tcre & - & \(\mathrm{T}_{\text {crc }}\) & - \\
\hline \[
\begin{aligned}
& T_{\text {cpw }} \\
& T_{\text {co }}{ }^{(1)}
\end{aligned}
\] & \begin{tabular}{l}
Counters A and B \\
PA4, PA5 Input Pulse Width PA4, PA5 Output Delay
\end{tabular} & Tcrc & \(\overline{500}\) & \(\mathrm{T}_{\text {crc }}\) & - \\
\hline \begin{tabular}{l}
\(T_{\text {pelw }}\) \\
TPLSU \\
\(\mathrm{T}_{\text {PBLH }}\)
\end{tabular} & Port B Latch Mode PAO Strobe Pulse Width PB Data Setup Time PB Data Hold Time & \[
\begin{gathered}
T_{\text {crc }} \\
175 \\
30
\end{gathered}
\] & - & \[
\begin{gathered}
T_{\text {crc }} \\
150 \\
30
\end{gathered}
\] & - \\
\hline \begin{tabular}{l}
\(T_{\text {Pow }}{ }^{(1)}\) \\
\(\mathrm{T}_{\text {cmos }}{ }^{\text {(1) }}\) \\
\(T_{\text {cpw }}\) \\
\(\mathrm{T}_{\text {pow }}{ }^{(1)}\) \\
\(\mathrm{T}_{\text {смоs }}{ }^{\text {(1) }}\)
\end{tabular} & \begin{tabular}{l}
Serial I/O \\
PA6 XMTR TTL \\
PA6 XMTR CMOS \\
PA4 RCVR S/R Clock Width PA4 XMTR Clock-S/R Mode (TTL) \\
PA4 XMTR Clock-S/R Mode (CMOS)
\end{tabular} &  & \[
\begin{array}{r}
500 \\
1000 \\
- \\
500 \\
1000
\end{array}
\] &  & \[
\begin{array}{r}
500 \\
1000 \\
- \\
500 \\
1000
\end{array}
\] \\
\hline
\end{tabular}

NOTE 1: Maximum Load Capacitance: 50pF
Passive Pull-Up Required

\section*{E.5.1 I/O, Edge Detect, Counter, and Serial I/O Timing}


\section*{R6511Q Microprocessor and R6500/13 Microcomputer}

\section*{E. 6 MICROPROCESSOR TIMING (D0-D7,} A0-A12, A15, SYNC, R/W)
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{SYMBOL} & \multirow[b]{2}{*}{PARAMETER} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|l|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline \(\mathrm{T}_{\text {Rws }}\) & R/W Setup Time & - & 225 & - & 140 \\
\hline \(\mathrm{T}_{\text {ADS }}\) & A0-A12, A15 Setup Time & - & 150 & - & 75 \\
\hline T \({ }_{\text {DSU }}\) & D0-D7 Data Setup Time & 50 & - & 35 & - \\
\hline \(\mathrm{T}_{\mathrm{HR}}\) & D0-D7 Read Hold Time & 10 & - & 10 & - \\
\hline \(\mathrm{T}_{\mathrm{HW}}\) & D0-D7 Write Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {MOS }}\) & D0-D7 Write Output Delay & - & 175 & - & 130 \\
\hline \(\mathrm{T}_{\text {SYM }}\) & SYNC Setup & - & 225 & - & 175 \\
\hline THA & A0-A12, A15 Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {HRW }}\) & R/W Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {ACC }}\) & \begin{tabular}{l}
External Memory Access \\
Time \(\mathrm{T}_{\mathrm{ACC}}=\mathrm{T}_{\mathrm{CYC}}-\mathrm{T}_{\mathrm{F}}\) - \\
\(T_{A D S}-T_{D S U}\)
\end{tabular} & - & \(\mathrm{T}_{\text {ACC }}\) & - & \(\mathrm{T}_{\text {ACC }}\) \\
\hline \(\mathrm{T}_{\text {SYH }}\) & SYNC Hold Time & 30 & - & 30 & - \\
\hline
\end{tabular}

\section*{E.6.1 Microprocessor Timing Diagram}


\section*{INTRODUCTION}

\section*{FEATURES}
- Enhanced 6502 CPU
- Four new bit manipulation instructions:

Set Memory Bit (SMB)
Reset Memory Bit (RMB)
Branch on Bit Set (BBS)
Branch on Bit Reset (BBR)
- Decimal and binary arithmetic modes
-13 addressing modes
- True indexing
- 192-byte static RAM
- 16 TTL-compatible I/O lines
- One 8-bit port with programmable latched input
- Two 16 -bit programmable counter/timers, with latches
- Pulse width measurement
- Asymmetrical pulse generation
- Pulse generation
- Interval timer
- Event counter
- Retriggerable interval timer
- Serial port
- Full-duplex asynchronous operation mode
- Selectable 5 - to 8 -bit characters
- Wake-up feature
- Synchronous shift register mode
- Standard programmable bit rates, programmable up to 62.5 K bits/sec @ 1 MHz
- Ten interrupts
- Four edge-sensitive lines; two positive, two negative
- Reset
- Non-maskable
- Two counter underflows
- Serial data received
- Serial data transmitted
- 16 K bytes of external memory addressing
- Flexible clock circuitry
-2 MHz or 1 MHz internal operation
- Internal clock with external 2 MHz to 4 MHz series resonant XTAL at two times internal frequency
- External clock input divided by one or two
- \(1 \mu \mathrm{~s}\) minimum instruction execution time @ 2 MHz
- NMOS-3 silicon gate, depletion load technology
- Single +5 V power supply
- 12 mW stand-by power for 32 bytes of the 192-byte RAM
- 40-pin DIP
- 44-pin PLCC

\section*{SUMMARY}

The Rockwell R6518 one-chip microprocessor is a complete 8-bit microcomputer on a single VLSI chip with the exception of external user-provided application ROM. The R6518 interfaces with up to 16 K bytes of external memory via a multiplexed address/data bus.

The R6518 consists of an enhanced R6502 CPU, an internal clock oscillator, 192 bytes of Random Access Memory (RAM) and versatile interface circuitry. The interface circuitry includes two 16-bit programmable timer/counters, 16 bidirectional input/output lines (including four edge-sensitive lines and input latching on one 8 -bit port), a full-duplex serial I/O channel, ten interrupts and 16 K of external address space.

The innovative architecture and the demonstrated high performance of the R6502 CPU, as well as instruction simplicity, results in system cost-effectiveness and a wide range of computational power. These features make this device a leading candidate for microprocessor applications.

Rockwell supports development of R6500/* single-chip microcomputer applications with the Rockwell Design Center Low Cost Emulator (LCE) and R6500/* Personality Set. Program assembly can be performed on any user-provided computer using an assembler generating R6500/* machine code. The machine code can then be downloaded via an RS-232-C serial channel to the LCE for program debugging and in-circuit emulation. Refer to the RDC-3101/2 LCE and RDC-3XX R6500/* Personality Set data sheets, Order No.s RDC17 and RDC06, respectively, for detailed information.

This product description is for the reader familiar with the R6502 CPU hardware and programming capabilities. A detailed description of the R6502 CPU hardware is included in the R6500 Microcomputer System Hardware Manual (Order No. 201). A description of the instruction capabilities of the R6502 CPU is contained in the R6500 Microcomputer System Programming Manual (Order No. 202).

ORDERING INFORMATION


\section*{INTERFACE}

This section presents the interface requirements for the R6518 single-chip microprocessor. Figure 1 is the Interface Diagram, Figure 2 shows the pin configurations and Table 1 describes the function of each pin. A detailed block diagram of the device and its internal function is illustrated in Figure 3. Package dimensions are illustrated in the last section.


Figure 1. Interface Diagram


Figure 2. R6518 Pin Assignments

Table 1. Pin Description
\begin{tabular}{|c|c|c|c|}
\hline \multirow[b]{2}{*}{Signal Name} & \multicolumn{2}{|l|}{Pin Number} & \multirow[b]{2}{*}{Description} \\
\hline & DIP & PLCC & \\
\hline \(V_{C C}\) & 21 & 24 & Main power supply +5 V \\
\hline \(V_{\text {RR }}\) & 39 & 42 & Separate power pin for RAM. In the event that \(\mathrm{V}_{\text {CC }}\) power is lost, this power retains 32 bytes of RAM Data. \\
\hline \(V_{\text {SS }}\) & 40 & 44 & Signal and power ground (0V) \\
\hline XTLI & 2 & 3 & Crystal or clock input for internal clock oscillator. Also allows input of X1 clock signal if XTLO is connected to \(\mathrm{V}_{\mathrm{SS}}\), or X 2 clock if XTLO is floated. \\
\hline XTLO & 1 & 2 & Crystal output from internal clock oscillator. \\
\hline \(\overline{\text { RES }}\) & 20 & 21 & The Reset input is used to initialize the device. This signal must not transition from low to high for at least eight cycles after \(\mathrm{V}_{\mathrm{CC}}\) reaches operating range and the internal oscillator is stabilized. \\
\hline \(\emptyset 2\) & 3 & 4 & Clock signal output at internal frequency. ) \\
\hline \(\overline{\text { NMI }}\) & 22 & 25 & A negative going edge on the Non-Maskable Interrupt signal requests that a non-maskable interrupt be generated within the CPU. \\
\hline PA0-PA7 & 30-23 & 33-26 & Two 8-bit ports used for either input/output. Each line of Ports A and B consists of an active transistor to \\
\hline PB0-PB7 & 38-31 & 41-34 & \(\mathrm{V}_{\text {SS }}\) and a passive pull-up to \(\mathrm{V}_{\mathrm{CC}}\). \\
\hline \[
\begin{aligned}
& \text { A0-A3, A12, R/W } \\
& A 13, \& \overline{\mathrm{EMS}}
\end{aligned}
\] & 4-11 & 5-12 & The address and timing pins have an active transistor to \(\mathrm{V}_{\text {SS }}\) and a passive pull-up to \(\mathrm{V}_{\mathrm{CC}}\). \\
\hline A4-A11/D0-D7 & 19-12 & 20-13 & These multiplexed address/data pins have active pull-up and pull-down transistors. \\
\hline NC & - & \[
\begin{array}{r}
1,22 \\
23,43
\end{array}
\] & No connection. These pins should be left open. \\
\hline
\end{tabular}

\section*{SYSTEM ARCHITECTURE}

This section provides a functional description of the R6518. Functionally it consists of a CPU, RAM memory, two 8 -bit parallel I/O ports, a serial I/O port, dual counter/latch circuits, a mode control register, and an interrupt flag/enable dual register circuit. A block diagram of the system is shown in Figure 3.

\section*{NOTE}

Throughout this document, unless specified otherwise, all memory or register address locations are specified in hexadecimal notation.

\section*{CPU LOGIC}

The internal CPU is a standard 6502 configuration with an 8 -bit Accumulator register, two 8-bit index registers ( X and Y ); an 8 -bit Stack Pointer register, an ALU, a 16-bit Program Counter, and standard instruction register/decode and internal timing control logic.

\section*{ACCUMULATOR}

The Accumulator is a general purpose 8 -bit register that stores the results of most arithmetic and logic operations. In addition, the Accumulator usually contains one of the two data words used in these operations.

\section*{INDEX REGISTERS}

There are two 8 -bit index registers, X and Y . Each index register can be used as a base to modify the address data program counter and thus obtain a new address-the sum of the program counter contents and the index register contents.

When executing an instruction which specifies indirect addressing, the CPU fetches the op code and the address, and modifies the address from memory by adding the index register to it prior to loading or storing the value of memory.

Indexing greatly simplifies many types of programs, especially those using data tables.

\section*{STACK POINTER}

The Stack Pointer is an 8 -bit register. It is automatically incremented and decremented under control of the microprocessor to perform stack manipulation in response to either user instructions, an internal \(\overline{\mathrm{RQ}}\) interrupt, or the external interrupt line \(\overline{\mathrm{NMII}}\). The Stack Pointer must be initialized by the user program.

The stack allows simple implementation of multiple level interrupts, subroutine nesting and simplification of many types of data manipulation. The JSR, BRK, RTI and RTS instructions use the stack and Stack Pointer.

The stack can be envisioned as a deck of cards which may only be accessed from the top. The address of a memory location is stored (or "pushed") onto the stack. Each time data are to be pushed onto the stack, the Stack Pointer is placed on the Address Bus, data are written into the memory location addressed by the Stack Pointer, and the Stack Pointer is decremented by 1. Each time data are read (or "pulled") from the stack, the Stack Pointer is incremented by 1. The Stack Pointer is then placed on the Address Bus, and data are read from the memory location addressed by the Pointer.

The stack is located on zero page, i.e., memory locations 00FF-0040. After reset, which leaves the Stack Pointer indeterminate, normal usage calls for its initialization at 00FF.

\section*{ARITHMETIC AND LOGIC UNIT (ALU)}

All arithmetic and logic operations take place in the ALU, including incrementing and decrementing internal registers (except the Program Counter). The ALU cannot store data for more than one cycle. If data are placed on the inputs to the ALU at the beginning of a cycle, the result is always gated into one of the storage registers or to external memory during the next cycle.

Each bit of the ALU has two inputs. These inputs can be tied to various internal buses or to a logic zero; the ALU then generates the function (AND, OR, SUM, and so on) using the data on the two inputs.

\section*{PROGRAM COUNTER}

The 16 -bit Program Counter provides the addresses that are used to step the processor through sequential instructions in a program. Each time the processor fetches an instruction from program memory, the lower (least significant) byte of the Program Counter (PCL) is placed on the low-order bits of the Address Bus and the higher (most significant) byte of the Program Counter ( PCH ) is placed on the high-order 8 bits of the Address Bus. The Counter is incremented each time an instruction or data is fetched from program memory.

\section*{INSTRUCTION REGISTER AND INSTRUCTION DECODE}

Instructions are fetched from ROM or RAM and gated onto the Internal Data Bus. These instructions are latched into the Instruction Register then decoded along with timing and interrupt signals to generate control signals for the various registers.

\section*{TIMING CONTROL}

The Timing Control Logic keeps track of the specific instruction cycle being executed. This logic is set to TO each time an instruction fetch is executed and is advanced at the beginning of each Phase One clock pulse for as many cycles as are required to complete the instruction. Each data transfer which takes place between the registers is caused by decoding the contents of both the instruction register and timing control unit.


\section*{INTERRUPT LOGIC}

Interrupt logic controls the sequencing of three interrupts; \(\overline{\mathrm{RES}}\), \(\overline{\mathrm{NMI}}\) and \(\overline{\mathrm{RQ}} . \overline{\mathrm{IRQ}}\) is generated by any one of eight conditions: 2 Counter Overflows, 2 Positive Edge Detects, 2 Negative Edge Detects, and 2 Serial Port Conditions.

The R6518 requires that 3-byte JMP instructions for \(\overline{N M I}, \overline{R E S}\) and IRQ be programmed in user-provided external ROM at hex locations 3FF7, 3FFA and 3FFD, respectively. These instructions must jump to the first instruction of the respective reset or interrupt handler routine. Terminate the interrupt handler routines as normal with an RTI. See Power-On Reset for details of RES internal initialization.

\section*{NEW INSTRUCTIONS}

In addition to the standard 6502 instruction set, four instructions have been added to the device to simplify operations that previously required a read/modify/write operation. In order for these instructions to be equally applicable to either I/O port, with or without mixed input and output functions, the I/O ports have been designed to read the contents of the specified port data register during the Read cycle of the read/modify/write operation, rather than I/O pins as in normal read cycles. The added instructions and their format are explained in the following subparagraphs. Refer to Appendix A for the Op Code mnemonic addressing matrix for these added instructions.

\section*{SET MEMORY BIT (SMB m, ADDR.)}

This instruction sets to " 1 " one of the 8 bits specified by the zero page address (memory or I/O port). The first byte of the instruction specifies the SMB operation and 1 of 8 bits to be set. The second byte of the instruction designates address ( \(00-\mathrm{FF}\) ) of the byte or I/O port to be operated upon.

\section*{RESET MEMORY BIT (RMB m, ADDR.)}

This instruction is the same in operation and format as the SMB instruction except that a reset to " 0 " of the bit results.

\section*{BRANCH ON BIT SET RELATIVE (BBS m, ADDR, DEST)}

This instruction tests one of 8 bits designated by a three bit immediate field within the first byte of the instruction. The second byte is used to designate the address of the byte to be tested within the zero page address range (memory or I/O ports). The third byte of the instruction is used to specify the 8 bit relative address to which the instruction branches if the bit tested is a " 1 ". If the bit tested is not set, the next sequential instruction is executed.

\section*{BRANCH ON BIT RESET RELATIVE (BBR m, ADDR, DEST)}

This instruction is the same in operation and format as the BBS instruction except that a branch takes place if the bit tested is a " 0 ".

\section*{READ ONLY MEMORY (ROM)}

This device has no internal application ROM. Up to 16 K of external memory can be attached via the 16 address/data and timing pins.

\section*{RANDOM ACCESS MEMORY (RAM)}

The RAM consists of 192 bytes of read/write memory with an assigned page zero address of 0040 through 00FF. The

R6518 provides a separate power pin ( \(V_{R R}\) ) which may be used for standby power for 32 bytes located at 0040-005F. In the event of the loss of \(V_{C C}\) power, the lowest 32 bytes of RAM data will be retained if standby power is supplied to the \(V_{R R}\) pin. If the RAM data retention is not required then \(V_{R R}\) must be connected to \(\mathrm{V}_{\mathrm{CC}}\). During operation \(\mathrm{V}_{\mathrm{RR}}\) must be at the \(\mathrm{V}_{\mathrm{CC}}\) level.

For the RAM to retain data upon loss of \(\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{RR}}\) must be supplied within operating range and \(\overline{R E S}\) must be driven low at least eight \(\emptyset 2\) clock pulses before \(V_{C C}\) falls out of operating range. \(\overline{\text { RES }}\) must then be held low while \(\mathrm{V}_{\mathrm{CC}}\) is out of operating range and until at least eight \(\emptyset 2\) clock cycles after \(\mathrm{V}_{\mathrm{CC}}\) is again within operating range and the internal \(\emptyset 2\) oscillator is stabilized. \(\mathrm{V}_{\mathrm{RR}}\) must remain within \(\mathrm{V}_{\mathrm{CC}}\) operating range during normal operation. When \(V_{C C}\) is out of operating range, \(V_{R R}\) must remain within the \(\mathrm{V}_{\mathrm{RR}}\) retention range in order to retain data. Figure 4 shows typical waveforms.


Figure 4. Data Retention Timing

\section*{CLOCK OSCILLATOR}

A reference frequency can be generated with the on-chip oscillator using an external crystal. The oscillator reference frequency passes through an internal countdown network (divide by 2) to obtain the internal operating frequency (see Figure 5a). The on-chip oscillator is designed for a parallel resonant crystal connected between XTLI and XTLO pins. The equivalent oscillator circuit is shown in Figure 5.

A parallel resonant crystal is specified by its load capacitance and series resonant resistance. For proper oscillator operation, the load capacitance ( \(\mathrm{C}_{\mathrm{L}}\) ), series resistance \(\left(\mathrm{R}_{\mathrm{S}}\right)\) and the crystal resonant frequency ( F ) must meet the following two relations:
\[
\begin{gathered}
(C+27)=2 C_{L} \quad \text { or } C=2 C_{L}-27 p F \\
R_{S} \leq R_{s \max }=\frac{2 \times 10^{6}}{\left(F C_{L}\right)^{2}}
\end{gathered}
\]
where: F is in MHz ; \(\mathrm{C}_{\mathrm{L}}\) is in pF ; and R is in ohms.
To select a parallel resonant crystal for the oscillator, first select the load capacitance from a crystal manufacturer's catalog. Next, calculate \(R_{\text {smax }}\) based on \(F\) and \(C_{L}\). The selected crystal must have a \(R_{s}\) less than the \(R_{\text {smax }}\).

For example, if \(\mathrm{C}_{\mathrm{L}}=22 \mathrm{pF}\) for a 4 MHz parallel resonant crystal, then
\[
\begin{aligned}
& C=(2 \times 22)-27=17 \mathrm{pF} \\
& \text { (use standard value of } 18 \mathrm{pF} \text { ) }
\end{aligned}
\]

The series resistance of the crystal must be less than
\[
R_{s \max }=\frac{2 \times 10^{6}}{(4 \times 22)^{2}}=258 \mathrm{ohms}
\]

Internal timing can also be controlled by driving the XTLI pin with an external frequency source. Figure \(5 b\) shows typical connections. If XTLO is left floating, the external source is divided by the internal countdown network. However, if XTLO is tied to \(\mathrm{V}_{\text {SS }}\), the internal countdown network is bypassed causing the chip to operate at the frequency of the external source.


Figure 5. Clock Oscillator Input Options

\section*{MODE CONTROL REGISTER (MCR)}

The Mode Control Register contains a control bit for Port B and mode select bits for Counter A and Counter B. Its setting, along with the setting of the Serial Communications Control Register (SCCR), determines the basic configuration of the device in any application. Initializing this register is one of the first actions of any software program. MCR bits 7, 6,5 must remain is in order for external memory referencing to be enabled. The Mode Control Register bit assignment is shown in Figure 6.


Figure 6. Mode Control Register
The use of Counter A Mode Select is shown in Section "Counter A".

The use of Counter B Mode Select is shown in Section "Counter B".

The use of Port B Latch Enable is shown in Section "Port B (PB)".

\section*{INTERRUPT FLAG REGISTER (IFR) AND INTERRUPT ENABLE REGISTER (IER)}
\(\mathrm{A} \overline{\mathrm{IRQ}}\) interrupt request can be initialized by any or all of eight possible sources. These sources are all capable of being enabled or disabled by the use of the appropriate interrupt enabled bits in the Interrupt Enable Register (IER). Multiple simultaneous interrupts will cause the \(\overline{\mathrm{RQ}}\) interrupt request to remain active until all interrupting conditions have been serviced and cleared.

The Interrupt Flag Register contains the information that indicates which I/O or counter needs attention. The contents of the Interrupt Flag Register may be examined at any time by reading at address: 0011. Edge detect IFR bits may be cleared by executing a RMB instruction at address location 0010. The RMB X , (0010) instruction reads FF, modifies bit X to a " 0 ", and writes the modified value at address location 0011. In this way IFR bits set to a " 1 " after the read cycle of a Read-Modify-Write instruction (such as RMB) are protected from being cleared. A logic " 1 " is ignored when writing to edge detect IFR bits.

Each IFR bit has a corresponding bit in the Interrupt Enable Register which can be set to a " 1 " by writing a " 1 " in the respective bit position at location 0012. Individual IER bits may be cleared by writing a " 0 "' in the respective bit position, or by RES. If set to a " 1 ", an IRQ will be generated when the corresponding IFR bit becomes true. The Interrupt Flag Register and Interrupt Enable Register bit assignments are shown in Figure 7 and the functions of each bit are explained in Table 2.


Figure 7. Interrupt Enable and Flag Registers

\section*{PROCESSOR STATUS REGISTER}

The 8-bit Processor Status Register, shown in Figure 8 contains seven status flags. Some of these flags are controlled by the user program; others may be controlled both by the user's program and the CPU. The R6502 instruction set contains a number of conditional branch instructions which are designed to allow testing of these flags. Each of the eight processor status flags is described in the following sections.

\section*{CARRY BIT (C)}

The Carry Bit (C) can be considered as the ninth bit of an arithmetic operation. It is set to logic 1 if a carry from the eighth bit has occurred or cleared to logic 0 if no carry occurred as the result of arithmetic operations.

The Carry Bit may be set or cleared under program control by use of the Set Carry (SEC) or Clear Carry (CLC) instruction, respectively. Other operations which affect the Carry Bit are ADC, ASL, CMP, CPX, CPY, LSR, PLP, ROL, ROR, RTI, and SBC.

Table 2. Interrupt Flag Register Bit Codes
\begin{tabular}{|c|c|}
\hline \[
\begin{gathered}
\text { Bit } \\
\text { Code }
\end{gathered}
\] & Function \\
\hline IFR 0: & PAO Positive Edge Detect Flag-Set to a " 1 " when a positive going edge is detected on PAO. Cleared by RMB 0 (0010) instruction or by \(\overline{\text { RES }}\). \\
\hline IFR 1: & PA1 Positive Edge Detect Flag-Set to a 1 when a positive going edge is detected on PA1. Cleared by RMB 1 (0010) instruction or by \(\overline{\text { RES }}\). \\
\hline IFR 2: & PA2 Negative Edge Detect Flag-Set to a 1 when a negative going edge is detected on PA2. Cleared by RMB 2 (0010) instruction or by \(\overline{\mathrm{RES}}\). \\
\hline IFR 3: & PA3 Negative Edge Detect Flag-Set to 1 when a negative going edge is detected on PA3. Cleared by RMB 3 (0010) instruction or by \(\overline{\text { RES }}\). \\
\hline IFR 4: & Counter A Underflow Flag-Set to a 1 when Counter A underflow occurs. Cleared by reading the Lower Counter A at location 0018, by writing to address location 001A, or by RES. \\
\hline IFR 5: & Counter B Underflow Flag-Set to a 1 when Counter B underflow occurs. Cleared by reading the Lower Counter B at location 001C, by writing to address location 001E, or by RES. \\
\hline IFR 6: & Receiver Interrupt Flag-Set to a 1 when any of the Serial Communication Status Register bits 0 through 3 is set to a 1. Cleared when the Receiver Status bits (SCSRO-3) are cleared or by \(\overline{\text { RES }}\). \\
\hline IRF 7: & Transmitter Interrupt Flag-Set to a 1 when SCSR6 is set to a 1 while SCSR5 is a 0 or SCSR 7 is set to a 1. Cleared when the Transmitter Status bits (SCSR6 \& 7) are cleared or by RES. \\
\hline
\end{tabular}


Figure 8. Processor Status Register

\section*{ZERO BIT (Z)}

The Zero Bit \((Z)\) is set to logic 1 by the CPU during any data movement or calculation which sets all 8 bits of the result to zero. This bit is cleared to logic 0 when the resultant 8 bits of a data movement or calculation operation are not all zero. The R6500 instruction set contains no instruction to specifically set or clear the Zero Bit. The Zero Bit is, however, affected by the following instructions; ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TXA, TSX, and TYA.

\section*{INTERRUPT DISABLE BIT (I)}

The Interrupt Disable Bit ( 1 ) is used to control the servicing of an interrupt request (IRQ). If the I Bit is reset to logic 0 , the \(\overline{\mathrm{IRQ}}\) signal will be serviced. If the bit is set to logic 1 ; the \(\overline{\mathrm{RQ}}\) signal will be ignored. The CPU will set the Interrupt Disable Bit to logic 1 if a RESET ( \(\overline{\mathrm{RES}}\) ), \(\overline{\mathrm{IRQ}}\), or Non-Maskable Interrupt ( \(\overline{\mathrm{NMI}}\) ) signal is detected.

The I bit is cleared by the Clear Interrupt Mask Instruction (CLI) and is set by the Set Interrupt Mask Instruction (SEI). This bit is set by the BRK Instruction. The Return from Interrupt (RTI) and Pull Processor Status (PLP) instructions will also affect the 1 bit.

\section*{DECIMAL MODE BIT (D)}

The Decimal Mode Bit (D), is used to control the arithmetic mode of the CPU. When this bit is set to logic 1, the adder operates
as a decimal adder. When this bit is cleared to logic 0 , the adder operates as a straight binary adder. The adder mode is controlled only by the programmer. The Set Decimal Mode (SED) instruction will set the D bit; the Clear Decimal Mode (CLD) instruction will clear it. The PLP and RTI instructions also effect the Decimal Mode Bit.

\section*{CAUTION}

The Decimal Mode Bit will either set or clear in an unpredictable manner upon power application. This bit must be initialized to the desired state by the user program or erroneous results may occur.

\section*{BREAK BIT (B)}

The Break Bit ( \(B\) ) is used to determine the condition which caused the \(\overline{\mathrm{RQ}}\) service routine to be entered. If the \(\overline{\mathrm{RQ}}\) service routine was entered because the CPU executed a BRK command, the Break Bit will be set to logic 1. If the \(\overline{\mathrm{RQ}}\) routine was entered as the result of an \(\overline{\mathrm{RQ}}\) signal being generated, the B bit will be cleared to logic 0 . There are no instructions which can set or clear this bit.

\section*{OVERFLOW BIT (V)}

The Overflow Bit \((\mathbb{V})\) is used to indicate that the result of a signed, binary addition, or subtraction, operation is a value that cannot be contained in seven bits ( \(-128 \leq n \leq 127\) ).

This indicator only has meaning when signed arithmetic (sign and seven magnitude bits) is performed. When the ADC or SBC instruction is performed, the Overflow Bit is set to logic 1 if the polarity of the sign bit (bit 7) is changed because the result exceeds +127 or -128 ; otherwise the bit is cleared to logic 0 . The V bit may also be cleared by the programmer using a Clear Overflow (CLV) instruction.

The Overflow Bit may also be used with the BIT instruction. The BIT instruction which may be used to sample interface devices, allows the overflow flag to reflect the condition of bit 6 in the sampled field. During a BIT instruction the Overflow Bit is set equal to the content of the bit 6 on the data tested with BIT instruction. When used in this mode, the overflow has nothing to do with signed arithmetic, but is just another sense bit for the microprocessor. Instructions which affect the V flag are ADC, BIT, CLV, PLP, RTI and SBC.

\section*{NEGATIVE BIT (N)}

The Negative Bit ( N ) is used to indicate that the sign bit (bit 7 ), in the resulting value of a data movement or data arithmetic operation, is set to logic 1 . If the sign bit is set to logic 1 , the resulting value of the data movement or arithmetic operation is negative; if the sign bit is cleared, the result of the data movement or arithmetic operation is positive. There are no instructions that set or clear the Negative Bit since the Negative Bit represents only the status of a result. The instructions that effect the state of the Negative Bit are: ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TSX, TXA, AND TYA.

\section*{PARALLEL INPUT/OUTPUT PORTS}

The R6518 has 16 I/O lines grouped into two 8 -bit ports (PA \(P B\) ). Ports A and B may be used either for input or output individually or in groups of any combination.

Multifunction I/O's in Port A are protected from normal port I/O instructions when they are programmed to perform a multiplexed function.

Internal pull-up resistors (FET's with an impedance range of \(3 \mathrm{~K} \leq \mathrm{Rpu} \leq 12 \mathrm{~K}\) ohm) are provided on all port pins.

The direction of the I/O lines are controlled by 8-bit port registers located in page zero. This arrangement provides quick programming access using simple two-byte zero page address instructions. There are no direction registers associated with the I/O ports, which simplifies I/O handling. The I/O addresses are shown in Table 3. I/O Port Timing is shown on page 29.

Table 3. I/O Port Addresses
\begin{tabular}{|c|c|}
\hline Port & Address \\
\hline A & 0000 \\
B & 0001 \\
\hline
\end{tabular}

\section*{INPUTS}

Inputs for Ports A and B are enabled by loading logic 1 into all I/O port register bit positions that are to correspond to I/O input lines. A low ( \(<0.8 \mathrm{~V}\) ) input signal will cause a logic 0 to be read when a read instruction is issued to the port register. A high ( \(>2.0 \mathrm{~V}\) ) input will cause a logic 1 to be read. An \(\overline{\mathrm{RES}}\) signal forces both I/O port registers to logic 1 thus initially treating all I/O lines as inputs.

The status of the input lines can be interrogated at any time by reading the I/O port addresses. Note that this will return the actual status of the input lines, not the data written into the I/O port registers.

Ready/Modify/Write instructions can be used to modify the operation of PA and PB. During the Read cycle of a Read/Modify/Write instruction the Port I/O register is read. For all other read instructions the port input lines are read. Read/Modify/Write instructions are: ASL, DEC, INC, LSR, RMB ROL, ROR, and SMB.

\section*{OUTPUTS}

Outputs for Ports A and B are controlled by writing the desired I/O line output states into the corresponding I/O port register
bit positions. A logic 1 will force a high ( \(>2.4 \mathrm{~V}\) ) output while a logic 0 will force a low ( \(<0.4 \mathrm{~V}\) ) output.

\section*{PORT A (PA)}

Port A can be programmed via the Mode Control Register (MCR) and the Serial Communications Control Register (SCCR) as a standard parallel 8 -bit, bit independent, I/O port or as serial channel I/O lines, counter I/O lines, or an input data strobe for the Port B input latch option. Table 4 tabulates the control and usage of Port \(A\).

In addition to their normal I/O functions, PA0 and PA1 can detect positive going edges, and PA2 and PA3 can detect negative going edges. A proper transition on these pins will set a corresponding status bit in the IFR and generate an interrupt request if the respective Interrupt Enable Bit is set. The maximum rate at which an edge can be detected is one-half the phase \(2(\emptyset 2)\) clock rate. Edge detection timing is shown on page 29.

\section*{PORT B (PB)}

Port B can be programmed as an 8 bit, bit independent \(I / O\) port. It has a latched input capability which may be enabled or disabled via the Mode Control Register (MCR). Table 5 tabulates the control and usage of Port B. An Input Data Strobe signal must be provided through PAO when Port B is programmed to be used with latched input option. Input data latch timing for Port B is shown on page 29.

Table 5. Port B Control \& Usage
\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[b]{4}{*}{Pin Name} & \multicolumn{2}{|c|}{I/O Mode} & \multicolumn{2}{|c|}{Latch Mode} \\
\hline & \multicolumn{2}{|c|}{MCR4 \(=0\)} & \multicolumn{2}{|c|}{\begin{tabular}{l}
\[
\text { MCR4 }=1
\] \\
(2)
\end{tabular}} \\
\hline & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} \\
\hline & Name & Type (1) & Name & Type \\
\hline PB0 & PBO & 1/O & PB0 & INPUT \\
\hline PB1 & PB1 & 1/0 & PB1 & INPUT \\
\hline PB2 & PB2 & I/O & PB2 & INPUT \\
\hline PB3 & PB3 & 1/O & PB3 & INPUT \\
\hline PB4 & PB4 & I/O & PB4 & INPUT \\
\hline PB5 & PB5 & I/O & PB5 & INPUT \\
\hline PB6 & PB6 & 1/O & PB6 & INPUT \\
\hline PB7 & PB7 & I/O & PB7 & INPUT \\
\hline
\end{tabular}
(1) Resistive pull-up, active buffer pull down
(2) Input data is stored in port B latch by PAO pulse

Table 4. Port A Control \& Usage


\section*{SERIAL INPUT/OUTPUT CHANNEL}

The device provides a full duplex Serial I/O channel with programmable bit rates and operating modes. The serial I/O functions are controlled by the Serial Communication Control Register (SCCR). The SCCR bit assignment is shown in Figure 9. The serial bit rate is determined by Counter A for all modes except the Receiver Shift Register (RCVR S/R) mode for which an external shift clock must be provided. The maximum data rate using the internal clock is 62.5 K bits per second ( \(@ \emptyset 2=\) 1 MHz ). The transmitter (XMTR) and receiver (RCVR) can be independently programmed to operate in different modes and can be independently enabled or disabled.


Figure 9. Serial Communication Control Register

Except for the Receiver Shift Register Mode (RCVR S/R), all XMTR and RCVR bit rates will occur at one sixteenth of the Counter A interval timer rate. Counter A is forced into an interval timer mode whenever the serial I/O is enabled in a mode requiring an internal clock.

Whenever Counter \(A\) is required as a timing source it must be loaded with the hexadecimal code that selects the data rate for the serial I/O Port. Refer to Section "Counter A," Table 6 for hexadecimal values to represent the desired data rate.

\section*{TRANSMITTER OPERATION (XTMR)}

The XTMR operation and the transmitter related control/status functions are enabled by bit 7 of the Serial Communications Control Register (SCCR). The transmitter, when in the Asynchronous (ASYN) mode, automatically adds a start bit, one or two stop bits, and when enabled, a parity bit to the transmitted data. A word of transmitted data (in asynchronous parity mode) can have \(5-, 6-, 7\)-, or 8 -bits of data. The nine data modes are in Figure 10. When parity is disabled, the 5 -, 6 -, 7 - or 8 -bits of data are terminated with two stop bits.


Figure 10. Transmitter Data Modes
In the S/R mode, eight data bits are always shifted out. Bits/ character and parity control bits are ignored. The serial data is shifted out via the SO output (PA6) and the shift clock is available at the CA (PA4) pin. When the transmitter under-runs in the S/R mode the SO output and shift clock are held in a high state.

The XMTR Interrupt Flag bit (IFR7) is controlled by Serial Communication Status Register bits SCSR5, SCSR6 and SCSR7.
\[
\text { IFR7 }=\text { SCSR6 }(\overline{\text { SCSR5 }}+\text { SCSR7 })
\]

\section*{RECEIVER OPERATION (RCVR)}

The receiver and its selected control and status functions are enabled when SCCR6 is set to a " 1 ". In the ASYN mode, data format must have a start bit, appropriate number of data bits, a parity bit (if enabled) and one stop bit. Refer to Figure 10 for a diagram of bit allocations. The receiver bit period is divided into 8 sub-intervals for internal synchronization. The receiver bit stream is synchronized by the start bit and a strobe signal is generated at the appropriate center of each incoming bit. Refer to Figure 11 for ASYN Receive Data Timing. The character assembly process does not start if the start bit signal is less than one-half bit time after a low level is detected on the Receive Data Input. Framing error, over-run, and parity error conditions or a RCVR Data Register Full will set the appropriate status bits, and any of the above conditions will cause an Interrupt Request if the Receiver Interrupt Enable bit is set to logic 1.


Figure 11. ASYN Receive Data Timing

In the S/R mode, an external shift clock must be provided at CA (PA4) pin along with 8 bits of serial data (LSB first) at the SI input (PA7). The maximum data rate using an external shift clock is one-eighth the internal clock rate. Refer to Figure 12 for SIR Mode Timing.


Figure 12. S/R Mode Timing
A RCVR interrupt (IFR6) is generated whenever any of SCSR0-3 are true.

\section*{SERIAL COMMUNICATION STATUS REGISTER (SCSR)}

The Serial Communication Status Register (SCSR) holds information on various communication error conditions, status of the transmitter and receiver data registers, a transmitter end-of-transmission condition, and a receiver idle line condition (Wake-Up Feature). The SCSR bit assignment is shown in Figure 13. SCSR bit assignments and functions are:

SCSRO: Receiver Data Register Full-Set to a logic 1 when a character is transferred from the Receiver Shift Register to the Receiver Data Register. This bit is cleared by reading the Receiver Data Register, or by \(\overline{\operatorname{RES}}\) and is disabled if SCCR6 \(=0\). The SCSR0 bit will not be set to a logic 1 if the received data contains an error condition, instead, a corresponding error bit will be set to a logic 1.
SCSR1: Over-Run Error-Set to a logic 1 when a new character is transferred from the Receiver Shift Register, with the last character still in the Receiver Data Register. This bit is cleared by reading the Receiver Data Register, or by RES.

SCSR2: Parity Error-Set to a logic 1 when the RCVR is in the ASYN Mode, Parity Enable bit is set, and the received data has
a parity error. This bit is cleared by reading the Receiver Data Register or by \(\overline{R E S}\).

SCSR3: Framing Error-Set to a logic 1 when the received data contains a zero bit after the last data or parity bit in the stop bit slot. Cleared by reading the Receiver Data Register or by \(\overline{R E S}\). (ASYN Mode only).

SCSR4: Wake-Up-Set to a logic 1 by writing a " 1 " in bit 4 of address: 0016. The Wake-Up bit is cleared by \(\overline{\mathrm{RES}}\) or when the receiver detects a string of ten consecutive 1 s . When the Wake-Up bit is set SCSRO through SCSR3 are inhibited.

SCSR5: End of Transmission-Set to a logic 1 by writing a " 1 " in bit position 5 of address: 0016. The End of Transmission bit is cleared by \(\overline{\mathrm{RES}}\) or upon writing a new data word into the Transmitter Data Register. When the End-of-Transmission bit is true the Transmitter Data Register Empty bit is disabled until a Transmitter Under-Run occurs.

SCSR6: Transmitter Data Register Empty-Set to a logic 1 when the contents of the Transmitter Data Register are transferred to the Transmitter Shift Register. Cleared upon writing new data into the Transmit Data Register. This bit is initialized to a logic 1 by RES.

SCSR7: Transmitter Under-Run-Set to a logic 1 when the last data bit is transmitted if the transmitter is in a S/R Mode or when the last stop bit is transmitted if the XMTR is in the ASYN Mode while the Transmitter Data Register Empty Bit is set. Cleared by a transfer of new data into the Transmitter Shift Register, or by \(\overline{R E S}\).

Figure 13. SCSR Bit Allocation

\section*{WAKE-UP FEATURE}

In multi-distributed microprocessor or microcomputer applications, a destination address is usually included at the beginning of the message. The Wake-Up Feature allows non-selected CPU's to ignore the remainder of the message until the beginning of the next message by setting the Wake-Up bit. As long as the Wake-Up flag is true, the Receiver Data Register Full Flag remains false. The Wake-Up bit is automatically cleared when the receiver detects a string of ten consecutive 1 s which indicates an idle transmit line. When the next byte is received, the Receiver Data Register Full Flag signals the CPU to wake-up and read the received data.

and read the received data.

\section*{COUNTER/TIMERS}

The device contains two 16-bit counters (Counter A and Counter B) and three 16 -bit latches associated with the counters. Counter A has one 16 -bit latch and Counter B has two 16 -bit latches. Each counter can be independently programmed to operate in one of four modes:

\section*{Counter A}
- Pulse width measurement
- Pulse Generation
- Interval Timer
- Event Counter

\section*{Counter B}
- Retriggerable Interval Counter
- Asymmetrical Pulse Generation
- Interval Timer
- Event Counter

Operating modes of Counter A and Counter B are controlled by the Mode Control Register. All counting begins at the initialization value and decrements. When modes are selected requiring a counter input/output line, PA4 is automatically selected for Counter A and PA5 is automatically selected for Counter B (see Table 4).

\section*{COUNTER A}

Counter A consists of a 16 -bit counter and a 16 -bit latch organized as follows: Lower Counter A (LCA), Upper Counter A (UCA), Lower Latch A (LLA), and Upper Latch A (ULA). The counter contains the count of either \(\emptyset 2\) clock pulses or external events, depending on the counter mode selected. The contents of Counter A may be read any time by executing a read at location 0019 for the Upper Counter A and at location 001A or location 0018 for the Lower Counter A. A read at location 0018 also clears the Counter A Underflow Flag (IFR4).

The 16 -bit latch contains the counter initialization value, and can be loaded at any time by executing a write to the Upper Latch A at location 0019 and the Lower Latch \(A\) at location 0018. In either case, the contents of the accumulator are copied into the applicable latch register.

Counter A can be started at any time by writing to address: 001A. The contents of the accumulator will be copied into the Upper Latch A before the contents of the 16 -bit latch are transferred to Counter A . Counter A is set to the latch value whenever Counter A underflows. When Counter A decrements from 0000 the next counter value will be the latch value, not FFFF, and the Counter A Underflow Flag (1FR 4) will be set to "1". This bit may be cleared by reading the Lower Counter \(A\) at location 0018 , by writing to address location 001 A , or by \(\overline{\mathrm{RES}}\).

Counter A operates in any of four modes. These modes are selected by the Counter A Mode Select bits in the Mode Control Register.
\begin{tabular}{|c|c|l|}
\hline \begin{tabular}{c} 
MCR1 \\
(bit 1)
\end{tabular} & \begin{tabular}{c} 
MCR0 \\
(bit 0)
\end{tabular} & \multicolumn{1}{c|}{ Mode } \\
\hline 0 & 0 & Interval Timer \\
0 & 1 & Pulse Generation \\
1 & 0 & Event Counter \\
1 & 1 & Pulse Width Measurement \\
\hline
\end{tabular}

The Interval Timer, Pulse Generation, and Pulse Width Measurement Modes are \(\emptyset 2\) clock counter modes. The Event Counter Mode counts the occurrences of an external event on the CNTR line.

The Counter is set to the Interval Timer Mode (00) when a \(\overline{\operatorname{RES}}\) signal is generated.

\section*{INTERVAL TIMER}

In the Interval Timer mode the Counter is initialized to the Latch value by either of two conditions:
1. When the Counter is decremented from 0000, the next Counter value is the Latch value (not FFFF).
2. When a write operation is performed to the Load Upper Latch and Transfer Latch to Counter address 001A, the Counter is loaded with the Latch value. Note that the contents of the Accumulator are loaded into the Upper Latch before the Latch value is transferred to the Counter.

The Counter value is decremented by one count at the \(\emptyset 2\) clock rate. The 16 -bit Counter can hold from 1 to 65535 counts. The Counter Timer capacity is therefore \(1 \mu \mathrm{~s}\) to 65.535 ms at the \(1 \mathrm{MHz} \emptyset 2\) clock rate or \(0.5 \mu \mathrm{~s}\) to 32.7675 ms at the \(2 \mathrm{MHz} \emptyset 2\) clock rate. Time intervals greater than the maximum Counter value can be easily measured by counting \(\overline{\mathrm{R} Q}\) interrupt requests in the counter \(\overline{\mathrm{RQ}}\) interrupt routine.

When Counter A decrements from 0000, the Counter A Underflow (IFR4) is set to logic 1. If the Counter A Interrupt Enable Bit (IER4) is also set, an \(\overline{\operatorname{RQ}}\) interrupt request will be generated. The Counter A Underflow bit in the Interrupt Flag Register can be examined in the \(\overline{\mathrm{RQ}}\) interrupt routine to determine that the \(\overline{\mathrm{RQ}}\) was generated by the Counter A Underflow.

While the timer is operating in the Interval Timer Mode, PA4 operates as a PA I/O bit.

A timing diagram of the Interval Timer mode is shown in Figure 14.


Figure 14. Interval Timer Timing Diagram

\section*{pulse generation mode}

In the Pulse Generation mode, the CA line operates as a Counter Output. The line toggles from low to high or from high to low whenever a Counter A Underflow occurs, or a write is performed to address 001A.

The normal output wave form is a symmetrical square-wave. The CA output is initialized high when entering the mode and transitions low when writing to 001A.

Asymmetric waveforms can be generated if the value of the latch is changed after each counter underflow.

A one-shot waveform can be generated by changing from Pulse Generation to Interval Timer mode after only one occurrence of the output toggle condition.

\section*{EVENT COUNTER MODE}

In this mode the CA is used as an Event Input line, and the Counter will decrement with each rising edge detected on this line. The maximum rate at which this edge can be detected is one-half the \(\emptyset 2\) clock rate (Figure 15).

The Counter can count up to 65,535 occurrences before underflowing. As in the other modes, the Counter A Underflow bit (IER4) is set to logic 1 if the underflow occurs.


Figure 15. Event Counter Mode Timing

\section*{PULSE WIDTH MEASUREMENT MODE}

This mode allows the accurate measurement of a low pulse duration on the CA line. The Counter decrements by one count at the \(\emptyset 2\) clock rate as long as the CA line is held in the low state. The Counter is stopped when CA is in the high state.

The Counter A underflow flag will be set only when the count in the timer reaches zero. Upon reaching zero the timer will be loaded with the latch value and continue counting down as long as the CA pin is held low. After the counter is stopped by a high level on CA, the count will hold as long as CA remains high. Any further low levels on CA will again cause the counter to count down from its present value. The state of the CA line can be determined by testing the state of PA4 (Figure 16).


Figure 16. Pulse Width Measurement Timing

\section*{SERIAL I/O DATA RATE GENERATION}

Counter A also provdes clock timing for the Serial I/O which establishes the data rate for the Serial I/O port. When the Serial I/O is enabled, Counter A is forced to operate at the internal clock rate. Counter \(A\) is not required for the RCVR S/R mode. The Counter I/O (PA4) may also be required to support the Serial I/O (see Table 4).

Table 6 identifies the values to be loaded in Counter A for selecting standard data rates with a \(\emptyset 2\) clock rate of 1 MHz and 2 MHz . Although Table 6 identifies only the more common data rates, any data rate from 1 to 62.5 K bps can be selected by using the formula:
\[
N=\frac{\emptyset 2}{16 \times \mathrm{bps}}-1
\]
where
\(\mathrm{N}=\) decimal value to be loaded into Counter A using its hexadecimal equivalent
\(\emptyset 2=\) the clock frequency ( 1 MHz or 2 MHz )
bps \(=\) the desired data rate.

\section*{NOTE}

In Table 6 you will notice that the standard data rate and the actual data rate may be slightly different. Transmitter and receiver errors of \(1.5 \%\) or less are acceptable. A revised clock rate is included in Table 6 for those baud rates which fall outside this limit.

Table 6. Counter A Values for Baud Rate Selection
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{Standard Baud Rate} & \multicolumn{2}{|l|}{Hexadecimal Value} & \multicolumn{2}{|c|}{\begin{tabular}{l}
Actual \\
Baud \\
Rate \\
At
\end{tabular}} & \multicolumn{2}{|l|}{Clock Rate Needed to Get Standard Baud Rate} \\
\hline & 1 MHz & 2 MHz & 1 MHz & 2 MHz & 1 MHz & 2 MHz \\
\hline 50 & 04E1 & 09C3 & 50.00 & 50.00 & 1.0000 & 2.0000 \\
\hline 75 & 0340 & 0682 & 75.03 & 74.99 & 1.0000 & 2.0000 \\
\hline 110 & 0237 & 046F & 110.04 & 110.04 & 1.0000 & 2.0000 \\
\hline 150 & 01A0 & 0340 & 149.88 & 150.06 & 1.0000 & 2.0000 \\
\hline 300 & 00CF & 01A0 & 300.48 & 299.76 & 1.0000 & 2.0000 \\
\hline 600 & 0067 & 00CF & 600.96 & 600.96 & 1.0000 & 2.0000 \\
\hline 1200 & 0033 & 0067 & 1201.92 & 1201.92 & 1.0000 & 2.0000 \\
\hline 2400 & 0019 & 0033 & 2403.85 & 2403.85 & 1.0000 & 2.0000 \\
\hline 3600 & 0010 & 0021 & 3676.47 & 3676.47 & 0.9792 & 1.9584 \\
\hline 4800 & 000 C & 0019 & 4807.69 & 4807.69 & 1.0000 & 2.0000 \\
\hline 7200 & 0008 & 0010 & 6944.44 & 7352.94 & 1.0368 & 1.9584 \\
\hline 9600 & 0006 & 000C & 8928.57 & 9615.38 & 1.0752 & 2.0000 \\
\hline
\end{tabular}

\section*{COUNTER B}

Counter B consists of a 16 -bit counter and two 16 -bit latches organized as follows: Lower Counter B (LCB), Upper Counter B (UCB), Lower Latch B (LLB), Upper Latch B (ULB), Lower Latch C (LLC), and Upper Latch C (ULC). Latch C is used only in the asymmetrical pulse generation mode. The counter contains the count of either \(\emptyset 2\) clock pulses or external events depending on the counter mode selected. The contents of Counter B may be read any time by executing a read at location 001D for the Upper Counter B and at location 001E or 001C for the Lower Counter B. A read at location 001C also clears the Counter B Underflow Flag.

Latch B contains the counter initialization value, and can be loaded at any time by executing a write to the Upper Latch B at location 001D and the Lower Latch B at location 001C. In each case, the contents of the accumulator are copied into the applicable latch register.
Counter B can be initialized at any time by writing to address: 001E. The contents of the accumulator is copied into the Upper Latch B before the value in the 16 -bit Latch B is transferred to Counter B. Counter B will also be set to the latch value and the Counter B Underflow Flag bit (IFR5) will be set to a " 1 " whenever Counter \(B\) underflows by decrementing from 0000.

IFR 5 may be cleared by reading the Lower Counter B at location 001C, by writing to address location 001E, or by RES.

Counter B operates in the same manner as Counter A in the Interval Timer and Event Counter modes. The Pulse Width Measurement Mode is replaced by the Retriggerable Interval Timer Mode and the Pulse Generation mode is replaced by the Asymmetrical Pulse Generation Mode.

\section*{RETRIGGERABLE INTERVAL TIMER MODE}

When operating in the Retriggerable Interval Timer mode, Counter \(B\) is initialized to the latch value by writing to address 001E, by a Counter B underflow, or whenever a positive edge occurs on the CB pin (PA5). The Counter B interrupt flag will be set if the counter underflows before a positive edge occurs on the CB line. Figure 17 illustrates the operation of this timer mode.


Figure 17. Counter B Retriggerable Interval Timer Mode

\section*{ASYMMETRICAL PULSE GENERATION MODE}

Counter B has a special Asymmetrical Pulse Generation Mode whereby a pulse train with programmable pulse width and period can be generated without the processor intervention once the latch values are initialized.

In this mode, the 16 -bit Latch \(B\) is initialized with a value which corresponds to the duration between pulses (referred to as D in the following descriptions). The 16 -bit Latch C is initialized with a value which corresponds to the desired pulse width (referred to as P in the following descriptions). The initialization sequence for Latch \(B\) and \(C\) and the starting of a counting sequence are as follows:
1. The lower 8 bits of \(P\) are loaded into LLB by writing to address 001 C , and the upper 8 bits of \(P\) are loaded into ULB and the full 16 bits are transferred to Latch C by writing to address location 001D. At this point both Latch B and Latch \(C\) contain the value of \(P\).
2. The lower 8 bits of \(D\) are loaded into LLB by writing to address 001C, and the upper 8 bits of \(D\) are loaded into ULB by writing to address location 001E. Writing to address location 001E also causes the contents of the 16-bit Latch \(B\) to be downloaded into the Counter \(B\) and causes the CB output to go low as shown in Figure 18.
3. When the Counter B underflow occurs the contents of the Latch C is loaded into the Counter B , and the CB output toggles to a high level and stays high until another underflow occurs. Latch B is then down-loaded and the CB output toggles to a low level repeating the whole process.


Figure 18. Counter B Pulse Generation

\section*{POWER-ON/INITIALIZATION CONSIDERATIONS}

\section*{POWER-ON TIMING}

After applications of \(\mathrm{V}_{\mathrm{CC}}\) and \(\mathrm{V}_{\text {RR }}\) power to the device, \(\overline{\mathrm{RES}}\) must be held low for at least eight \(\emptyset 2\) clock cycles after \(V_{C C}\) reaches operating range and the internal oscillator has stabilized. This stabilization time is dependent upon the input \(\mathrm{V}_{\mathrm{CC}}\) voltage and performance of the internal oscillator. The clock can be monitored at \(\emptyset 2\) (pin 3). Figure 19 illustrates the power turn-on waveforms. Clock stabilization time is typically 20 ms .


Figure 19. Power Turn-on Timing Detail

\section*{POWER-ON RESET}

The occurrence of \(\overline{\operatorname{RES}}\) going from low to high will cause the device to set the Interrupt Mask Bit — bit 2 of the Processor Status Register. Both I/O ports (PA, PB) will be forced to the high (logic 1) state. An internal initialization sequence lasting 16 clock cycles is then performed which sets bits 5-7 of the Mode Control Register to logic 1, thus enabling external user memory (Multiplexed Bus Mode). The remaining bits of the Control Register will be cleared to logic 0 causing the Interval Timers counter mode (mode 00 ) to be selected and causing all interrupt enabled bits to be reset.

\section*{RESET (RES) CONDITIONING}

When \(\overline{\operatorname{RES}}\) is driven from low to high the device is put in a reset state causing the registers and I/O ports to be configured as shown in Table 7.

Table 7. \(\overline{\operatorname{RES}}\) Initialization of I/O Ports and Registers
\begin{tabular}{|lcccccccc|}
\hline & \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline Registers & & & & & & & & \\
\(\quad\) Processor Status & - & - & - & - & 0 & 1 & - & - \\
Mode Control (MCR) & 1 & 1 & 1 & 0 & 0 & 0 & 0 & 0 \\
Int. Enable (IER) & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
Int. Flag (IFR) & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
Ser. Com. Control (SCCR) & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
Ser. Com. Status (SCSR) & 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 \\
Ports & & & & & & & & \\
PA Latch & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\
PB Latch & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\
\hline
\end{tabular}

All RAM and other CPU registers will initialize in a random, nonrepeatable data pattern.

\section*{INITIALIZATION}

Any initialization process for the device should include a \(\overline{\operatorname{RES}}\), as indicated in the preceding paragraphs. After stabilization of the internal clock (if a power-on situation) an initialization subroutine should be executed to perform (as a minimum) the following functions:
1. The Stack Pointer should be set
2. Clear or Set Decimal Mode
3. Set or Clear Carry Flag
4. Set up Mode Controls as required
5. Clear Interrupts

A typical initialization subroutine could be as follows:
LDX Load stack pointer starting address into \(X\) Register
TXS Transfer X Register value to Stack Pointer
CLD Clear Decimal Mode
SEC Set Carry Flag
.... Set-up Mode Control and
.... special function
\(\ldots\) registers as required
CLI Clear Interrupts

\section*{ENHANCED R6502 INSTRUCTION SET}

The following table contains a summary of the R6502 instruction set. For detailed information, consult the R6502 Microcomputer System Programming Manual, Order No. 202. The four
instructions notated with a * are added instructions to enhance the standard 6502 instruction set.

Instruction Set In Alphabetic Sequence
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Description & Mnemonic & Description \\
\hline ADC & Add Memory to Accumulator with Carry & LDA & Load Accumulator with Memory \\
\hline AND & "AND" Memory with Accumulator & LDX & Load Index X with Memory \\
\hline ASL & Shift Left One Bit (Memory or Accumulator) & LDY & Load Index Y with Memory \\
\hline & & LSR & Shift One Bit Right (Memory or (Accumulator) \\
\hline *BBR & Branch on Bit Reset Relative & & \\
\hline *BBS & Branch on Bit Set Relative & & \\
\hline BCC & Branch on Carry Clear & NOP & No Operation \\
\hline BCS & Branch on Carry Set & & \\
\hline BEQ & Branch on Result Zero & ORA & "OR" Memory with Accumulator \\
\hline BIT & Test Bits in Memory with Accumulator & & \\
\hline BMI & Branch on Result Minus & PHA & Push Accumulator on Stack \\
\hline BNE & Branch on Result not Zero & PHP & Push Processor Status on Stack \\
\hline BPL & Branch on Result Plus & PLA & Pull Accumulator from Stack \\
\hline BRK & Force Break & PLP & Pull Processor Status from Stack \\
\hline BVC & Branch on Overflow Clear & & \\
\hline BVS & Branch on Overflow Set & *RMB & Reset Memory Bit \\
\hline & & ROL & Rotate One Bit Left (Memory or Accumulator) \\
\hline CLC & Clear Carry Flag & ROR & Rotate One Bit Right (Memory or Accumulator) \\
\hline CLD & Clear Decimal Mode & RTI & Return from Interrupt \\
\hline CLI & Clear Interrupt Disable Bit & RTS & Return from Subroutine \\
\hline CLV & Clear Overflow Flag & & \\
\hline CMP & Compare Memory and Accumulator & & \\
\hline CPX & Compare Memory and Index X & & \\
\hline CPY & Compare Memory and Index Y & SBC & Subtract Memory from Accumulator with Borrow \\
\hline & & SEC & Set Carry Flag \\
\hline DEC & Decrement Memory by One & SED & Set Decimal Mode \\
\hline DEX & Decrement Index X by One & SEI & Set Interrupt Disable Status \\
\hline DEY & Decrement Index Y by One & *SMB & Set Memory Bit \\
\hline & & STA & Store Accumulator in Memory \\
\hline & & STX & Store Index X in Memory \\
\hline EOR & "Exclusive-Or" Memory with Accumulator & STY & Store Index Y in Memory \\
\hline INC & Increment Memory by One & & \\
\hline INX & Increment Index \(X\) by One & TAX & Transfer Accumulator to Index \(X\) \\
\hline INY & Increment Index Y by One & TAY & Transfer Accumulator to Index Y \\
\hline & & TSX & Transfer Stack Pointer to Index X \\
\hline & & TXA & Transfer Index X to Accumulator \\
\hline JMP & Jump to New Location & TXS & Transfer Index \(X\) to Stack Register \\
\hline JSR & Jump to New Location Saving Return Address & TYA & Transfer Index Y to Accumulator \\
\hline
\end{tabular}


INSTRUCTION CODE MATRIX

\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline & S 0 & 1 & 2 & 3 & 4 & 5 & 6 & 7 & 8 & 9 & A & B & C & D & E & F & \\
\hline \(\sum_{0}\) & BRK Implied 17 & ORA
(IND, X)
26 & & & & \[
\begin{aligned}
& \text { ORA } \\
& Z P \\
& 23
\end{aligned}
\] & \[
\begin{aligned}
& \text { ASL } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & \[
\begin{gathered}
\text { RMB0 } \\
\text { ZP } \\
2 \quad 5
\end{gathered}
\] & \[
\begin{gathered}
\text { PHP } \\
\text { Implied } \\
13
\end{gathered}
\] & \[
\begin{aligned}
& \text { ORA } \\
& \text { IMM } \\
& 22
\end{aligned}
\] & ASL Accum 12 & & & \[
\begin{aligned}
& \text { ORA } \\
& \text { ABS } \\
& 3 \quad 4
\end{aligned}
\] & \[
\begin{aligned}
& \text { ASL } \\
& \text { ABS } \\
& 36
\end{aligned}
\] & \[
\begin{aligned}
& \text { BBRO } \\
& \text { ZP } \\
& 3 \quad 5^{* *}
\end{aligned}
\] & 0 \\
\hline 1 & \begin{tabular}{l}
BPL \\
Relative \\
2 2**
\end{tabular} & \[
\begin{array}{|c|}
\hline \text { ORA } \\
\text { (IND), } Y \\
25^{*}
\end{array}
\] & & & & \[
\begin{gathered}
\text { ORA } \\
\text { ZP, } \mathrm{X} \\
24
\end{gathered}
\] & \[
\begin{aligned}
& \text { ASL } \\
& \text { ZP, X } \\
& 26
\end{aligned}
\] & \[
\begin{aligned}
& \text { RMB1 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & \begin{tabular}{l}
CLC \\
12
\end{tabular} & \[
\left|\begin{array}{c}
\text { ORA } \\
\text { ABS, } Y \\
3
\end{array}\right|
\] & & & & \[
\begin{aligned}
& \text { ORA } \\
& \text { ABS, } X \\
& 34^{*}
\end{aligned}
\] & \[
\begin{array}{|c|}
\hline \text { ASL } \\
\text { ABS, } X \\
37
\end{array}
\] & \[
\begin{gathered}
\text { BBR1 } \\
\text { ZP } \\
3 \quad 5^{* *}
\end{gathered}
\] & 1 \\
\hline 2 & \begin{tabular}{|c|}
\hline JSR \\
Absolute \\
3 \\
\hline
\end{tabular} & AND
(IND, \(X)\)
26 & & & \[
\begin{aligned}
& \text { BIT } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { AND } \\
& \text { ZP } \\
& 23
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{ROL} \\
& \mathrm{ZP} \\
& 2 \quad 5
\end{aligned}
\] & \[
\begin{aligned}
& \text { RMB2 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & \[
\begin{aligned}
& \text { PLP } \\
& \text { Implied }
\end{aligned}
\]
\[
14
\] & \[
\begin{aligned}
& \text { AND } \\
& \text { IMM } \\
& 2 \quad 2
\end{aligned}
\] & ROL Accum 12 & & \[
\begin{aligned}
& \text { BIT } \\
& \text { ABS } \\
& 34
\end{aligned}
\] & AND ABS 34 & \[
\begin{aligned}
& \mathrm{ROL} \\
& \mathrm{ABS} \\
& 36
\end{aligned}
\] & \[
\begin{aligned}
& \text { BBR2 } \\
& \text { ZP } \\
& 3 \quad 5^{* *}
\end{aligned}
\] & 2 \\
\hline 3 & \begin{tabular}{l}
BMI \\
Relative 2 2**
\end{tabular} & AND
(IND, Y)
\(2 \quad 5^{*}\) & & & & \[
\begin{gathered}
\text { AND } \\
\text { ZP, } \mathrm{X} \\
24
\end{gathered}
\] & \[
\begin{gathered}
\mathrm{ROL} \\
\mathrm{ZP}, \mathrm{X} \\
26
\end{gathered}
\] & \[
\begin{aligned}
& \text { RMB3 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & SEC Implied 12 & \[
\left.\begin{gathered}
\text { AND } \\
\text { ABS, } Y \\
3 \\
3
\end{gathered} \right\rvert\,
\] & & & & AND ABS, \(X\) 3 4* & \[
\begin{array}{|c|}
\hline \mathrm{ROL} \\
\mathrm{ABS}, \mathrm{x} \\
37
\end{array}
\] & \[
\begin{aligned}
& \text { BBR3 } \\
& \text { ZP } \\
& 3 \text { 5** }
\end{aligned}
\] & 3 \\
\hline 4 & \[
\begin{gathered}
\text { RTI } \\
\text { Implied } \\
16
\end{gathered}
\] & EOR
(IND, X)
26 & & & & \[
\begin{aligned}
& \text { EOR } \\
& Z P \\
& 23
\end{aligned}
\] & \[
\begin{aligned}
& \text { LSR } \\
& \mathrm{ZP} \\
& 25
\end{aligned}
\] & \[
\begin{gathered}
\text { RMB4 } \\
\text { ZP } \\
2 \quad 5
\end{gathered}
\] & \[
\begin{gathered}
\text { PHA } \\
\text { Implied } \\
13
\end{gathered}
\] & \[
\begin{aligned}
& \text { EOR } \\
& \text { IMM } \\
& 22
\end{aligned}
\] & LSR Accum 12 & & \[
\begin{aligned}
& \text { JMP } \\
& \text { ABS } \\
& 3 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { EOR } \\
& \text { ABS } \\
& 34
\end{aligned}
\] & \[
\begin{aligned}
& \text { LSR } \\
& \text { ABS } \\
& 36
\end{aligned}
\] & \[
\begin{gathered}
\text { BBR4 } \\
\text { ZP } \\
3 \quad 5^{* *}
\end{gathered}
\] & 4 \\
\hline 5 & \begin{tabular}{l}
BVC \\
Relative 2 2**
\end{tabular} & EOR
(IND), \(Y\)
\(25^{*}\) & & & & \[
\begin{gathered}
\text { EOR } \\
\text { ZP, } x \\
24
\end{gathered}
\] & \[
\begin{gathered}
\text { LSR } \\
\text { ZP, } X \\
26
\end{gathered}
\] & \[
\begin{aligned}
& \text { RMB5 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & CLI Implied 12 &  & & & & \[
\begin{gathered}
\text { EOR } \\
\text { ABS, } x \\
34^{*}
\end{gathered}
\] & \[
\left.\begin{gathered}
\text { LSR } \\
\text { ABS, } x \\
3 \\
7
\end{gathered} \right\rvert\,
\] & \[
\begin{aligned}
& \text { BBR5 } \\
& \text { ZP } \\
& 3 \quad 5^{* *}
\end{aligned}
\] & 5 \\
\hline 6 & \[
\begin{gathered}
\hline \text { RTS } \\
\text { Implied } \\
16
\end{gathered}
\] & ADC
(ND, \(X)\)
\(2 \quad 6\) & & & & \[
\begin{aligned}
& \text { ADC } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { ROR } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & \[
\begin{aligned}
& \text { RMB6 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & PLA Implied 14 & \[
\begin{aligned}
& \text { ADC } \\
& \text { IMM } \\
& 22
\end{aligned}
\] & ROR Accum 12 & & JMP Indirect 35 & \begin{tabular}{l}
ADC ABS \\
34
\end{tabular} & \[
\begin{aligned}
& \text { ROR } \\
& \text { ABS } \\
& 36
\end{aligned}
\] & \[
\begin{aligned}
& \text { BBR6 } \\
& \text { ZP } \\
& 3 \quad 5^{* *}
\end{aligned}
\] & 6 \\
\hline 7 & \begin{tabular}{l}
BVS \\
Relative \\
\(22^{* *}\)
\end{tabular} & \[
\begin{array}{|c|}
\hline \text { ADC } \\
(\text { IND, Y) } \\
25^{*}
\end{array}
\] & & & & \[
\begin{aligned}
& \text { ADC } \\
& \text { ZP, X } \\
& 24
\end{aligned}
\] & \[
\begin{aligned}
& \text { ROR } \\
& \mathrm{ZP}, \mathrm{X} \\
& 26 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { RMB7 } \\
& \text { ZP } \\
& 2 \quad 5 \\
& \hline
\end{aligned}
\] & SEI Implied 12 &  & & & & \[
\begin{gathered}
\text { ADC } \\
\text { ABS, } x \\
3 \\
3
\end{gathered} 4^{*} .
\] & \[
\begin{array}{|c|}
\text { ROR } \\
\text { ABS, } X \\
37
\end{array}
\] & \[
\begin{array}{|c|}
\hline \text { BBR7 } \\
\text { ZP } \\
3 \quad 5^{* *} \\
\hline
\end{array}
\] & 7 \\
\hline 8 & & STA
(IND, X)
26 & & & \[
\begin{aligned}
& \text { STY } \\
& \text { ZP } \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { STA } \\
& \text { ZP } \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { STX } \\
& \text { ZP } \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{gathered}
\text { SMBO } \\
\text { ZP } \\
2 \quad 5 \\
\hline
\end{gathered}
\] & DEY Impliod 12 & & TXA Implied 12 & & \[
\begin{aligned}
& \text { STY } \\
& \text { ABS } \\
& 34
\end{aligned}
\] & \[
\begin{aligned}
& \text { STA } \\
& \text { ABS } \\
& 3 \quad 4
\end{aligned}
\] & \[
\begin{aligned}
& \hline \text { STX } \\
& \text { ABS } \\
& 3 \quad 4 \\
& \hline
\end{aligned}
\] & \[
\begin{array}{|c|}
\hline \text { BBSO } \\
\text { ZP } \\
3 \quad 5^{* *}
\end{array}
\] & 8 \\
\hline 9 & \begin{tabular}{l}
BCC \\
Relative \\
2 2**
\end{tabular} & STA
(IND, Y)
26 & & & \[
\begin{gathered}
\text { STY } \\
\text { ZP, } \mathrm{X} \\
24
\end{gathered}
\] & \[
\begin{gathered}
\text { STA } \\
\text { ZP, } X \\
24
\end{gathered}
\] & \[
\begin{gathered}
\text { STX } \\
\text { ZP, Y } \\
24
\end{gathered}
\] & \[
\begin{aligned}
& \text { SMB1 } \\
& \text { ZP } \\
& 2 \quad 5 \\
& \hline
\end{aligned}
\] & TYA Implied 12 & STA
ABS, \(Y\)
\(3 \quad 5\) & TXS Implied 12 & & & \[
\begin{aligned}
& \text { STA } \\
& \text { ABS, } \mathrm{X}
\end{aligned}
\]
\[
35
\] & & \[
\begin{array}{|c|}
\hline \text { BBS1 } \\
\text { ZP } \\
3 \quad 5^{* *} \\
\hline
\end{array}
\] & 9 \\
\hline A & \[
\begin{aligned}
& \text { LDY } \\
& \text { IMM } \\
& 22 \\
& \hline
\end{aligned}
\] & \[
\begin{gathered}
\text { LDA } \\
\text { (IND, } \mathrm{X}) \\
266
\end{gathered}
\] & \[
\begin{aligned}
& \text { LDX } \\
& \text { IMM } \\
& 2 \quad 2 \\
& \hline
\end{aligned}
\] & & \[
\begin{aligned}
& \text { LDY } \\
& \text { ZP } \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { LDA } \\
& \text { ZP } \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { LDX } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { SMB2 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & TAY Implied 12 & \[
\begin{aligned}
& \text { LDA } \\
& \text { IMM } \\
& 22
\end{aligned}
\] & TAX Implied 12 & & \begin{tabular}{l}
LDY ABS \\
34
\end{tabular} & \[
\begin{aligned}
& \text { LDA } \\
& \text { ABS } \\
& 34
\end{aligned}
\] & \[
\begin{aligned}
& \text { LDX } \\
& \text { ABS } \\
& 34
\end{aligned}
\] & \[
\begin{gathered}
\text { BBS2 } \\
\text { ZP } \\
3 \quad 5 *
\end{gathered}
\] & A \\
\hline B & \begin{tabular}{l}
BCS \\
Relative \\
2 2**
\end{tabular} &  & & & \[
\begin{aligned}
& \text { LDY } \\
& \text { ZP, X } \\
& 24
\end{aligned}
\] & \[
\begin{aligned}
& \text { LDA } \\
& \text { ZP, } \mathrm{X} \\
& 24
\end{aligned}
\] & \[
\begin{aligned}
& L D X \\
& Z P, Y \\
& 24
\end{aligned}
\] & \[
\begin{aligned}
& \text { SMB3 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & CLV Implied 12 &  & TSX Implied 12 & &  & LDA ABS, \(X\) \(34^{*}\) &  & \[
\begin{gathered}
\text { BBS3 } \\
\text { ZP } \\
3 \quad 5^{\circ *}
\end{gathered}
\] & B \\
\hline C & \[
\begin{aligned}
& \text { CPY } \\
& \text { IMM } \\
& 22 \\
& \hline
\end{aligned}
\] &  & & & \[
\begin{aligned}
& \text { CPY } \\
& \text { ZP } \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { CMP } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { DEC } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & \[
\begin{aligned}
& \text { SMB4 } \\
& \text { ZP } \\
& 2 \quad 5 \\
& \hline
\end{aligned}
\] & INY Implied 12 & \[
\begin{aligned}
& \text { CMP } \\
& \text { IMM } \\
& 2 \quad 2 \\
& \hline
\end{aligned}
\] & \begin{tabular}{c} 
DEX \\
\hline Implied \\
\(1 \quad 2\)
\end{tabular} & & \[
\begin{aligned}
& \text { CPY } \\
& \text { ABS } \\
& 3 \quad 4
\end{aligned}
\] & \[
\begin{aligned}
& \text { CMP } \\
& \text { ABS } \\
& 34
\end{aligned}
\] & \[
\begin{aligned}
& \text { DEC } \\
& \text { ABS } \\
& 3 \quad 6
\end{aligned}
\] & \[
\begin{array}{|c|}
\hline \text { BBS4 } \\
\text { ZP } \\
3 \quad 5^{\prime *} \\
\hline
\end{array}
\] & C \\
\hline D & \begin{tabular}{l}
BNE \\
Relative \\
\(22^{* *}\)
\end{tabular} &  & & & & \[
\begin{gathered}
\text { CMP } \\
\text { 2P, X } \\
24
\end{gathered}
\] & \[
\begin{gathered}
\text { DEC } \\
\text { ZP, X } \\
26
\end{gathered}
\] & \[
\begin{aligned}
& \text { SMB5 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & CLD Implied 12 & \[
\begin{gathered}
\text { CMP } \\
\text { ABS, Y } \\
34^{\circ}
\end{gathered}
\] & & & &  &  & \[
\begin{gathered}
\text { BBS5 } \\
\text { ZP } \\
3 \text { 5** }
\end{gathered}
\] & D \\
\hline E & \[
\begin{aligned}
& C P X \\
& \text { IMM } \\
& 22
\end{aligned}
\] & SBC
(IND, X)
\(2 \quad 6\) & & & \[
\begin{aligned}
& \mathrm{CPX} \\
& \mathrm{ZP} \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{SBC} \\
& \mathrm{ZP} \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{array}{r}
\text { INC } \\
\text { ZP } \\
2 \quad 5 \\
\hline
\end{array}
\] & \[
\begin{gathered}
\text { SMB6 } \\
\text { ZP } \\
2 \quad 5 \\
\hline
\end{gathered}
\] & INX Implied 12 & \[
\begin{aligned}
& \hline \text { SBC } \\
& \text { IMM } \\
& 2 \quad 2 \\
& \hline
\end{aligned}
\] & NOP Implied 12 & & \[
\begin{aligned}
& \mathrm{CPX} \\
& \mathrm{ABS} \\
& 34
\end{aligned}
\] & \[
\begin{aligned}
& \text { SBC } \\
& \text { ABS } \\
& 3 \quad 4
\end{aligned}
\] & \[
\begin{aligned}
& \text { INC } \\
& \text { ABS } \\
& 3 \quad 6
\end{aligned}
\] & \[
\begin{array}{|c|}
\hline \text { BBS6 } \\
\text { ZP } \\
3 \quad 5^{\prime *} \\
\hline
\end{array}
\] & E \\
\hline F & \begin{tabular}{l}
BEQ \\
Relative 2 2**
\end{tabular} & SBC
(IND), \(Y\)
\(2 \quad 5^{*}\) & & & & \[
\begin{gathered}
\mathrm{SBC} \\
\mathrm{ZP}, \mathrm{X} \\
24
\end{gathered}
\] & \[
\begin{gathered}
\text { INC } \\
\mathrm{ZP}, \mathrm{X} \\
26
\end{gathered}
\] & \[
\begin{aligned}
& \text { SMB7 } \\
& \text { ZP } \\
& 2 \quad 5 \\
& \hline
\end{aligned}
\] & SED Implied 12 &  & & & & \[
\begin{gathered}
\text { SBC } \\
\text { ABS, } X \\
3 \quad 4^{*}
\end{gathered}
\] & \begin{tabular}{|c} 
INC \\
ABS, \(x\) \\
3 \\
7
\end{tabular} & \[
\begin{array}{|c|}
\hline \text { BBS7 } \\
\text { ZP } \\
3 \quad 5^{\circ} \\
\hline
\end{array}
\] & F \\
\hline & 0 & 1 & 2 & 3 & 4 & 5 & 6 & 7 & 8 & 9 & A & B & C & D & E & F & \\
\hline
\end{tabular}

\footnotetext{
*Add 1 to N if page boundary is crossed.
**Add 1 to N if branch occurs to same page; add 2 to N if branch occurs to different page.
}

\section*{KEY REGISTER SUMMARY}


CPU Registers


Mode Control Register


Interrupt Enable and Flag Registers


Serial Communications Control Register

\section*{ADDRESS ASSIGNMENTS AND MEMORY MAPS}

\section*{I/O AND INTERNAL REGISTER ADDRESS}
\begin{tabular}{|c|c|c|}
\hline \begin{tabular}{l}
ADDRESS \\
(HEX)
\end{tabular} & READ & WRITE \\
\hline \[
\begin{array}{r}
001 \mathrm{~F} \\
1 \mathrm{E} \\
1 \mathrm{D} \\
1 \mathrm{C}
\end{array}
\] & \begin{tabular}{l}
Lower Counter B \\
Upper Counter B \\
Lower Counter B, CLR Flag
\end{tabular} & Upper Latch B, Cntr B \(\longleftarrow\) Latch B; CLR Flag Upper Latch B, Latch C \(\longleftarrow\) Latch B Lower Latch B. \\
\hline \[
\begin{aligned}
& 1 B \\
& 1 A \\
& 19 \\
& 18
\end{aligned}
\] & \begin{tabular}{l}
Lower Counter A \\
Upper Counter A Lower Counter A, CLR Flag
\end{tabular} & \begin{tabular}{l}
Upper Latch A, Cntr A \(\longleftarrow\) Latch A, CLR Flag Upper Latch A \\
Lower Latch A
\end{tabular} \\
\hline \[
\begin{aligned}
& 17 \\
& 16 \\
& 15 \\
& 14
\end{aligned}
\] & Serial Receiver Data Register Serial Comm. Status Register Serial Comm. Control Register Mode Control Register & \begin{tabular}{l}
Serial Transmitter Data Register \\
Serial Comm. Status Reg. Bits 4 \& 5 only \\
Serial Comm. Control Register \\
Mode Control Register
\end{tabular} \\
\hline \[
\begin{array}{r}
13 \\
12 \\
11 \\
0010
\end{array}
\] & Interrupt Enable Register Interrupt Flag Register Read FF & \begin{tabular}{l}
Interrupt Enable Register \\
Clear Int Flag (Bits 0-3 only, Write 0's only)
\end{tabular} \\
\hline \begin{tabular}{l}
OF \\
OE \\
OD \\
OC
\end{tabular} &  & \[
\begin{aligned}
& -- \\
& -- \\
& --
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& \text { OB } \\
& 0 A \\
& 09 \\
& 08 \\
& \hline
\end{aligned}
\] & ——
——
—— & ——
——
—— \\
\hline \[
\begin{aligned}
& 07 \\
& 06 \\
& 05 \\
& 04
\end{aligned}
\] & \(\qquad\) & \(\qquad\) \\
\hline \[
\begin{array}{r}
03 \\
02 \\
01 \\
0000
\end{array}
\] & \begin{tabular}{l}
\(\qquad\)
\(\qquad\) \\
Port B Port A
\end{tabular} & \begin{tabular}{l}
Port B \\
Port A
\end{tabular} \\
\hline
\end{tabular}

MULTIPLEXED MODE MEMORY MAP


\section*{ELECTRICAL SPECIFICATIONS}

\section*{MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}} \& \mathrm{~V}_{\mathrm{RR}}\) & -0.3 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to +7.0 & Vdc \\
\hline \begin{tabular}{l} 
Operating Temperature \\
Commercial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & 0 to +70 & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\mathrm{STG}}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}
\(\left(V_{C C}=5 \mathrm{~V} \pm 5 \%, V_{R R}=V_{C C}, V_{S S}=0, T_{A}=0\right.\) to \(70^{\circ} \mathrm{C}\) except as noted \()\)
\begin{tabular}{|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ. & Max. & Unit \\
\hline Power Dissipation (Outputs High) Commercial @ \(0^{\circ} \mathrm{C}\) & \(P_{D}\) & - & & 1000 & mW \\
\hline RAM Standby Voltage (Retention Mode) & \(\mathrm{V}_{\mathrm{RR}}\) & 3.0 & - & \(\mathrm{V}_{\mathrm{CC}}\) & Vdc \\
\hline RAM Standby Current (Retention Mode) Commercial @ \(25^{\circ} \mathrm{C}\) & \(I_{\text {RR }}\) & - & 4 & - & mAdc \\
\hline Input High Voltage & \(\mathrm{V}_{\mathrm{IH}}\) & +2.0 & - & \(V_{C C}\) & Vdc \\
\hline Input High Voltage (XTLI) & \(\mathrm{V}_{\mathrm{IH}}\) & +4.0 & - & \(V_{C C}\) & Vdc \\
\hline Input Low Voltage & \(\mathrm{V}_{\mathrm{IL}}\) & -0.3 & - & +0.8 & Vdc \\
\hline Input Leakage Current ( \(\overline{\mathrm{RES}}, \overline{\mathrm{NMI}})\) \(\mathrm{V}_{\text {in }}=0\) to 5.0 Vdc & 1 IN & & & \(\pm 10.0\) & \(\mu \mathrm{Adc}\) \\
\hline Input Low Current PA, PB, and Address/Data
\[
\left(\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{Vdc}\right)
\] & \(\mathrm{I}_{\mathrm{LL}}\) & - & -1.0 & -1.6 & mAdc \\
\hline Output High Voltage (Except XTLO)
\[
\left(\mathrm{I}_{\text {LOAD }}=100 \mu \mathrm{Adc}\right)
\] & \(\mathrm{V}_{\mathrm{OH}}\) & +2.4 & - & \(\mathrm{V}_{\mathrm{CC}}\) & Vdc \\
\hline Output Low Voltage ( LOAD \(=1.6 \mathrm{mAdc}\) ) & \(\mathrm{V}_{\mathrm{OL}}\) & - & - & \(+0.4\) & Vdc \\
\hline Input Capacitance
\[
\begin{aligned}
& \left(\mathrm{V}_{\text {in }}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right) \\
& \text { PA, PB } \\
& \text { XTLI, XTLO }
\end{aligned}
\] & \(\mathrm{C}_{\text {in }}\) & - & - & \[
\begin{aligned}
& 10 \\
& 50
\end{aligned}
\] & pF \\
\hline I/O Port Pull-Up Resistance A0-A3, D0-D7; \(\overline{\mathrm{EMS}}, \mathrm{R} / \overline{\mathrm{W}}\) PA0-PA7, PB0-PB7 & \(\mathrm{R}_{\mathrm{L}}\) & 3.0 & 6.0 & 11.5 & \(K \Omega\) \\
\hline Output Capacitance
\[
\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}
\] & Cout & - & - & 10 & pF \\
\hline \multicolumn{6}{|l|}{Note: Negative sign indicates outward current flow, positive indicates inward flow.} \\
\hline
\end{tabular}

\section*{TYPICAL MEMORY HOOKUP}


\section*{TIMING REQUIREMENTS AND CHARACTERISTICS}

\section*{GENERAL NOTES}
1. \(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, 0^{\circ} \mathrm{C} \leq \mathrm{TA} \leq 70^{\circ} \mathrm{C}\)
2. A valid \(V_{c C}-\overline{R E S}\) sequence is required before proper operation is achieved.
3. All timing reference levels are 0.8 V and 2.0 V , unless otherwise specified.
4. All time units are nanoseconds, unless otherwise specified.
5. All capacitive loading is 130 pF maximum, except for Ports A and B which are 50 pF maximum.

\section*{CLOCK TIMING}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Symbol} & \multirow[b]{2}{*}{Parameter} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|r|}{2 MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min & Max & Min & Max & \\
\hline \(\mathrm{T}_{\text {CYC }}\) & Cycle Time & 1 & 10 & 0.5 & 10 & \(\mu \mathrm{S}\) \\
\hline \(\mathrm{T}_{\text {PWX1 }}\) & XTLI Input Clock Pulse Width (XTLO = VSS) & \[
\begin{aligned}
& 500 \\
& \pm 25
\end{aligned}
\] & - & \[
\begin{aligned}
& 250 \\
& \pm 10
\end{aligned}
\] & - & ns \\
\hline \(\mathrm{T}_{\text {PW02 }}\) & Output Clock Pulse Width at Minimum TCyc & \[
\begin{gathered}
\mathrm{T}_{\mathrm{PW} \times 1} \\
+0 \\
-25
\end{gathered}
\] & \(\mathrm{T}_{\text {Pwx } 1}\) & \[
\begin{gathered}
\mathrm{T}_{\mathrm{Pw} \mathrm{x}} \\
+0 \\
-20
\end{gathered}
\] & \(\mathrm{T}_{\mathrm{PWX} \times 1}\) & ns \\
\hline \(T_{R}, T_{F}\) & Output Clock Rise Fall Time & - & 25 & - & 15 & ns \\
\hline \(\mathrm{T}_{\text {IR }}, \mathrm{T}_{\text {IF }}\) & Input Clock Rise, Fall Time & - & 10 & - & 10 & ns \\
\hline
\end{tabular}


\section*{ADDRESS/DATA TIMING}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Symbol} & \multirow[b]{2}{*}{Parameter} & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} & \multirow[b]{2}{*}{Units} \\
\hline & & Min & Max & Min & Max & \\
\hline \(\mathrm{T}_{\text {PCRS }}\) & R/W Setup Time & - & 225 & - & 140 & ns \\
\hline \(\mathrm{T}_{\text {PCAS }}\) & Address Setup Time & - & 225 & - & 140 & ns \\
\hline \(\mathrm{T}_{\text {PBAS }}\) & Address Setup Time & - & 225 & - & 140 & ns \\
\hline \(\mathrm{T}_{\text {PBSU }}\) & Data Setup Time & 50 & - & 35 & - & ns \\
\hline \(\mathrm{T}_{\text {PBHR }}\) & Data Read Hold Time & 10 & - & 10 & - & ns \\
\hline TPBHW & Data Write Hold Time & 30 & - & 30 & - & ns \\
\hline \(\mathrm{T}_{\text {PBDD }}\) & Data Output Delay & - & 175 & - & 150 & ns \\
\hline \(\mathrm{T}_{\text {PCHA }}\) & Address Hold Time & 30 & - & 30 & - & ns \\
\hline \(\mathrm{T}_{\text {PBHA }}\) & Address Hold Time & 10 & 100 & 10 & 80 & ns \\
\hline \(\mathrm{T}_{\text {PCHR }}\) & R/W Hold Time & 30 & - & 30 & - & ns \\
\hline \(\mathrm{T}_{\text {PCHV }}\) & EMS Hold Time & 10 & - & 10 & - & ns \\
\hline \(\mathrm{T}_{\text {PCVD }}{ }^{(1)}\) & Address to EMS Delay Time & 30 & - & 30 & - & ns \\
\hline \(\mathrm{T}_{\text {PCVP }}\) & EMS Stabilization Time & 30 & - & 30 & - & ns \\
\hline \(\mathrm{T}_{\text {ESU }}\) & \(\overline{\mathrm{EMS}}\) Setup Time & - & 350 & - & 210 & ns \\
\hline
\end{tabular}

Note 1: Values assume Address and \(\overline{E M S}\) have the same capacitive load.


I/O, EDGE DETECT, COUNTERS, AND SERIAL I/O TIMING
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Symbol} & \multirow[b]{2}{*}{Parameter} & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} \\
\hline & & Min & Max & Min & Max \\
\hline \[
\begin{aligned}
& T_{\text {PDW }}{ }^{(1)} \\
& T_{\mathrm{CMOS}^{(1)}}
\end{aligned}
\] & \begin{tabular}{l}
Internal Write to Peripheral Data Valid PA, PB, TTL \\
PA, PB, CMOS
\end{tabular} & - & \[
\begin{array}{r}
500 \\
1000
\end{array}
\] & - & \[
\begin{array}{r}
500 \\
1000
\end{array}
\] \\
\hline \(\mathrm{T}_{\text {PDSU }}\) & Peripheral Data Setup Time PA, PB & 200 & - & 200 & - \\
\hline \(\mathrm{T}_{\text {PHR }}\) & Peripheral Data Hold Time PA, PB & 75 & - & 75 & - \\
\hline \(\mathrm{T}_{\text {EPW }}\) & PA0-PA3 Edge Detect Pulse Width & \(\mathrm{T}_{\mathrm{CYC}}\) & - & \(\mathrm{T}_{\mathrm{CYC}}\) & - \\
\hline \(T_{\text {CPW }}\)
\[
T_{C D^{1)}}
\] & \begin{tabular}{l}
Counters \(A\) and \(B\) \\
PA4, PA5 Input Pulse Width PA4, PA5 Output Delay
\end{tabular} & \(T_{\mathrm{CYC}}\) & \[
\overline{500}
\] & \(\mathrm{T}_{\text {CYC }}\) & \[
\overline{500}
\] \\
\hline \begin{tabular}{l}
\(T_{\text {PBLW }}\) \\
\(\mathrm{T}_{\text {PLSU }}\) \\
\(T_{\text {PBLH }}\)
\end{tabular} & Port B Latch Mode PAO Strobe Pulse Width PB Data Setup Time PB Data Hold Time & \[
\begin{gathered}
T_{\text {CYC }} \\
175 \\
30
\end{gathered}
\] & - & \[
\begin{gathered}
\mathrm{T}_{\mathrm{CYC}} \\
150 \\
30
\end{gathered}
\] & - \\
\hline \begin{tabular}{l}
\(T_{\text {PDW }}{ }^{(1)}\) \\
\(\mathrm{T}_{\text {CMOS }}{ }^{(1)}\) \\
\(\mathrm{T}_{\mathrm{CPW}}\) \\
\(\mathrm{T}_{\text {PDW }}{ }^{(1)}\) \\
\(\mathrm{T}_{\mathrm{CMOS}}{ }^{(1)}\)
\end{tabular} & \begin{tabular}{l}
Serial I/O \\
PA6 XMTR TTL \\
PA6 XMTR CMOS \\
PA4 RCVR S/R Clock Width PA4 XMTR Clock-S/R Mode (TTL) PA4 XMTR Clock-S/R Mode (CMOS)
\end{tabular} & \(4 T_{C Y C}\) & \[
\begin{array}{r}
500 \\
1000 \\
- \\
500 \\
1000
\end{array}
\] & \[
\begin{gathered}
- \\
4 \mathrm{~T}_{\mathrm{CYC}} \\
- \\
-
\end{gathered}
\] & \[
\begin{array}{r}
500 \\
1000 \\
- \\
500 \\
1000
\end{array}
\] \\
\hline
\end{tabular}

Notes: 1. Maximum load capacitance: 50 pF ; passive pull-up required.
2. All times are in nanoseconds.

I/O, EDGE DETECT, COUNTER, AND SERIAL I/O TIMING


\section*{PACKAGE DIMENSIONS}

\section*{40-PIN PLASTIC DIP}

\begin{tabular}{|c|c|c|c|c|}
\hline & \multicolumn{2}{|c|}{ MILLIMETERS } & \multicolumn{2}{c|}{ INCHES } \\
\cline { 2 - 5 } DIM & MIN & MAX & MIN & MAX \\
\hline A & 51.28 & 52.32 & 2.040 & 2.060 \\
\hline B & 1372 & 14.22 & 0.540 & 0.560 \\
\hline C & 3.55 & 5.06 & 0140 & 0200 \\
\hline D & 0.36 & 0.51 & 0.014 & 0020 \\
\hline F & 1.02 & 1.52 & 0.040 & 0.060 \\
\hline G & \multicolumn{2}{|c|}{2.54} & BSC & \multicolumn{2}{c|}{0.100} & BSC \\
\hline H & 1.65 & 2.16 & 0.065 & 0.085 \\
\hline J & 0.20 & 030 & \multicolumn{2}{|c|}{0.008} \\
\hline K & 3.30 & 4.32 & 0.012 \\
\hline L & \multicolumn{2}{|c|}{15.24} & BSC & \multicolumn{2}{c|}{0.600} & 0.170 \\
\hline M & \multicolumn{2}{|c|}{\(7^{\circ}\)} & \(10^{\circ}\) & \multicolumn{2}{c|}{\(7^{\circ}\)} & \(10^{\circ}\) \\
\hline N & \multicolumn{2}{|c|}{0.51} & 102 & \multicolumn{2}{c|}{0.020} & 0.040 \\
\hline
\end{tabular}

\section*{44-PIN PLASTIC LEADED CHIP CARRIER (PLCC) \\ TOP VIEW \\ CHAM.J \(\times 45^{\circ}\) \\ SIDE VIEW \\ SECTION A-A TYP FOR BOTH AXIS (EXCEPT FOR BEVELED EDGE) \\ EJECTOR PIN MARKS \\ 4 PLCS BOTTOM OF \\ PACKAGE ONLY \\ (TYPICAL) \\ BOTTOM VIEW \\  \\  \\ (TYPICAL) 11 PINS EQUALLY SPACES \\ \begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{ DIM } & \multicolumn{2}{|c|}{ MILLIMETERS } & \multicolumn{2}{c|}{ INCHES } \\
\cline { 2 - 5 } & MIN & MAX & MIN & MAX \\
\hline A & 414 & 4.39 & 0.163 & 0173 \\
\hline A1 & 137 & 1.47 & 0054 & 0058 \\
\hline A2 & 2.31 & 246 & 0091 & 0097 \\
\hline b & \multicolumn{2}{|c|}{0457 TYP } & \multicolumn{2}{|c|}{0018 TYP } \\
\hline D & 1745 & 1760 & 0687 & 0693 \\
\hline D1 & 1646 & 16.56 & 0.648 & 0652 \\
\hline D2 & 1262 & 1278 & \multicolumn{2}{|c|}{0497} & 0503 \\
\hline D3 & \multicolumn{2}{|c|}{15.75 REF } & \multicolumn{2}{|c|}{0.620 REF } \\
\hline e & \multicolumn{2}{|c|}{127 BSC } & \multicolumn{2}{|c|}{0050 BSC } \\
\hline h & \multicolumn{2}{|c|}{115 TYP } & \multicolumn{2}{|c|}{0045 TYP } \\
\hline J & \multicolumn{2}{|c|}{0.25 TYP } & \multicolumn{2}{|c|}{0010 TYP } \\
\hline\(\alpha\) & \multicolumn{2}{|c|}{\(45^{\circ}\) TYP } & \multicolumn{2}{|c|}{\(45^{\circ}\) TYP } \\
\hline R & \multicolumn{2}{|c|}{089 TYP } & \multicolumn{2}{|c|}{0.035 TYP } \\
\hline R1 & \multicolumn{2}{|c|}{025 TYP } & \multicolumn{2}{|c|}{0010 TYP } \\
\hline
\end{tabular} \\ CHAM. \(3 \times 45^{\circ}\) 3 PLCS}

\title{
R65F11 and R65F12 FORTH Based Microcomputers
}

\section*{SECTION 1 INTRODUCTION}

\subsection*{1.1 FEATURES}
- FORTH kernel in ROM
- Enhanced 6502 CPU
-Four new bit manipulation instructions:
Set Memory Bit (SMB)
Reset Memory Bit (RMB)
Branch on Bit Set (BBS)
Branch on Bit Reset (BBR)
-Decimal and binary arithmetic modes
-13 addressing modes
-True indexing
- 192-byte static RAM
- 16 bidirectional, TTL-compatible I/O lines (two ports, R65F11) or 40 bidirectional, TTL-compatible I/O lines (five ports, R65F12)
- One 8 -bit port with programmable latched input
- Two 16 -bit programmable counter/timers, with latches
-Pulse width measurement
-Asymmetrical pulse generation
-Pulse generation
-Interval timer
—Event counter
-Retriggerable interval timer
- Serial port
-Full-duplex asynchronous operation mode
-Selectable 5- to 8-bit characters
-Wake-up feature
-Synchronous shift register mode
-Standard programmable bit rates, programmable up to 62.5 K bits/sec
- Ten interrupts
-Four edge-sensitive lines; two positive, two negative
—Reset
-Non-maskable
-Two counter
-Serial data received
-Serial data transmitted
- Expandable to 16 K bytes of external memory
- Flexible clock circuitry
\(-2-\mathrm{MHz}\) or \(1-\mathrm{MHz}\) internal operation
-Internal clock with external XTAL at two times internal frequency
-External clock input divided by one or two
- \(1 \mu \mathrm{~s}\) minimum instruction execution time @ 2 MHz
- NMOS silicon gate, depletion load technology
- Single +5 V power supply
- 12 mW standby power for 32 bytes of the 192-byte RAM
- 40-pin DIP (R65F11)
- 64-pin QUIP (R65F12) has three additional 8-bit I/O ports to provide a total of \(40 \mathrm{I} / \mathrm{O}\) lines.

\subsection*{1.2 SUMMARY}

The Rockwell R65F11 and R65F12 are complete, high-performance, 8 -bit NMOS single chip microcomputers, and are compatible with all members of the R6500 family.

The kernel of the high level Rockwell Single Chip RSC-FORTH language is contained in the preprogrammed ROM of the R65F11 and R65F12. RSC-FORTH is based on the popular fig-FORTH model with extensions. All of the run time functions of RSCFORTH are contained in the ROM, including 16 - and 32 -bit mathematical, logical and stack manipulation, plus memory and input/output operators. The RSC-FORTH Operating System allows an external user program written in RSC-FORTH or Assembly Language to be executed from external EPROM, or development of such a program under the control of the R65FR1 RSC-FORTH Development ROM. Other development ROM's can also be accommodated.

The R65F11 and R65F12 consist of an enhanced 6502 CPU, an internal clock oscillator, 192 bytes of Random Access Memory (RAM) and versatile interface circuitry. The interface circuitry includes two 16 -bit programmable timer/counters, 16 bidirectional input/output lines (including four edge-sensitive lines and input latching on one 8 -bit port), a full-duplex serial I/O channel, ten interrupts and bus expandability.

The innovative architecture and the demonstrated high performance of the R6502 CPU, as well as instruction simplicity, results in system cost-effectiveness and a wide range of
computational power. These features in combination with the FORTH high level operating system make the R65F11 and R65F12 ideal for microcomputer applications.

For systems requiring additional I/O ports, the 64-pin QUIP version, the R65F12, provides three additional 8-bit ports.

A complete RSC-FORTH development system can be created with three MOS parts: the R65F11, one RAM chip and the R65FR1 Development ROM.

This product description is for the reader familiar with the R6502 CPU hardware and programming capabilities. A detailed description of the R6502 CPU hardware is included in the R6500 Microcomputer System Hardware Manual
(Order Number 201). A description of the instruction capabilites of the R6502 CPU is contained in the R6500 Microcomputer System Programming Manual (Order Number 202).

\subsection*{1.3 ORDERING INFORMATION}
\begin{tabular}{|c|c|}
\hline Part No. & Description \\
\hline R65F11P & 40-Pin FORTH Based Microcomputer at 1 MHz \\
\hline R65F11AP & 40-Pin FORTH Based Microcomputer at 2 MHz \\
\hline R65F12Q & \(64-\mathrm{Pin}\) FORTH Based Microcomputer at 1 MHz \\
\hline R65F12AQ & 64-Pin FORTH Based Microcomputer at 2 MHz \\
\hline R65FR1P & FORTH Development ROM for R65F11 or R65F12 \\
\hline R65FR2P & FORTH Development ROM for expanded capacity \\
\hline R65FK2P & FORTH Kernel ROM for expanded capacity development \\
\hline R65FR3P & FORTH Development ROM for R6501Q \\
\hline R65FK3P & FORTH Kernel ROM for R6501Q \\
\hline Order No. & Description \\
\hline 2148 & FORTH Based Microcomputer User's Manual* \\
\hline \begin{tabular}{l}
Note: \\
*Included w
\end{tabular} & R65FR1. \\
\hline
\end{tabular}

\section*{SECTION 2 \\ INTERFACE REQUIREMENTS}

This section describes the interface requirements for the R65F11 and R65F12 single chip microcomputers. Figure 2-1 is the Interface Diagram for the R65F11 and R65F12, Figure 2-2 shows the pin out configuration and Table 2-1 describes the function of each pin of the R65F11 and R65F12. Figure \(3-1\) is a detailed block diagram.


Figure 2-1. R65F11 and R65F12 Interface Diagram

Table 2-1. R65F11 and R65F12 Pin Descriptions
\begin{tabular}{|c|c|c|c|}
\hline Signal Name & Pin No. R65F11 & Pin No. R65F12 & Description \\
\hline \(V_{\text {cc }}\) & 21 & 50 & Main power supply +5V \\
\hline \(V_{\text {RR }}\) & 39 & 12 & Separate power pin for RAM. In the event that \(\mathrm{V}_{\mathrm{cc}}\) power is lost, this power retains RAM data. \\
\hline \(\mathrm{V}_{\text {Ss }}\) & 40 & 11 & Signal and power ground (OV) \\
\hline XTLI & 2 & 10 & Crystal or clock input for internal clock oscillator. Also allows input of X 1 clock signal if XTLO is connected to \(\mathrm{V}_{\mathrm{Ss}}\), or X 2 or X 4 clock if XTLO is floated. \\
\hline XTLO & 1 & 9 & Crystal output from internal clock oscillator. \\
\hline \(\overline{\text { RES }}\) & 20 & 41 & The Reset input is used to initialize the R65F11. This signal must not transition from low to high for at least eight cycles after \(\mathrm{V}_{\mathrm{cc}}\) reaches operating range and the internal oscillator has stabilized. \\
\hline \$2 & 3 & 13 & Clock signal output at internal frequency. \\
\hline \(\overline{\text { NMI }}\) & 22 & 51 & A negative going edge on the Non-Maskable Interrupt signal requests that a nonmaskable interrupt be generated within the CPU. \\
\hline PAO-PA7 & 30-23 & 64-57 & Two 8-bit ports used for either \\
\hline PB0-PB7 & 38-31 & 8-1 & input/output. Each line of Ports A and B consist of an active transistor to \(\mathrm{V}_{\mathrm{SS}}\) and a passive pull-up to \(\mathrm{V}_{\mathrm{Cc}}\). \\
\hline \[
\begin{aligned}
& \text { PCO-PC7 } \\
& \text { AO-A3 } \\
& \text { A12, } \bar{R} \bar{W} \\
& \text { A13, } \overline{E M S}
\end{aligned}
\] & 4-11 & 25-32 & Port C has an active pull-up transistor. Port D has active pull-up and pull-down transistors. Ports C and D lines form the external multiplexed \\
\hline \[
\begin{aligned}
& \text { PD0-PD7 } \\
& \text { A4-A11 } \\
& \text { D0-D7 }
\end{aligned}
\] & 19-12 & 40-33 & address and data bus to allow external memory addressing. \\
\hline PE0-PE7 & & 49-42 & On the R65F12, Port E may \\
\hline PF0-PF7 & & 24-17 & be used for output only. Ports \\
\hline PG0-PG4 & & 52-56, & F and G are similar to Ports \\
\hline PG5-PG7 & & 14-16 & \(A\) and \(B\) in construction and may be used for inputs or outputs. \\
\hline
\end{tabular}


Figure 2-2. Pin Out Configuration

\title{
SECTION 3 SYSTEM ARCHITECTURE
}

This section provides a functional description of the R65F11 and R65F12. Functionally the R65F11 consists of a CPU, RAM memory, two 8 -bit parallel I/O ports (five in the 64 -pin R65F12), a serial //O port, dual counter/latch circuits, a mode control register, an interrupt flag/enable dual register circuit, and an internal Operating System. The kernel of FORTH in ROM complements the system hardware. A block diagram of the system is shown in Figure 3-1.

\section*{NOTE}

Throughout this document, unless specified otherwise, all memory or register address locations are specified in hexadecimal notation.

\subsection*{3.1 CPU LOGIC}

The R65F11 internal CPU is a standard 6502 configuration with an 8-bit Accumulator register, two 8-bit Index Registers ( X and Y ); an 8-bit Stack Pointer register, and ALU, a 16-bit Program Counter, and standard instruction register/decode and internal timing control logic.

\subsection*{3.1.1 Accumulator}

The accumulator is a general purpose 8 -bit register that stores the results of most arithmetic and logic operations. In addition, the accumulator usually contains one of the two data words used in these operations.

\subsection*{3.1.2 Index Registers}

There are two 8 -bit index registers, \(X\) and \(Y\). Each index register can be used as a base to modify the address data program counter and thus obtain a new address-the sum of the program counter contents and the index register contents.

When executing an instruction which specifies indirect addressing, the CPU fetches the op code and the address, and modifies the address from memory by adding the index register to it prior to loading or storing the value of memory.

Indexing greatly simplifies many types of programs, especially those using data tables.

\subsection*{3.1.3 Stack Pointer}

The Stack Pointer is an 8 -bit register. It is automatically incremented and decremented under control of the microprocessor to perform stack manipulation in response to either user instructions, an internal \(\overline{\mathrm{RQ}}\) interrupt, or the external interrupt line NMI. The Stack Pointer must be initialized by the user program.

The stack allows simple implementation of multiple level interrupts, subroutine nesting and simplification of many types of data manipulation. The JSR, BRK, RTI and RTS instructions use the stack and Stack Pointer.

The stack can be envisioned as a deck of cards which may only be accessed from the top. The address of a memory location is stored (or "pushed") onto the stack. Each time data are to be pushed onto the stack, the Stack Pointer is placed on the Address Bus, data are written into the memory location addressed by the Stack Pointer, and the Stack Pointer is decremented by 1 . Each time data are read (or "pulled") from the stack, the Stack Pointer is incremented by 1. The Stack Pointer is then placed on the Address Bus, and data are read from the memory location addressed by the Pointer.

The stack is located on zero page, i.e., memory locations 00FF-0040. After reset, which leaves the Stack Pointer indeterminate, normal usage calls for its initialization at 00FF.

\subsection*{3.1.4 Processor Status Register}

The 8 -bit Processor Status Register contains seven status flags. Some of these flags are controlled by the user program; others may be controlled both by the user's program and the CPU. The R6500 instruction set contains a number of conditional branch instructions which are designed to allow testing of these flags. See Appendix B for details.

\subsection*{3.1.5 Program Counter}

The 16 -bit Program Counter provides the addresses that are used to step the processor through sequential instructions in a program. Each time the processor fetches an instruction from program memory, the lower (least significant) byte of the Program Counter (PCL) is placed on the low-order bits of the Address Bus and the higher (most significant) byte of the Program Counter \((\mathrm{PCH})\) is placed on the high-order 8 bits of the Address Bus. The Counter is incremented each time an instruction or data is fetched from program memory.

\subsection*{3.1.6 Arithmetic And Logic Unit (ALU)}

Each bit of the ALU has two inputs. These inputs can be tied to various internal buses or to a logic zero; the ALU then generates the function (AND, OR, SUM, and so on) using the data on the two inputs.

\subsection*{3.1.7 Instruction Register and Instruction Decode}

Instructions are fetched from ROM or RAM and gated onto the Internal Data Bus. These instructions are latched into the Instruction Register then decoded along with timing and interrupt signals to generate control signals for the various registers.


Figure 3-1. Detailed Block Diagram

\subsection*{3.1.8 Timing Control}

The Timing Control Logic keeps track of the specific instruction cycle being executed. This logic is set to TO each time an instruction fetch is executed and is advanced at the beginning of each Phase One clock pulse for as many cycles as are required to complete the instruction. Each data transfer which takes place between the registers is caused by decoding the contents of both the instruction register and timing control unit.

\subsection*{3.1.9 Interrupt Logic}

Interrupt logic controls the sequencing of three interrupts; \(\overline{\mathrm{RES}}, \overline{\mathrm{NMI}}\) and \(\overline{\mathrm{IRQ}} . \overline{\mathrm{IRQ}}\) is generated by any one of eight conditions: 2 Counter Overflows, 2 Positive Edge Detects, 2 Negative Edge Detects, and 2 Serial Port Conditions.

\subsection*{3.2 CPU INSTRUCTION SET}

The machine code instruction set of the R65F11 and R65F12 microcomputers are based on the popular R6500 microprocessor set. They contain all the instructions in the standard R6502 set, with the addition of the four new bit instructions added to the R6511 processor family. Refer to Appendix A for the Op Code mnemonics addressing matrix for details on these instructions.

\subsection*{3.3 READ-ONLY-MEMORY (ROM)}

The ROM consists of preprogrammed memory with an address space from F400 to FFFF. It contains the run time kernel of the high level language Rockwell Single Chip FORTH. There are 133 included functions stored in the ROM. Codes are in the format of a two byte code field, which identifies the interpreter assigned to execute that word, followed by a variable length Parameter Field, which contains the instructions and data used by that interpreter according to the programmed intention of that definition. See Appendix D for a complete list of the names of all included words. All words needed for support of the run time operation of dedicated applications programs are included. The RSC-FORTH Operating System is also part of the ROM code and is entered upon Reset. This Operating System allow the R65F11 and R65F12 to auto start a user program written in either RSC-FORTH or Assembly Language or enter a Development ROM if one is present. If no auto start program is found, an attempt will be made to boot an operating program from floppy disk.

\subsection*{3.4 RANDOM ACCESS MEMORY (RAM)}

The RAM consists of 192 bytes of read/write memory with an assigned page zero address of 0040 through 00FF. The R65F11 and R65F12 provide a separate power pin ( \(V_{R R}\) ) which may be used for standby power for 32 bytes located at 0040-005F. In the event of the loss of \(\mathrm{V}_{\mathrm{cc}}\) power, the lowest 32 bytes of RAM data will be retained if standby power is supplied to the \(V_{R R}\) pin. If the RAM data retention is not required then \(V_{R R}\) must be connected to \(V_{C C}\). During operation \(V_{R R}\) must be at the \(V_{C C}\) level.

For the RAM to retain data upon loss of \(V_{C C}, V_{R R}\) must be supplied within operating range and \(\overline{\text { RES }}\) must be driven low at least eight \(\phi 2\) clock pulses before \(V_{c c}\) falls out of operating range. \(\overline{\operatorname{RES}}\) must then be held low while \(V_{c c}\) is out of operating range and until at least eight \(\phi 2\) clock cycles after \(V_{C C}\) is again within operating range and the internal \(\varnothing 2\) oscillator is stabilized. \(V_{R R}\) must remain within \(V_{C C}\) operating range during normal operation. When \(V_{C C}\) is out of operating range, \(V_{R R}\) must remain within the \(V_{R R}\) retention range in order to retain data. Figure 3-2 shows typical waveforms.


Figure 3-2. Data Retention Timing

\subsection*{3.5 CLOCK OSCILLATOR}

A reference frequency can be generated with the on-chip oscillator using an external crystal. The oscillator reference frequency passes through an internal countdown network (divide by 2 ) to obtain the internal operating frequency.
The on-chip oscillator is designed for a parallel resonant crystal connected between XTLI and XTLO pins. The equivalent oscillator circuit is shown in Figure 3-3a.
A parallel resonant crystal is specified by its load capacitance and series resonant resistance. For proper oscillator operation, the load capacitance \(\left(C_{L}\right)\), series resistance \(\left(R_{S}\right)\) and the crystal resonant frequency \((F)\) must meet the following two relations:
\[
\begin{aligned}
& (\mathrm{C}+27)=2 \mathrm{C}_{\mathrm{L}} \quad \text { or } \quad \mathrm{C}=2 \mathrm{C}_{\mathrm{L}}-27 \mathrm{pF} \\
& \mathrm{R}_{\mathrm{S}} \leq \mathrm{R}_{\mathrm{smax}}=\frac{2 \times 10^{6}}{\left(\mathrm{FC}_{\mathrm{L}}\right)^{2}} \mathrm{~F} \text { in } \mathrm{MHz} ; \mathrm{C}_{\mathrm{L}} \text { in } \mathrm{pF}
\end{aligned}
\]

To select a parallel resonant crystal for the oscillator, first select the load capacitance from a Crystal Manufacturer's catalog. Next, calculate \(R_{\text {smax }}\) based on \(F\) and \(C_{L}\). The selected crystal must have a \(R_{s}\) less than the \(R_{s m a x}\).
For example, if \(C_{L}=22 \mathrm{pF}\) for a 4 MHz parallel resonant crystal, then
\[
\begin{aligned}
& \mathrm{C}=(2 \times 22)-27=17 \mathrm{pF} \\
& \text { (use standard value, } 18 \mathrm{pF} \text { ) }
\end{aligned}
\]

The series resistance of the crystal must be less than
\[
\mathrm{R}_{\mathrm{smax}}=\frac{2 \times 10^{6}}{(4 \times 22)^{2}}=258 \text { ohms }
\]

Internal timing can also be controlled by driving the XTLI pin with an external frequency source. Figure 3-3b shows typical connections. If XTLO is left floating, the external source is divided by the internal countdown network. However, if XTLO is tied to \(\mathrm{V}_{\mathrm{SS}}\), the internal coundown network is bypassed casuing the chip to operate at the freqency of the external source.

The R65F11 and R65F12 operate in the CLOCK MASTER mode. In this mode a frequence source (crystal or external source) must be applied to the XTLI and XTLO pins.

ф2 is a buffered output signal which closely approximates the internal timing. When a common external source is used to drive multiple devices the internal timing between devices as well as their \(\emptyset 2\) outputs will be skewed in time. If skewing represents a system problem it can be avoided by the Master/Slave connection and options shown in Figure 3-4.

The R65F11 and R65F12 is operated in the CLOCK MASTER MODE. A second processor could be operated in the CLOCK SLAVE MODE. Mask options in the SLAVE unit convert the \(\emptyset 2\) signal into a clock input pin which is tightly coupled to the internal timing generator. As a result, the internal timing of the MASTER and SLAVE units are synchronized with minimum skew. If the \(\emptyset 2\) signal to the SLAVE unit is inverted, the MASTER and SLAVE UNITS WILL OPERATE OUT OF PHASE. This approach allows the two devices to share external memory using cycle stealing techniques.


Figure 3-3. Clock Oscillator Input Options


Figure 3-4. Master/Slave Connections

\subsection*{3.6 MODE CONTROL REGISTER (MCR)}

The Mode Control Register contains bits for the multifunction I/O ports and mode select bits for Counter A and Counter B. Its setting, along with the setting of the Serial Communications Control Register (SCCR), determines the basic configuration of the R65F11 and R65F12 in any application. The Model Control Register bit assignment is shown in Figure 3-5. MCR Bits 7, 6, 5 must remain 1's in order for external memory referencing to be enabled.


Figure 3-5. Mode Control Register

The use of Counter A Mode Select is shown in Section 6.1.

The use of Counter B Mode Select is shown in Section 6.2.
The use of Port B Latch Enable is shown in Section 4.4.

\subsection*{3.7 INTERRUPT FLAG REGISTER (IFR) AND INTERRUPT ENABLE REGISTER (IER)}

An \(\overline{\mathrm{RQ}}\) interrupt request can be initiated by any or all of eight possible sources. These sources are all capable of being enabled or disabled by the use of the appropriate interrupt enabled bits in the Interrupt Enable Register (IER). Multiple simultaneous interrupts will cause the \(\overline{\mathrm{IQ}}\) interrupt request to remain active until all interrupting conditions have been serviced and cleared.

The Interrupt Flag Register contains the information that indicates which VO or counter needs attention. The contents of the Interrupt Flag Register may be examined at any time by reading at address: 0011. Edge detect IFR bits may be cleared in low level code by executing a RMB instruction at address location 0010. The RMB X, (0010) instruction reads \(F F\), modifies bit \(X\) to a " 0 ", and writes the modified value at address location 0011. In this way IFR bits set to a "1" after the read cycle of a Read-Modify-Write instruction (such as RMB) are protected from being cleared. A logic " 1 " is ignored when writing to edge detect IFR bits.

Each IFR bit has a corresponding bit in the Interrupt Enable Register which can be set to a "1" by writing a "1" in the respective bit position at location 0012. Individual IER bits may be cleared by writing a " 0 " in the respective bit position, or by \(\overline{\mathrm{RES}}\). If set to a "1", an IRQ will be generated when the corresponding IFR bit becomes true. The Interrupt Flag Register and Interrupt Enable Register bit assignments are shown in Figure 3-6 and the functions of each bit are explained in Table 3-1.


Figure 3-6. Interrupt Enable and Flag Registers

Table 3-1. Interrupt Flag Register Bit Codes
\begin{tabular}{|c|c|}
\hline Bit Code & Function \\
\hline IFR 0: & PAO Positive Edge Detect Flag-Set to a "1" when a positive going edge is detected on PAO. Cleared by RMB O (0010) instruction or by \(\overline{\mathrm{RES}}\). \\
\hline IFR 1: & PA1 Positive Edge Detect Flag-Set to a 1 when a positive going edge is detected on PA1. Cleared by RMB 1 (0010) instruction or by RES. \\
\hline IFR 2: & PA2 Negative Edge Detect Flag-Set to a 1 when a negative going edge is detected on PA2. Cleared by RMB 2 (0010) instruction or by RES. \\
\hline IFR 3: & PA3 Negative Edge Detect Flag-Set to 1 when a negative going edge is detected on PA3. Cleared by RMB 3 (0010) instruction or by \(\overline{\text { RES }}\). \\
\hline IFR 4: & Counter A Underflow Flag-Set to a 1 when Counter A underflow occurs. Cleared by reading the Lower Counter A at location 0018, by writing to address location 001A, or by RES. \\
\hline IFR 5: & Counter B Underflow Flag-Set to a 1 when Counter B underflow occurs. Cleared by reading the Lower Counter B at location 001C, by writing to address location 001E, or by RES. \\
\hline IFR 6: & Receiver Interrupt Flag-Set to a 1 when any of the Serial Communication Status Register bits 0 through 3 is set to a 1. Cleared when the Receiver Status bits (SCSR 0-3) are cleared or by RES. \\
\hline IFR 7: & Transmitter Interrupt Flag-Set to a 1 when SCSR 6 is set to a 1 while SCSR 5 is a 0 or SCSR 7 is set to a 1. Cleared when the Transmitter Status bits (SCSR \(6 \& 7\) ) are cleared or by \(\overline{\mathrm{RES}}\). \\
\hline
\end{tabular}

\subsection*{3.8 OPERATING SYSTEM}

The system startup function, COLD, is executed upon Reset. COLD, a high level FORTH word, forms the basis of the RSC Operating System. Upon reset this function initializes the R65F11 or R65F12 registers to establish the external 16K byte memory map and disable all interrupt sources. It also sets up the serial channel for 1200 baud (assuming a 1 MHz internal clock) asynchronous transmission (seven bits, parity disabled). The internal FORTH structure " \(W\) " is prepared for use and the low level input/output vectors are forced to point to the system serial channel routines. The FORTH User Area Pointer, UP, is assigned the value 0300 Hex.

A test is made of the variable CLD/WRM in memory location 030E. If this contains a value other than A55A Hex a cold reset is assumed. In this case, the low level IRQ vector, IRQVEC; the low level NMI Vector, NMIVEC, and the high level interrupt vector, INTVEC, are all forced to point to the system reset routine. This prevents an unintentionally generated interrupt from crashing the system. System variables TIB, RO, SO, UC/L, UPAD, UR/W and BASE are also initialized to their default values.

Whether a warm or cold reset, the memory map is then searched at every 1 K byte boundary starting at location 0400 Hex. The first two bytes at each boundary are checked against an A55A Hex bit pattern. This pattern indicates that an auto start program is installed. The next two bytes are assumed to point to the Parameter Field of the high level RSC-FORTH word to be executed upon reset. This may be the main function of a user defined program or the start up routine of a Development ROM. Figure 3-7 details proper alignment.

If no auto start ROM is found, the Operating System turns control over to a program that issues a "NO ROM" message to the systems terminal via the serial channel and attempts to boot a program from disk. A floppy disk controller, compatible with the WD1793 type, is assumed to be present at address 0100 Hex. The first half of Track 0 Sector 1 is loaded from a double density boot diskette into RAM starting at address 005F. When successfully loaded execution will be turned over to this boot program.


Figure 3-7. Auto Start ROM

\section*{SECTION 4 PARALLEL INPUT/OUTPUT PORTS}

The R65F11 has 16 VO lines grouped into two 8 -bit ports (PA, PB) and 16 lines programmed as an Address/Data bus (PC \& PD). Ports A and B may be used either for input or output individually or in groups of any combination. The R65F12 has 24 additional port lines grouped into three 8 -bit ports (PE, PF, PG).

Multifunction I/O's such as Port A are protected from normal port I/O instructions when they are programmed to perform a multiplexed function.

Internal pull-up resistors (FET's with an impedance range of \(3 \mathrm{~K} \leqslant \mathrm{Rpu} \leqslant 12 \mathrm{~K}\) ohm) are provided on all port pins.

The direction of the I/O lines are controlled by 8 -bit port registers located in page zero. This arrangement provides quick programming access using simple two-byte zero page address instructions. There are no direction registers associated with the I/O ports, which simplifies I/O handling. The //O addresses are shown in Table 4-1.

Table 4-1. I/O Port Addresses
\begin{tabular}{|c|c|}
\hline Port & Address \\
\hline A & 0000 \\
B & 0001 \\
E & 0004 \\
F & 0005 \\
G & 0006 \\
\hline
\end{tabular}

Appendix F. 4 shows the I/O Port Timing.

\subsection*{4.1 INPUTS}

Inputs for Ports \(A\) and \(B\) are enabled by loading logic 1 into all I/O port register bit positions that are to correspond to //O input lines. A low ( \(<0.8 \mathrm{~V}\) ) input signal will cause a logic 0 to be read when a read instruction is issued to the port register. A high ( \(>2.0 \mathrm{~V}\) ) input will cause a logic 1 to be read. An RES signal forces all I/O port registers to logic 1 thus initially treating all I/O lines as inputs.

The status of the input lines can be interrogated at any time by reading the I/O port addresses. Note that this will return the actual status of the input lines, not the data written into the I/O port registers.

Read/Modify/Write instructions can be used to modify the operation of PA and PB. During the Read cycle of a Read/ Modify/Write instruction the Port VO register is read. For all other read instructions the port input lines are read. Read/ Modify/Write instructions are: ASL, DEC, INC, LSR, RMB, ROL, ROR, and SMB.

\subsection*{4.2 OUTPUTS}

Outputs for Ports A and B are controlled by writing the desired I/O line output states into the corresponding I/O port register bit positions. A logic 1 will force a high ( \(>2.4 \mathrm{~V}\) ) output while a logic 0 will force a low ( \(<0.4 \mathrm{~V}\) ) output.

\subsection*{4.3 PORT A (PA)}

Port A can be programmed via the Mode Control Register (MCR) and the Serial Communications Control Register (SCCR) as a standard parallel 8-bit, bit independent, l/O port or as serial channel I/O lines, counter VO lines, or an input data strobe for the Port B input latch option. Table 4-3 tabulates the control and usage of Port A.

In addition to their normal I/O functions, PAO and PA1 can detect positive going edges, and PA2 and PA3 can detect negative going edges. A proper transition on these pins will set a corresponding status bit in the IFR and generate ah interrupt request if the respective Interrupt Enable Bit is set. The maximum rate at which an edge can be detecte \(d\) is onehalf the \(\varnothing_{2}\) clock rate. Edge detection timing is shown in Appendix F.4.

\subsection*{4.4 PORT B (PB)}

Port B can be programmed as an 8 bit, bit independent I/O port. It has a latched input capability which may be enabled or disabled via the Mode Control Register (MCR). Table 4-2 tabulates the control and usage of Port B. An Input Data Strobe signal must be provided thru PAO when Port B is programmed to be used with latched input option. Input data latch timing for Port B is shown in Appendix F.4.

Table 4-2. Port B Control \& Usage
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{4}{*}{\begin{tabular}{l}
Pin \\
No. R65F11
\end{tabular}} & \multirow[b]{4}{*}{} & \multicolumn{2}{|c|}{I/O Mode} & \multicolumn{2}{|c|}{Latch Mode} \\
\hline & & \multicolumn{2}{|r|}{MCR4 \(=0\)} & \multicolumn{2}{|l|}{\begin{tabular}{l}
\[
\text { MCR4 }=1
\] \\
(2)
\end{tabular}} \\
\hline & & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} \\
\hline & & Name & Type (1) & Name & Type \\
\hline 38 & 8 & PB0 & I/O & PB0 & INPUT \\
\hline 37 & 7 & PB1 & I/O & PB1 & INPUT \\
\hline 36 & 6 & PB2 & I/O & PB2 & INPUT \\
\hline 35 & 5 & PB3 & I/O & PB3 & INPUT \\
\hline 34 & 4 & PB4 & I/O & PB4 & INPUT \\
\hline 33 & 3 & PB5 & 1/O & PB5 & INPUT \\
\hline 32 & 2 & PB6 & I/O & PB6 & INPUT \\
\hline 31 & 1 & PB7 & I/O & PB7 & INPUT \\
\hline
\end{tabular}

\footnotetext{
(1) Resistive pull-up, active buffer pull down
(2) Input data is stored in port B latch by PAO pulse
}

Table 4-3. Port A Control and Usage


\subsection*{4.5 PORT C (PC)}

Port C is preprogrammed as part of the Address/Data bus. PCO-PC7 function as A0-A3, A12, R/W, A13, and EMS, respectively, as shown in Table 4-4. EMS (External Memory Select) is asserted (low) whenever the internal processor accesses memory area between 0100 and 3FFF. (See Memory Map, Appendix C). The leading edge of EMS may be used to strobe the eight address lines multiplexed on Port D. See Appendix F. 3 for Port C timing.

\subsection*{4.6 PORT D (PD)}

Port \([\) is also preprogrammed as part of the Address/Data bus. Data bits D0 through D7 are time multiplexed with address bits A4 through A11, respectively. Refer to the Memory Maps (Appendix C) for Multiplexed memory assignments. See Appendix F. 3 for Port D timing.

\subsection*{4.7 PORT E (PE), PORT F (PF), PORT G (PG)}

Ports E, F and G are available on the R65F12 only. Port E can only be used as outputs. Port \(F\) and Port \(G\) can be used for inputs or outputs and are similar to Port A and Port B in operation.

Table 4-4. Port C Control and Usage
\begin{tabular}{|c|c|c|}
\hline \multirow[b]{4}{*}{\[
\begin{gathered}
\text { R65F11/ } \\
\text { R65F12 } \\
\text { Port }
\end{gathered}
\]} & \multicolumn{2}{|c|}{Multiplexed Mode} \\
\hline & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=1
\end{aligned}
\]} \\
\hline & \multicolumn{2}{|c|}{Signal} \\
\hline & Name & Type (1) \\
\hline PCO & AO & OUTPUT \\
\hline PC1 & A1 & OUTPUT \\
\hline PC2 & A2 & OUTPUT \\
\hline PC3 & A3 & OUTPUT \\
\hline PC4 & A12 & OUTPUT \\
\hline PC5 & R/W & OUTPUT \\
\hline PC6 & A13 & OUTPUT \\
\hline PC7 & EMS & OUTPUT \\
\hline
\end{tabular}

Table 4-5. Port D Control and Usage
\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[b]{5}{*}{\[
\begin{gathered}
\text { R65F11/ } \\
\text { R65F12 } \\
\text { Port }
\end{gathered}
\]} & \multicolumn{4}{|c|}{Multiplexed Mode} \\
\hline & \multicolumn{4}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=1 \\
& \text { MCR5 }=1
\end{aligned}
\]} \\
\hline & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} \\
\hline & \multicolumn{2}{|c|}{Phase 1} & \multicolumn{2}{|c|}{Phase 2} \\
\hline & Name & Type (2) & Name & Type (3) \\
\hline PD0 & A4 & OUTPUT & DATAO & I/O \\
\hline PD1 & A5 & OUTPUT & DATA1 & 1/0 \\
\hline PD2 & A6 & OUTPUT & DATA2 & 1/0 \\
\hline PD3 & A7 & OUTPUT & DATA3 & I/O \\
\hline PD4 & A8 & OUTPUT & DATA4 & 1/O \\
\hline PD5 & A9 & OUTPUT & DATA5 & \(1 / 0\) \\
\hline PD6 & A10 & OUTPUT & DATA6 & 1/0 \\
\hline PD7 & A11 & OUTPUT & DATA7 & 1/O \\
\hline \multicolumn{5}{|l|}{\multirow[t]{3}{*}{\begin{tabular}{l}
(1). Active Buffer Pull-up and Pull-Down \\
(2) Tri-State Buffer is in Active Mode \\
(3) Tri-State Buffer is in Active Mode only during the Phase 2 Portion of a Write Cycle
\end{tabular}}} \\
\hline & & & & \\
\hline & & & & \\
\hline
\end{tabular}

\title{
SECTION 5 SERIAL INPUT/OUTPUT CHANNEL
}

The R65F11 and R65F12 Microcomputers provide a full duplex Serial I/O channel with programmable bit rates and operating modes. The serial I/O functions are controlled by the Serial Communication Control Register (SCCR). The SCCR bit assignment is shown in Figure 5-1. The serial bit rate is determined by Counter A for all modes except the Receiver Shift Register (RCVR S/R) mode for which an external shift clock must be provided. The maximum data rate using the internal clock is 62.5 K bits per second (@ ø2 \(=1 \mathrm{MHZ}\) ). The transmitter (XMTR) and receiver (RCVR) can be independently programmed to operate in different modes and can be independently enabled or disabled.


Figure 5-1. Serial Communication Control Register
Except for the Receiver Shift Register Mode (RCVR S/R), all XMTR and RCVR bit rates will occur at one sixteenth of the Counter A interval timer rate. Counter A is forced into an interval timer mode whenever the serial I/O is enabled in a mode requiring an internal ctock.

Whenever Counter \(A\) is required as a timing source it must be loaded with the hexadecimal code that selects the data rate for the serial I/O Port. Refer to Counter A (paragraph 6.1) for a table of hexadecimal values to represent the desired data rate.

\subsection*{5.1 TRANSMITTER OPERATION (XTMR)}

The XTMR operation and the transmitter related control/ status functions are enabled by bit 7 of the Serial Communications Control Register (SCCR). The transmitter, when in the Asynchronous (ASYN) mode, automatically adds a start bit, one or two stop bits, and, when enabled, a parity bit to the transmitted data. A word of transmitted data (in asynchronous parity mode) can have \(5,6,7\), or 8 bits of data. The nine data modes are shown below. When parity is disabled, the \(5,6,7\) or 8 bits of data are terminated with two stop bits.


Figure 5-2. Bit Allocations
In the \(\mathrm{S} / \mathrm{R}\) mode, eight data bits are always shifted out. Bits/ character and parity control bits are ignored. The serial data is shifted out via the SO output (PA6) and the shift clock is available at the CA (PA4) pin. When the transmitter underruns in the S/R mode the SO output and shift clock are held in a high state.

The XMTR Interrupt Flag bit (IFR7) is controlled by Serial Communication Status Register bits SCCR5, SCCR6 and SCCR7.
\[
\text { IFR7 }=\text { SCSR6 ( } \overline{\text { SCCR5 }}+\text { SCCR7 })
\]

\subsection*{5.2 RECEIVER OPERATION (RCVR)}

The receiver and its selected control and status functions are enabled when SCCR-6 is set to a "1." In the ASYN mode, data format must have a start bit, appropriate number of data bits, a parity bit (if enabled) and one stop bit. Refer to Figure \(5-2\) for a diagram of bit allocations. The receiver bit period is divided into 8 sub-intervals for internal synchronization. The receiver bit stream is synchronized by the start bit and a strobe signal is generated at the approximate center of each incoming bit. Refer to Figure 5-3 for ASYN Receive Data Timing. The character assembly process does not start if the start bit signal is less than one-half the bit time after a low level is detected on the Receive Data Input. Framing error, over-run, and parity error conditions or a RCVR Data Register Full will set the appropriate status bits, and any of the above conditions will cause an Interrupt Request if the Receiver Interrupt Enable bit is set to logic 1.

R65F11•R65F12


Figure 5-3. ASYN Receive Data Timing In the S/R mode, an external shift clock must be provided at CA (PA4) pin along with 8 bits of serial data (LSB first) at the SI input (PA7). The maximum data rate using an external shift clock is one-eighth the internal clock rate. Refer to Figure 5-4 for S/R Mode Timing.


Figure 5-4. S/R Mode Timing
A RCVR interrupt (IFR6) is generated whenever any of SCSRO-3 are true.

\subsection*{5.3 SERIAL COMMUNICATION STATUS REGISTER (SCSR)}

The Serial Communication Status Register (SCSR) holds information on varıous communication error conditions, status of the transmitter and receiver data registers, a transmitter end-of-transmission condition, and a receiver idle line condition (Wake-Up Feature). The SCSR bit assignment is shown in Figure 5-5. Bit assignments and functions of the SCSR are as follows:

SCSR 0: Receiver Data Register Full-Set to a logic 1 when a character is transferred from the Receiver Shift Register to the Receiver Data Register. This bit is cleared by reading the Receiver Data Register, or by \(\overline{\text { RES }}\) and is disabled if SCCR \(6=0\). The SCSR 0 bit will not be set to a logic 1 if the received data contains an error condition, however, a corresponding error bit will be set to a logic 1 instead.

SCSR 1: Over-Run Error-Set to a logic 1 when a new character is transferred from the Receiver Shift Register, with the last character still in the Receiver Data Register. This bit is cleared by reading the Receiver Data Register, or by \(\overline{\mathrm{RES}}\).

SCSR 2: Parity Error-Set to logic 1 when the RCVR is in the ASYN Mode, Parity Enable bit is set, and the

\section*{FORTH Based Microcomputers}
received data has a parity error. This bit is cleared by reading the Receiver Data Register or by RES.
SCSR 3: Framing Error-Set to a logic 1 when the received data contains a zero bit after the last data or parity bit in the stop bit slot. Cleared by reading the Receiver Data Register or by RES. (ASYN Mode only).
SCSR 4: Wake-Up-Set to a logic 1 by writing a "1" in bit 4 of address: 0016. The Wake-Up bit is cleared by \(\overline{\mathrm{RES}}\) or when the receiver detects a string of ten consecutive 1 's. When the Wake-Up bit is set SCSR0 through SCSR3 are inhibited.
SCSR 5: End of Transmission-Set to a logic 1 by writing a "1" in bit position 5 of address: 0016. The End of Transmission bit is cleared by \(\overline{\mathrm{RES}}\) or upon writing a new data word into the Transmitter Data Register. When the End-of-Transmission bit is true the Transmitter Register Empty bit is disabled until a Transmitter Under-Run occurs.
SCSR 6: Transmitter Data Register Empty-Set to a logic 1 when the contents of the Transmitter Data Register is transferred to the Transmitter Shift Register. Cleared upon writing new data into the Transmit Data Register. This bit is initialized to a logic 1 by RES.
SCSR 7: Transmitter Under-Run-Set to a logic 1 when the last data bit is transmitted if the transmitter is in a S/R Mode or when the last stop bit is transmitted if the XMTR is in the ASYN Mode while the Transmitter Data Register Empty Bit is set. Cleared by a transfer of new data into the Transmitter Shift Register, or by RES.


Figure 5-5. SCSR Bit Allocations

\subsection*{5.4 WAKE-UP FEATURE}

In a multi-distributed microprocessor or microcomputer applications, a destination address is usually included at the beginning of the message. The Wake-Up Feature allows non-selected CPU's to ignore the remainder of the message until the beginning of the next message by setting the WakeUp bit. As long as the Wake-Up flag is true, the Receiver Data Register Full Flag remains false. The Wake-Up bit is automatically cleared when the receiver detects a string of ten consecutive 1 's which indicates an idle transmit line. When the next byte is received, the Receiver Data Register Full Flag signals the CPU to wake-up and read the received data.

\title{
SECTION 6 COUNTER/TIMERS
}

The R65F11 and R65F12 Microcomputers contain two 16 -bit counters (Counter A and Counter B) and three 16-bit latches associated with the counters. Counter \(A\) has one 16 -bit latch and Counter B has two 16 -bit latches. Each counter can be independently programmed to operate in one of four modes:

\section*{Counter A}
- Pulse width measurement
- Pulse Generation
- Interval Timer
- Event Counter

\section*{Counter B}
- Retriggerable Interval Counter
- Asymmetrical Pulse Generation
- Interval Timer
- Event Counter

Operating modes of Counter A and Counter B are controlled by the Mode Control Register. All counting begins at the initialization value and decrements. When modes are selected requiring a counter input/output line, PA4 is automatically selected for Counter A and PA5 is automatically selected for Counter B (see Table 4.2).

\subsection*{6.1 COUNTER A}

Counter A consists of a 16 -bit counter and a 16 -bit latch organized as follows: Lower Counter A (LCA), Upper Counter A (UCA), Lower Latch A (LLA), and Upper Latch A (ULA). The counter contains the count of either \(\phi 2\) clock pulses or external events, depending on the counter mode selected. The contents of Counter A may be read any time by executing a read at location 0019 for the Upper Counter A and at location 001A or location 0018 for the Lower Counter A. A read at location 0018 also clears the Counter A Underflow Flag (IFR4).

The 16 -bit latch contains the counter initialization value, and can be loaded at any time by executing a write to the Upper Latch A at location 0019 and the Lower Latch A at location 0018. In either case, the contents of the accumulator are copied into the applicable latch register.

Counter A can be started at any time by writing to address: 001 A . The contents of the accumulator will be copied into the


Figure 6-1. Interval Timer Timing Diagram

Upper Latch A before the contents of the 16 -bit latch are transferred to Counter \(A\). Counter \(A\) is set to the latch value whenever Counter A underflows. When Counter A decrements from 0000 the next counter value will be the latch value, not FFFF, and the Counter A Underflow Flag (IFR 4) will be set to " 1 ". This bit may be cleared by reading the Lower Counter A at location 0018, by writing to address location 001A, or by \(\overline{\mathrm{RES}}\).

Counter A operates in any of four modes. These modes are selected by the Counter A Mode Control bits in the Control Register. See Table 6-1.

Table 6-1. Counter A Control Bits
\begin{tabular}{|c|c|l|}
\hline \begin{tabular}{c} 
MCR1 \\
(bit 1)
\end{tabular} & \begin{tabular}{c} 
MCR0 \\
(bit 0)
\end{tabular} & \multicolumn{1}{c|}{ Mode } \\
\hline 0 & 0 & Interval Timer \\
0 & 1 & Pulse Generation \\
1 & 0 & Event Counter \\
1 & 1 & Pulse Width Measurement \\
\hline
\end{tabular}

The Interval Timer, Pulse Generation, and Pulse Width Measurement Modes are \(\emptyset 2\) clock counter modes. The Event Counter Mode counts the occurrences of an external event on the CNTR line.

The Counter is set to the Interval Timer Mode (00) when a \(\overline{R E S}\) signal is generated.

\subsection*{6.1.1 Interval Timer}

In the Interval Timer mode the Counter is initialized to the Latch value by either of two conditions:
1. When the Counter is decremented from 0000 , the next Counter value is the Latch value (not FFFF).
2. When a write operation is performed to the Load Upper Latch and Transfer Latch to Counter address 001A, the Counter is loaded with the Latch value. Note that the contents of the Accumulator are loaded into the Upper Latch before the Latch value is transferred to the Counter.

The Counter value is decremented by one count at the \(\varnothing 2\) clock rate. The 16 -bit Counter can hold from 1 to 65535 counts. The Counter Timer capacity is therefore \(1 \mu \mathrm{~s}\) to 65535 ms at the \(1 \mathrm{MHz} \emptyset 2\) clock rate or \(0.5 \mu \mathrm{~s}\) to 32.767 ms at the \(2 \mathrm{MHz} \emptyset 2\) clock rate. Time intervals greater than the maximum Counter value can be easily measured by counting \(\overline{\mathrm{IRQ}}\) interrupt requests in the counter \(\overline{\mathrm{RQ}}\) interrupt routine.

When Counter A decrements from 0000, the Counter A Underflow (IFR4) is set to logic 1 . If the Counter A Interrupt Enable Bit (IER4) is also set, an \(\overline{\mathrm{IRQ}}\) interrupt request will be generated. The Counter A Underflow bit in the Interrupt Flag Register can be examined in the \(\overline{\mathrm{RQ}}\) interrupt routine to determine that the \(\overline{\mathrm{RQ}}\) was generated by the Counter A Underflow.

While the timer is operating in the Interval Timer Mode, PA4 operates as a PA I/O bit.

A timing diagram of the Interval Timer Mode is shown in Figure 6-1.

\subsection*{6.1.2 Pulse Generation Mode}

In tive Pulse Generation mode, the CA line operates as a Counter Output. The line toggles from low to high or from high to low whenever a Counter A Underflow occurs, or a write is performed to address 001A.

The normal output waveform is a symmetrical square-wave. The CA output is initialized high when entering the mode and transitions low when writing to 001 A .

Asymmetric waveforms can be generated if the value of the latch is changed after each counter underflow.

A one-shot waveform can be generated by changing from Pulse Generation to Interval Timer mode after only one occurrence of the output toggle condition.

\subsection*{6.1.3 Event Counter Mode}

In this mode the CA is used as an Event Input line, and the Counter will decrement with each rising edge detected on this line. The maximum rate at which this edge can be detected is one-half the \(\phi 2\) clock rate.

The Counter can count up to 65,535 occurrences before underflowing. As in the other modes, the Counter A Underflow bit (IER4) is set to logic 1 if the underflow occurs.

Figure 6.2 is a timing diagram of the Event Counter Mode.


Figure 6-2. Event Counter Mode

\subsection*{6.1.4 Pulse Width Measurement Mode}

This mode allows the accurate measurement of a low pulse duration on the CA line. The Counter decrements by one count at the \(\phi 2\) clock rate as long as the CA line is held in the low state. The Counter is stopped when CA is in the high state.

The Counter A underflow flag will be set only when the count in the timer reaches zero. Upon reaching zero the timer will be loaded with the latch value and continue counting down as long as the CA pin is held low. After the counter is stopped by a high level on CA, the count will hold as long as CA remains high. Any further low levels on CA will again cause the counter to count down from its present value. The state of the CA line can be determined by testing the state of PA4.

A timing diagram for the Pulse Width Measurement Mode is shown in Figure 6-3.


Figure 6-3. Pulse Width Measurement

\subsection*{6.1.5 Serial I/O Data Rate Generation}

Counter A also provides clock timing for the Serial I/O which establishes the data rate for the Serial \(1 / O\) port. When the Serial I/O is enabled, Counter \(A\) is forced to operate at the internal clock rate. Counter \(A\) is not required for the RCVR S/R mode. The Counter I/O (PA4) may also be required to support the Serial I/O (see Table 4-2).

Table 6-2 identifies the values to be loaded in Counter A for selecting standard data rates with a \(\emptyset 2\) clock rate of 1 MHz and 2 MHz . Although Table 6-2 identifies only the more common data rates, any data rate from 1 to 62.5 K bps can be selected by using the formula:
\[
N=\frac{\not \emptyset 2}{16 \times b p s}-1
\]
where
\[
\begin{array}{ll}
\mathrm{N} & =\text { decimal value to be loaded into Counter } \mathrm{A} \text { using } \\
& \text { its hexadecimal equivalent. } \\
\phi 2 & =\text { the clock frequency (1 } \mathrm{MHz} \text { or } 2 \mathrm{MHz}) \\
\mathrm{bps} & =\text { the desired data rate. }
\end{array}
\]

\section*{NOTE}

In Table 6-2 you will notice that the standard data rate and the actual data rate may be slightly different. Transmitter and receiver errors of \(1.5 \%\) or less are acceptable. A revised clock rate is included in Table \(6-2\) for those baud rates which fall outside this limit.

Table 6-2. Counter A Values för Baud Rate Selection
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{Standard Baud Rate} & \multicolumn{2}{|l|}{Hexadecimal Value} & \multicolumn{2}{|l|}{\begin{tabular}{l}
Actual Baud \\
Rate At
\end{tabular}} & \multicolumn{2}{|l|}{Clock Rate Needed To Get Standard Baud Rate} \\
\hline & 1 MHz & 2 MHz & 1 MHz & 2 MHz & 1 MHz & 2 MHz \\
\hline 50 & 04E1 & 09C3 & 50.00 & 50.00 & 1.0000 & 2.0000 \\
\hline 75 & 0340 & 0682 & 75.03 & 74.99 & 1.0000 & 2.0000 \\
\hline 110 & 0237 & 046F & 110.04 & 110.04 & 1.0000 & 2.0000 \\
\hline 150 & 01A0 & 0340 & 149.88 & 150.06 & 1.0000 & 2.0000 \\
\hline 300 & 00CF & 01A0 & 300.48 & 299.76 & 1.0000 & 2.0000 \\
\hline 600 & 0067 & O0CF & 600.96 & 600.96 & 1.0000 & 2.0000 \\
\hline 1200 & 0033 & 0067 & 1201.92 & 1201.92 & 1.0000 & 2.0000 \\
\hline 2400 & 0019 & 0033 & 2403.85 & 2403.85 & 1.0000 & 2.0000 \\
\hline 3600 & 0010 & 0021 & 3676.47 & 3676.47 & 0.9792 & 1.9584 \\
\hline 4800 & 000C & 0019 & 4807.69 & 4807.69 & 1.0000 & 2.0000 \\
\hline 7200 & 0008 & 0010 & 6944.44 & 7352.94 & 1.0368 & 1.9584 \\
\hline 9600 & 0006 & 000C & 8928.57 & 9615.38 & 1.0752 & 2.0000 \\
\hline
\end{tabular}

\subsection*{6.2 COUNTER B}

Counter B conșists of a 16-bit counter and two 16-bit latches organized as follows: Lower Counter B (LCB), Upper Counter B (UCB), Lower Latch B (LLB), Upper Latch B (ULB), Lower Latch C (LLC), and Upper Latch C (ULC). Latch C is used only in the asymmetrical pulse generation mode. The counter contains the count of either \(\emptyset 2\) clock pulses or external events depending on the counter mode selected. The contents of Counter B may be read any time by executing a read at location 001D for the Upper Counter B and at location 001 E or 001 C for the Lower Counter B. A read at location 001 C also clears the Counter B Underflow Flag.

Latch B contains the counter initialization value, and can be loaded at any time by executing a write to the Upper Latch \(B\) at location 001D and the Lower Latch \(B\) at location 001C. In each case, the contents of the accumulator are copied into the applicable latch register.

Counter B can be initialized at any time by writing to address: 001 E . The contents of the accumulator is copied into the Upper Latch B before the value in the 16 -bit Latch B is transferred to Counter B. Counter B will also be set to the latch value and the Counter B Underflow Flag bit (IFR5) will be set to a " 1 " whenever Counter B underflows by decrementing from 0000.

IFR 5 may be cleared by reading the Lower Counter \(B\) at location 001C, by writing to address location 001E, or by \(\overline{\text { RES }}\)

Counter B operates in the same manner as Counter A in the Interval Timer and Event Counter modes. The Pulse Width Measurement Mode is replaced by the Retriggerable Interval Timer mode and the Pulse Generation mode is replaced by the Asymmetrical Pulse Generation Mode.

\subsection*{6.2.1 Retriggerable Interval Timer Mode}

When operating in the Retriggerable Interval Timer mode, Counter B is initialized to the latch value by writing to address 001E, by a Counter B underflow, or whenever a positive edge
occurs on the CB pin (PA5). The Counter B interrupt flag will be set if the counter underflows before a positive edge occurs on the CB line. Figure 6-4 illustrates the operation.


Figure 6-4. Counter B. Retriggerable Interval Timer Mode

\subsection*{6.2.2 Asymmetrical Pulse Generation Mode}

Counter B has a special Asymmetrical Pulse Generation Mode whereby a pulse train with programmable pulse width and period can be generated without the processor intervention once the latch values are initialized.

In this mode, the 16 -bit Latch B is initialized with a value which corresponds to the duration between pulses (referred to as D in the following descriptions). The 16 -bit Latch C is initialized with a value which corresponds to the desired pulse width (referred to as \(P\) in the following descriptions). The initialization sequence for Latch B and C and the starting of a counting sequence are as follows:
1. The lower 8 bits of \(P\) are loaded into LLB by writing to address 001C, and the upper 8 bits of \(P\) are loaded into ULB and the full 16 bits are transferred to Latch C by writing to address location 001D. At this point both Latch \(B\) and Latch \(C\) contain the value of \(P\).
2. The lower 8 bits of \(D\) are loaded into LLB by writing to address 001C, and the upper 8 bits of \(D\) are loaded into ULB by writing to address location 001E. Writing to address location 001E also causes the contents of the 16 -bit Latch \(B\) to be downloaded into the Counter \(B\) and causes the CB output to go low as shown in Figure 6-5.
3. When the Counter \(B\) underflow occurs the contents of the Latch C is loaded into the Counter B , and the CB output toggles to a high level and stays high until another underflow occurs. Latch B is then down-loaded and the CB output toggles to a low level repeating the whole process.


Figure 6-5. Counter B Pulse Generation

\section*{SECTION 7 \\ POWER ON/INITIALIZATION CONSIDERATIONS}

\subsection*{7.1 POWER-ON-RESET}

The occurrence of \(\overline{\operatorname{RES}}\) going from low to high will cause the R65F11 or R65F12 to reset and enter the RSC-FORTH Operating System. As was described in Section 3.8, upon reset certain system variables will be initialized. See Appendix C. 4 for a list of these variables names, locations and contents. The external memory map will be searched for an auto start ROM.

A bit pattern of A55A at a 1 K byte page boundary indicates that an auto start program follows. The next two bytes are assumed to be a pointer to the high level RSC-FORTH word that is the entry point to that program. Auto start programs is written in assembly language, rather than RSC-FORTH, a series of indirect pointers as shown in 3-7 can be used to initiate program execution.

\subsection*{7.2 POWER ON TIMING}

After application of \(\mathrm{V}_{\mathrm{CC}}\) and \(\mathrm{V}_{\mathrm{RR}}\) power to the R65F11 or R65F12, \(\overline{R E S}\) must be held low for at least eight \(\varnothing 2\) clock cycles after \(\mathrm{V}_{\mathrm{CC}}\) reaches operating range and the internal oscillator has stabilized. This stabilization time is dependent upon the input \(\mathrm{V}_{\mathrm{CC}}\) voltage and performance of the internal oscillator. The clock can be monitored at \(\varnothing 2\) (pin 3). Figure 7-1 illustrates the power turn-on waveforms. Clock stabilization time is typically 20 ms .


Figure 7-1. Power Turn-On Timing Detail

\subsection*{7.3 RESET ( \(\overline{\mathrm{RES}})\) CONDITIONING}

When \(\overline{\mathrm{RES}}\) is driven from low to high the R65F11 or R65F12 is put in a reset state. The registers and I/O ports are configured as shown in Table 7-1 when the external ROM is autostarted.

Table 7-1. RES Initialization of I/O Ports and Registers
\begin{tabular}{|l|llllllll|}
\hline & \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline REGISTERS & & & & & & & & \\
\(\quad\) Mode Control (MCR) & 1 & 1 & 1 & 0 & 0 & 0 & 0 & 0 \\
Int. Enable (IER) & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
Int. Flag (IFR) & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
Ser. Com. Control (SCCR) & 1 & 1 & 0 & 0 & 0 & 1 & 0 & 0 \\
Ser. Com. Status (SCSR) & 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 \\
PORTS & & & & & & & & \\
PA Latch & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\
PB Latch & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\
\hline
\end{tabular}

\title{
APPENDIX A \\ R65F11 AND R65F12 INSTRUCTION SET
}

\begin{abstract}
This appendix contains a summary of the R6500 instruction set. For detailed information, consult the R6500 Microcomputer System Programming Manual, Document 29650 N30. The four instructions notated with a * are added instructions for the R65F11 and R65F12 which are not part of the standard 6502 instruction set.
\end{abstract}

\section*{A. 1 INSTRUCTION SET IN ALPHABETIC SEQUENCE}
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Instruction & Mnemonic & Instruction \\
\hline ADC & Add Memory to Accumulator with Carry & LDA & Load Accumulator with Memory \\
\hline AND & "AND" Memory with Accumulator & LDX & Load Index X with Memory \\
\hline ASL & Shift Left One Bit (Memory or Accumulator) & LDY & Load Index Y with Memory \\
\hline & & LSR & Shift One Bit Right (Memory or \\
\hline *BBR & Branch on Bit Reset Relative & & Accumulator) \\
\hline *BBS & Branch on Bit Set Relative & & \\
\hline BCC & Branch on Carry Clear & NOP & No Operation \\
\hline BCS & Branch on Carry Set & & \\
\hline BEQ & Branch on Result Zero & ORA & "OR" Memory with Accumulator \\
\hline BIT & Test Bits in Memory with Accumulator & & \\
\hline BMI & Branch on Result Minus & PHA & Push Accumulator on Stack \\
\hline BNE & Branch on Result not Zero & PHP & Push Processor Status on Stack \\
\hline BPL & Branch on Result Plus & PLA & Pull Accumulator from Stack \\
\hline BRK & Force Break & PLP & Pull Processor Status from Stack \\
\hline BVC & Branch on Overflow Clear & & \\
\hline BVS & Branch on Overflow Set & *RMB & Reset Memory Bit \\
\hline & & ROL & Rotate One Bit Left (Memory or \\
\hline CLC & Clear Carry Flag & & Accumulator) \\
\hline CLD & Clear Decimal Mode & ROR & Rotate One Bit Right (Memory or \\
\hline CLI & Clear Interrupt Disable Bit & & Accumulator) \\
\hline CLV & Clear Overflow Flag & RTI & Return from Interrupt \\
\hline CMP & Compare Memory and Accumulator & RTS & Return from Subroutine \\
\hline CPX & Compare Memory and Index X & & \\
\hline CPY & Compare Memory and Index Y & SBC & Subtract Memory from Accumulator with Borrow \\
\hline DEC & Decrement Memory by One & SEC & Set Carry Flag \\
\hline DEX & Decrement Index \(X\) by One & SED & Set Decimal Mode \\
\hline DEY & Decrement Index Y by One & SEI & Set Interrupt Disable Status \\
\hline & & *SMB & Set Memory Bit \\
\hline EOR & "Exclusive-Or" Memory with & STA & Store Accumulator in Memory \\
\hline & Accumulator & STX & Store Index X in Memory \\
\hline & & STY & Store Index Y in Memory \\
\hline INC & Increment Memory by One & & \\
\hline INX & Increment Index X by One & TAX & Transfer Accumulator to Index \(X\) \\
\hline INY & Increment Index Y by One & TAY & Transfer Accumulator to Index \(Y\) \\
\hline & & TSX & Transfer Stack Pointer to Index \(X\) \\
\hline JMP & Jump to New Location & TXA & Transfer Index X to Accumulator \\
\hline JSR & Jump to New Location Saving Return Address & TXS & Transfer Index X to Stack Register Transfer Index \(Y\) to Accumulator \\
\hline
\end{tabular}


\section*{A. 3 INSTRUCTION CODE MATRIX}


\footnotetext{
*Add 1 to N if page boundary is crossed.
**Add 1 to N if branch occurs to same page; add 2 to N if branch occurs to different page
}

\section*{APPENDIX B \\ KEY REGISTER SUMMARY}


CPU Registers
\[
-0
\]
\(1=\) Break Command
\(0=\) Non Break Command
OVERFLOW (0) (1)
1 = Overliow Set
\(0=\) Overtiow Cleat
negative ( N ) (1)
\[
\begin{aligned}
& 1=\text { Negative Value } \\
& 0=\text { Postive Value }
\end{aligned}
\]

\section*{notes}
(1) Not initialized by \(\overline{\text { EES }}\)
(2) Set to Logic 1 by \(\frac{\text { RES }}{\text { RES }}\)

Processor Status Register


1~7 Bita/Char
\(0 \sim 6\) Bits/Char
\(1 \sim 5\) Bits/Char
0 - 0 XMTR \& RCVR ASYN Mode
\(0-1\) XMTR ASYN, RCVR S/R
\(1-\mathrm{X}\) XMTR S/R, RCVR ASYN
RCVR Disable
1 RCVR Enable
XMTR Disable
1 XMTR Enable
Serial Communications Control Register


Mode Control Register


Interrupt Enable and Flag Registers


Serial Communications Status Register

\section*{APPENDIX C ADDRESS ASSIGNMENTS/MEMORY MAPS/PIN FUNCTIONS}

\section*{C. 1 I/O AND INTERNAL REGISTER ADDRESSES}
\begin{tabular}{|c|c|c|}
\hline \begin{tabular}{l}
ADDRESS \\
(HEX)
\end{tabular} & READ & WRITE \\
\hline \[
\begin{array}{r}
001 \mathrm{~F} \\
1 \mathrm{E} \\
1 \mathrm{D} \\
1 \mathrm{C}
\end{array}
\] & \begin{tabular}{l}
Lower Counter B \\
Upper Counter B Lower Counter B, CLR Flag
\end{tabular} & Upper Latch B, Cntr B \(\leftarrow\) Latch B, CLR Flag Upper Latch B, Latch C \(\leftarrow\) Latch B Lower Latch B. \\
\hline \[
\begin{aligned}
& 1 B \\
& 1 A \\
& 19 \\
& 18
\end{aligned}
\] & \begin{tabular}{l}
Lower Counter A \\
Upper Counter A \\
Lower Counter A, CLR Flag
\end{tabular} & \begin{tabular}{l}
Upper Latch A, Cntr A↔Latch A, CLR Flag \\
Upper Latch A \\
Lower Latch A
\end{tabular} \\
\hline \[
\begin{aligned}
& 17 \\
& 16 \\
& 15 \\
& 14
\end{aligned}
\] & Serial Receiver Data Register Serial Comm. Status Register Serial Comm. Control Register Mode Control Register & \begin{tabular}{l}
Serial Transmitter Data Register Serial Comm. Status Reg. Bits 4 \& 5 only \\
Serial Comm. Control Register \\
Mode Control Register
\end{tabular} \\
\hline \[
\begin{aligned}
& 13 \\
& 12 \\
& 11 \\
& 10
\end{aligned}
\] & Interrupt Enable Register Interrupt Flag Register Read FF & \begin{tabular}{l}
Interrupt Enable Register \\
Clear Int Flag (Bits 0-3 only, Write 0's only)
\end{tabular} \\
\hline \[
\begin{aligned}
& O F \\
& O E \\
& O D \\
& O C
\end{aligned}
\] & \[
\begin{aligned}
& -ー \\
& -- \\
& --
\end{aligned}
\] &  \\
\hline \[
\begin{aligned}
& O B \\
& 0 A \\
& 09 \\
& 08
\end{aligned}
\] & \[
\begin{aligned}
& -- \\
& -- \\
& --
\end{aligned}
\] & \[
\begin{aligned}
& -ー \\
& -- \\
& --
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& 07 \\
& 06 \\
& 05 \\
& 04
\end{aligned}
\] & \begin{tabular}{l}
Port G* \\
Port F* \\
Port E *
\end{tabular} & \begin{tabular}{l}
Port G* \\
Port F* \\
Port E*
\end{tabular} \\
\hline \[
\begin{array}{r}
03 \\
02 \\
01 \\
0000
\end{array}
\] & Port B Port A & Port B Port A \\
\hline
\end{tabular}

NOTE: *R65F12 Only

\section*{C. 2 MULTIPLE FUNCTION PIN ASSIGNMENTSPORT C AND PORT D}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{2}{|c|}{\begin{tabular}{c} 
PIN \\
NUMBER
\end{tabular}} & \begin{tabular}{c} 
I/O PORT \\
FUNCTION \\
REPLACED
\end{tabular} & \begin{tabular}{c} 
MULTIPLEXED PORT \\
FUNCTION
\end{tabular} \\
\hline R65F11 & R65F12 & AN \\
\hline 4 & 25 & PC0 & AO \\
5 & 26 & PC1 & A1 \\
6 & 27 & PC2 & A2 \\
7 & 28 & PC3 & A3 \\
\hline 8 & 29 & PC4 & A12 \\
9 & 30 & PC5 & R/W \\
10 & 31 & PC6 & A13 \\
11 & 32 & PC7 & EMS \\
\hline 19 & 40 & PD0 & A4/D0 \\
18 & 39 & PD1 & A5/D1 \\
17 & 38 & PD2 & A6/D2 \\
16 & 37 & PD3 & A7/D3 \\
\hline 15 & 36 & PD4 & A8/D4 \\
14 & 35 & PD5 & A9/D5 \\
13 & 34 & PD6 & A10/D6 \\
12 & 33 & PD7 & A11/D7 \\
\hline
\end{tabular}

\section*{C. 3 MULTIPLEXED MODE} MEMORY MAP


\section*{C. 4 SYSTEA VARIABLES IN RAM}
\begin{tabular}{|c|c|c|c|}
\hline ADDRESS & NAME & COLD START VALUE & WARM START VALUE \\
\hline 0040 & IRQVEC & (COLD) & - \\
\hline 0042 & NMIVEC & (COLD) & - \\
\hline 0044 & UKEY & (INK) & (INK) \\
\hline 0046 & UEMIT & (OUT) & (OUT) \\
\hline 0048 & UP & 0300 & 0300 \\
\hline 004A & INTFLG & 00 & 00 \\
\hline 004B & (W-1) & 6 C & 6 C \\
\hline 004C & W & - & - \\
\hline 004E & IP & - & - \\
\hline 0050 & ( \(\mathrm{N}-1\) ) & - & - \\
\hline 0051 & N & - & - \\
\hline 0059 & XSAVE & - & - \\
\hline 005B & INTVEC & (COLD) & - \\
\hline 005D & TOS & - & - \\
\hline 0300 & TIB & 0380 & 0380 \\
\hline 0302 & Ro & 00FF & 00FF \\
\hline 0304 & SO & \(00 \mathrm{C2}\) & 00 C 2 \\
\hline 0306 & UC/L & 0050 & - \\
\hline 0308 & UPAD & 037E & - \\
\hline 030A & UR/W & (DISK) & - \\
\hline 030C & BASE & 0010 & - \\
\hline 030E & CLD/WRM & - & - \\
\hline 0310 & IN & - & - \\
\hline 0312 & DPL & - & - \\
\hline 0314 & HLD & - & - \\
\hline 0316 & DISKNO & - & - \\
\hline 0318 & CURCYL & - & - \\
\hline 031C & B/SIDE & - & - \\
\hline
\end{tabular}

\section*{APPENDIX E ELECTRICAL SPECIFICATIONS}

\section*{MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}} \& \mathrm{~V}_{\mathrm{RR}}\) & -0.3 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to +7.0 & Vdc \\
\hline \begin{tabular}{l} 
Operating Temperature Range, \\
Commercial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{c}
\(\mathrm{T}_{\mathrm{L}}\) to \(\mathrm{T}_{\mathrm{H}}\) \\
0 to +70
\end{tabular} & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\mathrm{STG}}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}

\begin{abstract}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
\end{abstract}

\section*{DC CHARACTERISTICS}
\(\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{RR}}=\mathrm{V}_{\mathrm{CC}} ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{A}}=0^{\circ}\right.\) to \(70^{\circ}\), unless otherwise specified)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ \({ }^{1}\) & Max & Unit & Test Conditions \\
\hline RAM Standby Voltage (Retention Mode) & \(\mathrm{V}_{\text {RR }}\) & 3.0 & & \(\mathrm{V}_{\text {cc }}\) & V & \\
\hline RAM Standby Current (Retention Mode) & \(\mathrm{I}_{\text {RR }}\) & - & 4 & - & mA & \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) \\
\hline Input High Voltage All Except XTLI XTLI & \(\mathrm{V}_{\mathrm{H}}\) & \[
\begin{array}{r}
+2.0 \\
+4.0 \\
\hline
\end{array}
\] & - & \[
\begin{aligned}
& V_{c c} \\
& V_{c c}
\end{aligned}
\] & V & \\
\hline Input Low Voltage & \(\mathrm{V}_{\mathrm{IL}}\) & -0.3 & - & +0.8 & V & \\
\hline Input Leakage Current \(\overline{\text { RES }}, \overline{\text { NMI }}\) & IN & - & - & \(\pm 10.0\) & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{IN}}=0\) to 5.0 V \\
\hline Input Low Current \(\mathrm{PA}, \mathrm{PB}, \mathrm{PC}, \mathrm{PD}, \mathrm{PF}^{3}, \mathrm{PG}^{3}\) & ILI & - & -1.0 & -1.6 & mA & \(\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V}\) \\
\hline Output High Voltage (Except XTLO) & \(\mathrm{V}_{\mathrm{OH}}\) & +2.4 & - & \(\mathrm{V}_{\mathrm{cc}}\) & V & \(\mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A}\) \\
\hline Output Low Voltage & \(\mathrm{V}_{\mathrm{OL}}\) & - & - & +0.4 & V & \(\mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA}\) \\
\hline \[
\begin{aligned}
& \text { I/O Port Pull-Up Resistance } \\
& \text { PAO-PA7, PB0-PB7, PC0-PC7, PF0-PF73, } \\
& \text { PG0-PG73 }
\end{aligned}
\] & \(\mathrm{R}_{\mathrm{L}}\) & 3.0 & 6.0 & 11.5 & Kohm & \\
\hline Output Leakage Current (Three-State Off) & lout & - & - & \(\pm 10\) & \(\mu \mathrm{A}\) & \\
\hline \(\underset{\mathrm{PE}^{3}}{\text { Darlington Current Drive }}\) & \(\mathrm{IOH}^{\text {O }}\) & -1.0 & - & - & mA & \(\mathrm{V}_{\text {OUT }}=1.5 \mathrm{~V}\) \\
\hline Input Capacitance XTLI, XTLO All Others & \(\mathrm{C}_{\text {IN }}\) & - & - & \[
\begin{aligned}
& 50 \\
& 10
\end{aligned}
\] & pF & \[
\begin{aligned}
& \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\
& \mathrm{~V}_{1 \mathrm{~N}}=0 \mathrm{~V} \\
& \mathrm{f}=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Output Capacitance (Three-State Off) & \(\mathrm{C}_{\text {OUt }}\) & - & - & 10 & pF & \[
\begin{aligned}
& \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\
& \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\
& \mathrm{f}=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Power Dissipation (Outputs High) & \(\mathrm{P}_{\mathrm{D}}\) & - & & 1000 & mW & \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) \\
\hline \multicolumn{7}{|l|}{\begin{tabular}{l}
Notes: \\
1. Typical values measured at \(T_{A}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{C C}=5.0 \mathrm{~V}\). \\
2. Negative sign indicates outward current flow, positive indicates inward flow. \\
3. R65F12 only.
\end{tabular}} \\
\hline
\end{tabular}

\section*{APPENDIX F \\ TIMING REQUIREMENTS AND CHARACTERISTICS}

\section*{F. 1 GENERAL NOTES}
1. \(V_{C C}=5 \mathrm{~V} \pm 5 \%, 0^{\circ} \mathrm{C} \leqslant T A \leqslant 70^{\circ} \mathrm{C}\)
2. \(A\) valid \(V_{C C}\) - RES sequence is required before proper operation is achieved.
3. All timing reference levels are 0.8 V and 2.0 V , unless otherwise specified.
4. All time units are nanoseconds, unless otherwise specified.
5. All capacitive loading is 130 pf maximum, except as noted below:
PA, PB, PE, PF, PG
- 50pf maximum

\section*{F. 2 CLOCK TIMING}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{SYMBOL} & \multirow{2}{*}{PARAMETER} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|r|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline TCrc & Cycle Time & 1000 & \(10 \mu \mathrm{~s}\) & 500 & \(10 \mu \mathrm{~s}\) \\
\hline \(\mathrm{T}_{\mathrm{PW} \times 1}\) & XTLI Input Clock Pulse Width XTLO = VSS & \[
\begin{aligned}
& 500 \\
& \pm 25
\end{aligned}
\] & - & \[
\begin{aligned}
& 250 \\
& \pm 10
\end{aligned}
\] & - \\
\hline \(\mathrm{T}_{\text {PW02 }}\) & Output Clock Pulse Width at Minimum \(\mathrm{T}_{\mathrm{CyC}}\) & \(T_{\text {PWX1 }}\) & \[
\begin{gathered}
T_{\text {PWX1 }} \\
\pm 25
\end{gathered}
\] & \(\mathrm{T}_{\text {PWX1 }}\) & \[
\begin{aligned}
& T_{P W \times 1} \\
& \pm 20
\end{aligned}
\] \\
\hline \(\mathrm{T}_{\mathrm{R}}, \mathrm{T}_{\mathrm{F}}\) & Output Clock Rise, Fall Time & - & 25 & - & 15 \\
\hline \(\mathrm{T}_{\text {IR }}, \mathrm{T}_{\text {IF }}\) & Input Clock Rise, Fall Time & - & 10 & - & 10 \\
\hline
\end{tabular}


\section*{F. 3 MULTIPLEXED MODE TIMING-PC AND PD}
\((\) MCR \(5=1\), MCR \(6=1, M C R 7=1)\)
\begin{tabular}{|l|l|c|c|c|c|}
\hline \multirow{2}{*}{ SYMBOL } & \multicolumn{1}{|c|}{ PARAMETER } & \multicolumn{2}{|c|}{\(\mathbf{1} \mathbf{M H z}\)} & \multicolumn{2}{c|}{\(\mathbf{2} \mathbf{M H z}\)} \\
\cline { 3 - 7 } & & MIN & MAX & MIN & MAX \\
\hline\(T_{\text {PCRS }}\) & (PC5) R/W Setup Time & - & 225 & - & 140 \\
\hline\(T_{\text {PCAS }}\) & (PC0-PC4, PC6) Address Setup Time & - & 225 & - & 140 \\
\hline\(T_{\text {PBAS }}\) & (PD) Address Setup Time & - & 225 & - & 140 \\
\hline\(T_{\text {PBSU }}\) & (PD) Data Setup Time & 50 & - & 35 & - \\
\hline\(T_{\text {PBHR }}\) & (PD) Data Read Hold Time & 10 & - & 10 & - \\
\hline\(T_{\text {PBHW }}\) & (PD) Data Write Hold Time & 30 & - & 30 & - \\
\hline\(T_{\text {PBDD }}\) & (PD) Data Output Delay & - & 175 & - & 150 \\
\hline\(T_{\text {PCHA }}\) & (PC0-PC4, PC6) Address Hora Time & 30 & - & 30 & - \\
\hline\(T_{\text {PBHA }}\) & (PD) Address Hold Time & 10 & 100 & 10 & 80 \\
\hline\(T_{\text {PCHR }}\) & (PC5) R/W Hold Time & 30 & - & 30 & - \\
\hline\(T_{\text {PCHV }}\) & (PC7) EMS Hold Time & 10 & - & 10 & - \\
\hline\(T_{\text {PCVD }}{ }^{\text {(1) }}\) & (PC7) Address to EMS Delay Time & 30 & - & 30 & - \\
\hline\(T_{\text {PCVP }}\) & (PC7) EMS Stabilization Time & 30 & - & 30 & - \\
\hline\(T_{\text {ESU }}\) & \(\overline{E M S}\) Set Up Time & - & 350 & - & 210 \\
\hline
\end{tabular}

NOTE 1: Values assume PC0-PC4, PC6 and PC7 have the same capacitive load.

\section*{F.3.1 Multiplex Mode Timing Diagram}


\section*{F. 4 I/O, EDGE DETECT, COUNTERS, AND SERIAL I/O TIMING}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{SYMBOL} & \multirow[b]{2}{*}{PARAMETER} & \multicolumn{2}{|l|}{1 MHz} & \multicolumn{2}{|r|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline \[
\begin{aligned}
& T_{\text {PDW }}{ }^{(1)} \\
& T_{\text {CMOS }}{ }^{(1)} \\
& \hline
\end{aligned}
\] & Internal Write to Peripheral Data Valid PA, PB TTL PA, PB CMOS & - & \[
\begin{array}{r}
500 \\
1000
\end{array}
\] & - & \[
\begin{array}{r}
500 \\
1000
\end{array}
\] \\
\hline Tpdsu & Peripheral Data Setup Time PA, PB & 200 & - & 200 & - \\
\hline \(\mathrm{T}_{\text {PH }}\) & Peripheral Data Hold Time PA, PB & 75 & - & 75 & - \\
\hline \(\mathrm{T}_{\text {EPW }}\) & PA0-PA3 Edge Detect Pulse Width & TCrc & - & T crc & - \\
\hline \[
\begin{aligned}
& \mathrm{T}_{\mathrm{CPW}} \\
& \mathrm{~T}_{\mathrm{CD}}{ }^{(1)}
\end{aligned}
\] & \begin{tabular}{l}
Counters A and B \\
PA4, PA5 Input Pulse Width PA4, PA5 Output Delay
\end{tabular} & T \({ }_{\text {cre }}\) & \[
500
\] & \(\mathrm{T}_{\mathrm{Crc}}\) & - 500 \\
\hline \(T_{\text {PBLW }}\) TPLSU \(T_{\text {PBLH }}\) & \begin{tabular}{l}
Port B Latch Mode \\
PAO Strobe Pulse Width PB Data Setup Time PB Data Hold Time
\end{tabular} & \[
\begin{gathered}
T_{\text {crc }} \\
175 \\
30 \\
\hline
\end{gathered}
\] & - & \[
\begin{gathered}
T_{\text {crc }} \\
150 \\
30 \\
\hline
\end{gathered}
\] & - \\
\hline \begin{tabular}{l}
\(T_{\text {PDW }}{ }^{(1)}\) \\
Tcmos \({ }^{(1)}\) \\
\(T_{\text {CPW }}\) \\
\(\mathrm{T}_{\text {PDW }}{ }^{(1)}\) \\
Tcmos \({ }^{(1)}\)
\end{tabular} & \begin{tabular}{l}
Serial I/O \\
PA6 XMTR TTL \\
PA6 XMTR CMOS \\
PA4 RCVR S/R Clock Width PA4 XMTR Clock-S/R Mode (TTL) PA4 XMTR Clock-S/R Mode (CMOS)
\end{tabular} &  & \[
\left.\begin{array}{r}
500 \\
1000 \\
- \\
500 \\
1000
\end{array} \right\rvert\,
\] &  & 500
1000
-
500
1000 \\
\hline
\end{tabular}

\footnotetext{
NOTE 1: Maximum Load Capacitance: 50pF Passive Pull-Up Required.
}

\section*{F.4.1 I/O Edge Detect, Counter, and Serial I/O Timing}


\section*{APPENDIX G \\ INCLUDED FORTH FUNCTIONS IN ROM}
\begin{tabular}{|c|c|c|c|}
\hline BANKEXECUTE & BANKEEC! & BANKC@ & BANKC! \\
\hline EEC! & - & .R & D. \\
\hline ? & \#S & \# & SIGN \\
\hline D.R & <\# & SPACES & SEEK \\
\hline \# > & DWRITE & DREAD & SELECT \\
\hline INIT & M/MOD & */ & */MOD \\
\hline DISK & / & /MOD & \\
\hline MOD & M * & MAX & MIN \\
\hline M/ & ABS & D+- & +- \\
\hline DABS & COLD & (NUMBER) & HOLD \\
\hline S->D & ERASE & FILL & QUERY \\
\hline BLANKS & (.") & -TRAILING & TYPE \\
\hline EXPECT & DECIMAL & HEX & -DUP \\
\hline COUNT & PICK & ROT & > \\
\hline SPACE & U< & = & - \\
\hline < & 1- & 2+ & 1+ \\
\hline 2- & C/L & HLD & DPL \\
\hline PAD & CLD/WRM & BASE & UR/W \\
\hline IN & UC/L & RO & SO \\
\hline UPAD & BL & 4 & 3 \\
\hline TIB & 1 & 0 & C! \\
\hline 2 & C@ & @ & TOGGLE \\
\hline ! & BOUNDS & 2DUP & DUP \\
\hline +! & 2DROP & DROP & OVER \\
\hline SWAP & NEGATE & D+ & + \\
\hline DNEGATE & \(0=\) & R & R> \\
\hline \(0<\) & LEAVE & ; S & RP@ \\
\hline >R & SP! & SP@ & XOR \\
\hline RP! & AND & U/ & U* \\
\hline OR & CR & ?TERMINAL & KEY \\
\hline CMOVE & ENCLOSE & (FIND) & DIGIT \\
\hline EMIT & (+LOOP) & (LOOP) & OBRANCH \\
\hline (DO) & EXECUTE & CLIT & LIT \\
\hline BRANCH & & & \\
\hline
\end{tabular}

\section*{R65FRx and R65FKx RSC FORTH Development and Kernel ROMS}

\section*{INTRODUCTION}

The Rockwell Single Chip (RSC) FORTH System can be configured using the R65F11, R65F12 microcomputers or the R6501Q ROM-less microcomputer. One of these microcomputers, when used in conjunction with a development ROM and a FORTH kernel ROM, provide the designer with maximum flexibility when developing FORTH applications.

RSC-FORTH is based on the popular fig-FORTH model with extensions. The R65F11 and R65F12 both have the kernel of the high level Rockwell Single Chip RSC-FORTH language contained in the preprogrammed ROM. The R65FK2 and R65FK3 Kernel ROMs are preprogrammed ROMs for use with the R6501Q when developing larger applications requiring more memory and I/O line support. All of the run time functions of the RSC-FORTH are contained in these ROMs, including 16- and 32-bit mathematical, logical and stack manipulation, plus memory and input/output operators. The RSC-FORTH Operating System allows an external user program written in RSC-FORTH or Assembly Language to be executed from external EPROM, or development of such a program under the control of the R65FR1, R65FR2 or R65FR3 RSC-FORTH Development ROMs.

This document describes five different RSC-FORTH system configurations using the development and kernel ROMs.
ORDERING INFORMATION
\begin{tabular}{|l|l|}
\hline Part No. & \multicolumn{1}{|c|}{ Description } \\
\hline R65FR1P & FORTH Development ROM for R65F11 or R65F12 \\
R65FR2P & FORTH Development ROM for R6501Q \\
R65FR3P & FORTH Development ROM for R6501Q \\
R65FK2P & FORTH Kernel ROM for R6501Q \\
R65FK3P & FORTH Kernel ROM for R6501Q \\
R65F11P & 40-Pin FORTH Based Microcomputer at 1 MHz \\
R65F11AP & 40-Pin FORTH Based Microcomputer at 2 MHz \\
R65F12Q & 64-Pin FORTH Based Microcomputer at 1 MHz \\
R65F12AQ & 64-Pin FORTH Based Microcomputer at 2 MHz \\
R6501Q & 64-Pin One-Chip Microprocessor at 1 MHz \\
R6501AQ & 64-Pin One-Chip Microprocessor at 2 MHz \\
\hline Order No. & \multicolumn{1}{|c|}{ Description } \\
\hline 2145 & \begin{tabular}{l} 
R6501Q One-Chip Microprocessor Product \\
\\
2146
\end{tabular} \\
& Description \\
2148 & R65F11 and R65F12 FORTH Based Microcomputer \\
2162 & Product Description \\
& RSC-FORTH User's Manual \\
& Application Note: A Low-Cost Development Module \\
for the R65F11 FORTH Microcomputer \\
\hline
\end{tabular}

\section*{FEATURES}
- R65FR1 FORTH Development ROM
—8K ROM
—Addressable from \$2000 through \$3FFF in FORTH development configuration memory map
-R65F11 and R65F12 compatible
-Operates in the R65F11/F12 FORTH development configuration
- R65FR2 FORTH Development ROM
-8K ROM
-Addressable from \(\$ 4000\) through \(\$ 5 F F F\) in the FORTH development configuration memory map
—R6501Q compatible for use in emulation of the R65F11/F12 FORTH development configuration
- R65FR3 FORTH Development ROM
-8K ROM
-Addressable from \$C000 through \$DFFF in the FORTH development configuration memory map
-Operates in the R6501Q FORTH development configuration
- R65FK2 FORTH Kernel ROM
-4K ROM
-Addressable from \$F400 through \$FFFF in the FORTH development configuration memory map
-R6501Q compatible for use in the emulation of the R65F11/F12 FORTH development configuration
-Replaces the FORTH kernel contained in the R65F11 and R65F12 microcomputers during development
- R65FK3 FORTH Kernel ROM
-4K ROM
—Addressable from \$F400 through \$FFFF in the FORTH development and production configuration memory maps
-R6501Q compatible
-Operates in the R6501Q FORTH development and production configurations

\section*{RSC-FORTH SYSTEM CONFIGURATIONS}

The three configurations of the RSC-FORTH System are identified by the CPU-Development ROM combinations listed below:

RSC-FORTH System Configurations
\begin{tabular}{|l|l|c|c|}
\hline CPU & \begin{tabular}{l} 
Kernel \\
ROM
\end{tabular} & \begin{tabular}{c} 
Development \\
ROM
\end{tabular} & \begin{tabular}{c} 
RSC \\
Configuration
\end{tabular} \\
\hline R65F11 & none & R65FR1 & 1 \\
R65F12 & none & R65FR1 & 1 \\
R6501Q & R65FK2 & R65FR2 & 2 \\
R6501Q & R65FK3 & R65FR3 & 3 \\
\hline
\end{tabular}

\section*{RSC-FORTH CONFIGURATION 1 (R65FR1) R65F11/R65F12 DEVELOPMENT AND PRODUCTION}

The RSC-FORTH Configuration 1 provides the designer with a FORTH development and application environment at a minimal cost. The application program is developed using an R65F11 or R65F12 microcomputer, an R65FR1 Development ROM and external RAM. Up to 8 K bytes of RAM space is available using this configuration. However, Configuration 1 is limited to 5 K or less bytes of RAM during development. This is the result of allocating 2 K bytes of RAM for disk buffers and at least 1 K bytes of RAM for the "Program heads". The program heads are contained in a dictionary containing the Name (NFA), Link Field Address (LFA) and the Parameter Field Address Pointer (PFA). This dictionary is a list of FORTH word words and user-defined FORTH words used in the development of a FORTH program and is not present during the execution of the FORTH program.

Although programs may reside in the upper 8 K bytes of memory area, normally filled by the R65FR1 Development ROM, it is difficult to develop code for that area using this configuration of the RSC-FORTH System.

The difference in using the R65F11 or the R65F12 is in the number of I/O lines available to the user. The R65F11 supports 16 I/O lines, the R65F12 supports 40 I/O lines.

Figure 1 shows the development and production configurations for the R65F11/F12. Configurations 1 A and 1 B list the features, memory maps, and the relationship of the R65F11 and R65F12 to the R65FR1 Development ROM in the development and production environment.


Figure 1. R65FR1 Configuration 1 Block Diagram

\section*{CONFIGURATION 1A CONSIDERATIONS}

Features
- 8K Bytes of User Memory
- 16 I/O Lines

\section*{Device Configuration}
\begin{tabular}{l}
\multicolumn{1}{l}{\begin{tabular}{l} 
DEVELOPMENT \\
\hline
\end{tabular} \begin{tabular}{|c|c|}
\hline & PRODUCTION \\
R65F11 Microcomputer & \\
\hline
\end{tabular}} \\
\hline R65FR1 Development ROM \\
\hline
\end{tabular}

\section*{User Memory-I/O Resource Matrix}

User memory may be a mix of ROM, EEROM, UVPROM or RAM.


\section*{CONFIGURATION 1B CONSIDERATIONS}

Features
- 8K Bytes of User Memory
- 40 I/O Lines

Device Configuration


\section*{User Memory-1/O Resource Matrix}

User memory may be a mix of ROM, EEROM, UVPROM or

\section*{RSC-FORTH CONFIGURATION 2 (R65FR2, R65FK2) \\ R6501Q DEVELOPMENT AND R65F11/F12 PRODUCTION}

The RSC-FORTH Configuration 2 provides the designer with the capability of using the full 16 K bytes of external address space of the R65F11 and R65F12.

The R6501Q ROM-less microprocessor, when used with the R65FK2 Kernel ROM and the R65FR2 Development ROM, emulates the operation of the R65F11/F12. Because of the greater address space of the R6501Q, the R65FR2 Development ROM can be relocated to address \(\$ 4000\) and the disk buffers and HEADS program to \(\$ 6000\). This expands the available user memory space to 16 K bytes, \(\$ 0000\) through \(\$ 3 F F F\).

Using this configuration, the application program can be developed using the R6501Q and then later installed in an R65F11 or R65F12 microcomputer without modification.

Figure 2 shows the development and production configuration for the R6501Q. Configurations 2A and 2B list the features, memory maps, and the relationship of the R6501Q to the R65FR2 Development ROM and R65FK2 Kernel ROM in the development and production environment. Figure 3 is a schematic of the R6501Q, R65FR2, R65FK2 development setup designed to plug into a 40 pin socket in place of the R65F11.

Note: Ports E, F and G of the R65F12 are not present on the R6501Q and must be emulated by external TTL logic. Contact Rockwell for further information.


Figure 2. R65FR2 and R65FK2 Configuration 2 Block Diagrams

\section*{CONFIGURATION 2A CONSIDERATIONS}

Features
- 16K Bytes of User "Headerless" Memory
- 16 I/O Lines

\section*{Device Configuration}
\begin{tabular}{l|l|l|} 
& \multicolumn{1}{l}{ DEVELOPMENT } & PRODUCTION \\
R65F11 Microcomputer & & \\
R6501Q Microprocessor & & \\
\hline & & \\
\cline { 2 - 3 } & & \\
\hline
\end{tabular}

\section*{Memory-I/O Matrix}

If floppy disk is used in the application, space for the disk buffers must be allocated in memory from \(\$ 0500\) through \(\$ 3 F F F\) or \(\$ 6000\) through \(\$ 7 F F F\). User memory can be a mix of ROM, EEROM, UVROM or RAM.



\section*{Memory Maps}


\section*{CONFIGURATION 2B CONSIDERATIONS}

Features
- 16K Bytes of User "Headerless" Memory
- 40 I/O Lines

\section*{Device Configuration}
\begin{tabular}{l|l|l|} 
& \multicolumn{1}{l}{ DEVELOPMENT } & PRODUCTION \\
R65F12 Microcomputer & & \\
R6501Q Microprocessor & & \\
R65FR2 Development ROM & & \\
\hline & & \\
\hline
\end{tabular}

\section*{Memory-I/O Matrix}

If floppy disk is used in the application, space for the disk buffers must be allocated in memory \(\$ 0000\) through \(\$ 3 F F F\). User memory can be a mix of ROM, EEROM, UVROM or RAM.


\section*{Memory Maps}


2n When emulating a R65F12 system Ports E, F or G
must be constructed externally using TTL circuits (contact Rockwell).


\section*{RSC-FORTH CONFIGURATION 3 (R65FR3, R65FK3) \\ R6501Q BASED SYSTEM DEVELOPMENT AND PRODUCTION}

The RSC-FORTH Configuration 3 is designed for those applications which require a larger amount of ROM or RAM space than the R65F11 or R65F12 can provide.

In the development configuration, the user is provided with up to 48 K bytes of memory. The user memory is located from \(\$ 0000\) through \$BFFF. The program heads will use some of this area but the user will still have considerably more memory space available then in the previous configurations.

The production configuration provides up to 56 K bytes of user memory. This is due to the fact that the R65FR3 Development ROM, used in the development configuration, is not required in the production configuration and releases the 8 K bytes of memory space. This memory is located at \$C000 through \$DFFF.

Figure 4 shows the development and production configurations for the R6501Q. Configuration 3 lists the features, memory maps, and the relationship of the R6501Q to the R65FR3 Development ROM and the R65FK3 Kernel ROM in the development and production environment.


Figure 4. R65FR3 and R65FK3
Configuration 3 Block Diagrams

\section*{CONFIGURATION 3 CONSIDERATIONS}

Features
- R6501Q w/FORTH
- 48K Bytes of User Memory
- 30 I/O Lines

Device Configuration
\begin{tabular}{l|l|l|} 
& \multicolumn{2}{l}{ DEVELOPMENT PRODUCTION } \\
\hline R6501Q Microcomputer & & \\
\hline & & \\
\hline R65FK3 Development ROM & & \\
\hline & & \\
\hline
\end{tabular}

User Memory-I/O Resource Matrix
All ports act as I/O ports. Memory is on the bus. PC6 \& PC7 (I/O lines) are assigned to memory. User memory can be a mix of ROM, EEROM, UVPROM or RAM.


Note: Chip select for the Floppy Disk Controller should be at \$E000-\$E006 and at \$E100-\$E106 for this configuration.


RSC-FORTH ROM Pin Assignments

\section*{ABSOLUTE MAXIMUM RATINGS*}

R65FR1, R65FR2, R65FR3, R65FK2, R65FK3
\begin{tabular}{|l|l|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.5 to +7.0 & V \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.5 to +7.0 & V \\
\hline Operating Temperature Range & \(\mathrm{T}_{\mathrm{A}}\) & 0 to +70 & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\mathrm{ST}}\) & -65 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline Power Dissipation & \(\mathrm{P}_{\mathrm{D}}\) & 1.0 & W \\
\hline
\end{tabular}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device atr these or any other conditions above those indicated in the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{OPERATING CONDITIONS}
\begin{tabular}{|c|c|}
\hline Parameter & Range \\
\hline\(V_{\mathrm{CC}}\) Power Supply & \(5.0 \mathrm{~V} \pm 5 \%\) \\
\hline Operating Temperature & \(0^{\circ} \mathrm{C}\) to \(70^{\circ}\) \\
\hline
\end{tabular}

\section*{D.C. CHARACTERISTICS}
\(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\) (unless otherwise specified)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Symbol & Parameter & Min & Typ & Max & Units & Test Conditions \\
\hline \(\mathrm{V}_{\mathrm{OH}}\) & Output High Voltage R65FRx R65FKx & 2.4 & - & \(\mathrm{V}_{\mathrm{Cc}}\) & V & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\
& \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \\
& \mathrm{I}_{\mathrm{OH}}=-240 \mu \mathrm{~A} \\
& \hline
\end{aligned}
\] \\
\hline \(\mathrm{V}_{\mathrm{OL}}\) & Output Low Voltage R65FRx R65FKx & - & - & 0.4 & V & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\
& \mathrm{I}_{\mathrm{OL}}=3.3 \mathrm{~mA} \\
& \mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA}
\end{aligned}
\] \\
\hline \(\mathrm{V}_{\text {IH }}\) & Input High Voltage & 2.0 & - & \(\mathrm{V}_{\mathrm{CC}}\) & V & \\
\hline \(\mathrm{V}_{\text {IL }}\) & Input Low Voltage & \(-0.5\) & - & 0.8 & V & \\
\hline \(\mathrm{I}_{\mathrm{LI}}\) & Input Load Current & - & - & 10 & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{OV} \leq \mathrm{V}_{\text {IN }} 5.25 \mathrm{~V}\) \\
\hline ILO & Output Leakage Current & - & - & \(\pm 10\) & \(\mu \mathrm{A}\) & Chip Deselected,
\[
\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{OUT}}=+0.4 \mathrm{~V} \text { to } \mathrm{V}_{\mathrm{CC}}
\] \\
\hline \(I_{\text {cc }}\) & Power Supply Current R65FRx R65FKx & - & \[
\begin{aligned}
& 25 \\
& 80
\end{aligned}
\] & \[
\begin{gathered}
55 \\
135
\end{gathered}
\] & \[
\begin{aligned}
& \mathrm{mA} \\
& \mathrm{~mA}
\end{aligned}
\] & \(\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} @ 0^{\circ} \mathrm{C}\) \\
\hline \(\mathrm{C}_{1}\) & Input Capacitance & - & - & 7 & pF & \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\), Chip Deselected, pin under test at OV \\
\hline \(\mathrm{C}_{\mathrm{O}}\) & Output Capacitance & - & - & 10 & pF & \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\), Chip Deselected, pin under test at 0 V \\
\hline
\end{tabular}

\title{
Section 4 16-Bit Microprocessors and Peripherals
}
Page
Product Family Overview ..... 4-2
R68000 16-bit Microprocessing Unit (MPU) ..... 4-3
R68C552 Dual Asynchronous Communications Interface Adapter (DACIA) ..... 4-62
R68560 Multi-Protocol Communications Controller (MPCC) ..... \(4-83\)

\section*{16-Bit Microprocessor and Peripherals Meeting System Communications Needs}

Rockwell peripherals give a designer the communication control elements for the 68000 processor. They allow you to design functional systems utilizing all the speed and data handling potential of the 16 -bit 68000 family.
These peripherals consist of the Rockwell designed Multi-Protocol Communications Controller and the Dual Asynchronous Interface Adapter - each a significant "first" that eliminates "glue parts" between a CPU and peripherals.
The R68561 Multi-Protocol Communications Controller (MPCC) is one of the highest throughput communications devices ever commercially made. It operates up to \(4 \mathrm{Mbits} / \mathrm{sec}\) and supports all major communication protocols.

It is available to work with either a 16 -bit or 8 -bit bus and can be adapted to function with essentially any of today's more common busses.

The R68C552 Dual Asynchronous Interface Adapter (DACIA) provides an easily implemented, programmed controlled interface between 16 -bit microprocessor-based systems and serial communication data sets and modems. This device is the first CMOS ACIA in the industry.

Rockwell lets you build efficient and economical 16-bit systems through families of 16 -bit and 8 -bit peripherals, all compatible. No other company offers you more.


R68000/R6500 Peripheral Migration

\title{
R68000 \\ 16-Bit Microprocessing Unit (MPU)
}

\section*{DESCRIPTION}

The R68000 microprocessor is designed for high performance where operational computation and versatility is required. The R68000 provides powerful mass-memory handling capability and architectural features designed to fit the broad range of 16-bit needs. The Rockwell family of 16 -bit products also includes a wide range of peripherals that will allow complete system design and manufacture.


R68000 Registers

The R68000 offers seventeen 32 -bit registers in addition to the 32 -bit program counter and a 16 -bit status register. The first eight registers (D0-D7) are used as data registers for byte (8-bit), word (16-bit), and long word (32-bit) data operations. The second set of seven registers (A0-A6) and the system stack pointer may be used as software stack pointers and base address registers. In addition, these registers may be used for word and long word address operations. All 17 registers may be used as index registers.

\section*{FEATURES}
- 16M byte (8M word) Linear Addessing Range
- 14 Operand Addressing Modes
- 56 Powerful Instruction Types
- Instruction Set Supports Structured High-Level Languages
- Pipelining Instruction Execution
- 32-Bit Program Counter
- 16-Bit Data Bus
- 23-Line Address Bus
- 32-Bit Data and Address Registers Including:
- Eight General Purpose Data Registers
- Seven Address Registers
- Two Stack Pointers (User, Supervisory)
- All 17 Registers Can Be Index Registers
- Memory Mapped Peripheral Devices
- Vector Generated Exception Processing
- Seven Unique Autovectors for Interrupt Service Routines
- Trace Mode for Software Debugging
- Operations Occur on Five Main Data Types
- Bit
- BCD
- Byte
- Word
- Long Word
- Asynchronous and Synchronous Peripheral Interface Capability
- Many Peripheral Chips Available
- R68560/R68561 Multi-Protocol Communications Controller (MPCC)
- R68802 Local Network Controller (LNET)
- R68C552 Dual Asynchronous Communications Interface Adapter (DACIA)
- Up to 12.5 MHz Input Clock
- +5 VDC Power Supply
ORDERING INFORMATION



R68000J/L Pin Assignments-68-Pin PCC and LCC*
*Pin Assignment package outlines are not actual size (refer to PACKAGE DIMENSIONS on pages 56-59).

\section*{SIGNAL DESCRIPTION}

The following paragraphs briefly describe the input and output signals and also reference (if applicable) other paragraphs that contain more detail about the function being performed. Bus operation during the various machine cycles and operations is also discussed. The input and output signals can be functionally organized into the groups shown in Figure 1.

\section*{Note}

The terms assertion and negation are used to avoid confusion when dealing with a mixture of "active-low" and "active-high" signals. The terms assert, or assertion, indicates that a signal is active, or true, independent of whether that voltage is low or high. The term negate, or negation, indicates that a signal is inactive or false.

ADDRESS BUS (A1 THROUGH A23). This 23-bit, unidirectional, three-state bus can address eight megawords of data. It provides the address for bus operation during all cycles except interrupt cycles. During interrupt cycles, address lines A1, A2, and A3 encode the interrupt level to be serviced while address lines A4 through A23 are all set high.

DATA BUS (DO THROUGH D15). This 16-bit, bidirectional, three-state bus is the general purpose data path. It transfers and accepts data in either word or byte length. During an interrupt acknowledge cycle, an external device supplies the vector number on data lines DO-D7.

ASYNCHRONOUS BUS CONTROL. Asynchronous data transfers are handled using the following control signals: address strobe, read/write, upper and lower data strobes, and data transfer acknowlege. These signals are explained in the following paragraphs.


Figure 1. Input and Output Signals

Address Strobe ( \(\overline{\mathbf{A S}}\) ). The \(\overline{\mathrm{AS}}\) output indicates that there is a valid address on the address bus.
Read/Write \((\mathbf{R} / \overline{\mathrm{W}}\) ). The \(\mathrm{R} \overline{\mathrm{W}}\) output defines the data bus transfer as a read or write cycle. The R \(\bar{W}\) signal also works in conjunction with the upper and lower data strobes as explained in the following paragraph.

Upper and Lower Data Strobes ( \(\overline{\text { UDS }}, \overline{\text { LDS }}\) ). The \(\overline{\text { UDS }}\) and \(\overline{\text { LDS }}\) outputs control the data on the data bus, as shown in Table 1. When the \(\mathrm{R} \bar{W}\) line is high, the processor reads from the data bus as indicated. When the R \(\bar{W}\) line is low, the processor writes to the data bus as shown.

Data Transfer Acknowledge ( \(\overline{\text { DTACK }})\). The \(\overline{\text { DTACK }}\) input indicates that the data transfer is completed. When the processor recognizes \(\overline{\text { DTACK }}\) during a read cycle, data is latched and the bus cycle terminated. When DTACK is recognized during a write cycle, the bus cycle terminates. Refer to ASYNCHRONOUS VERSUS SYNCHRONOUS OPERATION.

BUS ARBITRATION CONTROL. These three signals form a bus arbitration circuit to determine which device will be the bus master device.
Bus Request ( \(\overline{\mathbf{B R}}\) ). The \(\overline{\mathrm{BR}}\) input indicates to the processor that some other device desires to become the bus master. This input can be externally ORed with all other devices that could be bus masters.

Bus Grant ( \(\overline{\mathrm{BG}}\) ). The \(\overline{\mathrm{BG}}\) output indicates to all other potential bus master devices that the processor will release bus control at the end of the current bus cycle.
Bus Grant Acknowledge ( \(\overline{\mathrm{BGACK}})\). The \(\overline{\mathrm{BGACK}}\) input indicates that some other device has become the bus master. This signal cannot be asserted until the following four conditions are met:
1. a bus grant ( \(\overline{\mathrm{BG}}\) ) has been received,
2. address strobe ( \(\overline{\mathrm{AS}}\) ) is inactive which indicates that the processor is not using the bus

Table 1. Data Strobe Control of Data Bus
\begin{tabular}{|c|c|c|c|c|}
\hline\(\overline{\text { UDS }}\) & \(\overline{\text { LDS }}\) & R/ \(\bar{W}\) & D8-D15 & D0-D7 \\
\hline High & High & - & No valid data & No valid data \\
\hline Low & Low & High & \begin{tabular}{c} 
Valid data bits \\
\(8-15\)
\end{tabular} & \begin{tabular}{c} 
Valid data bits \\
\(0-7\)
\end{tabular} \\
\hline High & Low & High & \begin{tabular}{c} 
No valid data
\end{tabular} & \begin{tabular}{c} 
Valid data bits \\
\(0-7\)
\end{tabular} \\
\hline Low & High & High & \begin{tabular}{c} 
Valid data bits \\
\(8-15\)
\end{tabular} & No valid data \\
\hline Low & Low & Low & \begin{tabular}{c} 
Valid data bits \\
\(8-15\)
\end{tabular} & \begin{tabular}{c} 
Valid data bits \\
\(0-7\)
\end{tabular} \\
\hline High & Low & Low & \begin{tabular}{c} 
Valid data bits \\
\(0-7^{*}\)
\end{tabular} & \begin{tabular}{c} 
Valid data bits \\
\(0-7\)
\end{tabular} \\
\hline Low & High & Low & \begin{tabular}{c} 
Valid data bits \\
\(8-15\)
\end{tabular} & \begin{tabular}{c} 
Valid data bits \\
\(8-15^{*}\)
\end{tabular} \\
\hline
\end{tabular}
*These conditions are a result of current implementation and may not appear on future devices.
3. data transfer acknowledge ( \(\overline{\text { DTACK }}\) ) is inactive which indicates that neither memory nor peripherals are using the bus, and
4. bus grant acknowledge ( \(\overline{\mathrm{BGACK}}\) ) is inactive which indicates that no other device is still claiming bus mastership.

INTERRUPT CONTROL ( \(\overline{\text { IPLO }}, \overline{\text { IPL1 }}, \overline{\text { IPL2 }})\). These input pins indicate the encoded priority level of the device requesting an interrupt. Level seven is the highest priority while level zero indicates that no interrupts are requested. Level seven cannot be masked. \(\overline{\mathrm{IPLO}}\) is the least significant bit while \(\overline{\mathrm{IPL} 2}\) is the most significant bit. To insure an interrupt is recognized, the interrupt control lines ( \(\overline{\mathrm{IPLX}})\) must remain stable until the processor signals interrupt acknowledge (FC0, FC1, and FC2 all high).

SYSTEM CONTROL. The system control inputs either reset or halt the processor or indicate to the processor that bus errors have occurred. The three system control inputs are explained in the following paragraphs.

Bus Error ( \(\overline{\mathrm{BERR}})\). The \(\overline{\mathrm{BERR}}\) input informs the processor that a problem exists with the cycle currently being executed. Problems may be a result of:
1. nonresponding devices,
2. interrupt vector number acquisition failure,
3. illegal access request as determined by a memory management unit, or
4. other application dependent errors.

The Bus Error ( \(\overline{\mathrm{BERR}})\) signal interacts with the \(\overline{\mathrm{HALT}}\) signal to determine if exception processing should be performed or the current bus cycle should be retried.

Refer to BUS ERROR AND HALT OPERATION paragraph for additional information about the interaction of the bus error and halt signals.

Reset ( \(\overline{\mathbf{R E S E T}})\). This bidirectional signal line acts to reset (initiate a system initialization sequence) the processor and system in response to an external reset signal. An internally generated reset (result of a RESET instruction) resets all external devices while not affecting the internal state of the processor. A total system reset (processor and external devices) is the result of external HALT and RESET signals applied simultaneously. Refer to RESET OPERATION paragraph for additional information.

Halt ( \(\overline{\mathrm{HALT}}\) ). The bidirectional \(\overline{\mathrm{HALT}}\) line, when driven by an external device, will cause the processor to stop at the completion of the current bus cycle. Halting the processor using HALT causes all control signals to go inactive and all three-state lines to go to their high-impedance state. Refer to BUS ERR'OR AND HALT OPERATION paragraph for additional information about the interaction between the \(\overline{\mathrm{HALT}}\) and \(\overline{\mathrm{BERR}}\) signals.

When the processor has stopped executing instructions, such as in a double bus fault condition, the \(\overline{\text { HALT }}\) line is driven by the processor to indicate to external devices that the processor has stopped. Refer to paragaph on Double Bus Faults.

R6500 PERIPHERAL CONTROL. These control signals are used to allow the interfacing of synchronous R6500 peripheral devices with the asynchronous R68000. These signals are explained in the following paragraphs.

Enable (E). The E output signal is the standard enable signal ( \(\varnothing 2\) clock) common to all R6500 type peripheral devices. The period for this output is ten R68000 clock periods (six clocks low; four clocks high). Enable is generated by an internal ring counter which may come up in any state (i.e., at power on, it is impossible to guarantee phase relationship of \(E\) to CLK). \(E\) is a free-running clock and runs regardless of the state of the bus on the MPU.

Valid Peripheral Address ( \(\overline{\mathrm{VPA}}\) ). The \(\overline{\mathrm{VPA}}\) input indicates that the device or region addressed is a R6500 family device and that data transfer should be synchronized with the enable (E) signal. This input also indicates that the processor should use automatic vectoring for an interrupt. Refer to INTERFACE WITH R6500 PERIPHERALS.

Valid Memory Address ( \(\overline{\mathrm{VMA}}\) ). The \(\overline{\mathrm{VMA}}\) output indicates to R6500 peripheral devices that there is a valid address on the address bus and that the processor is synchronized to enable. This signal only responds to a valid peripheral address ( \(\overline{\mathrm{VPA}}\) ) input which indicates that the peripheral is a R6500 family device.

PROCESSOR STATUS (FC0, FC1, FC2). These function code outputs indicate the state (user or supervisor) and the cycle type currently being executed, as shown in Table 2. The information indicated by the function code outputs is valid whenever address strobe ( \(\overline{\mathrm{AS}}\) ) is active.

CLOCK (CLK). The clock input is a TTL-compatible signal that is internally buffered for development of the internal clocks needed by the processor. The clock input should not be gated off at any time and the clock signal must conform to minimum and maximum pulse width times.

SIGNAL SUMMARY. Table 3 summarizes all the signals discussed in the previous paragraphs.

Table 2. Function Code Outputs
\begin{tabular}{|l|l|l|l|}
\hline FC2 & FC1 & FC0 & \multicolumn{1}{|c|}{ Cycle Type } \\
\hline Low & Low & Low & (Undefined, Reserved) \\
\hline Low & Low & High & User Data \\
\hline Low & High & Low & User Program \\
\hline Low & High & High & (Undefined, Reserved) \\
\hline High & Low & Low & (Undefined, Reserved) \\
\hline High & Low & High & Supervisor Data \\
\hline High & High & Low & Supervisor Program \\
\hline High & High & High & Interrupt Acknowledge \\
\hline
\end{tabular}

Table 3. Signal Summary
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Signal Name} & \multirow[b]{2}{*}{Mnemonic} & \multirow[b]{2}{*}{Input/Output} & \multirow[b]{2}{*}{Active State} & \multicolumn{2}{|c|}{\(\mathrm{Hi}-\mathrm{Z}\)} \\
\hline & & & & On HALT & On \(\overline{\text { BGACK }}\) \\
\hline Address Bus & A1-A23 & Output & High & Yes & Yes \\
\hline Data Bus & D0-D15 & Input/Output & High & Yes & Yes \\
\hline Address Strobe & \(\overline{\text { AS }}\) & Output & Low & No & Yes \\
\hline Read/Write & R/W & Output & Read-High Write-Low & No & Yes \\
\hline Upper and Lower Data Strobes & \(\overline{U D S}, \overline{L D S}\) & Output & Low & No & Yes \\
\hline Data Transfer Acknowledge & \(\overline{\text { DTACK }}\) & Input & Low & No & No \\
\hline Bus Request & \(\overline{\mathrm{BR}}\) & Input & Low & No & No \\
\hline Bus Grant & \(\overline{B G}\) & Output & Low & No & No \\
\hline Bus Grant Acknowledge & \(\overline{\text { BGACK }}\) & Input & Low & No & No \\
\hline Interrupt Priority Level & \(\overline{\mathrm{IPLO}}, \overline{\mathrm{IPL}}\), \(\overline{\mathrm{IPL} 2}\) & Input & Low & No & No \\
\hline Bus Error & \(\overline{\text { BERR }}\) & Input & Low & No & No \\
\hline Reset & RESET & Input/Output & Low & No* & No* \\
\hline Halt & \(\overline{\text { HALT }}\) & Input/Output & Low & No* & No* \\
\hline Enable & E & Output & High & No & No \\
\hline Valid Memory Address & \(\overline{\mathrm{VMA}}\) & Output & Low & No & Yes \\
\hline Valid Peripheral Address & \(\overline{\mathrm{VPA}}\) & Input & Low & No & No \\
\hline Function Code Output & FC0, FC1, FC2 & Output & High & No & Yes \\
\hline Clock & CLK & Input & High & No & No \\
\hline Power Input & \(V_{\text {CC }}\) & Input & - & - & - \\
\hline Ground & GND & Input & - & - & - \\
\hline
\end{tabular}

\section*{REGISTER DESCRIPTION AND DATA ORGANIZATION}

STATUS REGISTER. The status register contains the eight level interrupt mask as well as the condition codes; extend ( X ), negative ( N ), zero \((\mathrm{Z})\), overflow ( V ), and carry ( C ). Additional status bits indicate that the processor is in a trace ( T ) mode and/or in a supervisor ( S ) state.


\section*{OPERAND SIZE}

Operand sizes are defined as follows: a byte equals 8 bits, a word equals 16 bits, and a long word equals 32 bits. The operand size for each instruction is either explicitly encoded in the instruction or implicitly defined by the instruction operation. Implicit instructions support some subset of all three sizes.

\section*{DATA ORGANIZATION IN REGISTERS}

The eight data registers support data operands of \(1,8,16\), or 32 bits. The seven address registers together with the active stack pointer support address operands of 32 bits.

DATA REGISTERS. Each data register is 32 bits wide. Byte operands occupy the low order 8 bits, word operands the low order 16 bits, and long word operands the entire 32 bits. The least significant bit is addressed as bit zero; the most significant bit is addressed as bit 31. When a data register is used as either a source or destination operand, only the appropriate low-order portion is changed; the remaining high order portion is neither used nor changed.


Figure 2. Word Organization In Memory

ADDRESS REGISTERS. Each address register and the stack pointer is 32 bits wide and holds a full 32 -bit address. Address registers do not support byte sized operands. Therefore, when an address register is used as a source operand, either the low order word or the entire long word operand is used depending upon the operation size. When an address register is used as the destination operand, the entire register is affected regardless of the operation size. If the operation size is word, any other operands are sign extended to 32 bits before the operation is performed.

\section*{DATA ORGANIZATION IN MEMORY}

Bytes are individually addressable with the high order byte having an even address the same as the word, as shown in Figure 2. The low order byte has an odd address that is one higher than the word address. Instructions and multi-byte data are accessed only on word (even byte) boundaries. If a long word datum is located at address n ( n even), then the second word of that datum is located at address \(n+2\).

The data types supported by the R68000 are: bit data, integer data of 8,16 , or 32 bits, 32 -bit addresses and binary coded decimal data. Each of these data types is put in memory, as shown in Figure 3. The numbers indicate the order in which data is accessed from the processor.

\section*{BUS OPERATION}

The following paragraphs explain control signal and bus operation during data transfer operations, bus arbitration, bus error and halt conditions, and reset operation.

DATA TRANSFER OPERATIONS. Transfer of data between devices involves the following signals:
- Address Bus A1 through A23
- Data Bus D0 through D15
- Control Signals

The address and data buses are separate parallel buses which transfer data using an asynchronous bus structure. In all cycles, the bus master assumes responsibility for deskewing all signals it issues at both the start and end of a cycle. In addition, the bus master is responsible for deskewing the acknowledge and data signals from the slave device.

The following paragraphs explain the read, write, and read-modify-write cycles. The indivisible read-modify-write cycle is the method used by the R68000 for interlocked multiprocessor communications.

Read Cycle. During a read cycle, the processor receives data from memory or a peripheral device. The processor reads bytes of data in all cases, and for a word (or double word) operation, the processor reads both upper and lower bytes simultaneously by asserting both upper and lower data strobes. When the instruction specifies byte operation, the processor uses an internal AO bit to determine which byte to read and then issues the data strobe required for that byte. When the AO bit equals zero, the upper data strobe is issued, and when the AO bit equals one, the lower data strobe is issued. The processor correctly positions the received data internally.

A word read cycle flow chart is given in Figure 4. A byte read cycle flow chart is given in Figure 5. Read cycle timing is given in Figure 6. Figure 7 details word and byte read cycle operations.

Write Cycle. During a write cycle, the processor sends bytes of data to memory or a peripheral device. If the instruction specifies a word operation, the processor writes both bytes. When the instruction specifies a byte operation, the processor uses an internal AO bit to determine which byte to write and then issues the data strobe required for that byte. When the AO bit equals zero, the upper data strobe is issued and when the AO bit equals one, the lower data strobe is issued. A word write cycle flow chart is given in Figure 8. A byte write cycle flow chart is given in Figure 9. Write cycle timing is given in Figure 6. Figure 10 details word and byte write cycle operation.
ADDRESSES
1 ADDRESS = 32 BITS

MSB = MOST SIGNIFICANT BIT
LSB = LEAST SIGNIFICANT BIT
DECIMAL DATA
2 BINARY CODED DECIMAL DIGITS = 1 BYTE
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline 15 & \(14 \quad 13\) & 12 & 11 & 10 & 9 & 8 & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline MSD & BCD 0 & & & \multicolumn{2}{|l|}{BCD 1} & LSD & & \multicolumn{2}{|r|}{BCD 2} & & & \multicolumn{2}{|l|}{BCD 3} & \\
\hline & BCD 4 & & & \multicolumn{3}{|l|}{BCD 5} & & \multicolumn{2}{|r|}{BCD 6} & & & \multicolumn{2}{|l|}{BCD 7} & \\
\hline
\end{tabular}
MSD \(=\) MOST SIGNIFICANT DIGIT
LSD = LEAST SIGNIFICANT DIGIT

Figure 3. Data Organization In Memory


Figure 4. Word Read Cycle Flow Chart

Read-Modify-Write Cycle. The read-modify-write cycle performs a read, modifies the data in the arithmetic-logic unit, and writes the data back to the same address. In the R68000 this cycle is indivisible in that the address strobe is asserted throughout the entire cycle. The test and set (TAS) instruction uses this cycle to provide meaningful communication between processors in a multiple processor environment. TAS is the only instruction that uses the read-modify-write cycles. Since the test and set instruction only operates on bytes, all read-modify-write cycles are byte operations. A read-modify-write cycle flow chart is given in Figure 11 and a timing diagram is given in Figure 12.

BUS ARBITRATION. Bus arbitration is a technique used by master-type devices to request, be granted, and acknowledge bus mastership. In its simplest form, it consists of:
1. asserting a bus mastership request,
2. receiving a grant that the bus is available at the end of the current cycle, and
3. acknowledging that mastership has been assumed.


Figure 5. Byte Read Cycle Flow Chart

Figure 13 is a flow chart showing the detail involved in a request from a single device. Figure 14 is a timing diagram for the same operation. This technique allows processing of bus requests during data transfer cycles.

The timing diagram shows that the bus request is negated at the time that an acknowledge is asserted. This is true for a system consisting of the processor and one device capable of bus mastership. However, in systems having a number of devices capable of bus mastership, the bus request line from each device is ORed to the processor. In this system, it is easy to see that there could be more than one bus request being made. The timing diagram shows that the bus grant signals negate a few clock cycles after the transition of the acknowledge ( \(\overline{\mathrm{BGACK}})\) signal.

However, if the bus requests are still pending, the processor will assert another bus grant within a few clock cycles after negation. This additional assertion of bus grant allows external arbitration circuitry to select the next bus master before the current bus master has completed its requirements. The following paragraphs provide additional information about the three steps in the arbitration process.


Figure 6. Read and Write Cycle Timing Diagram


Figure 7. Word and Byte Read Cycle Timing Diagram

Requesting the Bus. External devices capable of becoming bus masters request the bus by asserting the bus request ( \(\overline{\mathrm{BR}}\) ) signal. This ORed signal (although it need not be constructed from open collector devices) indicates to the processor that some external device requires control of the external bus. The processor, at a lower bus priority level than the external device, will relinquish the bus after it has completed the last bus cycle it has started. If no acknowledge is received before the bus request signal goes inactive, the processor will continue processing when it detects that the bus request is inactive. This allows ordinary processing to continue if the arbitration circuitry inadvertently responded to noise.

Receiving the Bus Grant. Normally the processor asserts bus grant \((\overline{\mathrm{BG}})\) as soon as possible after internal synchronization. The only exception occurs when the processor has made an internal decision to execute the next bus cycle but has not progressed far enough into the cycle to have asserted the address strobe \((\overline{\mathrm{AS}})\) signal. In this case, bus grant will not be asserted until one clock after address strobe is asserted to indicate to external devices that a bus cycle is being executed.

The bus grant signal may be routed through a daisy-chained network or through a specific priority-encoded network. The processor is not affected by the external method of arbitration as long as the protocol is obeyed.


Figure 8. Word Write Cycle Flow Chart


Figure 9. Byte Write Cycle Flow Chart


Figure 10. Word and Byte Write Cycle Timing Diagram
3) REMOVE DATA FROM DO-D7 OR D8-D15
4) SET R/W TO READ
 \(V\) START NEXT CYCLE

Figure 11. Read-Modify-Write Cycle Flow Chart


Figure 12. Read-Modify-Write Cycle Tining Diagram


Figure 13. Bus Arbitration Cycle Flow Chart

Acknowledgment of Mastership. Upon receiving a bus grant \((\overline{\mathrm{BG}})\), the requesting device waits until address strobe \((\overline{\mathrm{AS}})\), data transfer acknowledge ( \(\overline{\mathrm{DTACK}}\) ), and bus grant acknowledge (BGACK) are negated before issuing its own BGACK. The negation of the address strobe indicates that the previous master has completed its cycle, while the negation of bus grant acknowledge indicates that the previous master has released the bus. (If address strobe is asserted no device is allowed to "break into"" a cycle.) The negation of data transfer acknowledge indicates the previous slave has terminated its connection to the previous master. In some applications data transfer acknowledge may not be required. In this case the devices would use the address strobe. When bus grant acknowledge is issued the device is bus master. Only after the bus cycle(s) is (are) completed should bus grant acknowledge be negated to terminate bus mastership.

The bus request from the granted device should be dropped after bus grant acknowledge is asserted. If a bus request is still pending, another bus grant will be asserted within a few clocks of the negation of bus grant. Refer to Bus Arbitration Control section. The processor does not perform any external bus cycles before it reasserts bus grant.

BUS ARBITRATION CONTROL. The bus arbitration control unit in the R68000 is implemented with a finite state machine. A state diagram of this machine is shown in Figure 15. All asynchronous signals to the R68000 are synchronized before being used internally. This synchronization is accomplished in a maximum of one cycle of the system clock, assuming that the asynchronous input setup time (\#47) has been met (see Figure 16). The input signal is sampled on the falling edge of the clock and is valid internally after the next falling edge. If \(\overline{B R}\) and \(\overline{B G A C K}\) meet the asynchronous set-up time tASI (\#47), then tBGKBR (\#37A) can be ignored. If \(\overline{B R}\) and \(\overline{B G A C K}\) are asserted asynchronously with respect to the clock, \(\overline{\mathrm{BGACK}}\) has to be asserted before \(\overline{\mathrm{BR}}\) is negated.

As shown in Figure 15, input signals labeled \(R\) and \(A\) are internally synchronized on the bus request and bus grant acknowledge pins respectively. The bus grant output is labeled \(G\) and the internal three-state control signal \(T\). If \(T\) is true, the address, data, and control buses are placed in a high-impedance state when \(\overline{\mathrm{AS}}\) is negated. All signals are shown in positive logic (active high) regardless of their true active voltage level.

State changes (valid outputs) occur on the next rising clock edge after the internal signal is valid.

A timing diagram of the bus arbitration sequence during a processor bus cycle is shown in Figure 17. The bus arbitration sequence while the bus is inactive (i.e., executing internal operations such as a multiply instruction) is shown in Figure 18.

If a bus request \((\overline{\mathrm{BR}})\) is made at a time when the MPU has already begun a bus cycle but \(\overline{\mathrm{AS}}\) has not been asserted (bus state SO\(), \overline{\mathrm{BG}}\) will not be asserted on the next rising edge. Instead \(\overline{B G}\) will be delayed until the second rising edge following its internal assertion. This sequence is shown in Figure 19.

BUS ERROR AND HALT OPERATION. In a bus architecture that requires a handshake from an external device, the possibility exists that the handshake might not occur. Since different systems will require a different maximum response time, a bus error input is provided.

External circuitry must be used to determine the duration between address strobe and data transfer acknowledge before issuing a bus error signal. When a bus error signal is received, the processor has two options: initiate a bus error exception sequence or try running the bus cycle again.


Figure 14. Bus Arbitration Cycle Timing Diagram


Figure 15. State Diagram of R68000 Bus Arbitration Unit

*THIS DELAY TIME IS EQUAL TO PARAMETER \#33, tCHGL

Figure 16. Timing Relationship of External Asynchronous Inputs to Internal Signals

Bus Error Operation. When \(\overline{\mathrm{BERR}}\) is asserted, the current bus cycle is terminated. If \(\overline{B E R R}\) is asserted before the falling edge of \(\mathrm{S} 2, \overline{\mathrm{AS}}\) will be negated in S 7 in either a read or write cycle. As long as \(\overline{B E R R}\) remains asserted, the data and address buses will be in the high-impedance state. When \(\overline{B E R R}\) is negated, the processor will begin stacking for exception processing. Figure 20 is a timing diagram for the exception sequence. The sequence is composed of the following elements:
1. stacking the program counter and status register,
2. stacking the error information,
3. reading the bus error vector table entry, and
4. executing the bus error handler routine.


Figure 17. Bus Arbitration During Processor Bus Cycle


Figure 18. Bus Arbitration with Bus Inactive


Figure 19. Bus Arbitration During Processor Bus Cycle Special Case


Figure 20. Bus Error Timing Diagram

The stacking of the program counter and the status register is identical to the interrupt sequence. Several additional items are stacked when a bus error occurs. These items are used to determine the nature of the error and correct it, if possible. The bus error vector is vector number two located at address \$000008. The processor loads the new program counter from this location. A software bus error handler routine is then executed by the processor. Refer to EXCEPTION PROCESSING for additional information.

Re-Running the Bus Cycle. When, during a bus cycle, the processor receives a \(\overline{B E R R}\), and HALT is being driven by an external device, the processor enters the re-run sequence. Figure 21 is a timing diagram for re-running the bus cycle.

The processor terminates the bus cycle, then puts the address and data output lines in the high-impedance state. The processor remains "halted" and will not run another bus cycle until external logic negates \(\overline{H A L T}\). Then the processor will re-run the previous bus cycle using the same address, the same function codes, the same data (for a write operation), and the same controls. \(\overline{B E R R}\) should be negated at least one clock cycle before \(\overline{\mathrm{HALT}}\) is negated.

\section*{Note}

The processor will not re-run a read-modify-write cycle. This restriction is made to guarantee that the entire cycle runs correctly and that the write operation of a Test-andSet operation is performed without ever releasing \(\overline{\mathrm{AS}}\). If \(\overline{B E R R}\) and HALT are asserted during a read-modify-write bus cycle, a bus error operation results.

Halt Operation with No Bus Error. The \(\overline{\text { HALT }}\) input signal to the R68000 performs a Halt/Run/Single-Step function in a similar fashion to the R6500 halt functions. When the HALT signal is constantly active the processor "halts" (does nothing) and when the HALT signal is constantly inactive the processor "runs" (does something).

The single-step mode, derived from correctly timed transitions on the HALT signal input, forces the processor to execute a single bus-cycle by entering the "run"' mode until the processor starts a bus cycle then changing to the "halt" mode. Thus, the single-step mode allows the user to proceed through (and therefore debug) processor operations one bus cycle at a time.

Figure 22 details the timing required for correct single-step operations. Some care must be exercised to avoid harmful interactions between BERR and HALT when using the single cycle mode as a debugging tool. This is also true of interactions between the HALT and RESET lines since these can reset the machine.

When the processor completes a bus cycle after recognizing that \(\overline{\mathrm{HALT}}\) is active, most three-state signals are put in the highimpedance state. These include:
1. address lines, and
2. data lines.

This is required for correct performance of the re-run bus cycle operation.

Honoring the halt request has no effect on bus arbitration. Only the bus arbitration function removes the control signals from the bus.

Total debugging flexibility is derived from the software debugging package, the halt function, and the hardware trace capability. These processor capabilities allow the hardware debugger to trace single bus cycles or single instructions at a time.

Double Bus Faults. When a bus error exception occurs, the processor will attempt to stack several words containing information about the state of the machine. If a bus error exception occurs during the stacking operation, there have been two bus errors in a row, or a double bus fault. A double bus fault causes the processor to halt. Once a bus error exception has occurred, any bus error exception occurring before the execution of the next instruction constitutes a double bus fault.


Figure 21. Re-Run Bus Cycle Timing Diagram


Figure 22. Halt Signal Timing Waveforms

Note that a bus cycle which is re-run does not constitute a bus error exception, and does not contribute to a double bus fault. This means that as long as the external hardware requests it, the processor will continue to re-run the same bus cycle.

The bus error ( \(\overline{\mathrm{BERR}})\) pin also has an effect on processor operation after the processor receives an external reset input. The processor reads the vector table after a reset to determine the address to start program execution. If a bus error occurs while reading the vector table (or at any time before the first instruction is executed), the processor reacts as if a double bus fault has occurred and it halts. Only an external reset will start a halted processor.

RESET OPERATION. The reset signal is a bidirectional signal that allows either the processor or an external signal to reset the system. Figure 23 is a timing diagram for reset operations. Both HALT and RESET must be applied to ensure total reset of the processor.

When the \(\overline{\text { RESET }}\) and \(\overline{\text { HALT }}\) are driven by an external device the entire system, including the processor, is reset. The processor responds by reading the reset vector table entry (vector number zero, address \$000000) and loading into the supervisor stack pointer (SSP). Vector table entry number one at address \(\$ 000004\) is read next and loaded into the program counter. The processor initializes the status register to an interrupt level of seven, with no other register being affected.

Execution of the RESET instruction drives the reset pin low for 124 clock periods. In this case, the processor is trying to reset the rest of the system. The internal state of the processor, including the processor's internal registers and the status register, is unaffected by the execution of a RESET instruction. All external devices connected to the reset line will be reset at the completion of the RESET instruction.

Asserting \(\overline{\operatorname{RESET}}\) and \(\overline{\text { HALT }}\) for 10 clock cycles will cause a processor reset, except when Vcc is initially applied to the processor. In this case, an external reset must be applied for 100 milliseconds.

\section*{THE RELATIONSHIP OF \(\overline{\text { DTACK }}, \overline{B E R R}\), AND HALT}

In order to properly control termination of a bus cycle for a re-run or a bus error condition, \(\overline{\text { DTACK }}, \overline{B E R R}\), and HALT should be asserted and negated on the rising edge of R68000 clock. This will assure that when two signals are asserted simultaneously, the required setup time (\#47) for both of them will be met during the same bus state.

This, or some equivalent precaution, should be designed external to the R68000. Parameter \#48 is intended to ensure this operation in a totally asynchronous system, and may be ignored if the above conditions are met.

The preferred bus cycle terminations may be summarized as follows (case numbers refer to Table 4):
Normal Termination: \(\overline{\text { DTACK }}\) occurs first (case 1).
Halt Termination: \(\overline{\text { HALT }}\) is asserted at same time, or precedes \(\overline{\text { DTACK (no } \overline{B E R R} \text { ) cases } 2 \text { and } 3 . ~}\)
Bus Error Termination: \(\overline{\operatorname{BERR}}\) is asserted in lieu of, at same time, or preceding \(\overline{\text { DTACK }}\) (case 4); \(\overline{B E R R}\) negated at same time, or after DTACK.

Re-Run Termination: \(\overline{\text { HALT }}\) and BERR asserted in lieu of, at the same time, or before DTACK (cases 6 and 7); \(\overline{\text { HALT must }}\) be negated at least one cycle after \(\overline{B E R R}\). (Case 5 indicates \(\overline{B E R R}\) may precede HALT which allows fully asynchronous assertion).

Table 4 details the resulting bus cycle termination under various combinations of control signal sequences. The negation of these same control signals under several conditions is shown in Table 5. (DTACK is assumed to be negated normally in all cases; for best results, both \(\overline{\text { DTACK }}\) and \(\overline{\text { BERR }}\) should be negated when address strobe is negated).

Example A: A system uses a watch-dog timer to terminate accesses to unpopulated address space. The timer asserts \(\overline{\mathrm{DTACK}}\) and \(\overline{B E R R}\) simultaneously after timeout (case 4).


NOTES:
1) INTERNAL START-UP TIME
2) SSP HIGH READ IN HERE
3) SSP LOW READ IN HERE
4) PC HIGH READ IN HERE
5) PC LOW READ IN HERE 6) FIRST INSTRUCTION FETCHED HERE.

> XXXX bus state unknown (all CONTROL SIGNALS INACTIVE)
> \(>\) dATA bus in read mode

Figure 23. Reset Operation Timing Diagram

Example B: A system uses error detection on RAM contents. Designer may (a) delay \(\overline{\text { DTACK }}\) until data verified, and return BERR and HALT simultaneously to re-run error cycle (case 6), or if valid, return DTACK (case 1); (b) delay DTACK until data verified and return BERR at same time as DTACK if data in error (case 4).

\section*{ASYNCHRONOUS VERSUS SYNCHRONOUS OPERATION}

\section*{Asynchronous Operation}

To achieve clock frequency independence at a system level, the R68000 can be used in an asynchronous manner. This entails using only the bus handshake lines ( \(\overline{\mathrm{AS}}, \overline{\mathrm{UDS}}, \overline{\mathrm{LDS}}, \overline{\mathrm{DTACK}}\), \(\overline{B E R R}, \overline{H A L T}\), and \(\overline{\mathrm{VPA}}\) ) to control the data transfer. Using this method, \(\overline{A S}\) signals the start of a bus cycle and the data strobes are used as a condition for valid data on a write cycle. The slave device (memory or peripheral) then responds by placing the requested data on the data bus for a read cycle or latching data on a write cycle and asserting the data transfer acknowledge signal (DTACK) to terminate the bus cycle. If no slave reponds or the access is invalid, external control logic asserts the BERR, or \(\overline{B E R R}\) and \(\overline{\text { HALT, signal to abort or rerun the bus cycle. }}\)

The \(\overline{\text { DTACK }}\) signal is allowed to be asserted before the data from a slave device is valid on a read cycle. The length of time that DTACK may precede data is given as parameter \#31 (See Figure 45) and it must be met in any asynchronous system to insure that valid data is latched into the processor. Notice that there is no maximum time specified from the assertion of \(\overline{A S}\) to the assertion of DTACK. This is because the MPU will insert wait cycles of one clock period each until DTACK is recognized.

The \(\overline{B E R R}\) signal is allowed to be asserted after the \(\overline{\text { DTACK }}\) signal is asserted. \(\overline{B E R R}\) must be asserted within the time given as parameter \#48 after DTACK is asserted in any asynchronous system to insure proper operation. If this maximum delay time is violated, the processor may exhibit erratic behavior.

\section*{Synchronous Operation}

To allow for those systems which use the system clock as a signal to generate DTACK and other asynchronous inputs, the asynchronous inputs setup time is given as parameter \#47. If this setup is met on an input, such as DTACK, the processor is guaranteed to recognize that signal on the next falling edge of the system clock. However, the converse is not true-if the input signal does not meet the setup time it is not guaranteed not to be recognized. In addition, if DTACK is recognized on a falling edge, valid data will be latched into the processor (on a read cycle) on the next falling edge provided that the data meets the setup time given as parameter \#27. Given this, parameter \#31 may be ignored. Note that if \(\overline{\text { DTACK }}\) is asserted, with the required setup time, before the falling edge of \(S 4\), no wait states will be incurred and the bus cycle will run at its maximum speed of four clock periods.

In order to assure proper operation in a synchronous system when BERR is asserted after DTACK, the following conditions must be met. Within one clock cycle after DTACK was recognized, \(\overline{B E R R}\) must meet the setup time parameter \#27A prior to the falling edge of the next clock. The setup time is critical to proper operation, and the R68000 may exhibit erratic behavior if it is violated.
Note
During an active bus cycle, VPA and \(\overline{\text { BERR }}\) are sampled
on every falling edge of the clock starting with SO. \(\overline{\text { DTACK }}\)
is sampled on every falling edge of the clock starting with
S4 and data is latched on the falling edge of 56 during
a read. The bus cycle will then be terminated in S7 except
when BERR is asserted in the absence of DTACK, in
which case it will terminate one clock cycle later in S9.

\section*{Note}

During an active bus cycle, \(\overline{\mathrm{VPA}}\) and \(\overline{\mathrm{BERR}}\) are sampled on every falling edge of the clock starting with SO. DTACK is sampled on every falling edge of the clock starting with S4 and data is latched on the falling edge of S6 during a read. The bus cycle will then be terminated in 57 except which case it will terminate one clock cycle later in S9.

Table 4. \(\overline{\text { DTACK }}, \overline{B E R R}, \overline{\text { HALT }}\) Assertion Results
\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Case No.} & \multirow[b]{2}{*}{Control Signal} & \multicolumn{2}{|l|}{Asserted on Rising Edge of State} & \multirow[b]{2}{*}{Result} \\
\hline & & N & \(\mathrm{N}+2\) & \\
\hline 1 & \begin{tabular}{l}
\(\overline{\text { DTACK }}\) \\
BERR \\
HALT
\end{tabular} & \begin{tabular}{l}
A \\
NA \\
NA
\end{tabular} & \[
\begin{aligned}
& \mathrm{S} \\
& \mathrm{X} \\
& \mathrm{X} \\
& \hline
\end{aligned}
\] & Normal cycle terminate and continue. \\
\hline 2 & \(\overline{\text { DTACK }}\) BERR HALT & \[
\begin{aligned}
& \mathrm{A} \\
& \mathrm{NA} \\
& \mathrm{~A} \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& S \\
& X \\
& S
\end{aligned}
\] & Normal cycle terminate and halt. Continue when \(\overline{\text { HALT }}\) removed. \\
\hline 3 & \[
\begin{aligned}
& \overline{\overline{\text { DTACK }}} \\
& \overline{\text { BERR }} \\
& \text { HALT }
\end{aligned}
\] & \[
\begin{aligned}
& \text { NA } \\
& \text { NA } \\
& \text { A }
\end{aligned}
\] & \begin{tabular}{l}
A \\
NA \\
S
\end{tabular} & Normal cycle terminate and halt. Continue when \(\overline{\text { HALT }}\) removed. \\
\hline 4 & DTACK BERR HALT & \begin{tabular}{l}
X \\
A \\
NA
\end{tabular} & \begin{tabular}{l}
X \\
S \\
NA
\end{tabular} & Terminate and take bus error trap. \\
\hline 5 & \[
\begin{aligned}
& \overline{\text { DTACK }} \\
& \frac{\overline{B E R R}}{\text { HALT }}
\end{aligned}
\] & \[
\begin{aligned}
& \text { NA } \\
& \text { A } \\
& \text { NA }
\end{aligned}
\] & \[
\begin{aligned}
& X \\
& S \\
& \text { A }
\end{aligned}
\] & Terminate and re-run. \\
\hline 6 & \[
\begin{aligned}
& \overline{\overline{\text { DTACK }}} \\
& \frac{\overline{\text { HERR }}}{}
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{X} \\
& \mathrm{~A} \\
& \mathrm{~A}
\end{aligned}
\] & \[
\begin{aligned}
& X \\
& S \\
& S
\end{aligned}
\] & Terminate and re-run when \(\overline{\text { HALT }}\) removed. \\
\hline 7 & \[
\begin{aligned}
& \overline{\overline{\text { DTACK }}} \\
& \frac{\overline{\text { BERR }}}{\text { HALT }}
\end{aligned}
\] & \[
\begin{aligned}
& \text { NA } \\
& \text { NA } \\
& \text { A }
\end{aligned}
\] & \[
\begin{aligned}
& X \\
& \text { A } \\
& \text { S }
\end{aligned}
\] & Terminate and re-run when \(\overline{\text { HALT }}\) removed. \\
\hline
\end{tabular}

Legend:
N - the number of the current even bus state (e.g., S4, S6, etc.)
A - signal is asserted in this bus state
NA - signal is not asserted in this state
X - don't care
S - signal was asserted in previous state and remains asserted in this state

Table 5. \(\overline{\text { BERR }}\) AND \(\overline{\text { HALT }}\) Negation Results
\begin{tabular}{|c|c|c|c|c|c|}
\hline & & & \[
d \text { on }
\]
of & \begin{tabular}{l}
ising \\
te
\end{tabular} & \\
\hline Table 4-4 & Signal & N & & \(N+2\) & Results - Next Cycle \\
\hline Bus Error & \[
\frac{\overline{\text { BERR }}}{\text { HALT }}
\] & \(\bullet\) & or or & \[
\bullet
\] & Takes bus error trap. \\
\hline Re-run & \[
\overline{\overline{\text { BERR }}}
\] & \(\bullet\) & or & - & Illegal sequence; usually traps to vector number 0 . \\
\hline Re-run & \[
\frac{\overline{\text { BERR }}}{\text { HALT }}
\] & - & & \(\bullet\) & Re-runs the bus cycle. \\
\hline Normal & \[
\frac{\overline{\text { BERR }}}{\text { HALT }}
\] & \(\bullet\) & or & \(\bullet\) & May lengthen next cycle. \\
\hline Normal & \[
\frac{\overline{\text { BERR }}}{\text { HALT }}
\] & & & none & If next cycle is started it will be terminated as a bus error. \\
\hline \multicolumn{6}{|l|}{\(\bullet=\) Signal is negated in this bus state.} \\
\hline
\end{tabular}

\section*{PROCESSING STATES}

The following paragraphs describe the actions of the R68000 which are outside the normal processing associated with the execution of instructions. The functions of the bits in the supervisor portion of the status register are covered: the supervisor/user bit, the trace enable bit, and the processor interrupt priority mask. The sequence of memory references and actions taken by the processor on exception conditions are detailed.

The R68000 is always in one of three processing states: normal, exception, or halted. The normal processing state associated with instruction execution; the memory references are to fetch instructions and operands, and to store results. A special case of the normal state is the stopped state which the processor enters when a STOP instruction is executed. In this state, no further references are made.

The exception processing state is associated with interrupts, trap instructions, tracing and other exceptional conditions. The exception may be internally generated by an instruction or by an unusual condition arising during the execution of an instruction. Externally, exception processing can be forced by an interrupt, by a bus error, or by a reset. Exception processing is designed to provide an efficient context switch so that the processor may handle unusual conditions.

The halted processing state is an indication of a catastrophic hardware failure. For example, if during the exception processing of a bus error another bus error occurs, the processor assumes that the system is unusable and halts. Only an external reset can restart a halted processor. Note that a processor in the stopped state is not in the halted state, nor vice versa.

\section*{PRIVILEGE STATES}

The processor operates in one of two states of privilege: the "user'" state or the "'supervisor" state. The privilege state determines legal operations. It is used to choose between the supervisor stack pointer and the user stack pointer in instruction references, and by the external memory management device to control and translate accesses.

The privilege state is a mechanism for providing security in a computer system by allowing most programs to execute in user state. In this state, the accesses are controlled, and the effects on other parts of the system are limited. Programs should access only their own code and data areas, and ought to be restricted from accessing information.

The operating system which executes in the supervisor state, has access to all resources and performs the overhead tasks for the user state programs.

SUPERVISOR STATE. The supervisor state is the higher state of privilege. For instruction execution, the supervisor state is determined by asserting (high) the S-bit of the status register. All instructions can be executed in the supervisor state. The bus cycles generated by instructions executed in the supervisor state are classified as supervisor references. While the processor is in the supervisor privilege state, those instructions which use either the system stack pointer implicitly or address register seven explicitly access the supervisor stack pointer.

All exception processing is done in the supervisor state, regardless of the setting of the S-bit. The bus cycles generated during exception processing are classified as supervisor references. All stacking operations during exception processing use the supervisor stack pointer.

USER STATE. The user state is the lower state of privilege. For instruction execution, the user state is determined by negating (low) the S-bit of the status register.

Most instructions execute the same in user state as in the supervisor state. However, some instructions which have important system effects are made privileged. User programs are not permitted to execute the STOP instruction, or the RESET instruction. To ensure that a user program cannot enter the supervisor state except in a controlled manner, the instructions which modify the whole state register are priviled. To aid in debugging programs which are to be used as operating systems, the move to user stack pointer (MOVE to USP) and move from user stack pointer (MOVE from USP) instructions are also privileged.

The bus cycles generated by an instruction executed in user state are classified as user state references. This allows an external memory management device to translate the address and to control access to protected portions of the address space. While the processor is in user privilege state, those instructions which use either the system stack pointer implicitly or address register seven explicitly, access the user stack pointer.

PRIVILEGE STATE CHANGES. Once the processor is in the user state and executing instructions, only exception processing can change the privilege state. During exception processing, the current setting of the S-bit of the status register is saved and the S -bit is asserted, putting the processing in the supervisor state. Therefore, when instruction execution resumes to process the exception, the processor is in the supervisor privilege state.

REFERENCE CLASSIFICATION. When the processor makes a reference, it classifies the kind of reference being made by using the encoding on the three function code output lines. This allows external translation of addresses, control of access, and differentiation of special processor states, such as interrupt acknowledge. Table 6 lists the classification of references.

Table 6. Reference Classification
\begin{tabular}{|c|c|c|l|}
\hline \multicolumn{3}{|c|}{ Function Code Output } & \multirow{2}{*}{} \\
\cline { 1 - 2 } FC2 & FC1 & FC0 & \multirow{2}{*}{ Reference Class } \\
\hline 0 & 0 & 0 & (Unassigned) \\
\hline 0 & 0 & 1 & User Data \\
\hline 0 & 1 & 0 & User Program \\
\hline 0 & 1 & 1 & (Unassigned) \\
\hline 1 & 0 & 0 & (Unassigned) \\
\hline 1 & 0 & 1 & Supervisor Data \\
\hline 1 & 1 & 0 & Supervisor Program \\
\hline 1 & 1 & 1 & Interrupt Acknowledge \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|}
\hline WORD 0 & NEW PROGRAM COUNTER (HIGH) & \(A 0=0, A 1=0\) \\
\hline WORD 1 & NEW PROGRAM COUNTER (LOW) & \(A 0=0, A 1=1\) \\
\hline
\end{tabular}

Figure 24. Exception Vector Format


Figure 25. Peripheral Vector Number Format


Figure 26. Address Translated From 8-Bit Vector Number

\section*{EXCEPTION PROCESSING}

Before discussing the details of interrupts, traps, and tracing, a general description of exception processing is in order. The processing of an exception occurs in four steps, with variations for different exception causes. During the first step, a temporary copy of the status register is made, and the status register is set for exception processing. In the second step the exception vector is determined, and the third step is the saving of the current processor contents. In the fourth step a new context is obtained, and the processor switches to instruction processing.

EXCEPTION VECTORS. Exception vectors are memory locations from which the processor fetches the address of a routine which will handle that exception. All exception vectors are two words in length (Figure 24), except for the reset vector, which is four words. All exception vectors lie in the supervisor data space, except for the reset vector which is in the supervisor program space. A vector number is an eight-bit number which, when multipled by four, gives the address of an exception vector. Vector numbers are generated internally or externally, depending on the cause of the exception. In the case of interrupts, during the interrupt acknowledge bus cycle, a peripheral provides an 8 -bit vector number (Figure 25) to the processor on data bus lines D0 through D7. The processor translates the vector number into a full 24 -bit address, as shown in Figure 26. The memory layout for exception vectors is given in Table 7.

As shown in Table 7, the memory layout is 512 words long (1024 bytes). It starts at address 0 and proceeds through
address 1023. This provides 255 unique vectors; some of these are reserved for TRAPS and other system functions. Of the 255, there are 192 reserved for user interrupt vectors. However, there is no protection on the first 64 entries, so user interrupt vectors may overlap at the discretion of the systems designer.

KINDS OF EXCEPTIONS. Exceptions can be generated either internally or externally. Externally generated exceptions include interrupts (IRQ), bus error (BERR), and reset ( \(\overline{\mathrm{RESET}}\) ) requests. Interrupts are requests from peripheral devices for processor action while BERR and RESET inputs are used for access control and processor restart. Internally generated exceptions come from instructions, from address errors, or from tracing. The trap (TRAP), trap on overflow (TRAPV), check register against bounds (CHK) and divide (DIV) instructions can all generate exceptions as part of their instruction execution. In addition, illegal instructions, word fetches from odd addresses and privilege violations cause exceptions. Tracing behaves like a very high priority, internally generated interrupt after each instruction execution.

EXCEPTION PROCESSING SEQUENCE. Exception processing occurs in four identifiable steps. In the first step, an internal copy is made of the status register. After the copy is made, the S-bit is asserted, putting the processor into the supervisor privilege state. Also, the T-bit is negated which will allow the exception handler to execute unhindered by tracing. For the reset and interrupt exceptions, the interrupt priority mask is also updated.

Table 7. Exception Vector Assignment



Figure 27. Exception Stack Order (Groups 1 and 2)
In the second step, the vector number of the exception is determined. For interrupts, the vector number is obtained by a processor fetch, classified as an interrupt acknowledge. For all other exceptions, internal logic provides the vector number. This vector number is then used to generate the address of the exception vector.

The third step is to save the current processor status except for the reset exception. The current program counter value and the saved copy of the status register are stacked using the supervisor stack pointer as shown in Figure 27. The program counter value stacked usually points to the next unexecuted instruction; however, for bus error and address error, the value stacked for the program counter is unpredictable, and may be incremented from the address of the instruction which caused the error. Additional information defining the current context is stacked for the bus error and address error exceptions.

The last step is the same for all exceptions. The new program counter value is fetched from the exception vector. The processor then resumes instruction execution. The instruction at the address given in the exception vector is fetched, and normal instruction decoding and execution is started.

MULTIPLE EXCEPTIONS. These paragraphs describe the processing which occurs when multiple exceptions arise simultaneously. Exceptions can be grouped according to their occurrence and priority. The Group 0 exceptions are reset, bus error, and address error. These exceptions cause the instruction currently being executed to be aborted, and the exception processing to commence within two clock cycles. The Group 1 exceptions are trace and interrupt, as well as the privilege violations and illegal instructions. These exceptions allow the current instruction to execute to completion, but preempt the execution of the next instruction by forcing exception processing to occur (privilege violations and illegal instructions are detected when they are the next instruction to be executed). The Group 2 exceptions occur as part of the normal processing of instructions. The TRAP, TRAPV, CHK, and zero divide exceptions are in this group. For these exceptions, the normal execution of an instruction may lead to exception processing.

Group 0 exceptions have highest priority, while Group 2 exceptions have lowest priority. Within Group 0, reset has highest priority, followed by address error and then bus error. Within Group 1, trace has priority over external interrupts, which in turn takes priority over illegal instruction and privilege violation. Since only one instruction can be executed at a time, there is no priority relation within Group 2.

Table 8. Exception Grouping and Priority
\begin{tabular}{|c|l|l|}
\hline Group & \multicolumn{1}{|c|}{ Exception } & \multicolumn{1}{c|}{ Processing } \\
\hline 0 & \begin{tabular}{l} 
Reset \\
Address Error \\
Bus Error
\end{tabular} & \begin{tabular}{l} 
Exception processing begins \\
within two clock cycles.
\end{tabular} \\
\hline 1 & \begin{tabular}{l} 
Trace \\
Interrupt \\
Illegal Instruction \\
Privilege Violation
\end{tabular} & \begin{tabular}{l} 
Exception processing begins \\
before the next instruction.
\end{tabular} \\
\hline 2 & \begin{tabular}{l} 
TRAP, TRAPV, CHK, \\
Zero Divide
\end{tabular} & \begin{tabular}{l} 
Exception processing is started \\
by normal instruction execution
\end{tabular} \\
\hline
\end{tabular}

The priority relation between two exceptions determines which is taken first if the conditions for both arise simultaneously. Therefore, if a bus error occurs during a TRAP instruction, the bus error takes precedence, and the TRAP instruction processing is aborted. In another example, if an interrupt request occurs during the execution of an instruction while the \(T\)-bit is asserted, the trace exception has priority, and is processed first. Before instruction processing resumes, however, the interrupt exception is also processed, and instruction processing commences finally in the interrupt handler routine. Table 8 gives a summary of exception grouping and priority.

\section*{EXCEPTION PROCESSING DETAILED DISCUSSION}

Exceptions have a number of sources, and each exception has a unique processing sequence. The following paragraphs detail the sources of exceptions, how each arises, and how each is processed.

RESET. The reset input provides the highest exception level. The processing of the reset signal is designed for system initiation, and recovery from catastrophic failure. Any processing in progress at the time of the reset is aborted and cannot be recovered. The processor is forced into the supervisor state and the trace state is forced off. The processor interrupt priority mask is set at level seven. The vector number is internally generated to reference the reset exception vector at location 0 in the supervisor program space. Because no assumptions can be made about the validity of register contents, in particular the supervisor stack pointer, neither the program counter nor the status register is saved. The address contained in the first two words of the reset exception vector is fetched as the initial supervisor stack pointer, and the address in the last two words of the reset exception vector is fetched as the initial program counter. Finally, instruction execution is started at the address in the program counter. The powerup/restart code should be pointed to by the initial program counter.

The RESET instruction does not cause loading of the reset vector, but does assert the reset line to reset external devices. This allows the software to reset the system to a known state and then continue processing with the next instruction.

INTERRUPTS. Seven levels of interrupt priorities are provided. Devices may be chained externally within interrupt priority levels, allowing an unlimited number of peripheral devices to interrupt the processor. Interrupt priority levels are numbered from one to seven, level seven being the highest priority. The status register contains a three-bit mask which indicates the current processor priority. Interrupts are inhibited for all priority levels less than or equal to the current processor priority.

An interrupt request is made to the processor by encoding the interrupt request level on the interrupt request lines; a zero indicates no interrupt request. Interrupt requests arriving at the processor do not face immediate exception processing, but are made pending. Pending interrupts are detected between instruction executions. If the priority of the pending interrupt is lower than or equal to the current processor priority, execution continues with the next instruction and the interrupt exception processing is postponed. (The recognition of level seven is slightly different, as explained in a following paragraph.)

If the priority of the pending interrupt is greater than the current processor priority, the exception processing sequence is started. First a copy of the status register is saved, and the privilege state is set to supervisor, then tracing is suppressed, and the processor priority level is set to the level of the interrupt being acknowledged. The processor fetches the vector number from the interrupting device, classifying the reference as an interrupt acknowledge and displaying the level number of the interrupt being acknowledged on the address bus. If external logic requests an automatic vectoring, the processor internally generates a vector number which is determined by the interrupt level number. If external logic indicates a bus error, the interrupt is taken to be spurious, and the generated vector number references the spurious interrupt vector. The processor then proceeds with the usual exception processing, saving the program counter and status register on the supervisor stack. The saved value of the program counter is the address of the instruction which would have been executed had the interrupt not been present. The content of the interrupt vector whose vector number was previously obtained is fetched and loaded into the program counter, and normal instruction execution commences in the interrupt handling routine. A flow chart for the interrupt acknowledge sequence is given in Figure 28, a timing diagram is given in Figure 29, and the interrupt exception timing sequence is shown in Figure 30.

Priority level seven is a special case. Level seven interrupts cannot be inhibited by the interrupt priority mask, thus providing a "non-maskable interrupt" capability. An interrupt is generated each time the interrupt request level changes from some lower level to level seven. Note that a level seven interrupt may still be caused by the level comparison if the request level is a seven and the processor priority is set to a lower level by an instruction.

UNINITIALIZED INTERRUPT. An interrupting device asserts \(\overline{V P A}\) or provides an interrupt vector during an interrupt acknowledge cycle to the R68000. If the vector register has not been initialized, the responding R68000 Family peripheral will provide vector 15 , the uninitialized interrupt vector. This provides a uniform way to recover from a programming error.


Figure 28. Interrupt Acknowledge Sequence Flow Chart

SPURIOUS INTERRUPT. If during the interrupt acknowledge cycle no device responds by asserting \(\overline{\text { DTACK }}\) or \(\overline{\mathrm{VPA}}\), the bus error line should be asserted to terminate the vector acquisition. The processor separates the processing of this error from bus error by fetching the spurious interrupt vector instead of the bus error vector. The processor then proceeds with the usual exception processing.

INSTRUCTION TRAPS. Traps are exceptions caused by instructions. They arise either from processor recognition of abnormal conditions during instruction execution, or from use of instructions whose normal behavior is trapping.

*ALthough a vector number is one byte, both data strobes are asserted due to the microcode used FOR EXCEPTION PROCESSING. THE PROCESSOR DOES NOT RECOGNIZE ANYTHING ON DATA LINES D8 THROUGH D15 AT THIS TIME.

Figure 29. Interrupt Acknowledge Sequence Timing Diagram


Figure 30. Interrupt Exception Timing Sequence

Some instructions are used specifically to generate traps. The TRAP instruction always forces an exception, and is useful for implementing system calls for user programs. The TRAPV and CHK instructions force an exception if the user program detects a runtime error, which may be an arithmetic overflow or a subscript out of bounds.

The signed divide (DIVS) and unsigned divide (DIVU) instructions will force an exception if a division operation is attempted with a divisor of zero.

ILLEGAL AND UNIMPLEMENTED INSTRUCTIONS. Illegal instruction refers to any of the word bit patterns which are not the bit pattern of the first word of a legal instruction. During instruction execution, if such an instruction is fetched, an illegal instruction exception occurs. Rockwell reserves the right to define instructions whose opcodes may be any of the illegal instructions. Three bit patterns will always force an illegal instruction trap on all R68000 Family compatible microprocessors. They are: \$4AFA, \$4AFB, and \$4AFC. Two of the patterns, \$4AFA and \(\$ 4 \mathrm{AFB}\), are reserved for Rockwell system products. The third pattern, \$4AFC, is reserved for customer use.

Word patterns with bits 15 through 12 equaling 1010 or 1111 are distinguished as unimplemented instructions and separate exception vectors are given to these patterns to permit efficient emulation. This facility allows the operating system to detect program errors, or to emulate unimplemented instructions in software.

PRIVILEGE VIOLATIONS. In order to provide system security, various instructions are privileged. An attempt to execute one of the privileged instructions while in the user state will cause an exception. The privileged instructions are:
\begin{tabular}{ll} 
STOP & AND Immediate to SR \\
RESET & EOR Immediate to SR \\
RTE & OR Immediate to SR \\
MOVE USP & MOVE to SR
\end{tabular}

TRACING. To aid in program development, the R68000 includes a facility to allow instruction by instruction tracing. In the trace state, after each instruction is executed an exeception is forced, allowing a debugging program to monitor the execution of the program under test.

The trace facility uses the \(T\)-bit in the supervisor portion of the status register. If the T-bit is negated (off), tracing is disabled, and instruction execution proceeds from instruction to instruction as normal. If the T-bit is asserted (on) at the beginning of the execution of an instruction, a trace exception will be generated after the execution of that instruction is completed. If the instruction is not executed, either because an interrupt is taken, or the instruction is illegal or privileged, the trace exception does not occur. The trace exception also does not occur if the instruction is aborted by a reset, bus error, or address error exception. If the instruction is indeed executed and an interrupt
is pending on completion, the trace exception is processed before the interrupt exception. If, during the execution of the instruction, an exception is forced by that instruction, the forced exception is processed before the trace exception.

As an extreme illustration of the above rules, consider the arrival of an interrupt during the execution of a TRAP instruction while tracing is enabled. First the trap exception is processed, then the trace exception, and finally the interrupt exception. Instruction execution resumes in the interrupt handler routine.

BUS ERROR. Bus error exceptions occur when the external logic requests that a bus error be processed by an exception. The current bus cycle which the processor is making is then aborted. Whether the processor was doing instruction or exception processing, that processing is terminated, and the processor immediately begins exception processing.

Exception processing for bus error follows the usual sequence of steps. The status register is copied, the supervisor state is entered, and the trace state is turned off. The vector number is generated to refer to the bus error vector. Since the processor was not between instructions when the bus error exception request was made, the context of the processor is more detailed. To save more of this context, additional information is saved on the supervisor stack. The program counter and the copy of the status register are of course saved. The value saved for the program counter is advanced by some amount, two to ten bytes beyond the address of the first word of the instruction which made the reference causing the bus error. If the bus error occurred during the fetch of the next instruction, the saved program counter has a value in the vicinity of the current instruction, even if the current instruction is a branch, a jump, or a return instruction. Besides the usual information, the processor saves its internal copy of the first word of the instruction being processed, and the address which was being accessed by the aborted bus cycle. Specific information about the access is also saved: whether it was a read or a write, whether the processor was processing an instruction or not, and the classification displayed on the function code outputs when the bus error occurred. The processor is processing an instruction if in the normal state or processing a Group 2 exception; the processor is not processing an instruction when processing a Group 0 or a Group 1 exception. Figure 31 illustates how the information is organized on the supervisor stack. Although this information is not sufficient to effect full recovery from the bus error, it does allow software diagnosis. Finally, the processor commences instruction processing at the address contained in the vector. It is the responsibility of the error handler routine to clean up the stack and determine where to continue execution.

If a bus error occurs during the exception processing for a bus error, address error, or reset, the processor is halted, and all processing ceases. This simplifies the detection of catastrophic system failure, since the processor removes itself from the system rather than destroy all memory contents. Only the RESET pin can restart a halted processor.


Figure 31. Supervisor Stack Order (Group 0)


Figure 32. Address Error Timing

ADDRESS ERROR. Address error exceptions occur when the processor attempts to access a word or a long word operand or an instruction at an odd address. The effect is much like an internally generated bus error, so that the bus cycle is aborted, and the processor ceases whatever processing it is currently doing and begins exception processing. After exception processing commences, the sequence is the same as that for bus error including the information that is stacked, except that the vector number refers to the address error vector instead. Likewise, if an address error occurs during the exception processing for a bus error, address error, or reset, the processor is halted. As shown in Figure 32, an address error will execute a short bus cycle followed by an exception processing.

\section*{INTERFACE WITH R6500 PERIPHERALS}

Rockwell's line of R6500 peripherals are directly compatible with the R68000. Some of these devices that are particularly useful are:

R6520 Peripheral Interface Adapter (PIA)
R6522 Versatile Interface Adapter (VIA)
R6545 CRT Controller (CRTC)
R6551 Asynchronous Communication Interface Adapter (ACIA)

To interface the synchronous R6500 peripherals with the asynchronous R68000, the processor modifies its bus cycle to meet the R6500 cycle requirements whenever an R6500 device address is detected. This is possible since both processors use memory mapped I/O. Figure 33 is a flow chart of the interface operation between the processor and R6500 devices. 6800 peripherals are also compatible with the R68000 processor.


Figure 33. R6500 Interfacing Flow Chart

\section*{DATA TRANSFER OPERATION}

Three signals on the processor provide the R6500 interface. They are: enable ( E ), valid memory address ( \(\overline{\mathrm{VMA}}\) ), and valid Peripheral address (VPA). Enable corresponds to the E or \(\emptyset 2\) signal in existing R6500 systems. The bus frequency is one tenth of the incoming R68000 clock frequency. The timing of E allows 1 MHz peripherals to be used with an 8 MHz R68000. Enable has a 60/40 duty cycle; that is, it is low for six input clocks and high for four input clocks. This duty cycle allows the processor to do successive \(\overline{\mathrm{VPA}}\) accesses on successive \(E\) pulses.

Figures 34 and 35 give a general R6500 to R68000 interface timing, while Figures 36 and 37 detail the specific timing parameters involved in the interface. At state zero (S0) in the cycle, the address bus is in the high-impedance state. A function code is asserted on the function code output lines. Onehalf clock later, in state 1 , the address bus is released from the high-impedance state.

During state 2 , the address strobe ( \(\overline{\mathrm{AS}}\) ) is asserted to indicate that there is a valid address on the address bus. If the bus cycle is a read cycle, the upper and/or lower data strobes are also asserted in state 2. If the bus cycle is a write cycle, the read/write ( \(R / \bar{W}\) ) signal is switched to a low (write) during state 2. One-half clock later, in state 3, the write data is placed on the data bus, and in state 4 the data strobes are issued to indicate valid data on the data bus. The processor now inserts wait states until it recognizes the assertion of \(\overline{\mathrm{VPA}}\).

The \(\overline{V P A}\) input signals the processor that the address on the bus is the address of an R6500 device (or an area reserved for R6500 devices) and that the bus should conform to the \(\emptyset 2\) transfer characteristics of the R6500 bus. Valid peripheral address ( \(\overline{\mathrm{VPA}}\) ) is derived by decoding the address bus, conditioned by address strobe ( \(\overline{\mathrm{AS}}\) ). Chip select for the R6500 peripherals should be derived by decoding the address bus conditioned by VMA.

After the recognition of \(\overline{\mathrm{VPA}}\), the processor assures that the Enable (E) is low, by waiting if necessary, and subsequently asserts \(\overline{\mathrm{VMA}}\). Valid memory address is then used as part of the chip select equation of the peripheral. This ensures that the R6500 peripherals are selected and deselected at the correct time. The peripheral now runs its cycle during the high portion of the E signal. Figures 34 and 35 depict the best and worst case R6500 cycle timing. This cycle length is dependent strictly upon when VPA is asserted in relationship the E clock.

If we assume that external circuitry asserts \(\overline{\mathrm{VPA}}\) as soon as possible after the assertion of \(\overline{\mathrm{AS}}\), then VPA will be recognized as being asserted on the falling edge of S4. In this case, no "extra" wait cycles will be inserted prior to the recognition of \(\overline{\text { VPA }}\) assertion and only the wait cycles inserted to synchronize with the E clock will determine the total length of the cycle. In any case, the synchronization delay will be some integral number of clock cycles within the following two extremes:
1. Best Case- \(\overline{V P A}\) is recognized as being asserted on the falling edge three clock cycles before E rises (or three clock cycles after \(E\) falls).


Figure 34. R68000 to R6500 Peripheral Timing-Best Case


Figure 35. R68000 to R6500 Peripheral Timing-Worst Case


NOTES:
THIS FIGURE REPRESENTS THE BEST CASE R6500 TIMING WHERE \(\overline{\text { PPA }}\) FALLS BEFORE THE THIRD SYSTEM CLOCK CYCLE AFTER THE FALLING EDGE OF E.
this timing diagram is included for those who wish to design their own circuit to generate \(\overline{\text { VMA it shows }}\) the best case possibly attainable.
2. Worst Case- \(\overline{\mathrm{VPA}}\) is recognized as being asserted on the falling edge two clock cycles before \(E\) rises (or four clock cycles after E falls).

Near the end of a read cycle, the processor latches the peripheral's data in state 6 . For all cycles, the processor negates the address and data strobes one half clock cycle later in state 7, and the Enable signal goes low at this time. Another half clock later, the address bus is put in the high-impedance state. Upon write cycle completion, the data bus is put in the high-impedance state and the read/write signal is switched high. The peripheral logic must remove VPA within one clock after address strobe is negated.
\(\overline{\text { DTACK }}\) should not be asserted while \(\overline{\mathrm{VPA}}\) is asserted. Note that the R68000 VMA is active low. This allows the processor to put its buses in the high-impedance state on DMA requests without inadvertently selecting peripherals.

\section*{INTERRUPT OPERATION}

During an interrupt acknowledge cycle while the processor is fetching the vector, if \(\overline{\mathrm{VPA}}\) is asserted, the R68000 will assert \(\overline{\mathrm{VMA}}\) and complete a normal R6500 read cycle as shown in Figure 38. The processor will then use an internally generated vector, called an autovector, that is a function of the interrupt being served. The seven autovectors are vector numbers 25 through 31 (decimal).

Autovectors operate in the same fashion as (but are not restricted to) the R6500 interrupt sequence. The basic difference is that there are six normal interrupt vectors and one NMI type vector. As with both the R6500 and the R68000's normal vectored interrupt, the interrupt service routine can be located anywhere in the address space. This is due to the fact that while the vector numbers are fixed, the contents of the vector table entries are assigned by the user.

Since \(\overline{\mathrm{VMA}}\) is asserted during autovectoring, the R6500 peripheral address decoding should prevent unintended accesses.

\section*{DATA TYPES AND ADDRESSING MODES}

Five basic data types are supported. These data types are:
Bits
BCD Digits (4-bits)
Bytes (8-bits)
Word (16-bits)
Long Words (32-bits)

In addition, operations on other data types such as memory addresses, status word data, etc., are provided for in the instruction set.

The 14 addressing modes, shown in Table 9, include six basic types:

\footnotetext{
Register Direct
Register Indirect
Absolute
Program Counter Relative Implied
Immediate
}

Included in the register indirect addressing modes is the capability to do postincrementing, predecrementing, offsetting and indexing. Program counter relative mode can also be modified via indexing and offsetting.

Table 9. Addressing Modes
\begin{tabular}{|c|c|}
\hline Mode & Generation \\
\hline Register Direct Addressing Data Register Direct Address Register Direct & \[
\begin{aligned}
& E A=D n \\
& E A=A n
\end{aligned}
\] \\
\hline Absolute Data Addressing Absolute Short Absolute Long & \[
\begin{aligned}
& E A=\text { (Next Word }) \\
& E A=\text { (Next Two Words })
\end{aligned}
\] \\
\hline \begin{tabular}{l}
Program Counter Relative Addressing \\
Relative with Offset Relative with Index and Offset
\end{tabular} & \[
\begin{aligned}
& E A=(P C)+d_{16} \\
& E A=(P C)+(X n)+d_{8}
\end{aligned}
\] \\
\hline \begin{tabular}{l}
Register Indirect Addressing \\
Register Indirect \\
Postincrement Register Indirect \\
Predecrement Register Indirect \\
Register Indirect with Offset \\
Indexed Register Indirect with Offset
\end{tabular} & \[
\begin{aligned}
& E A=(A n) \\
& E A=(A n), A n \leftarrow A n+N \\
& A n \not A n-N, E A=(A n) \\
& E A=(A n)+d_{16} \\
& E A=(A n)+(X n)+d_{8}
\end{aligned}
\] \\
\hline Immediate Data Addressing Immediate Quick Immediate & DATA \(=\) Next Word(s) Inherent Data \\
\hline Implied Addressing Implied Register & \(E A=S R, U S P, S P, P C\) \\
\hline \begin{tabular}{l}
NOTES: \\
\(E A=\) Effective Address \\
An = Address Register \\
Dn = Data Register \\
\(\mathrm{Xn}=\) Address or Data Register used as Index Register \\
\(\mathrm{SR}=\) Status Register \\
PC = Program Counter \\
( ) = Contents of \\
\(\mathrm{d}_{8}=\) Eight-bit Offset (displacement) \\
\(d_{16}=\) Sixteen-bit Offset (displacement)
\end{tabular} & \begin{tabular}{l}
\(N=1\) for Byte, 2 for Words and 4 for Long Word. If An is the stack pointer and the operand size is byte, \(N=2\) to keep the stack pointer on a word boundry. \\
= Replaces
\end{tabular} \\
\hline
\end{tabular}

\section*{INSTRUCTION SET OVERVIEW}

The R68000 instruction set is shown in Table 10. Some additional instructions are variations, or subsets, of these and they appear in Table 11. Special emphasis has been given to the instruction set's support of structured high-level languages to facilitate ease of programming. Each instruction, with few exceptions, operates on bytes, words, and long words and most instructions can use any of the 14 addressing modes. Combining instruction types, data types, and addressing modes, over 1000 useful instructions are provided. These instructions include signed and unsigned multiply and divide, "quick" arithmetic operations. BCD arithmetic and expanded operations (through traps).


NOTE: THIS TIMING DIAGRAM IS INCLUDED FOR THOSE WHO WISH TO DESIGN THEIR OWN CIRCUIT TO GENERATE VMA. IT SHOWS THE WORST CASE POSSIBLY ATTAINABLE.

Figure 37. RC68000 to R6500 Peripheral Timing Diagram - Worst Case

*ALTHOUGH A VECTOR NUMBER IS ONE BYTE, BOTH DATA STROBES ARE ASSERTED DUE TO THE MICROCODE USED FOR EXCEPTION PROCESSING. THE PROCESSOR DOES NOT RECOGNIZE ANYTHING ON DATA LINES D8 THROUGH D15 AT THIS TIME.

Figure 38. Autovector Operation Timing Diagram

Table 10. Instruction Set Summary
\begin{tabular}{|c|c|c|c|c|c|}
\hline Mnemonic & Description & Mnemonic & Description & Mnemonic & Description \\
\hline \multirow[t]{6}{*}{\begin{tabular}{l}
ADBC \\
ADD \\
AND \\
ASL \\
ASR
\end{tabular}} & \multirow[t]{6}{*}{\begin{tabular}{l}
Add Decimal with Extend \\
Add \\
Logical And \\
Arithmetic Shift Left \\
Arithmetic Shift Right
\end{tabular}} & \multirow[t]{4}{*}{\[
\begin{aligned}
& \text { EOR } \\
& \text { EXG } \\
& \text { EXT }
\end{aligned}
\]} & \multirow[t]{4}{*}{Exclusive Or Exchange Registers Sign Extend} & \multirow[t]{2}{*}{PEA} & \multirow[t]{2}{*}{Push Effective Address} \\
\hline & & & & & \\
\hline & & & & \multirow[t]{9}{*}{\begin{tabular}{l}
RESET \\
ROL \\
ROR \\
ROXL \\
ROXR \\
RTE \\
RTR \\
RTS
\end{tabular}} & \multirow[t]{9}{*}{\begin{tabular}{l}
Reset External Devices \\
Rotate Left without Extend \\
Rotate Right without Extend \\
Rotate Left with Extend \\
Rotate Right with Extend \\
Return from Exception \\
Return and Restore \\
Return from Subroutine
\end{tabular}} \\
\hline & & & & & \\
\hline & & JMP JSR & Jump Jump to Subroutine & & \\
\hline & & \multirow[t]{2}{*}{JSR} & \multirow[t]{2}{*}{Jump to Subroutine} & & \\
\hline \multirow[t]{7}{*}{\(B_{C C}\) BCHG BCLR BRA BSET BSR BTST} & \multirow[t]{7}{*}{Branch Conditionally Bit Test and Change Bit Test and Clear Branch Always Bit Test and Set Branch to Subroutine Bit Test} & & & & \\
\hline & & \multirow[t]{5}{*}{\begin{tabular}{l}
LEA \\
LINK \\
LSL \\
LSR
\end{tabular}} & \multirow[t]{5}{*}{\begin{tabular}{l}
Load Effective Address \\
Link Stack Logical Shift Left Logical Shift Right
\end{tabular}} & & \\
\hline & & & & & \\
\hline & & & & & \\
\hline & & & & & \\
\hline & & & & \multirow[t]{5}{*}{\begin{tabular}{l}
SBCD \\
SCC \\
STOP \\
SUB \\
SWAP
\end{tabular}} & \multirow[t]{4}{*}{\begin{tabular}{l}
Subtract Decimal with Extend Set Conditional \\
Stop \\
Subtract \\
Swap Data Register Halves
\end{tabular}} \\
\hline & & \multirow[t]{3}{*}{\begin{tabular}{l}
MOVE \\
MULS \\
MULU
\end{tabular}} & \multirow[t]{3}{*}{Move Signed Multiply Unsigned Multiply} & & \\
\hline CHK & \multirow[t]{4}{*}{Check Register Against Bounds Clear Operand Compare} & & & & \\
\hline & & & & & \\
\hline CLR & & \multirow[t]{4}{*}{\begin{tabular}{l}
NBCD \\
NEG \\
NOP \\
NOT
\end{tabular}} & \multirow[t]{4}{*}{Negate Decimal with Extend Negate No Operation One's Complement} & & \\
\hline CMP & & & & TAS & Test and Set Operand \\
\hline & \multirow[b]{4}{*}{Test Condition, Decrement and Branch Signed Divide Unsigned Divide} & & & TRAP & Trap \\
\hline \(\mathrm{DBCC}^{\text {c }}\) & & & & TRAPV TST & Trap on Overflow Test \\
\hline DIVS & & \multirow[t]{2}{*}{OR} & \multirow[t]{2}{*}{Logical Or} & & \\
\hline DIVU & & & & UNLK & Unlink \\
\hline
\end{tabular}

Table 11. Variations of Instruction Types
\begin{tabular}{|c|c|c|c|c|c|}
\hline Instruction Type & Variation & Description & Instruction Type & Variation & Description \\
\hline ADD & \begin{tabular}{l}
ADD \\
ADDA \\
ADDQ \\
ADDI \\
ADDX
\end{tabular} & \begin{tabular}{l}
Add \\
Add Address \\
Add Quick \\
Add Immediate \\
Add with Extend
\end{tabular} & move & \begin{tabular}{l}
MOVE \\
MOVEA \\
MOVEM \\
MOVEP \\
MOVEQ \\
MOVE from SR
\end{tabular} & \begin{tabular}{l}
Move \\
Move Address \\
Move Multiple Registers \\
Move Peripheral Data \\
Move Quick \\
Move from Status Register
\end{tabular} \\
\hline \multirow[t]{2}{*}{AND} & \begin{tabular}{l}
AND \\
ANDI \\
ANDI to CCR
\end{tabular} & \multirow[t]{2}{*}{Logical And And Immediate And Immediate to Condition Codes And Immediate to Status Register} & & MOVE to SR MOVE to CCR MOVE USP & Move to Status Register Move to Condition Codes Move User Stack Pointer \\
\hline & ANDI to SR & & NEG & NEG NEGX & \begin{tabular}{l}
Negate \\
Negate with Extend
\end{tabular} \\
\hline CMP & \begin{tabular}{l}
CMP \\
CMPA \\
CMPM \\
CMPI
\end{tabular} & \begin{tabular}{l}
Compare \\
Compare Address \\
Compare Memory Compare Immediate
\end{tabular} & OR & \begin{tabular}{l}
OR \\
ORI \\
ORI to CCR \\
ORI to SR
\end{tabular} & \begin{tabular}{l}
Logical Or \\
Or Immediate \\
Or Immediate to Condition Codes \\
Or Immediate to \\
Status Register
\end{tabular} \\
\hline EOR & \begin{tabular}{l}
EOR \\
EORI \\
EORI to CCR \\
EORI to SR
\end{tabular} & \begin{tabular}{l}
Exclusive Or \\
Exclusive Or Immediate \\
Exclusive Or Immediate to Condition Codes \\
Exclusive Or Immediate to Status Register
\end{tabular} & SUB & SUB SUBA SUBI SUBQ SUBX & \begin{tabular}{l}
Subtract \\
Subtract Address \\
Subtract Immediate \\
Subtract Quick \\
Subtract with Extend
\end{tabular} \\
\hline
\end{tabular}

The following paragraphs contain an overview of the form and structure of the R68000 instruction set. The instructions form a set of tools that include all the machine functions to perform the following operations:

\author{
Data Movement \\ Integer Arithmetic \\ Logical \\ Shift and Rotate \\ Bit Manipulation \\ Binary Coded Decimal \\ Program Control \\ System Control
}

The complete range of instruction capabilities combined with the flexible addressing modes described previously provide a very flexible base for program development.

\section*{ADDRESSING}

Instructions for the R68000 contain two kinds of information: the type of function to be performed, and the location of the operand(s) on which to perform that function. The methods used to locate (address) the operand(s) are explained in the following paragraphs.

Instructions specify an operand location in one of three ways:
Register Specification - the number of the register is given in the register field of the instruction.
Effective Address - use of the different effective address modes.
Implicit Reference
- the definition of certain instructions implies the use of specific registers.

\section*{DATA MOVEMENT OPERATIONS}

The move (MOVE) instruction provides a means for data acquisition (transfer and storage). The move instruction and the effective addressing modes allow both address and data manipulation. Data move instructions allow byte, word, and long word operands to be transferred from memory to memory, memory to register, register to memory, and register to register. Address move instructions allow word and long word operand transfers and ensure that only legal address manipulations are executed. In addition to the general move instruction there are several special data movement instructions: move multiple registers (MOVEM), move peripheral data (MOVEP), exchange registers (EXG), load effective address (LEA), push effective address (PEA), link stack (LINK), unlink stack (UNLK), and move quick (MOVEQ). Table 12 summarizes the data movement operations.

\section*{INTEGER ARITHMETIC OPERATIONS}

The arithmetic operators include the four basic operations of add (ADD), subtract (SUB), multiply (MUL), and divide (DIV) as well as arithmetic compare (CMP), clear (CLR), and negate (NEG). The add and subtract instructions are available for both address and data operations, and with data operations accepting all

Table 12. Data Movement Operations
\begin{tabular}{|c|c|c|}
\hline Instruction & Operand Size & Operation \\
\hline EXG & 32 & \(R x \rightarrow R y\) \\
\hline LEA & 32 & \(\mathrm{EA} \sim \mathrm{An}\) \\
\hline LINK & - & \[
\begin{aligned}
& \mathrm{An} \rightarrow-(\mathrm{SP}) \\
& \mathrm{SP} \rightarrow \mathrm{An} \\
& \mathrm{SP}+\text { displacement } \rightarrow \mathrm{SP}
\end{aligned}
\] \\
\hline MOVE & 8, 16, 32 & \(s \rightarrow d\) \\
\hline MOVEM & 16, 32 & \((E A) \rightarrow A n, D n\) \(A n, D n \rightarrow E A\) \\
\hline MOVEP & 16, 32 & \[
\begin{aligned}
& (E A) \rightarrow D n \\
& D n \rightarrow(E A)
\end{aligned}
\] \\
\hline MOVEQ & 8 & \(\# x x x \rightarrow\) Dn \\
\hline PEA & 32 & \(E A \rightarrow-(S P)\) \\
\hline SWAP & 32 & \(\mathrm{Dn}[31: 16] \rightarrow \mathrm{Dn}[15: 0]\) \\
\hline UNLK & - & \[
\begin{aligned}
& A n \rightarrow S p \\
& (S P)+\rightarrow A n
\end{aligned}
\] \\
\hline \multicolumn{3}{|l|}{NOTES:} \\
\hline
\end{tabular}
operand sizes. Address operations are limited to legal address size operands (16 or 32 bits). Data, address, and memory compare operations are also available. The clear and negate instructions may be used on all sizes of data operands.

The multiply and divide operations are available for signed and unsigned operands using word multiply to produce a long word product, and a long word dividend with word divisor to produce a word quotient with a word remainder.

Multiprecision and mixed size arithmetic can be accomplished using a set of extended instructions. These instructions are: add extended (ADDX), subtract extended (SUBX), sign extend (EXT), and negate binary with extend (NEGX).

A text operand (TST) instruction that sets the condition codes as a result of a compare of the operand with zero is available. Test and set (TAS) is a synchronization instruction useful in multiprocessor systems. Table 13 summrizes the integer arithmetic operations.

\section*{INSTRUCTION FORMAT}

Instructions, as shown in Figure 39, vary from one to five words in length. The first word of the instruction, called the operation word, specifies the length of the instruction and the operation to be performed. The remaining words further specify the operands. These words are either immediate operands or extensions to the effective address mode specified in the operation word.

Table 13. Integer Arithmetic Operations
\begin{tabular}{|c|c|c|}
\hline Instruction & Operand Size & Operation \\
\hline ADD & \[
8,16,32
\]
\[
16,32
\] & \[
\begin{aligned}
& D n+(E A) \rightarrow D n \\
& (E A)+D n \rightarrow(E A) \\
& (E A)+\# x x x \rightarrow(E A) \\
& A n+(E A) \rightarrow A n
\end{aligned}
\] \\
\hline ADDX & \[
\begin{aligned}
& 8,16,32 \\
& 16,32
\end{aligned}
\] & \[
\begin{aligned}
& D x+D y+X \rightarrow D x \\
& -(A x)+-(A y)+X \rightarrow(A x)
\end{aligned}
\] \\
\hline CLR & 8, 16, 32 & \(0 \rightarrow E A\) \\
\hline CMP & \[
\begin{aligned}
& 8,16,32 \\
& 16,32
\end{aligned}
\] & \[
\begin{aligned}
& D n-(E A) \\
& (E A)-\# x x x \\
& (A x)+-(A y)- \\
& A n-(E A)
\end{aligned}
\] \\
\hline DIVS & \(32 \div 16\) & \(\mathrm{Dn} \div(\mathrm{EA}) \rightarrow \mathrm{Dn}\) \\
\hline DIVU & \(32 \div 16\) & \(\mathrm{Dn} \div(\mathrm{EA}) \rightarrow \mathrm{Dn}\) \\
\hline EXT & \[
\begin{aligned}
& 8 \rightarrow 16 \\
& 16 \rightarrow 32
\end{aligned}
\] & \[
\begin{aligned}
& (D n)_{8} \rightarrow D n_{16} \\
& (D n)_{16}-D n_{32}
\end{aligned}
\] \\
\hline MULS & \(16 \times 16 \rightarrow 32\) & \(\mathrm{Dn} \times(\mathrm{EA}) \rightarrow \mathrm{Dn}\) \\
\hline MULU & \(16 \times 16 \rightarrow 32\) & Dn \(\times(E A) \rightarrow\) Dn \\
\hline NEG & 8, 16, 32 & \(0-(E A) \rightarrow(E A)\) \\
\hline NEGX & 8, 16, 32 & \(0-(E A)-X \rightarrow(E A)\) \\
\hline SUB & \[
\begin{aligned}
& 8,16,32 \\
& 16,32
\end{aligned}
\] & \[
\begin{aligned}
& D n-(E A) \rightarrow D n \\
& (E A)-D n \rightarrow(E A) \\
& (E A)-\# x x x \rightarrow(E A) \\
& A n-(E A) \rightarrow A n
\end{aligned}
\] \\
\hline SUBX & 8, 16, 32 & \[
\begin{aligned}
& D x-D y-X \rightarrow D x \\
& -(A x)--(A y)-X \rightarrow(A x)
\end{aligned}
\] \\
\hline TAS & 8 & \([E A]-0,1 \rightarrow E A[7]\) \\
\hline TST & 8, 16, 32 & (EA) -0 \\
\hline \multicolumn{3}{|l|}{```
NOTES:
    ] = bit number
-( ) = indirect with predecrement
( )+ = indirect with postdecrement
    # = immediate data
```} \\
\hline
\end{tabular}

\section*{PROGRAM/DATA REFERENCES}

The R68000 separates memory references into two classes: program references, and data references. Program references reference that section of memory that contains the program being executed. Data references refer to that section of memory that contains data. Operand reads are from the data space, except in the case of the program counter relative addressing mode. All operand writes are to the data space.

\section*{REGISTER SPECIFICATION}

The register field within an instruction specifies the register to be used. Other fields within the instruction specify whether the register selected is an address or data register and how the register is to be used.

\section*{EFFECTIVE ADDRESS}

Most instructions specify the location of an operand by using the effective address field in the operation word. For example, Figure 40 shows the general format of the single effective address instruction operation word. The effective address is composed of two 3-bit fields: the mode field, and the register field. The value in the mode field selects the different address modes. The register field contains the number of a register.

The effective address field may require additional information to fully specify the operand. This additional information, called the effective address extension, is contained in the following word or words and is considered part of the instruction, as shown in Figure 39. The effective address modes are grouped into three categories: register direct, memory addressing, and special.

REGISTER DIRECT MODES. These effective addressing modes specify that the operand is in one of the 16 multifunction registers.

Data Register Direct. The operand is in the data register specified by the effective address register field.

Address Register Direct. The operand is in the address register specified by the effective address register field.

MEMORY ADDRESS MODES. These effective addressing modes specify that the operand is in memory and provide the specific address of that operand.


Figure 39. Instruction Format
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline 15 & 14 & 13 & 12 & 11 & 10 & 9 & 8 & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline X & X & X & X & X & X & X & X & X & X & & & & & & \\
\hline
\end{tabular}

Figure 40. Single-Effective-Address Instruction Operation Word General Format

Address Register Indirect. The address of the operand is in the address register specified by the register field. The reference is classified as a data reference with the exception of the jump and jump to subroutine instructions.

Address Register Indirect With Postincrement. The address of the operand is in the address register specified by the register field. After the operand address is used, it is incremented by one, two or four depending upon whether the size of the operand is byte, word, or long word. If the address register is the stack pointer and the operand size is byte, the address is incremented by two rather than one to keep the stack pointer on a word boundary. The reference classifies as a data reference.

Address Register Indirect With Predecrement. The address of the operand is in the address register specified by the register field. Before the operand address is used, it is decremented by one, two, or four depending upon whether the operand size is byte, word, or long word. If the address register is the stack pointer and the operand size is byte, the address is decremented by two rather than one to keep the stack pointer on a word boundary. The reference is classified as a data reference.

Address Register Indirect with Displacement. This address mode requires one word of extension. The address of the operand is the sum of the address in the address register and the sign-extended 16 -bit displacement integer in the extension word. The reference classifies as a data reference with the exception of the jump to subroutine instructions.

Address Register Indirect With Index. This address mode requires one word of extension. The address of the operand sums the addresses in the address register, the sign-extended displacement integer in the low order eight bits of the extension word, and the contents of the index register. The reference is classified as a data reference with the exception of the jump and jump to subroutine instructions.

SPECIAL ADDRESS MODE. The special address modes use the effective address register field to specify the special addressing mode instead of a register number.

Absolute Short Address. This address mode requires one word of extension. The address of the operand is the extension word. The 16 -bit address is sign extended before it is used. The reference classifies as a data reference with the exception of the jump and jump to subroutine instructions.

Absolute Long Address. This address mode requires two words of extension. The address of the operand is developed by the concatenation of the extension words. The high-order part of the address is the first extension word; the low-order part of the
address is the second extension word. The reference classifies as a data reference with the exception of the jump and jump to subroutine instructions.

Program Counter With Displacement. This address mode requires one word of extension. The address of the operand sums the addresses in the program counter and the signextended 16 -bit displacement integer in the extension word. The value in the program counter is the address of the extension word. The reference classifies as a program reference.

Program Counter With Index. This address mode requires one word of extension. This address sums the addresses in the program counter, the sign-extended displacement integer in the lower eight bits of the extension word, and the contents of the index register. The value in the program counter is the address of the extension word. This reference classifies as a program reference.

Immediate Data. This address mode requires either one or two words of extension depending on the size of the operation.
\(\left.\begin{array}{ll}\text { Byte Operation } & \text { - operand is low order byte of exten- } \\
\text { sion word }\end{array}\right]\)\begin{tabular}{ll} 
Word Operation & operand is extension word \\
Long Word Operation - operand is in the two extension \\
& words, high-order 16 bits are in the \\
first extension word, low-order 16 \\
& bits are in the second extension \\
word.
\end{tabular}

\section*{IMPLICIT REFERENCE}

Some instructions make implicit reference to the program counter (PC), the system stack pointer (SP), the supervisor stack pointer (SSP), the user stack pointer (USP), or the status register (SR).

A selected set of instructions may reference the status register by means of the effective address field. These are:

ANDI to CCR
ANDI to SR
EORI to CCR
EORI to SR
MOVE to CCR
MOVE to SR
MOVE from SR
ORI to CCR
ORI to SR

\section*{EFFECTIVE ADDRESS ENCODING SUMMARY}

Table 14 summarizes the effective addressing modes discussed in the previous paragraphs.

Table 14. Effective Address Encoding Summary
\begin{tabular}{|c|c|c|}
\hline Addressing Mode & Mode & \multicolumn{1}{|c|}{ Register } \\
\hline Data Register Direct & 000 & register number \\
\hline Address Register Direct & 001 & register number \\
\hline Address Register Indirect & 010 & register number \\
\hline \begin{tabular}{c} 
Address Register Indirect with \\
Postincrement
\end{tabular} & 011 & register number \\
\hline \begin{tabular}{c} 
Address Register Indirect with \\
Predecrement
\end{tabular} & 100 & register number \\
\hline \begin{tabular}{c} 
Address Register Indirect with \\
Displacement
\end{tabular} & 101 & register number \\
\hline \begin{tabular}{c} 
Address Register Indirect with \\
Index
\end{tabular} & 110 & register number \\
\hline Absolute Short & 111 & 000 \\
\hline Absolute Long & 111 & 001 \\
\hline Program Counter with & 111 & 010 \\
\hline Displacement & 111 & 011 \\
\hline Program Counter with Index & 111 & 100 \\
\hline Immediate & \\
\hline
\end{tabular}

SYSTEM STACK. The system stack is used implicitly by many instructions; user stacks and queues may be created and maintained through the addressing modes. Address register seven (A7) is the system stack pointer (SP). The system stack pointer is either the supervisor stack pointer (SSP) or the user stack pointer (USP), depending on the state of the S-bit in the status register. If the S-bit indicates supervisor state (High), SSP is the active system stack pointer, and the USP cannot be referenced as an address register. If the S -bit indicates user state (Low), the USP is the active system stack pointer, and the SSP cannot be referenced. Each system stack fills from high memory to low memory.

\section*{LOGICAL OPERATIONS}

Logical operation instructions AND, OR, EOR, and NOT are available for all sizes of integer data operands. A similar set of immediate instructions (ANDI, ORI, and EORI) provide these logical operations with all sizes of immediate data. Table 15 summarizes the logical operations.

\section*{SHIFT AND ROTATE OPERATIONS}

Shift operations in both directions are provided by arithmetic instructions ASR and ASL and logical shift instructions LSR and LSL. The rotate instructions (with and without extend) available are ROXR, ROXL, ROR, and ROL. All shift and rotate operations can be performed in either registers or memory. Register shifts and rotates support all operand sizes and allow a shift count specified in a data register.

Table 15. Logical Operations
\begin{tabular}{|c|c|c|}
\hline Instruction & Operand Size & Operation \\
\hline AND & 8, 16, 32 & \[
\begin{aligned}
& D n \Lambda(E A) \rightarrow D n \\
& (E A) \Lambda D n \rightarrow(E A) \\
& (E A) \Lambda \# x x x \rightarrow(E A)
\end{aligned}
\] \\
\hline OR & 8, 16, 32 & \[
\begin{aligned}
& \mathrm{Dn} \nu(\mathrm{EA}) \rightarrow \mathrm{Dn} \\
& (\mathrm{EA}) \nu \mathrm{Dn} \rightarrow(\mathrm{EA}) \\
& (\mathrm{EA}) \nu \# \mathrm{xxx} \rightarrow(\mathrm{EA})
\end{aligned}
\] \\
\hline EOR & 8, 16, 32 & \[
\begin{aligned}
& (E A) \oplus D y \rightarrow(E A) \\
& (E A) \oplus \# x x x \rightarrow(E A)
\end{aligned}
\] \\
\hline NOT & 8, 16, 32 & \(\sim(E A) \rightarrow(E A)\) \\
\hline \multicolumn{3}{|l|}{NOTES:
\[
\begin{array}{rlrl}
\sim & =\text { invert } & \nu=\text { logical OR } \\
\# & =\text { immediate data } & \oplus & =\text { logical exclusive OR } \\
\Lambda & =\text { logical AND } & &
\end{array}
\]} \\
\hline
\end{tabular}

Memory shifts and rotates are for word operands only and allow only sing!e-bit shifts or rotates.

Table 16 summarizes the shift and rotate operations.

\section*{BIT MANIPULATION OPERATIONS}

The following instructions provide bit manipulation operations: bit test (BTST), bit test and set (BSET), bit test and clear (BCLR), and bit test and change (BCHG). Table 17 is a summary of the bit manipulation operations. (Bit 2 of the status register is Z .)

Table 16. Shift and Rotate Operations
\begin{tabular}{|c|c|c|}
\hline Instruction & Operand Size & Operation \\
\hline ASL & 8, 16, 32 & \(X / C)-\) \\
\hline ASR & 8, 16, 32 & \[
\rightarrow \longrightarrow x / C
\] \\
\hline LSL & 8, 16, 32 & \(x / C-4\) \\
\hline LSR & 8, 16, 32 & \[
0 \rightarrow \longrightarrow x / C
\] \\
\hline ROL & 8, 16, 32 & \[
\mathrm{C}, 4
\] \\
\hline ROR & 8, 16, 32 & \[
\rightarrow \longrightarrow \mathrm{C}
\] \\
\hline ROXL & 8, 16, 32 & \[
\mathrm{C},
\] \\
\hline ROXR & 8, 16, 32 &  \\
\hline
\end{tabular}

Table 17. Bit Manipulation Operations
\(\left.\left.\left.\begin{array}{|c|c|c|}\hline \text { Instruction } & \text { Operand Size } & \text { Operation } \\ \hline \text { BTST } & 8,32 & \sim \text { bit of }(E A) \rightarrow Z\end{array} \right\rvert\, \begin{array}{l}\sim \text { bit of }(E A) \rightarrow Z \\ 1 \rightarrow \text { bit of EA }\end{array}\right] \begin{array}{l}\sim \text { bit of (EA) } \rightarrow Z \\ 0 \rightarrow \text { bit of EA }\end{array}\right]\)

\section*{BINARY CODED DECIMAL OPERATIONS}

The following instructions accomplish multiprecision arithmetic operations on binary coded decimal numbers: add decimal with extend (ABCD), subtract decimal with extend (SBCD), and negate decimal with extend (NBCD). Table 18 summarizes the binary coded decimal operations.

\section*{PROGRAM CONTROL OPERATIONS}

Program control operations implementation requires a series of conditional and unconditional branch instructions and return instructions. These instructions are summarized in Table 19.

The conditional instructions provide setting and branching for the following conditions:
CC - carry clear
CS - carry set
EQ - equal
F - never true
GE - greater or equal
GT - greater than
HI - high
LE - less or equal
LS - low or same
LT - less than
MI - minus
NE - not equal
PL — plus
T - always true
VC - no overflow
VS - overflow

Table 18. Binary Coded Decimal Operations
\begin{tabular}{|c|c|c|}
\hline Instruction & Operand Size & \multicolumn{1}{|c|}{ Operation } \\
\hline ABCD & 8 & \begin{tabular}{l}
\(D x_{10}+D y_{10}+X \rightarrow D x\) \\
\(-(A x)_{10}+-(A y)_{10}+x \rightarrow(A x)\)
\end{tabular} \\
\hline SBCD & 8 & \begin{tabular}{l}
\(D x_{10}-D y_{10}-X \rightarrow D x\) \\
\(-(A x)_{10}--(A y)_{10}-X \rightarrow(A x)\)
\end{tabular} \\
\hline NBCD & 8 & \(0-(E A)_{10}-X \rightarrow(E A)\) \\
\hline NOTE: \(-(\quad)=\) indirect with predecrement \\
\hline
\end{tabular}

Table 19. Program Control Operations
\begin{tabular}{|c|c|}
\hline Instruction & Operation \\
\hline \begin{tabular}{l}
Conditional \(B_{C C}\) \\
\(\mathrm{DB}_{\mathrm{CC}}\) \\
\(\mathrm{S}_{\mathrm{CC}}\)
\end{tabular} & \begin{tabular}{l}
Branch conditionally (14 conditions) \\
8 - and 16 -bit displacement \\
Test condition, decrement, branch 16-bit displacement \\
Set byte conditionally (16 conditions)
\end{tabular} \\
\hline \begin{tabular}{l}
Unconditional BRA \\
BSR \\
JMP \\
JSR
\end{tabular} & \begin{tabular}{l}
Branch always \\
8 - and 16 -bit displacement \\
Branch to subroutine \\
8 - and 16 -bit displacement \\
Jump \\
Jump to subroutine
\end{tabular} \\
\hline Returns RTR RTS & Return and restore condition codes Return from subroutine \\
\hline
\end{tabular}

\section*{SYSTEM CONTROL OPERATIONS}

System control operations are accomplished by using privileged instructions, trap generating instructions, and instructions that use or modify the status register. These instructions are summarized in Table 20.

\section*{INSTRUCTION SET}

The following paragraphs provide information about the addressing categories and instruction set of the R68000.

\section*{ADDRESSING CATEGORIES}

Effective address modes may be categorized by the ways in which they may be used. The following classifications will be used in the instructions definitions.
Data If an effective address mode may be used to refer to data operands, it is considered a data addressing effective address mode.
Memory If an effective address mode may be used to refer to memory operands, it is considered a memory addressing effective address mode.
Alterable If an effective address mode may be used to refer to alterable (writeable) operands, it is considered an alterable addressing effective address mode.
Control If an effective address mode may be used to refer to memory operands without an associated size, it is considered control addressing effective address mode.

Table 21 shows the various categories to which each of the effective address modes belong. Table 22 is the instruction set summary.

Table 20. System Control Operations
\begin{tabular}{|l|l|}
\hline \multicolumn{1}{|c|}{ Instruction } & \multicolumn{1}{|c|}{ Operation } \\
\hline Privileged & \\
ANDI to SR & Logical AND to Status Register \\
EORI to SR & Logical EOR to Status Register \\
MOVE EA to SR & Load New Status Register \\
MOVE USP & Move User Stack Pointer \\
ORI to SR & Logical OR to Status Register \\
RESET & Reset External Devices \\
RTE & Return from Exception \\
STOP & Stop Program Execution \\
\hline Trap Generating & \\
CHK & Check Data Register Against Upper Bounds \\
TRAP & Trap \\
TRAPV & Trap on Overflow \\
\hline Status Register & \\
ANDI to CCR & Logical AND to Condition Codes \\
EORI to CCR & Logical EOR to Condition Codes \\
MOVE EA to CCR & Load New Condition Codes \\
MOVE SR to EA & Store Status Register \\
ORI to CCR & Logical OR to Condition Codes \\
\hline
\end{tabular}

The status register addressing mode is not permitted unless it is explicitly mentioned as a legal addressing mode.

These categories may be combined, so that additional, more restrictive, classifications may be defined. For example, the instruction descriptions use such classifications as alterable memory or data alterable. The former refers to those addressing modes which are both alterable and memory addresses, and the latter refers to addressing modes which are both data and alterable.

\section*{INSTRUCTION PREFETCH}

The R68000 uses a two-word tightly-coupled instruction prefetch mechanism to enhance performance. This mechanism is described in terms of the microcode operations involved. If the execution of an instruction is defined to begin when the microroutine for that instruction is entered, some features of the prefetch mechanism can be described.
1) When execution of an instruction begins, the operation word and the word following have already been fetched. The operation word is in the instruction decoder.
2) In the case of multi-word instructions, as each additional word of the instruction is used internally, a fetch is made to the instruction stream to replace it.
3) The last fetch from the instruction stream is made when the operation word is discarded and decoding is started on the next instruction.
4) If the instruction is a single-word instruction causing a branch, the second word is not used. But because this word is fetched by the preceding instruction, it is impossible to avoid this superfluous fetch.
5) In the case of an interrupt or trace exception, both words are not used.
6) The program counter usually points to the last word fetched from the instruction stream.

\section*{INSTRUCTION EXECUTION TIMES}

The following paragraphs contain listings of the instruction execution times in terms of external clock (CLK) periods. In this timing data, it is assumed that both memory read and write cycle times are four clock periods. Any wait states caused by a longer memory cycle must be added to the total instruction time. The number of bus read and write cycles for each instruction is enclosed in parenthesis following the execution periods and is shown as ( \(r / w\) ) where \(r\) is the number of read cycles and \(w\) is the number of write cycles.

Table 21. Effective Addressing Mode Categories
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{Effective Address Modes} & \multirow[b]{2}{*}{Mode} & \multirow[b]{2}{*}{Register} & \multicolumn{4}{|c|}{Addressing Categories} \\
\hline & & & Data & Memory & Control & Alterable \\
\hline Dn An (An) & \[
\begin{aligned}
& 000 \\
& 001 \\
& 010 \\
& \hline
\end{aligned}
\] & Register Number Register Number Register Number & \[
\frac{x}{x}
\] & \[
\overline{\bar{x}}
\] & \[
\overline{\bar{x}}
\] & \[
\begin{aligned}
& x \\
& x \\
& x
\end{aligned}
\] \\
\hline (An) + \(-(A n)\) \(\mathrm{d}(\mathrm{An})\) & \[
\begin{aligned}
& 011 \\
& 100 \\
& 101
\end{aligned}
\] & Register Number Register Number Register Number & \[
\begin{aligned}
& x \\
& X \\
& X
\end{aligned}
\] & \[
\begin{aligned}
& x \\
& x \\
& x
\end{aligned}
\] & \[
\overline{\bar{x}}
\] & \[
\begin{aligned}
& x \\
& x \\
& x
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& d(A n, i x) \\
& x x x . W \\
& x x x . L
\end{aligned}
\] & \[
\begin{aligned}
& 110 \\
& 111 \\
& 111
\end{aligned}
\] & \begin{tabular}{l}
Register Number 000 \\
001
\end{tabular} & \[
\begin{aligned}
& X \\
& X \\
& X
\end{aligned}
\] & \[
\begin{aligned}
& X \\
& X \\
& X
\end{aligned}
\] & \[
\begin{aligned}
& X \\
& X \\
& X
\end{aligned}
\] & \[
\begin{aligned}
& x \\
& x \\
& x
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& d(P C) \\
& d(P C, i x) \\
& \# x x x
\end{aligned}
\] & \[
\begin{aligned}
& 111 \\
& 111 \\
& 111
\end{aligned}
\] & \[
\begin{aligned}
& 010 \\
& 011 \\
& X
\end{aligned}
\] & \[
\begin{aligned}
& x \\
& x \\
& x
\end{aligned}
\] & X
X
X & \begin{tabular}{l}
X \\
X \\
\hline
\end{tabular} & - \\
\hline
\end{tabular}

Table 22. Instruction Set
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Mnemonic} & \multirow[b]{2}{*}{Description} & \multirow[b]{2}{*}{Operation} & \multicolumn{5}{|l|}{Condition Codes} \\
\hline & & & X & N & Z & V & C \\
\hline ABCD & Add Decimal with Extend & \((\text { Destination })_{10}+(\text { Source })_{10}+\mathrm{X} \rightarrow\) Destination & * & U & * & U & * \\
\hline ADD & Add Binary & (Destination) + (Source) \(\rightarrow\) Destination & * & * & * & * & * \\
\hline ADDA & Add Address & (Destination) + (Source) \(\rightarrow\) Destination & - & - & - & - & - \\
\hline ADDI & Add Immediate & (Destination) + Immediate Data \(\rightarrow\) Destination & * & * & * & * & * \\
\hline ADDQ & Add Quick & (Destination) + Immediate Data \(\rightarrow\) Destination & * & * & * & * & * \\
\hline ADDX & Add Extended & (Destination) + (Source) \(+\mathrm{X} \rightarrow\) Destination & * & * & * & * & * \\
\hline AND & AND Logical & (Destination) \(\Lambda\) (Source) \(\rightarrow\) Destination & - & * & * & 0 & 0 \\
\hline ANDI & AND Immediate & (Destination) \(\Lambda\) Immediate Data \(\rightarrow\) Destination & - & * & * & 0 & 0 \\
\hline ANDI to CCR & AND Immediate to Condition Codes & (Source) \(\Lambda\) CCR \(\rightarrow\) CCR & * & * & * & * & * \\
\hline ANDI to SR & AND Immediate to Status Register & (Source) \(\Lambda\) SR \(\rightarrow\) SR & * & * & * & * & * \\
\hline ASL, ASR & Arithmetic Shift & (Destination) Shifted by <count> \(\rightarrow\) Destination & * & * & * & * & * \\
\hline \({ }^{\text {BCC }}\) & Branch Conditionally & If CC then \(\mathrm{PC}+\mathrm{d} \rightarrow \mathrm{PC}\) & - & - & - & - & - \\
\hline BCHG & Test a Bit and Change & \begin{tabular}{l}
\(\sim(<\) bit number >) OF Destination \(\rightarrow Z\) \\
\(\sim\) (<bit number \(>\) ) OF Destination \(\rightarrow\) \\
<bit number> OF Destination
\end{tabular} & - & - & * & - & - \\
\hline BCLR & Test a Bit and Clear & \[
\begin{aligned}
& \sim(<\text { bit number }>) \text { OF Destination } \rightarrow Z \\
& 0 \rightarrow \text { bit number }>\rightarrow \text { OF Destination }
\end{aligned}
\] & - & - & * & - & - \\
\hline BRA & Branch Always & \(P C+d \rightarrow P C\) & - & - & - & - & - \\
\hline BSET & Test a Bit and Set & \begin{tabular}{l}
\(\sim\) (<bit number \(>\) ) OF Destination \(\rightarrow\) Z \\
\(1 \rightarrow\) <bit number \(>\) OF Destination
\end{tabular} & - & - & * & - & - \\
\hline BSR & Branch to Subroutine & \(\mathrm{PC} \rightarrow(\mathrm{SP}) ; \mathrm{PC}+\mathrm{d} \rightarrow \mathrm{PC}\) & - & - & - & - & - \\
\hline BTST & Test a Bit & \(\sim\) (< bit number \(>\) ) OF Destination \(\rightarrow Z\) & - & - & * & - & - \\
\hline CHK & Check Register Against Bounds & If Dn <0 or \(\mathrm{Dn}>(<\mathrm{ea}>)\) then TRAP & - & * & U & U & U \\
\hline CLR & Clear and Operand & \(0 \rightarrow\) Destination & - & 0 & 1 & 0 & 0 \\
\hline CMP & Compare & (Destination) - (Source) & - & * & * & * & * \\
\hline CMPA & Compare Address & (Destination) - (Source) & - & * & * & * & * \\
\hline CMPI & Compare Immediate & (Destination) - Immediate Data & - & * & * & * & * \\
\hline CMPM & Compare Memory & (Destination) - (Source) & - & * & * & * & * \\
\hline \({ }^{\text {DBCC }}\) & Test Condition, Decrement and Branch & If \(\sim \mathrm{CC}\) then \(\mathrm{Dn}-1 \rightarrow \mathrm{Dn}\); if \(\mathrm{Dn} \neq-1\) then \(\mathrm{PC}+\mathrm{d} \rightarrow \mathrm{PC}\) & - & - & - & - & - \\
\hline DIVS & Signed Divide & \((\) Destination)/(Source) \(\rightarrow\) Destination & - & * & * & * & 0 \\
\hline DIVU & Unsigned Divide & (Destination)/(Source) \(\rightarrow\) Destination & - & * & * & * & 0 \\
\hline EOR & Exclusive OR Logical & (Destination) \(\oplus\) (Source) \(\rightarrow\) Destination & - & * & * & 0 & 0 \\
\hline EORI & Exclusive OR Immediate & (Destination) \(\oplus\) Immediate Data \(\rightarrow\) Destination & - & * & * & 0 & 0 \\
\hline EORI to CCR & Exclusive OR Immediate to Condition Codes & (Source) \(\oplus \mathrm{CCR} \rightarrow \mathrm{CCR}\) & * & * & * & * & * \\
\hline \multicolumn{8}{|l|}{NOTES:} \\
\hline
\end{tabular}

Table 22. Instruction Set (Continued)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Mnemonic} & \multirow[b]{2}{*}{Description} & \multirow[b]{2}{*}{Operation} & \multicolumn{5}{|l|}{Condition Codes} \\
\hline & & & X & N & Z & V & C \\
\hline EORI to SR & Exclusive OR Immediate to Status Register & (Source) \(\oplus\) SR \(\rightarrow\) SR & * & * & * & * & * \\
\hline EXG & Exchange Register & \(R x \rightarrow R y\) & - & - & - & - & - \\
\hline EXT & Sign Extend & (Destination) Sign-Extended \(\rightarrow\) Destination & - & * & * & 0 & 0 \\
\hline JMP & Jump & Destination \(\rightarrow\) PC & - & - & - & - & - \\
\hline JSR & Jump to Subroutine & \(\mathrm{PC} \rightarrow-(\mathrm{SP})\); Destination \(\rightarrow \mathrm{PC}\) & - & - & - & - & - \\
\hline LEA & Load Effective Address & <ea> \(\rightarrow\) An & - & - & - & - & - \\
\hline LINK & Link and Allocate & \(\mathrm{An} \rightarrow\) (SP); SP \(\rightarrow \mathrm{An} ; \mathrm{SP}+\) Displacement \(\rightarrow\) SP & - & - & - & - & - \\
\hline LSL, LSR & Logical Shift & (Destination) Shifted by <count> \(\rightarrow\) Destination & * & * & * & 0 & * \\
\hline MOVE & Move Data from Source to Destination & (Source) \(\rightarrow\) Destination & - & * & * & 0 & 0 \\
\hline MOVE to CCR & Move to Condition Code & (Source) \(\rightarrow\) CCR & * & * & * & * & * \\
\hline MOVE to SR & Move to the Status Register & (Source) \(\rightarrow\) SR & * & * & * & * & * \\
\hline MOVE from SR & Move from the Status Register & \(S R \rightarrow\) Destination & - & - & - & - & - \\
\hline MOVE USP & Move User Stack Pointer & USP \(\rightarrow\) An; An \(\rightarrow\) USP & - & - & - & - & - \\
\hline MOVEA & Move Address & (Source) \(\rightarrow\) Destination & - & - & - & - & - \\
\hline MOVEM & Move Multiple Registers & Register \(\rightarrow\) Destination (Source) \(\rightarrow\) Registers & - & - & - & - & - \\
\hline MOVEP & Move Peripheral Data & (Source) \(\rightarrow\) Destination & - & - & - & - & - \\
\hline MOVEQ & Move Quick & Immediate Data \(\rightarrow\) Destination & - & * & * & 0 & 0 \\
\hline MULS & Signed Multiply & \((\) Destination \() \times(\) Source \() \rightarrow\) Destination & - & * & * & 0 & 0 \\
\hline MULU & Unsigned Multiply & \((\) Destination \() \times(\) Source \() \rightarrow\) Destination & - & * & * & 0 & 0 \\
\hline NBCD & Negate Decimal with Extend & \(0-\) (Destination) \(10-X \rightarrow\) Destination & * & U & * & U & * \\
\hline NEG & Negate & \(0-\) (Destination) \(\rightarrow\) Destination & * & * & * & * & * \\
\hline NEGX & Negate with Extend & \(0-\) (Destination) - \(\mathrm{X} \rightarrow\) Destination & * & * & * & * & * \\
\hline NOP & No Operation & - & - & - & - & - & - \\
\hline NOT & Logical Complement & \(\sim\) (Destination) \(\rightarrow\) Destination & - & * & * & 0 & 0 \\
\hline OR & Inclusive OR Logical & \((\) Destination) \(\nu\) (Source) \(\rightarrow\) Destination & - & * & * & 0 & 0 \\
\hline ORI & Inclusive OR Immediate & (Destination) \(\nu\) Immediate Data \(\rightarrow\) Destination & - & * & * & 0 & 0 \\
\hline ORI to CCR & Inclusive OR Immediate to Condition Codes & (Source) \(\nu\) CCR \(\rightarrow\) CCR & * & * & * & * & * \\
\hline ORI to SR & Inclusive OR Immediate to Status Register & (Source) \(\nu \mathrm{SR} \rightarrow\) SR & * & * & * & * & * \\
\hline PEA & Push Effective Address & \(<\) ea> \(\rightarrow\) - (SP) & - & - & - & - & - \\
\hline RESET & Reset External Device & \[
1-
\] & - & - & - & - & - \\
\hline ROL, ROR & Rotate (Without Extend) & (Destination) Rotated by \(<\) count \(>\rightarrow\) Destination & - & * & * & 0 & * \\
\hline \multicolumn{8}{|l|}{NOTES:} \\
\hline
\end{tabular}

Table 22. Instruction Set (Continued)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Mnemonic} & \multirow[b]{2}{*}{Description} & \multirow[b]{2}{*}{Operation} & \multicolumn{5}{|l|}{Condition Codes} \\
\hline & & & x & N & z & \(v\) & c \\
\hline ROXL, ROXR & Rotate with Extend & (Destination) Rotated by <count > \(\rightarrow\) Destination & * & * & * & 0 & * \\
\hline RTE & Return from Exception & \((\mathrm{SP})+\rightarrow \mathrm{SR}\); \((\mathrm{SP})+\rightarrow \mathrm{PC}\) & * & * & * & * & * \\
\hline RTR & Return and Restore Condition Codes & \((\mathrm{SP})+\rightarrow \mathrm{CC} ;(\mathrm{SP})+\rightarrow \mathrm{PC}\) & * & * & * & * & * \\
\hline RTS & Return from Subroutine & \((\mathrm{SP})+\rightarrow \mathrm{PC}\) & - & - & - & - & - \\
\hline SBCD & Subtract Decimal with Extend & (Destination) \(1_{10}\) - (Source) \(10-\mathrm{X} \rightarrow\) Destination & * & U & * & \(\cup\) & * \\
\hline SCC & Set According to Condition & If CC then 1 's \(\rightarrow\) Destination else 0 's \(\rightarrow\) Destination & - & - & - & - & - \\
\hline STOP & Load Status Register and Stop & Immediate Data \(\rightarrow\) SR; STOP & * & * & * & * & * \\
\hline SUB & Subtract Binary & (Destination) - (Source) \(\rightarrow\) Destination & * & * & * & * & * \\
\hline SUBA & Subtract Address & (Destination) - (Source) \(\rightarrow\) Destination & - & - & - & - & - \\
\hline SUBI & Subtract Immediate & (Destination) - Immediate Data \(\rightarrow\) Destination & * & * & * & * & * \\
\hline SUBQ & Subtract Quick & (Destination) - Immediate Data \(\rightarrow\) Destination & * & * & * & * & * \\
\hline SUBX & Subtract with Extend & (Destination) - (Source) - \(\mathrm{X} \rightarrow\) Destination & * & * & * & * & * \\
\hline SWAP & Swap Register Halves & Register [31:16] \(\rightarrow\) Register [15:0] & - & * & * & 0 & 0 \\
\hline TAS & Test and Set an Operand & (Destination) Tested \(\rightarrow\) CC; \(1 \rightarrow\) [7] OF Destination & - & * & * & 0 & 0 \\
\hline TRAP & Trap & \(\mathrm{PC} \rightarrow\) ( SSP ); SR \(\rightarrow\) - (SSP); (Vector) \(\rightarrow\) PC & - & - & - & - & - \\
\hline TRAPV & Trap on Overflow & If \(\nu\) then TRAP & - & - & - & - & - \\
\hline TST & Test and Operand & (Destination) Tested \(\rightarrow\) CC & - & * & * & 0 & 0 \\
\hline UNLK & Unlink & \(\mathrm{An} \rightarrow \mathrm{SP} ;(\mathrm{SP})+\rightarrow \mathrm{An}\) & - & - & - & - & - \\
\hline
\end{tabular}

\section*{NOTES:}
\begin{tabular}{ll}
{\(\left[\begin{array}{ll}{[ } & =\text { bit number } \\
\Lambda & =\text { logical AND }\end{array}\right.\)} & \(*=\) affected \\
\(\nu=\) logical OR & \\
\(\nu=\) unaffected \\
\(\oplus\) & \(=\) logical exclusive OR \\
\(\sim\) & \(=\) logical complement
\end{tabular}

\section*{Note}

The number of periods includes instruction fetch and all applicable operand fetches and stores.

\section*{EFFECTIVE ADDRESS OPERAND CALCULATION TIMING}

Table 23 lists the number of clock periods required to compute an instruction's effective address. It includes fetching of any extension words, the address computation, and fetching of the memory operand. The number of bus read and write cycles is shown in parenthesis as (r/w). Note there are no write cycles involved in processing the effective address.

\section*{MOVE INSTRUCTION CLOCK PERIODS}

Tables 24 and 25 indicate the number of clock periods for the move instruction. This data includes instruction fetch, operand reads, and operand writes. The number of bus read and write cycles is shown in parenthesis as (r/w).

\section*{STANDARD INSTRUCTION CLOCK PERIODS}

The number of clock periods shown in Table 26 delineate the time required to perform the operations, store the results, and read the next instruction. The number of bus read and write cycles is shown in parenthesis as (r/w). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

In Table 26, the headings have the following meanings: \(\mathrm{An}=\) address register operand, \(\mathrm{Dn}=\) data register operand, \(\mathrm{ea}=\mathrm{an}\) operand specified by an effective address, and \(M=\) memory effective address operand.

\section*{IMMEDIATE INSTRUCTION CLOCK PERIODS}

The number of clock periods shown in Table 27 includes the time to fetch immediate operands, perform the operations, store the results, and read the next operation. The number of bus read and write cycles is shown in parenthesis as (r/w). The number

Table 23. Effective Address Calculation Timing
\begin{tabular}{|c|c|c|c|}
\hline & Addressing Mode & Byte, Word & Long \\
\hline \[
\begin{aligned}
& \text { Dn } \\
& \text { An }
\end{aligned}
\] & \begin{tabular}{l}
Register \\
Data Register Direct \\
Address Register Direct
\end{tabular} & \[
\begin{aligned}
& 0(0 / 0) \\
& 0(0 / 0)
\end{aligned}
\] & \[
\begin{aligned}
& 0(0 / 0) \\
& 0(0 / 0)
\end{aligned}
\] \\
\hline (An)
\[
(A n)+
\] & \begin{tabular}{l}
Memory \\
Address Register Indirect \\
Address Register Indirect with Postincrement
\end{tabular} & \[
\begin{aligned}
& 4(1 / 0) \\
& 4(1 / 0)
\end{aligned}
\] & \[
\begin{aligned}
& 8(2 / 0) \\
& 8(2 / 0)
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& -(A n) \\
& d(A n)
\end{aligned}
\] & Address Register Indirect with Predecrement Address Register Indirect with Displacement & \[
\begin{aligned}
& 6(1 / 0) \\
& 8(2 / 0)
\end{aligned}
\] & \[
\begin{aligned}
& 10(2 / 0) \\
& 12(3 / 0)
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& \mathrm{d}(\mathrm{An}, \mathrm{ix})^{\star} \\
& \mathrm{xxx} \cdot \mathrm{~W}
\end{aligned}
\] & Address Register Indirect with Index Absolute Short & \[
\begin{array}{r}
10(2 / 0) \\
8(2 / 0)
\end{array}
\] & \[
\begin{aligned}
& 14(3 / 0) \\
& 12(3 / 0)
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& x x x . L \\
& d(P C)
\end{aligned}
\] & \begin{tabular}{l}
Absolute Long \\
Program Counter with Displacement
\end{tabular} & \[
\begin{array}{r}
12(3 / 0) \\
8(2 / 0)
\end{array}
\] & \[
\begin{aligned}
& 16(4 / 0) \\
& 12(3 / 0)
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& \mathrm{d}(\mathrm{PC}, \mathrm{ix})^{*} \\
& \# \mathrm{xxx}
\end{aligned}
\] & Program Counter with Index Immediate & \[
\begin{array}{r}
10(2 / 0) \\
4(1 / 0)
\end{array}
\] & \[
\begin{array}{r}
14(3 / 0) \\
8(2 / 0)
\end{array}
\] \\
\hline \multicolumn{4}{|l|}{*The size of the index register (ix) does not affect execution time.} \\
\hline
\end{tabular}

Table 24. Move Byte and Word Instruction Clock Periods
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Source} & \multicolumn{9}{|c|}{Destination} \\
\hline & Dn & An & (An) & (An) + & -(An) & \(\mathrm{d}(\mathrm{An})\) & d(An, ix)* & xxx.W & xxx.L \\
\hline Dn & 4(1/0) & 4(1/0) & 8(1/1) & 8(1/1) & 8(1/1) & 12(2/1) & 14(2/1) & 12(2/1) & 16(3/1) \\
\hline An & 4(1/0) & 4(1/0) & 8(1/1) & 8(1/1) & 8(1/1) & 12(2/1) & 14(2/1) & 12(2/1) & 16(3/1) \\
\hline (An) & 8(2/0) & 8(2/0) & 12(2/1) & 12(2/1) & 12(2/1) & 16(3/1) & 18(3/1) & 16(3/1) & 20(4/1) \\
\hline (An) + & 8(2/0) & 8(2/0) & 12(2/1) & 12(2/1) & 12(2/1) & 16(3/1) & 18(3/1) & 16(3/1) & 20(4/1) \\
\hline - (An) & 10(2/0) & 10(2/0) & 14(2/1) & 14(2/1) & 14(2/1) & 18(3/1) & 20(3/1) & 18(3/1) & 22(4/1) \\
\hline \(\mathrm{d}(\mathrm{An})\) & 12(3/0) & 12(3/0) & 16(3/1) & 16(3/1) & 16(3/1) & 20(4/1) & 22(4/1) & 20(4/1) & 24(5/1) \\
\hline \(\mathrm{d}(\mathrm{An}, \mathrm{ix})^{*}\) & 14(3/0) & 14(3/0) & 18(3/1) & 18(3/1) & 18(3/1) & 22(4/1) & 24(4/1) & 22(4/1) & 26(5/1) \\
\hline xxx.W & 12(3/0) & 12(3/0) & 16(3/1) & 16(3/1) & 16(3/1) & 20(4/1) & 22(4/1) & 20(4/1) & 24(5/1) \\
\hline xxx.L & 16(4/0) & 16(4/0) & 20(4/1) & 20(4/1) & 20(4/1) & 24(5/1) & 26(5/1) & 24(5/1) & 28(6/1) \\
\hline d(PC) & 12(3/0) & 12(3/0) & 16(3/1) & 16(3/1) & 16(3/1) & 20(4/1) & 22(4/1) & 20(4/1) & 24(5/1) \\
\hline \(\mathrm{d}(\mathrm{PC}, \mathrm{ix})^{*}\) & 14(3/0) & 14(3/0) & 18(3/1) & 18(3/1) & 18(3/1) & 22(4/1) & 24(4/1) & 22(4/1) & 26(5/1) \\
\hline \#xxx & 8(2/0) & 8(2/0) & 12(2/1) & 12(2/1) & 12(2/1) & 16(3/1) & 18(3/1) & 16(3/1) & 20(4/1) \\
\hline
\end{tabular}
*The size of the index register (ix) does not affect execution time.
of clock periods and the number of read and write cycles must be added respectively to those of the effective adress calculation where indicated.

In Table 27, the headings have the following meanings: \# = immediate operand, \(\mathrm{Dn}=\) data register operand, \(A n=\) address register operand, \(M=\) memory operand, and \(S R=\) status register.

\section*{SINGLE OPERAND INSTRUCTION CLOCK PERIODS}

Table 28 indicates the number of clock periods for the single operand instructions. The number of bus read and write cycles is shown in parenthesis as (r/w). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

Table 25. Move Long Instruction Clock Periods


Table 26. Standard Instruction Clock Periods
\begin{tabular}{|c|c|c|c|c|}
\hline Instruction & Size & op<ea>, An \(\dagger\) & op<ea>, Dn & op Dn, <M> \\
\hline \multirow[b]{2}{*}{ADD} & Byte, Word & \(8(1 / 0)+\) & 4(1/0) + & \(8(1 / 1)+\) \\
\hline & Long & \(6(1 / 0)+\) ** & \(6(1 / 0)+^{* *}\) & 12(1/2) + \\
\hline \multirow[b]{2}{*}{AND} & Byte, Word & - & \(4(1 / 0)+\) & \(8(1 / 1)+\) \\
\hline & Long & - & \(6(1 / 0)+\) ** & 12(1/2) + \\
\hline \multirow[b]{2}{*}{CMP} & Byte, Word & \(6(1 / 0)+\) & \(4(1 / 0)+\) & - \\
\hline & Long & \(6(1 / 0)+\) & \(6(1 / 0)+\) & - \\
\hline DIVS & - & - & 158(1/0) + * & - \\
\hline DIVU & - & - & 140(1/0) + * & - \\
\hline \multirow[t]{2}{*}{EOR} & Byte, Word & - & 4(1/0)*** & \(8(1 / 1)+\) \\
\hline & Long & - & 8(1/0)*** & 12(1/2) + \\
\hline MULS & - & - & 70(1/0) + * & - \\
\hline MULU & - & - & 70(1/0) + * & - \\
\hline \multirow[t]{2}{*}{OR} & Byte, Word & - & \(4(1 / 0)+\) & \(8(1 / 1)+\) \\
\hline & Long & - & \(6(1 / 0)+\) ** & 12(1/2) + \\
\hline \multirow[t]{2}{*}{SUB} & Byte, Word & \(8(1 / 0)+\) & \(4(1 / 0)+\) & \(8(1 / 1)+\) \\
\hline & Long & \(6(1 / 0)+* *\) & \(6(1 / 0)+\) * & 12(1/2) + \\
\hline
\end{tabular}

\section*{NOTES:}
+ add effective address calculation time
\(\dagger\) word or long only
* indicates maximum value
** The base time of six clock periods is increased to eight if the effective address mode is register direct or immediate (effective address time should also be added).
*** Only available effective address mode is data register direct
DIVS, DIVU The divide algorithm used by the R68000 provides less than \(10 \%\) difference between the best and worst case timings.
MULS, MULU The multiply algorithm requires \(38+2 n\) clocks where \(n\) is defined as:
MULU: \(\mathrm{n}=\) the number of ones in each <ea>
MULU: \(n=\) concatanate the <ea> with a zero as the LSB; \(n\) is the resultant number of 10 or 01 patterns in the 17-bit source; i.e., worst case happens when the source is \(\$ 5555\).

Table 27. Immediate Instruction Clock Periods


Table 28. Single Operand Instruction Clock Periods
\begin{tabular}{|c|c|c|c|}
\hline Instruction & Size & Register & Memory \\
\hline \multirow[b]{2}{*}{CLR} & Byte, Word & 4(1/0) & 8(1/1) + \\
\hline & Long & 6(1/0) & 12(1/2) + \\
\hline NBCD & Byte & 6(1/0) & \(8(1 / 1)+\) \\
\hline \multirow[b]{2}{*}{NEG} & Byte, Word & 4(1/0) & \(8(1 / 1)+\) \\
\hline & Long & 6(1/0) & 12(1/2) + \\
\hline \multirow[b]{2}{*}{NEGX} & Byte, Word & 4(1/0) & 8(1/1) + \\
\hline & Long & 6(1/0) & 12(1/2) + \\
\hline \multirow[b]{2}{*}{NOT} & Byte, Word & 4(1/0) & \(8(1 / 1)+\) \\
\hline & Long & 6(1/0) & 12(1/2) + \\
\hline \multirow[b]{2}{*}{\(S_{\text {CC }}\)} & Byte, False & 4(1/0) & \(8(1 / 1)+\) \\
\hline & Byte, True & 6(1/0) & \(8(1 / 1)+\) \\
\hline TAS & Byte & 4(1/0) & 10(1/1) + \\
\hline \multirow[b]{2}{*}{TST} & Byte, Word & 4(1/0) & \(4(1 / 0)+\) \\
\hline & Long & 4(1/0) & 4(1/0) + \\
\hline \multicolumn{4}{|l|}{+ add effective address calculation time} \\
\hline
\end{tabular}

\section*{SHIFT/ROTATE INSTRUCTION CLOCK PERIODS}

Table 29 delineates the number of clock periods for the shift and rotate instructions. The number of bus read and write cycles is shown in parenthesis as: (r/w). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

\section*{BIT MANIPULATION INSTRUCTION CLOCK PERIODS}

Table 30 indicates the number of clock periods required for the bit manipulation instructions. The number of bus read and write cycles is shown in parenthesis as: (r/w). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

\section*{CONDITIONAL INSTRUCTION CLOCK PERIODS}

Table 31 delineates the number of clock periods required for the conditional instructions. The number of bus read and write cycles is indicated in parenthesis as: (r/w). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

\section*{JMP, JSR, LEA, PWA, MOVEM INSTRUCTION CLOCK PERIODS}

Table 32 indicates the number of clock periods required for the jump, jump to subroutine, load effective address, push effective address, and move multiple registers instructions. The number of bus read and write cycles is shown in parenthesis as: \((r / w)\).

Table 29. Shift/Rotate Instruction Clock Periods
\begin{tabular}{|c|c|c|c|}
\hline Instruction & Size & Register & Memory \\
\hline \multirow[b]{2}{*}{ASR, ASL} & Byte, Word & \(6+2 n(1 / 0)\) & \(8(1 / 1)+\) \\
\hline & Long & \(8+2 \mathrm{n}(1 / 0)\) & - \\
\hline \multirow[b]{2}{*}{LSR, LSL} & Byte, Word & \(6+2 n(1 / 0)\) & 8(1/1) + \\
\hline & Long & \(8+2 n(1 / 0)\) & - \\
\hline \multirow[b]{2}{*}{ROR, ROL} & Byte, Word & \(6+2 n(1 / 0)\) & \(8(1 / 1)+\) \\
\hline & Long & \(8+2 \mathrm{n}(1 / 0)\) & - \\
\hline \multirow[b]{2}{*}{ROXR, ROXL} & Byte, Word & \(6+2 n(1 / 0)\) & 8(1/1) + \\
\hline & Long & \(8+2 n(1 / 0)\) & - \\
\hline \multicolumn{4}{|l|}{+ add effective address calculation time n is shift or rotate count} \\
\hline
\end{tabular}

Table 30. Bit Manipulation Instruction Clock Periods
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Instruction} & \multirow[b]{2}{*}{Size} & \multicolumn{2}{|c|}{Dynamic} & \multicolumn{2}{|c|}{Static} \\
\hline & & Register & Memory & Register & Memory \\
\hline \multirow[b]{2}{*}{BCHG} & Byte & - & \(8(1 / 1)+\) & - & 12(2/1) + \\
\hline & Long & 8(1/0)* & - & 12(2/0)* & - \\
\hline \multirow[b]{2}{*}{BCLR} & Byte & - & 8(1/1) + & - & 12(2/1) + \\
\hline & Long & 10(1/0)* & - & 14(2/0)* & - \\
\hline \multirow[b]{2}{*}{BSET} & Byte & - & \(8(1 / 1)+\) & - & 12(2/1) + \\
\hline & Long & 8(1/0)* & - & 12(2/0)* & - \\
\hline \multirow[t]{2}{*}{BTST} & Byte & - & 4(1/0) + & - & \(8(2 / 0)+\) \\
\hline & Long & 6(1/0) & - & 10(2/0) & - \\
\hline \multicolumn{6}{|l|}{\begin{tabular}{l}
+ add effective address calculation time \\
* indicates maximum value
\end{tabular}} \\
\hline
\end{tabular}

Table 31. Conditional Instruction Clock Periods
\begin{tabular}{|c|c|c|c|}
\hline Instruction & Displacement & Branch Taken & Branch Not Taken \\
\hline \multirow{2}{*}{ BCC } & Byte & \(10(2 / 0)\) & \(8(1 / 0)\) \\
\cline { 2 - 4 } & Word & \(10(2 / 0)\) & \(12(2 / 0)\) \\
\hline \multirow{2}{*}{ BRA } & Byte & \(10(2 / 0)\) & - \\
\hline \multirow{2}{*}{ BSR } & Word & \(10(2 / 0)\) & - \\
\hline \multirow{2}{*}{ DBCC } & Byte & \(18(2 / 2)\) & - \\
\hline & Word & \(18(2 / 2)\) & - \\
\hline
\end{tabular}

Table 32. JMP, JSR, LEA, PEA, MOVEM INSTRUCTION CLOCK PERIODS
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline Instr & Size & (An) & (An) + & -(An) & \(d(A n)\) & d(An, ix)* + & xxx.W & xxx.L & \(\mathrm{d}(\mathrm{PC})\) & d(PC, ix)* \\
\hline JMP & - & 8(2/0) & - & - & 10(2/0) & 14(3/0) & 10(2/0) & 12(3/0) & 10(2/0) & 14(3/0) \\
\hline JSR & - & 16(2/2) & - & - & 18(2/2) & 22(2/2) & 18(2/2) & 20(3/2) & 18(2/2) & 22(2/2) \\
\hline LEA & - & 4(1/0) & - & - & 8(2/0) & 12(2/0) & 8(2/0) & 12(3/0) & 8(2/0) & 12(2/0) \\
\hline PEA & - & 12(1/2) & - & - & 16(2/2) & 20(2/2) & 16(2/2) & 20(3/2) & 16(2/2) & 20(2/2) \\
\hline \multirow{2}{*}{MOVEM
\[
M \rightarrow R
\]} & Word & \[
\begin{aligned}
& 12+4 n \\
& (3+n / 0)
\end{aligned}
\] & \[
\begin{aligned}
& 12+4 n \\
& (3+n / 0)
\end{aligned}
\] & - & \[
\begin{aligned}
& 16+4 n \\
& (4+n / 0)
\end{aligned}
\] & \[
\begin{aligned}
& 18+4 n \\
& (4+n / 0)
\end{aligned}
\] & \[
\begin{aligned}
& 16+4 n \\
& (4+n / 0)
\end{aligned}
\] & \[
\begin{aligned}
& 20+4 n \\
& (5+n / 0)
\end{aligned}
\] & \[
\begin{aligned}
& 16+4 n \\
& (4+n / 0)
\end{aligned}
\] & \[
\begin{aligned}
& 18+4 n \\
& (4+n / 0)
\end{aligned}
\] \\
\hline & Long & \[
\begin{aligned}
& 12+8 n \\
& (3+2 n / 0)
\end{aligned}
\] & \[
\begin{aligned}
& 12+8 n \\
& (3+2 n / 0)
\end{aligned}
\] & - & \[
\begin{aligned}
& 16+8 n \\
& (4+2 n / 0)
\end{aligned}
\] & \[
\begin{aligned}
& 18+8 n \\
& (4+2 n / 0)
\end{aligned}
\] & \[
\begin{aligned}
& 16+8 n \\
& (4+2 n / 0)
\end{aligned}
\] & \[
\begin{aligned}
& 20+8 \mathbf{n} \\
& (5+2 n / 0)
\end{aligned}
\] & \[
\begin{aligned}
& 16+8 n \\
& (4+2 n / 0)
\end{aligned}
\] & \[
\begin{aligned}
& 18+8 n \\
& (4+2 n / 0)
\end{aligned}
\] \\
\hline \multirow{2}{*}{\[
\begin{aligned}
& \text { MOVEM } \\
& R \rightarrow M
\end{aligned}
\]} & Word & \[
\begin{aligned}
& 8+4 n \\
& (2 / n)
\end{aligned}
\] & - & \[
\begin{aligned}
& 8+4 n \\
& (2 / n)
\end{aligned}
\] & \[
\begin{aligned}
& 12+4 n \\
& (3 / n)
\end{aligned}
\] & \[
\begin{aligned}
& 14+4 n \\
& (3 / n)
\end{aligned}
\] & \[
\begin{aligned}
& 12+4 n \\
& (3 / n)
\end{aligned}
\] & \[
\begin{aligned}
& 16+4 n \\
& (4 / n)
\end{aligned}
\] & - & - \\
\hline & Long & \[
\begin{aligned}
& 8+8 n \\
& (2 / 2 n)
\end{aligned}
\] & - & \[
\begin{aligned}
& 8+8 n \\
& (2 / 2 n)
\end{aligned}
\] & \[
\begin{aligned}
& 12+8 n \\
& (3 / 2 n)
\end{aligned}
\] & \[
\begin{aligned}
& 14+8 n \\
& (3 / 2 n)
\end{aligned}
\] & \[
\begin{aligned}
& 12+8 n \\
& (3 / 2 n)
\end{aligned}
\] & \[
\begin{aligned}
& 16+8 n \\
& (4 / 2 n)
\end{aligned}
\] & - & - \\
\hline \multicolumn{11}{|l|}{\begin{tabular}{l}
n is the number of registers to move \\
* The size of the index register (ix) does not affect the instruction's execution time
\end{tabular}} \\
\hline
\end{tabular}

\section*{MULTI-PRECISION INSTRUCTION CLOCK PERIODS}

Table 33 delineates the number of clock periods for the multiprecision instructions. The number of clock periods includes the time to fetch both operands, perform the operations, store the results, and read the next instructions. The number of read and write cycles is shown in parenthesis as: (r/w).

In Table 33, the headings have the following meanings: \(\mathrm{Dn}=\) data register operand and \(\mathrm{M}=\) memory operand.

Table 33. Multi-Precision Instruction Clock Periods
\begin{tabular}{|c|l|c|c|}
\hline \multirow{2}{*}{ Instruction } & Size & op Dn, Dn & op M, M \\
\hline \multirow{2}{*}{ ADDX } & Byte, Word & \(4(1 / 0)\) & \(\mathbf{1 8 ( 3 / 1 )}\) \\
\cline { 2 - 4 } & Long & \(8(1 / 0)\) & \(30(5 / 2)\) \\
\hline \multirow{2}{*}{ CMPM } & Byte, Word & - & \(12(3 / 0)\) \\
\cline { 2 - 4 } & Long & - & \(20(5 / 0)\) \\
\hline \multirow{2}{*}{ SUBX } & Byte, Word & \(4(1 / 0)\) & \(18(3 / 1)\) \\
\cline { 2 - 4 } & Long & \(8(1 / 0)\) & \(30(5 / 2)\) \\
\hline ABCD & Byte & \(6(1 / 0)\) & \(18(3 / 1)\) \\
\hline SBCD & Byte & \(6(1 / 0)\) & \(18(3 / 1)\) \\
\hline
\end{tabular}

\section*{miscellaneous instruction clock periods}

Table 34 and 35 indicate the number of clock periods for the following miscellaneous instructions. The number of bus read and write cycles is shown in parenthesis as: \((r / w)\). The number of clock periods plus the number of read and write cycles must be added to those of the effective address calculation where indicated.

\section*{EXCEPTION PROCESSING CLOCK PERIODS}

Table 36 delineates the number of clock periods for exception processing. The number of clock periods includes the time for all stacking, the vector fetch, and the fetch of the first instruction of the handler routine. The number of bus read and write cycles is shown in parenthesis as (r/w).

Table 34. Miscellaneous Instruction Clock Periods


Table 35. Move Peripheral Instruction Execution Times
\begin{tabular}{|c|c|c|c|}
\hline Instruction & Size & Register \(\rightarrow\) Memory & Memory \(\rightarrow\) Register \\
\hline \multirow{2}{*}{ MOVEP } & Word & \(16(2 / 2)\) & \(16(4 / 0)\) \\
\cline { 2 - 4 } & Long & \(24(2 / 4)\) & \(24(6 / 0)\) \\
\hline
\end{tabular}

Table 36. Exception Processing Clock Periods
\begin{tabular}{|c|c|}
\hline Exception & Periods \\
\hline Address Error & 50(4/7) \\
\hline Bus Error & 50(4/7) \\
\hline CHK Instruction & 44(5/4) + \\
\hline Divide by Zero & 42(5/4) \\
\hline Illegal Instruction & 34(4/3) \\
\hline Interrupt & 44(5/3)* \\
\hline Privilege Violation & 34(4/3) \\
\hline RESET** & 40(6/0) \\
\hline Trace & 34(4/3) \\
\hline TRAP Instruction & 38(4/4) \\
\hline TRAPV Instruction & 34(4/3) \\
\hline \multicolumn{2}{|l|}{\begin{tabular}{l}
+ add effective address calculation time \\
* The interrupt acknowledge cycle is assumed to take four clock periods. \\
Indicates the time from when \(\overline{\text { RESET }}\) and \(\overline{\text { HALT }}\) are first sampled as negated to when instruction execution starts.
\end{tabular}} \\
\hline
\end{tabular}

\section*{MAXIMUM RATINGS}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Rating } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.3 to +7.0 & V \\
Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to +7.0 & V \\
Operating Temperature Range & \(\mathrm{T}_{\mathrm{A}}\) & \(\mathrm{T}_{\mathrm{L}}\) to \(\mathrm{T}_{\mathrm{H}}{ }^{*}\) & \({ }^{\circ} \mathrm{C}\) \\
Storage Temperature & \(\mathrm{T}_{\mathrm{STG}}\) & -65 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline \multicolumn{3}{|c|}{ *See ordering information } \\
\hline
\end{tabular}

\section*{THERMAL CHARACTERISTICS}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Characteristic } & Symbol & Value & Unit \\
\hline Thermal Resistance & \(\theta_{\text {JA }}\) & & \\
64-Pin Ceramic & & 30 & \({ }^{\circ} \mathrm{C} / \mathrm{W}\) \\
64-Pin Plastic Dip & & \(55 \pm 5\) & \({ }^{\circ} \mathrm{C} / \mathrm{W}\) \\
\hline
\end{tabular}

This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields; however, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum-rated voltages to this high-impedance circuit. Reliability of operation is enhanced if unused inputs are tied to an appropriate logic voltage level (e.g., either \(\mathrm{V}_{\mathrm{SS}}\) or \(\mathrm{V}_{\mathrm{C}}\).

\section*{POWER CONSIDERATIONS}

The average chip-junction temperature, \(\mathrm{T}_{\mathrm{J}}\), in \({ }^{\circ} \mathrm{C}\) can be obtained from:
\[
\begin{equation*}
T_{J}=T_{A}+\left(P_{D} \cdot \theta_{J} A\right) \tag{1}
\end{equation*}
\]

Where:
\[
\begin{aligned}
\mathrm{T}_{\mathrm{A}} \equiv & \equiv \text { Ambient Temperature, }{ }^{\circ} \mathrm{C} \\
\theta \mathrm{JA} \equiv & \equiv \text { Package Thermal Resistance, Junction-to- } \\
& \text { Ambient, }{ }^{\circ} \mathrm{C} / \mathrm{W} \\
\mathrm{PDD} \equiv & \equiv \mathrm{P}_{I N T}+\mathrm{P}_{\mathrm{I} / \mathrm{O}} \\
\mathrm{P}_{\mathrm{INT}} \equiv & \mathrm{ICC} \cdot \mathrm{~V}_{\mathrm{C}} \mathrm{C}, \text { Watts-Chip Internal Power } \\
\mathrm{P}_{\mathrm{I} / \mathrm{O}} \equiv & \equiv \begin{array}{l}
\text { Power Dissipation on Input and Output Pins- } \\
\\
\text { User Determined }
\end{array}
\end{aligned}
\]

For most applications \(\mathrm{P}_{\mathrm{I} / \mathrm{O}} \ll \mathrm{PINT}\) and can be neglected.
An approximate relationship between \(P_{D}\) and \(T_{J}\) (if \(\mathrm{P}_{\mathrm{l} / \mathrm{O}}\) is neglected) is:
\[
\begin{equation*}
P_{D}=K \div\left(T_{J}+273^{\circ} \mathrm{C}\right) \tag{2}
\end{equation*}
\]

Solving equations 1 and 2 for \(K\) gives:
\[
\begin{equation*}
K=P_{D} \cdot\left(T_{A}+273^{\circ} \mathrm{C}\right)+\theta J A \cdot P_{D}{ }^{2} \tag{3}
\end{equation*}
\]

Where K is a constant pertaining to the particular part. K can be determined from equation 3 by measuring \(\mathrm{PD}_{\mathrm{D}}\) (at equilibrium) for a known \(T_{A}\). Using this value of \(K\) the values of \(P_{D}\) and \(T_{J}\) can be obtained by solving equations (1) and (2) iteratively for any value of \(T_{A}\).

DC ELECTRICAL CHARACTERISTICS
\(\left(V_{C C}=5.0 \mathrm{Vdc} \pm 5 \%, V_{S S}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}\right.\) to \(\mathrm{T}_{\mathrm{H}}{ }^{\circ} \mathrm{C}\). See Figures 41,42 , and 43.)
\begin{tabular}{|c|c|c|c|c|c|}
\hline Characteristic & Symbol & Min & Max & Unit & Test Conditions \\
\hline Input High Voltage & \(\mathrm{V}_{\mathrm{IH}}\) & 2.0 & \(\mathrm{V}_{\mathrm{CC}}\) & V & \\
\hline Input Low Voltage & \(\mathrm{V}_{\text {IL }}\) & VSS - 0.3 & 0.8 & V & \\
\hline Input Leakage Current \(\overline{\text { BERR, }} \overline{\mathrm{BGACK}}, \overline{\mathrm{BR}}, \overline{\mathrm{DTACK}}, \mathrm{CLK}, \overline{\mathrm{PLL}}-\overline{\mathrm{PPL}}, \overline{\mathrm{VPA}}\) HALT, \(\overline{\text { RESET }}\) & IN & - & \[
\begin{aligned}
& 2.5 \\
& 20
\end{aligned}
\] & \[
\begin{aligned}
& \mu \mathrm{A} \\
& \mu \mathrm{~A}
\end{aligned}
\] & \[
\begin{aligned}
& V_{\mathrm{IN}}=5.25 \\
& \mathrm{~V}_{\mathrm{CC}}=0 \mathrm{~V}
\end{aligned}
\] \\
\hline \begin{tabular}{l}
Three-State (Off State) Input Current \\
\(\overline{\mathrm{AS}}, \mathrm{A} 1-\mathrm{A} 23, \mathrm{D} 0-\mathrm{D} 15, \mathrm{FC} 0-\mathrm{FC} 2, \overline{\mathrm{LDS}}, \mathrm{R} / \overline{\mathrm{W}}, \overline{\mathrm{UDS}}, \overline{\mathrm{VMA}}\)
\end{tabular} & ITSI & - & 20 & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\
& \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}
\end{aligned}
\] \\
\hline \begin{tabular}{l}
Output High Voltage \\
E* \\
E, \(\overline{\mathrm{AS}}, \mathrm{A} 1-\mathrm{A} 23, \overline{\mathrm{BG}}, \mathrm{D} 0-\mathrm{D} 15, \mathrm{FC} 0-\mathrm{FC} 2, \overline{\mathrm{LDS}}, \mathrm{R} / \overline{\mathrm{W}}, \overline{\mathrm{UDS}}, \overline{\mathrm{VMA}}\)
\end{tabular} & \(\mathrm{V}_{\mathrm{OH}}\) & \[
\mathrm{V}_{\mathrm{CC}}-0.4
\] & & \[
\begin{aligned}
& \mathrm{v} \\
& \mathrm{v}
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{VCC}=4.75 \mathrm{~V} \\
& \mathrm{IOH}=-400 \mu \mathrm{~A} \\
& \hline
\end{aligned}
\] \\
\hline \begin{tabular}{l}
Output Low Voltage HALT \\
BG, FC0-FC2, A1-A23 \\
RESET \\
\(\overline{A S}, D 0-D 15, \overline{L D S}, R / \bar{W} \overline{U D S}, \overline{V M A}, E\)
\end{tabular} & \(\mathrm{V}_{\text {OL }}\) & \[
\begin{aligned}
& \text { Z } \\
& \text { - }
\end{aligned}
\] & \[
\begin{aligned}
& 0.5 \\
& 0.5 \\
& 0.5 \\
& 0.5 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& v \\
& v \\
& v \\
& v \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
\mathrm{VCC} & =4.75 \mathrm{~V} \\
(\mathrm{IOL} & =1.6 \mathrm{~mA}) \\
(\mathrm{IOL} & =3.2 \mathrm{~mA}) \\
(\mathrm{IOL} & =5.0 \mathrm{~mA}) \\
(1 \mathrm{OL} & =5.3 \mathrm{~mA})
\end{aligned}
\] \\
\hline Power Dissipation & PD*** & - & 1.5 & W & \\
\hline Input Capacitance & \(\mathrm{CIN}^{\text {N }}\) & - & 20.0 & pF & \[
\begin{aligned}
& V_{C C}=5.0 \mathrm{~V}, V_{I N}=O V \\
& f=1 \mathrm{MHz}, T_{A}=25^{\circ} \mathrm{C}
\end{aligned}
\] \\
\hline
\end{tabular}
*With external pullup resistor of \(1.1 \mathrm{k} \Omega\)
**Capacitance is periodically sampled rather than \(100 \%\) tested.
***During normal operation instantaneous \(V_{C C}\) current requirements may be as high as 1.5A.


Figure 41. \(\overline{\text { RESET }}\) Test Load


Figure 42. HALT Test Load


Figure 43. Test Loads

CLOCK TIMING (See Figure 44)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Characteristic} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|c|}{4 MHz} & \multicolumn{2}{|c|}{6 MHz} & \multicolumn{2}{|c|}{8 MHz} & \multicolumn{2}{|r|}{10 MHz} & \multicolumn{2}{|l|}{12.5 MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min & Max & Min & Max & Min & Max & Min & Max & Min & Max & \\
\hline Frequency of Operation & F & 2.0 & 4.0 & 2.0 & 6.0 & 2.0 & 8.0 & 2.0 & 10.0 & 4.0 & 12.5 & MHz \\
\hline Cycle Time & \(\mathrm{t}_{\text {cyc }}\) & 250 & 500 & 167 & 500 & 125 & 500 & 100 & 500 & 80 & 250 & ns \\
\hline Clock Pulse Width & \[
\begin{aligned}
& \mathrm{t}_{\mathrm{t} L} \\
& \mathrm{t} \mathrm{CH} \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& 115 \\
& 115 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& 250 \\
& 250 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& 75 \\
& 75 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& 250 \\
& 250 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& 55 \\
& 55 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& 250 \\
& 250 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& 45 \\
& 45 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& 250 \\
& 250 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& 35 \\
& 35 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& 125 \\
& 125 \\
& \hline
\end{aligned}
\] & ns \\
\hline Rise and Fall Times & \[
\begin{aligned}
& { }^{\mathrm{t}} \mathrm{Cr} \\
& { }^{\mathrm{t}} \mathrm{f}
\end{aligned}
\] & - & \[
\begin{aligned}
& 10 \\
& 10
\end{aligned}
\] & - & \[
\begin{aligned}
& 10 \\
& 10
\end{aligned}
\] & - & \[
\begin{aligned}
& 10 \\
& 10
\end{aligned}
\] & - & 10
10 & - & 5 & ns \\
\hline
\end{tabular}


Figure 44. Input Clock Waveform

AC ELECTRICAL SPECIFICATIONS - READ AND WRITE CYCLES
( \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc} ; \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}\) to \(\mathrm{T}_{\mathrm{H}}\), see Figures 45 and 46)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Num.} & \multirow[b]{2}{*}{Characteristic} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|l|}{4 MHz} & \multicolumn{2}{|l|}{6 MHz} & \multicolumn{2}{|c|}{8 MHz} & \multicolumn{2}{|l|}{10 MHz} & \multicolumn{2}{|l|}{12.5 MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & & Min & Max & Min & Max & Min & Max & Min & Max & Min & Max & \\
\hline 1 & Clock Period & \({ }^{\text {che }}\) & 250 & 500 & 167 & 500 & 125 & 500 & 100 & 500 & 80 & 250 & ns \\
\hline 2 & Clock Width Low & \({ }^{\text {t }}\) CL & 115 & 250 & 75 & 250 & 55 & 250 & 45 & 250 & 35 & 125 & ns \\
\hline 3 & Clock Width High & \({ }^{\text {t }} \mathrm{CH}\) & 115 & 250 & 75 & 250 & 55 & 250 & 45 & 250 & 35 & 125 & ns \\
\hline 4 & Clock Fall Time & \(\mathrm{t}_{\mathrm{Cf}}\) & - & 10 & - & 10 & - & 10 & - & 10 & - & 5 & ns \\
\hline 5 & Clock Rise Time & \({ }^{1} \mathrm{Cr}\) & - & 10 & - & 10 & - & 10 & - & 10 & - & 5 & ns \\
\hline 6 & Clock Low to Address & \({ }^{\text {t CLAV }}\) & - & 90 & - & 80 & - & 70 & - & 60 & - & 55 & ns \\
\hline 6A & Clock High to FC Valid & t CHFCV & - & 90 & - & 80 & - & 70 & - & 60 & - & 55 & ns \\
\hline 7 & Clock High to Address Data High Impedance (Maximum) & \({ }^{\text {t CHAZx }}\) & - & 120 & - & 100 & - & 80 & - & 70 & - & 60 & ns \\
\hline 8 & Clock High to Address/FC Invalid (Minimum) & \({ }^{\text {t }} \mathrm{CHAZn}\) & 0 & - & 0 & - & 0 & - & 0 & - & 0 & - & ns \\
\hline 91 & Clock High to \(\overline{A S}, \overline{D S}\) Low (Maximum) & tCHSLx & - & 80 & - & 70 & - & 60 & - & 55 & - & 55 & ns \\
\hline 10 & Clock High to \(\overline{A S}, \overline{D S}\) Low (Minimum) & \({ }^{\text {t }} \mathrm{CHSLn}\) & 0 & - & 0 & - & 0 & - & 0 & - & 0 & - & ns \\
\hline \(11^{2}\) & Address to \(\overline{\mathrm{AS}}, \overline{\mathrm{DS}}\) (Read) Low/AS Write & \({ }^{\text {taVSL }}\) & 55 & - & 35 & - & 30 & - & 20 & - & 0 & - & ns \\
\hline 11A \({ }^{2}\) & FC Valid to \(\overline{A S}, \overline{D S}\) (Read) Low/ \(\overline{\mathrm{AS}}\) Write & \({ }^{\text {t }}\) FCVSL & 80 & - & 70 & - & 60 & - & 50 & - & 40 & - & ns \\
\hline \(12^{1}\) & Clock Low to \(\overline{\mathrm{AS}}, \overline{\mathrm{DS}}\) High & \({ }^{\text {t CLSH}}\) & - & 90 & - & 80 & - & 70 & - & 55 & - & 50 & ns \\
\hline \(13^{2}\) & \(\overline{\mathrm{AS}}, \overline{\mathrm{DS}}\) High to Address/FC Invalid & tSHAZ & 60 & - & 40 & - & 30 & - & 20 & - & 10 & - & ns \\
\hline 142 & \(\overline{\mathrm{AS}}, \overline{\mathrm{DS}}\) Width Low (Read)/ \(\overline{\mathrm{AS}}\) Write & \({ }^{\text {t }}\) SL & 535 & - & 337 & - & 240 & - & 195 & - & 160 & - & ns \\
\hline \(14 \mathrm{~A}^{2}\) & \(\overline{\mathrm{DS}}\) Width Low (Write) & tDWPW & 285 & - & 170 & - & 115 & - & 95 & - & 80 & - & ns \\
\hline \(15^{2}\) & \(\overline{\text { AS }}\), \(\overline{\mathrm{DS}}\) Width High & \({ }^{\text {tSH}}\) & 285 & - & 180 & - & 150 & - & 105 & - & 65 & - & ns \\
\hline 16 & Clock High to \(\overline{\mathrm{AS}}, \overline{\mathrm{DS}}\) High & \({ }^{\text {t }} \mathrm{CHSZ}\) & - & 120 & - & 100 & - & 80 & - & 70 & - & 60 & ns \\
\hline \(17^{2}\) & \(\overline{\text { AS }}\), \(\overline{\mathrm{DS}}\) High to R//W High & tsHRH & 60 & - & 50 & - & 40 & - & 20 & - & 10 & - & ns \\
\hline 181 & Clock High to R/W High (Maximum) & \({ }^{\text {t }}\) CHRHx & - & 90 & - & 80 & - & 70 & - & 60 & - & 60 & ns \\
\hline 19 & Clock High to R/W High (Minimum) & \({ }^{\text {t }} \mathrm{CHRHn}\) & 0 & - & 0 & - & 0 & - & 0 & - & 0 & - & ns \\
\hline \(20^{1}\) & Clock High to R/产 Low & tCHRL & - & 90 & - & 80 & - & 70 & - & 60 & - & 60 & ns \\
\hline \(20{ }^{6}\) & \(\overline{\overline{A S}}\) Low to R/W Valid & tASRV & - & 20 & - & 20 & - & 20 & - & 20 & - & 20 & ns \\
\hline \(21^{2}\) & Address Valid to R/W Low & tavRL & 45 & - & 25 & - & 20 & - & 0 & - & 0 & - & ns \\
\hline \(21 \mathrm{~A}^{2}\) & FC Valid to R/W Low & \({ }^{\text {t }}\) FCVRL & 80 & - & 70 & - & 60 & - & 50 & - & 30 & - & ns \\
\hline \(22^{2}\) & R/W Low to \(\overline{\text { DS }}\) Low (Write) & trLSL & 200 & - & 140 & - & 80 & - & 50 & - & 30 & - & ns \\
\hline 23 & Clock Low to Data Out Valid & tCLDO & - & 90 & - & 80 & - & 70 & - & 55 & - & 55 & ns \\
\hline 24 & Clock High to R/W, \(\overline{\mathrm{VMA}}\) High Impedance & \({ }^{\text {t }} \mathrm{CHR} \mathrm{Z}\) & - & 120 & - & 100 & - & 80 & - & 70 & - & 60 & ns \\
\hline \(25^{2}\) & \(\overline{\mathrm{DS}}\) High to Data Out Invalid & tSHDO & 60 & - & 40 & - & 30 & - & 20 & - & 15 & - & ns \\
\hline \(26^{2}\) & Data Out Valid to \(\overline{\mathrm{DS}}\) Low (Write) & \({ }^{\text {t }}\) OOSL & 55 & - & 35 & - & 30 & - & 20 & - & 15 & - & ns \\
\hline 275 & Data In to Clock Low (Setup Time) & \({ }^{\text {t DICL }}\) & 30 & - & 25 & - & 15 & - & 10 & - & 10 & - & ns \\
\hline 27A & Late \(\overline{\text { BERR }}\) Low to Clock Low (Setup Time) & \(\mathrm{t}_{\mathrm{BELCL}}\) & 45 & - & 45 & - & 45 & - & 45 & - & 45 & - & ns \\
\hline \(28^{2}\) & \(\overline{\text { AS, }} \overline{\text { DS }}\) High to \(\overline{\text { DTACK }}\) High & tSHDAH & 0 & 490 & 0 & 325 & 0 & 245 & 0 & 190 & 0 & 150 & ns \\
\hline
\end{tabular}

\section*{AC ELECTRICAL SPECIFICATIONS - READ AND WRITE CYCLES (CONTINUED)}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Num.} & \multirow[b]{2}{*}{Characteristic} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|l|}{4 MHz} & \multicolumn{2}{|l|}{6 MHz} & \multicolumn{2}{|l|}{8 MHz} & \multicolumn{2}{|l|}{10 MHz} & \multicolumn{2}{|l|}{12.5 MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & & Min & Max & Min & Max & Min & Max & Min & Max & Min & Max & \\
\hline 29 & \(\overline{\mathrm{DS}}\) High to Data Invalid (Hold Time) & tSHDI & 0 & - & 0 & - & 0 & - & 0 & - & 0 & - & ns \\
\hline 30 & \(\overline{\mathrm{AS}}, \overline{\mathrm{DS}}\) High to \(\overline{\mathrm{BERR}}\) High & tSHBEH & 0 & - & 0 & - & 0 & - & 0 & - & 0 & - & ns \\
\hline 312,5 & DTACK Low to Data In (Setup Time) & tDALDI & - & 180 & - & 120 & - & 90 & - & 65 & - & 50 & ns \\
\hline 32 & HALT and \(\overline{\text { RESET Input }}\) Transition Time & \({ }^{\text {tr }}\) Hr,f & 0 & 200 & 0 & 200 & 0 & 200 & 0 & 200 & 0 & 200 & ns \\
\hline 33 & Clock High to \(\overline{B G}\) Low & \({ }^{\text {t }} \mathrm{CHGL}\) & - & 90 & - & 80 & - & 70 & - & 60 & - & 50 & ns \\
\hline 34 & Clock High to \(\overline{\text { BG }}\) High & \({ }^{\text {t }} \mathrm{CHGH}\) & - & 90 & - & 80 & - & 70 & - & 60 & - & 50 & ns \\
\hline 35 & \(\overline{\mathrm{BR}}\) Low to \(\overline{\mathrm{BG}}\) Low & tBRLGL & 1.5 & 3.5 & 1.5 & 3.5 & 1.5 & 3.5 & 1.5 & 3.5 & 1.5 & 3.5 & Clk. Per. \\
\hline 36 & \(\overline{B R}\) High to \(\overline{B G}\) High & tBRHGH & 1.5 & 3.5 & 1.5 & 3.5 & 1.5 & 3.5 & 1.5 & 3.5 & 1.5 & 3.5 & Clk. Per. \\
\hline 37 & BGACK Low to \(\overline{\text { BG High }}\) & tGALGH & 1.5 & 3.0 & 1.5 & 3.0 & 1.5 & 3.0 & 1.5 & 3.0 & 1.5 & 3.0 & Clk. Per. \\
\hline 37A & \(\overline{\text { BGACK Low to } \overline{B R} \text { High }}\) (to Prevent Rearbitration) & \({ }^{\text {tBGKBR }}\) & 30 & - & 25 & - & 20 & - & 20 & - & 20 & - & ns \\
\hline 38 & \(\overline{B G}\) Low to Bus High Impedance (with \(\overline{\mathrm{AS}} \mathrm{High})\) & \({ }^{\mathrm{t}} \mathrm{GLZ}\) & - & 120 & - & 100 & - & 80 & - & 70 & - & 60 & ns \\
\hline 39 & \(\overline{B G}\) Width High & \(\mathrm{t}_{\mathrm{GH}}\) & 1.5 & - & 1.5 & - & 1.5 & - & 1.5 & - & 1.5 & - & Clk. Per. \\
\hline 40 & Clock Low to VMA Low & tCLVML & - & 90 & - & 80 & - & 70 & - & 70 & - & 70 & ns \\
\hline 41 & Clock Low to E Transition & tCLC & - & 100 & - & 85 & - & 70 & - & 55 & - & 45 & ns \\
\hline 42 & E Output Rise and Fall Time & \({ }_{\text {t }}\) r, f & - & 25 & - & 25 & - & 25 & - & 25 & - & 25 & ns \\
\hline 43 & \(\overline{\text { VMA }}\) Low to E High & tVMLEH & 325 & - & 240 & - & 200 & - & 150 & - & 90 & - & ns \\
\hline 44 & \(\overline{\mathrm{AS}}, \overline{\mathrm{DS}}\) High to \(\overline{\mathrm{VPA}}\) High & tSHVPH & 0 & 240 & 0 & 160 & 0 & 120 & 0 & 90 & 0 & 70 & ns \\
\hline 45 & E Low to Address/ \(\overline{\mathrm{VMA}} /\) FC Invalid & telai & 55 & - & 35 & - & 30 & - & 10 & - & 10 & - & ns \\
\hline 46 & BGACK Width & \({ }_{\text {t }}\) BGL & 1.5 & - & 1.5 & - & 1.5 & - & 1.5 & - & 1.5 & - & Clk. Per. \\
\hline 475 & Asynchronous Input Setup Time & tASI & 30 & - & 25 & - & 20 & - & 20 & - & 20 & - & ns \\
\hline 483,5 & \(\overline{\text { BERR Low to DTACK Low }}\) & tBELDAL & 30 & - & 25 & - & 20 & - & 20 & - & 20 & - & ns \\
\hline 49 & E Low to \(\overline{A S}, \overline{D S}\) Invalid & tELSI & -80 & - & -80 & - & -80 & - & -80 & - & -80 & - & ns \\
\hline 50 & E Width High & \({ }^{\text {t E H }}\) & 900 & - & 600 & - & 450 & - & 350 & - & 280 & - & ns \\
\hline 51 & E Width Low & \(\mathrm{t}_{\mathrm{EL}}\) & 1400 & - & 900 & - & 700 & - & 550 & - & 440 & - & ns \\
\hline 52 & E Extended Rise Time & tCIEHX & - & 80 & - & 80 & - & 80 & - & 80 & - & 80 & ns \\
\hline 53 & Data Hold from Clock High & \({ }^{\text {t }} \mathrm{CHDO}\) & 0 & - & 0 & - & 0 & - & 0 & - & 0 & - & ns \\
\hline 54 & Data Hold from E Low (Write) & teldoz & 60 & - & 40 & - & 30 & - & 20 & - & 15 & - & ns \\
\hline 55 & R/W to Data Bus Impedance Change & trLDO & 55 & - & 35 & - & 30 & - & 20 & - & 10 & - & ns \\
\hline \(56^{4}\) & HALT/RESET Pulse Width & tHRPW & 10 & - & 10 & - & 10 & - & 10 & - & 10 & - & Clk. Per. \\
\hline
\end{tabular}

Notes:
1. For a loading capacitance of less than or equal to 50 picofarads, subtract 5 nanoseconds from the value given in these columns.
2. Actual value depends on clock period.
3. If \#47 is satisfied for both \(\overline{\text { DTACK }}\) and \(\overline{B E R R}, ~ \# 48\) may be 0 nanoseconds.
4. For power up, the MPU must be held in RESET state for 100 ms to stabilize all on-chip circuitry. After the system is powered up, \#56 refers to the minimum pulse width required to reset the system.
5. If the asynchronous setup time (\#47) requirements are satisfied the \(\overline{\text { DTACK }}\) low-to-data setup time (\#31) requirement can be ignored. The data must only satisfy the data-in clock-low setup time (\#27) for the following cycle.
6. When \(\overline{\mathrm{AS}}\) and \(\mathrm{R} / \overline{\mathrm{W}}\) are equally loaded ( \(\pm 20 \%\) ), subtract 10 nanoseconds from the value given in these columns.


NOTES:
1. SETUP TIME FOR THE ASYNCHRONOUS INPUTS \(\overline{\text { BGACK }}, \overline{\mathrm{IPLO}}-\overline{\mathrm{IPL2}}\), aND \(\overline{\mathrm{VPA}}\) GUARANTEES THEIR RECOGNITION AT THE NEXT FALLING EDGE OF THE CLOCK.
2. \(\overline{B R}\) NEEDS FALL AT THIS TIME ONLY IN ORDER TO INSURE BEING RECOGNIZED AT THE END OF THIS BUS CYCLE.
3. TIMING MEASUREMENTS ARE REFERENCED TO AND FROM A LOW VOLTAGE OF 0.8 VOLTS AND A HIGH VOLTAGE OF 2.0 VOLTS, UNLESS OTHERWISE NOTED.

Figure 45. Read Cycle Timing


NOTES:
1. BECAUSE OF LOADING VARIATIONS, R/W MAY BE VALID AFTER \(\overline{A S}\) EVEN THOUGH BOTH ARE INITIATED BY THE RISING EDGE OF S2 (SPECIFICATION 20A).
2. TIMING MEASUREMENTS ARE REFERENCED TO AND FROM A LOW VOLTAGE OF 0.8 VOLTS AND A HIGH VOLTAGE OF 2.0 VOLTS, UNLESS OTHERWISE NOTED.

Figure 46. Write Cycle Timing

AC ELECTRICAL SPECIFICATIONS - BUS ARBITRATION
\(\left(V_{C c}=5.0 \mathrm{Vdc} \pm 5 \%, V_{S S}=0 \mathrm{Vdc}, T_{A}=T_{L}\right.\) to \(T_{H}{ }^{\circ} \mathrm{C}\). See Figure 47.)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Num.} & \multirow[b]{2}{*}{Characteristic} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|l|}{4 MHz} & \multicolumn{2}{|l|}{6 MHz} & \multicolumn{2}{|l|}{8 MHz} & \multicolumn{2}{|l|}{10 MHz} & \multicolumn{2}{|l|}{12.5 MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & & Min & Max & Min & Max & Min & Max & Min & Max & Min & Max & \\
\hline 33 & Clock High to \(\overline{\mathrm{BG}}\) Low & tCHGL & - & 90 & - & 80 & - & 70 & - & 60 & - & 50 & ns \\
\hline 34 & Clock High to \(\overline{\mathrm{BG}}\) High & \({ }^{\text {t }} \mathrm{CHGH}\) & - & 90 & - & 80 & - & 70 & - & 60 & - & 50 & ns \\
\hline 35 & \(\overline{\mathrm{BR}}\) Low to \(\overline{\mathrm{BG}}\) Low & tBRLGL & 1.5 & 3.5 & 1.5 & 3.5 & 1.5 & 3.5 & 1.5 & 3.5 & 1.5 & 3.5 & Clk. Per. \\
\hline 36 & \(\overline{\mathrm{BR}}\) High to \(\overline{\mathrm{BG}}\) High & tBRHGH & 1.5 & 3.5 & 1.5 & 3.5 & 1.5 & 3.5 & 1.5 & 3.5 & 1.5 & 3.5 & Clk. Per. \\
\hline 37 & \(\overline{\text { BGACK }}\) Low to \(\overline{\mathrm{BG}}\) High & tGALGH & 1.5 & 3.0 & 1.5 & 3.0 & 1.5 & 3.0 & 1.5 & 3.0 & 1.5 & 3.0 & Clk. Per. \\
\hline 37A & \(\overline{\mathrm{BGACK}}\) Low to \(\overline{\mathrm{BR}}\) High (to Prevent Rearbitration) & tBGKBR & 30 & - & 25 & - & 20 & - & 20 & - & 20 & - & ns \\
\hline 38 & \(\overline{\mathrm{BG}}\) Low to Bus High Impedance (with \(\overline{\mathrm{AS}} \mathrm{High})\) & \({ }^{\text {t }}\) GLZ & - & 120 & - & 100 & - & 80 & - & 70 & - & 60 & ns \\
\hline 39 & \(\overline{\text { BG Width High }}\) & tGH & 1.5 & - & 1.5 & - & 1.5 & - & 1.5 & - & 1.5 & - & Clk. Per. \\
\hline 46 & BGACK Width & \({ }^{\text {t }}\) BGL & 1.5 & - & 1.5 & - & 1.5 & - & 1.5 & - & 1.5 & - & Clk. Per. \\
\hline
\end{tabular}

THESE WAVEFORMS SHOULD ONLY BE REFERENCED IN REGARD TO THE EDGE-TO-EDGE MEASUREMENT OF THE TIMING SPECIFICATIONS. THEY ARE NOT INTENDED AS A FUNCTIONAL DESCRIPTION OF THE INPUT AND OUTPUT SIGNALS. REFER TO OTHER FUNCTIONAL DESCRIPTIONS AND THEIR RELATED DIAGRAMS FOR DEVICE OPERATION.


NOTES:
1. SETUP TIME FOR THE ASYNCHRONOUS INPUTS \(\overline{B E R R}, \overline{B G A C K}, \overline{B R}, \overline{\mathrm{DTACK}}, \overline{\mathrm{IPLO}}-\overline{\mathrm{IPL2}}\), AND \(\overline{\mathrm{VPA}}\) GUARANTEES THEIR RECOGNITION AT THE NEXT FALLING EDGE OF THE CLOCK.
2. WAVEFORM MEASUREMENTS FOR ALL INPUTS AND OUTPUTS ARE SPECIFIED AT: LOGIC HIGH = 2.0 VOLTS, LOGIC LOW = 0.8 VOLTS

Figure 47. AC ELECTRICAL Waveforms - Bus Arbitration

\section*{PACKAGE DIMENSIONS}

\section*{64-PIN CERAMIC DUAL IN-LINE PACKAGE (DIP)}


64-PIN PLASTIC DUAL IN-LINE PACKAGE (DIP)

\begin{tabular}{|c|c|c|c|c|}
\hline \multirow{2}{*}{ DIM } & \multicolumn{2}{|c|}{ MILLIMETERS } & \multicolumn{2}{c|}{ INCHES } \\
\cline { 2 - 5 } & MIN & MAX & MIN & MAX \\
\hline A & 81.15 & 81.91 & 3.195 & 3.225 \\
\hline B & 20.07 & 20.57 & 0.799 & 0.810 \\
\hline C & 4.32 & 4.82 & 0170 & 0.190 \\
\hline D & 0.38 & 0.58 & 0.015 & 0.023 \\
\hline F & 1.42 & 1.62 & 0.056 & 0.064 \\
\hline G & 2.54 & BSC & \multicolumn{2}{|c|}{0.100} \\
\hline BSC & 1.15 & 1.65 & 0.045 & 0.065 \\
\hline J & 0.20 & 0.30 & 0.008 & 0.012 \\
\hline K & 3.05 & 3.55 & 0.120 & 0.140 \\
\hline L & 22.71 & 23.01 & 0.894 & 0.906 \\
\hline M & 0 & 10 & 0 & 10 \\
\hline N & 0.51 & 1.01 & 0.020 & 0.040 \\
\hline
\end{tabular}

\section*{64-PIN PLASTIC QUAD IN-LINE PACKAGE (QUIP)}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{ DIM } & \multicolumn{2}{|c|}{ MILLIMETERS } & \multicolumn{2}{c|}{ INCHES } \\
\cline { 2 - 5 } & MIN & MAX & MIN & MAX \\
\hline A & 41.10 & 41.61 & 1.618 & 1.638 \\
\hline B & 17.02 & 1723 & 0670 & 0.690 \\
\hline C & 356 & 4.58 & 0.140 & 0.180 \\
\hline D & 048 & 0.56 & 0018 & 0022 \\
\hline E1 & \multicolumn{2}{|c|}{19.05 BSC } & \multicolumn{2}{|c|}{0.750 BSC } \\
\hline E2 & \multicolumn{2}{|c|}{23.50 BSC } & \multicolumn{2}{|c|}{0.925 BSC } \\
\hline G & \multicolumn{2}{|c|}{1.27 BSC } & \multicolumn{2}{|c|}{0.050 BSC } \\
\hline J & 0.18 & 0.33 & 0.007 & 0.013 \\
\hline K1 & 2.92 & 3.18 & 0.115 & 0.125 \\
\hline K2 & 483 & 5.34 & 0.190 & 0210 \\
\hline
\end{tabular}


\section*{68-PIN PLASTIC CHIP CARRIER (PCC)}


TOP VIEW


TYP FOR BOTH AXIS (EXCEPT FOR BEVELED EDGE)

\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{ DIM } & \multicolumn{2}{|c|}{ MILLIMETERS } & \multicolumn{2}{c|}{ INCHES } \\
\cline { 2 - 5 } & MIN & MAX & MIN & MAX \\
\hline A & 3.683 & 3.785 & .145 & .149 \\
\hline A1 & 1.829 & 1.930 & .072 & .076 \\
\hline A2 & 1.803 & 1.905 & .071 & .075 \\
\hline A3 & 1.372 & 1.473 & .054 & .058 \\
\hline A4 & 2.311 & 2.464 & .091 & .097 \\
\hline A5 & 0.203 & 0.305 & .008 & .012 \\
\hline b & \multicolumn{2}{|c|}{0.457 TYP } & .018 TYP \\
\hline D & 25.02 & 25.27 & .985 & .995 \\
\hline D1 & 24.00 & 24.26 & .945 & .955 \\
\hline D2 & 20.19 & 20.45 & .795 & .805 \\
\hline D3 & 23.24 & 23.50 & .915 & .925 \\
\hline D4 & 20.96 & 21.21 & .825 & .835 \\
\hline D5 & 22.23 & 22.48 & .875 & .885 \\
\hline e & \multicolumn{2}{|c|}{1.27 BSC } & .050 BSC \\
\hline h & 0.254 TYP & .010 TYP \\
\hline J & 1.143 TYP & .045 TYP \\
\hline\(\alpha\) & \multicolumn{2}{|c|}{\(4^{\circ}\) TYP } & \(44^{\circ}\) TYP \\
\hline\(\alpha 1\) & \multicolumn{2}{|c|}{\(10^{\circ}\) TYP } & \(10^{\circ}\) TYP \\
\hline\(\alpha 2\) & \(45^{\circ}\) TYP & \(45^{\circ}\) TYP \\
\hline R & \multicolumn{2}{|c|}{0.889 TYP } & .035 TYP \\
\hline R1 & \multicolumn{2}{|c|}{0.254 TYP } & .010 TYP \\
\hline
\end{tabular}

\section*{68-PIN CERAMIC CHIP CARRIER (LCC)}

\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{DIM} & \multicolumn{2}{|l|}{MILLIMETERS} & \multicolumn{2}{|c|}{INCHES} \\
\hline & MIN & MAX & MIN & MAX \\
\hline A & 1.65 & 1.91 & 0.065 & 0.075 \\
\hline A1 & 1.40 & 165 & 0.055 & 0.065 \\
\hline \(b\) & 0.51 & 0.76 & 0.020 & 0.030 \\
\hline D & 23.83 & 24.43 & 0.938 & 0.962 \\
\hline D1 & 20.12 & 20.52 & 0.792 & 0.808 \\
\hline D2 & 12.45 & 12.70 & 0.490 & 0.500 \\
\hline D3 & \multicolumn{2}{|c|}{1.27 REF} & \multicolumn{2}{|r|}{0.050 REF} \\
\hline e & \multicolumn{2}{|c|}{1.27 BSC} & \multicolumn{2}{|l|}{0.050 BSC} \\
\hline h & \multicolumn{2}{|c|}{1.02 REF} & \multicolumn{2}{|l|}{0.040 REF} \\
\hline 1 & \multicolumn{2}{|c|}{0.51 REF} & \multicolumn{2}{|r|}{0.020 REF} \\
\hline L & \multicolumn{2}{|c|}{1.27 REF} & \multicolumn{2}{|r|}{0.050 REF} \\
\hline L1 & 1.96 & 2.36 & 0.077 & 0.093 \\
\hline
\end{tabular}

\section*{R68C552 \\ Dual Asynchronous Communications Interface Adapter (DACIA)}

\section*{PRELIMINARY}

\section*{DESCRIPTION}

The Rockwell CMOS R68C552 Dual Asynchronous Communications Interface Adapter (DACIA) provides an easily implemented, program controlled two-channel interface between 16-bit microprocessor-based systems and serial communication data sets and modems.

The DACIA is designed for maximum programmed control from the microprocessor (MPU) to simplify hardware implementation. Dual sets of registers allow independent control and monitoring of each channel.

Transmitter and Receiver bit rates may be controlled by an internal baud rate generator or external times 16 clocks. The baud rate generator accepts either a crystal or a clock input, and provides 15 programmable baud rates. When a 3.6864 MHz crystal is used, the baud rates range from 50 bps to \(38,400 \mathrm{bps}\).

The DACIA may be programmed to transmit and receive frames having word lengths of 5, 6, 7 or 8 bits; even, odd, space, mark or no parity; and 1 or 2 stop bits.

A Compare Register, and the ability to detect address frames, facilitate address recognition in a multidrop mode.

\section*{FEATURES}
- Low power CMOS N-well silicon gate technology
- Two independent full duplex channels with buffered receivers and transmitters.
- Data set/modem control functions
- Internal baud rate generator with 15 programmable baud rates ( 50 bps to \(38,400 \mathrm{bps}\) )
- Program-selectable internally or externally controlled receiver and transmitter bit rates
- Programmable word lengths, number of stop bits, and parity bit generation and detection
- Programmable interrupt control
- Edge detect for \(\overline{\mathrm{DCD}}, \overline{\mathrm{DSR}}\), and \(\overline{\mathrm{CTS}}\)
- Program-selectable echo mode for each channel
- Compare Register
- Address/Data frame recognition
- 5.0 Vdc \(\pm 5 \%\) supply requirements
- 40-pin plastic or ceramic DIP or 44-pin PLCC
- Full TTL or CMOS input/output compatibility
- Compatible with R68000 microprocessors

\section*{ORDERING INFORMATION}

\section*{Part Number: \\ R68C552}


Blank \(=0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\) \(E=-40^{\circ} \mathrm{C}\) to \(+85^{\circ} \mathrm{C}\)

Package:
\(C=40-\) Pin Ceramic DIP
\(\mathrm{P}=40-\mathrm{Pin}\) Plastic DIP
\(J=44\)-Pin Plastic Leaded
Chip Carrier (PLCC)

\section*{INTERFACE SIGNALS}

The DACIA is available in a 40 -pin DIP or a 44 -pin PLCC. Figure 1 shows the pin assignments for each package. The DACIA interface signals are shown in Figure 2. Table 1 contains a description of each signal.


Figure 1. R68C552 Pin Assignments


Figure 2. R68C552 DACIA Interface Signals

Table 1. DACIA Interface Signal Definitions
\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Signal} & \multicolumn{2}{|c|}{Pin No.} & \multirow[b]{2}{*}{1/0} & \multirow[b]{2}{*}{Name/Description} \\
\hline & DIP & PLCC & & \\
\hline \multicolumn{5}{|l|}{Host Interface} \\
\hline \(\overline{\text { RES }}\) & 1 & 24 & 1 & Reset. Active low input controlling the reset function. This signal must be driven low for a minimum of \(4 \mu \mathrm{~s}\) for a valid reset to occur. It is driven high during normal operation. \\
\hline \(R / \bar{W}\) & 38 & 20 & 1 & Read/Write. Input controlling the direction of data transfer. It is driven low during write cycles, and is driven high at all other times. \\
\hline \(\overline{\mathrm{CS}}\) & 39 & 21 & 1 & Chip Select. Active low input enabling data transfers between the host CPU and the DACIA. The DACIA latches register selects and the R/W input on the falling edge of \(\overline{C S}\). It latches input data on the rising edge of \(\overline{\mathrm{CS}}\). \\
\hline RS0-RS3 & 35-37 & 17-19 & 1 & Register Select. Three inputs controlling access to the DACIA internal registers. Table 3 lists the coding for each register. \\
\hline D0-D3
D4-D7 & \(24-21\)
\(19-16\) & \(6-3\)
\(44-41\) & 1/0 & Data Bus. Eight bidirectional lines used to transfer data between the host and the DACIA. These lines output data during READ cycles when \(\overline{\mathrm{CS}}\) is low and they output the interrupt vector during INTERRUPT ACKNOWLEDGE cycles when IACK1 or \(\overline{\text { IACK2 }}\) is low. At all other times, they are in the high impedence state. \\
\hline \(\overline{\text { DTACK }}\) & 2 & 25 & 0 & Data Transfer Acknowledge. Active low open drain output generated in response to \(\overline{\mathrm{CS}}, \overline{\mathrm{IACK} 1}\) and \(\overline{\text { IACK2 }}\) during asynchronous data transfers. \(\overline{\text { DTACK }}\) goes to the high impedence state when \(\overline{\mathrm{CS}}, \overline{\mathrm{IACK1}}\) and \(\overline{\text { IACK2 }}\) are high. \\
\hline \(\frac{\overline{\mathrm{IRQ1}}}{\overline{\mathrm{IRQ2}}}\) & 29
11 & 11
35 & 0 & Interrupt Request. Two active low, open-drain outputs from the interrupt control logic. These outputs are normally high. An IRQ line goes low when one of the flags of the associated ISR is set if the corresponding enable bit is set in the IER. \\
\hline \(\frac{\overline{\text { IACK } 1}}{\text { IACK2 }}\) & 34
6 & 16
30 & 1 & Interrupt Acknowledge. Two active low inputs indicating that an INTERRUPT ACKNOWLEDGE cycle is in progress. When an \(\overline{\mathrm{IACK}}\) goes low, the DACIA places the interrupt vector for the associated channel on the data bus and issues DTACK. \\
\hline \multicolumn{5}{|l|}{Clock Interface} \\
\hline \begin{tabular}{l}
XTALI \\
XTALO
\end{tabular} & 3 & \[
\begin{aligned}
& 26 \\
& 27
\end{aligned}
\] & \[
\begin{aligned}
& 1 \\
& 0
\end{aligned}
\] & Crystal Input/Output. One input and one output through which the reference signal for the internal clock oscillator is supplied. A parallel resonant crystal may be connected across the pins or a clock may be input at XTALI. When a clock is used, XTALO must be left open. \\
\hline CLK OUT & 5 & 29 & 0 & Clock Out. A buffered output from the internal clock oscillator which is in phase with XTALI. This output may be used to drive the XTALI input of another DACIA. Therefore, several DACIA chips may be driven with one crystal. \\
\hline RxC & 25 & 7 & 1 & Receiver Clock. Input for external 16x receiver clock. \\
\hline TxC & 15 & 39 & 1 & Transmitter Clock. Input for external 16x transmitter clock. \\
\hline \multicolumn{5}{|l|}{Serial Channel Interface} \\
\hline \(\overline{\text { DTR1 }}\) & 27
13 & 9
37 & 0 & Data Terminal Ready. Two general purpose outputs which are set high upon reset. The output level is programmed by setting the appropriate bit in the associated Format Register (FR) high or low. The state of each \(\overline{\text { DTR }}\) line is reflected by the \(\overline{\text { DTR LVL bit in the associated Control Status Register (CSR). }}\) \\
\hline \(\frac{\overline{\text { DSR1 }}}{\text { DSR2 }}\) & 33
7 & 15
31 & 1 & Data Set Ready. Two general purpose inputs. An active transition sets the \(\overline{\mathrm{DSR}} \mathrm{T}\) bit in the Interrupt Enable Register (ISR). The \(\overline{\mathrm{DSR}}\) LVL bit in the associated CSR reflects the current state of a \(\overline{\mathrm{DSR}}\) line. \\
\hline \(\overline{\overline{\text { RTS } 1}}\) & 30
10 & 12
34 & 0 & Request To Send. Two general purpose outputs which are set high upon reset. The output level is programmed by setting the appropriate bit in the associated FR high or low. The state of an RTS line is reflected by the RTS LVL bit in the associated CSR. \\
\hline \(\frac{\overline{\text { CTS } 1}}{\overline{\text { CTS } 2}}\) & 31
9 & 13
33 & 1 & Clear To Send. The \(\overline{\mathrm{CTS}}\) control line inputs allow handshaking by the transmitters. When \(\overline{\mathrm{CTS}}\) is low, the data is transmitted continuously. When \(\overline{\mathrm{CTS}}\) is high, the Transmit Data Register Empty bit (TDRE) in the associated ISR is not set. The word presently in the Transmit Shift Register is sent normally. Any active transition on a \(\overline{\mathrm{CTS}}\) line sets the \(\overline{\mathrm{CTS}} \mathrm{T}\) bit in the appropriate ISR. The \(\overline{\mathrm{CTS}} \mathrm{LVL}\) bit in the associated CSR reflects the current state of CTS. \\
\hline TxD1
TxD2 & 26
14 & 8
38 & 0 & Transmit Data. The TxD outputs transfer serial non-return to zero (NRZ) data to the data communications equipment (DCE). The data is transferred, LSB first, at a rate determined by the baud rate generator or external clock. \\
\hline \(\frac{\overline{D C D 1}}{\overline{D C D 2}}\) & 32
8 & 14
32 & 1 & Data Carrier Detect. Two general purpose inputs. An active transition sets the \(\overline{\mathrm{DCD}} \mathrm{T}\) bit in the appropriate ISR. The \(\overline{\mathrm{DCD}}\) LVL bit in the associated CSR reflects the current state of a \(\overline{\mathrm{DCD}}\) line. \\
\hline RxD1
RxD2 & 28
12 & 10
36 & 1 & Receive Data. The RxD inputs transfer serial NRZ data into the DACIA from the DCE, LSB first. The receiver baud rate is determined by the baud rate generator or external clock. \\
\hline \multicolumn{5}{|l|}{Power} \\
\hline \[
\begin{aligned}
& \text { VCC } \\
& \text { VSS }
\end{aligned}
\] & 40
20 & 22
1 & 1 & DC Power Input. 5.0V \(\pm 5 \%\). Power and Signal Reference. \\
\hline
\end{tabular}

\section*{FUNCTIONAL DESCRIPTION}

Figure 3 is a block diagram of the DACIA which consists of two asynchronous communications interface adapters with common microprocessor interface control logic and data bus buffers. The individual functional elements of the DACIA are described in the following paragraphs.

\section*{RESET LOGIC}

The Reset Logic sets various internal registers, status bits and control lines to a known state. The \(\overline{\operatorname{RES}}\) input must be driven low for a minimum of \(4 \mu \mathrm{~S}\) for a valid reset to occur. At this time, the IERs are set to \(\$ 80\), the RDRs and ACRs are cleared, and the compare mode is disabled. Also, the \(\overline{\mathrm{DTR}}\) and \(\overline{\mathrm{RTS}}\) outputs are driven high and the \(\overline{C T S}, \overline{D C D}\) and \(\overline{\mathrm{DSR}}\) transition detect flags are cleared. No other bits are affected.

\section*{DATA BUS BUFFER}

The Data Bus Buffer is a bidirectional interface between the data lines and the internal data bus. The state of the Data Bus Buffer is controlled by the I/O Control Logic and the Interrupt Logic. Table 2 summarizes the Data Bus Buffer states.

\section*{I/O CONTROL LOGIC}

The I/O Control Logic controls data transfers between the Internal Registers and the Data Bus Buffer. Internal Register selection is determined by the Register Select inputs as shown in Table 3. When \(\mathrm{R} / \overline{\mathrm{W}}\) is high and \(\overline{\mathrm{CS}}\) is low, data from the selected register is transferred from the internal data bus to the data lines and \(\overline{\text { DTACK }}\) is asserted. When \(\overline{C S}\) is high, the DACIA is deselected if the \(\overline{\mathrm{IACK}}\) inputs are high and the data lines are tri-stated.

\section*{INTERRUPT LOGIC}

The interrupt logic causes the \(\overline{\mathrm{RQ}}\) lines ( \(\overline{\mathrm{IRQ1}}\) or \(\overline{\mathrm{IRQ} 2}\) ) to go low when conditions are met that require the attention of the MPU. There are two registers (the Interrupt Enable Register and the Interrupt Status Register) involved in the control of interrupts in the DACIA. Corresponding bits in both registers must be set to cause an \(\overline{\mathrm{RQ}}\).

When an \(\overline{\mathrm{ACK}}\) input goes low in response to an \(\overline{\mathrm{RQ}}\), the following occurs if \(\overline{\mathrm{CS}}\) and \(\mathrm{R} / \bar{W}\) are high: D 0 goes low if the \(\overline{\mathrm{RQ}}\) is generated by TDR empty or RDR full. DO goes high for all other interrupt sources. TDRE and RDRF interrupts have priority over all other interrupt sources. D1 goes low when the interrupt request is from Channel 1. It goes high if the IRQ is from Channel 2. D2 through D7 outputs the Interrupt Vector Number stored in bits 2 through 7 of the Auxiliary Control Register. DTACK is asserted.

\section*{CLOCK OSCILLATOR LOGIC}

The internal clock oscillator supplies the time base for the baud rate generator. The oscillator can be driven by a crystal or an external clock.

The baud rate generator may be disabled by connecting XTALI to ground and leaving XTALO open. When this is done, a transmitter times 16 clock must be input at TxC, a receiver times 16 clock must be input at RxC and the Control Registers must be programmed to select TxC and RxC clocks.

Table 2. Data Bus Buffer Summary
\begin{tabular}{|cccc|c|}
\hline \multicolumn{4}{|c|}{ Control Signals } & Data Bus Buffer State \\
R/W & \(\overline{\text { CS }}\) & IACK1 & IACK2 & \\
\hline L & L & L & L & Illegal Mode - Tri-State \\
L & L & L & H & Illegal Mode - Tri-State \\
L & L & H & L & Illegal Mode - Tri-State \\
L & L & H & H & Write Mode - Tri-State \\
L & H & L & L & Ilegal Mode - Tri-State \\
L & H & L & H & Illegal Mode - Tri-State \\
L & H & H & L & Illegal Mode - Tri-State \\
L & H & H & H & Tri-State \\
H & L & L & L & Illegal Mode - Output \$OF \\
H & L & L & H & Illegal Mode - Output \$OF \\
H & L & H & L & Illegal Mode - Output \$OF \\
H & L & H & H & Read Mode - Output Data \\
H & H & L & L & Illegal Mode - Output \$OF \\
H & H & L & H & Output IRQ Vector 1 \\
H & H & H & L & Output IRQ Vector 2 \\
H & H & H & H & Tri-State \\
\hline
\end{tabular}



Figure 3. DACIA Block Diagram

Table 3. DACIA Register Selection
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{\multirow[t]{2}{*}{Register Select Lines}} & \multicolumn{4}{|c|}{Register Accessed} \\
\hline & & & & \multicolumn{2}{|c|}{Write} & \multicolumn{2}{|c|}{Read} \\
\hline HEX & RS2 & RS1 & RS0 & Symbol & Name & Symbol & Name \\
\hline 0 & L & L & L & IER1 & Interrupt Enable Register 1 & ISR1 & Interrupt Status Register 1 \\
\hline \multirow[t]{2}{*}{1} & \multirow[t]{2}{*}{L} & \multirow[t]{2}{*}{L} & \multirow[t]{2}{*}{H} & CR1 & Control Register \({ }^{11}\) & \multirow[t]{2}{*}{CSR1} & \multirow[t]{2}{*}{Control Status Register 1} \\
\hline & & & & FR1 & Format Register \(1^{2}\) & & \\
\hline \multirow[t]{2}{*}{2} & \multirow[t]{2}{*}{L} & \multirow[t]{2}{*}{H} & \multirow[t]{2}{*}{L} & CDR1 & Compare Data Register \(1^{3}\) & & \multirow[t]{2}{*}{Not Used} \\
\hline & & & & ACR1 & Auxiliary Control Register \({ }^{14}\) & & \\
\hline 3 & L & H & H & TDR1 & Transmit Data Register 1 & RDR1 & Receive Data Register 1 \\
\hline 4 & H & L & L & IER2 & Interrupt Enable Register 2 & ISR2 & Interrupt Status Register 2 \\
\hline \multirow[t]{2}{*}{5} & \multirow[t]{2}{*}{H} & \multirow[t]{2}{*}{L} & \multirow[t]{2}{*}{H} & CR2 & Control Register \({ }^{11}\) & \multirow[t]{2}{*}{CSR2} & \multirow[t]{2}{*}{Control Status Register 2} \\
\hline & & & & FR2 & Format Register \(2^{2}\) & & \\
\hline \multirow[t]{2}{*}{6} & \multirow[t]{2}{*}{H} & \multirow[t]{2}{*}{H} & \multirow[t]{2}{*}{L} & CDR2 & Compare Data Register \(2^{3}\) & & \multirow[t]{2}{*}{Not Used} \\
\hline & & & & ACR2 & Auxiliary Control Register \(2^{4}\) & & \\
\hline 7 & H & H & H & TDR2 & Transmit Data Register 2 & RDR2 & Receive Data Register 2 \\
\hline
\end{tabular}

Notes:
1. D7 must be set low to write to the Control Registers.
2. D7 must be set high to write to the Format Registers.
3. Control Register bit 6 must be set to 0 to access the Compare Register.
4. Control Register bit 6 must be set to 1 to access the Auxiliary Control Register.

\section*{SERIAL DATA CHANNELS}

Two independent serial data channels are available for the full duplex (simultaneous transmit and receive) transfer of asynchronous frames. Separate internal registers are provided for each channel for the selection of frame parameters (number of bits per character, parity options, etc.), status flags, interrupt control and handshake. The asynchronous frame format is shown in Figure 4.

Transmit data from the host system is loaded into the Transmit Data Register. From there, it is transferred to the Transmit Shift Register where it is shifted, LSB first, onto the TXD line. All transmissions begin with a start bit and end with the user selected number of stop bits. A parity bit is transmitted before the stop bit(s) if parity is enabled.

Receive data is shifted into the Receive Shift Register from the associated RxD line. Start and stop bits are stripped from the frame and the data is transferred to the Receive Data Register. Parity bits may be discarded or stored in the ISR.

Five I/O lines are provided for each channel for handshake with the data communications equipment (DCE). Four of these signals ( \(\overline{R T S}, \overline{\mathrm{DTR}}, \overline{\mathrm{DSR}}\) and \(\overline{\mathrm{DCD}}\) ) are general purpose inputs or outputs. The fitth signal, CTS, enables/disables the transmitter. When CTS
is high and the Transmit Shift Register is empty, the transmitter (except for Echo Mode) is inhibited. When CTS is low, the transmitter is enabled.


Figure 4. Asynchronous Frame Format

\section*{INTERNAL REGISTERS}

The DACIA contains ten control registers and four status registers in addition to the transmit and receive registers. The Control Registers provide for control of frame parameters, baud rate, interrupt generation, handshake lines, transmission and reception. The status registers provide status information on transmit and receive registers, error conditions and interrupt sources. Table 4 summarizes the bit definitions of these registers. A detailed description follows.

Table 4. Register Formats
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline Register Select (Hex) & Register & R/W & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 & \[
\begin{aligned}
& \text { Reset } \\
& \text { Value } \\
& \mathbf{7 6 5 4 3 2 1 0}
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& 0 \\
& 4
\end{aligned}
\] & \[
\begin{aligned}
& \text { ISR1 } \\
& \text { ISR2 }
\end{aligned}
\] & R & ANY BIT SET & TDRE & \(\overline{\mathrm{CTS}} \mathrm{T}\) & \(\overline{\text { DCD }}\) T & DSRT & PAR & F/O/B & RDRF & 1-00000- \\
\hline \[
\begin{aligned}
& 0 \\
& 4
\end{aligned}
\] & \begin{tabular}{l}
IER1 \\
IER2
\end{tabular} & W & CLR/SET BITS & TDRE IE & \[
\begin{gathered}
\overline{\mathrm{CTS} T} \\
\mathrm{IE}
\end{gathered}
\] & \[
\begin{gathered}
\overline{\mathrm{DCD}} \mathrm{~T} \\
\mathrm{IE}
\end{gathered}
\] & \[
\begin{aligned}
& \overline{\mathrm{DSR}} \mathrm{~T} \\
& \mathrm{IE}
\end{aligned}
\] & \[
\begin{aligned}
& \text { PAR } \\
& \text { IE }
\end{aligned}
\] & \[
\begin{gathered}
\text { F/O/B } \\
\text { IE }
\end{gathered}
\] & RDRF IE & - 0000000 \\
\hline \[
\begin{aligned}
& 1 \\
& 5
\end{aligned}
\] & CSR1 CSR2 & R & FE & TUR & \[
\begin{aligned}
& \overline{\text { CTS }} \\
& \text { LVL }
\end{aligned}
\] & \[
\begin{aligned}
& \hline \overline{\mathrm{DCD}} \\
& \mathrm{LVL}
\end{aligned}
\] & \[
\begin{aligned}
& \overline{\mathrm{DSR}} \\
& \mathrm{LVL}
\end{aligned}
\] & BRK & \[
\begin{aligned}
& \overline{\overline{\mathrm{DTR}}} \\
& \text { LVL }
\end{aligned}
\] & \[
\begin{aligned}
& \overline{\mathrm{RTS}} \\
& \text { LVL }
\end{aligned}
\] & 1---011 \\
\hline \[
\begin{aligned}
& 1 \\
& 5
\end{aligned}
\] & \[
\begin{aligned}
& \text { CR1 } \\
& \text { CR2 }
\end{aligned}
\] & W & 0 & \[
\begin{aligned}
& \text { CDR/ } \\
& \text { ACR }
\end{aligned}
\] & \[
\begin{aligned}
& \text { STOP } \\
& \text { BITS }
\end{aligned}
\] & ECHO & & BIT P & SEL & & 0......- \\
\hline \[
\begin{aligned}
& 1 \\
& 5
\end{aligned}
\] & \[
\begin{aligned}
& \text { FR1 } \\
& \text { FR2 }
\end{aligned}
\] & W & 1 & DAT & ITS & & & \[
\begin{aligned}
& \text { PAR } \\
& \text { EN }
\end{aligned}
\] & \(\overline{\text { DTR }}\) CNTL & \(\overline{\text { RTS }}\) CNTL & 1-..... \\
\hline \[
\begin{aligned}
& 2 \\
& 6
\end{aligned}
\] & \[
\begin{aligned}
& \text { CDR1 } \\
& \text { CDR2 }
\end{aligned}
\] & \[
\begin{gathered}
W \\
(C R 6=0)
\end{gathered}
\] & & &  & COMP & DATA & & & & --.---- \\
\hline \[
\begin{aligned}
& 2 \\
& 6
\end{aligned}
\] & \begin{tabular}{l}
ACR1 \\
ARC2
\end{tabular} & \[
\begin{gathered}
W \\
(C R 6=1)
\end{gathered}
\] & & & Q VECT & NUMB & & & TRNS BRK & \[
\begin{gathered}
\text { PAR } \\
\text { ERR/ST }
\end{gathered}
\] & --. - 00 \\
\hline \[
\begin{aligned}
& 3 \\
& 7
\end{aligned}
\] & RDR1 RDR2 & R & & & & EIVE D & REGIS & & & & 00000000 \\
\hline \[
\begin{aligned}
& 3 \\
& 7
\end{aligned}
\] & TDR1 TDR2 & W & & & & NSMIT & A REGIS & & & & ---.-.-- \\
\hline
\end{tabular}

\section*{INTERRUPT STATUS REGISTERS (ISR1, ISR2)}

The Interrupt Status Registers are read-only registers indicating the status of each interrupt source. Bits 6 through 0 are set when the indicated \(\overline{\mathrm{RQ}}\) condition has occurred. Bit 7 is set to a 1 when any \(\overline{\mathrm{RQ}}\) source bit is set, or if Echo Mode is disabled, when CTS is high.
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \(\mathbf{7}\) & 6 & 5 & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & 1 & 0 \\
\hline \begin{tabular}{c} 
ANY \\
BIT \\
SET
\end{tabular} & TDRE & \(\overline{\text { CTST }}\) & \(\overline{\text { DCDT }}\) & \(\overline{\text { DSRT } T}\) & PAR & F/O/B & RDRF \\
\hline
\end{tabular}

Address \(=0,4\)
Reset Value \(=1.00000-\)
\begin{tabular}{|c|c|}
\hline Bit 7 & Any Bit Set \\
\hline 1 & Any bit ( 6 through 0 ) has been set to a 1 or \(\overline{\mathrm{CTS}}\) is high with echo disabled \\
\hline 0 & No bits have been set to a 1 or echo is enabled \\
\hline Bit 6 & Transmit Data Register Empty (TDRE) \\
\hline 1 & Transmit Data Register is empty and CTS is low \\
\hline 0 & Transmit Data Register is full or \(\overline{\text { CTS }}\) is high \\
\hline Bit 5 & Transition On \(\overline{\text { CTS }}\) Line ( \(\overline{\text { (TSST) }}\) \\
\hline 1 & A positive or negative transition has occurred on CTS \\
\hline 0 & No transition has occurred on CTS, or ISR has been Read \\
\hline Bit 4 & Transition On \(\overline{\text { DCD }}\) Line ( \(\overline{\text { DCDT }}\) ) \\
\hline 1 & A positive or negative transition has occurred on \(\overline{D C D}\) \\
\hline 0 & No transition has occurred on \(\overline{D C D}\), or ISR has been Read \\
\hline Bit 3 & Transition On \(\overline{\text { DSR }}\) Line ( \(\overline{\text { DSRT }}\) ) \\
\hline 1 & A positive or negative transition has occurred on DSR \\
\hline 0 & No transition has occurred on \(\overline{\mathrm{DSR}}\), or ISR has been Read \\
\hline Bit 2 & Parity Status (PAR) ACR bit \(0=0\) \\
\hline 1 & A parity error has occurred in received data \\
\hline 0 & No parity error has occurred, or the Receive Data Register (RDR) has been Read ACR bit \(0=1\) \\
\hline 1 & Parity bit \(=1\) \\
\hline 0 & Parity bit \(=0\) \\
\hline Bit 1 & Frame Error, Overrun, Break \\
\hline 1 & A framing error, receive overrun, or receive break has occurred or has been detected \\
\hline 0 & No error, overrun, break has occurred or RDR has been Read \\
\hline Bit 0 & Receive Data Register Full (RDRF) \\
\hline 1 & Receive Data Register is full \\
\hline 0 & Receive Data Register is empty \\
\hline
\end{tabular}

\section*{INTERRUPT ENABLE REGISTERS (IER1, IER2)}

The Interrupt Enable Registers are write-only registers that enable/disable the \(\overline{\mathrm{IRQ}}\) sources. \(\overline{\mathrm{IRQ}}\) sources are enabled by writing to an IER with bit 7 set to a 1 and the bit for every \(\overline{\mathrm{RQ}}\) source to be enabled set to a 1 . \(\overline{\mathrm{RQ} Q}\) sources are disabled by writing to an IER with bit 7 reset to a 0 and the bit for every source to be disabled set to a 1 . Any source bit reset to 0 is unaffected and remains in its original state. Thus, writing \(\$ 7 \mathrm{~F}\) to an IER disables all of that channel's interrupts and writing an \$FF to an IER enables all of that channel's interrupts.
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline \begin{tabular}{c} 
SET \\
BITS
\end{tabular} & \begin{tabular}{c} 
TDRE \\
IE
\end{tabular} & \begin{tabular}{c} 
CTST \\
IE
\end{tabular} & \begin{tabular}{c}
\(\overline{\text { DCDT }}\) \\
IE
\end{tabular} & \begin{tabular}{c}
\(\overline{\text { DSRT }}\) \\
IE
\end{tabular} & \begin{tabular}{c} 
PAR \\
IE
\end{tabular} & \begin{tabular}{c} 
F/O/B \\
IE
\end{tabular} & \begin{tabular}{c} 
RDRF \\
IE
\end{tabular} \\
\hline
\end{tabular}

Address \(=0,4\)
\begin{tabular}{cl} 
Bit 7 & Enable/Disable \\
1 & Enable selected IRQ source \\
0 & Disable selected IRQ source \\
Bits 0-6 & \\
1 & \\
0 & Select for enable/disable \\
& No change
\end{tabular}

\section*{CONTROL STATUS REGISTERS (CSR1, CSR2)}

The Control Status Registers are read-only registers that provide I/O status and error condition information. A CSR is normally read after an IRQ has occurred to determine the exact cause of the interrupt condition.
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline FE & TUR & \begin{tabular}{c}
\(\overline{\mathrm{CTS}}\) \\
LVL
\end{tabular} & \begin{tabular}{c}
\(\overline{\text { DCD }}\) \\
LVL
\end{tabular} & \begin{tabular}{c}
\(\overline{\mathrm{DSR}}\) \\
LVL
\end{tabular} & BRK & \begin{tabular}{c}
\(\overline{\text { DTR }}\) \\
LVL
\end{tabular} & \begin{tabular}{c}
\(\overline{\mathrm{RTS}}\) \\
LVL
\end{tabular} \\
\hline
\end{tabular}

Address \(=1,5\)
Bit 7
1
0

1 Transmit Shift Register is empty and TDRE is set
0 Transmitter Shift Register is not empty
Bit \(5 \quad \overline{\text { CTS }}\) Level ( \(\overline{C T S}\) LVL)
1 CTS line is high
\(0 \quad \overline{C T S}\) line is low
Bit \(4 \overline{\mathrm{DCD}}\) Level ( \(\overline{\mathrm{DCD}}\) LVL)

Bit 1 DTR Level ( \(\overline{\text { DTR LVL }}\) )
1 DTR line is high
\(0 \quad \overline{\text { DTR }} 0\) line is low
Bit \(0 \quad \overline{\text { RTS }}\) Level ( \(\overline{\text { RTS LVL }}\) )
1 RTS line is high
\(0 \quad \overline{R T S}\) line is low

\section*{CONTROL REGISTERS (CR1, CR2)}

The Control Registers are write-only registers. They control access to the Auxiliary Control Register and the Compare Data Register. They select the number of stop bits, control Echo Mode, and select the data rate.
(Accessed when Bit \(7=0\) )
\begin{tabular}{|c|c|c|c|cccc|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline \(\mathbf{0}\) & CDR/ACR & \begin{tabular}{l} 
STOP \\
BITS
\end{tabular} & ECHO & & BAUD RATE SEL & \\
\hline
\end{tabular}

Address \(=1,5\)
Reset Value \(=0 \ldots \ldots\)
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{3}{|c|}{\[
\begin{gathered}
\text { Bit } 7 \\
0
\end{gathered}
\]} & Control or Format Register Access Control Register \\
\hline \multicolumn{3}{|c|}{Bit 6} & CDR/ACR \\
\hline \multicolumn{3}{|c|}{\multirow[t]{2}{*}{1}} & Access the Auxiliary Control Register (ACR) \\
\hline & & & Access the Compare Data Register (CDR) \\
\hline \multicolumn{3}{|c|}{Bit 5} & Number of Stop Bits Per Character \\
\hline \multicolumn{3}{|c|}{1} & Two stop bits \\
\hline \multicolumn{3}{|c|}{0} & One stop bit \\
\hline \multicolumn{3}{|c|}{Bit 4} & Echo Mode Selection \\
\hline \multicolumn{3}{|c|}{1} & Echo Mode enabled \\
\hline \multicolumn{3}{|c|}{0} & Echo Mode disabled \\
\hline \multicolumn{3}{|r|}{Bits 3-0} & Baud Rate Selection \\
\hline 3 & 21 & 0 & (bits per second with 3.6864 MHz crystal) \\
\hline 0 & 00 & 0 & 50 \\
\hline 0 & 00 & 1 & 109.2 \\
\hline 0 & 01 & 0 & 134.58 \\
\hline 0 & 01 & 1 & 150 \\
\hline 0 & 10 & 0 & 300 \\
\hline 0 & 10 & 1 & 600 \\
\hline 0 & 11 & 0 & 1200 \\
\hline 0 & 11 & 1 & 1800 \\
\hline 1 & 00 & 0 & 2400 \\
\hline 1 & 00 & 1 & 3600 \\
\hline 1 & 01 & 0 & 4800 \\
\hline 1 & 01 & 1 & 7200 \\
\hline 1 & 10 & 0 & 9600 \\
\hline 1 & 10 & 1 & 19200 \\
\hline 1 & 11 & 0 & 38400 \\
\hline 1 & 11 & 1 & External TxC and RxC X16 Clocks \\
\hline
\end{tabular}

\section*{FORMAT REGISTERS (FR1, FR2)}

The Format Registers are write-only registers. They select the number of data bits per character and parity generation/checking options. They also control \(\overline{\text { RTS }}\) and \(\overline{\text { DTR. }}\)
(Accessed when Bit \(7=1\) )
\begin{tabular}{|c|c|c|c|c|c|}
\hline 7 & 65 & 43 & 2 & 1 & 0 \\
\hline 1 & \begin{tabular}{l}
DATA \\
BITS
\end{tabular} & \begin{tabular}{l}
PAR \\
SEL
\end{tabular} & PAR
EN & \[
\begin{aligned}
& \overline{\text { DTR }} \\
& \text { CNTL. }
\end{aligned}
\] & \[
\begin{gathered}
\overline{\mathrm{RTS}} \\
\text { CNTL }
\end{gathered}
\] \\
\hline
\end{tabular}

Address \(=1,5\)
\begin{tabular}{|c|c|}
\hline \[
\begin{gathered}
\text { Bit } 7 \\
1
\end{gathered}
\] & Control or Format Register Access Format Register \\
\hline Bits 6-5 & Number of Data Bits Per Character \\
\hline 65 & \\
\hline 00 & 5 \\
\hline 01 & 6 \\
\hline 10 & 7 \\
\hline 11 & 8 \\
\hline Bits 4-3 & Parity Mode Selection \\
\hline 43 & \\
\hline 00 & Odd Parity \\
\hline 01 & Even Parity \\
\hline 10 & Mark in Parity bit \\
\hline 11 & Space in Parity bit \\
\hline Bit 2 & Parity Enable \\
\hline 1 & Parity as specified by bits 4-3 \\
\hline 0 & No Parity \\
\hline Bit 1 & \(\overline{\text { DTR Control }}\) \\
\hline 1 & Set DTR high \\
\hline 0 & Set DTR low \\
\hline Bit 0 & RTS Control \\
\hline 1 & Set RTS high \\
\hline 0 & Set RTS low \\
\hline
\end{tabular}

\section*{COMPARE DATA REGISTERS (CDR1, CDR2)}

The Compare Data Registers are write-only registers which can be accessed when CR bit \(6=0\). By writing a value into the CDR, the DACIA is put in the compare mode. In this mode, setting of the RDRF bit is inhibited until a character is received which matches the value in the CDR. The next character is then received and the RDRF bit is set. The receiver will now operate normally until the CDR is again loaded.
(Control Register bit \(6=0\) )
\begin{tabular}{|cccccccc|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multicolumn{7}{|c|}{ COMPARE DATA } \\
\hline
\end{tabular}

Address \(=2,6\)
Reset Value \(=\cdots \cdots \cdot\).

\section*{AUXILIARY CONTROL REGISTERS (ACR1, ACR2)}

The Auxiliary Control Registers are write-only registers. Bits 7-2 hold the user selected interrupt vector number to be output on data lines \(7-2\) during interrupt acknowledge. Bit 1 causes the transmitter to transmit a BREAK. Bit 0 determines whether parity error or the parity bit is displayed in ISR bit 2.
(Control Register bit \(6=1\) )
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multicolumn{6}{|c|}{IRQ VECTOR ADDRESS} & TRNS BRK & \begin{tabular}{l}
PAR \\
ERR/ST
\end{tabular} \\
\hline
\end{tabular}

Address \(=2,6\)
Reset Value \(=-\cdots-\cdots 00\)
\begin{tabular}{cl} 
Bits 7-2 & IRQ Vector Address \\
Bit 1 & Transmit Break (TRNS BRK) \\
1 & Transmit continuous Break \\
0 & Normal transmission \\
Bit 0 & Parity Error/State (PAR ERR/ST) \\
1 & Send value of parity bit to ISR bit 2 (Address \\
0 & Recognition mode) \\
Send Parity Error status to ISR bit 2
\end{tabular}

\section*{RECEIVE DATA REGISTERS (RDR1, RDR2)}

The Receive Data Registers are read-only registers which are loaded with the received data character of each frame. Start bits, stop bits and parity bits are stripped off of incoming frames before the data is transferred from the Receive Shift Register to the Receive Data Register. For characters of less than eight bits, the unused bits are the high order bits which are set to 0 .

MSB
LSB
\begin{tabular}{|cccccccc|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multicolumn{7}{|c|}{ RECEIVE DATA } \\
\hline
\end{tabular}

Address \(=3,7\)
Reset Value \(=00000000\)

\section*{TRANSMIT DATA REGISTERS (TDR1, TDR2)}

The Transmit Data Registers are write-only registers which are loaded from the CPU with data to be transmitted. For data characters of less than eight bits, the unused bits are the high order bits which are "don't care".


\section*{OPERATION}

\section*{TERMINATION OF UNUSED INPUTS}

Noise on floating inputs can affect chip operation. All unused inputs must be terminated. If unused, \(\overline{\mathrm{IACK} 1}\) and \(\overline{\mathrm{IACK}} 2\) must be tied high. If the baud rate generator is bypassed, XTALI must be connected to ground (XTALO is an output and must be left open). If the external clock mode is not used, RxC and TxC may be tied either to +5 V or to ground. If the handshake inputs are not needed, the \(\overline{\mathrm{CTS}}\) inputs should be tied low to enable the transmitters. The \(\overline{D C D}\) and \(\overline{D S R}\) inputs may either be tied high or low.

\section*{RESET INITIALIZATION}

During power on initialization, all readable registers should be read to assure that the status registers are initialized. Specifically, the RDRF bit of the Interrupt Status Registers is not initialized by reset. The Receiver Data Registers must be read to clear this bit.

\section*{BAUD RATE CLOCK OPTIONS}

The receiver and transmitter clocks may be supplied either by the internal Baud Rate Generator or by user supplied external clocks. Both channels may use the same clock source or one may use the Baud Rate Generator and the other channel external clocks. If both channels use the Baud Rate Generator, each channel may have a different bit rate. The options are shown in Figure 5.

An internal clock oscillator supplies the time base for the Baud Rate Generator. The oscillator can be driven by a crystal or an external clock.

If the on-chip oscillator is driven by a crystal, a parallel resonant crystal is connected between the XTALI and XTALO pins. The equivalent oscillator circuit is shown in Figure 6.

A parallel resonant crystal is specified by its load capacitance and series resonant resistance. For proper oscillator operation, the load capacitance \(\left(\mathrm{C}_{\mathrm{L}}\right)\), series resistance \(\left(\mathrm{R}_{\mathrm{s}}\right)\) and the crystal resonant frequency \((F)\) must meet the following two relations:
\[
\begin{gathered}
(C+2)=2 C_{L} \quad \text { or } \quad C=2 C_{L}-2 \\
R_{S} \leq R_{s \max }=\frac{2 \times 10^{6}}{\left(F C_{L}\right)^{2}}
\end{gathered}
\]
where: \(F\) is in \(M H z ; C\) and \(C_{L}\) are in \(p F ; R\) is in ohms.

To select a parallel resonant crystal for the oscillator, first select the load capacitance from a crystal manufacturer's catalog. Next, calculate \(R_{\text {smax }}\) based on \(F\) and \(C_{L}\). The selected crystal must have a \(R_{s}\) less than the \(R_{\text {smax }}\).


Figure 5. Baud Rate Clock Options


Figure 6.
For example, if \(\mathrm{C}_{\mathrm{L}}=22 \mathrm{pF}\) for a 3.6864 MHz parallel resonant crystal, then
\[
C=(2 \times 22)-2=42 \mathrm{pF} \text { (use standard value of } 43 \mathrm{pF} \text { ) }
\]

The series resistance of the crystal must be less than
\[
R_{\text {smax }}=\frac{2 \times 10^{6}}{(3.6864 \times 22)^{2}}=304 \text { ohms }
\]

If the on-chip oscillator is driven by an external clock, the clock is input at XTALI and XTALO is left open.

An internal counter/divider circuit divides the frequency input at XTALI by the divisor selected in bits 3 through 0 of the Control Registers. Table 5 lists the divisors that may be selected and shows the bit rates generated with a 3.6864 MHz crystal or clock input. Other bit rates may be generated by changing the clock or crystal frequency. However, the input frequency must not exceed 4 MHz .

For external clock operation, a transmitter times 16 clock must be supplied at TxC and a receiver times 16 clock must be input at RxC. Since there are separate receiver and transmitter clock inputs, the receiver data rate may be different from the transmitter data rate.

Table 5. Baud Rate Generator Divisor Selection
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{Control Register Bits} & \multirow[t]{2}{*}{\begin{tabular}{l}
Divisor Selected \\
For The \\
Internal Counter
\end{tabular}} & \multirow[t]{2}{*}{Baud Rate Generated With 3.6864 MHz Crystal or Clock} & \multirow[t]{2}{*}{Baud Rate Generated* With a Crystal or Clock of Frequency ( \(\mathbf{f}\) )} \\
\hline 3 & 2 & 1 & 0 & & & \\
\hline 0 & 0 & 0 & 0 & 73,728 & \(\left(3.6864 \times 10^{6}\right) / 73,728=50\) & f/73,728 \\
\hline 0 & 0 & 0 & 1 & 33,538 & \(\left(3.6864 \times 10^{6}\right) / 33,538=109.92\) & f/33,538 \\
\hline 0 & 0 & 1 & 0 & 27,408 & \(\left(3.6864 \times 10^{6}\right) / 27,408=134.58\) & f/27,408 \\
\hline 0 & 0 & 1 & 1 & 24,576 & \(\left(3.6864 \times 10^{6}\right) / 24,576=150\) & f/24,576 \\
\hline 0 & 1 & 0 & 0 & 12,288 & \(\left(3.6864 \times 10^{6}\right) / 12,288=300\) & f/12,288 \\
\hline 0 & 1 & 0 & 1 & 6,144 & \(\left(3.6864 \times 10^{6}\right) / 6,144=600\) & f/6,144 \\
\hline 0 & 1 & 1 & 0 & 3,072 & \(\left(3.6864 \times 10^{6}\right) / 3,072=1,200\) & f/3,072 \\
\hline 0 & 1 & 1 & 1 & 2,048 & \(\left(3.6864 \times 10^{6}\right) / 2,048=1,800\) & f/2,048 \\
\hline 1 & 0 & 0 & 0 & 1,536 & \(\left(3.6864 \times 10^{6}\right) / 1,536=2,400\) & f/1,536 \\
\hline 1 & 0 & 0 & 1 & 1,024 & \(\left(3.6864 \times 10^{6}\right) / 1,024=3,600\) & f/1,024 \\
\hline 1 & 0 & 1 & 0 & 768 & \(\left(3.6864 \times 10^{6}\right) / 768=4,800\) & f/768 \\
\hline 1 & 0 & 1 & 1 & 512 & \(\left(3.6864 \times 10^{6}\right) / 512=7,200\) & f/512 \\
\hline 1 & 1 & 0 & 0 & 384 & \(\left(3.6864 \times 10^{6}\right) / 384=9,600\) & f/384 \\
\hline 1 & 1 & 0 & 1 & 192 & \(\left(3.6864 \times 10^{6}\right) / 192=19,200\) & f/192 \\
\hline 1 & 1 & 1 & 0 & 96 & \(\left(3.6864 \times 10^{6}\right) / 96=38,400\) & f/96 \\
\hline 1 & 1 & 1 & 1 & 16 & Transmitter Baud Rate \(=\) TxC/16 & er Baud Rate \(=\) RxC/16 \\
\hline \multicolumn{4}{|l|}{\[
\text { *Baud Rate }=\frac{\text { Frequency }}{\text { Divisor }}
\]} & & & \\
\hline
\end{tabular}

\section*{CONTINUOUS DATA TRANSMIT}

In the normal operating mode, the TDRE bit in the ISR signals the MPU that the DACIA is ready to accept the next data word. An \(\overline{\mathrm{IRQ}}\) occurs if the corresponding TDRE IRQ enable bit is set in the IER. The TDRE bit is set at the beginning of the start bit. When the MPU writes a word to the TDR the TDRE bit is cleared. In order to maintain continuous transmission the TDR must be loaded before the stop bit(s) are ended. Figure 7 shows the relationship between \(\overline{\mathrm{RQ}}\) and TXD for the Continuous Data Transmit mode.

\section*{CAUTION:}

When the Baud Rate Generator is the clock source, writing to the Format or Control Register of a channel with an active transmitter can result in loss of data. Do not write to the Control or Format Register when the transmitter is shifting out data. This precaution does not apply to channels using the external clock option, i.e., TxC.


Figure 7. Continuous Data Transmit

\section*{TRANSMIT UNDERRUN CONDITION}

If the MPU is unable to load the TDR before the last stop bit is sent, the TxD line goes to the MARK condition and the underrun flag
(TUR) is set. This condition persists until the TDR is loaded with a new word. Figure 8 shows the relation between \(\overline{\mathrm{RQ}}\) and TXD for the Transmit Underrun Condition.


Figure 8. Transmit Underrun Condition Relationship

\section*{TRANSMIT BREAK CHARACTER}

A BREAK may be transmitted by setting bit 1 of the ACR (Transmit Break bit) to a 1. The BREAK is transmitted after the character in the Transmit Shift Register is sent. If there is a character in the Transmit Data Register, it will be transmitted after the BREAK is terminated. The Transmit Break bit must remain set for at least
one character time to assure that a proper BREAK is transmitted. If the Transmit Break bit is cleared before one character time of BREAK has been transmitted, the BREAK will be terminated after one character time has elapsed. If the Transmit Break bit is cleared after one character time of BREAK has been transmitted, the BREAK will be terminated immediately. Figure 9 shows the relationship of TxD, IRQ and ACR bit 1 for various BREAK options.

b. Transmit Break bit cleared during first character time of BREAK-BREAK terminates after one character time

c. Transmit Break bit cleared after first character time of BREAK-BREAK terminates immediately

Figure 9. Transmit BREAK

\section*{EFFECTS OF CTS ON TRANSMITTER}

The \(\overline{\mathrm{CTS}}\) control line controls the transmission of data or the handshaking of data to a "busy" device (such as a printer). When the CTS line is low, the transmitter operates normally. A high condition inhibits the TDRE bit in the ISR from becoming set. Transmission of the word currently in the shift register is completed but any word in the TDR is held until CTS goes low.

Any transition on CTS sets bit 5 (CTST) of the ISR. A high on CTS forces bit 6 (TDRE) of the ISR to a 0 . Bit 7 of the ISR also goes to a 1 when CTS is high, if Echo Mode is disabled. Thus, when the ISR is \(\$ 80\), it means that CTS is high and no interrupt source requires service. A processor interrupt will not be generated under these circumstances, but an ISR polling routine should accommodate this.


Figure 10. Effects of \(\overline{\text { CTS }}\) on Transmitter

\section*{ECHO MODE TIMING}

In the Echo Mode, the TxD line re-transmits the data received on the RxD line, delayed by \(1 / 2\) of a bit time. An internal underrun mode must occur before Echo Mode will start transmitting. In normal transmit mode if TDRE occurs (indicating end of data) an
underflow flag would be set and continuous Mark transmitted. If Echo is initiated, the underflow flag will not be set at end of data and continuous Mark will not be transmitted. Figure 11 shows the relationship of RxD and TxD for Echo Mode.


Figure 11. Echo Mode Timing

\section*{CONTINUOUS DATA RECEIVE}

The normal receive mode sets the RDRF bit in the ISR when the DACIA channel has received a full data word. This occurs at about the 9/16 point through the stop bit. The processor must read the RDR before the next stop bit, or an overrun error occurs. Figure 12 shows the relationship between \(\overline{\mathrm{RQ}}\) and RxD for the continuous Data Receive mode.

\section*{CAUTION:}

When the Baud Rate Generator is the clock source, writing to the Control or Format Registers of a channel with an active receiver can result in loss of data. Do not write to the Control or Format Registers when the receiver is shifting in data. This precaution is not necessary on channels using the external clock option, i.e., RxC.


Figure 12. Continuous Data Receive

\section*{EFFECTS OF OVERRUN ON RECEIVER}

If the processor does not read the RDR before the stop bit of the next word, an overrun error occurs, the overrun bit is set in the ISR, and the new data word is not transferred to the RDR. The RDR
contains the last word not read by the MPU and all following data is lost. The receiver will return to normal operation when the RDR is read. Figure 13 shows the relationship of \(\overline{\mathrm{RQ}}\) and RxD when overrun occurs.


Figure 13. Effects of Overrun on Receiver

\section*{RECEIVE BREAK CHARACTER}

In the event that a Break character is received by the receiver, the Break bit is set. The receiver does not set the RDRF bit and remains in this state until a stop bit is received. At this time the
next character is to be received normally. Figure 14 shows the relationship of \(\overline{\mathrm{RQ}}\) and RxD for a Receive Break Character.


Figure 14. Receive Break Character

\section*{FRAMING ERROR}

Framing error is caused by the absence of stop bit(s) on received data. The framing error bit is set when the RDRF bit is set. Subsequent data words are tested separately, so the status bit always
reflects the last data word received. Figure 15 shows the relationship of \(\overline{\mathrm{RQ}}\) and RxD when a framing error occurs.


Figure 15. Framing Error

\section*{PARITY ERROR DETECT/ADDRESS FRAME RECOGNITION}

The Parity Status bit (ISR bit 2) may be programmed to indicate parity errors (ACR bit \(0=0\) ) or to display the parity bit received (ACR bit \(0=1\) ).

In applications where parity checking is used, one of the parity checking modes is enabled by setting bits 2,3 and 4 of the Format Register to the desired option and bit 0 of the Auxiliary Control Register is reset to 0 . Then, when the RDRF bit (bit 0 ) is set in the ISR, the PAR bit (bit 2) will be set when a parity error is detected.

In multi-drop applications, the parity bit is used as an address/data flag. It is set to 1 for address frames and is 0 on data frames. For
this type of operation, bit 0 of the ACR is set to a 1 and bits 2,3 and 4 of the FR select a parity checking mode. Then, ISR bit 2 will be set to a 1 by incoming address frames and it will be a 0 on data frames.

\section*{COMPARE MODE}

The Compare Mode is automatically enabled, i.e., the channel is put to sleep, whenever data is written to the Compare Data Register. NOTE: Bit 6 of the Control Register must be set to 0 to enable access to the Compare Data Register. When the channel is in the compare mode, the RDRF bit (bit 0 of the ISR) is forced to a 0 . Upon receipt of a matching character, normal receiver operation resumes and the RDRF bit (bit 0 of the ISR) will be set upon receipt of the next character.

\section*{SPECIFICATIONS}

\section*{DACIA READ/WRITE WAVEFORMS}


\section*{DACIA READ/WRITE CYCLE TIMING}
\(\left(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}\right.\) to \(\mathrm{T}_{\mathrm{H}}\), unless otherwise noted)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Number & Characteristic & Symbol & Min. & Typ. & Max. & Unit \\
\hline 1 & R/W, RSO-RS2 Valid to \(\overline{\mathrm{CS}}\) Low (Setup) & \(\mathrm{T}_{\text {RSU }}\) & 0 & & - & ns \\
\hline 2 & \(\overline{\mathrm{CS}}\) Low to R/W, RSO-RS2 Invalid (Hold) & \(\mathrm{T}_{\text {RH }}\) & 45 & & - & ns \\
\hline 3 & \(\stackrel{\rightharpoonup}{\text { CS }}\) Pulse Width & \(\mathrm{T}_{\mathrm{CP}}\) & 210 & & - & ns \\
\hline 4 & \(\overline{\mathrm{CS}}\) Low to DTACK Low & \(\mathrm{T}_{\text {CTL }}\) & & 160 & 320 & ns \\
\hline 5 & \(\overline{\mathrm{CS}}\) High to \(\overline{\text { DTACK }}\) High & \(\mathrm{T}_{\text {CTH }}\) & & 200 & & ns \\
\hline 6 & \(\overline{\mathrm{CS}}\) Low to Data Valid (Read) & \(\mathrm{T}_{\text {CDV }}\) & - & & 210 & ns \\
\hline 7 & \(\overline{\text { DTACK }}\) Low to Data Valid (Read) & TTDV & & 90 & & ns \\
\hline 8 & \(\overline{\overline{\mathrm{CS}}}\) High to Data Invalid (Read) & \(T_{\text {CDR }}\) & 10 & & 50 & ns \\
\hline 9 & Data Valid to \(\overline{\mathrm{CS}}\) High (Write, Setup) & T DSU & 20 & & - & ns \\
\hline 10 & \(\overline{\mathrm{CS}}\) High to Data Invalid (Write Hold) & \(\mathrm{T}_{\text {cow }}\) & 30 & & - & ns \\
\hline 11 & \(\overline{\mathrm{DS}}\) Low to \(\overline{\mathrm{CS}}\) Low (Delay for \(\overline{\mathrm{CS}}\) derived from Data Strobe) & \(\mathrm{T}_{\text {DSC }}\) & & 20 & & ns \\
\hline
\end{tabular}

DACIA TRANSMIT/RECEIVER WAVEFORMS


\section*{DACIA INTERRUPT ACKNOWLEDGE WAVEFORMS}


TRANSMIT/RECEIVE AND INTERRUPT ACKNOWLEDGE TIMING
\(\left(V_{C C}=5 \mathrm{Vdc} \pm 5 \%, V_{S S}=0 \mathrm{Vdc}, T_{A}=T_{L}\right.\) to \(T_{H}\), unless otherwise noted)
\begin{tabular}{|c|c|c|c|c|c|}
\hline Number & Characteristic & Symbol & Min. & Max. & Unit \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{6}{|l|}{TRANSMIT/RECEIVE TIMING} \\
\hline 12 & Transmit/Receive Clock Rate & \(\mathrm{t}_{\mathrm{CY}}\) & 250 & - & ns \\
\hline 13 & Transmit/Receive Clock High & \(\mathrm{t}_{\mathrm{CH}}\) & 100 & - & ns \\
\hline 14 & Transmit/Receive Clock Low & \({ }_{\text {ch }}\) & 100 & - & ns \\
\hline 15 & TxC, RxC to TxD Propagation Delay & \(t_{\text {DD }}\) & - & 285 & ns \\
\hline 16 & TxC, RxC to \(\overline{\mathrm{RQ}}\) Propagation Delay & \(\mathrm{t}_{\mathrm{DI}}\) & - & 250 & ns \\
\hline 17 & \(\overline{C T S}\), \(\overline{D C D}, \overline{\text { DSR }}\) Valid to \(\overline{\mathrm{IRQ}}\) Low & \(\mathrm{t}_{\mathrm{CTI}}\) & - & 150 & ns \\
\hline 18 &  & \(\mathrm{t}_{\text {IRQ }}\) & - & 150 & ns \\
\hline 19 & \(\overline{\text { RTS, }} \overline{\text { DTR }}\) Propagation Delay & \(t_{\text {DLY }}\) & - & 150 & ns \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{6}{|l|}{INTERRUPT ACKNOWLEDGE TIMING} \\
\hline 20 & \(\overline{\text { IACK }}\) Low to Data Valid & tidv & - & 210 & ns \\
\hline 21 & \(\overline{\text { IACK Low to DTACK Low }}\) & \(t_{\text {ITL }}\) & 0 & - & ns \\
\hline 22 & \(\overline{\text { IACK High to } \overline{\text { DTACK }} \text { High }}\) & \(\mathrm{t}_{\text {ITH }}\) & 0 & - & ns \\
\hline 23 & IACK High to Data Invalid & \(\mathrm{t}_{10 Z}\) & 10 & 30 & ns \\
\hline
\end{tabular}

\section*{ABSOLUTE MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline Parameter & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.3 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to \(\mathrm{V}_{\mathrm{CC}}+0.3\) & Vdc \\
\hline Output Voltage & \(\mathrm{V}_{\text {OUT }}\) & -0.3 to \(\mathrm{V}_{\mathrm{CC}}+0.3\) & Vdc \\
\hline \begin{tabular}{l} 
Operating Temperature \\
Commercial \\
Industrial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{c}
0 to +70 \\
-40 to +85
\end{tabular} & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\text {STG }}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}

\section*{OPERATING CONDITIONS}
\begin{tabular}{|l|c|c|}
\hline Parameter & Symbol & Value \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & \(5 \mathrm{~V} \pm 5 \%\) \\
\hline \begin{tabular}{c} 
Temperature Range \\
Commercial \\
Industrial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & 0 to \(70^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}
\(\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{S S}=0, T_{A}=T_{L}\right.\) to \(T_{H}\), unless otherwise noted)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ & Max & Unit & Test Conditions \\
\hline Input High Voltage Except XTALI and XTALO XTALI and XTALO & \(\mathrm{V}_{\mathrm{IH}}\) & \[
\begin{aligned}
& +2.0 \\
& +2.4
\end{aligned}
\] & - & \[
\begin{aligned}
& V_{\mathrm{cc}}+0.3 \\
& V_{\mathrm{cc}}+0.3
\end{aligned}
\] & V & \\
\hline Input Low Voltage Except XTALI and XTALO XTALI and XTALO & \(V_{\text {IL }}\) & \[
\begin{aligned}
& -0.3 \\
& -0.3
\end{aligned}
\] & - & \[
\begin{aligned}
& +0.8 \\
& +04
\end{aligned}
\] & V & \\
\hline Input Leakage Current R \(\bar{W}, \overline{R E S}, R S O, R S 1, R S 2, R \times D, \overline{C T S}, \overline{D C D}, \overline{D S R}, R \times C\), TXC, \(\overline{\mathrm{CS}}, \overline{\mathrm{IACK}}\) & \(\mathrm{I}_{\mathrm{IN}}\) & - & 10 & 50 & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V} \text { to } 5.0 \mathrm{~V} \\
& \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}
\end{aligned}
\] \\
\hline Input Leakage Current for Three-State Off D0-D7 & \(\mathrm{I}_{\text {TSI }}\) & - & \(\pm 2\) & 10 & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\
& \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}
\end{aligned}
\] \\
\hline Output High Voltage DO-D7, TxD, CLK OUT, RTS, DTR & \(\mathrm{V}_{\mathrm{OH}}\) & +2.4 & - & - & V & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\
& \mathrm{I}_{\mathrm{LOAD}}=-100 \mu \mathrm{~A}
\end{aligned}
\] \\
\hline Output Low Voltage D0-D7, TxD, CLK OUT, RTS, DTR & \(\mathrm{V}_{\text {OL }}\) & - & - & \(+0.4\) & V & \[
\begin{aligned}
& V_{C C}=4.75 \mathrm{~V} \\
& \mathrm{I}_{\mathrm{LOAD}}=1.6 \mathrm{~mA}
\end{aligned}
\] \\
\hline Output Leakage Current (Off State) \(\overline{\text { IRQ, }}, \overline{\text { DTACK }}\) & \(\mathrm{I}_{\text {OFF }}\) & - & \(\pm 2\) & \(\pm 10\) & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} \\
& \mathrm{~V}_{\mathrm{OUT}}=0 \text { to } 2.4 \mathrm{~V}
\end{aligned}
\] \\
\hline Power Dissipation & \(\mathrm{P}_{\mathrm{D}}\) & - & - & 10 & \(\mathrm{mW} / \mathrm{MHz}\) & \\
\hline Input Capacitance Except XTALI and XTALO XTALI and XTALO & \(\mathrm{C}_{1 \mathrm{~N}}\) & - & - & \[
\begin{gathered}
5 \\
10
\end{gathered}
\] & \[
\begin{aligned}
& \mathrm{pF} \\
& \mathrm{pF}
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \\
& \mathrm{~V}_{\mathrm{IN}}=\mathrm{OV} \\
& \mathrm{f}=2 \mathrm{MHz}
\end{aligned}
\] \\
\hline Output Capacitance & \(\mathrm{C}_{\text {OUT }}\) & - & & 10 & pF & \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}

\section*{Notes:}
1. All units are direct current (dc) except for capacitance.
2. Negative sign indicates outward current flow, positive indicates inward flow.
3. Typical values are shown for \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\) and \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\).

\section*{PACKAGE DIMENSIONS}


\title{
R68560, R68561 Multi-Protocol Communications Controller (MPCC)
}

\section*{DESCRIPTION}

The R68560, R68561 Multi-Protocol Communications Controller (MPCC) interfaces a single serial communications channel to a 68008/68000 microcomputer-based system using either asynchronous or synchronous protocol. High speed bit rate, automatic formatting, low overhead programming, eight character buffering, two channel DMA interface and three separate interrupt vector numbers optimize MPCC performance to take full advantage of the 68008/68000 processing capabilities and asynchronous bus structure.

In synchronous operation, the MPCC supports bit-oriented protocols (BOP), such as SDLC/HDLC, and character-oriented protocols (COP), such as IBM Bisync (BSC) in either ASCII or EBCDIC coding. Formatting, synchronizing, validation and error detection is performed automatically in accordance with protocol requirements and selected options. Asynchronous (ASYNC) and isochronous (ISOC) modes are also supported. In addition, modem interface handshake signals are available for general use.

Control, status and data are transferred between the MPCC and the microcomputer bus via 22 directly addressable registers and a DMA interface. Two first-in first-out (FIFO) registers, addressable through separate receiver and transmitter data registers, each buffer up to eight characters at a time to allow more MPU processing time to service data received or to be transmitted and to maximize bus throughput, especially during DMA operation. The two-channel Direct Memory Access (DMA) interface operates with the MC68440/MC68450 DMA Controllers. Three prioritized interrupt vector numbers separately support receiver, transmitter and modem interface operation.

An on-chip oscillator drives the internal baud rate generator (BRG) and an external clock output with an 8 MHz input crystal or clock frequency. The BRG, in conjunction with two selectable prescalers and 16-bit programmable divisor, provides a data bit rate of DC to 4 MHz .

The 48-pin R68561 supports word-length (16-bit) operation when connected to the 68000 16-bit asynchronous bus, as well as bytelength ( 8 -bit) operation when connected to the 680088 -bit bus. The 40-pin R68560 supports byte-length operation on the 68008 bus.

\section*{FEATURES}
- Full duplex synchronous/asynchronous receiver and transmitter
- Implements IBM Binary Synchronous Communications (BSC) in two coding formats: ASCII and EBCDIC
- Supports other synchronous character-oriented protocols (COP), such as six-bit BSC, X3.28k, ISO IS1745, ECMA-16, etc.
- Supports synchronous bit oriented protocols (BOP), such as SDLC, HDLC, X.25, etc.
- Asynchronous and isochronous modes
- Modem handshake interface
- High speed serial data rate (DC to 4 MHz )
- Internal oscillator and baud rate generator with programmable data rate
- Crystal or TTL level clock input and buffered clock output ( 8 MHz )
- Direct interface to \(68008 / 68000\) asynchronous bus
- Eight-character receiver and transmitter buffer registers
- 22 directly addressable registers for flexible option selection, complete status reporting, and data transfer
- Three separate programmable interrupt vector numbers for receiver, transmitter and serial interface
- Maskable interrupt conditions for receiver, transmitter and serial interface
- Programmable microprocessor bus data transfer; polled, interrupt and two-channel DMA transfer compatible with MC68440/MC68450
- Clock control register for receiver clock divisor and receiver and transmitter clock routing
- Selectable full/half duplex, autoecho and local loop-back modes
- Selectable parity (enable, odd, even) and CRC (control field enable, CRC-16, CCITT V.41, VRC/LRC)

\section*{ORDERING INFORMATION}
\(\left.\begin{array}{|ccc|}\hline \text { Part Number } & \text { Frequency } & \text { Temperature Range } \\ \text { R6856 } \\ \text { 4 MHz } & 0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ \text { Package: } \mathrm{C}=\text { Ceramic } \\ \mathrm{P}=\text { Plastic }\end{array}\right]\)


Figure 1. MPCC Block Diagram

\section*{PIN DESCRIPTION}

Throughout the document, signals are presented using the terms active and inactive or asserted and negated independently of whether the signal is active in the high-voltage state or lowvoltage state. (The active state of each logic pin is described below.) Active low signals are denoted by a superscript bar. For example, \(R / \bar{W}\) indicates write is active low and read is active high.
Note: The R68561 interface is described for word mode operation only and the R68560 interface is described for byte mode operation only.

A1-A4-Address Lines. A1-A4 are active high inputs used in conjunction with the \(\overline{\mathrm{CS}}\) input to access the internal registers. The address map for these registers is shown in Table 1.

D0-D15-Data Lines. The bidirectional data lines transfer data between the MPCC and the MPU, memory or other peripheral device. D0-D15 are used when connected to the 16-bit 68000 bus and operating in the MPCC word mode. D0-D7 are used when connected to the 16 -bit 68000 bus or the 8 -bit 68008 bus and operating in the MPCC byte mode. The data bus is threestated when \(\overline{\mathrm{CS}}\) is inactive. (See exceptions in DMA mode.)
\(\overline{\mathbf{C S}}\)-Chip Select. \(\overline{\mathrm{CS}}\) low selects the MPCC for programmed transfers with the host. The MPCC is deselected when the \(\overline{C S}\) input is inactive in non-DMA mode. \(\overline{\mathrm{CS}}\) must be decoded from the address bus and gated with address strobe ( \(\overline{\mathrm{AS}}\) ).

R/ \(\overline{\mathbf{W}}\)-Read/Write. \(\mathrm{R} / \overline{\mathrm{W}}\) controls the direction of data flow through the bidirectional data bus by indicating that the current bus cycle is a read (high) or write (low) cycle.
\(\overline{\text { DTACK-Data Transfer Acknowledge. } \overline{\text { DTACK }} \text { is an active }}\) low output that signals the completion of the bus cycle. During read or interrupt acknowledge cycles, \(\overline{\text { DTACK }}\) is asserted by the MPCC after data has been provided on the data bus; during write cycles it is asserted after data has been accepted at the data bus. DTACK is driven high after assertion prior to being tri-stated. A holding resistor is required to maintain DTACK high between bus cycles.
\(\overline{\mathrm{DS}}\)-Data Strobe (R68560). During a write (R/ \(\bar{W}\) low), the \(\overline{\mathrm{DS}}\) positive transition latches data on data bus lines D0-D7 into the MPCC. During a read (R/W high), \(\overline{\mathrm{DS}}\) low enables data from the MPCC to data bus lines D0-D7.
\(\overline{\text { LDS-Lower Data Strobe (R68561). During a write (R } / \bar{W} \text { low), }}\) the positive transition latches data on the data bus lines D0-D7 (and on D8-D15 if UDS is low) into the MPCC. During a read ( \(\mathrm{R} \overline{\mathrm{W}}\) high), \(\overline{\mathrm{LDS}}\) low enables data from the MPCC to D0-D7 (and to D8-D15 if UDS is low).

A0-Address Line A0 (R68560). When interfacing to an 8-bit data bus system such as the 68008, address line AO is used to access an internal register. \(A 0=0\) defines an even register and \(A O=1\) defines an odd register. See Table 1 b .

UDS-Upper Data Strobe (R68561). When interfacing to a 16-bit data bus system such as the 68000, a low on control bus signal UDS enables access to the upper data byte on D8-D15. A high on UDS disables access to D8-D15. Data is latched and enabled in conjunction with \(\overline{\text { LDS }}\).
\(\overline{\operatorname{IRQ}}-\) Interrupt Request. The active low \(\overline{\mathrm{RQ}}\) output requests interrupt service by the MPU. \(\overline{\mathrm{RQ}}\) is driven high after assertion prior to being tri-stated.
\(\overline{\text { IACK }}\)-Interrupt Acknowledge. The active low \(\overline{\text { IACK }}\) input indicates that the current bus cycle is an interrupt acknowledge cycle. When \(\overline{\mathrm{ACK}}\) is asserted the MPCC places an interrupt vector on the lower byte (D0-D7) of the data bus.

TDSR-Transmitter Data Service Request. When Transmitter DMA mode is active, the low TDSR output requests DMA service.

RDSR-Receiver Data Service Request. When receiver DMA mode is active, the low RDSR output requests DMA service.
\(\overline{\text { DACK }}\)-DMA Acknowledge. The \(\overline{\text { DACK }}\) low input indicates that the data bus has been acquired by the DMAC and that the requested bus cycle is beginning.

DTC-Data Transfer Complete. On a 68000 bus, the \(\overline{\text { DTC }}\) low input indicates that a DMA data transfer was completed with no bus conflicts. \(\overline{\mathrm{DTC}}\) in response to a \(\overline{\text { RDSR }}\) indicates that the data has been successfully stored in memory. \(\overline{\text { DTC }}\) in response to a TDSR indicates that the data is present on the data bus for strobing into the MPCC. If not used, this input should be connected to ground.


Figure 2. MPCC Input and Output Signals
\(\overline{\text { DONE }}-\) Done. \(\overline{\text { DONE }}\) is a bidirectional active low signal. The \(\overline{\text { DONE signal is asserted by the DMAC when the DMA transfer }}\) count is exhausted and there is no more data to be transferred, or asserted by the MPCC when the status byte following the last character of a frame (block) is being transferred in response to a RDSR. The DONE signal asserted by the DMAC in response to a \(\overline{T D S R}\) will be stored to track with the data byte (lower byte for word transfer) through the TxFIFO.
\(\overline{\text { RESET}}\)-Reset. \(\overline{\text { RESET }}\) is an active low, high impedance input that initializes all MPCC functions. RESET must be asserted for at least 500 ns to initialize the MPCC.
\(\overline{\text { DTR-Data Terminal Ready. The } \overline{D T R} \text { active low output is }}\) general purpose in nature, and is controlled by the DTRLVL bit in the Serial Interface Control Register (SICR).
\(\overline{\text { RTS }}\)-Request to Send. The \(\overline{\mathrm{RTS}}\) active low output is general purpose in nature, and is controlled by the RTSLVL bit in the SICR.
\(\overline{\text { CTS }}-C l e a r ~ t o ~ S e n d . ~ T h e ~ C T S ~ a c t i v e ~ l o w ~ i n p u t ~ p o s i t i v e ~ t r a n s i-~\) tion and level are reported in the CTST and CTSLVL bits in the Serial Interface Status Register (SISR), respectively.
\(\overline{\text { DSR-Data Set Ready. The } \overline{\mathrm{DSR}} \text { active low input negative }}\) transition and level are reported in the DSRT and DSRLVL bits in the SISR, respectively. \(\overline{\mathrm{DSR}}\) is also an output for RSYN.
\(\overline{\mathrm{DCD}}\)-Data Carrier Detect. The \(\overline{\mathrm{DCD}}\) active low input positive transition and level are reported in the DCDT and DCDLVL bits in the the SISR, respectively.
TxD-Transmitted Data. The MPCC transmits serial data on the TxD output. The TxD output changes on the negative going edge of TxC.
RxD—Received Data. The MPCC receives serial data on the RxD input. The RxD input is shifted into the receiver with the negative going edge of RxC.

TxC-Transmitter Clock. TxC can be programmed to be an input or an output. When TxC is selected to be an input, the transmitter clock must be provided externally. When TxC is programmed to be an output, a clock is generated by the MPCC's internal baud rate generator.
RxC-Receiver Clock. RxC provides the MPCC receiver with received data timing information.

\section*{EXTAL-Crystal/External Clock Input.}

XTAL Crystal Return. EXTAL and XTAL connect a 20 kHz to 8.064 MHz parallel resonant external crystal to the MPCC internal oscillator (see CLOCK OSCILLATOR). The pin EXTAL may also be used as a TTL level input to supply DC to 8 MHz reference timing from an external clock source. XTAL must be tied to ground when applying an external clock to the EXTAL input.
BCLK—Buffered Clock. BCLK is the internal oscillator buffered output available to other MPCC devices eliminating the need for additional crystals.
\(\mathrm{V}_{\text {cc }}\)-Power. \(5 \mathrm{~V} \pm 5 \%\).
GND-Ground. Ground ( \(\mathrm{V}_{\mathrm{SS}}\) ).


Pin Configuration

\section*{MPCC REGISTERS}

Twenty-two registers control and monitor the MPCC operation. The registers and their addresses are identified in Table 1a (R68561 operation in word mode) and in Table 1b (R68560 operation in byte mode). When the R68561 is operated in the word mode, two registers are read or written at a time starting at an even boundary. When the R68560 is operated in the byte mode, each register is explicitly addressed based on AO.

Table 2 summarizes the MPCC register bit assignments and their access. A read from an unassigned location results in a read from a "null register." A null register returns all ones for data and results in a normal bus cycle. Unused bits of a defined register are read as zeros unless otherwise noted.

Table 1a. R68561 Accessible Registers (Word Mode)

\begin{tabular}{|l|l|c|c|cc|}
\hline Transmitter Control Register (TCR) & Transmitter Status Register (TSR) & R/W & 08 & 0 & 1 \\
\hline Transmitter Data Register (TDR)-16 bits \({ }^{2}\) & & 0 \\
\hline Transmitter Interrupt Enable Register (TIER) & Transmitter Interrupt Vector Number Register (TIVNR) & R/W & 0 OC & 0 & 1 \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|c|cccc|}
\hline Serial Interface Control Register (SICR) & Serial Interface Status Register (SISR) & R/W & 10 & 1 & 0 & 0 & 0 \\
\hline Reserved \(^{3}\) & Reserved \(^{3}\) & R/W & 12 & 1 & 0 & 0 & 1 \\
\hline Serial Interrupt Enable Register (SIER) \(\quad\) Serial Interrupt Vector Number Register (SIVNR) & R/W & 14 & 1 & 0 & 1 & 0 \\
\hline
\end{tabular}
\begin{tabular}{|l|l|l|l|llll|}
\hline Protocol Select Register 2 (PSR2) & Protocol Select Register (PSR1) & R/W & 18 & 1 & 1 & 0 & 0 \\
\hline Address Register 2 (AR2) & Address Register 1 (AR1) & R/W & 1 A & 1 & 1 & 0 & 1 \\
\hline Baud Rate Divider Register 2 (BRDR2) & Baud Rate Divider Register 1 (BRDR1) & R/W & \(1 C\) & 1 & 1 & 1 & 0 \\
\hline Error Control Register (ECR) & Clock Control Register (CCR) & R/W & 1E & 1 & 1 & 1 & 1 \\
\hline
\end{tabular}

\section*{Notes:}
1. Accessible register of the four word RxFIFO. The data is not initialized, however, \(\overline{\text { RES }}\) resets the RxFIFO pointer to the start of the first word.
2. Accessible register of the four word TxFIFO. The data is not initialized, however, \(\overline{\operatorname{RES}}\) resets the TxFIFO pointer to the start of the first word.
3. Reserved registers may contain random bit values.

\section*{CLOCK OSCILLATOR}

An on-chip oscillator is designed for a parallel resonant crystal connected between XTLI and XTLO pins. The equivalent oscillator circuit is shown in the figure below.


A parallel resonant crystal is specified by its load capacitance and series resonant resistance. For proper oscillator operation, the load capacitance \(\left(\mathrm{C}_{\mathrm{L}}\right)\), series resistance \(\left(\mathrm{R}_{\mathrm{s}}\right)\) and the crystal resonant frequency ( F ) must meet the following two relations:
\[
\begin{gathered}
\mathrm{C}_{1}=2 \mathrm{C}_{\mathrm{L}}-12 \mathrm{pF} \\
\mathrm{C}_{2}=2 \mathrm{C}_{\mathrm{L}}-33 \mathrm{pF} \\
\mathrm{R}_{\mathrm{S}} / \mathrm{R}_{\mathrm{smax}}=\frac{2 \times 10^{6}}{\left(\mathrm{FC}_{\mathrm{L}}\right)^{2}}
\end{gathered}
\]
where: \(F\) is in \(M H z ; C\) and \(C_{L}\) are in \(p F ; R\) is in ohms.
To select a parallel resonant crystal for the oscillator, first select the load capacitance from a crystal manufacturer's catalog. Next, calculate \(R_{\text {smax }}\) based on \(F\) and \(C_{L}\). The selected crystal must have a \(R_{s}\) less than the \(R_{\text {smax }}\).
For example, if \(\mathrm{C}_{\mathrm{L}}=20 \mathrm{pF}\) for an 8.064 MHz parallel resonant crystal, then
\(\mathrm{C}_{1}=40-12=28 \mathrm{pF}\) (Use standard value of 27 pF .)
\(\mathrm{C}_{2}=40-33=7 \mathrm{pF}\) (Use standard value of 6.8 pF .)
Note: \(\mathrm{C}_{\mathrm{x}}=\) Total Shunt Capacitance including that due to board layout.

The series resistance of the crystal must be less than
\[
R_{\text {smax }}=\frac{2 \times 10^{6}}{(8.064 \times 20)^{2}}=77 \mathrm{ohms}
\]

Table 1b. R68560 Accessible Registers (Byte Mode)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Register(s)} & \multirow[b]{2}{*}{R/W} & \multirow[t]{2}{*}{\begin{tabular}{l}
Addr \\
(Hex.)
\end{tabular}} & \multicolumn{5}{|c|}{Address Lines} \\
\hline & & & A4 & A3 & A2 & A1 & A0 \\
\hline \multicolumn{8}{|c|}{0} \\
\hline Receiver Status Register (RSR) & R/W & 00 & 0 & 0 & 0 & 0 & 0 \\
\hline Receiver Control Register (RCR) & R/W & 01 & 0 & 0 & 0 & 0 & 1 \\
\hline Receiver Data Register (RDR)-8 bits \({ }^{1}\) & R & 02 & 0 & 0 & 0 & 1 & 0 \\
\hline Reserved \({ }^{3}\) & & 03 & 0 & 0 & 0 & 1 & 1 \\
\hline Receiver Interrupt Vector Number Register (RIVNR) & R/W & 04 & 0 & 0 & 1 & 0 & 0 \\
\hline Receiver Interrupt Enable Register (RIER) & R/W & 05 & 0 & 0 & 1 & 0 & 1 \\
\hline
\end{tabular}
\begin{tabular}{|l|c|c|ccc|}
\hline Transmitter Status Register (TSR) & R/W & 08 & 0 & 1 & 0 \\
\hline Transmitter Control Register (TCR) & R/W & 09 & 0 & 1 & 0 \\
\hline Transmitter Data Register (TDR) & 0 & 0 & 1 \\
\hline Reserved \(^{3}\) & Wits & & \(0 A\) & 0 & 1 \\
\hline Transmitter Interrupt Vector Number Register (TIVNR) & R/W & 0 & 1 \\
\hline Transmitter Interrupt Enable Register (TIER) & OB & 0 & 1 & 0 & 1 \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|ccc|}
\hline Serial Interface Status Register (SISR) & R/W & 10 & 1 & 0 & 0 \\
\hline Serial Interface Control Register (SICR) & R/W & 11 & 0 & 0 & 0 \\
\hline Reserved \(^{3}\) & & 0 & 1 \\
\hline Reserved \(^{3}\) & & 12 & 1 & 0 & 0 \\
\hline Serial Interrupt Vector Number Register (SIVNR) & 13 & 1 & 0 & 0 & 1 \\
\hline Serial Interrupt Enable Register (SIER) & R/W & 14 & 1 & 0 & 1 \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline Protocol Select Register 1 (PSR1) & R/W & 18 & 1 & 1 & 0 & 0 & 0 \\
\hline Protocol Select Register 2 (PSR2) & R/W & 19 & 1 & 1 & 0 & 0 & 1 \\
\hline Address Register 1 (AR1) & R/W & 1A & 1 & 1 & 0 & 1 & 0 \\
\hline Address Register 2 (AR2) & R/W & 1B & 1 & 1 & 0 & 1 & 1 \\
\hline Baud Rate Divider Register 1 (BRDR1) & R/W & 1 C & 1 & 1 & 1 & 0 & 0 \\
\hline Baud Rate Divider Register 2 (BRDR2) & R/W & 1D & 1 & 1 & 1 & 0 & 1 \\
\hline Clock Control Register (CCR) & R/W & 1 E & 1 & 1 & 1 & 1 & 0 \\
\hline Error Control Register (ECR) & R/W & 1F & 1 & 1 & 1 & 1 & 1 \\
\hline
\end{tabular}

\section*{Notes:}
1. Accessible register of the eight byte RxFIFO. The data is not initialized, however, \(\overline{\text { RES }}\) resets the RxFIFO pointer to the start of the first byte.
2. Accessible register of the eight byte TXFIFO. The data is not initialized, however, \(\overline{\operatorname{RES}}\) resets the TxFIFO pointer to the start of the first byte.
3. Reserved registers may contain random bit values.

Table 2. MPCC Register Bit Assignments
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { R/W } \\
& \text { Access }
\end{aligned}
\]} & \multicolumn{8}{|c|}{Bit Number} & \multirow[t]{2}{*}{Reset \({ }^{(1)}\) Value} & \multirow[b]{3}{*}{Receiver Status Register (RSR)} \\
\hline & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 & & \\
\hline R/W & RDA & EOF & 0 & C/PERR & FRERR & ROVRN & RA/B & RIDLE & 00 & \\
\hline R/W & 0 & RDSREN & DONEEN & RSYNEN & STRSYN & 0 & RABTEN & RRES & 01 & Receiver Control Register (RCR) \\
\hline \(R\) & & & & EIVER & TA (RxFIF & & & & - - & Receiver Data Register (RDR) \\
\hline R/W & & & EIVER IN & ERRUPT & ECTOR N & MBER (RIV & & & OF & Receiver Interrupt Vector Number Register (RIVNR) \\
\hline R/W & \[
\begin{gathered}
\text { RDA } \\
\text { IE }
\end{gathered}
\] & \[
\begin{gathered}
\mathrm{EOF} \\
\mathrm{IE}
\end{gathered}
\] & 0 & C/PERR IE & FRERR IE & ROVRN IE & RA/B IE & 0 & 00 & Receiver Interrupt Enable Register (RIER) \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline R/W & TDRA & TFC & 0 & 0 & 0 & TUNRN & TFERR & 0 & 80 & Transmitter Status Register (TSR) \\
\hline R/W & TEN & TDSREN & TICS & THW & TLAST & TSYN & TABT & TRES & 01 & Transmitter Control Register (TCR) \\
\hline W & \multicolumn{8}{|c|}{TRANSMITTER DATA (TxFIFO) \({ }^{2}\)} & - - & Transmitter Data Register (TDR) \\
\hline R/W & \multicolumn{8}{|c|}{TRANSMITTER INTERRUPT VECTOR NUMBER (TIVN)} & OF & Transmitter Interrupt Vector Number Register (TIVNR) \\
\hline R/W & TDRA IE & \[
\begin{gathered}
\text { TFC } \\
\text { IE } \\
\hline
\end{gathered}
\] & 0 & 0 & 0 & TUNRN IE & TFERR IE & 0 & 00 & Transmitter Interrupt Enable Register (TIER) \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline R/W & CTST & DSRT & DCDT & CTSLVL & DSRLVL & DCDLVL & 0 & 0 & 00 \\
\hline R/W & RTSLVL & DTRLVL & 0 & 0 & 0 & ECHO & TEST & 0 & 00 \\
\hline & \multicolumn{8}{|c|}{\begin{tabular}{l} 
Serial Interface Status \\
Register (SISR) \\
Serial Interface Control \\
Register (SICR)
\end{tabular}} \\
(reserved)
\end{tabular}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline R/W & 0 & 0 & 0 & 0 & 0 & 0 & CTLEX & ADDEX & 00 & \begin{tabular}{l}
Protocol Select \\
Register 1 (PSR11)
\end{tabular} \\
\hline \multirow[b]{2}{*}{R/W} & \multirow[b]{2}{*}{WD/BYT} & \multicolumn{2}{|l|}{STOP BIT SEL} & \multicolumn{2}{|l|}{CHAR LEN SEL} & \multicolumn{3}{|c|}{PROTOCOL SEL} & \multirow[b]{2}{*}{00} & \multirow[t]{2}{*}{Protocol Select Register 2 (PSR2)} \\
\hline & & SB2 & SB1 & CL2 & CL1 & PS3 & PS2 & PS1 & & \\
\hline R/W & \multicolumn{8}{|c|}{BOP ADDRESS/BSC \& COP PAD} & 00 & Address Register 1 (AR1) \\
\hline R/W & \multicolumn{8}{|c|}{BOP ADDRESS/BSC \& COP SYN} & 00 & Address Register 2 (AR2) \\
\hline R/W & \multicolumn{8}{|c|}{BAUD RATE DIVIDER (LSH)} & 01 & Baud Rate Divider Register 1 (BRDR1) \\
\hline R/W & \multicolumn{8}{|c|}{BAUD RATE DIVIDER (MSH)} & 00 & Baud Rate Divider Register 2 (BRDR2) \\
\hline \multirow[b]{2}{*}{R/W} & \multirow[b]{2}{*}{0} & \multirow[b]{2}{*}{0} & \multirow[b]{2}{*}{0} & \multirow[b]{2}{*}{PSCDIV} & \multirow[b]{2}{*}{TCLKO} & \multirow[b]{2}{*}{RCLKIN} & \multicolumn{2}{|c|}{CLK DIV} & \multirow[b]{2}{*}{00} & \multirow[t]{2}{*}{Clock Control Register (CCR)} \\
\hline & & & & & & & CK2 & CK1 & & \\
\hline \multirow[b]{2}{*}{R/W} & \multirow[b]{2}{*}{PAREN} & \multirow[b]{2}{*}{ODDPAR} & \multirow[t]{2}{*}{0} & \multirow[t]{2}{*}{0} & \multirow[b]{2}{*}{CFCRC} & \multirow[b]{2}{*}{CRCPRE} & \multicolumn{2}{|c|}{CRC SEL} & \multirow[b]{2}{*}{04} & \multirow[t]{2}{*}{\begin{tabular}{l}
Error Control \\
Register (ECR)
\end{tabular}} \\
\hline & & & & & & & CR2 & CR1 & & \\
\hline
\end{tabular}

\section*{Notes:}
1. RESET \(=\) Register contents upon power up or RESET.
2. 16-bits for R68561 (word mode); 8-bits for R68560 (byte mode).

\section*{REGISTER DEFINITIONS}

\section*{RECEIVER REGISTERS}

Receiver Status Register (RSR)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline RDA & EOF & 0 & C/PERR & FRERR & ROVRN & RA/B & RIDLE \\
\hline
\end{tabular}

Address \(=00\)
Reset Value \(=\$ 00\)
The Receiver Status Register (RSR) contains the status of the receiver including error conditions. Status bits are cleared by writing a 1 into respective positions, by writing a 1 into the RCR RRES bit or by RESET. If an EOF, C/PERR, or FRERR is set in the RSR, the data reflecting the error (the next byte or word in the RxFIFO) must be read prior to resetting the corresponding status bit in the RSR. The \(\overline{\mathrm{RQ}}\) output is asserted if any of the conditions reported by the status bits occur and the corresponding interrupt enable bit in the RIER is set.

The RSR format is the same as the frame status format (see below) except as noted.

\section*{RSR}

RDA -Receiver Data Available. (RSR only).
The FxFIFO is empty (i.e., no received data is available).
1 RDA is set and an interrupt issued (if enabled) when the RxFIFO has 1 to 8 bytes, or 1 to 4 words, of data in it.

RDA Reset - RDA cannot be cleared or reset in software. It is initialized to 0 upon hardware reset and remains 0 if no data has been received. It is set to a 1 and an interrupt issued when a data byte/word is loaded to the RxFIFO with the negative edge of RxC coincident with the first bit of the next byte transmitted. It is automatically reset to 0 when the last byte/word is read from the RxFIFO by the host through RDR.

\section*{RSR}
\(\begin{array}{ll}6 \\ 0 & \text { EOF } \\ \text { No end of frame has been detected. }\end{array}\)
1 The closing flag (BOP) or pad (BSC) has been detected. EOF is loaded in the RxFIFO along with the FSB with which it is associated. The EOF is loaded into the RSR and the interrupt issued, if enabled, (when the RxFIFO read pointer is positioned at the FSB) with the trailing edge of \(\overline{\text { LDS }}\).
EOF Reset - The byte/word containing the FSB must be read from the RxFIFO before resetting the EOF bit. Then EOF may be reset by writing a 1 to RSR6.

\section*{RSR}

RHW -Receive Half Word. (Frame Status only) \({ }^{*}\) The last word of the frame contains data on the upper half (D8-D15) and frame status on the lower half (D0-D7) of the data bus.
1 The lower half of the data bus (D0-D7) contains the frame status but the upper half (D8-D15) is blank or invalid.
*See Frame Status (RSR) on next page.

\section*{RSR}

4 C/PERR -CRC/Parity Error. No CRC or parity error detected.
1 CRC error detected (BOP, BSC) or parity error detected (ASYNC, ISOC and COP). The C/PERR bit is loaded into the RxFIFO with the negative-going RxC edge, along with the byte or word with which it is associated. For ASYNC, ISOCH or COP protocols, this is with the byte/word containing a parity error. For BOP or BSC, it is loaded to RxFIFO (after the CRC check) with the FSB. C/PERR is loaded into the RSR and the interrupt issued (when the read pointer is positioned at the FSB) with the trailing edge of LDS.

C/PERR Reset - The byte/word containing the FSB must be read from the RxFIFO before resetting the C/PERR bit. Then it may be reset by writing a 1 to RSR4.

\section*{RSR}

3 FRERR -Frame Error.
No frame error detected.
1 FRERR is set for receiver overrun, flag detected off boundary (BOP), or frame error (ASYNC, ISOCH). For receiver overrun, the FRERR bit is set in the RxFIFO with the last byte when the overrun is detected.

For BOP, a minimum message size is an opening flag, one address byte and one control byte. If the closing flag is detected before the control byte is sent, a short frame is indicated and a frame error results. For address extension, multi-address bytes may be received before the control byte is expected. The FRERR bit is latched in RxFIFO with the negative-going edge of \(R \times C\) with the last address byte received upon detection of the flag off boundary. FRERR is loaded into the RSR and the interrupt issued when the read pointer is positioned at the FSB with the trailing edge of LDS.

In ASYNC or ISOCH, a FRERR bit set indicates that the stop bit was detected off boundary (too early or too late for the number of bits expected by the setting of PSR2-3 and PSR2-4) or it was not the correct width (as expected by the setting of PSR2-6 and PSR2-5).

FRERR Reset - The byte/word containing the FSB must be read from the RxFIFO before resetting the C/PERR bit. The C/PERR bit may then be reset by writing a 1 to RSR3.

\section*{RSR}

2 ROVRN -Receiver Overrun.
No receiver overrun detected.
1 Receiver overrun detected. Data is loaded into the RxFIFO on byte boundaries with the negative-going edge of RxC coincident with the first bit of the subsequent data being received. When the eighth byte, or fourth word, of data has been written into RxFIFO without any data being read out, the RxFIFO is full and the incremented write pointer "catches up" with the read pointer. The next attempt to write data to RxFIFO causes ROVRN bit to be loaded to the RSR and the interrupt issued (if enabled). The data in the RxFIFO is not affected, but new received data is lost.

ROVRN Reset - The ROVRN bit is not self-clearing when data is read from the RxFIFO, but may be reset by writing a 1 to RSR2.

RSR
\(\begin{array}{ll}1 & \text { RA/B } \\ 0 & \text { Normal Operaiver Abort/Break. }\end{array}\)
1 (BOP) When an ABORT (seven 1s) is detected after the opening flag, the RA/B bit is set in the RSR and an interrupt issued (if enabled). This bit is latched with the negative edge of RxC after the seventh 1 bit is detected. (NOTE: Because the previous byte can end in zero to five 1 bits, the abort could be recognized in the next byte as early as two to seven 1 bits.)
(BSC) When ENQ is detected in a block of text data, the RA/B bit is set in the RSR and the interrupt issued (if enabled) with the next negative edge of the RxC clock.

RA/B Reset - The RA/B bit is reset by writing a 1 to RSR1.

RSR
0 RIDLE -Receiver Idle. (BOP only). Receiver is not idle.
15 or more 1s have been detected. The RIDLE bit is set in RSR with the negative edge of the next RxC after 15 consecutive is have been detected.

RIDLE Reset - The RIDLE is reset by writing a 1 to RSRo. (NOTE: The RIDLE bit will set again in 15 clock cycles if RxD is still in the idle condition.)
*Frame Status (RSR)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline 0 & EOF & RHW & C/PERR & FRERR & ROVRN & RA \(/ B\) & 0 \\
\hline
\end{tabular}

For the BSC and BOP protocols which have defined message blocks or frames, a "frame status" byte will be loaded into the RXFIFO following the last data byte of each block. The frame status contains all the status contained within the RSR with the exception of RDA and RIDLE. But, in addition to the RSR con-
tents, the frame status byte has a RHW status in bit 5 which indicates either an even or odd boundary (applicable to word mode only).

If the MPCC is in word mode and the last data byte was on an even byte boundary (i.e., there was an even number of bytes in the message), a blank byte will be loaded into the RxFIFO prior to loading the frame status byte in order to force the "frame status" byte and the next frame to be on an even boundary. When RHW = 0 , the last word of the frame contains data on the upper half and status on the lower half of the data bus. If RHW = 1, the lower half of the bus contains status but the upper half is a blank or invalid byte.

In the byte mode, the status byte will always immediately follow the last data byte of the block/frame (see Figure 3). The EOF status in the RSR is then set when the byte/word containing the frame status is the next byte/word to be read from the RxFIFO.
In the receiver DMA mode, when the EOF status in the RSR is set, DONE is asserted to the DMAC. Thus the last byte accessed by the DMAC is always a status byte, which the processor may read to check the validity of entire frame.

\section*{Receiver Control Register (RCR)}
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline- & RDSREN & DONEEN & RSYNEN & STRSYN & 0 & RABEN & RRES \\
\hline
\end{tabular}

Address \(=01\)
Reset value \(=\$ 01\)
The Receiver Control Register (RCR) selects receiver control options.

RCR

ODD NUMBER OF BYTES
byte
MODE
\begin{tabular}{|c|c|}
\hline BYTE & D7 \\
\hline M & DATA \\
\hline \(\mathrm{M}+1\) & STATUS \\
\hline \(M+2\) & NEXT FRAME \\
\hline
\end{tabular}

\section*{EVEN NUMBER OF BYTES}
WORD
\begin{tabular}{|c|l|l|}
\hline \multicolumn{1}{l}{ D15 } & D8 \(\mathbf{D 7}\) & D0 \\
\hline \(\mathbf{N}\) & DATA & DATA \\
\hline \(\mathbf{N}+1\) & BLANK & STATUS \\
\hline \(\mathbf{N}+2\) & NEXT & FRAME \\
\hline
\end{tabular}
(RHW = 1)
\begin{tabular}{c|l|}
\multicolumn{1}{l}{ BYTE } & \multicolumn{1}{l}{ D7 } \\
\begin{tabular}{|c|l|}
\hline\(M\) & DATA \\
\hline\(M+1\) & STATUS \\
\hline\(M+2\) & NEXT FRAME \\
\hline
\end{tabular}
\end{tabular}

Figure 3. BSC/BOP Block/Frame Status Location

\section*{RCR}

RCR
    4 RSYNEN -RSYNEN Output Enable. Selects the
                        DSR signal input or the RSYN SYNC
                signal output on the \(\overline{D S R}\) pin.
    Input DSR on DSR.
    Output RSYN on \(\overline{\text { DSR }}\).
RCR
3 STRSYN -Strip SYN Character (COP only).
    Do not strip SYN character.
    Strip SYN character.
RCR
    MUST BE ZERO
RCR
1 RABTEN -Receiver Abort Enable (BOP only).
    Do not abort frame upon error detection.
    Abort frame upon RxFIFO overrun (ROVRN bit \(=1\) in
    the RSR) or CFCRC error detection (C/PERR bit \(=1\)
    in the RSR). If either error occurs, the MPCC ignores
    the remainder of the current frame and searches for
    the beginning of the next frame. (EOF is set upon
    abort).
\begin{tabular}{c} 
RCR \\
0 \\
\hline 0 \\
1
\end{tabular}

RRES -Receiver Reset Command. Enable normal receiver operation.
Reset receiver. Resets the receiver section including the RxFIFO and the RSR (but not the RCR). RRES is set by RESET or by writing a 1 into this bit and must be cleared by writing a 0 into this bit. RRES requires clearing after RESET.

Receiver Data Register (RDR)
R68561 (Word Mode)


Address \(=02\)

R68560 (Byte Mode)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multicolumn{2}{|c|}{MSB} & \multicolumn{4}{|c|}{Byte 0} & \multicolumn{2}{|c|}{LSB} \\
\hline
\end{tabular}

Address \(=02\)
The receiver has an 8 -byte (or 4-word) First In First Out (FIFO) register file (RxFIFO) where received data are stored before being transferred to the bus. The received data is transferred out of the RxFIFO via the RDR in 8 -bit bytes or 16 -bit words depending on the WD/BYT bit setting in PSR2. When the RxFIFO has a data byte/word ready to be transferred, the RDA status bit in the RSR is set to 1 .

Receiver Interrupt Vector Number Register (RIVNR)
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline \multicolumn{6}{|c|}{ Receiver Interrupt Vector Number (RIVN) } \\
\hline
\end{tabular}

Address \(=04\)
Reset value \(=\$ 0 \mathrm{~F}\)
If a receiver interrupt condition occurs (as reported by status bits in the RSR that correspond to interrupt enable bits in the RIER) and the corresponding bit is set in the RIER, IRQ output is asserted to request MPU receiver interrupt service. When the IACK input is asserted from the bus, the Receiver Interrupt Vector Number (RIVN) from the Receiver Interrupt Vector Number Register (RIVNR) is placed on the data bus.

Receiver Interrupt Enable Register (RIER)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline \begin{tabular}{c} 
RDA \\
IE
\end{tabular} & \begin{tabular}{c} 
EOF \\
IE
\end{tabular} & \(\mathbf{0}\) & \begin{tabular}{c}
\(\mathrm{C} /\) PERR \\
IE
\end{tabular} & \begin{tabular}{c} 
FRERR \\
IE
\end{tabular} & \begin{tabular}{c} 
ROVRN \\
IE
\end{tabular} & \begin{tabular}{c} 
RA/B \\
IE
\end{tabular} & \(\mathbf{0}\) \\
\hline
\end{tabular}

Address \(=05\)
Reset value \(=\$ 00\)
The Receiver Interrupt Enable Register (RIER) contains interrupt enable bits for the Receiver Status Register (RSR). When enabled, the \(\overline{\mathrm{RQ}}\) output is asserted when the corresponding condition is detected and reported in the RSR.
\begin{tabular}{|c|c|}
\hline RIER & \\
\hline 7 & \multirow[t]{2}{*}{RDA IE \(\quad \begin{aligned} & \text { Receiver Data Available Interrupt } \\ & \text { Enable. }\end{aligned}\)} \\
\hline & \\
\hline 0 & Disable RDA Interrupt. \\
\hline 1 & Enable RDA Interrupt. \\
\hline RIER & \\
\hline 6 & EOF IE -End of Frame Interrupt Enable. \\
\hline 0 & Disable EOF Interrupt. \\
\hline 1 & Enable EOF Interrupt. \\
\hline RIER & \multirow[b]{2}{*}{-Not used.} \\
\hline 5 & \\
\hline RIER & \\
\hline 4 & C/PERR IE -CRC/Parity Error Interrupt Enable. \\
\hline 0 & Disable C/PERR Interrupt. \\
\hline 1 & Enable C/PERR Interrupt. \\
\hline RIER & \\
\hline 3 & FRERR IE -Frame Error Interrupt Enable. \\
\hline 0 & Disable FRERR Interrupt. \\
\hline 1 & Enable FRERR Interrupt. \\
\hline RIER & \\
\hline 2 & ROVRN IE -Receiver Overrun Interrupt Enable. \\
\hline 0 & Disable ROVRN Interrupt. \\
\hline 1 & Enable ROVRN Interrupt. \\
\hline RIER & \\
\hline 1 & RA/B IE -Receiver Abort/Break Interrupt Enable. \\
\hline 0 & Disable RA/B Interrupt. \\
\hline 1 & Enable RA/B Interrupt. \\
\hline RIER & \\
\hline 0 & -Not used. \\
\hline
\end{tabular}

\section*{TRANSMITTER REGISTERS}

Transmitter Status Register (TSR)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline TDRA & TFC & \(\mathbf{0}\) & 0 & 0 & TUNRN & TFERR & \(\mathbf{0}\) \\
\hline
\end{tabular}

Address \(=08\)
Reset value \(=\$ 80\)
The Transmitter Status Register (TSR) contains the transmitter status including error conditions. The transmitter status bits are cleared by writing a 1 into their respective positions, by writing a 1 into the TCR TRES bit, or by \(\overline{\operatorname{RESET}}\). The \(\overline{\mathrm{RQ}}\) output is asserted if any of the conditions reported by the status bits occur and the corresponding interrupt enable bit in the TIER is set.

\section*{TSR}

7 TDRA -Transmitter Data Register Available. The TxFIFO is full.
1 The TxFIFO is available to be loaded via the TDR ( 1 to 8 bytes, or 1 to 4 words).

TDRA Reset - TDRA cannot be reset by the host in normal operation. It initializes to a 1 upon hardware or software reset of the MPCC. TDRA is not dependent on the serial clock.

\section*{TSR}

6 TFC -Transmitted Frame Complete. (BOP, BSC and COP only).
0 (All) Frame not complete.
1 (BOP) Closing flag or ABORT has been transmitted. The TFC bit is set and the interrupt issued (if enabled) with the negative edge of TxC coincident with the end of the last bit of the flag. When TABT is set in TCR1, an ABORT is transmitted immediately but TFC is not issued until after the closing flag or 8 bits of the MARK idle condition after the TXFIFO is flushed of all current data bytes.
(BSC) Trailing pad has been transmitted. TFC bit set and/or interrupt issued with negative edge of TxC coincident with the end of the last bit of the trailing pad.
(COP) Last byte has been transmitted (TLAST set in TCR3). TFC bit set and/or interrupt issued with negative edge of the TxC coincident with the end of the last bit of the last byte.
TFC Reset - One full cycle of the serial clock ( TxC ) must elapse before the TFC bit can be reset by writing a 1 to TSR6.

\section*{TSR}

5-3
-Not used.
TSR
2 TUNRN -Transmitter Underrun (BOP, BSC and COP only).
0 No TxFIFO underrun has occurred.
1 An empty TxFIFO was accessed for data. (BOP) Underrun is treated as an ABORT in that eight consecutive is are transmitted followed by the idle condition of MARK or FLAG.
(BSC, COP) Underrun causes SYN characters to be transmitted until new data is available in the TxFIFO.

The TUNRN bit is set in TSR2 and the interrupt issued with the positive edge of the TXC coincident with the eighth bit of data prior to the ABORT in BOP or to SYN in BSC or COP.

TUNRN Reset - One full cycle of the serial clock (TxC) must elapse before the TUNRN bit can be reset by writing a 1 to TSR2.

TFERR -Transmit Frame Error (BOP only). No frame error has occurred.
A short frame condition exists in that no control field is transmitted. (TLAST was issued early with an address byte.) TFERR bit is set and the interrupt issued with the positive edge of TxC coincident with the end of the last bit of the byte causing the error.

TFERR Reset - One full cycle of the serial clock (TxC) must elapse before TFERR bit can be reset by writing a 1 to TSR1.

Transmitter Control Register (TCR)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline TEN & TDSREN & TICS & THW & TLAST & TSYN & TABT & TRES \\
\hline
\end{tabular}

Address \(=09\)
Reset value \(=\$ 01\)
The Transmitter Control Register (TCR) selects transmitter control function.

\section*{TCR}
\begin{tabular}{ll}
7 & TEN \(\quad\) Transmitter Enable. \\
\cline { 1 - 3 }\(n\) & Disable transmitter. TxD output is idled. The TxFIFO \\
may be loaded while the transmitter is disabled.
\end{tabular} Enable transmitter.

\section*{TCR}
\(\square\) TDSREN -Transmitter Data Service Request Enable.
0 Disable transmitter DMA mode.
1 Enable transmitter DMA mode.

\section*{TCR}

5 TICS -Transmitter Idle Character Select. Selects the idle character to be transmitted when the transmitter is in an active idle mode (transmitter enabled or disabled). Mark Idle (TxD output is held high).
1 Content of AR2 (BSC and COP), BREAK condition (ASYNC and ISOC), or FLAG character (BOP).

\section*{TCR}

4 THW -Transmit Half Word. (R68561, word mode only). This bit is used when the frame or block ends on an odd boundary in conjunction with the TLAST bit and indicates that the last word in the TxFIFO contains valid data in the upper byte only. This bit must always be 0 in byte mode (R68560).
0 Transmit full word (16 bits) from the TxFIFO.
1 Transmit upper byte ( 8 bits) from the TxFIFO.

\section*{TCR}

3 TLAST -Transmit Last Character (BOP, BSC and COP only).
0 The next character is not the last character in a frame or block.
1 The next character to be written into the TDR is the last character of the message. The TLAST bit automatically returns to a 0 when the associated word/byte is written to the TxFIFO. If the transmitter DMA mode is enabled, TLAST is set to a 1 by DONE from the DMAC. In this case the character written into the TDR in the current cycle is the last character.

TCR
\(\frac{2}{0}\) TSYN -Transmit SYN (BSC and COP only). Do not transmit SYN characters.
Transmit SYN characters. Causes a pair of SYN characters to be transmitted immediately following the current character. If BSC transparent mode is active, a DLE SYN sequence is transmitted. The TSYN bit automatically returns to a 0 when the SYN character is loaded into the Transmitter Shift Register.

\section*{TCR}

\section*{\(\frac{1}{0}\) TABT -Transmit ABORT (BOP only). \\ Enable normal transmitter operation.}

1 Causes an abort by sending eight consecutive 1's. A data word/byte must be loaded into the TxFIFO after setting this bit in order to complete the command. The TABT bit clears automatically when the subsequent data word/byte is loaded into the TxFIFO.

TCR


TRES -Transmitter Reset Command. Enable normal transmitter operation.
Reset transmitter. Clears the transmitter section including the TxFIFO and the TSR (but not the TCR). The TxD output is held in 'Mark' condition. TRES is set by \(\overline{\text { RESET }}\) or by writing a 1 into this bit and is cleared by writing a 0 into this bit. TRES requires clearing after RESET.

Transmit Data Register (TDR)


Address \(=0 A\)

R68560 (Byte Mode)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multicolumn{2}{|c|}{MSB} & \multicolumn{4}{|c|}{Byte 0} & \multicolumn{2}{|c|}{LSB} \\
\hline
\end{tabular}

Address \(=0 \mathrm{~A}\)
The transmitter has an 8-byte (or 4-word) FIFO register file (TxFIFO). Data to be transmitted is transferred from the bus into the TxFIFO via the TDR in 8 -bit bytes or 16 -bit words depending on the WD/BYT bit setting in PSR2. The TDRA status bit in the TSR is set to 1 when the TxFIFO is ready to accept another data word/byte.

Transmitter Interrupt Vector Number Register (TIVNR)
\begin{tabular}{|l|l|c|c|c|c|c|c|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline \multicolumn{6}{|c|}{ Transmitter Interrupt Vector Number (TIVN) } \\
\hline
\end{tabular}

Address \(=0 \mathrm{C}\)
Reset value \(=\$ 0 F\)
If a transmitter interrupt condition occurs (as reported by status bits in the TSR that correspond to interrupt enable bits in the TIER) and the corresponding bit in the TIER is set, the \(\overline{\mathrm{RQ}}\) output is asserted to request MPU transmitter interrupt service. When the \(\overline{\text { IACK }}\) input is asserted from the bus, the Transmitter Interrupt Vector Number (TIVN) from the Transmitter Interrupt Vector Number Register (TIVNR) is placed on the data bus.

Transmitter Interrupt Enable Register (TIER)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline \begin{tabular}{c} 
TDRA \\
IE
\end{tabular} & \begin{tabular}{c} 
TFC \\
IE
\end{tabular} & \(\mathbf{0}\) & \(\mathbf{0}\) & \(\mathbf{0}\) & \begin{tabular}{c} 
TUNRN \\
IE
\end{tabular} & \begin{tabular}{c} 
TFERR \\
IE
\end{tabular} & \(\mathbf{-}\) \\
\hline
\end{tabular}

Address \(=0 D\)
Reset value \(=\$ 00\)
The Transmitter Interrupt Enable Register (TIER) contains interrupt enable bits for the Transmitter Status Register. When enabled, the \(\overline{\mathrm{IRQ}}\) output is asserted when the corresponding condition is detected and reported in the TSR.

TIER
7 TDRA IE -Transmitter Data Register (TDR) Available Interrupt Enable.
0 Disable TDRA Interrupt.
1 Enable TDRA Interrupt.
TIER
6 TFC IE -Transmit Frame Complete (TFC) Interrupt Enable.
0
Disable TFC Interrupt.
1 Enable TFC Interrupt.
TIER
5-3 -Not used.
TIER
2
TUNRN IE —Transmitter Underrun (TUNRN) Interrupt Enable.
Disable TUNRN Interrupt.
Enable TUNRN Interrupt.
TIER
\(\qquad\) TFERR IE —Transmit Frame Error (TFERR) Interrupt Enable.
0
Disable TFERR Interrupt.
Enable TFERR Interrupt.
TIER
0 -Not used.

\section*{SERIAL INTERFACE REGISTERS}

Serial Interface Status Register (SISR)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline CTST & DSRT & DCDT & CTSLVL & DSRLVL & DCDLVL & \(\mathbf{0}\) & \(\mathbf{0}\) \\
\hline
\end{tabular}

Address \(=10\)
Reset value \(=\$ 00\)

The Serial Interface Status Register (SISR) contains the serial interface status information. The transition status bits (CTST, DSRT and DCDT) are cleared by writing a 1 into their respective positions, or by RESET. The level status bits (CTSLVL, DSRLVL and DCDLVL) reflect the state of their respective inputs and cannot be cleared internally. The \(\overline{\mathrm{IRQ}}\) output is asserted if any of the conditions reported by the transition status bits occur and the corresponding interrupt enable bit in the SIER is set.

\section*{SISR}

7 CTST -Clear to Send Transition Status.
The input on \(\overline{\mathrm{CTS}}\) has not transitioned positive.
1 The input on \(\overline{\mathrm{CTS}}\) has transitioned positive from active to inactive. To detect this transition, \(\overline{R T S}\) must be active (low) and the transmitter must be enabled (TRES in TCR0 \(=0\) ). The CTST bit is set in SISR7 and an interrupt issued (if enabled) with the negative edge of TxC.

CTST Reset - A negative transition of the serial clock (TxC) must occur after the \(\overline{\mathrm{CTS}}\) input goes high before the CTST bit can be reset by writing a 1 to SISR7.

\section*{SISR}
\(\frac{6}{0}\)

DSRT -Data Set Ready Transition Status.
1 The input on \(\overline{\mathrm{DSR}}\) has not transitioned negative.
1 The input on \(\overline{D S R}\) has transitioned negative from inactive to active. The DSRT bit is set in SISR7 and an interrupt issued (if enabled) with the negative edge of RxC. The receiver must be enabled (RRES in \(R C R 0=0\) ).
DSRT Reset - A negative transition of the serial clock (RxC) must occur after the \(\overline{\mathrm{DSR}}\) input goes high before the DSRT bit can be reset by writing a 1 to SISR6.

\section*{SISR}

5 DCDT -Data Carrier Detect Transition Status.
0 The input on \(\overline{D C D}\) has not transitioned positive.
1 The input on \(\overline{D C D}\) has transitioned positive from active to inactive. The DCDT bit is set in SISR5 and an interrupt issued (if enabled) with the negative edge of \(R \times C\). The receiver must be enabled (RRES in RCRO \(=0\) ).

DCDT Reset - A negative transition of the serial clock (RxC) must occur after the \(\overline{\mathrm{DCD}}\) input goes high before the DCDT bit can be reset by writing a 1 to SISR5.

\section*{SISR}
\begin{tabular}{l}
4 \\
\hline 0
\end{tabular}

CTSLVL - Clear to Send Level. The input on \(\overline{\mathrm{CTS}}\) is negated (high, inactive). The input on \(\overline{\mathrm{CTS}}\) is asserted (low, active).

CRSLVL Reset - The CTSLVL bit in SISR4 follows the state of the input to \(\overline{\mathrm{CTS}}\) and cannot be reset internally.

\section*{SISR}
\(\frac{3}{0}\)
DSRLVL -Data Set Ready Level. The input on \(\overline{D S R}\) is negated (high, inactive). The input on \(\overline{\mathrm{DSR}}\) is asserted (low, active).
DSRLVL Reset - The DSRLVL bit in SISR3 follows the state of the input to \(\overline{\mathrm{DSR}}\) and cannot be reset internally.

SISR
2 DCDLVL -Data Carrier Detect Level. The input on \(\overline{D C D}\) is negated (high, inactive).
1 The input on \(\overline{D C D}\) is asserted (low, active).
DCDLVL. Reset - The DCDLVL bit in SISR2 follows the state of the input to \(\overline{\mathrm{DCD}}\) and cannot be reset internally.

SISR
1-0 -Not used.
Serial Interface Control Register (SICR)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline RTSLVL & DTRLVL & \(\mathbf{0}\) & \(\mathbf{0}\) & \(\mathbf{0}\) & ECHO & TEST & \(\mathbf{0}\) \\
\hline
\end{tabular}

Address \(=11\)
Reset value \(=\$ 00\)
The Serial Interface Control Register (SICR) controls various serial interface signals and test functions.

SICR
7
RTSLVL -Request to Send Level.
Negate \(\overline{R T S}\) output (high).
Assert \(\overline{\mathrm{RTS}}\) output (low).

\section*{NOTE}

In BOP, BSC, or COP, when the RTSLVL bit is cleared in the middle of data transmission, the \(\overline{\text { RTS }}\) outputremains asserted until the end of the current frame or block has been transmitted. In ASYNC or ISOC, the \(\overline{\mathrm{RTS}}\) output is negated when the TxFIFO is empty. If the transmitter is idling when the RTSLVL bit is reset, the \(\overline{R T S}\) output is negated within two bit times.

SICR
DTRLVL —Data Terminal Ready Level.
Negate \(\overline{\text { DTR }}\) output (high).
Assert DTR output (low).
SICR
5-3 -Not used. These bits are initialized to 0 by \(\overline{\text { RESET }}\) and must not be set to 1 .

SICR
2 ECHO —Echo Mode Enable.
Disable Echo mode (enable normal operation).
1 Enable Echo mode. Received data (RxD) is routed back through the transmitter to TxD. The contents of the TxFIFO is undisturbed. This mode may be used for remote test purposes.

SICR
\(\frac{1}{0}\)
TEST -Self-test Enable.
Disable self-test (enable normal operation). Enable self-test. The transmitted data (TxD) and clock (TxC) are routed back through to the receiver through RxD and RxC, respectively ( \(\overline{D C D}\) and \(\overline{C T S}\) are ignored). This "loopback" self-test may be used for all protocols. RxC is external and CCR bits 2 and 3 must be a 1.

\author{
SICR \\ \(\frac{0}{0}\) MUST BE ZERO
}

Serial Interrupt Vector Number Register (SIVNR)
\begin{tabular}{|l|l|c|c|c|c|c|c|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline \multicolumn{6}{|c|}{ Serial Interrupt Vector Number (SIVN) } \\
\hline
\end{tabular}

Address \(=14\)
Reset value \(=\$ 0 \mathrm{~F}\)

If a serial interface interrupt condition occurs (as reported by status bits in the SISR that correspond to interrupt enable bits in the SIER) and the corresponding bit in the SIER is set, the \(\overline{\text { IRQ output is asserted to request MPU serial interface interrupt }}\) service. When the \(\overline{\mathrm{IACK}}\) input is asserted from the bus, the Serial Interrupt Vector Number (SIVN) from the Serial Interrupt Vector Number Register (SIVNR) is placed on the data bus.

Serial Interrupt Enable Register (SIER)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & 2 & \(\mathbf{1}\) & 0 \\
\hline \begin{tabular}{c} 
CTS \\
IE
\end{tabular} & \begin{tabular}{c} 
DSR \\
IE
\end{tabular} & \begin{tabular}{c} 
DCD \\
IE
\end{tabular} & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

Address \(=15\)
Reset value \(=\$ 00\)

The Serial Interrupt Enable Register (SIER) contains interrupt enable bits for the Serial Interface Status Register. When an interrupt enable bit is set, the IRQ output is asserted when the corresponding condition occurs as reported in the SISR.


SIER
4-0 -Not used.

\section*{GLOBAL REGISTERS}

The global registers contain command information applying to different modes of operation and protocols. After changing global register data, TRES in the TCR and RRES in the RCR should be set then cleared prior to performing normal mode processing.

Protocol Select Register 1 (PSR1)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline \(\mathbf{0}\) & 0 & 0 & 0 & 0 & 0 & CTLEX & ADDEX \\
\hline
\end{tabular}

Address \(=18\)
Reset value \(=\$ 00\)

Protocol Select Register 1 (PSR1) selects BOP protocol related options.

\section*{PSR1}

7-2 -Not used.
PSR1
\(\begin{array}{ll}1 & \text { CTLEX } \\ 0 & \text { Select } 8 \text {-bit control Field Extend (BOP only). }\end{array}\)
1 Select 16-bit control field.

\section*{PSR1}

ADDEX -Address Extend (BOP only).
Disable address extension. All eight bits of the address byte are utilized for addressing.
1 Enable address extension. When bit 0 in the address byte is a 0 the address field is extended by one byte. An exception to the address field extension occurs when the first address byte is all 0 's (null address).

Protocol Select Register 2 (PSR2)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline \multirow{2}{*}{ WD/BYT } & \multicolumn{2}{|l|}{ STOP BIT SEL } & \multicolumn{2}{|c|}{ CHAR LEN SEL } & \multicolumn{2}{|c|}{ PROTOCOL SEL } \\
\cline { 2 - 9 } & SB2 & SB1 & CL2 & CL1 & PS3 & PS2 & PS1 \\
\hline
\end{tabular}

Address \(=19\)
Reset value \(=\$ 00\)
Protocol Select Register 2 (PSR2) selects protocols, character size, the number of stop bits, and word/byte mode.

\section*{PSR2}

WD/BYT -Data Bus Word/Byte Mode.
Select byte mode. Selects the number of data bits to be transferred from the RxFIFO and the registers to the data bus and to be transferred from the data bus to the TXFIFO and the registers. The MPCC is initialized by RESET to the byte mode.
1 Select word mode. For operation with the 16 -bit bus, select the word mode by sending \(\$ 80\) on D7-D0 to address \(\$ 19\) prior to transferring subsequent data between the MPCC and the data bus.

\section*{PSR2}

6-5 STOP BIT SEL -Number of Stop Bits Select. Selects the number of stop bits transmitted at the end of the data bits in ASYNC and ISOC modes.
\begin{tabular}{cccc} 
& & \multicolumn{2}{c}{ No. of Stop Bits } \\
\cline { 4 - 4 } \(\mathbf{6}\) & \(\mathbf{5}\) & & \\
\(\frac{\text { SB2 }}{}\) & \(\frac{\text { SB1 }}{}\) & \(\frac{\text { ASYNC }}{1}\) & \(\frac{\text { ISOC }}{1}\) \\
0 & 0 & \(1-1 / 2\) & 2 \\
0 & 1 & 2 & 2
\end{tabular}

\section*{PSR2}

4-3 CHAR LEN SEL —Character Length Select. Selects the character length except in BOP and BSC where the character length is always eight bits. Parity is not included in the character length.
\begin{tabular}{ccc}
4 & \begin{tabular}{c}
3 \\
CL2
\end{tabular} & \(\frac{\text { CL1 }}{}\)
\end{tabular}\(\quad\)\begin{tabular}{c} 
Character Length \\
\hline 0
\end{tabular}

PSR2
2-0 PROTOCOL SEL-Protocol Select. Selects protocol and defines the protocol dependent control bits.
\begin{tabular}{cccl}
\begin{tabular}{c}
2 \\
PS3 \\
0
\end{tabular} & \(\frac{1}{\text { PS2 }}\) & \begin{tabular}{c}
\(\mathbf{0}\) \\
0
\end{tabular} & \(\frac{\text { PS1 }}{0}\)
\end{tabular}

Address Register 1 (AR1) Address
\begin{tabular}{|l|l|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & \(\mathbf{4}\) & 3 & 2 & 1 & 0 \\
\hline \multicolumn{7}{|c|}{ BOP ADDRESS/BSC \& COP PAD } \\
\hline
\end{tabular}

Address \(=1 \mathrm{~A}\)
Reset value \(=\$ 00\)

Address Register 2 (AR2)
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multicolumn{7}{|c|}{ BSC \& COP SYN } \\
\hline
\end{tabular}

Address \(=1 \mathrm{~B}\)
Reset value \(=\$ 00\)

The protocol selected in PSR2 (BOP, BSC and COP only) determines the function of the two 8-bit Address Registers (AR1 and AR2). As a secondary station in BOP, the contents of AR1 is used for address matching. In BSC and COP, AR1 and AR2 contain programmable leading PAD and programmable SYN characters, respectively.

Address Register (AR) Contents
\begin{tabular}{|l|c|c|}
\hline Protocol Selected & AR1 & AR2 \\
\hline BOP (Primary) & X & X \\
BOP (Secondary) & Address & X \\
BSC EBCDIC & Leading PAD & SYN \\
BSC ASCII & Leading PAD & SYN \\
COP & Leading PAD & SYN \\
\hline \multicolumn{2}{|l|}{} \\
\hline \multicolumn{3}{|l|}{} \\
\hline
\end{tabular}

Baud Rate Divider Register 1 (BRDR1)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multicolumn{7}{|c|}{ BAUD RATE DIVIDER (LSH) } \\
\hline
\end{tabular}

Address \(=1 \mathrm{C} \quad\) Reset value \(=\$ 01\)

Baud Rate Divider Register 2 (BRDR2)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multicolumn{7}{|c|}{ BAUD RATE DIVIDER (MSH) } \\
\hline
\end{tabular}

Address \(=1 \mathrm{D}\)
Reset value \(=\$ 00\)

The two 8-bit Baud Rate Divider Registers (BRDR1 and BRDR2) hold the divisor of the Baud Rate Divider circuit. BRDR1 contains the least significant half (LSH) and BRDR2 contains the most significant half (MSH), With an 8.064 MHz EXTAL input, standard bit rates can be selected using the combination of Prescaler Divider (in the CCR) and Baud Rate Divider values shown in Table 3. For isochronous or synchronous protocols, the Baud Rate Divider value must be multiplied by two for the same Prescaler Divider value.

The Baud Rate Divider (BRD) value can be computed for other crystal frequency, prescaler divider and desired baud rate values as follows:
\[
\mathrm{BRD}=\frac{\text { Crystal Frequency }}{(\text { Prescaler Divider) (Baud Rate) }(\mathrm{K})}
\]
where: \(\quad K=1\) for isochronous or synchronous 2 for asynchronous

\section*{Clock Control Register (CCR)}
\begin{tabular}{|l|l|l|c|c|c|c|c|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline 0 & \(\mathbf{0}\) & \(\mathbf{0}\) & PSCDIV & TCLKO & RCLKIN & \multicolumn{2}{|c|}{ CLK DIV } \\
\cline { 7 - 8 } & & & & & & CK2 & CK1 \\
\hline
\end{tabular}

Address \(=1 \mathrm{E}\)
Reset value \(=\$ 00\)
The CCR selects various clock options.
CCR
7-5 -Not used.

\section*{CCR}

4 PSCDIV -Prescaler Divider. The Prescaler Divider network reduces the external/oscillator frequency to a value for use by the internal Baud Rate Generator.
\(0 \quad\) Divide by 2.
1 Divide by 3.
CCR
\begin{tabular}{l}
3 \\
\hline 0 \\
1
\end{tabular}
TCLKO -Transmitter Clock Output Select.
Select TxC to be an input.
1 Select TxC to be an output. (1X clock)

Table 3. Standard Baud Selection (8.064 MHz Crystal)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{4}{*}{Desired Baud Rate (Bit Rate)} & \multicolumn{2}{|l|}{\multirow[b]{2}{*}{Prescaler Divider}} & \multicolumn{6}{|c|}{Baud Rate Divider} \\
\hline & & & \multicolumn{3}{|c|}{Asynchronous} & \multicolumn{3}{|l|}{Isochronous and Synchronous} \\
\hline & \multirow[b]{2}{*}{Decimal Value} & \multirow[b]{2}{*}{\[
\begin{aligned}
& \text { PSCDIV } \\
& (0 \text { to } 1)
\end{aligned}
\]} & \multirow[b]{2}{*}{Decimal Value} & \multicolumn{2}{|l|}{Hexadecimal Value} & \multirow[b]{2}{*}{Decimal Value} & \multicolumn{2}{|l|}{Hexadecimal Value} \\
\hline & & & & \begin{tabular}{l}
BRDR2 \\
(MSH)
\end{tabular} & \[
\begin{gathered}
\text { BRDR1 } \\
\text { (LSH) }
\end{gathered}
\] & & BRDR2
(MSH) & \[
\begin{gathered}
\text { BRDR1 } \\
\text { (LSH) }
\end{gathered}
\] \\
\hline 50 & 3 & 1 & 26,880 & 69 & 00 & 53,760 & D2 & 00 \\
\hline 75 & 2 & 0 & 26,880 & 69 & 00 & 53,760 & D2 & 00 \\
\hline 110 & 3 & 1 & 12,218 & 2 F & BA & 24,436 & 5 F & 74 \\
\hline 135 & 2 & 0 & 14,933 & 3A & 55 & 29,866 & 74 & AA \\
\hline 150 & 3 & 1 & 8,960 & 23 & 00 & 17,920 & 46 & 00 \\
\hline 300 & 2 & 0 & 6,720 & 1A & 40 & 13,440 & 34 & 80 \\
\hline 1200 & 3 & 1 & 1,120 & 04 & 60 & 2,240 & 08 & C0 \\
\hline 1800 & 2 & 0 & 1,120 & 04 & 60 & 2,240 & 08 & C0 \\
\hline 2400 & 2 & 0 & 840 & 03 & 48 & 1,680 & 06 & 90 \\
\hline 3600 & 2 & 0 & 560 & 02 & 30 & 1,120 & 04 & 60 \\
\hline 4800 & 3 & 1 & 280 & 01 & 18 & 560 & 02 & 30 \\
\hline 7200 & 2 & 0 & 280 & 01 & 18 & 560 & 02 & 30 \\
\hline 9600 & 3 & 1 & 140 & 00 & 8 C & 280 & 01 & 18 \\
\hline 19200 & 3 & 1 & 70 & 00 & 46 & 140 & 00 & 8C \\
\hline 38400 & 3 & 1 & 35 & 00 & 23 & 70 & 00 & 46 \\
\hline
\end{tabular}

CCR
2 RCLKIN -Receiver Clock Internal Select (ASYNC only). Select External RxC.
1 Select Internal RxC.

\section*{CCR}

1-0 CLK DIV —External Receiver Clock Divider. Selects the divider of the external RxC to determine the receiver data rate.
\(\left.\begin{array}{ccc}\text { CK2 } & \text { CK1 } & \text { Divider } \\
\hline 0 & 0 & 1 \text { (ISOC) } \\
0 & 1 & 16 \\
1 & 0 & 32 \\
1 & 1 & 64\end{array}\right\}\)\begin{tabular}{c} 
(ASYNC) \\
only
\end{tabular}

Error Control Register (ECR)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline PAREN & ODDPAR & - & - & CFCRC & CRCPRE & \multicolumn{2}{|c|}{ CRCSEL } \\
\cline { 6 - 8 } & & & & & & CR2 & CR1 \\
\hline
\end{tabular}

Address \(=1 \mathrm{~F}\)
Reset value \(=\$ 04\)
The Error Control Register (ECR) selects the error detection method used by the MPCC.

ECR
7 PAREN -Parity Enable. (ASYNC, ISOC and COP only).
0 Disable parity generation/checking.
1 Enable parity generation/checking.

ODDPAR —Odd/Even Parity Select (Effective only when PAREN = 1). Generate/check even parity.
1 Generate/check odd parity.

ECR
5-4 -Not used.
ECR
3 CFCRC -Control Field CRC Enable. (BOP Only) Disable control field CRC.
1 Enables an intermediate CRC remainder to be appended after the address/control field in transmitted BOP frames and checked in received frames. The CRC generator is reset after control field CRC calculation.

ECR
2 CRCPRE -CRC Generator Preset Select.
(BOP, BSC Only)
0 Preset CRC Generator to 0. (For BSC)
1 Preset CRC Generator to 1 and transmit the 1's complement of the resulting remainder. (For BOP)

ECR
1-0 CRCSEL -CRC Polynomial Select. Selects one of the RC polynominals.

10
\begin{tabular}{|c|c|c|}
\hline CR2 & CR1 & Polynominal \\
\hline 0 & 0 & \(x^{16}+x^{12}+x^{5}+1\) (CCITT V.41) (BOP) \\
\hline 0 & 1 & \(x^{16}+x^{15}+x^{2}+1\) (CRC-16) (BSC) \\
\hline 1 & 0 & \(\begin{array}{ll}x^{8}+1 & \text { (VRC/LRC)* (BSC, } \\ & \text { ASCII, non-transparent) }\end{array}\) \\
\hline 1 & 1 & Not used. \\
\hline
\end{tabular}
*VRC: Odd-parity check is performed on each character including the LRC character.

\section*{INPUT/OUTPUT FUNCTIONS}

\section*{MPU INTERFACE}

Transfer of data between the MPCC and the system bus involves the following signals:
\begin{tabular}{|c|c|c|}
\hline & R68561 & R68560 \\
\hline Address Lines & A1-A4 & A0-A4 \\
\hline Data Lines & D0-D15 & D0-D7 \\
\hline Read/Write & \(\mathrm{R} / \overline{\mathrm{W}}\) & R/W \\
\hline Data Transfer Acknowledge & \(\overline{\text { DTACK }}\) & DTACK \\
\hline Chip Select & \(\overline{\mathrm{CS}}\) & \(\overline{\text { CS }}\) \\
\hline Data Strobes & \(\overline{\text { UDS }}\) and \(\overline{\text { LDS }}\) & \(\overline{\text { DS }}\) \\
\hline
\end{tabular}

Figures 10 and 11 show typical interface connections.

\section*{Read/Write Operation}

The \(\mathrm{R} \overline{\mathrm{W}}\) input controls the direction of data flow on the data bus. \(\overline{\mathrm{CS}}\) (Chip Select) enables the MPCC for access to the internal registers and other operations. When \(\overline{\mathrm{CS}}\) is asserted, the data I/O buffer acts as an output driver during a read operation and as an input buffer during a write operation. \(\overline{\mathrm{CS}}\) must be decoded from the address bus and gated with address strobe ( \(\overline{\mathrm{AS}}\) ).

When the R68561 is connected to the 16 -bit bus for operation in the word mode (WD/BYT = 1 in the PSR2), address lines A1-A4 select the internal register(s) (the 8 -bit control/status registers are accesed two at a time and the 16 -bit data registers are accessed on even address boundaries). When the MPCC is selected ( \(\overline{\mathrm{CS}}\) low) during a read ( \(\mathrm{R} / \overline{\mathrm{W}}\) high), 16 bits of register data are placed on the data bus when the data strobes (LDS and \(\overline{\text { UDS }}\) ) are asserted. \(\overline{\mathrm{LDS}}\) strobes the eight data bits from the even numbered registers to the lower data bus lines (D0-D7) and UDS strobes the eight data bits from the odd numbered registers to the upper data bus lines (D8-D15). The MPCC asserts Data Transfer Acknowledge (DTACK) prior to placing data on the data bus. Conversely, when the MPCC is selected ( \(\overline{\mathrm{CS}}\) low) during a write (R/W low) \(\overline{L D S}\) and \(\overline{U D S}\) strobe data from the DO-D7 and D8-D15 data bus lines into the addressed even and odd numbered registers, respectively, and the MPCC asserts DTACK. \(\overline{\text { DTACK }}\) is negated when \(\overline{C S}\) is negated. Figures 12 and 13 show the read and write timing relationships.

When the R68560 is connected to the 8-bit bus for operation in the byte mode (WD/BYT \(=0\) in the PSR2), address lines A0-A4 select one internal 8 -bit register. When the MPCC is selected (CS low) during a read ( \(\mathrm{R} / \overline{\mathrm{W}}\) high), eight bits of register data are placed on data bus lines D0-D7 when the data strobe ( \(\overline{\mathrm{DS}}\) ) is asserted. When the MPCC is selected ( \(\overline{C S}\) low) for a write ( \(\mathrm{R} / \overline{\mathrm{W}}\) low), \(\overline{\mathrm{DS}}\) strobes data from the D0-D7 data lines into the selected register.

\section*{DMA INTERFACE}

The MPCC is capable of providing DMA data transfers at up to 2 Mbytes per second when used with the MC68440 or MC68450 DMAC in the single address mode. Based on \(4 \mathrm{Mb} / \mathrm{s}\) serial data rate and 5 bits/character, the maximum DMA required transfer rate is 800 Kbytes per second.

The MPCC has separate DMA enable bits for the transmitter and receiver, each of which requires a DMA channel. Both the transmitter and receiver data are implicitly addressed (TDR or RDR) therefore addressing of the data register is not required before data may be transferred. Communication between the MPCC
and the DMAC is accomplished by a two-signal request/ acknowledge handshake. Since the MPCC has only one acknowledge input ( \(\overline{\mathrm{DACK}}\) ) for its two DMA request lines, an external OR function must be provided to combine the two DMA acknowledge signals. The MPCC uses the R/W input to distinguish between the Transmitter Data Service Request (TDSR acknowledge and the Receiver Data Service Request (RDSR) acknowledge.

\section*{Receiver DMA Mode}

The receiver DMA mode is enabled when the RDSREN bit in the RCR is set to 1 . When data is available in the RxFIFO, Receiver Data Service Request ( \(\overline{\mathrm{RDSR}}\) ) is asserted for one receiver clock period (BOP and BSC) to initiate the MPCC to memory DMA transfer. For asynchronous operation, \(\overline{\text { RDSR }}\) is asserted for 2-3 periods of the system clock depending on prescale factor. The next \(\overline{\text { RDSR }}\) cycle may be initiated as soon as the current \(\overline{\text { RDSR }}\) cycle is completed (i.e., a full sequence of \(\overline{\mathrm{DACK}}, \overline{\mathrm{DS}}\), and \(\overline{\mathrm{DTC}}\) ).

In response to \(\overline{\text { RDSR }}\) assertion, the DMAC sets the R/W line to write, asserts the memory address, address strobe, and DMA acknowledge. The MPCC outputs data from the RxFIFO to the data bus and the DMAC asserts the data strobes. The memory latches the data and asserts DTACK to complete the data transfer. The DMAC asserts DTC to indicate to the MPCC that data transfer is complete. Figure 14 shows the timing relationships for the receiver DMA mode.
\(\overline{\operatorname{RDSR}}\) is inhibited when either RDSREN is reset to 0 or RRES is set to 1 (both in the RCR), or when RESET is asserted.

\section*{Transmitter DMA Mode}

The transmitter DMA mode is enabled when the TDSREN bit in the TCR is set to 1 . When the TxFIFO is available, Transmitter Data Service Request ( \(\overline{\text { TDSR }}\) ) is asserted for one transmitter clock period to initiate the memory to MPCC DMA transfer. For asynchronous operation, TDSR is asserted for a period of one-half the transmitter baud rate. The next TDSR cycle may be initiated as soon as the current TDSR cycle is completed.

In the transmitter DMA mode, the TxFIFO Is implicitly addressed. That is, when the transfer is from memory to the TxFIFO, only the memory is addressed. In response to TDSR assertion, the DMAC sets the R \(\bar{W}\) line to read, asserts the memory address, the address strobe, the data strobes and DMA acknowledge. The memory places data on the data bus and asserts DTACK. Data is valid at this time and will remain valid until the data strobes are negated. The DMAC asserts \(\overline{\text { DTC }}\) to indicate to the MPCC that data is available. The MPCC loads the data into the TxFIFO on the negation (rising edge) of \(\overline{\mathrm{DS}}\) and the transfer is complete. When a TxFIFO underrun occurs, the TUNRN bit is set in TSR2, the interrupt is issued, and the ABORT sequence is entered (eight consecutive is are transmitted). The next word/byte in TxFIFO clears the ABORT bit and the idle mode is entered. When a transmission is aborted, it is expected that the interrupt will allow the host system to decide the next course of action; probably to reset the DMAC and retransmit the message. A timing diagram for the transmitter DMA Mode is shown in Figure 15.
\(\overline{T D S R}\) is inhibited when either TDSREN is reset to 0 or TRES is set to 1 (both in the TCR), or when RESET is asserted.

DONE Signal
When the DMA transfer count is exhausted in transmitter DMA mode, the DMAC asserts DONE which sets the TLAST bit in the TCR to indicate that the last word/byte has been transferred. In the receiver DMA mode of operation, \(\overline{\text { DONE }}\) is issued by the MPCC on an MPCC-to-memory transfer when the last byte/word is being transferred from the RxFIFO to the data bus (if DONEEN bit is set in RCR5). In the byte mode, this is the Frame Status Byte (FSB). In the word mode, this is the last data byte and FSB (for an odd number of data byte transfers) or FSB and blank (for an even number of data byte transfers).
\(\overline{\mathrm{DONE}}\) is asserted as a result of the FSB being transferred and not as a result of the error conditions. The EOF, C/PERR and FRERR are addendum bits in the RxFIFO which are written to FIFO when they occur and follow the data through the FIFO. The frame is aborted upon overrun or error detection if RCR1 \(=1\).

\section*{CAUTION}
\(\overline{\text { DONE }}\) is reasserted with each occurrence of \(\overline{\text { DACK }}\) until EOF is cleared in the RSR.

\section*{INTERRUPTS}

If an interrupt generating status occurs and the interrupt is enabled, the MPCC asserts the \(\overline{\mathrm{IRQ}}\) output. Upon receiving \(\overline{\mathrm{IACK}}\) for the pending interrupt request, the MPCC places an interrupt vector on D0-D7 data bus and asserts DTACK.

The MPCC has three vector registers: Receiver Interrupt Vector Number Register (RIVNR), Transmitter Interrupt Vector Number Register (TIVN), and Serial Interrupt Vector Number Register (SIVNR). The receiver interrupt has priority over the transmitter interrupt, and the transmitter interrupt has priority over the serial interface interrupt. For example, if a pending interrupt request has been generated simultaneously by the receiver and the transmitter, the Receiver Interrupt Vector Number (RIVN) is placed on D0-D7 when acknowledged by the MPU. Upon completion of the first interrupt request cycle (which clears the receiver interrupt), \(\overline{\mathrm{RQ}}\) will remain low to start the transmitter interrupt cycle. \(\overline{\mathrm{IRQ}}\) is negated by clearing all bits set in a status register that could have caused the interrupt.

\section*{CAUTION}

A higher priority interrupt occuring while \(\overline{\mathrm{IACK}}\) is low during transfer of a lower priority interrupt vector to the MPU will cause the lower priority interrupt vector on the data bus to be invalid if there are any 1 's in the higher priority interrupt vector in the same bit poositions as any 0's in the lower priority interrupt vector. To prevent this problem from occuring, ensure that the higher priority interrupt vectors contain 1 's only in bit positions where there are 1's in the lower priority interrupt vectors, e.g.:
\(\left.\begin{array}{lcc}\text { Vector } & \begin{array}{c}\text { Vector Value } \\ \text { (Hex) }\end{array} & \end{array} \begin{array}{c}\text { Vector Value } \\ \text { (Binary) }\end{array}\right]\)

A timing diagram for the interrupt acknowledge sequence is shown in Figure 16.

\section*{SERIAL INTERFACE}

The MPCC is a high speed, high performance device supporting the more popular bit and character oriented data protocols. The lower speed asynchronous (ASYNC) and isochronous (ISOCH) modes are also supported. An on-chip clock oscillator and baud rate generator provide an output data clock at a frequency of DC to a 4 MHz .. The clock can also be used in the ASYNC mode to provide a receive clock for the incoming data. The serial interface consists of the following signals:

\section*{\(\overline{\text { RTS }}\) (Request to Send) Output}

The \(\overline{R T S}\) output to the DCE is controlled by the RTSLVL bit in the SICR inn conjunction with the state of the transmitter section. When the RTSLVL bit is set to 1 , the RTS output is asserted. When the RTSLVL bit is reset to 0 (no sooner than one full cycle of TxC after transmission has started), the RTS output remains asserted until the TxFIFO becomes empty, or the end of the message (or frame), complete with CRC code (if any), closing flag, and one full cycle of idle has been transmitted. \(\overline{\text { RTS }}\) also is negated when the RTSLVL bit is reset during transmitter idle, or when the RESET input is asserted.

\section*{\(\overline{\text { CTS }}\) (Clear to Send) Input}

The CTS input signal is normally generated by the DCE to indicate whether or not the data set is ready to receive data. The CTST bit in the SISR reflects the transition status of the CTS input while the CTSLVL bit in the SISR reflects the current level. A positive transition on the \(\overline{\mathrm{CTS}}\) pin asserts \(\overline{\mathrm{RQ}}\) if the CTS IE bit in the SIER is set. The \(\overline{\text { CTS }}\) input in an inactive state disables the start of transmission of each frame.

\section*{\(\overline{\text { DCD }}\) (Data Carrier Detect) Input}

The \(\overline{D C D}\) input signal is normally gnerated by the DCE and indicates that the DCE is receiving a data carrier signal suitable for demodulation. The DCDT bit in the SISR reports the transition status of the \(\overline{D C D}\) input while the DCDLVL bit in the SISR contains the current level. A positive transition on the \(\overline{D C D}\) pin asserts the IRQ output if the DCD IE bit in the SIER is set. A negated \(\overline{\mathrm{DCD}}\) input disables the start of the receiver but does not stop the operation of an incoming message already in progress.

\section*{\(\overline{\text { DSR }}\) (Data Set Ready) Input/RSYN Output}

The DSRT input from the DCE indicates the status of the local set. The DSRT bit in the SISR contains the transition status of the \(\overline{\mathrm{DSR}}\) input while the DSRLVL bit in the SISR reports the current level. A negative transition on the \(\overline{D S R}\) pin asserts the \(\overline{\operatorname{IRQ}}\) output if the DSR IE bit in the SIER is set.

The \(\overline{\mathrm{DSR}}\) pin is used as an output for RSYN when enabled by a 1 in RSR4 (RSYNEN = 1). DSR output low indicates detection of a SYN (non-transparent) in BSC or COP protocols or DLESYN pair (transparent) in BSC protocol. It is asserted as a negative-going pulse one-bit time after the end of the SYN byte and lasts for one full serial clock cycle before being reset.

In BOP protocol, RSYN is asserted as a result of address match at the beginning of a frame. It is asserted one bit time after the end of the address byte(s) if an address match is made, and lasts for one full serial clock cycle.

\section*{DTR (Data Terminal Ready) Output}

The \(\overline{\text { DTR }}\) output is general purpose in nature and can be used to control switching of the DCE. The \(\overline{\text { DTR }}\) output is controlled by the DTRLVL bit in the SICR.

\section*{TxC (Transmitter Clock) Input/Output}

The transmitter clock (TxC) may be programmed to be input or an output. When the TCLKO control bit in the CCR is set to a 1 , the TxC pin becomes an output and provides the DCE with a clock whose frequency is determined by the internal baud rate generator. When the TCKLO control bit is reset, TxC is an input and the transmitter shift timing must be provided exernally. The TxD output changes state on the negative-going edge of the transmitter clock. In the asynchronous mode when TCLKO \(=0\) in the CCR, the TxC input frequency must be two times the desired baud rate.

\section*{TxD (Transmitted Data) Output}

The serial data transmitted from the MPCC is coded in NRZ data format. The first byte of a message transmitted out of the R68561 MPCC is the even byte of the 68000 bus (D8-D15). It is transmitted least significant bit (LSB) first.

\section*{RxC (Receiver Clock) Input}

The receiver latches data on the negative transition of the RxC.

\section*{RxD (Received Data) Input}

The serial data received by the MPCC is in NRZ data format. The first byte received in the MPCC RXFIFO is output to the 68000 bus on (D8-D15).

\section*{Serial Interface Timing}

The timing for the serial interface clock and data lines is shown in Figure 18. The MPCC supports high speed synchronous operation. As shown, the TxD output changes with the negative-going edge of \(T x C\) and the received data on RxD is latched on the negative edge of RxC. This assures high speed two-way operation between two MPCCs connected as shown in Figure 17.

For low speed operation between the MPCC and a modem or RS-232C Data Communications Equipment (DCE), an inverter can be used in the TxC output lines as shown in Figure 17. RS-232 and RS-423 (covering serial data interface up to 100 K baud) require that data be centered \(\pm 25 \%\) about the negative-going edge of the \(R \times C\). This criteria is met for frequencies up to 1.25 MHz using the inverter. Use of the inverter also allows MPCC to MPCC operation up to 2.17 MHz .

\section*{SERIAL COMMUNICATION MODES AND PROTOCOLS}

\section*{ASYNCHRONOUS AND ISOCHRONOUS MODES}

Asynchronous and isochronous data are transferred in frames. Each frame consists of a start bit, 5 to 8 data bits plus optional even or odd parity, and \(1,11 / 2\), or 2 stop bits. The data character is transmitted with the least significant bit (LSB) first. The data line is normally held high (MARK) between frames, however, a BREAK (minimum of one frame length for which the line is held low) is used for control purposes. Figure 4 illustrates the frame format supported by the MPCC.

\section*{Asynchronous Receive}

In the asynchronous (ASYNC) mode, data reception on RxD occurs in three phases: (1) detection of the start bit and bit synchronization, (2) character assembly and optional parity check, and (3) stop bit detection. The receiver bit stream may be synchronized by the internal baud rate generator clock or by an external clock on RxC. When RCLKIN in the CCR is set to 0 , an external clock with a frequency of 16,32, or 64 times the data rate establishes the data bit midpoint and maintains bit synchronization. The character assembly process does not start if the start bit is less than one-half bit time. Framing and parity errors are detected and buffered along with the character on which errors occurred. They are passed on to the RxFIFO and set appropriate status bits in the RSR when the character with an error reaches the last RxFIFO register where it is ready to be transferred onto the data bus via the RDR.

\section*{Isochronous Receive}

In the isochronous (ISOC) mode, a times 1 clock on RxC is required with the data on \(R \times D\) and the serial data bit is latched on the falling edge of each clock pulse. The requirement for the detection of a valid start bit, or the beginning of a break, is satisfied by the detection of a high-to-low transition on the serial data input line. Error detection and status indication are the same as the asynchronous mode.

\section*{Asynchronous and Isochronous Transmit}

In asynchronous and isochronous transmit modes, output data transmission on TxD begins with the start bit. This is followed by the data character which is transmitted LSB first. If parity generation is enabled, the parity bit is transmitted after the MSB of the character. Each frame is terminated with \(1,11 / 2\) or 2 stop bits as selected by PSR2 bits 5 and 6.


Figure 4. Asynchronous and Isochronous Frame Format

\section*{SYNCHRONOUS MODES}

In synchronous modes, a times one clock is provided along with the data. Serial output data is shifted out and input data is latched on the falling edge of the clock.

\section*{BIT ORIENTED PROTOCOLS (BOP)}

In bit oriented protocols (BOP), messages (data) are transmitted and received in frames. Each frame contains an opening flag, address field, control field, frame check sequence, and a closing flag. A frame may also contain an information field. (See Figure 5).

The opening flag is a special character whose bit pattern is 01111110 . It marks the frame boundaries and is the interframe fill character. The address field of a frame contains the address of the secondary station which is receiving or responding to a command. The address field may be one or more bytes long. The
address field can be extended by setting the ADDEX bit to a 1 in PSR1. In this case, the address field will be extended until the occurrence of an address byte with a 1 in bit 0 . The first byte of the address field is automatically checked when the MPCC is programmed to be a secondary station in BOP. An automatic check for global (11111111) or null ( 00000000 ) address is also made. The control field of one or two bytes is transparent to the MPCC and sent directly to the host without interpretation.

The optional information field consists of 8 -bit characters. Cyclic redundancy checking is used for error detection and the CRC remainder resulting from the calculation is transmitted as the frame check sequence field. For BOP, the polynomial \(X^{16}+X^{12}\) \(+X^{5}+1\) (CRC-CCITT) should be used, i.e., selected in the CRC SEL bits in the ECR. The registers representing the CRC-CCITT polynomial are generally preset to all 1 s , and the 1 s complement of the resulting remainder is transmitted. (See X. 25 Recommendation.)
\begin{tabular}{|l|l|l|l|l|l|}
\hline \begin{tabular}{l} 
FLAG \\
01111110
\end{tabular} & \begin{tabular}{l} 
ADDRESS \\
1 OR N \\
BYTES
\end{tabular} & \begin{tabular}{l} 
CONTROL \\
1 OR \\
2 BYTES
\end{tabular} & \begin{tabular}{l} 
INFORMATION \\
N BYTES \\
(OPTIONAL)
\end{tabular} & \begin{tabular}{l} 
FCS \\
2 BYTES
\end{tabular} & \begin{tabular}{l} 
FLAG \\
01111110
\end{tabular} \\
\hline
\end{tabular}

Figure 5. Bit Oriented Protocol (BOP) Frame Format

Zero insertion/deletion is employed to prevent valid frame data from being confused with the special characters. A 0 is inserted by the transmitter after every fifth consecutive 1 in the data stream. These inserted zeros are removed by the receiver to restore the data to its original form. The inserted zeros are not included in the CRC calculation.

The end of the frame is determined by the detection of the closing Flag special character which is the same is the opening Flag.

With the control options offered by the MPCC, commonly used bit oriented protocols such as SDLC, HDLC and X. 25 standards can be supported. Figure 6 compares the requirements of these options.

\section*{BOP Receiver Operation}

In BOP, the receiver starts assembling characters and accumulating CRC immediately after the detection of a Flag. The receiver also continues to search for additional Flag, or Abort, characters on a bit-by-bit basis. Zero deletion is implemented in the Receiver Shift Register after the Flag detection logic and before the CRC circuitry. The receiver recognizes the shared flag (the closing flag for one frame serves as the opening flag for the next frame) and the shared zero (the ending 0 of a closing flag serves as the beginning 0 of an opening flag forming the pattern "011111101111110."

Character assembly and CRC accumulation are stopped when a closing Flag or Abort is detected. The CRC accumulation includes all the characters between the opening Flag and the closing Flag. The contents of the CRC register are checked at the close of a frame and the C/PERR bit in the RSR is updated. The FCS and the Flag are not passed on to the RxFIFO.

If the Flag is a closing flag, checks for short frame (no control field) and CRC error conditions are made and the appropriate status is updated. When an Abort (seven 1s) is detected, the remaining frame is discarded and the RA/B bit is set in the RSR. When a link idle ( 15 or more consecutive 1 s ) is detected, the RIDLE status bit is set in the RSR. The zeros that have been inserted to distinguish data from special characters are detected and deleted from the data stream before characters are assembled. The MPCC programmed as a secondary station provides automatic address matching of the first byte. If there is no address match, or if null address is received, the receiver ignores the remainder of the frame by searching for the Flag. If there is a match, the address bytes are transferred to the RxFIFO as they are assembled.

For the control field, one or two bytes are assembled and passed on to the RxFIFO depending on the state of the extended control field bit.

If the CFCRC bit in the ECR is set to 1 , an intermediate CRC check will be made after the address and control field. The Frame Check Sequence is still calculated over the remainder of the frame.

\section*{BOP Transmitter Operation}

In BOP, the TxFIFO can be preloaded through the TDR while the transmitter is disabled (TEN \(=0\) in the TCR). When the transmitter is enabled (TEN = 1 in the TCR), the leading Flag is automatically sent prior to transmitting data from the TxFIFO. The TDRA bit is set to 1 in the TSR as long as TxFIFO is not full. If an underrun occurs, the TUNRN bit in the TSR is set to a 1 and an Abort (11111111) is transmitted followed by continuous Flags or marks until a new sequence is initiated.

The TLAST bit in the TCR must be set prior to loading the last character of the message to signal the transmitter to append the two-byte Frame Check Sequence (FCS) following the last character. If the transmitter DMA mode is selected (the TDSREN bit set to 1 in the TCR) the TLAST bit is set by the DONE signal from the DMAC.

A message may be terminated at any time by setting the TABT bit in the TCR to 1 . This causes the transmitter to send an Abort character followed by the remainder of the current frame data in the TxFIFO.

The serial data from the Transmitter Shift Register is continuously monitored for five consecutive 1 s , and a 0 is inserted in the data stream each time this condition occurs (excluding Flag and Abort characters).

CRC accumulation begins with the first non-Flag character and includes all subsequent characters. The CRC remainder is transmitted as the FCS following the last data character. If the CTLCRC bit in the ECR is set to 1, an intermediate CRC remainder is appended after the Address and Control field. The final Frame Check Sequence is calculated over the balance of the frame.

IBM SDLC FRAME FORMAT
\begin{tabular}{|l|l|l|l|l|l|}
\hline FLAG & ADDRESS & CONTROL & INFORMATION & FCS & FLAG \\
01111110 & 1 BYTE & 1 BYTE & N BYTES & 2 BYTES & 01111110 \\
\hline
\end{tabular}

HDLC FRAME FORMAT
\begin{tabular}{|l|l|l|l|l|l|}
\hline FLAG \\
01111110
\end{tabular}\(\quad\)\begin{tabular}{l} 
ADDRESS \\
N BYTES
\end{tabular}\(\quad\)\begin{tabular}{l} 
CONTROL \\
1 OR \\
2 BYTES
\end{tabular}

Figure 6. Bit Oriented Protocols
\(\left.\begin{array}{|l|l|l|l|l|l|}\hline \begin{array}{l}\text { LEADING PAD } \\
\text { 1 BYTE } \\
\text { (AR1) }\end{array} & \begin{array}{l}\text { SYN } \\
1 \text { BYTE } \\
\text { (AR2) }\end{array} & \begin{array}{l}\text { SYN } \\
\text { 1 BYTE } \\
\text { (AR2) }\end{array} & \text { BODY } & \text { BCC } & \text { TRAILING } \\
\text { PAD }\end{array}\right]\)\begin{tabular}{ll} 
&
\end{tabular}

Figure 7. BSC Block Format

\section*{BISYNC (BSC)}

The structure of messages utilizing the IBM Binary Synchronous Communications (BSC) protocol, commonly called Bisync, is shown in Figure 7. The MPCC can process both transparent and nontransparent messages using either the EBCDIC or the ASCII codes. The CRC-16 polynomial should be selected by setting the appropriate CRCSEL bits in the ECR for both transparent and non-transparent EBCDIC and for transparent ASCII coded messages. VRC/LRC should be selected for non-transparent ASCII coded messages. BSC messages are formatted using defined data-link control characters. Data-link control characters generated and recognized by the MPCC are listed in Table 4.

Table 4. BSC Control Sequences-Inclusion in CRC Accumulation
\begin{tabular}{|l|c|c|l|c|c|}
\hline \multicolumn{3}{|c|}{ ASCII } & \multicolumn{3}{c|}{ EBCDIC } \\
\hline Command & Byte 1 & Byte 2 & Command & Byte 1 & Byte 2 \\
\hline SYN & \(16^{*}\) & - & SYN & \(32^{*}\) & - \\
SOH & 01 & - & SOH & 01 & - \\
STX & 02 & - & STX & 02 & - \\
ETB & 17 & - & EOB (ETB) & 26 & - \\
ETX & 03 & - & ETX & 03 & - \\
ENQ & 05 & - & ENQ & \(2 D\) & - \\
DLE & 10 & - & DLE & 10 & - \\
ITB & \(1 F\) & - & ITB & \(1 F\) & - \\
EOT & 04 & - & EOT & 37 & - \\
ACK N* & 10 & \(30-37\) & ACK 0 & 10 & 70 \\
NAK & 15 & - & ACK 1 & 10 & 61 \\
WACK & 10 & \(3 B\) & NAK & \(3 D\) & - \\
RVI & 10 & \(3 C\) & WACK & 10 & \(6 B\) \\
& & RVI & 10 & \(7 C\) \\
\hline \multicolumn{6}{|l|}{ Note: *Programmable } \\
\hline
\end{tabular}

A heading is a block of data starting with an SOH and containing one or more characters that are used for message control (e.g., message identification, routing, and priority). The SOH initiates the block-check-character (BCC) accumulation, but is not included in the accumulation. The heading is terminated by STX when it is part of a block containing both heading and text. A block containing only a heading is terminated with an ITB or an

ETB followed by the BCC. Only the first SOH or STX in a transmission block following a line turnaround causes the BCC to reset. All succeeding STX or SOH characters are included in the BCC. This permits the entire transmission (excluding the first SOH or STX) to be block-checked.

The text data is transmitted in complete units called messages, which are initiated by STX and concluded with ETX. A message can be subdivided into smaller blocks for ease in processing and more efficient error control. Each block starts with STX and ends with ETB (except for the last block of a message, which ends with ETX). A single transmission can contain any number of blocks (ending with ETB) or messages (ending with ETX). An EOT following the last ETX block indicates a normal end of transmission. Message blocking without line turnaround can be accomplished by using ITB (see the Additional Data Link Capabilities section, IBM GA 27-3004-2).

Two modes of data transfers are used in BSC. In non-transparent mode, data link control characters may not appear as text data. In transparent mode, each control character is preceded by a data link escape (DLE) character to differentiate it from the text data. Table 5 indicates which control characters are excluded in the CRC generation. All characters not shown in the table are included in the CRC generation. Figure 8 shows various formats for Control/Response Blocks and Heading and Text Blocks.

Table 5. Transparent Mode BSC Control Sequences Inclusion in CRC Accumulation
\begin{tabular}{|c|c|c|}
\hline \multirow{2}{*}{ Character of Sequence } & \multicolumn{2}{|c|}{ Included in CRC Accumulation } \\
\cline { 2 - 3 } & Yes & No \\
\hline TSYN & - & DLESYN \\
TSOH & - & DLESOH \\
TSTX* & - & DLESTX \\
TETB & ETB & DLE \\
TETX & ETX & DLE \\
TDLE & (DLE)DLE & DLE(DLE) \\
\hline
\end{tabular}
*If not preceded within the same block by transparent heading information.

CONTROL/RESPONSE BLOCKS:
\begin{tabular}{|l|l|l|l|l|l|l|l|l|l|}
\hline \begin{tabular}{l} 
LEADING \\
PAD
\end{tabular} & SYN & SYN & EOT & \begin{tabular}{l} 
FOLLOW- \\
ING PAD
\end{tabular} & SYN & SYN & ADDRESS & ENQ & \begin{tabular}{l} 
FOLLOW- \\
ING PAD
\end{tabular} \\
\hline
\end{tabular}

POLLING OR SELECTION


POSITIVE ACKNOWLEDGEMENT


NEGATIVE ACKNOWLEDGEMENT

HEADING AND TEXT BLOCKS:


NONTRANSPARENT HEADING AND TEXT


Figure 8. BSC Message Format Examples

\section*{BSC Receiver Operation}

Character length defaults to eight bits in BSC mode. When ASCII is selected, the eighth bit is used for parity provided that VRC/LRC polynomial is selected. Character assembly starts after the receipt of two consecutive SYN characters. Serial data bits are shifted through the Receiver Shift Register into the Serial-to-Parallel Register and transferred to the RxFIFO. The RDA status bit in the RSR is set to 1 each time data is transferred to the RxFIFO. The SYN character pairs in non-transparent mode and DLE-SYN pairs in transparent mode are discarded.

The receiver starts each block in the non-transparent mode. It switches to transparent mode if a block begins with a DLE-SOH or DLE-STX pair. The receiver remains in transparent mode until a DLE-ITB, DLE-ETB, DLE-ETX or DLE-ENQ pair is received. BCC accumulation begins after an opening SOH, STX, or DLESTX. SYN characters in non-transparent mode or DLE-SYN pairs in transparent mode are excluded from the BCC accumulation. The first DLE of a DLE-DLE sequence is not included in the BCC accumulation and is discarded. The BCC is checked after receipt of an ITB, ETB, or ETX in non-transparent mode or DLE-ITB, DLE-ETB, DLE-ETX in transparent mode. If a CRC error is detected, the C/PERR and EOF bits in the RSR are set to 1. If no error is detected only the EOF bit is set. If the closing character was an ITB, BCC accumulation and character assembly starts again on the first character following the BCC.

\section*{BSC Transmitter Operation}

BSC transmission begins with the sending of an opening pad (PAD) and two sync (SYN) characters. These characters are programmable and stored in AR1(PAD) and AR2(SYN). The first SOH or STX initiates the block-check-character (BCC) accumulation. An initial SOH or STX is not included in the BCC accumulation. Should an underrun condition occur, the content of AR2 (normally SYN character) is transmitted until new characters become available. The message is terminated by the transmission of the BCC followed by a closing pad when an ETB, ITB, or ETX is fetched from the TxFIFO. The closing PAD is generated by the MPCC.

In transparent mode, the BCC accumulation is initiated by DLESTX and is terminated by the sequences DLE-ETX, DLE-ETB, or DLE-ITB. See Table 5 for character sequence and inclusion in CRC accumulation. If an underrun occurs, DLE-SYN characters will be transmitted until new characters are available in the TxFIFO. ETB, ETX, ITB, or ENQ with a TLAST tag is treated as a control character and the MPCC automatically inserts a DLE immediately preceding these characters. DLE-ETB, DLE-ETX, DLE-ITB, or DLE-ENQ terminates a block of transparent text, and returns the data link to normal mode. BCC generation is not used for messages beginning with characters other than SOH, STX, DLE-SOH, or DLE-STX. On all message types, if the TSYN bit is set to 1 in the TCR, a SYN-SYN (DLE-SYN sequence on transparent messages) sequence is transmitted before the next character is fetched from the TxFIFO.

\section*{CHARACTER ORIENTED PROTOCOLS}

The character oriented protocol (COP) option uses the format shown in Figure 9. It may be used for various character oriented protocols with \(5-8\) bit character sizes and optional parity checking. The input data is checked on a bit-by-bit basis for a pair of consecutive SYN characters to establish character synchronization. These SYN characters are discarded after detection. The PAD and SYN characters may be 5-8 bits long and are user programmable as stored in AR1 and AR2, respectively.

If parity checking is enabled the characters assembled after character sync are checked for parity errors. If STRSYN is set in the RCR, all SYN characters detected within the message will be discarded and will not be passed on to the RxFIFO. If STRSYN is reset, SYNs detected within the message will be treated as data.

\section*{DMA CONSIDERATIONS}

When the R68561, in the word mode, is used with a DMAC, high throughput of bit-oriented protocols is achieved. However, problems can arise when trying to DMA byte-oriented data in the word mode.

BOP and BSC have well-defined message boundaries and the MPCC can detect the end of message, determine if there is an odd (single) byte at the end of a message, and so inform the host MPU by setting the Received Half Word (RHW) bit in the Frame Status byte.

In byte-oriented protocols (such as ASYNC and COP) there is no defined message length. In the word mode, received bytes are grouped in pairs. In the byte mode, each byte is available through the RxFIFO as it is received. Thus, the MPCC in the word mode has no way of knowing when an odd (single) byte has been received at an end of a transmission to be passed onto the host MPU. In the word mode received bytes are grouped in pairs. In the byte mode each byte is available through the FIFO as it is received.

For transmission of data by the MPCC in the word mode, the MPCC provides a Transmit Half Word (THW) bit in the Transmit Control Register. When set, this bit informs the MPCC that the last word in the TxFIFO (marked by setting the TLAST bit with \(\overline{\mathrm{DONE}}\) ) contains only the upper byte as valid data. However, the currently available DMACs have no method to inform the MPCC that the last word of the message contains a single byte and MPU intervention is necessary.

To handle byte-oriented protocols with DMAC, an R68561 in the byte mode or the R68560 (byte mode only) should be used.
\begin{tabular}{|l|l|l|l|l|l|}
\hline LEADING PAD & SYN & SYN & \multicolumn{5}{|c|}{\begin{tabular}{l} 
MESSAGE \\
\(5-8\) BITS \\
(AR1)
\end{tabular}} & \begin{tabular}{ll}
\(5-8\) BITS \\
(AR2)
\end{tabular} & \begin{tabular}{l} 
(AR2)
\end{tabular} & & \\
\hline
\end{tabular}

Figure 9. Character Oriented Protocol Format


Figure 10. Typical Interface to \(\mathbf{6 8 0 0 0}\)-Based System
4-108




Figure 12. MPCC Read Cycle Timing

SOURCE


NOTES:
1. BYTE MODE WHEN CONNECTED TO AO ON 68008 bUS.
2. WORD MODE WHEN CONNECTED TO UDS ON 68000 BUS.
3. TIMING MEASUREMENTS ARE REFERENCED TO AND FROM A LOW VOLTAGE OF 0.8 VOLTS AND A HIGH VOLTAGE OF 2.0 VOLTS, UNLESS OTHERWISE NOTED.
4. SEE ADDITIONAL NOTES ON PAGE 32.

Figure 13. MPCC Write Cycle Timing


Figure 14. MPCC to Memory DMA Transfer Cycle Timing (Receiver DMA Mode)


4

Figure 15. Memory to MPCC DMA Transfer Cycle Timing (Transmitter DMA Mode)


Figure 16. Interrupt Request Cycle Timing


Figure 17. Serial Interface

HIGH SPEED APPLICATION


LOW SPEED APPLICATION (RS-232 COMPATIBLE)


Figure 18. Serial Interface Timing


NOTE:
timing measurements are referenced to and from a low voltage of 0.8 Volts and a high voltage OF 2.0 VOLTS, UNLESS OTHERWISE NOTED.

Figure 19. Serial Interface Echo Mode Timing

AC CHARACTERISTICS
\(\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.\) to \(\left.70^{\circ} \mathrm{C}\right)\)
\begin{tabular}{|c|c|c|c|c|c|}
\hline Number & Parameter & Symbol & Min & Max & Unit \\
\hline 1 & R/ \(\bar{W}\) High to \(\overline{C S}\), \(\overline{D S}\) Low & \(\mathrm{t}_{\text {RHSL }}\) & 0 & - & ns \\
\hline 2 & Address Valid to CS, \(\overline{\mathrm{DS}}\) Low & \(\mathrm{t}_{\text {AVSL }}\) & 30 & - & ns \\
\hline 31 & \(\overline{\mathrm{CS}}\) Low to \(\overline{\text { DTACK }}\) Low & \(\mathrm{t}_{\text {CLDAL }}\) & 0 & 60 & ns \\
\hline 41 & \(\overline{\mathrm{CS}}, \overline{\mathrm{DS}}\) Low to Data Valid & \(\mathrm{t}_{\text {SLDV }}\) & 0 & 140 & ns \\
\hline 5 & \(\overline{\mathrm{DS}}\) High to Data Invalid & \(\mathrm{t}_{\text {SHDXR }}\) & 10 & 150 & ns \\
\hline 6 & \(\overline{\text { DS High to } \overline{\text { DTACK }} \text { High }}\) & \(\mathrm{t}_{\text {SHDAT }}\) & 0 & 40 & ns \\
\hline 7 & \(\overline{\mathrm{DS}}\) High to Address Invalid & \(t_{\text {SHAI }}\) & 20 & - & ns \\
\hline 8 & \(\overline{\mathrm{CS}}, \overline{\mathrm{DS}}\) High to R/ \(\bar{W}\) Low & \(t_{\text {SHRL }}\) & 20 & - & ns \\
\hline 9 & R/̄W Low to \(\overline{\mathrm{CS}}, \overline{\mathrm{DS}}\) Low & \(\mathrm{t}_{\text {RLSL }}\) & 0 & - & ns \\
\hline 10 & \(\overline{\mathrm{CS}}\) High, \(\overline{\mathrm{DS}}\) High to R/ \(\bar{W}\) High & \(t_{\text {SHRH }}\) & 20 & - & ns \\
\hline 11 & Data Valid to \(\overline{C S}, \overline{\mathrm{DS}}\) High & \(\mathrm{t}_{\text {DVSH }}\) & 60 & - & ns \\
\hline 12 & \(\overline{\mathrm{CS}}, \overline{\mathrm{DS}}\) High to Data Invalid & \(\mathrm{t}_{\text {SHDXW }}\) & 0 & - & ns \\
\hline 17 & \(\overline{\text { DTC }}\) Low to \(\overline{\mathrm{DS}}\) High & \(\mathrm{t}_{\text {CLSH }}\) & 60 & - & ns \\
\hline 18 & \(\overline{\text { DACK }}\) Low to Data Valid, \(\overline{\text { DONE }}\) Low & \(\mathrm{t}_{\text {ALDV }}\) & 0 & 140 & ns \\
\hline 19 & \(\overline{\mathrm{DS}}\) High to Data Invalid & \(\mathrm{t}_{\text {SHDXDR }}\) & 10 & 150 & ns \\
\hline 21 & Data Valid to \(\overline{\mathrm{DS}}\) High & \(t_{\text {DVSH }}\) & 60 & - & ns \\
\hline 22 & \(\overline{\mathrm{DS}}\) High to Data Invalid & \(\mathrm{t}_{\text {SHDXDW }}\) & 0 & - & ns \\
\hline 25 & \(\overline{\text { IACK Low to } \overline{\text { DTACK }} \text { Low }}\) & \(\mathrm{t}_{\text {IALAL }}\) & 0 & 40 & ns \\
\hline 26 & \(\overline{\mathrm{IACK}}, \overline{\mathrm{DS}}\) Low to Data Valid & t IALDV & 0 & 140 & ns \\
\hline 27 & \(\overline{\mathrm{DS}}\) High to Data Invalid & \(\mathrm{t}_{\text {ISHDI }}\) & 10 & 150 & ns \\
\hline 28 & \(\overline{\text { IACK }}\) High to \(\overline{\text { DTACK }}\) High & \(\mathrm{t}_{\text {IAHDAT }}\) & 0 & 40 & ns \\
\hline 30 & RxC and TxC Period & \(\mathrm{t}_{\mathrm{CP}}\) & 248 & - & ns \\
\hline 31 & TxC Low to TxD Delay & \(\mathrm{t}_{\text {TCLTD }}\) & 0 & 200 & ns \\
\hline 32 & RxC Low to RxD Transition (Hold) & \(\mathrm{t}_{\text {RCLRD }}\) & 0 & - & ns \\
\hline 33 & RxD Transition to RxC Low (Setup) & \(\mathrm{t}_{\text {RDRCL }}\) & 30 & - & ns \\
\hline 34 & RxD to TxD Delay (Echo Mode) & \(\mathrm{t}_{\text {RDTD }}\) & - & 200 & ns \\
\hline 35 & R/ \(\bar{W}\) Low to \(\overline{\text { DACK }}\) Low (Setup) & \(\mathrm{t}_{\text {RLAL }}\) & 0 & - & ns \\
\hline 36 & \(\overline{\text { DACK }}\) High to DONE High & \(\mathrm{t}_{\text {AHDH }}\) & 0 & - & ns \\
\hline \(37^{2,3}\) & \(\overline{\text { RDSR }}\) Pulse Width & \(t_{\text {RPW }}\) & 1 & - & clock period \\
\hline 382, 4 & TDSR Pulse Width & \({ }_{\text {t }}\) TPW & 1 & - & clock period \\
\hline
\end{tabular}

Notes:
1. For read cycle timing, the MPCC asserts \(\overline{\text { DTACK }}\) within the MPU S 4 clock low setup time requirement and establishes valid data (Data In ) within the MPU S6 clock low setup time requirement.
2. For synchronous protocols, this is one full serial clock period of RxC for \(\overline{R D S R}\) and \(T x C\) for \(\overline{T D S R}\).
3. For asynchronous protocols, \(\overline{\operatorname{RDSR}}\) is asserted for two system clock periods for a prescale factor of 2 and for three system clock periods for a prescale factor of 3.
4. For asynchronous protocols, \(\overline{\mathrm{TDSR}}\) is asserted for a period of one-half the baud rate.

\section*{*NOTES TO FIGURES 12-16.}

Address, \(\overline{L D S}, \overline{U D S}\) and \(R / \bar{W}\) are signals generated by the 68000 MPU and its bus timing prevails. \(\overline{\mathrm{CS}}\) is derived with external logic from the address bus and generally an Address Strobe ( \(\overline{\mathrm{AS}}\) ) signal from the MPU. It will naturally be delayed somewhat from the \(\overline{A S}\) signal. The active read or write cycle timing in the MPCC is during the summation of the active signal time, i.e., the last active signal starts the timing sequence. For an MPCC read cycle, for example, the data out parameter ( \(\mathrm{t}_{\text {sLov, }}\) item 4) will be available 0 to 140 ns from the falling edge of CS or LDS whichever is active last. The data out parameter
( \(\mathrm{t}_{\text {SHDXR }}\), item 5) will remain valid for 0-150 ns after the negation of \(\overline{C S}\) or \(\overline{\text { LDS }}\), whichever is negated first.

The minimum pulse widths for \(\overline{\mathrm{CS}}, \overline{\mathrm{LDS}}, \overline{\mathrm{UDS}}, \overline{\mathrm{DACK}}, \overline{\mathrm{IACK}}\) and \(\overline{\text { DTC }}\) are not specified since they are system dependent and relate to system clock timing. For example, it is apparent that the minimum active time for "AND" condition of CS and LDS is 140 ns (tslov, item 4) plus the setup time of the Data In to the receiving device if \(\overline{\mathrm{LDS}}\) high is used to strobe the data in. These same factors hold true for \(\overline{\text { UDS }}, \overline{\mathrm{DACK}}\) and \(\overline{\mathrm{IACK}}\). If \(\overline{\mathrm{DTC}}\) is used it must be true a minimum of 60 ns before the rising edge of \(\overline{\mathrm{LDS}}\) and thus this is the minimum pulse width. It may be connected to ground.

\section*{ABSOLUTE MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.3 to +7.0 & V \\
\hline Input Voltage & \(\mathrm{V}_{\text {IN }}\) & -0.3 to +7.0 & V \\
\hline Operating Temperature Range & \(\mathrm{T}_{\mathrm{A}}\) & 0 to +70 & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\mathrm{STG}}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{THERMAL CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|}
\hline Parameter & Symbol & Value & Rating \\
\hline Thermal Resistance & \(\theta_{\mathrm{JA}}\) & & \({ }^{\circ} \mathrm{C} / \mathrm{W}\) \\
Ceramic & & 50 & \\
Plastic & & 68 & \\
\hline
\end{tabular}

\section*{DC CHARACTERISTICS}
\(\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.\) to \(70^{\circ} \mathrm{C}\) unless otherwise noted)
\begin{tabular}{|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Max & Unit & Test Conditions \\
\hline Input High Voltage All Inputs & \(\mathrm{V}_{\mathrm{IH}}\) & 2.0 & \(\mathrm{V}_{\mathrm{cc}}\) & V & \\
\hline Input Low Voltage All Inputs & \(\mathrm{V}_{\text {IL }}\) & -0.3 & +0.8 & V & \\
\hline Input Leakage Current R/ \(\bar{W}, \overline{R E S E T}, \overline{C S}\), A1-A4 & \(\mathrm{I}_{\mathrm{N}}\) & - & 10.0 & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{IN}}=0 \text { to } 5.25 \mathrm{~V} \\
& \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}
\end{aligned}
\] \\
\hline Three-State (Off State) Input Current \(\overline{\mathrm{IRQ}}, \overline{\mathrm{DTACK}}, \mathrm{DO}\)-D15 & \(\mathrm{T}_{\text {TSI }}\) & - & 10.0 & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& V_{\text {IN }}=0.4 \text { to } 2.4 \mathrm{~V} \\
& V_{C C}=5.25 \mathrm{~V}
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& \text { Output High Voltage } \\
& \overline{\text { RDSR }, ~} \overline{\text { TDSR, }} \overline{\mathrm{IRQ}}, \overline{\mathrm{DTACK}}, \mathrm{DO}-\mathrm{D} 15, \overline{\mathrm{DSR}}, \overline{\mathrm{DTR}}, \overline{\mathrm{RTS}}, \\
& \text { TxD, TxC }
\end{aligned}
\] & \(\mathrm{V}_{\mathrm{OH}}\) & \(\mathrm{V}_{\text {Ss }}+2.4\) & - & V & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\
& \mathrm{I}_{\text {LOAD }}=-400 \mu \mathrm{~A} \\
& \mathrm{C}_{\text {LOAD }}=130 \mathrm{pF}
\end{aligned}
\] \\
\hline BCLK & \(\mathrm{V}_{\mathrm{OH}}\) & \(\mathrm{V}_{\text {SS }}+2.4\) & - & V & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\
& \mathrm{~L}_{\text {LOAD }}=0 \\
& C_{\text {LOAD }}=30 \mathrm{pF}
\end{aligned}
\] \\
\hline \begin{tabular}{l}
Output Low Voltage \\
\(\overline{R D S R}, \overline{T D S R}, \overline{I R Q}, \overline{D T A C K}\) DO-D15, \(\overline{D S R}, \overline{D T R}, \overline{R T S}\), TxD, TxC, BCLK,
\end{tabular} & \(V_{\text {OL }}\) & - & 0.5 & V & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\
& \mathrm{I}_{\mathrm{LOAD}}=3.2 \mathrm{~mA}
\end{aligned}
\] \\
\hline DONE & \(\mathrm{V}_{\text {OL }}\) & - & 0.5 & V & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\
& \mathrm{I}_{\text {LOAD }}=8.8 \mathrm{~mA}
\end{aligned}
\] \\
\hline Internal Power Dissipation & Pint & - & 1 & W & \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) \\
\hline Input Capacitance & \(\mathrm{Cl}_{\text {IN }}\) & - & 13 & pF & \[
\begin{aligned}
& V_{I N}=0 \mathrm{~V} \\
& T_{A}=25^{\circ} \mathrm{C} \\
& \mathrm{f}=1 \mathrm{MHz}
\end{aligned}
\] \\
\hline
\end{tabular}

PACKAGE DIMENSIONS - 40-PIN DIP


\section*{R68560, R68561}

\section*{PACKAGE DIMENSIONS - 48-PIN DIP}

\section*{48-PIN CERAMIC DIP}

\begin{tabular}{|c|c|c|c|c|}
\hline & \multicolumn{2}{|c|}{ MILLIMETERS } & \multicolumn{2}{c|}{ INCHES } \\
\cline { 2 - 5 } DIM & MIN & MAX & MIN & MAX \\
\hline A & 60.35 & 61.57 & 2.376 & 2.424 \\
\hline B & 14.73 & 15.24 & 0.580 & 0.600 \\
\hline C & 3.30 & 4.32 & 0.130 & 0.170 \\
\hline D & 0.38 & 0.53 & 0.015 & 0.021 \\
\hline F & 1.02 & 1.52 & 0.040 & 0.060 \\
\hline G & \multicolumn{2}{|c|}{2.54} & BSC & 0.100 \\
\hline BSC \\
\hline J & 0.20 & 0.30 & 0.008 & 0.012 \\
\hline K & 2.54 & 4.06 & 0.100 & 0.160 \\
\hline L & 14.99 & 15.49 & 0.590 & 0.610 \\
\hline M & \(0^{\circ}\) & \(10^{\circ}\) & \(0^{\circ}\) & \(10^{\circ}\) \\
\hline N & 1.02 & 1.52 & 0.040 & 0.060 \\
\hline
\end{tabular}

\section*{48-PIN PLASTIC DIP}


\section*{Section 5 \\ Intelligent Display Controllers}
Page
Product Family Overview ..... 5-2
10937 and 10957 Alphanumeric Display Controller ..... 5-3
10938 and 10939 Dot Matrix Display Controller ..... 5-11
10939, 10942 and 10943 Dot Matrix Display Controller ..... 5-21
10941 and 10939 Alphanumeric and Bargraph Display Controller ..... 5-31
10951 Bargraph and Numeric Display Controller ..... 5-41
10955 Segmented Display Controller/Driver ..... 5-51

\section*{10937 and 10957 \\ Alphanumeric Display Controller}

\section*{DESCRIPTION}

The 10937 and 10957 Alphanumeric Display Controllers, two of the Rockwell Intelligent Display Controller products, are MOS/LSI general purpose display controllers designed to interface to segmented displays (vacuum fluorescent, or LED).

The 10937 or 10957 will drive displays with up to 16 characters with 14 or 16 segments plus a decimal point and comma tail. Segment decoding within each device provides for the ASCII character set (upper case only). No external drive circuitry is required for displays that operate on 20 ma of drive current up to 50 volts. A \(16 \times 64\)-bit segment decoder provides internal ASCII character set decoding for the display.

The 10937 and 10957 are identical with the exception that the 10957 has two additional decodings for the decimal point and comma tail.

\section*{FEATURES}
- 16 character display driver with decimal point and comma tail
- 14 or 16 segment drivers
- Up to 66 kHz data rate
- Direct digit drive of 20 ma at 50 volts
- Supports vacuum fluorescent, or LED displays
- \(64 \times 16\)-bit PLA provides segment decoding for ASCII character set (all caps only)
- Serial data input for 8 -bit display and control data words.
- 40-Pin DIP

ORDERING INFORMATION
\begin{tabular}{|l|c|c|c|}
\hline \begin{tabular}{c} 
Part \\
Number
\end{tabular} & \begin{tabular}{c} 
Package \\
Type
\end{tabular} & \begin{tabular}{c} 
Drive \\
Voltage
\end{tabular} & \begin{tabular}{c} 
Temperature \\
Range ( \(\left.{ }^{\circ} \mathrm{C}\right)\)
\end{tabular} \\
\hline 109X7P-40 & Plastic & 40 V & 0 to +70 \\
109X7P-50 & Plastic & 50 V & 0 to +70 \\
109X7PE-40 & Plastic & 40 V & -40 to +85 \\
109X7PE-50 & Plastic & 50 V & -40 to +85 \\
\hline \\
Note: \(\mathrm{X}=3\) or 5 \\
\hline
\end{tabular}


10937 and 10957 Block Diagram

\section*{INTERFACE DESCRIPTION}

Pin Functions
\begin{tabular}{|l|c|l|}
\hline Signal Name & Pin No. & \multicolumn{1}{|c|}{ Function } \\
\hline VSS & 1 & Power and signal reference \\
AD16-AD1 & \(2-17\) & Digits 16 through 1 driver outputs \\
VDD & 18 & DC power connection \\
A & 19 & A clock output used for testing \\
POR & 20 & Power-on reset input \\
DATA & 21 & Serial data input \\
SCLK & 22 & Serial data clock input \\
SGA-SGP & \(23-38\) & Segments A through P driver outputs \\
TAIL & 39 & Comma tail driver output \\
PNT & 40 & Decimal point driver output \\
\hline
\end{tabular}

\section*{SPECIFICATIONS}

\section*{MAXIMUM RATINGS*}

All voltages are specified relative to \(\mathrm{V}_{\mathrm{SS}}\).
\begin{tabular}{|l|l|l|r|l|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Min & Max & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{DD}}\) & +0.3 & -20 & V \\
Input Voltage & \(\mathrm{V}_{\text {IN }}\) & +0.3 & -20 & V \\
Output Voltage & \(\mathrm{V}_{\mathrm{OUT}}\) & +0.3 & -50 & V \\
Operating Current & \(\mathrm{I}_{\mathrm{DD}}\) & & 7 & mA \\
Output Current Digits & \(\mathrm{I}_{\mathrm{SD}}\) & & 20 & mA \\
Output Current Segments & \(\mathrm{I}_{\mathrm{SS}}\) & & 10 & mA \\
Operating Temperature & & & & \\
Commercial & \(\mathrm{T}_{\mathrm{C}}\) & 0 & +70 & \({ }^{\circ} \mathrm{C}\) \\
Industrial & \(\mathrm{T}_{\mathrm{I}}\) & -40 & +85 & \({ }^{\circ} \mathrm{C}\) \\
Storage Temperature & \(\mathrm{T}_{\mathrm{STG}}\) & -55 & +125 & \({ }^{\circ} \mathrm{C}\) \\
Input Capacitance & \(\mathrm{C}_{\mathrm{IN}}\) & & 5 & pF \\
Output Capacitance & \(\mathrm{C}_{\mathrm{OUT}}\) & & 10 & pF \\
\hline
\end{tabular}


Pin Configuration
*NOTE: Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Parameter} & \multicolumn{3}{|c|}{Limits ( \(\mathbf{V}_{\mathbf{S s}}=0\) )} & \multicolumn{3}{|c|}{Limits ( \(\mathrm{V}_{S S}=+5 \mathrm{~V}\) )} & \multirow[b]{2}{*}{Conditions} & \multirow[b]{2}{*}{Unit} \\
\hline & Min. & Typ. & Max. & Min. & Typ. & Max. & & \\
\hline Supply Voltage ( \(\mathrm{V}_{\mathrm{DD}}\) )
Power dissipation & -16.5 & \[
\begin{gathered}
\hline-15.0 \\
40
\end{gathered}
\] & \[
-13.5
\] & -11.5 & \[
-10.0
\] & \[
\begin{gathered}
-8.5 \\
100
\end{gathered}
\] & & V \\
\hline Input DATA, SCLK, & & & & & & & & V \\
\hline Logic " 1 ", & -1.0 & & +0.3 & +4.0 & & +5.3 & & V \\
\hline Logic "0" & \(\mathrm{V}_{\mathrm{DD}}\) & & -4.2 & \(V_{D D}\) & & +0.8 & & \\
\hline Input POR & & & & & & & & \\
\hline Logic "1" & -3.0 & & +0.3 & +2.0 & & +5.3 & & \\
\hline Logic "0" & \(V_{D D}\) & & -10.0 & \(V_{D D}\) & & -5.0 & & \\
\hline Output Digit and & & & & & & & & \\
\hline Segment Strobes Driver On & & & & & & & & \\
\hline Commercial & & & -1.5 & & & +3.5 & & V \\
\hline Industrial & & & -1.7 & & & +3.3 & At 10 mA & V \\
\hline Driver Off 109X7-40 & & & -40 & & & -35 & Actual value & V \\
\hline Driver Off 109X7-50 & & & -50 & & & -45 & determined by external circuit & V \\
\hline Output Leakage & & & 10 & & & 10 & Per driver when & \(\mu \mathrm{A}\) \\
\hline Input Leakage & & & 10 & & & 10 & driver is off & \(\mu \mathrm{A}\) \\
\hline \multicolumn{9}{|l|}{Notes: All outputs require puldown resistors. \(\mathrm{X}=3\) or 5 depending on device.} \\
\hline
\end{tabular}

\section*{AC CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ & Max \\
\hline SCLK Clock & & & & \\
On Time & \(T_{\text {on }}\) & 1.0 & & \\
Off Time & \(T_{\text {off }}\) & 1.0 & & \\
Data Input Sample Time & \(T_{\text {boff }}\) & 200.0 & & \\
Before SCLK Clock Off & \(T_{\text {aoff }}\) & 100 & & \\
After SCLK Clock Off & & & & \\
\hline ns \\
\hline
\end{tabular}


SCLK and Serial Data Timing


SCLK and Serial Data (Control Word) Examples


Data Word LSB/MSB Timing


\section*{FUNCTIONAL DESCRIPTION}

The 10937 or 10957 is a general purpose display controller for multiplexed, segmented displays with up to 16 character positions and 14 or 16 segments, plus decimal point and comma tail. No external drive circuitry is needed for displays requiring up to 20 ma of drive current up to 50 volts. All timing signals required to control the display are generated in the 10937 or 10957 device without any refresh input from the host processor.

Input data is loaded into the Display Data Buffer via the Serial Data Input (Data) channel. Internal timing and control blocks synchronize the segment and digit output signals to provide the proper timing for the multiplexing operation. A \(16 \times 64\)-bit PLA is provided for segment decoding for the full ASCII character set (upper case only).

Input data is loaded into the 10937 or 10957 ADC as a series of 8 -bit words with the most significant bit (MSB), bit 7, first. If bit 7 of any word loaded is a logic 1 (this bit is referred to as the control bit C ), the loaded word is a control data word. If the \(C\) bit of any word is a logic 0 , the loaded word is a display data word. The following paragraphs describe the format and functions of these control and display data words.

\section*{INPUT CONTROL DATA WORDS}

When the C -Bit (bit 7) of the 8 -bit input word is a logic 1 , bits 5 and 6 are decoded into one of four control commands while data associated with the command are extracted from bits 0-4 (see Table 1). The four control codes perform the following display functions:
- Load the Display Data Buffer pointer,
- Load the Digit Counter,
- Load the Duty Cycle register,
- Enable the Test Mode.

Table 1 lists the control codes and their functions.

\section*{Buffer Pointer Control}

The Buffer Pointer Control code allows the Display Data Buffer pointer to be set to any digit position so that individual characters may be modified. The Buffer Pointer is loaded with a decimal equivalent value 2 less than the desired value (i.e., to point to the digit controlled by AD6 of the display, a value of 4 is entered). See Table 2 for a complete list of the Buffer Pointer values.

Table 2. Buffer Pointer Control Codes
\begin{tabular}{|c|c|c|}
\hline Hex Code & Pointer Value & Character Controlled By \\
\hline A0 & 0 & AD2 \\
A1 & 1 & AD3 \\
A2 & 2 & AD4 \\
A3 & 3 & AD5 \\
A4 & 4 & AD6 \\
A5 & 5 & AD7 \\
A6 & 6 & AD8 \\
A7 & 7 & AD9 \\
A8 & 8 & AD10 \\
A9 & 9 & AD11 \\
AA & 10 & AD12 \\
AB & 11 & AD13 \\
AC & 12 & AD14 \\
AD & 13 & AD15 \\
AE & 14 & AD16 \\
AF & 15 & AD1 \\
\hline
\end{tabular}

\section*{Digit Counter Control}

The Digit Counter Control code is normally used only during initialization routines to define the number of character positions to be controlled. This code maximizes the duty cycle for any display. If 16 characters are to be controlled, enter a value of 0 (zero). Otherwise, enter the value desired.

\section*{Duty Cycle Control}

The Duty Cycle Control code is used to turn the display on and off, and to adjust display brightness. As shown in the block diagram, the time slot for each character is 32 clock cycles. The segment and digit drivers for each character are on for a maximum of 31 cycles with a 1 cycle inter-digit off-time. The Duty Cycle Control code contains a 5-bit numeric field which modifies the on-time for the driver outputs from 0 to 31 cycles. A duty cycle of 0 puts both the segment and digit drivers into the off state.

\section*{Test Mode Enable}

The Test Mode Enable code is a device test function only. If executed, it will lock the device in the Test Mode. Once locked in, the device can only be removed from Test Mode by performing a power-on reset.

If this mode is activated, the digit time is reduced from 32 to 4 clock cycles to speed up the output driver sequencing time for ease in testing.

\section*{INPUT DISPLAY DATA WORDS}

Display data words are loaded as 8-bit ASCII format codes. The 64 codes available (with the C -bit set to 0 to indicate a display data word) are shown in Table 3 with their corresponding ASCII characters.

Table 1. Control Data Words
\begin{tabular}{|c|c|c|}
\hline \multicolumn{2}{|c|}{8-Bit Control Word} & \multirow[b]{2}{*}{Function} \\
\hline C-Bit (Bit 7) & 7-Bit Code (Bits 6-0) & \\
\hline \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 1
\end{aligned}
\] & 010NNNN \({ }^{(1)}\) 100NNNN \({ }^{(1)}\) 11NNNNN \({ }^{(2)}\) OONNNNN \({ }^{(3)}\) & BUFFER POINTER CONTROL (Position of character to be changed) DIGIT COUNTER CONTROL (Number of characters to be output) DUTY CYCLE CONTROL (On/off and brightness control) TEST MODE ENABLE (Not a user function) \\
\hline \multicolumn{2}{|l|}{\begin{tabular}{l}
Notes: 1. NNNN is a 4-bit binary value representing the digit number to be loaded. \\
2. NNNNN is a 5 -bit binary value representing the number of clock cycles each digit is on.
\end{tabular}} & 3. This code is a device test function only. If executed it will lock the device in the test mode. Once locked in, the device can only be removed from Test Mode by performing a power-on reset. \\
\hline
\end{tabular}

Sixteen display data words must be entered to completely load the Display Data Buffer. The Buffer Pointer is automatically incremented before each data word is stored in the Display Buffer except for decimal point and comma words. These do not cause the Buffer Pointer to increment and thus are always associated with the previous character entered. To select the next character
position to be loaded out of the normal sequence, use the Buffer Pointer Control command before entering the display data word. It is not necessary to use the Buffer Pointer Control command to cycle back to position 1 when less than 16 character positions are being used.


Figure 1. Display Scan Timing Diagram (Duty Cycle)

Table 3. Character Assignments for Display Data Words
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multicolumn{2}{|l|}{DATA WORD} & \multirow{2}{*}{CHARACTER} & \multicolumn{2}{|l|}{DATA WORD} & \multirow{2}{*}{CHARACTER} & \multicolumn{2}{|l|}{DATA WORD} & \multirow{2}{*}{CHARACTER} & \multicolumn{2}{|l|}{DATA WORD} & \multirow{2}{*}{CHARACTER} \\
\hline BINARY & HEX & & BINARY & HEX & & BINARY & HEX & & BINARY & HEX & \\
\hline OX000000 & 00 & (1) & 0X010000 & 10 & P & 0X100000 & 20 & & OX110000 & 30 & 0 \\
\hline \(0 \times 000001\) & 01 & A & \(0 \times 010001\) & 11 & Q & 0X100001 & 21 & \(!\) & 0X110001 & 31 & 1 \\
\hline \(0 \times 000010\) & 02 & B & \(0 \times 010010\) & 12 & R & 0X100010 & 22 & " & 0X110010 & 32 & 2 \\
\hline \(0 \times 000011\) & 03 & C & \(0 \times 010011\) & 13 & S & 0X100011 & 23 & \# & 0X110011 & 33 & 3 \\
\hline \(0 \times 000100\) & 04 & D & \(0 \times 010100\) & 14 & T & 0X100100 & 24 & \$ & 0X110100 & 34 & 4 \\
\hline \(0 \times 000101\) & 05 & E & \(0 \times 010101\) & 15 & U & 0X100101 & 25 & \% & 0X110101 & 35 & 5 \\
\hline \(0 \times 000110\) & 06 & F & \(0 \times 010110\) & 16 & V & 0X100110 & 26 & \& & 0X110110 & 36 & 6 \\
\hline 0X000111 & 07 & G & \(0 \times 010111\) & 17 & W & 0X100111 & 27 & , & 0X110111 & 37 & 7 \\
\hline 0X001000 & 08 & H & 0X011000 & 18 & X & 0X101000 & 28 & ( & 0X111000 & 38 & 8 \\
\hline \(0 \times 001001\) & 09 & I & 0X011001 & 19 & Y & 0X101001 & 29 & ) & 0X111001 & 39 & 9 \\
\hline \(0 \times 001010\) & OA & \(J\) & \(0 \times 011010\) & 1 A & Z & 0X101010 & 2 A & * & 0X111010 & 3A & : \\
\hline \(0 \times 001011\) & OB & K & \(0 \times 011011\) & 1 B & [ & \(0 \times 101011\) & 2 B & + & 0X111011 & 3B & ; \\
\hline \(0 \times 001100\) & OC & L & \(0 \times 011100\) & 1 C & 1 & 0X101100 & 2 C & , & 0X111100 & 3 C & \(<\) \\
\hline \(0 \times 001101\) & OD & M & \(0 \times 011101\) & 1D & ] & 0x101101 & 2D & - & 0X111101 & 3D & \(=\) \\
\hline 0X001110 & OE & N & \(0 \times 011110\) & 1E & \(\wedge\) & 0X101110 & 2 E & - & 0X111110 & 3E & > \\
\hline \(0 \times 001111\) & OF & 0 & 0X011111 & 1F & A & 0X101111 & 2 F & \(\backslash\) & \(0 \times 111111\) & 3F & ? \\
\hline \multicolumn{12}{|l|}{Note: X means this bit (bit 7) is a "don't care" bit except for PNT and TAIL on 10957 only. The hex codes shown assume bit 7 is a zero.} \\
\hline
\end{tabular}

\section*{POWER-ON RESET (POR)}

The Power-On Reset (POR) initializes the internal circuits of the 10937 or 10957 ADC when power ( \(\mathrm{V}_{\mathrm{DD}}\) ) is applied. The following conditions are established after a Power-On Reset:
a. The Digit Drivers (AD1 - AD16) are in the off state (floating).
b. The Segment Drivers (SGA-SGP) are in the off state (floating). This includes PNT and Tail.
c. The Duty Cycle is set to 0 .
d. The Digit Counter is set to 16 (a bit code value of 0 ).
e. The Buffer Pointer points to the character controlled by AD1.

\section*{DIGIT DRIVERS (AD1-AD16)}

The sixteen Digit Drivers (AD1 - AD16) are used to select each of the display digits sequentially during a refresh scan. Display segments will be illuminated when both the Digit Drivers and Segment Drivers for a particular character are energized simultaneously. The timing characteristics of both the digits and segments are shown in Figure 1. See POR for the Power-On Reset state of these drivers.

Table 4. Comparison of 10957 with 10937
\begin{tabular}{|c|c|c|}
\hline \begin{tabular}{c} 
Input \\
Data
\end{tabular} & \begin{tabular}{c}
10937 \\
Character
\end{tabular} & \begin{tabular}{c}
10957 \\
Character
\end{tabular} \\
\hline 2 C & \(;\) & \(;\) \\
\hline 2 E & \(\cdot\) & \(\cdot\) \\
\hline 6 C & \(;\) & \(\cdot\) \\
\hline 6 E & \(\cdot\) & \\
\hline
\end{tabular}

\section*{SEGMENT DRIVERS (SGA-SGP)}

Sixteen (16) Segment Drivers are provided (SGA - SGP), plus the decimal point (PNT) and comma tail (TAIL). The segment outputs are internally decoded from the 8 -bit characters in the Display Data Buffer by means of a \(64 \times 16\)-bit PLA. The Segment Driver Allocations are shown in Figure 2. Data codes and their corresponding segment patterns are shown in Figure 3. Timing characteristics for the segment outputs are shown in Figure 1. See POR for the Power-On Reset state of these drivers.

\section*{NOTE}

For 14-segment displays, SGA is used for the top segment and SGF is used for the bottom segment. SGB and SGE can be floated.

\section*{TYPICAL SYSTEM HOOK-UP}

Figure 4 shows the 10937 or 10957 as it would be connected to a V-F display when driven by a host system. \(\mathrm{E}_{\mathrm{K}}\) is determined by the V-F display specifications and \(R_{C}\) is selected to provide proper biasing current for zeners. Pull down resistors \(R_{A}\) and \(R_{G}\) are determined by the interconnection capacitance between the device and the display.


Figure 2. Segment Driver Allocations


16-Segment Display


14-Segment Display
Notes: Bit 7 of the data byte is a "don't care" bit except for PNT and TAIL on 10957. Data byte hex codes shown assume bit 7 is a zero.

\footnotetext{
* = 10957 only.
}

Figure 3. Display Segment Driver Character Patterns


Figure 4. Partial System Schematic

\section*{10938 and 10939 Dot Matrix Display Controller}

\section*{DESCRIPTION}

The Rockwell 10938 and 10939 Dot Matrix Display Controller is a two-chip MOS/LSI general purpose display controller system designed to interface to dot matrix displays (vacuum-fluorescent or LED).

The two-chip set will drive displays with up to 35 anodes (dots) and up to 20 grids (characters) plus a cursor. The chips can be cascaded to drive larger displays of as many as 80 characters. An internal PLA-type decoder provides character decoding and dot pattern generation for the full 96-character ASCII set and an additional 32 special characters.

ORDERING INFORMATION
\begin{tabular}{|l|l|r|}
\hline \begin{tabular}{c} 
Part \\
Number
\end{tabular} & \begin{tabular}{c} 
Package \\
Type
\end{tabular} & \begin{tabular}{c} 
Temperature \\
Range \(\left({ }^{\circ} \mathrm{C}\right)\)
\end{tabular} \\
\hline 10938 P & Plastic & 0 to +70 \\
10938 PE & Plastic & -40 to +85 \\
10939 P & Plastic & 0 to +70 \\
10939 PE & Plastic & -40 to +85 \\
\hline
\end{tabular}

\section*{FEATURES}
- 20-character display driver cascadable to 80
- Standard \(5 \times 7\) character font.
- Separate cursor driver output
- Direct drive capability for vacuum-fluorescent displays
- \(128 \times 35\) PLA provides segment decoding for full 96 -character ASCII set, plus 32 special characters
- Serial or parallel data input for 8 -bit display and control characters
- Brightness, refresh rate, and display mode controls
- 40-pin DIP


Block Diagram of 10938 and 10939

\section*{INTERFACE DESCRIPTION}
\begin{tabular}{|l|c|l|}
\multicolumn{2}{c}{10938 Pin Functions } \\
\hline Signal Name & Pin No. & \multicolumn{1}{|c|}{ Function } \\
\hline\(V_{\text {SS }}\) & 2 & Power and signal reference \\
SG01-SG35 & \(3-25,27-38\) & Anode driver outputs \\
SCLK-DIS & 39 & Serial data shift clock \\
DATA-LOAD & 40 & Serial data output/latch control \\
\(V_{\text {DD }}\) & 1 & DC Power \\
\(V_{\text {GG }}\) & 26 & Display voltage \\
\hline
\end{tabular}


10938 Pin Configuration

\section*{SPECIFICATIONS}

\section*{ABSOLUTE MAXIMUM RATINGS*}

Voltages are referenced to \(\mathrm{V}_{\mathrm{SS}}\)
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline \begin{tabular}{l} 
Operating Temperature \\
Commercial \\
Industrial \\
Storage Temperature
\end{tabular} & Tc & 0 to +70 & \({ }^{\circ} \mathrm{C}\) \\
\hline Operating Voltage & Ti & -40 to +85 & \({ }^{\circ} \mathrm{C}\) \\
\hline Operating Display Voltage & \(\mathrm{V}_{\mathrm{DD}}\) & -22 to +125 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}

10939 Pin Functions
\begin{tabular}{|l|c|l|}
\hline Signal Name & Pin No. & \multicolumn{1}{|c|}{ Function } \\
\hline V SS \(^{\prime 2}\) & 36 & Power and signal reference \\
V \(_{\text {DD }}\) & 37 & DC Power \\
CLOCK & 38 & Synchronization Clock \\
CURSOR & 14 & Cursor drive output \\
MASTER & 39 & Master/Slave Mode control \\
SIP & 3 & Sync Input \\
SOP & 2 & Sync Output \\
DO-D7 & \(6-13\) & Serial or parallel data input \\
LD & 5 & Input data strobe \\
POR & 4 & Power-on reset \\
SCLK-DIS & 1 & Serial data shift clock \\
DATA-LOAD & 40 & Serial data output/latch control \\
STR00-STR19 & \(15-34\) & Grid Driver Outputs \\
V \(_{\text {GG }}\) & 35 & Display voltage \\
\hline
\end{tabular}


\section*{10939 Pin Configuration}
*NOTE: Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}

All voltages referenced to \(V_{S S}\)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Notes & Symbol & Min & Typ & Max & Unit \\
\hline \[
\begin{aligned}
& \text { Input Do-D7, LD, SIP } \\
& \text { Logic " } 1 \text { "' } \\
& \text { Logic " } 0 \text { " }
\end{aligned}
\] & 2 & \[
\begin{aligned}
& V_{I H} \\
& V_{I L}
\end{aligned}
\] & \[
\begin{aligned}
& -1.2 \\
& V_{D D}
\end{aligned}
\] & & \[
\begin{aligned}
& +0.3 \\
& -4.2
\end{aligned}
\] & \[
\begin{aligned}
& V \\
& V
\end{aligned}
\] \\
\hline Input POR Logic "1" Logic " 0 " & 2 & \[
\begin{aligned}
& \mathrm{V}_{\text {IHPO }} \\
& \mathrm{V}_{\text {ILPO }}
\end{aligned}
\] & \[
\begin{aligned}
& -3.0 \\
& V_{D D}
\end{aligned}
\] & & \[
\begin{array}{r}
+0.3 \\
-10.0
\end{array}
\] & \[
\begin{aligned}
& \text { V } \\
& \mathrm{V}
\end{aligned}
\] \\
\hline Output SOP Logic " 1 " Logic " 0 " & 2 & \begin{tabular}{l}
\(\mathrm{V}_{\mathrm{OHSY}}\) \\
\(V_{\text {OLSY }}\)
\end{tabular} & \[
\begin{aligned}
& -1.2 \\
& V_{D D}
\end{aligned}
\] & & \[
\begin{gathered}
V_{S S} \\
-4.2
\end{gathered}
\] & \[
\begin{aligned}
& V \\
& V
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& \text { Output Grids, Cursor, and Anodes } \\
& \text { Logic " } 1 \text { " ( (I load }=10 \mathrm{~mA} 10939,2 \mathrm{~mA} 10938) \\
& \text { Logic " } 0 \text { " }\left(I_{\text {load }}=0 \mathrm{~mA}\right)
\end{aligned}
\] & 1 & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{OH}} \\
& \mathrm{~V}_{\mathrm{OL}}
\end{aligned}
\] & \[
\begin{aligned}
& -1.5 \\
& V_{G G}
\end{aligned}
\] & & \[
\stackrel{V_{\mathrm{SS}}}{0.95 \times \mathrm{V}_{\mathrm{GG}}}
\] & \[
\begin{aligned}
& \mathrm{V} \\
& \mathrm{~V}
\end{aligned}
\] \\
\hline
\end{tabular}

Notes: 1. Designates characteristics for both 10938 and 10939.
2. Designates characteristics for 10939.

\section*{OPERATING CURRENTS}
\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Parameter} & \multicolumn{2}{|c|}{Maximum} & Typical & Unit \\
\hline & Industrial
\[
\begin{aligned}
\mathrm{TA} & =-40^{\circ} \mathrm{C} \\
\mathrm{~V}_{\mathrm{DD}} & =-22 \mathrm{Vdc} \\
\mathrm{~V}_{\mathrm{GG}} & =-50 \mathrm{Vdc}
\end{aligned}
\] & Commercial
\[
\begin{gathered}
\mathrm{TA}=0^{\circ} \mathrm{C} \\
\mathrm{~V}_{\mathrm{DD}}=-22 \mathrm{Vdc} \\
\mathrm{~V}_{\mathrm{GG}}=-50 \mathrm{Vdc}
\end{gathered}
\] & \[
\begin{aligned}
\mathrm{TA} & =25^{\circ} \mathrm{C} \\
\mathrm{~V}_{\mathrm{DD}} & =-20 \mathrm{Vdc} \\
\mathrm{~V}_{\mathrm{GG}} & =-50 \mathrm{Vdc}
\end{aligned}
\] & \\
\hline \[
\begin{gathered}
10938^{1} \\
I_{D D} \\
I_{G G} \\
\hline
\end{gathered}
\] & \[
\begin{array}{r}
4.5 \\
11.2
\end{array}
\] & \[
\begin{aligned}
& 3.6 \\
& 9.0
\end{aligned}
\] & \[
\begin{aligned}
& 3.2 \\
& 8.0
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{mA} \\
& \mathrm{~mA}
\end{aligned}
\] \\
\hline ```
10939 (master)}\mp@subsup{}{}{2
    IDD
    IGG
``` & \[
\begin{array}{r}
13.6 \\
1.0
\end{array}
\] & \[
\begin{array}{r}
10.9 \\
0.8
\end{array}
\] & \[
\begin{aligned}
& 6.0 \\
& 0.5
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{mA} \\
& \mathrm{~mA}
\end{aligned}
\] \\
\hline \[
\begin{gathered}
10939 \text { (slave) }^{2} \\
\mathrm{I}_{\mathrm{DD}} \\
\mathrm{I}_{\mathrm{GG}}
\end{gathered}
\] & \[
\begin{aligned}
& 9.1 \\
& 1.0
\end{aligned}
\] & \[
\begin{aligned}
& 7.3 \\
& 0.8
\end{aligned}
\] & \[
\begin{aligned}
& 4.0 \\
& 0.5
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{mA} \\
& \mathrm{~mA}
\end{aligned}
\] \\
\hline
\end{tabular}

\section*{Notes:}
1. The 10938 has 35 internal drivers which are brought out. \(I_{G G}\) is proportional to the number of drivers on. The values given are for all 35 drivers on. Divide \(\mathrm{I}_{\mathrm{GG}}\) shown by 35 to determine \(\mathrm{I}_{\mathrm{GG}}\) for one driver.
2. The 10939 will never have more than two drivers on at any one time; one grid driver and the cursor. The values shown are for two drivers on with \(100 \%\) duty cycle.

\section*{AC CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ & Max & Unit \\
\hline \begin{tabular}{l}
GENERAL INTERFACE TIMING \\
Data Load (LD) \\
On Time \\
Off time \\
Commercial \\
Industrial \\
Cycle Time \\
Commerical \\
Industrial
\end{tabular} & \begin{tabular}{l}
\(T_{\text {Idon }}\) \\
\(T_{\text {ldoff }}\) \\
\(T_{\text {Idcyc }}\)
\end{tabular} & \[
\begin{array}{r}
1.0 \\
40.0 \\
44.5 \\
60.0 \\
66.7
\end{array}
\] & & & \begin{tabular}{l}
\(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\) \(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\) \(\mu \mathrm{S}\)
\end{tabular} \\
\hline \begin{tabular}{l}
SERIAL INTERFACE TIMING \\
Serial Clock (D1) \\
On Time \\
Off Time \\
Cycle Time \\
Serial Clock (DO) \\
Set-up Time \\
Hold Time \\
Serial Clock to LD Time \\
LD to Serial Clock
\end{tabular} & \begin{tabular}{l}
\(\mathrm{T}_{\text {scon }}\) \\
\(T_{\text {scoff }}\) \\
\(T_{\text {sccyc }}\) \\
\(T_{\text {ssetup }}\) \\
\(T_{\text {shold }}\) \\
\(T_{s l}\) \\
\(T_{\text {Is }}\)
\end{tabular} & \[
\begin{gathered}
1.0 \\
1.0 \\
2.0 \\
\\
400 \\
400 \\
1.0 \\
1.0
\end{gathered}
\] & & 20.0 & \begin{tabular}{l}
\(\mu \mathrm{S}\) \(\mu \mathrm{S}\) \(\mu \mathrm{S}\) \\
ns ns \(\mu \mathrm{S}\) \(\mu \mathrm{S}\)
\end{tabular} \\
\hline PARALLEL INTERFACE TIMING
```

Parallel Data (D0-D7)
Set-up Time
Hold Time

``` & \begin{tabular}{l}
\(T_{\text {psetup }}\) \\
\(T_{\text {phold }}\)
\end{tabular} & \[
200^{0}
\] & & & \[
\begin{aligned}
& \text { ns } \\
& \text { ns }
\end{aligned}
\] \\
\hline
\end{tabular}

\section*{TIMING WAVEFORMS}


Serial Interface Timing Waveforms


Parallel Interface Timing Waveforms

\section*{FUNCTIONAL DESCRIPTION}

Once the display buffer has been loaded from the host processor, the 10938/10939 system generates all timing signals required to control the display.

Input data is loaded into the Display Data Buffer as a series of 8 -bit words via the Serial or Parallel Data Input channel on the 10939. Internal timing and control logic synchronize the digit output signals with the Serial Data and Load signals to the 10938 to provide the proper timing for the multiplexing operation. A \(128 \times 35\) bit PLA is provided for decoding the full 96 character ASCII set, plus 32 special characters.

The parallel data input mode is implemented by toggling any of data lines D2-D7 after POR has gone low. Once the parallel data load mode has been implemented, a power-on reset procedure must be performed to return to serial data load mode. Parallel data transfer is accomplished by putting the command or display data on the data lines, then pulsing the LD line. The load cycle time must be at least \(60 \mu \mathrm{~s}\) with the LD line set high for at least one \(\mu \mathrm{s}\) and held low for at least \(40 \mu \mathrm{~s}\).

The serial data input mode is implemented during the poweron reset procedure. In those systems using serial mode, ports D2-D7 should be tied low to prevent the inadvertent implementation of the parallel load mode. Serial data bytes are shifted into a data buffer MSB first on line D0 using line D1 as the serial clock. The last eight bits clocked in are latched into the display controller by a pulse on the LD line. The cycle time for each data bit is \(2 \mu \mathrm{~s}\) and the load time for each byte is \(60 \mu \mathrm{~s}\).

Input data may be Control or Display data. The following paragraphs describe the format and functions of these control and display data words.

\section*{CONTROL DATA WORDS}

Control data words are used to select the operating parameters of the display controller. They must be preceded by a Control Prefix word ( 0000 0001, hexadecimal 01) to be distinguished from Display Data words.

\section*{Buffer Pointer Control}

The Buffer Pointer Control code sets the Display Data Buffer pointer. The lower 5 bits of the code are loaded into the buffer pointer (see Table 2).

Table 1. Control Word Assignments
\begin{tabular}{|c|l|}
\hline Hex Value & \multicolumn{1}{|c|}{ Function } \\
\hline 00 & Not used \\
01 & Load 01 into Data Buffer \\
02 & Not used \\
03 & Not used \\
04 & Not used \\
05 & Set digit time to 16 cycles per grid \\
06 & Set digit time to 32 cycles per grid \\
07 & Set digit time to 64 cycles per grid \\
08 & Enable Normal Display Mode (MSB in data words \\
& is used for cursor control only) \\
09 & Enable Blank Mode (data words with MSB = 1 will \\
& be blanked and cursor will be on) \\
\(0 A\) & Enable Inverse Mode (data words with MSB = 1 \\
& will be "inversed" and cursor will be on) \\
\(0 B\) & Not used \\
\(0 C\) & Not used \\
\(0 D\) & Not used \\
\(0 E\) & Start Display Refresh Cycle (use only once after \\
0 & reset) \\
\(0 F\) & Not used \\
\(10-3 F\) & Not used \\
\(40-7 F\) & Load Duty Cycle Register with lower 6 bits (0-63) \\
\(80-9 F\) & Load Digit Counter (80=32, 81=1, 82 = 2 , etc.) \\
A0-BF & Not used \\
CO-D3 & Load Buffer Pointer Register with lower 5 bits \\
EO-FF & Not used \\
\hline
\end{tabular}

Table 2. Buffer Pointer Control Codes
\begin{tabular}{|c|c|c|}
\hline \begin{tabular}{c} 
Code \\
Value
\end{tabular} & \begin{tabular}{c} 
Pointer \\
Value
\end{tabular} & \begin{tabular}{c} 
Character \\
Position
\end{tabular} \\
\hline C0 & 00 & 0 \\
C1 & 01 & 1 \\
C2 & 02 & 2 \\
C3 & 03 & 3 \\
C4 & 04 & 4 \\
C5 & 05 & 5 \\
C6 & 06 & 6 \\
C7 & 07 & 7 \\
C8 & 08 & 8 \\
C9 & 09 & 9 \\
CA & \(0 A\) & 10 \\
CB & \(0 B\) & 11 \\
CC & 0 C & 12 \\
CD & \(0 D\) & 13 \\
CE & \(0 E\) & 14 \\
CF & \(0 F\) & 15 \\
D0 & 10 & 16 \\
D1 & 11 & 17 \\
D2 & 12 & 18 \\
D3 & 13 & 19 \\
\hline \multicolumn{3}{|c|}{ Note: } \\
DO NOT USE CHARACTER POSITIONS 20-31 \\
CODES D4-DF) \\
\hline \multicolumn{3}{|l|}{} \\
\hline
\end{tabular}

\section*{Digit Counter Control}

The Digit Counter Control code defines the number of character positions (grids) to be controlled. This code is normally used only during initialization routines, but it may also be used in conjunction with the Duty Cycle Control code to extend the range of brightness control (see Table 3).

\section*{Duty Cycle Control}

The Duty Cycle Control code turns the display on and off, adjusts display brightness, and modifies display timing. The time slot for each character is 16,32 , or 64 cycles as selected by the Digit Time Control codes (see Table 1). The anode and grid drivers for each character are on for a maximum of 13,29 , or 61 cycles with a 3 cycle inter-digit off-time. The lower 6 bits of the Duty Cycle Control code are loaded into the Duty Cycle Register. Resultant duty cycles are shown in Table 4.

Table 3. Digit Counter Control Codes
\begin{tabular}{|c|c|c|}
\hline Code & Digit Counter Value & No. of Grids Controlled \\
\hline 80 & 00 & 32 \\
\hline 81 & 01 & 1 \\
\hline 82 & 02 & 2 \\
\hline 83 & 03 & 3 \\
\hline 84 & 04 & 4 \\
\hline 85 & 05 & 5 \\
\hline 86 & 06 & 6 \\
\hline 87 & 07 & 7 \\
\hline 88 & 08 & 8 \\
\hline 89 & 09 & 9 \\
\hline 8A & OA & 10 \\
\hline 8B & OB & 11 \\
\hline 8 C & OC & 12 \\
\hline 8D & OD & 13 \\
\hline 8 E & OE & 14 \\
\hline 8F & OF & 15 \\
\hline 90 & 10 & 16 \\
\hline 91 & 11 & 17 \\
\hline 92 & 12 & 18 \\
\hline 93 & 13 & 19 \\
\hline 94 & 14 & 20 \\
\hline 95 & 15 & 21 \\
\hline 96 & 16 & 22 \\
\hline 97 & 17 & 23 \\
\hline 98 & 18 & 24 \\
\hline 99 & 19 & 25 \\
\hline 9A & 1A & 26 \\
\hline 9B & 1B & 27 \\
\hline 9 C & 1 C & 28 \\
\hline 9D & 1D & 29 \\
\hline 9 E & 1E & 30 \\
\hline 9 F & 1F & 31 \\
\hline
\end{tabular}

\section*{Digit Time Select}

The Digit Time Select code sets the total time for each character during the refresh cycle. Three values can be set using the three codes shown in Table 1. The default value set at power-on is 64 cycles per grid. For displays with 40 or more characters, or under conditions where the display can be subjected to quick movements during viewing (e.g. portable or vehicle-mounted applications), it may be necessary to increase the refresh rate by selecting 16 or 32 cycles per grid with the appropriate control code.

Table 4. Duty Cycle Control Codes
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Code} & \multicolumn{2}{|l|}{Digit Time \(=16\)} & \multicolumn{2}{|l|}{Digit Time \(=32\)} & \multicolumn{2}{|l|}{Digit Time \(=64\)} \\
\hline & On & Off & On & Off & On & Off \\
\hline 40 & - & 16 & - & 32 & - & 64 \\
\hline 41 & - & 16 & - & 32 & - & 64 \\
\hline 42 & - & 16 & - & 32 & - & 64 \\
\hline 43 & 1 & 15 & 1 & 31 & 1 & 63 \\
\hline 44 & 2 & 14 & 2 & 30 & 2 & 62 \\
\hline 45 & 3 & 13 & 3 & 29 & 3 & 61 \\
\hline 46 & 4 & 12 & 4 & 28 & 4 & 60 \\
\hline 47 & 5 & 11 & 5 & 27 & 5 & 59 \\
\hline 48 & 6 & 10 & 6 & 26 & 6 & 58 \\
\hline 49 & 7 & 9 & 7 & 25 & 7 & 57 \\
\hline 4A & 8 & 8 & 8 & 24 & 8 & 56 \\
\hline 4B & 9 & 7 & 9 & 23 & 9 & 55 \\
\hline 4 C & 10 & 6 & 10 & 22 & 10 & 54 \\
\hline 4D & 11 & 5 & 11 & 21 & 11 & 53 \\
\hline 4E & 12 & 4 & 12 & 20 & 12 & 52 \\
\hline 4F & 13 & 3 & 13 & 19 & 13 & 51 \\
\hline 50 & 13 & 3 & 14 & 18 & 14 & 50 \\
\hline 51 & 13 & 3 & 15 & 17 & 15 & 49 \\
\hline 52 & 13 & 3 & 16 & 16 & 16 & 48 \\
\hline 53 & 13 & 3 & 17 & 15 & 17 & 47 \\
\hline - & - & - & - & - & - & - \\
\hline - & - & - & - & - & - & - \\
\hline - & - & - & - & - & - & - \\
\hline 5B & 13 & 3 & 25 & 7 & 25 & 39 \\
\hline 5C & 13 & 3 & 26 & 6 & 26 & 38 \\
\hline 5D & 13 & 3 & 27 & 5 & 27 & 37 \\
\hline 5E & 13 & 3 & 28 & 4 & 28 & 36 \\
\hline 5 F & 13 & 3 & 29 & 3 & 29 & 35 \\
\hline 60 & 13 & 3 & 29 & 3 & 30 & 34 \\
\hline 61 & 13 & 3 & 29 & 3 & 31 & 33 \\
\hline 62 & 13 & 3 & 29 & 3 & 32 & 32 \\
\hline - & - & - & - & - & - & - \\
\hline - & - & - & - & - & - & - \\
\hline 70 & 13 & 3 & 2 & - & 58 & - \\
\hline 7 C & 13 & 3 & 29 & 3 & 58 & 6 \\
\hline 7 D & 13 & 3 & 29 & 3 & 59 & 5 \\
\hline 7E & 13 & 3 & 29 & 3 & 60 & 4 \\
\hline 7F & 13 & 3 & 29 & 3 & 61 & 3 \\
\hline
\end{tabular}

\section*{Display Mode Select}

Each ASCII character is represented by the lower seven bits of the 8 -bit value loaded into the 10939. The eighth (most significant) bit controls the cursor (see Cursor Control). This bit is known as the data byte control bit. If either Blank or Inverse mode is selected, a " 0 " in this bit causes a normal character display, while " 1 "' selects either Blank or Inverse mode, depending on which mode is enabled. Three control codes are provided (see Table 1) to enable Blank Mode, Inverse Mode, or Normal Display Mode.

In the Blank mode, any character with the MSB = " 1 " will be blanked. In the Inverse mode, it will be displayed with all segment driver outputs inverted. On video displays, this is referred to as "Inverse Video" format. These controls allow individual characters or groups of characters to be blinked or blanked by simply changing the mode without changing the data in the Display Buffer.

\section*{Cursor Control}

The data byte control bit (MSB 8), besides selecting Blank, Inverse, or Normal mode, also controls the cursor output which is enabled on all characters with the MSB equal to one. Therefore, when the Normal mode is enabled and the MSB of the data byte is set to a one, the normal character is displayed with the cursor on. When the Blank mode is enabled and the MSB is set to a one, the character is blanked but the cursor is on. If Inverse mode is enabled and the MSB is set to a one, the inverse character is displayed and the cursor is on but not inversed.

\section*{Start Refresh}

At power on, the 10939 is held in an internal halt mode. The normal display refresh sequence starts upon receipt of a Start Refresh control code. This is particularly useful for synchronizing systems using more than one 10939. Only the Master 10939 in a multi-chip system will recognize the Start Refresh code. The Master starts the Slave(s) at the appropriate time, using the SOP signal.

\section*{INPUT DISPLAY DATA WORDS}

Display data words are loaded as 8 -bit codes. The eighth (most significant) bit specifies normal ( 0 ) or blank/inverse (1) display mode, depending on the blank/inverse mode selection (see Control data words 09 and 0A in Table 1). This bit also controls the cursor.

Twenty display data words must be entered to completely load the Display Data Buffer. The Buffer Pointer automatically increments after each data word is stored in the buffer. To select a character position to be loaded out of sequence, use the Buffer Pointer control code. The Buffer Pointer will automatically reset to character position 0 when its value is equal to the programmed Digit Count.

\section*{POWER-ON RESET}

The Power-On Reset (POR) initializes the internal circuits of the 10939. This is normally accomplished when power ( \(V_{D D}\) ) is applied. The following conditions are established by application of POR:
a. The Grid Drivers (STR00-STR19) on the 10939 are in the off state.
b. The Anode Drivers (SG01-SG35) on the 10938 are in the off state.
c. The Duty Cycle is set to 0 .
d. The Digit Counter is set to 32 .
e. The Buffer Pointer is set to 0 .
f. The Digit time is set to 64 .
g. The Normal display mode is set.
h. DATA-LOAD is set to high impedance state.
i. SCLK-DIS is set to \(V_{O L}\) to disable the anode drivers in the 10938.
j. \(\operatorname{SOP}\) is set to \(V_{O L}\) to disable the sync pulse.

\section*{NOTE:}
1. When the POR signal is removed, SCLK-DIS is set to the high impedance state.
2. During the initial rise time of \(V_{D D}\) at power turn-on, the magnitude of \(\mathrm{V}_{\mathrm{GG}}\) should not exceed the magnitude of \(\mathrm{V}_{\mathrm{DD}}\).

\section*{GRID (DIGIT) DRIVERS (STR00-STR19) PLUS CURSOR}

The 20 Digit Drivers select each of the display character positions sequentially during a refresh scan. Display dots will be illuminated when both the Digit Drivers and Dot Drivers for a particular character are energized simultaneously. The cursor segment is generated by the 10939, but its timing characteristics are identical to the anode timing generated by the 10938.

\section*{ANODE (DOT) DRIVERS (SG01-SG35)}

35 Dot Drivers are provided in the 10938. The output states for each character pattern are internally decoded from the 8 -bit characters received from the 10939 by means of a \(128 \times 35\)-bit PLA. Data codes and the corresponding patterns are shown in Figure 1. Figure 2 shows the Dot Driver (SG01-SG35) assignments as they relate to the \(5 \times 7\) dot matrix patterns.

\section*{TYPICAL SYSTEM HOOKUPS}

Figure 3 shows a 10938 and 10939 in a parallel interface with the host system driving a 20 character display. Figure 4 shows a 10938 and a 10939 in a serial interface with the host system driving a 20 character display. Figure 5 shows a 10938 and two 10939's in a parallel interface with the host system driving a 40 character display.
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline 00 & & 01 &  & 02 & \(\because \because\) & 03 & \(\cdots\) & 04 & \(\cdots\) & 05 &  & 06 & \(\cdots\) & 07 & \(\cdots\) \\
\hline 08 & \(\cdots\) & 09 &  & OA & \(\cdots\) & OB & \(\stackrel{\circ}{*}^{\bullet}\) & OC &  & OD & : \(\because\) : & OE & \% & OF & - \\
\hline 10 &  & 11 &  & 12 & -••吅 & 13 &  & 14 & \begin{tabular}{|c|}
\hline\(\therefore\) \\
\(\cdots \cdots\)
\end{tabular} & 15 & \(\cdots\)
\(\cdots \cdots\)
\(\cdots \cdots\) & 16 & \(\cdots\) & 17 & -… \\
\hline 18 & \(\because\) & 19 & ! & 1A & \(\cdots\) & 18 & \(\because\) & 1C & : & 1D & \(\cdots\) & 1 E & ..... & 1F & \(\because \square\) \\
\hline 20 & & 21 &  & 22 & : : & 23 &  & 24 & \(\cdots\) & 25 &  & 26 &  & 27 & - \\
\hline 28 & ! \({ }^{\bullet}\) & 29 & - \({ }^{\bullet}\) & 2 A & \(\because \because\) & 2 B & \(\cdots\) & 2 C & - & 20 & . \(\cdot .\). & 2 E & : & \(2 F\) & .\(^{\circ}\) \\
\hline 30 & \(\underbrace{\cdots \cdots}\) & 31 & \% & 32 &  & 33 &  & 34 &  & 35 & \(\cdots\) & 36 &  & 37 &  \\
\hline 38 &  & 39 &  & 3 A & - & 3 B & : & \(3 C\) &  & 3D & ....... & 3E &  & \(3 F\) & \(\cdots\) \\
\hline 40 &  & 41 & ! \({ }^{\cdots \prime \prime}\) & 42 &  & 43 & \(\square^{\cdots \cdots}\) & 44 &  & 45 & \begin{tabular}{|c|}
\hline\(\cdots \cdots\) \\
\(\vdots \cdots\) \\
\hline\(\cdots .\).
\end{tabular} & 46 & ! \({ }^{*}\) & 47 & ¢ \(\begin{gathered}\cdots \\ \vdots \\ \cdots\end{gathered}\) \\
\hline 48 & ! \(\quad \vdots\) & 49 & \(\because\)
\(\vdots\)
\(\vdots\) & 4A &  & 4B &  & 4C &  & 4D & \(\cdots\) & 4 E &  & 4F & ! \({ }^{\cdots}\) \\
\hline 50 &  & 51 & \(\cdots \cdots\)
\(\vdots\)
\(\square\) & 52 &  & 53 &  & 54 &  & 55 & ¢ \(\quad \vdots\) & 56 & \(\vdots \vdots\) & 57 & ! \(\begin{gathered}\text { ¢ } \\ \vdots \\ \vdots\end{gathered}\) \\
\hline 58 &  & 59 &  & 5A &  & 5B & \begin{tabular}{|c|}
\hline\(\cdots\) \\
\(\vdots\) \\
\(\vdots\)
\end{tabular} & 5C &  & 5D &  & 5E &  & 5F & ! \\
\hline 60 & \(\bullet \cdot\) & 61 & \(\ldots\) & 62 &  & 63 &  & 64 &  & 65 &  & 66 &  & 67 & : \(\because \cdot!\) \\
\hline 68 &  & 69 & \(\because\) & 6A & \(\because\) & 6B &  & 6C &  & 6 D & \(\because: \%\) & 6E &  & \(6 F\) & \({ }^{\bullet \cdots}\) \\
\hline 70 &  & 71 &  & 72 &  & 73 & \(\cdots\) & 74 &  & 75 & ! & 76 & ! \(\quad\) : & 77 & \(\vdots:\) \\
\hline 78 &  & 79 &  & 7A &  & 78 &  & 7 C &  & 70 &  & 7E & ..... & 7F & \begin{tabular}{l}
\(: \%: \%\) \\
\(: \%: \%\) \\
\(: \%: \%\) \\
\hline
\end{tabular} \\
\hline
\end{tabular}

Figure 1. \(5 \times 7\) Dot Matrix PLA Patterns


Figure 2. Anode (Dot) Driver Assignments



Figure 5. Typical Display System with Parallel Interface to Host and Two 10939 Devices

\section*{10939, 10942, and 10943 Dot Matrix Display Controller}

\section*{DESCRIPTION}

The Rockwell 10939, 10942, and 10943 Dot Matrix Display Controller is a three-chip MOS/LSI general purpose display controller system designed to interface to dot matrix displays (vacuumfluorescent or LED).

The three-chip set will drive displays with up to 46 anodes (dots) and up to 20 grids (characters) plus a cursor. The chips can be cascaded to drive larger displays of up to 80 characters. An internal PLA-type decoder provides character decoding and dot pattern generation for the full 96 -character ASCII set and an additional 32 special characters.

\section*{FEATURES}
- 20-character display driver cascadable to 80 characters
- Standard \(5 \times 12\) character font
- Separate cursor driver output
- Two \(128 \times 23\) PLAs provide decoding for full 96-character ASCII set plus 32 special characters
- Serial or parallel data input for 8 -bit display and control characters
- Brightness, refresh rate, and display mode controls
- 10939 provided in 40 -pin DIP
- 10942 and 10943 provided in 28 -pin DIP

\section*{ORDERING INFORMATION}
\begin{tabular}{|l|c|r|}
\hline \begin{tabular}{c} 
Part \\
Number
\end{tabular} & \begin{tabular}{c} 
Package \\
Type
\end{tabular} & \begin{tabular}{c} 
Temperature \\
Range ( \({ }^{\circ} \mathrm{C}\) )
\end{tabular} \\
\hline 10939 P & Plastic & 0 to +70 \\
\(10939 P E\) & Plastic & -40 to +85 \\
10942 P & Plastic & 0 to +70 \\
\(10942 P E\) & Plastic & -40 to +85 \\
\(10943 P\) & Plastic & 0 to +70 \\
\(10943 P E\) & Plastic & -40 to +85 \\
\hline
\end{tabular}


Block Diagram of 10939, 10942, 10943

\section*{INTERFACE DESCRIPTION}

10942 and 10943 Pin Functions
\begin{tabular}{|l|c|l|}
\hline Signal Name & Pin No. & \multicolumn{1}{|c|}{ Function } \\
\hline\(V_{D D}\) & 1 & DC Power \\
\(V_{S S}\) & 2 & Power and signal reference \\
SG01-SG23 & \(3-17,19-26\) & Anode (Dot) driver outputs \\
V \(_{\text {GG }}\) & 18 & Display voltage \\
SCLK-DIS & 27 & Serial data shift clock \\
DATA-LOAD & 28 & Serial data output/latch control \\
\hline
\end{tabular}


10942 and 10943 Pin Configurations

10939 Pin Functions
\begin{tabular}{|l|c|l|}
\hline Signal Name & Pin No. & \multicolumn{1}{|c|}{ Function } \\
\hline V \(_{\text {SS }}\) & 36 & Power and signal reference \\
V \(_{\text {DD }}\) & 37 & DC Power \\
CLOCK & 38 & Synchronization Clock \\
CURSOR & 14 & Cursor driver output \\
MASTER & 39 & Master/Slave Mode control \\
SIP & 3 & Sync Input \\
SOP & 2 & Sync Output \\
D0-D7 & \(6-13\) & Serial or parallel data input \\
LD & 5 & Input data strobe \\
POR & 4 & Power-on reset \\
SCLK-DIS & 1 & Serial data shift clock \\
DATA-LOAD & 40 & Serial data output/latch control \\
STR00-STR19 & \(15-34\) & Digit (grid) driver outputs \\
V GG & 35 & Display voltage \\
\hline
\end{tabular}


10939 Pin Configurations

\section*{SPECIFICATIONS}

\section*{ABSOLUTE MAXIMUM RATINGS*}

Voltages are referenced to \(\mathrm{V}_{\mathrm{SS}}\), where \(\mathrm{V}_{\mathrm{SS}}=+5 \mathrm{Vdc}\)
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline \begin{tabular}{l} 
Operating Temperature \\
Commercial \\
Industrial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{c}
0 to +70 \\
Storage Temperature
\end{tabular} & \(\mathrm{T}_{\mathrm{S}}\)
\end{tabular} \begin{tabular}{c}
\({ }^{\circ} \mathrm{C}\) \\
\({ }^{\circ} \mathrm{C}\) \\
-55 to \(+85+125\)
\end{tabular}\(\stackrel{ }{\circ} \mathrm{C}^{\circ} \mathrm{C}\).
*NOTE: Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}
\(\left(\mathrm{V}_{\mathrm{DD}}=-18.0\right.\) to \(-22 \mathrm{Vdc}, \mathrm{V}_{\mathrm{SS}}=0 \mathrm{Vdc}\), unless otherwise noted. All voltages referenced to \(\mathrm{V}_{\mathrm{SS}}\).)
\begin{tabular}{|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min. & Typical & Max. & Unit \\
\hline ```
10942 and 10943
    Output Anodes (Dots)
        Logic "1" (ILOAD = 2 mA)
        Logic "0" ( (LOAD = 0 mA)
``` & \[
\begin{aligned}
& \mathrm{v}_{\mathrm{OH}} \\
& \mathrm{v}_{\mathrm{OL}}
\end{aligned}
\] & \[
\begin{aligned}
& -1.5 \\
& \mathrm{~V}_{\mathrm{GG}}
\end{aligned}
\] & & \[
\begin{gathered}
\mathrm{V}_{\mathrm{SS}} \\
0.95 \times \mathrm{V}_{\mathrm{GG}} \\
\hline
\end{gathered}
\] & \[
\begin{aligned}
& V \\
& V
\end{aligned}
\] \\
\hline ```
10939
    Input D0-D7, LD, SIP
        Logic "1"
        Logic "0"
    Input POR
        Logic "1"
        Logic "0"
    Output SOP
        Logic "1"
        Logic "0"
    Output Digits, Cursor
        Logic "1" (I_LOA = 10 mA)
        Logic "0'' (l LOAD = 0 mA)
``` & \begin{tabular}{l}
\(\mathrm{V}_{\mathrm{IH}}\) \\
\(V_{\text {IL }}\) \\
\(\mathrm{V}_{\text {IHPO }}\) \\
\(V_{\text {ILPO }}\) \\
\(\mathrm{V}_{\mathrm{OHSY}}\) \\
\(V_{\text {OLSY }}\) \\
\(\mathrm{V}_{\mathrm{OH}}\) \\
\(\mathrm{V}_{\mathrm{OL}}\)
\end{tabular} & \[
\begin{aligned}
& -1.2 \\
& \mathrm{~V}_{\mathrm{DD}} \\
& -3.0 \\
& \mathrm{~V}_{\mathrm{DD}} \\
& -1.2 \\
& \mathrm{~V}_{\mathrm{DD}} \\
& -1.5 \\
& \mathrm{~V}_{\mathrm{GG}}
\end{aligned}
\] & & \[
\begin{gathered}
+0.3 \\
-4.2 \\
\\
+0.3 \\
-10.0 \\
\\
V_{\mathrm{SS}} \\
-4.2 \\
\\
V_{\mathrm{SS}} \\
0.95 \times V_{\mathrm{GG}}
\end{gathered}
\] & \[
\begin{aligned}
& v \\
& v \\
& v \\
& v \\
& v \\
& v \\
& v \\
& v \\
& v
\end{aligned}
\] \\
\hline
\end{tabular}

Note: \(\mathrm{TA}=0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\) (commercial) or \(-40^{\circ} \mathrm{C}\) to \(+85^{\circ} \mathrm{C}\) (industrial), unless otherwise noted.

\section*{OPERATING CURRENTS}
\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Parameter} & \multicolumn{2}{|c|}{Maximum} & Typical & \multirow[b]{2}{*}{Unit} \\
\hline & Industrial
\[
\begin{aligned}
\mathrm{TA} & =-40^{\circ} \mathrm{C} \\
\mathrm{~V}_{\mathrm{DD}} & =-22 \mathrm{Vdc} \\
\mathrm{~V}_{\mathrm{GG}} & =-50 \mathrm{Vdc}
\end{aligned}
\] & Commercial
\[
\begin{aligned}
\mathrm{TA} & =0^{\circ} \mathrm{C} \\
\mathrm{~V}_{\mathrm{DD}} & =-22 \mathrm{Vdc} \\
\mathrm{~V}_{\mathrm{GG}} & =-50 \mathrm{Vdc}
\end{aligned}
\] & \[
\begin{gathered}
\mathrm{TA}=25^{\circ} \mathrm{C} \\
\mathrm{~V}_{\mathrm{DD}}=-20 \mathrm{Vdc} \\
\mathrm{~V}_{\mathrm{GG}}=-50 \mathrm{Vdc}
\end{gathered}
\] & \\
\hline \multicolumn{5}{|l|}{10942 or 10943} \\
\hline \(\mathrm{I}_{\mathrm{DD}}\) & 4.5 & 3.6 & 3.2 & mA \\
\hline \[
\begin{gathered}
\mathrm{I}_{\mathrm{GG}}{ }^{1} \\
1093 \text { (master) }
\end{gathered}
\] & 7.4 & 5.9 & 5.3 & mA \\
\hline \(\mathrm{I}_{\mathrm{DD}}\) & 13.6 & 10.9 & 6.0 & mA \\
\hline \(\mathrm{IGG}^{2}\) & 1.0 & 0.8 & 0.5 & mA \\
\hline \multicolumn{5}{|l|}{10939 (slave)} \\
\hline IDD & 9.1 & 7.3 & 4.0 & mA \\
\hline \(\mathrm{IGG}^{2}\) & 1.0 & 0.8 & 0.5 & mA \\
\hline
\end{tabular}

\section*{Notes:}
1. The 10942 and 10943 each have 23 driver outputs. \(I_{G G}\) is proportional to the number of drivers on. The values given are for all 23 drivers on. Divide \(\mathrm{I}_{\mathrm{GG}}\) shown by 23 to determine \(\mathrm{I}_{\mathrm{GG}}\) for one driver. Multiply \(\mathrm{I}_{\mathrm{GG}}\) by 2 to find total current requirements for all drivers on for both devices.
2. The 10939 will never have more than two drivers on at any one time; one grid driver and the cursor. The values shown are for two drivers on with \(100 \%\) duty cycle.

\section*{AC CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min. & Typical & Max. & Unit \\
\hline Data Load (LD) On Time Off Time Commercial Industrial Cycle Time Commercial Industrial & \begin{tabular}{l}
\(T_{\text {Idon }}\) \(T_{\text {Idoff }}\) \\
\(T_{\text {Idcyc }}\)
\end{tabular} & \[
\begin{array}{r}
1.0 \\
40.0 \\
44.5 \\
60.0 \\
66.7
\end{array}
\] & & & \begin{tabular}{l}
\(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\)
\end{tabular} \\
\hline \begin{tabular}{l}
SERIAL INTERFACE TIMING \\
Serial Clock (D1) \\
On Time \\
Off Time \\
Cycle Time \\
Serial Data (DO) \\
Set-up time \\
Hold Time \\
Serial Clock to LD Time \\
LD to Serial Clock
\end{tabular} & \begin{tabular}{l}
\(T_{\text {scon }}\) \\
\(T_{\text {scoff }}\) \\
\(\mathrm{T}_{\text {sccyc }}\) \\
\(T_{\text {ssetup }}\) \\
\(\mathrm{T}_{\text {shold }}\) \\
\(\mathrm{T}_{\mathrm{s} /}\) \\
\(\mathrm{T}_{\text {Is }}\)
\end{tabular} & \[
\begin{array}{r}
1.0 \\
1.0 \\
2.0 \\
400 \\
400 \\
1.0 \\
1.0
\end{array}
\] & & 20.0 & \[
\begin{aligned}
& \mu \mathrm{S} \\
& \mu \mathrm{~S} \\
& \mu \mathrm{~S} \\
& \\
& \mathrm{~ns} \\
& \mathrm{~ns} \\
& \mu \mathrm{~S} \\
& \mu \mathrm{~S}
\end{aligned}
\] \\
\hline \begin{tabular}{l}
PARALLEL INTERFACE TIMING \\
Parallel Data (D0-D7) \\
Set-up Time \\
Hold Time
\end{tabular} & \(T_{\text {psetup }}\) \(T_{\text {phold }}\) & \[
\begin{array}{r}
0 \\
200
\end{array}
\] & & & \[
\begin{aligned}
& \text { ns } \\
& \text { ns }
\end{aligned}
\] \\
\hline
\end{tabular}

\section*{TIMING WAVEFORMS}


Serial Interface Timing Waveforms


Parallel Interface Timing Waveforms

\section*{FUNCTIONAL DESCRIPTION}

Once the display buffer has been loaded from the host processor, the 10939, 10942, and 10943 system generates all timing signals required to control the display.

Input data is loaded into the Display Data Buffer as a series of 8-bit words via the Serial or Parallel Data Input channel on the 10939. Internal timing and control logic synchronize the digit output signals with the Serial Data and Load signals to the 10942/10943 to provide the proper timing for the multiplexing operation. Two \(128 \times 23\) bit PLAs, one in the 10942 and the other in the 10943, decode the full 96-character ASCII set plus 32 special characters.

The parallel data input mode is implemented by toggling any of data lines D2-D7 after POR has gone low. Once the parallel data load mode has been implemented, a power-on reset procedure must be performed to return to serial data load mode. Parallel data transfer is accomplished by putting the command or display data on the data lines, then pulsing the LD line. The load cycle time must be at least \(60 \mu \mathrm{~s}\) with the LD line set high for at least one \(\mu \mathrm{s}\) and held low for at least \(40 \mu \mathrm{~s}\).

The serial data input mode is implemented during the poweron reset procedure. In those systems using serial mode, ports D2-D7 should be tied low to prevent the inadvertent implementation of the parallel load mode. Serial data bytes are shifted into a data buffer MSB first on line D0 using line D1 as the serial clock. The last eight bits clocked in are latched into the display controller by a pulse on the LD line. The cycle time for each data bit is \(2 \mu \mathrm{~s}\) and the load time for each byte is \(60 \mu \mathrm{~s}\).

Input data may be Control or Display data. The following paragraphs describe the format and functions of these control and display data words.

\section*{CONTROL DATA WORDS}

Control data words are used to select the operating parameters of the display controller. They must be preceded by a control prefix word (0000 0001, hexadecimal 01) to be distinguished from display data words.

\section*{Buffer Pointer Control}

The Buffer Pointer Control code sets the Display Data Buffer pointer. The lower 5 bits of the code are loaded into the buffer pointer (see Table 2).

\section*{Digit Counter Control}

The Digit Counter Control code defines the number of character positions (grids) to be controlled. This code is normally used only during initialization routines, but it may also be used in conjunction with the Duty Cycle Control code to extend the range of brightness control (see Table 3).

\section*{Duty Cycle Control}

The Duty Cycle Control code is used to turn the display on and off, to adjust display brightness, or to modify display timing. The
time slot for each character is 16,32 , or 64 cycles as selected by the Digit Time Control codes (see Table 1). The segment and digit drivers for each character are on for a maximum of 13, 29, or 61 cycles with a 3 cycle inter-digit off-time. The lower 6 bits of the Duty Cycle Control code are loaded into the Duty Cycle Register. Resultant duty cycles are shown in Table 4.

Table 1. Control Word Assignments
\begin{tabular}{|c|l|}
\hline Hex Value & \multicolumn{1}{|c|}{ Function } \\
\hline 00 & Not Used \\
01 & Load O1 into Data Buffer \\
02 & Not used \\
03 & Not used \\
04 & Not used \\
05 & Set Digit Time to 16 cycles per grid \\
06 & Set Digit Time to 32 cycles per grid \\
07 & Set Digit Time to 64 cycles per grid \\
08 & Enable Normal Display Mode (MSB in data words \\
& is ignored \\
09 & Enable Blank Mode (data words with MSB = 1 will \\
& be blanked) \\
\(0 A\) & Enable Inverse Mode (data words with MSB = 1 will \\
& be "inversed") \\
\(0 B\) & Not used \\
\(0 C\) & Not used \\
\(0 D\) & Not used \\
\(0 E\) & Start Display Refresh Cycle (use only once after \\
& reset) \\
\(0 F\) & Not used \\
\(10-3 F\) & Not used \\
\(40-7 F\) & Load Duty Cycle Register \\
\(80-9 F\) & Load Digit Counter (80 = 32, 81 = 1, 82 = 2, etc.) \\
AO-BF & Not used \\
C0-DF & Load Buffer Pointer Register with lower 5 bits \\
E0-FF & Not used \\
&
\end{tabular}

Table 2. Buffer Pointer Control Codes
\begin{tabular}{|c|c|c|}
\hline \begin{tabular}{c} 
Code \\
Value
\end{tabular} & \begin{tabular}{c} 
Pointer \\
Value
\end{tabular} & \begin{tabular}{c} 
Character \\
Position
\end{tabular} \\
\hline C0 & 00 & 0 \\
C1 & 01 & 1 \\
C2 & 02 & 2 \\
C3 & 03 & 3 \\
C4 & 04 & 4 \\
C5 & 05 & 5 \\
C6 & 06 & 6 \\
C7 & 07 & 7 \\
C8 & 08 & 8 \\
C9 & 09 & 9 \\
CA & \(0 A\) & 10 \\
CB & \(0 B\) & 11 \\
CC & \(0 C\) & 12 \\
CD & \(0 D\) & 13 \\
CE & \(0 E\) & 14 \\
CF & \(0 F\) & 15 \\
D0 & 10 & 16 \\
D1 & 11 & 17 \\
D2 & 12 & 18 \\
D3 & 13 & 19 \\
\hline Note: Do not use character positions \(20-31\) (Codes D4-DF). \\
\hline
\end{tabular}

Table 3. Digit Counter Control Codes
\begin{tabular}{|c|c|c|}
\hline Code & \begin{tabular}{c} 
Digit \\
Counter Value
\end{tabular} & \begin{tabular}{c} 
No. of Grids \\
Controlled
\end{tabular} \\
\hline 80 & 00 & 32 \\
81 & 01 & 1 \\
82 & 02 & 2 \\
83 & 03 & 3 \\
84 & 04 & 4 \\
85 & 05 & 5 \\
86 & 06 & 6 \\
87 & 07 & 7 \\
88 & 08 & 8 \\
89 & 09 & 9 \\
\(8 A\) & 0 A & 10 \\
\(8 B\) & \(0 B\) & 11 \\
8 C & 0 C & 12 \\
8 D & 0 D & 13 \\
8 E & 0 E & 14 \\
8 F & 0 F & 15 \\
90 & 10 & 16 \\
91 & 11 & 17 \\
92 & 12 & 18 \\
93 & 13 & 19 \\
94 & 14 & 20 \\
95 & 15 & 21 \\
96 & 16 & 22 \\
97 & 17 & 23 \\
98 & 18 & 24 \\
99 & 19 & 25 \\
9 A & 1 F & 26 \\
9 B & 1 F & 27 \\
9 B & 1 B & 28 \\
9 F & 1 B & 30 \\
\hline & 09 \\
\hline
\end{tabular}

\section*{Digit Time Select}

The Digit Time Select code sets the total time for each character during the refresh cycle. Three values can be set using the three codes shown in Table 1. The default value set at poweron is 64 cycles per grid. For displays with 40 or more characters,or under conditions where the display can be subjected to quick movements during viewing (e.g. portable or vehiclemounted applications), it may be necessary to increase the refresh rate by selecting 16 or 32 cycles per grid with the appropriate control code.

\section*{Display Mode Select}

Each ASCII character is represented by the lower seven bits of the 8 -bit value loaded into the 10939. The eighth (most significant) bit is used to turn the cursor (see Cursor Control) on in Normal display mode. If either Blank or Inverse mode is selected, a " 0 " in this bit causes a normal character display mode, while a "1" selects either Blank or Inverse mode, depending on which mode is enabled. Three control codes are provided (see Table 1) to enable Blank Mode, Inverse Mode, or Normal Display Mode.

In the Blank mode, any character with the MSB = " 1 " will be blanked. In the Inverse mode, it will be displayed with all segment driver outputs inverted. On video displays, this is referred to as "Inverse Video" format. These controls allow individual

Table 4. Duty Cycle Control Codes
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Code} & \multicolumn{2}{|l|}{Digit Time \(=16\)} & \multicolumn{2}{|l|}{Digit Time \(=32\)} & \multicolumn{2}{|l|}{Digit Time \(=64\)} \\
\hline & On & Off & On & Off & On & Off \\
\hline 40 & - & 16 & - & 32 & - & 64 \\
\hline 41 & - & 16 & - & 32 & - & 64 \\
\hline 42 & - & 16 & - & 32 & - & 64 \\
\hline 43 & 1 & 15 & 1 & 31 & 1 & 63 \\
\hline 44 & 2 & 14 & 2 & 30 & 2 & 62 \\
\hline 45 & 3 & 13 & 3 & 29 & 3 & 61 \\
\hline 46 & 4 & 12 & 4 & 28 & 4 & 60 \\
\hline 47 & 5 & 11 & 5 & 27 & 5 & 59 \\
\hline 48 & 6 & 10 & 6 & 26 & 6 & 58 \\
\hline 49 & 7 & 9 & 7 & 26 & 7 & 57 \\
\hline 4A & 8 & 8 & 8 & 24 & 8 & 56 \\
\hline 4B & 9 & 7 & 9 & 23 & 9 & 55 \\
\hline 4C & 10 & 6 & 10 & 22 & 10 & 54 \\
\hline 4D & 11 & 5 & 11 & 21 & 11 & 53 \\
\hline 4E & 12 & 4 & 12 & 20 & 12 & 52 \\
\hline 4F & 13 & 3 & 13 & 19 & 13 & 51 \\
\hline 50 & 13 & 3 & 14 & 18 & 14 & 50 \\
\hline 51 & 13 & 3 & 15 & 17 & 15 & 49 \\
\hline 52 & 13 & 3 & 16 & 16 & 16 & 48 \\
\hline 53 & 13 & 3 & 17 & 15 & 17 & 47 \\
\hline . & . & . & . & . & - & . \\
\hline - & - & - & . & - & . & . \\
\hline 5B & 13 & 3 & 25 & 7 & 25 & 39 \\
\hline 5 C & 13 & 3 & 26 & 6 & 26 & 38 \\
\hline 5D & 13 & 3 & 27 & 5 & 27 & 37 \\
\hline 5E & 13 & 3 & 28 & 4 & 28 & 36 \\
\hline 5 F & 13 & 3 & 29 & 3 & 29 & 35 \\
\hline 60 & 13 & 3 & 29 & 3 & 30 & 34 \\
\hline 61 & 13 & 3 & 29 & 3 & 31 & 33 \\
\hline 62 & 13 & 3 & 29 & 3 & 32 & 32 \\
\hline - & . & . & . & . & . & . \\
\hline - & - & - & . & - & . & - \\
\hline - & , & . & . & & . & . \\
\hline 7C & 13 & 3 & 29 & 3 & 58 & 6 \\
\hline 7D & 13 & 3 & 29 & 3 & 59 & 5 \\
\hline 7E & 13 & 3 & 29 & 3 & 60 & 4 \\
\hline 7F & 13 & 3 & 29 & 3 & 61 & 3 \\
\hline
\end{tabular}
characters or groups of characters to be blinked or blanked by simply changing the mode without changing the data in the Display Buffer.

\section*{Cursor Control}

The data byte control (MSB 8), besides selecting Blank, Inverse, or Normal mode, also controls the cursor output which is enabled on all characters with the MSB equal to one. Therefore, when the Normal mode is enabled and the MSB of the data byte is set to a one, the normal character is displayed with the cursor on. When the Blank mode is enabled and the MSB is set to a one, the character is blanked but the cursor is on. If Inverse mode is enabled and the MSB is set to a one, the inverse character is displayed, and the cursor is on but not inversed.

\section*{Start Refresh}

At power on, the 10939 is held in an internal halt mode. The normal display refresh sequence starts upon receipt of a Start Refresh control code. This is particularly useful for synchronizing systems using more than one 10939. Only the Master 10939 in a multi-chip system will recognize the Start Refresh code. The Master starts the Slave(s) at the appropriate time, using the SOP signal.

\section*{INPUT DISPLAY DATA WORDS}

Display data words are loaded as 8-bit codes. The eighth (most significant) bit is a dual purpose bit. This bit specifies normal (0) or blank/inverse (1) display mode, depending on the blank/inverse mode selection (see control data words 09 and OA in Table 1). It also controls the cursor output from the 10939; on (1) or off (0). Note, that this bit always controls the cursor no matter what display mode is selected.

Twenty display data words must be entered to completely load the Display Data Buffer. The Buffer Pointer automatically increments after each data word is stored in the buffer. To select a character position to be loaded out of sequence, use the Buffer Pointer Control code command. The Buffer Pointer will automatically reset to character position 0 when its value is equal to the programmed Digit Count.

\section*{DIGIT GRID DRIVERS (STR00-STR19) PLUS CURSOR}

The 20 Digit Drivers select each of the display character positions sequentially during a refresh scan. Display dots are illuminated when both the Digit Drivers and Anode (Dot) Drivers for a particular character are energized simultaneously. The Cursor output is generated by the 10939, but its timing characteristics are identical to the 46 segment outputs generated by the 10942 and the 10943.

\section*{ANODE (DOT) DRIVERS (SG01-SG23)}

A total of 46 Dot Drivers are provided by the 10942 and the 10943. The output states for each ASCII charcter pattern are internally decoded from the 8-bit characters received from the 10939 by means of two \(128 \times 23\)-bit PLAs, one in the 10942 and the other in the 10943. Figure 1 shows the dot matrix drivers (SG01-SG23) as they relate to the 10942 and 10943. Data codes and the corresponding character patterns are also shown in Figure 1.

\section*{POWER-ON RESET}

The Power-On Reset (POR) initializes the internal circuits of the 10939. This is normally accomplished when power ( \(\mathrm{V}_{\mathrm{DD}}\) ) is applied. The following conditions are established by the application of POR:
a. The Grid Drivers (STR00-STR19) on the 10939 are in the off state.
b. The Anode Drivers, SG01-SG23 on the 10942 and SG01-SG23 on the 10943, are in the off state.
c. The Duty Cycle is set to 0 .
d. The Digit Counter is set to 32 .
e. The Buffer Pointer is set to 0 .
f. The Digit time is set to 64 .
g. The Normal display mode is set.
h. DATA-LOAD is set to high impedance state.
i. SCLK-DIS is set to \(V_{O L}\) to disable the anode drivers in the 10942 and 10943.
j. SOP is set to \(V_{O L}\) to disable the sync pulse.

NOTE:
1. When th POR signal is removed, SCLK-DIS is set to the high impedance state.
2. During the initial rise time of \(V_{D D}\) at power turn-on, the magnitude of \(\mathrm{V}_{\mathrm{GG}}\) should not exceed the magnitude of \(\mathrm{V}_{\mathrm{DD}}\).

\section*{TYPICAL SYSTEM HOOKUPS}

Figure 2 shows a 10939, 10942, and a 10943 in a parallel interface with the host system driving a 20-character display. Figure 3 shows a 10939, 10942, and a 10943 in a serial interface with the host system driving a 20-character display. Figure 4 shows two 10939s, a 10942, and a 10943 in a parallel interface with the host system driving a 40-character display.


Figure 1. \(5 \times 12\) Dot Matrix PLA Patterns and Driver Assignments


Figure 2. Typical Display System with Parallel Interface to Host System


Figure 4. Typical Display System with Serial Interface to Host System


Figure 4. Typical Display System with Parallel Interface to Host and Two 10939 Devices

\section*{10941 and 10939 \\ Alphanumeric and Bargraph Display Controller}

\section*{DESCRIPTION}

The Rockwell 10939 and 10941 Alphanumeric and Bargraph Display Controller is a two-chip MOS/LSI general purpose display controller system designed to interface with bargraph and segmented displays (vacuum-fluorescent or LED).

The two-chip set will drive displays with up to 16 segments (plus decimal point and comma tail) and up to 20 grids (characters) plus a cursor. The chips can be cascaded to drive larger displays of 80 characters. Segment decoding for ASCII characters and bargraph patterns is accomplished through an internal PLA.

\section*{ORDERING INFORMATION}
\begin{tabular}{|l|l|r|}
\hline \begin{tabular}{c} 
Part \\
Number
\end{tabular} & \begin{tabular}{c} 
Package \\
Type
\end{tabular} & \begin{tabular}{c} 
Temperature \\
Range \(\left({ }^{\circ} \mathrm{C}\right)\)
\end{tabular} \\
\hline 10941 P & Plastic & 0 to +70 \\
10941 PE & Plastic & -40 to +85 \\
10939 P & Plastic & 0 to +70 \\
\(10939 P E\) & Plastic & -40 to +85 \\
\hline
\end{tabular}

\section*{FEATURES}
- 20-character display driver cascadable to 80 characters
- Direct drive capability for vacuum-fluorescent displays
- \(128 \times 18\) PLA provides segment decoding for ASCII characters (all caps only) and bargraph patterns
- Serial or parallel data input for 8 -bit display and control characters
- Brightness, refresh rate, and display mode controls
- Separate cursor driver output
- 10939-40-pin DIP package
- 10941-24-pin DIP package


Block Diagram of 10941 and 10939

\section*{INTERFACE DESCRIPTION}

10941 Pin Functions
\begin{tabular}{|l|c|l|}
\hline Signal Name & Pin No. & \multicolumn{1}{|c|}{ Function } \\
\hline V SS & 2 & Power and signal reference \\
SG01-SG16 & \(6-15,17-22\) & Segment driver outputs \\
SCLK-DIS & 23 & Serial data shift clock \\
DATA-LOAD & 24 & Serial data output/latch control \\
PNT & 4 & Decimal Point driver output \\
TAIL & 5 & Comma Tail driver output \\
V DD \(^{\text {DN }}\) & 1 & DC Power \\
V GG & 16 & Display voltage \\
\hline
\end{tabular}


10941 Pin Configuration

\section*{SPECIFICATIONS}

\section*{ABSOLUTE MAXIMUM RATINGS*}

Voltages are referenced to \(V_{S S}\)
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline \begin{tabular}{l} 
Operating Temperature \\
Commercial \\
Industrial \\
Storage Temperature
\end{tabular} & & 0 to +70 & \({ }^{\circ} \mathrm{C}\) \\
\hline Operating Voltage & Tc & -40 to +85 & \({ }^{\circ} \mathrm{C}\) \\
& Ti & -55 to +125 & \({ }^{\circ} \mathrm{C}\) \\
\hline Operating Display Voltage & \(\mathrm{V}_{\mathrm{DD}}\) & \begin{tabular}{l}
-22 to -18 \\
-20 (typical)
\end{tabular} & \(\mathrm{Vddc}_{\mathrm{GG}}\) \\
\hline
\end{tabular}

10939 Pin Functions
\begin{tabular}{|l|c|l|}
\hline \multicolumn{1}{|c|}{ Signal Name } & Pin No. & \multicolumn{1}{|c|}{ Function } \\
\hline\(V_{S S}\) & 36 & Power and signal reference \\
V \(_{\text {DD }}\) & 37 & DC Power \\
CLOCK & 38 & Synchronization Clock \\
CURSOR & 14 & Cursor driver output \\
MASTER & 39 & Master/Slave Mode control \\
SIP & 3 & Sync Input \\
SOP & 2 & Sync Output \\
D0-D7 & \(6-13\) & Serial or parallel data input \\
LD & 5 & Input data strobe \\
POR & 4 & Power-on reset \\
SCLK-DIS & 1 & Serial data shift clock \\
DATA-LOAD & 40 & Serial data output/latch control \\
STR00-STR19 & \(15-34\) & Grid Driver Outputs \\
VGG & 35 & Display voltage \\
\hline
\end{tabular}


\section*{10939 Pin Configuration}
*NOTE: Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}

All voltages referenced to \(\mathrm{V}_{\mathrm{SS}}\)
\begin{tabular}{|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ & Max & Unit \\
\hline ```
10941
    Output Segments
        Logic "1" ( ( load = 2mA)
        Logic "1" (ILOAD = 0 mA)
``` & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{OH}} \\
& \mathrm{~V}_{\mathrm{OL}}
\end{aligned}
\] & \[
\begin{aligned}
& -1.5 \\
& V_{G G}
\end{aligned}
\] & & \[
\stackrel{V_{S S}}{0.95} \times \mathrm{V}_{\mathrm{GG}}
\] & \[
\begin{gathered}
v \\
v
\end{gathered}
\] \\
\hline ```
10939
    Input DO-D7, LD, SIP
        Logic "1"
        Logic "0"
``` & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{IH}} \\
& \mathrm{~V}_{\mathrm{IL}}
\end{aligned}
\] & \[
\begin{aligned}
& -1.2 \\
& V_{D D}
\end{aligned}
\] & & \[
\begin{array}{r}
+0.3 \\
-4.2
\end{array}
\] & v \\
\hline Input POR Logic "1" Logic "0" & \[
\begin{aligned}
& \mathrm{V}_{\text {IHPO }} \\
& \mathrm{V}_{\text {ILPO }}
\end{aligned}
\] & \[
\begin{aligned}
& -3.0 \\
& \mathrm{~V}_{\mathrm{DD}}
\end{aligned}
\] & & \[
\begin{array}{r}
+0.3 \\
-10.0
\end{array}
\] & \[
\begin{aligned}
& v \\
& v
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& \text { Output SOP } \\
& \text { Logic " } 1 \text { ", } \\
& \text { Logic " } 0 \text { " }
\end{aligned}
\] & \begin{tabular}{l}
\(V_{\mathrm{OHSY}}\) \\
\(V_{\text {OLSY }}\)
\end{tabular} & \[
\begin{aligned}
& -1.2 \\
& V_{D D}
\end{aligned}
\] & & \[
\begin{gathered}
v_{\mathrm{SS}} \\
-4.2
\end{gathered}
\] & \[
\begin{aligned}
& v \\
& v
\end{aligned}
\] \\
\hline \begin{tabular}{l}
Output Digits, Cursor \\
Logic " 1 " ( \(\left.l_{\text {load }}=10 \mathrm{~mA}\right)\) \\
Logic " 0 " ( \(\left.\left.\right|_{\text {load }}=0 \mathrm{~mA}\right)\)
\end{tabular} & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{OH}} \\
& \mathrm{~V}_{\mathrm{OL}}
\end{aligned}
\] & \[
\begin{aligned}
& -1.5 \\
& \mathrm{~V}_{\mathrm{GG}}
\end{aligned}
\] & & \[
\begin{gathered}
\mathrm{V}_{\text {SS }} \\
0.95 \times \mathrm{V}_{\mathrm{GG}}
\end{gathered}
\] & v \\
\hline
\end{tabular}

\section*{operating currents}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Parameter} & \multirow[b]{2}{*}{Notes} & \multicolumn{2}{|c|}{Maximum} & Typical & \multirow[b]{2}{*}{Unit} \\
\hline & & Industrial
\[
\begin{aligned}
\mathrm{TA} & =-40^{\circ} \mathrm{C} \\
\mathrm{~V}_{\mathrm{DD}} & =-22 \mathrm{Vdc} \\
\mathrm{~V}_{\mathrm{GG}} & =-50 \mathrm{Vdc}
\end{aligned}
\] & \begin{tabular}{l}
Commercial \\
\(\mathrm{TA}=0^{\circ} \mathrm{C}\) \\
\(V_{D D}=-22 \mathrm{Vdc}\) \\
\(V_{G G}=-50 \mathrm{Vdc}\)
\end{tabular} & \[
\begin{gathered}
T A=25^{\circ} \mathrm{C} \\
\mathrm{~V}_{\mathrm{DD}}=-20 \mathrm{Vdc} \\
\mathrm{~V}_{\mathrm{GG}}=-50 \mathrm{Vdc}
\end{gathered}
\] & \\
\hline \[
\begin{gathered}
10941 \\
\mathrm{I}_{\mathrm{DD}} \\
\mathrm{I}_{\mathrm{GG}} \\
\hline
\end{gathered}
\] & 1 & \[
\begin{aligned}
& 4.5 \\
& 5.7 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& 3.6 \\
& 4.6
\end{aligned}
\] & \[
\begin{aligned}
& 3.2 \\
& 4.1
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{mA} \\
& \mathrm{~mA}
\end{aligned}
\] \\
\hline \[
\begin{gathered}
10939 \text { (master) } \\
I_{\mathrm{DD}} \\
\mathrm{I}_{\mathrm{GG}} \\
\hline
\end{gathered}
\] & 2 & \[
\begin{array}{r}
13.6 \\
1.0
\end{array}
\] & \[
\begin{array}{r}
10.9 \\
0.8
\end{array}
\] & \[
\begin{aligned}
& 6.0 \\
& 0.5
\end{aligned}
\] & \[
\begin{gathered}
\mathrm{mA} \\
\mathrm{~mA}
\end{gathered}
\] \\
\hline \[
\begin{gathered}
10939 \text { (slave) } \\
\mathrm{I}_{\mathrm{DD}} \\
\mathrm{I}_{\mathrm{GG}} \\
\hline
\end{gathered}
\] & 2 & \[
\begin{aligned}
& 9.1 \\
& 1.0
\end{aligned}
\] & \[
\begin{aligned}
& 7.3 \\
& 0.8
\end{aligned}
\] & \[
\begin{aligned}
& 4.0 \\
& 0.5
\end{aligned}
\] & \[
\mathrm{mA}
\] \\
\hline
\end{tabular}

\section*{Notes:}
1. The 10941 has 18 internal drivers which are brought out. \(I_{G G}\) is proportional to the number of drivers on. The values given are for all 18 drivers on. Divide \(\mathrm{I}_{\mathrm{GG}}\) shown by 18 to determine \(\mathrm{I}_{\mathrm{GG}}\) for one driver.
2. The 10939 will never have more than two drivers on at any one time; one grid driver and the cursor. The values shown are for two drivers on with \(100 \%\) duty cycle.

\section*{AC CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ & Max & Unit \\
\hline \begin{tabular}{l}
GENERAL INTERFACE TIMING \\
Data Load (LD) \\
On Time \\
Off time \\
Commercial \\
Industrial \\
Cycle Time \\
Commerical \\
Industrial
\end{tabular} & \begin{tabular}{l}
\(T_{\text {Idon }}\) \\
\(T_{\text {ldoff }}\) \\
\(T_{\text {Idcyc }}\)
\end{tabular} & \[
\begin{array}{r}
1.0 \\
40.0 \\
44.5 \\
60.0 \\
66.7
\end{array}
\] & & & \begin{tabular}{l}
\(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\)
\end{tabular} \\
\hline \begin{tabular}{l}
SERIAL INTERFACE TIMING \\
Serial Clock (D1) \\
On Time \\
Off Time \\
Cycle Time \\
Serial Data (D0) \\
Set-up Time \\
Hold Time \\
Serial Clock to LD Time \\
LD to Serial Clock
\end{tabular} & \begin{tabular}{l}
\(\mathrm{T}_{\text {scon }}\) \\
\(\mathrm{T}_{\text {scoff }}\) \\
\(\mathrm{T}_{\text {sccyc }}\) \\
\(\mathrm{T}_{\text {ssetup }}\) \\
\(\mathrm{T}_{\text {shold }}\) \\
\(\mathrm{T}_{\mathrm{sl}}\) \\
\(\mathrm{T}_{\text {Is }}\)
\end{tabular} & \[
\begin{array}{r}
1.0 \\
1.0 \\
2.0 \\
400 \\
400 \\
1.0 \\
1.0
\end{array}
\] & & 20.0 & \begin{tabular}{l}
\(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\) \\
ns \\
ns \\
\(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\)
\end{tabular} \\
\hline \begin{tabular}{l}
PARALLEL INTERFACE TIMING \\
Parallel Data (D0-D7) \\
Set-up Time \\
Hold Time
\end{tabular} & \begin{tabular}{l}
\(T_{\text {psetup }}\) \\
\(T_{\text {phold }}\)
\end{tabular} & \[
200^{0}
\] & & & \[
\begin{aligned}
& \text { ns } \\
& \text { ns }
\end{aligned}
\] \\
\hline
\end{tabular}

\section*{TIMING WAVEFORMS}


Serial Interface Timing Waveforms


Parallel Interface Timing Waveforms

\section*{FUNCTIONAL DESCRIPTION}

Once the display buffer has been loaded from the host processor, the 10941/10939 system generates all timing signals required to control the display.

Input data is loaded into the Display Data Buffer as a series of 8 -bit words via the Serial or Parallel Data Input channel on the 10939. Internal timing and control logic synchronize the digit output signals with the Serial Data and Load signals to the 10941 to provide the proper timing for the multiplexing operation. A \(128 \times 18\) bit PLA is provided for decoding the character set and bargraph codes.

The parallel data input mode is implemented by toggling any of data lines D2-D7 after POR has gone low. Once the parallel data load mode has been implemented, a power-on reset procedure must be performed to return to serial data load mode. Parallel data transfer is accomplished by putting the command or display data on the data lines, then pulsing the LD line. The load cycle time must be at least \(60 \mu \mathrm{~s}\) with the LD line set high for at least one \(\mu \mathrm{s}\) and held low for at least \(40 \mu \mathrm{~s}\).

The serial data input mode is implemented during the poweron reset procedure. In those systems using serial mode, ports D2-D7 should be tied low to prevent the inadvertent implementation of the parallel load mode. Serial data bytes are shifted into a data buffer MSB first on line D0 using line D1 as the serial clock. The last eight bits clocked in are latched into the display controller by a pulse on the LD line. The cycle time for each data bit is \(2 \mu \mathrm{~S}\) and the load time for each byte is \(60 \mu \mathrm{~s}\).

Input data may be Control or Display data. The following paragraphs describe the format and functions of these control and display data words.

\section*{CONTROL DATA WORDS}

Control data words are used to select the operating parameters of the display controller. They must be preceded by a Control Prefix word ( 00000001 , hexadecimal 01) to be distinguished from Display Data words. Table 1 shows the Control Word code assignments and functions.

\section*{Buffer Pointer Control}

The Buffer Pointer Control code sets the Display Data Buffer pointer. The lower 5 bits of the code are loaded into the buffer pointer (see Table 2).

Table 1. Control Word Assignments
\begin{tabular}{|c|l|}
\hline Hex Value & \multicolumn{1}{|c|}{ Function } \\
\hline 00 & Not used \\
01 & Load 01 into Data Buffer \\
02 & Not used \\
03 & Not used \\
04 & Not used \\
05 & Set digit time to 16 cycles per grid \\
06 & Set digit time to 32 cycles per grid \\
07 & Set digit time to 64 cycles per grid \\
08 & Enable Normal Display Mode (MSB in data words \\
& is cursor control only) \\
09 & Enable Blank Mode (data words with MSB = 1 will \\
& be blanked and cursor will be on) \\
\(0 A\) & Enable Inverse Mode (data words with MSB = 1 \\
& will be "inversed" and cursor will be on) \\
\(0 B\) & Not used \\
\(0 C\) & Not used \\
\(0 D\) & Not used \\
\(0 E\) & Start Display Refresh Cycle (use only once after \\
0 & reset) \\
\(0 F\) & Not used \\
\(10-3 F\) & Not used \\
\(40-7 F\) & Load Duty Cycle Register with lower 6 bits (0-63) \\
\(80-9 F\) & Load Digit Counter (80=32, 81=1, 82=2, etc.) \\
A0-BF & Not used \\
C0-DF & Load Buffer Pointer Register with lower 5 bits \\
E0-FF & Not used
\end{tabular}

Table 2. Buffer Pointer Control Codes
\begin{tabular}{|c|c|c|}
\hline \begin{tabular}{c} 
Code \\
Value
\end{tabular} & \begin{tabular}{c} 
Pointer \\
Value
\end{tabular} & \begin{tabular}{c} 
Character \\
Position
\end{tabular} \\
\hline C0 & 00 & 0 \\
C1 & 01 & 1 \\
C2 & 02 & 2 \\
C3 & 03 & 3 \\
C4 & 04 & 4 \\
C5 & 05 & 5 \\
C6 & 06 & 6 \\
C7 & 07 & 7 \\
C8 & 08 & 8 \\
C9 & 09 & 9 \\
CA & \(0 A\) & 10 \\
CB & \(0 B\) & 11 \\
CC & \(0 C\) & 12 \\
CD & \(0 D\) & 13 \\
CE & \(0 E\) & 14 \\
CF & OF & 15 \\
D0 & 10 & 16 \\
D1 & 11 & 17 \\
D2 & 12 & 18 \\
D3 & 13 & 19 \\
\hline
\end{tabular}

\section*{Digit Counter Control}

The Digit Counter Control code defines the number of character positions (grids) to be controlled. This code is normally used only during initialization routines, but it may also be used in conjunction with the Load Duty Cycle control code to extend the range of brightness control (see Table 3).

\section*{Duty Cycle Control}

The Duty Cycle Control code turns the display on and off, adjusts display brightness, or modifies display timing. The time slot for each character is 16, 32, or 64 cycles as selected by the Digit Time Control codes (see Table 1). The segment and digit drivers for each character are on for a maximum of 13,29 , or 61 cycles with a 3 cycle inter-digit off-time. The lower 6 bits of the Duty Cycle Control code are loaded into the Duty Cycle Register. Resultant duty cycles are shown in Table 4.

\section*{Digit Time Select}

The Digit Time Select code sets the total time for each character during the refresh cycle. Three values can be set using the three codes shown in Table 1. The default value set at power-on is 64 cycles per grid. For displays with 40 or more characters, or under conditions where the display can be subjected to quick movements during viewing (e.g. portable or vehicle-mounted applications), it may be necessary to increase the refresh rate by selecting 16 or 32 cycles per grid with the appropriate control code.

Table 3. Digit Counter Control Codes
\begin{tabular}{|c|c|c|}
\hline Code & \begin{tabular}{c} 
Digit \\
Counter Value
\end{tabular} & \begin{tabular}{c} 
No. of Grids \\
Controlled
\end{tabular} \\
\hline 80 & 00 & 32 \\
81 & 01 & 1 \\
82 & 02 & 2 \\
83 & 03 & 3 \\
84 & 04 & 4 \\
85 & 05 & 5 \\
86 & 06 & 6 \\
87 & 07 & 7 \\
88 & 08 & 8 \\
89 & 09 & 9 \\
\(8 A\) & 0 A & 10 \\
\(8 B\) & \(0 B\) & 11 \\
8 C & 0 C & 12 \\
8 D & 0 E & 13 \\
8 E & 0 F & 14 \\
8 F & 10 & 15 \\
90 & 11 & 16 \\
91 & 12 & 17 \\
92 & 13 & 18 \\
93 & 14 & 19 \\
94 & 15 & 20 \\
95 & 16 & 21 \\
96 & 17 & 22 \\
97 & 18 & 23 \\
98 & 19 & 24 \\
99 & 1 A & 25 \\
9 A & 1 B & 26 \\
9 B & 1 C & 27 \\
9 C & 1 D & 28 \\
9 D & 1 E & 29 \\
9 E & 1 F & 30 \\
9 F & & 31 \\
\hline & & \\
\hline
\end{tabular}

\section*{Display Mode Select}

Each ASCII character is represented by the lower seven bits of the 8 -bit value loaded into the 10939. The eighth (most

Table 4. Duty Cycle Control Codes
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Code} & \multicolumn{2}{|l|}{Digit Time \(=16\)} & \multicolumn{2}{|l|}{Digit Time \(=32\)} & \multicolumn{2}{|l|}{Digit Time \(=64\)} \\
\hline & On & Off & On & Off & On & Off \\
\hline 40 & - & 16 & - & 32 & - & 64 \\
\hline 41 & - & 16 & - & 32 & - & 64 \\
\hline 42 & - & 16 & - & 32 & - & 64 \\
\hline 43 & 1 & 15 & 1 & 31 & 1 & 63 \\
\hline 44 & 2 & 14 & 2 & 30 & 2 & 62 \\
\hline 45 & 3 & 13 & 3 & 29 & 3 & 61 \\
\hline 46 & 4 & 12 & 4 & 28 & 4 & 60 \\
\hline 47 & 5 & 11 & 5 & 27 & 5 & 59 \\
\hline 48 & 6 & 10 & 6 & 26 & 6 & 58 \\
\hline 49 & 7 & 9 & 7 & 25 & 7 & 57 \\
\hline 4A & 8 & 8 & 8 & 24 & 8 & 56 \\
\hline 4B & 9 & 7 & 9 & 23 & 9 & 55 \\
\hline 4C & 10 & 6 & 10 & 22 & 10 & 54 \\
\hline 4D & 11 & 5 & 11 & 21 & 11 & 53 \\
\hline 4E & 12 & 4 & 12 & 20 & 12 & 52 \\
\hline 4F & 13 & 3 & 13 & 19 & 13 & 51 \\
\hline 50 & 13 & 3 & 14 & 18 & 14 & 50 \\
\hline 51 & 13 & 3 & 15 & 17 & 15 & 49 \\
\hline 52 & 13 & 3 & 16 & 16 & 16 & 48 \\
\hline 53 & 13 & 3 & 17 & 15 & 17 & 47 \\
\hline . & . & - & - & . & . & . \\
\hline . & - & - & \(\cdot\) & - & - & . \\
\hline 5B & 13 & 3 & 25 & 7 & 25 & 39 \\
\hline 5C & 13 & 3 & 26 & 6 & 26 & 38 \\
\hline 5D & 13 & 3 & 27 & 5 & 27 & 37 \\
\hline 5E & 13 & 3 & 28 & 4 & 28 & 36 \\
\hline 5F & 13 & 3 & 29 & 3 & 29 & 35 \\
\hline 60 & 13 & 3 & 29 & 3 & 30 & 34 \\
\hline 61 & 13 & 3 & 29 & 3 & 31 & 33 \\
\hline 62 & 13 & 3 & 29 & 3 & 32 & 32 \\
\hline - & . & - & . & . & . & . \\
\hline . & . & - & - & - & . & . \\
\hline 7C & 13 & 3 & 29 & 3 & 58 & 6 \\
\hline 7 D & 13 & 3 & 29 & 3 & 59 & 5 \\
\hline 7E & 13 & 3 & 29 & 3 & 60 & 4 \\
\hline 7F & 13 & 3 & 29 & 3 & 61 & 3 \\
\hline
\end{tabular}
significant) bit controls the cursor (see Cursor Control). This bit is known as the data byte control bit. If either Blank or Inverse mode is selected, a " 0 " in this bit causes a normal character display, while a " 1 " selects either Blank or Inverse mode, depending on which mode is enabled. Three control codes are provided (see Table 1) to enable Blank Mode, Inverse Mode, or Normal Display mode.

In the Blank mode, any character with the MSB = " 1 " will be blanked. In the Inverse mode, it will be displayed with all segment driver outputs inverted. On video displays, this is referred to as "Inverse Video" format. These controls allow individual characters or groups of characters to be blinked or blanked by simply changing the mode without changing the data in the Display Buffer.

\section*{Cursor Control}

The data byte control bit (MSB 8), besides selecting Blank, Inverse, or Normal mode, also controls the cursor output which is enabled on all characters with the MSB equal to one. Therefore, when the Normal mode is enabled and the MSB of the data byte is set to a one, the normal character is displayed with the cursor on. When the Blank mode is enabled and the MSB is set to a one, the character is blanked but the cursor is on. If Inverse mode is enabled and the MSB is set to a one, the inverse character is displayed and the cursor is on but not inversed.

\section*{Start Refresh}

At power on, the 10939 is held in an internal halt mode. The normal display refresh sequence starts upon receipt of a Start Refresh control code. This is particularly useful for synchronizing systems using more than one 10939. Only the Master 10939 in a multi-chip system will recognize the Start Refresh code. The Master starts the Slave(s) at the appropriate time, using the SOP signal.

\section*{INPUT DISPLAY DATA WORDS}

Display data words are loaded as 8 -bit codes. The eighth (most significant) bit specifies normal (0) or blank/inverse (1) display mode, depending on the blank/inverse mode selection (see Control data words 09 and 0A in Table 1). This bit also controls the cursor.

Twenty display data words must be entered to completely load the Display Data Buffer. The Buffer Pointer automatically increments after each data word is stored in the buffer. To select a character position to be loaded out of sequence, use the Buffer Pointer control code. The Buffer Pointer will automatically reset to character position 0 when its value is equal to the programmed Digit Count.

\section*{POWER-ON RESET}

The Power-On Reset (POR) initializes the internal circuits of the 10939. This is normally accomplished when power ( \(\mathrm{V}_{\mathrm{DD}}\) ) is applied. The following conditions are established by application of POR:
a. The Grid Drivers (STR00-STR19) on the 10939 are in the off state.
b. The Segment Drivers (SG01-SG16) on the 10941 are in the off state.
c. The Duty Cycle is set to 0 .
d. The Digit Counter is set to 32 .
e. The Buffer Pointer is set to 0 .
f. The Digit time is set to 64 .
g. The Normal display mode is set.
h. DATA-LOAD is set to high impedance state.
i. SCLK-DIS is set to \(\mathrm{V}_{\text {OL }}\) to disable the anode drivers in the 10941.
j. SOP is set to \(V_{O L}\) to disable the sync pulse.

\section*{Note:}
1. When the POR signal is removed, SCLK-DIS is set to the high impedance state.
2. During the initial rise time of \(V_{D D}\) at power turn-on, the magnitude of \(\mathrm{V}_{\mathrm{GG}}\) should not exceed the magnitude of \(\mathrm{V}_{\mathrm{DD}}\).

\section*{DIGIT (GRID) DRIVERS (STR00-STR19) PLUS CURSOR}

The 20 Digit (Grid) Drivers select each of the display character positions sequentially during a refresh scan. Display segments are illuminated when both the Digit Drivers and Segment Drivers for a particular character are energized simultaneously. The Cursor segment is generated by the 10939, but its timing characteristics are identical to the 16 segments generated by the 10941 .

\section*{SEGMENT (ANODE) DRIVERS (SG01-SG16, PNT, TAIL)}

Eighteen Segment (Anode) Drivers are provided in the 10941. The output states for each character pattern and each bargraph pattern are internally decoded from the 8-bit characters received from the 10939 by means of a \(128 \times 18\)-bit PLA. Data codes and the corresponding segment patterns are shown in Figure 1. Data codes and the corresponding bargraph patterns are shown in Figure 2.


Figure 1. 16-Segment PLA Character Codes


Figure 2. 16-Segment BarGraph Codes

\section*{TYPICAL SYSTEM HOOKUPS}

Figure 3 shows a 10941 and 10939 in a parallel interface with the host system driving a 20 character display. Figure 4 shows a 10941 and a 10939 in a serial interface with the host system
driving a 20 character display. Figure 5 shows a 10941 and two 10939's in a parallel interface with the host system driving a 40 character display.


Figure 3. Typical Display System with Parallel Interface to Host System


Figure 4. Typical Display System with Serial Interface to Host System


Figure 5. Typical Display System with Parallel Interface to Host and Two 10939 Devices

\section*{10951 \\ Bargraph and Numeric Display Controller}

\section*{DESCRIPTION}

The Rockwell 10951 Bargraph and Numeric Display Controller is an LSI general purpose display controller designed to interface to bargraph and numeric displays (vacuum fluorescent or LED).
The 10951 will drive 16 -segment bargraph or seven-segment plus comma and decimal numeric displays with up to 16 display positions. The controller accepts command and data input words on a clocked serial input line. Commands control the on/off duty cycle, starting character position and number of characters to display. Encoded data words display bargraph position (single segment or increasing bar length), numbers, comma, decimal and selected upper and lower case letters. No external drive circuitry is required for displays that operate on 20 mA of drive current up to 50 volts. A \(64 \times 16\)-bit segment decoder provides character set decoding for the display.

ORDERING INFORMATION
\begin{tabular}{|c|c|c|c|}
\hline \begin{tabular}{c} 
Part \\
Number
\end{tabular} & \begin{tabular}{c} 
Package \\
Type
\end{tabular} & \begin{tabular}{c} 
Drive \\
Voltage
\end{tabular} & \begin{tabular}{c} 
Temperature \\
Range \(\left({ }^{\circ} \mathrm{C}\right)\)
\end{tabular} \\
\hline \(10951 \mathrm{P}-40\) & Plastic & 40 V & 0 to +70 \\
\(10951 \mathrm{P}-50\) & Plastic & 50 V & 0 to +70 \\
10951 PE-40 & Plastic & 40 V & -40 to +85 \\
10951PE-50 & Plastic & 50 V & -40 to +85 \\
\hline
\end{tabular}

\section*{FEATURES}
- 16 segment drivers plus decimal point and comma tail drivers
- 16 digit drivers
- Up to 66 kHz data rate
- Direct digit drive of 20 mA for up to 50 volt displays
- Supports vacuum fluorescent or LED displays
- Serial data input for 8 -bit display and control data words
- \(64 \times 16\)-bit PLA provides data decoding driving
- Any 1 of 16 bargraph segments
- 1 to 16 bargraph segments
- Ten seven-segment numeric characters (0-9)
- Comma and decimal
- Eight upper and lower case seven-segment characters
- Command functions
— Duty cycle adjust
- Character position select
- Number of characters
- 40-Pin DIP package


\section*{INTERFACE DESCRIPTION}

10951 Pin Functions
\begin{tabular}{|l|c|l|}
\hline Signal Name & Pin No. & \multicolumn{1}{|c|}{ Function } \\
\hline V \(_{\text {SS }}\) & 1 & Power and signal reference \\
AD16-AD1 & \(2-17\) & Digits 16 through 1 driver outputs \\
V DD \(^{\text {A }}\) & 18 & DC power connection \\
A & 19 & A clock output used for testing \\
POR & 20 & Power-on reset input \\
DATA & 21 & Serial data input \\
SCLK & 22 & Serial data clock input \\
SGA-SGP & \(23-38\) & Segments A through P driver outputs \\
TAIL & 39 & Comma tail driver output \\
PNT & 40 & Decimal point driver output \\
\hline
\end{tabular}

\section*{SPECIFICATIONS}

\section*{ABSOLUTE MAXIMUM RATINGS*}

All voltages are specified relative to \(V_{S S}\).
\begin{tabular}{|l|l|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{DD}}\) & +0.3 to -20 & V \\
Operating Current & \(\mathrm{I}_{\mathrm{DD}}\) & \(7-0.3\) to -20 & mA \\
Input Voltage & \(\mathrm{V}_{\text {IN }}\) & +0.3 \\
Output Voltage & \(\mathrm{V}_{\text {IV }}\) & +0.3 to -50 & V \\
Output Current Digits & \(\mathrm{I}_{\mathrm{D}}\) & 20 & mA \\
Output Current Segments & \(\mathrm{I}_{\mathrm{S}}\) & 10 & mA \\
Operating Temperature & & 0 & mA \\
Commercial & \(\mathrm{T}_{\mathrm{C}}\) & 0 to +70 & \({ }^{\circ} \mathrm{C}\) \\
Industrial & \(\mathrm{T}_{1}\) & -40 to +85 & \({ }^{\circ} \mathrm{C}\) \\
Storage Temperature & \(\mathrm{T}_{\text {STG }}\) & -55 to +125 & \({ }^{\circ} \mathrm{C}\) \\
Input Capacitance & \(\mathrm{C}_{\text {IN }}\) & 5 & pF \\
Output Capacitance & \(\mathrm{C}_{\text {OUT }}\) & 10 & pF \\
\hline
\end{tabular}


\section*{10951 Pin Configuration}
*NOTE: Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Parameter} & \multicolumn{3}{|c|}{Limits ( \(\mathrm{V}_{\mathbf{S S}}=0\) )} & \multicolumn{3}{|c|}{Limits ( \(\left.\mathrm{V}_{\mathrm{SS}}=+5 \mathrm{~V}\right)\)} & \multirow[b]{2}{*}{Conditions} & \multirow[b]{2}{*}{Unit} \\
\hline & Min & Typ & Max & Min & Typ & Max & & \\
\hline Supply Voltage ( \(\mathrm{V}_{\mathrm{DD}}\) ) & -16.5 & - 15.0 & -13.5 & -11.5 & -10.0 & -8.5 & & V \\
\hline Power Dissipation & & 40 & 100 & & 40 & 100 & & mW \\
\hline Input DATA,SCLK, & & & & & & & & \\
\hline Logic " 1 "' & -1.0 & & +0.3 & +4.0 & & + 5.3 & & V \\
\hline Logic "0" & \(V_{D D}\) & & -4.2 & \(V_{D D}\) & & +0.8 & & \\
\hline Input POR & & & & & & & & \\
\hline Logic "1" & -3.0 & & +0.3 & +2.0 & & +5.3 & & \\
\hline Logic " 0 "' & \(V_{D D}\) & & -10.0 & \(\mathrm{V}_{\mathrm{DD}}\) & & -5.0 & & \\
\hline Output Digit and & & & & & & & & \({ }^{*}\) \\
\hline Segment Strobes & & & & & & & & \\
\hline Driver On & & & & & & & & \\
\hline Commercial & & & -1.5 & & & +3.5 \(\}\) & & V \\
\hline Industrial & & & -1.7 & & & +3.3 \(\}\) & At 10 mA & V \\
\hline Driver Off 10951-40 & -40 & & -35 & -35 & & -30 ) & Actual value & V \\
\hline Driver Off 10951-50 & -50 & & -45 & -45 & & \(-40\}\) & determined by external circuit & V \\
\hline & & & & & & 10 & Per driver at & \\
\hline Input Leakage & & & 10 & & & 10 10 & Per driver at driver off & \(\mu \mathrm{A}\) \\
\hline
\end{tabular}

AC CHARACTERISTICS
\begin{tabular}{|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ & Max & Unit \\
\hline SCLK Clock & & & & \\
On Time & \(T_{\text {on }}\) & & & \\
On Time & \(T_{\text {off }}\) & 1.0 & & \\
Data Input Sample Time & & & & \\
Before SCLK Clock Off & \(T_{\text {boff }}\) & 200 & & \\
After SCLK Clock Off & \(T_{\text {aoff }}\) & 100 & & \\
\hline
\end{tabular}


SCLK and Serial Data Timing


SCLK and Serial Data (Control Word) Examples


Data Word LSB/MSB Timing


Power-On Reset

\section*{FUNCTIONAL DESCRIPTION}

The 10951 receives commands and data on a serial input line clocked externally by a separate clock input line. The controller decodes the commands from control data words, decodes the data words in accordance with an internal \(64 \times 16\)-bit programmable logic array (PLA) and turns on and off segment and digit output drivers. The segment output patterns are controlled by the decoded data words while the digit output and segment output timing are controlled by the decoded control words. All timing signals required to control the display are generated in the 10951 device without any refresh input from the host processor.

Input data is loaded into the Display Data Buffer via the Serial Data Input (Data) channel. Internal timing and control blocks synchronize the segment and digit output signals to provide the proper timing for the multiplexing operation. The \(16 \times 64\) PLA decodes 8 -bit data words to drive the 16 segment, comma and decimal point drivers. The decoded data words will drive 16 segments to display bargaph patterns (single segment and multiple segment for increasing length displays) or seven-segment patterns to display numbers, selected upper and lower case letters, comma and decimal point.

Input data is loaded into the 10951 as a series of 8 -bit words with the most significant bit (MSB), bit 7, first. If the MSB is a logic 1 (this bit is referred to as the control bit C), the loaded word is a control data word. If the C bit of any word is a logic 0 , the loaded word is a display data word. The following paragraphs describe the format and functions of these control and display data words.

\section*{INPUT CONTROL DATA WORDS}

When the C-Bit (bit 7) of the 8 -bit input word is a logic 1, bits 5 and 6 are decoded into one of four control commands while data associated with the command are extracted from bits \(0-4\). There are four control codes which perform the following display functions:
- Load the Display Data Buffer pointer,
- Load the Digit Counter,
- Load the Duty Cycle register,
- Enable the Test Mode.

Table 1 lists the control codes and their functions.

\section*{Buffer Pointer Control}

The Buffer Pointer Control code allows the Display Data Buffer pointer to be set to any digit position so that individual characters may be modified. The Buffer Pointer is loaded with a decimal equivalent value 2 less than the desired value (i.e., to point to the digit controlled by AD6 of the display, a value of 4 is entered). See Table 2 for a complete list of the Buffer Pointer values.

\section*{Digit Counter Control}

The Digit Counter Control code is normally used only during initialization routines to define the number of character positions to be controlled. This code maximizes the duty cycle for any display. If 16 characters are to be controlled, enter a value of 0 (zero). Otherwise, enter the value desired.

\section*{Duty Cycle Control}

The Duty Cycle Control code is used to turn the display on and off, and to adjust display brightness. As shown in the block diagram, the time slot for each character is 32 clock cycles. The segment and digit drivers for each character are on for a maximum of 31 cycles with a 1 cycle inter-digit off-time. The Duty Cycle Control code contains a 5-bit numeric field which modifies the on-time for the driver outputs from 0 to 31 cycles. A duty cycle of 0 puts both the segment and digit drivers into the off state. Figure 1 shows the timing characteristics for the segment outputs.

\section*{Test Mode Enable}

The Test Mode Enable code is a device test function only. If executed, it will lock the device in the Test Mode. This mode can be disabled only by performing a power-on reset.

If this mode is activated, the digit time is reduced from 32 to 4 clock cycles to speed up the output driver sequencing time for ease in testing.

Table 1. Control Data Words
\begin{tabular}{|c|c|c|}
\hline \multicolumn{2}{|c|}{8-Bit Control Word} & \multirow[b]{2}{*}{Function} \\
\hline C-Bit & 7-Bit Code & \\
\hline 1 & O10NNNN \({ }^{1}\) & Buffer Pointer Control (Position of character to be changed) \\
\hline 1 & 100NNNN \({ }^{1}\) & Digit Counter Control (Number of characters to be output) \\
\hline 1 & 11NNNNN2 & Duty Cycle Control (On/off and brightness control) \\
\hline 1 & OONNNNN \({ }^{3}\) & Test Mode Enable (Not a user function) \\
\hline \multicolumn{3}{|l|}{Note:} \\
\hline \multicolumn{3}{|l|}{1. NNNN is a 4-bit binary value representing the digit number to be loaded.} \\
\hline \multicolumn{3}{|l|}{2. NNNNN is a 5-bit binary value representing the number of clock cycles each digit is on.} \\
\hline \multicolumn{3}{|l|}{3. This code is a device test function only. If executed it will lock the device in the Test Mode. Test Mode can be disabled only by performing a power-on reset.} \\
\hline
\end{tabular}

Table 2. Buffer Pointer Control Codes
\begin{tabular}{|c|c|c|}
\hline Hex Code & Pointer Value & Character Controlled By \\
\hline A0 & 0 & AD2 \\
A1 & 1 & AD3 \\
A2 & 2 & AD4 \\
A3 & 3 & AD5 \\
A4 & 4 & AD6 \\
A5 & 5 & AD7 \\
A6 & 6 & AD8 \\
A7 & 7 & AD9 \\
A8 & 8 & AD10 \\
A9 & 9 & AD111 \\
AA & 10 & AD12 \\
AB & 11 & AD13 \\
AC & 12 & AD14 \\
AD & 13 & AD15 \\
AE & 14 & AD16 \\
AF & 15 & AD1 \\
\hline
\end{tabular}

\section*{INPUT DISPLAY DATA WORDS}

Display data words are loaded as 8 -bit format codes. There are 64 codes available (with the C -bit set to 0 to indicate a display data word).

Sixteen display data words must be entered to completely load the Display Data Buffer. The Buffer Pointer is automatically incremented before each data word is stored in the Display Buffer except for decimal point and comma words. The decimal point and comma words do not cause the Buffer Pointer to increment and thus are always associated with the previous character entered. To enter a character position out of the normal sequence, use the Buffer Pointer control command before entering the display data word. It is not necessary to use the Buffer Pointer control command to cycle back to position 1 when less than 16 character positions are being used (Digit Counter \(\neq 0\) ).

\section*{DIGIT DRIVERS (AD1-AD16)}

The sixteen Digit Drivers (AD1 - AD16) are used to select each of the display digits sequentially during a refresh scan. Display segments will be illuminated when both the Digit Drivers and Segment Drivers for a particular character are energized simultaneously. The timing characteristics of both the digits and segments are shown in Figure 1. See POR for the Power-On Reset state of these drivers.


Figure 1. Display Scan Timing Diagram (Duty Cycle)

\section*{POWER-ON RESET (POR)}

The Power-On Reset (POR) initializes the internal circuits of the 10951 when power ( \(\mathrm{V}_{\mathrm{DD}}\) ) is applied. The following conditions are established after a Power-On Reset:
a. The Digit Drivers (AD1-AD16) are in the off state (floating).
b. The Segment Drivers (SGA-SGP) are in the off state (floating).

This includes PNT and TAIL.
c. The Duty Cycle is set to 0 .
d. The Digit Counter is set to 16 (a bit code value of 0 ).
e. The Buffer Pointer points to the character controlled by AD1.

\section*{SEGMENT DRIVERS (SGA-SGP)}

Sixteen (16) Segment Drivers are provided (SGA-SGP), plus the decimal point (PNT) and comma tail (TAIL). The segment, PNT and TAIL outputs are internally decoded from the 8 -bit characters in the Display Data Buffer by means of a \(64 \times 16\)-bit PLA. The driver allocations for the 16 -segment bargraph display and the seven-segment alphanumeric character plus comma and
decimal point are shown in Figure 2. The input codes associated with seven-segment alphanumeric, comma and decimal point display are also shown in Figure 2. The complete set of 8-bit codes for the bargraph and alphanumeric display is shown in Table 3. Note that only segment drivers SGA-SGG are used to drive the seven-segment characters. Segment drivers SGH-SGP may be used for other purposes as decoded in accordance with Table 3. Figure 3 shows the total allocation of the 16 -segment drivers as they would appear on a 7-segment display or a 16 -segment bargraph display. Timing characteristics for the segment outputs are shown in Figure 1. See POR for the Power-On Reset state of these drivers.

\section*{TYPICAL SYSTEM HOOK-UP}

Figure 4 shows the 10951 as it would be connected to a V-F display when driven by a host system. \(\mathrm{E}_{\mathrm{K}}\) is determined by the V-F display specifications and \(R_{C}\) is selected to provide proper biasing current for zeners. Pull down resistors \(R_{A}\) and \(R_{G}\) are determined by the interconnection capacitance between the 10951 and the display.

Table 3. 10951 Data Codes



Figure 2. Segment Allocation and 7-Segment Alphanumeric Codes


Figure 3. Total Character Allocation for Bargraph or 7-Segment Displays


Figure 4. Partial System Schematic


\section*{10955}

Segmented Display Controller/Driver

\section*{DESCRIPTION}

The 10955 Segmented Display/Driver is a MOS/LSI device capable of directly driving both the grids and anodes of multiplexed vacuum-fluorescent segmented displays. All timing circuits (including a clock generator) required to control the display drivers are contained within the device. The 10955 can drive segmented displays with 8 or 16 grids (characters) and 8,16 , or 24 anodes (segments). A serial interface allows for a host microprocessor to transmit commands and display data to the 10955 directly.

A \(128 \times 16\) bit PLA provides coding for both 16 -segment and 14 -segment alphanumeric ASCII code character sets (all caps only). The PLA is divided into lower 64 and upper 64 code sets. Only one set can be selected at a time. In lower set mode the 16 -segment display characters are selected. In upper set mode the 14 -segment display characters are selected. The PLA can also be bypassed so that data words from the host microprocessor are loaded directly into segment drivers without decoding by the PLA. This mode is especially useful for creating special display patterns such as bar graph displays. Bypass mode is limited to eight drivers per data word.

\section*{FEATURES}
- 8 - or 16 -character display driver
- 8 -, 16-, or 24 -segment drivers
- Average data rate 66 kHz
- Single character burst rate 500 kHz
- Direct digit drive of 20 ma for up to 40 or 50 voit vacuumfluorescent serial displays
- \(128 \times 16\)-bit PLA provides 16 - or 14 -segment alpha-numeric character set
- Internal clock generator circuit
- Serial host interface
- PLA bypass mode
- 40-pin DIP

\section*{ORDERING INFORMATION}
\begin{tabular}{|c|c|c|c|}
\hline \begin{tabular}{c} 
Part \\
Number
\end{tabular} & \begin{tabular}{c} 
Package \\
Type
\end{tabular} & \begin{tabular}{c} 
Drive \\
Voltage
\end{tabular} & \begin{tabular}{c} 
Temperature \\
Range \(\left({ }^{\circ} \mathbf{C}\right)\)
\end{tabular} \\
\hline 10955P-40 & Plastic & 40 V & 0 to +70 \\
10955P-50 & Plastic & 50 V & 0 to +70 \\
10955PE-40 & Plastic & 40 V & -40 to +85 \\
10955PE-50 & Plastic & 50 V & -40 to +85 \\
\hline
\end{tabular}


\section*{INTERFACE DESCRIPTION}
\begin{tabular}{|l|c|l|}
\hline \multicolumn{1}{|c|}{ Signal Name } & Pin No. & \multicolumn{1}{c|}{ Function } \\
\hline V \(_{\text {SS }}\) & 1 & Power and signal reference \\
C12P & 2 & Test clock-factory test \\
SCLK & 3 & Serial input data clock \\
DATAIN & 4 & Serial data input \\
SEGA-SEGP & \(5-20\) & Segments A through P driver \\
& outputs \\
D7/STR15-D0/STR08 & \(21-28\) & Direct segment outputs or \\
& & strobe outputs \\
STR07-STR00 & \(29-35,37\) & Strobe outputs \\
V GG \(^{\text {VDD }}\) & 36 & Display voltage \\
POR & 38 & Logic supply voltage \\
LD & 39 & Power on reset \\
\hline
\end{tabular}

\section*{SPECIFICATIONS}

\section*{ABSOLUTE MAXIMUM RATINGS*}

All voltages are specified relative to \(V_{S S}\).
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{DD}}\) & +0.3 to -25 & V \\
Operating Current & \(\mathrm{I}_{\mathrm{DD}}\) & 8 & mA \\
Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & +0.3 to -25 & V \\
Display Voltage & \(\mathrm{V}_{\mathrm{GG}}\) & +0.3 to -50 & V \\
Operating Temperature & & & \\
Commercial & \(\mathrm{T}_{\mathrm{C}}\) & 0 to +70 & \({ }^{\circ} \mathrm{C}\) \\
Industrial & \(\mathrm{T}_{\mathrm{I}}\) & -40 to +85 & \({ }^{\circ} \mathrm{C}\) \\
Storage Temperature & \(\mathrm{T}_{\mathrm{STG}}\) & -55 to +125 & \({ }^{\circ} \mathrm{C}\) \\
Input Capacitance & \(\mathrm{C}_{\text {IN }}\) & 5 & pF \\
Output Capacitance & \(\mathrm{C}_{\mathrm{OUT}}\) & 10 & pF \\
\hline
\end{tabular}


\section*{10955 Pin Configuration}
*Note: Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}
\(\left(V_{D D}=-18.0\right.\) to \(-22.0 \mathrm{Vdc}, \mathrm{V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{TA}=0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\) (commercial) or \(-40^{\circ} \mathrm{C}\) to \(+85^{\circ} \mathrm{C}\) (industrial), unless otherwise noted. All voltages referenced to \(V_{S S}\).)
\begin{tabular}{|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min. \({ }^{4}\) & Typical \({ }^{3}\) & Max. \({ }^{4}\) & Unit \\
\hline Operating Current, Logic Commercial Industrial & \(\mathrm{I}_{\mathrm{DD}}\) & - & \[
\begin{aligned}
& 3.2 \\
& 4.0
\end{aligned}
\] & \[
\begin{aligned}
& 6.4 \\
& 8.0 \\
& \hline
\end{aligned}
\] & mA \\
\hline \begin{tabular}{l}
Operating Current Display \\
1 strobe plus 24 segments @ \(V_{\mathrm{OH}}\) Commercial Industrial \\
1 strobe plus 16 segments @ \(\mathrm{V}_{\mathrm{OH}}\) Commercial Industrial \\
All display drivers \\
(1) \(\mathrm{V}_{\mathrm{GG}}\) and \(85^{\circ} \mathrm{C}\)
\end{tabular} & \(\mathrm{I}_{\mathrm{GG}}\) & -
-
- & -
-
-
- & \[
\begin{aligned}
& 6.5 \\
& 8.0 \\
& 4.3 \\
& 5.3 \\
& 320
\end{aligned}
\] & \begin{tabular}{l}
mA \\
mA \\
mA \\
mA \\
\(\mu \mathrm{A}\)
\end{tabular} \\
\hline \[
\begin{aligned}
& \text { Display Voltage } \\
& 10955-40 \\
& 10955-50
\end{aligned}
\] & \(V_{G G}\) & \[
\begin{aligned}
& -40.0 \\
& -50.0
\end{aligned}
\] & - & - & V \\
\hline Input Leakage (at -20V) & \(1 / 2\) & - & - & 10 & \(\mu \mathrm{A}\) \\
\hline \[
\begin{aligned}
& \text { Input (DATAIN, LD, SCLK) } \\
& \text { Logic "1"", } \\
& \text { Logic " } 0 \text { " } \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& v_{1 H} \\
& v_{\mathrm{IL}}
\end{aligned}
\] & \[
\begin{aligned}
& \bar{v}_{D D}^{-1.2} \\
& \hline
\end{aligned}
\] & \[
\begin{array}{r}
-0.5 \\
-6.0 \\
\hline
\end{array}
\] & \[
\begin{aligned}
& +0.3 \\
& -4.2
\end{aligned}
\] & V \\
\hline \[
\begin{aligned}
& \text { Input POR } \\
& \text { Logic "1", " } 0 \text { " }
\end{aligned}
\] & \[
\begin{aligned}
& V_{\text {IHPO }} \\
& V_{\text {ILPP }}
\end{aligned}
\] & \[
\bar{v}_{D D}^{-3.0}
\] & - 12.0 & \[
\begin{array}{r}
+0.3 \\
-10.0 \\
\hline
\end{array}
\] & V \\
\hline \[
\begin{gathered}
\hline \text { Output (C12P) } \\
\text { Logic " } 1 \text { "', } \\
\text { Logic " } 0 \text { " } 1 \\
\hline
\end{gathered}
\] & \[
\begin{aligned}
& V_{\text {OHSY }} \\
& V_{\text {OLSY }}
\end{aligned}
\] & \[
\begin{aligned}
& -0.7 \\
& V_{D D} \\
& \hline
\end{aligned}
\] & - & +0.3 & V \\
\hline ```
Output (Strobe STR00-07, D0-D7, SGA-SGP)
    Logic " 1 " ( Load \(=10 \mathrm{~mA}\) )
    Logic "1" ( \((\text { Load }=20 \mathrm{~mA})^{2}\)
    Logic " 0 " ( Load \(=0 \mathrm{~mA}\) )
``` & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{OH}} \\
& \mathrm{~V}_{\mathrm{OH}}
\end{aligned}
\] & \[
\frac{-1.5}{V_{\mathrm{GG}}}
\] & \[
\begin{gathered}
-1.0 \\
-2.0 \\
0.5+V_{G G}
\end{gathered}
\] & \[
\begin{gathered}
V_{\mathrm{SS}} \\
V_{\mathrm{SS}} \\
0.95 \times \mathrm{V}_{\mathrm{GG}}
\end{gathered}
\] & V \\
\hline \multicolumn{6}{|l|}{\begin{tabular}{l}
Notes: \\
1. Open drain driver. Requires external pull-down resistor for testing only. \\
2. STR00-STR07 only (also for D0-D7 when used as character drivers) \\
3. Typical measured at \(V_{D D}=20.0 \mathrm{~V}\) and \(Y_{A}=25^{\circ} \mathrm{C}\). \\
4. Max. values are most positive limits. Min. values are most negative limits.
\end{tabular}} \\
\hline
\end{tabular}

\section*{AC CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|c|}
\hline Characteristic & Symbol & Min. & Max. & Unit \\
\hline \begin{tabular}{l}
Clock Timing Cycle Time \\
Commercial \\
Industrial \\
HOST INTERFACE TIMING \\
Serial Clock (SCLK) \\
On Time \\
Off Time \\
Cycle Time \\
Serial Data (DATAIN) \\
Set-up Time \\
Hold Time \\
Serial Clock to LD Time \\
LD to Serial Clock \\
Data Load (LD) \\
On Time \\
Off Time (Commercial \\
Off Time (Industrial) \\
Cycle Time (Commercial) \\
Cycle Time (Industrial)
\end{tabular} & \begin{tabular}{l}
\({ }^{t_{C Y C}}\) \\
\(t_{\text {SCON }}\) \({ }^{\text {t }}\) SCOFF \(t_{\mathrm{SCCYC}}\) \\
\(t_{\text {SSETUP }}\) \\
\(t_{\text {SHOLD }}\) \\
\(t_{S L}\) \\
\(t_{\text {LS }}\) \\
tLDON \\
t LDOFF \\
\(t_{\text {LDOFF }}\) \\
\(t_{\text {LDCYC }}\) \\
\(\mathrm{t}_{\text {LDCYC }}\)
\end{tabular} & \begin{tabular}{l}
6.66
5.88 \\
1.2 \\
1.0 \\
2.2 \\
400 \\
400 \\
600 \\
400 \\
1.0 \\
46.0 \\
48.0 \\
69.0 \\
72.0
\end{tabular} & \begin{tabular}{l}
\[
\begin{aligned}
& 23.0 \\
& 24.0
\end{aligned}
\] \\
40.0 \\
- \\
- \\
- \\
- \\
-
\end{tabular} & \begin{tabular}{l}
usec usec \\
usec usec usec \\
nsec nsec nsec nsec usec usec usec usec usec
\end{tabular} \\
\hline \multicolumn{5}{|l|}{\begin{tabular}{l}
Note: \\
\(t_{r}\) and \(t_{f}=\) rise and fall time of clocking signals which are 10 to 30 nsec.
\end{tabular}} \\
\hline
\end{tabular}


Serial Interface Timing Waveforms


Display Scan Timing Diagram

\section*{FUNCTIONAL DESCRIPTION}

All timing signals required to control the display are generated by the 10955 device after the display buffer and control registers have been loaded from the host processor. In the following functional description, refer to the 10955 block diagram.

Input data is loaded into the Display Data Buffer via the serial data input channel. Internal timing and control logic synchronize the digit output signals with the segment output signals to provide the proper timing for the multiplexing operation. The segment decoding is performed in a \(128 \times 16\) PLA character code set.

\section*{CHARACTER DRIVERS (STR00-STR07)}

The eight character (grid) drivers are used to select the display character positions sequentially during a refresh scan. Display characters are illuminated when the character driver for a particular character position and the segment (anode) drivers are energized simultaneously.

\section*{DISCRETE DRIVERS (D0-D7)}

The function of these eight drivers depends on the display mode. In some modes these drivers act as segment (anode) drivers
loaded directly from the Data Buffer (RAM). In other modes these drivers are used as extra character (grid) drivers (STR8-STR15). See Display Modes for further discussion of these driver functions.

\section*{SEGMENT DRIVERS (SGA-SGP)}

Depending on the display mode, the sixteen segment drivers are loaded through an \(8 \times 16\) PLA decoder or directly from the Data Buffer RAM.

\section*{SYSTEM CLOCK}

Each 10955 device has its own on-board oscillator and clock generator.

\section*{POWER-ON RESET}

The Power-On Reset (POR) input initializes the internal circuits of the 10955. This is normally performed when power (VDD) is applied. The following conditions are established by application of POR:
a. The grid and anode drivers (STR00-STR07, D0-D7, and SGASGP) are in the off state.
b. Duty Cycle register is set to zero.
c. The Digit Counter is set to 32 digits.
d. The Buffer Pointer is set to zero.
e. The Digit Time is set to 64.
f. The PLA Bypass/Sixteen Digit display mode is set.

At power on, the 10955 is held in an internal halt mode. This allows the host system to load the control registers and the data buffer without flashing invalid data on the display.

During the initial rise time of VDD at power turn-on, the magnitude of VGG should not exceed the magnitude of VDD.

\section*{HOST SYSTEM INTERFACE}

Input data is loaded into the 10955 via a serial data input channel as a series of nine-bit words.

After nine bits of data (with the most significant bit first) have been shifted into the data buffer, a pulse on the LD signal loads the data into an internal buffer and informs the 10955 that a new data word is available. After the LD pulse, a new data word may be shifted in while the 10955 is processing the first word.

The following sections describe the format and functions of the input words which may contain either control data or display data.

\section*{Display Data Words}

Display data words are loaded as nine bit codes. The lower eight bits ( \(7-0\) ) are data. The ninth bit (the most significant) is always a zero (0).

Sixteen display data words must be entered to completely load the Display Data Buffer. The Buffer Pointer is automatically incremented after each data word is stored in the buffer. The Buffer Pointer will automatically reset to character position 0 when its value is equal to the programmed digit count value. The Buffer Pointer may be set to any desired value with the Buffer Pointer Control Word. This permits arbitrary loading of the Display Data Buffer.

\section*{Control Words}

Control words are distinguished from display words by the fact that the most significant bit is always a one. Control words and their functions are defined below.

\begin{tabular}{llllllll}
0 & 1 & \(X\) & \(X\) & \(X\) & \(X\) & \(X\) & \(X\) \\
1 & 0 & 0 & \(X\) & \(X\) & \(X\) & \(X\) & \(X\) \\
1 & 1 & 0 & 0 & \(X\) & \(X\) & \(X\) & \(X\) \\
0 & 0 & 0 & \(X\) & \(X\) & \(X\) & \(X\) & \(X\) \\
0 & 0 & 0 & \(X\) & \(X\) & \(Y\) & 0 & 0 \\
0 & 0 & 0 & \(X\) & \(X\) & \(Y\) & 0 & 1 \\
0 & 0 & 0 & \(X\) & \(X\) & \(Y\) & 1 & 0 \\
0 & 0 & 0 & \(X\) & \(X\) & \(Y\) & 1 & 1 \\
0 & 0 & 0 & \(X\) & \(X\) & 0 & \(Z\) & \(Z\) \\
0 & 0 & 0 & \(X\) & \(X\) & 1 & \(Z\) & \(Z\) \\
0 & 0 & 0 & 0 & 0 & \(Y\) & \(Z\) & \(Z\) \\
0 & 0 & 0 & 0 & 1 & \(Y\) & \(Z\) & \(Z\) \\
0 & 0 & 0 & 1 & 0 & \(Y\) & \(Z\) & \(Z\) \\
0 & 0 & 0 & 1 & 1 & \(Y\) & \(Z\) & \(Z\)
\end{tabular}

\section*{BIT}

DUTY CYCLE, DIGIT COUNT, BUFFER POINTER
\(\longleftarrow\) CONTROL REGISTER

\section*{DUTY CYCLE CONTROL} DIGIT COUNT CONTROL BUFFER POINTER CONTROL CONTROL REGISTER
( 5 bits coded as shown below)
64 cycles per grid
16 cycles per grid
32 cycles per grid
8 cycles per grid
16 digit configuration
8 digit and two output
PLA bypass
Reserved for upgrade
Lower 64 PLA (64U)
Lower 64 PLA (64L)

\section*{Buffer Pointer}

The Buffer Pointer Control code sets the Display Data Buffer Pointer. The five least significant bits of the code are loaded into the Buffer Pointer to select the character position as shown in Table 1.

Table 1. Load Buffer Pointer Codes
\begin{tabular}{|c|c|c|}
\hline \begin{tabular}{c} 
Load Code \\
Value
\end{tabular} & \begin{tabular}{c} 
Pointer \\
Value
\end{tabular} & \begin{tabular}{c} 
Character Position \\
Selected
\end{tabular} \\
\hline C0 & 00 & 0 \\
C1 & 01 & 1 \\
C2 & 02 & 2 \\
C3 & 03 & 3 \\
C4 & 04 & 4 \\
C5 & 05 & 5 \\
C6 & 06 & 6 \\
C7 & 07 & 7 \\
C8 & 08 & 8 \\
C9 & 09 & 9 \\
CA & OA & 10 \\
CB & OB & 11 \\
CC & OC & 12 \\
CD & OD & 13 \\
CE & OE & 14 \\
CF & OF & 15 \\
\hline
\end{tabular}

\section*{Digit Count Control}

The Digit Count Control command defines the number of character positions (grids) to be controlled. This code is normally used only during initialization routines, but it may also be used in conjunction with the Duty Cycle Control code to extend the range of brightness control. Strobing begins at character position 0 and proceeds thru the last position specified. If more than 16 grids are selected (17-32), extra time slots are generated for these phantom strobes. When the phantom strobes are active, strobes 0 through 15 are off so the displayed data is not affected
although the duty cycle is decreased as each phantom strobe is added. The code, digit count value, and number of grids controlled by the Digit Counter are shown in Table 2.

Table 2. Load Digit Counter Control Codes
\begin{tabular}{|c|c|c|}
\hline Code & Digit Counter Value & No. of Grids Controlled \\
\hline 80 & 00 & 32 \\
\hline 81 & 01 & 1 \\
\hline 82 & 02 & 2 \\
\hline 83 & 03 & 3 \\
\hline 84 & 04 & 4 \\
\hline 85 & 05 & 5 \\
\hline 86 & 06 & 6 \\
\hline 87 & 07 & 7 \\
\hline 88 & 08 & 8 \\
\hline 89 & 09 & 9 \\
\hline 8A & OA & 10 \\
\hline 8B & OB & 11 \\
\hline 8 C & OC & 12 \\
\hline 8D & OD & 13 \\
\hline 8E & OE & 14 \\
\hline 8 F & OF & 15 \\
\hline 90 & 10 & 16 \\
\hline 91 & 11 & 17 \\
\hline 92 & 12 & 18 \\
\hline 93 & 13 & 19 \\
\hline 94 & 14 & 20 \\
\hline 95 & 15 & 21 \\
\hline 96 & 16 & 22 \\
\hline 97 & 17 & 23 \\
\hline 98 & 18 & 24 \\
\hline 99 & 19 & 25 \\
\hline 9A & 1A & 26 \\
\hline 9 B & 1 B & 27 \\
\hline 9 C & 1 C & 28 \\
\hline 9D & 1D & 29 \\
\hline 9 E & 1E & 30 \\
\hline 9 F & 1F & 31 \\
\hline
\end{tabular}

\section*{Duty Cycle}

The Duty Cycle Control code is used to turn on and off the display, to adjust display brightness, or to modify display timing. The time slot for each character is \(8,16,32\), or 64 internal cycles (an internal cycle \(=1 / 2 \mathrm{t}_{\mathrm{CYC}}\) as selected by the Digit

Time codes in the control register. The segment and digit drivers for each character may be turned on for a maximum of 5,13 , 29 , or 61 cycles with a 3 cycle mandatory inter-digit off time. The lower six bits of the Duty Cycle Control code are loaded into the Duty Cycle Register. Resultant duty cycles (on-times and off-times) are shown in Table 3.

Table 3. Duty Cycle Control Codes
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Code} & \multicolumn{2}{|r|}{Digit Time \(=8\)} & \multicolumn{2}{|l|}{Digit Time \(=16\)} & \multicolumn{2}{|l|}{Digit Time \(=32\)} & \multicolumn{2}{|l|}{Digit Time \(=64\)} \\
\hline & On & Off & On & Off & On & Off & On & Off \\
\hline 40 & - & 8 & - & 16 & - & 32 & - & 64 \\
\hline 41 & - & 8 & - & 16 & - & 32 & - & 64 \\
\hline 42 & - & 8 & - & 16 & - & 32 & - & 64 \\
\hline 43 & 1 & 7 & 1 & 15 & 1 & 31 & 1 & 63 \\
\hline 44 & 2 & 6 & 2 & 14 & 2 & 30 & 2 & 62 \\
\hline 45 & 3 & 5 & 3 & 13 & 3 & 29 & 3 & 61 \\
\hline 46 & 4 & 4 & 4 & 12 & 4 & 28 & 4 & 60 \\
\hline 47 & 5 & 3 & 5 & 11 & 5 & 27 & 5 & 59 \\
\hline 48 & 5 & 3 & 6 & 10 & 6 & 26 & 6 & 58 \\
\hline 49 & 5 & 3 & 7 & 9 & 7 & 25 & 7 & 57 \\
\hline 4A & 5 & 3 & 8 & 8 & 8 & 24 & 8 & 56 \\
\hline 4B & 5 & 3 & 9 & 7 & 9 & 23 & 9 & 55 \\
\hline 4 C & 5 & 3 & 10 & 6 & 10 & 22 & 10 & 54 \\
\hline 4D & 5 & 3 & 11 & 5 & 11 & 21 & 11 & 53 \\
\hline 4E & 5 & 3 & 12 & 4 & 12 & 20 & 12 & 52 \\
\hline 4F & 5 & 3 & 13 & 3 & 13 & 19 & 13 & 51 \\
\hline 50 & 5 & 3 & 13 & 3 & 14 & 18 & 14 & 50 \\
\hline 51 & 5 & 3 & 13 & 3 & 15 & 17 & 15 & 49 \\
\hline 52 & 5 & 3 & 13 & 3 & 16 & 16 & 16 & 48 \\
\hline 53 & 5 & 3 & 13 & 3 & 17 & 15 & 17 & 47 \\
\hline . & . & . & . & . & . & . & . & . \\
\hline . & . & . & . & . & . & . & . & . \\
\hline - & 5 & 3 & 13 & 3 & 5 & 7 & 25 & 39 \\
\hline 5B & 5 & 3 & 13 & 3 & 25 & 7 & 25 & 39 \\
\hline 5C & 5 & 3 & 13 & 3 & 26 & 6 & 26 & 38 \\
\hline 5D & 5 & 3 & 13 & 3 & 27 & 5 & 27 & 37 \\
\hline 5E & 5 & 3 & 13 & 3 & 28 & 4 & 28 & 36 \\
\hline 5F & 5 & 3 & 13 & 3 & 29 & 3 & 29 & 35 \\
\hline 60 & 5 & 3 & 13 & 3 & 29 & 3 & 30 & 34 \\
\hline 61 & 5 & 3 & 13 & 3 & 29 & 3 & 31 & 33 \\
\hline 62 & 5 & 3 & 13 & 3 & 29 & 3 & 32 & 32 \\
\hline . & . & - & . & . & . & . & . & . \\
\hline - & - & - & . & - & . & . & . & - \\
\hline & 5 & \% & & 3 & & 3 & 58 & 6 \\
\hline 7 D & 5 & 3 & 13 & 3
3 & 29 & 3 & 58
59 & 6
5 \\
\hline 7E & 5 & 3 & 13 & 3 & 29 & 3 & 60 & 4 \\
\hline 7F & 5 & 3 & 13 & 3 & 29 & 3 & 61 & 3 \\
\hline
\end{tabular}

\section*{Control Register}

There is a 5 -bit control register, which can be loaded by the control word, 000XXYZZ. The lower 5 bits of this control word are loaded into the control register.

The least significant two bits of the control register set the total Digit Time for each character during the refresh cycle. Four values can be set using the codes, \(8,16,32\), or 64 cycles per grid. The default value set at power-on is 64 cycles per grid. Under conditions where the display can be subjected to quick movements during viewing (e.g. portable or vehicle mounted applications) it may be necessary to increase the refresh rate by selecting 8,16 or 32 cycles per grid with the appropriate control codes.

The middle bit of the 5 bit control register determines the sixteen digit or eight digit configurations. The two most significant bits select one of the four PLA Modes.

\section*{DISPLAY MODES}

The 10955 can operate in any of eight display modes which control the maximum number of active strobes and segments and the manner in which the RAM Data Buffer is decoded onto the segment drivers.

\section*{16 Digit Configuration}

If the third bit of the control register is zero or is reset by the POR signal, the 16 digit configuration is selected. In this case, a maximum of 16 segments and 16 strobes are provided. The 16 words in the RAM Data Buffer correspond to the 16 strobes. The 8 data bits of each word are sent to the PLA for decode.

\section*{8 Digit Configuration}

If the third bit of the control register is a one, the 10955 is configured into the 8 digit mode. In this case, a maximum of 8 strobes and 24 segments are allowed. The 8 -bit words in the RAM Data Buffer are grouped into 8 word pairs which correspond to strobes STRO-STR7: 0-1, 2-3, 4-5, 6-7, 8-9, 10-11, 12-13, and 14-15. The data in the even-numbered word of each pair is loaded into the direct-output segment drivers (D0-D7). The data in the odd-numbered word of each pair is decoded in the segment PLA decoder before being loaded into the 16 -segment output drivers (SGA-SGP).

\section*{PLA Bypass Mode}

If both of the most significant bits of the control register are zero, the PLA Bypass Mode is selected. In this mode, the PLA is bypassed. Each data word is loaded directly into the segment drivers without being decoded by the PLA. Since there are only 8 data bits but 16 drivers, each data bit is loaded into two
adjacent drivers which can be connected externally to provide twice the current drive of an individual driver. The data bits/segments selection allocation is as follows:
\begin{tabular}{|lcccccccc|}
\hline Data bit & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline Segments & \(O, P\) & \(M, N\) & \(K, L\) & \(I, J\) & \(G, H\) & \(E, F\) & \(C, D\) & \(A, B\) \\
\hline
\end{tabular}

\section*{Upper 64 PLA Mode (64U)}

In this mode (bit \(5=1\), bit \(4=0\) ) the Upper 64 out of the 128 codes are used, (i.e., 64 to 127). Since 64 codes can be specified by a 6 -bit word, the most significant two bits of the 8 -bit word from the RAM are not used. However, the most significant two bits of the display data are brought out directly to SEGO and SEGP outputs. Therefore, the 64 codes can be decoded to the 16 -segment outputs, or only 14 -segment outputs leaving two for direct output from the RAM.

\section*{Lower 64 PLA Mode (64L)}

This mode (bit \(5=1\), bit \(4=1\) ) is similar to the Upper 64 PLA Mode, but only the lower 64 codes ( \(0-63\) ) out of the 128 codes are used. The 64L and 64U PLA modes allow two independent sets of 64 codes to be programmed into one chip. In running the display, only one set can be selected at a time.

\section*{Fourth PLA Mode}

A fourth PLA mode is reserved for future expansion of the 10955. This code (bit \(5=0\), bit \(4=1\) ) should not be used. Selecting this PLA mode may result in non-defined characters appearing on the display.

\section*{PLA CHARACTER SET CODES}

Figure 1 shows the 16 -segment and 14 -segment driver assignments for the corresponding segmented displays. Figure 2 shows the 16 -segment and 14 -segment PLA character set patterns coded into the 10955.


Figure 1. Segment Driver Assignments


16-Segment PLA Patterns


14-Segment PLA Patterns

Figure 2. 16- and 14-Segment PLA Character Sets

\section*{PACKAGE DIMENSIONS}

\section*{40-PIN PLASTIC DIP}

\begin{tabular}{|c|c|c|c|c|c|}
\hline & \multicolumn{3}{|c|}{ MILLIMETERS } & \multicolumn{2}{c|}{ INCHES } \\
\cline { 2 - 5 } DIM & MIN & MAX & MIN & MAX \\
\hline A & 51.28 & 52.32 & 2.040 & 2.060 \\
\hline B & 13.72 & 14.22 & 0.540 & 0.560 \\
\hline C & 3.55 & 5.08 & 0.140 & 0.200 \\
\hline D & 0.36 & 0.51 & 0.014 & 0.020 \\
\hline F & 1.02 & 1.52 & \multicolumn{2}{|c|}{0.040} & 0.060 \\
\hline G & 2.54 & BSC & \multicolumn{2}{|c|}{0.100 BSC } \\
\hline H & 1.65 & 2.16 & 0.065 & 0.085 \\
\hline J & 0.20 & 0.30 & 0.008 & 0.012 \\
\hline K & 3.30 & 4.32 & 0.130 & 0.170 \\
\hline L & 15.24 & BSC & \multicolumn{2}{|c|}{0.600} & BSC \\
\hline M & \(7^{\circ}\) & \(10^{\circ}\) & \(7^{\circ}\) & \(10^{\circ}\) \\
\hline N & 0.51 & 1.02 & 0.020 & 0.040 \\
\hline
\end{tabular}

\section*{Section 6 Application Notes}
Page
Low-Cost Crystal Oscillator for Clock Input ..... 6-3
R6500/R6532 Timer Interrupt Precautions ..... 6-4
A Dot Matrix Controller System Design Using 10938/10939 Display Drivers and R6500/1EB Microcomputer ..... 6-6
Intelligent Display Controller Designer's Notes ..... 6-22

\section*{Low-Cost Crystal Oscillator for Clock Input}

\section*{PURPOSE}

This application note describes a low cost oscillator circuit which will produce the basic input frequency required by the clock generator circuits in the Rockwell R65XX series microprocessors. This circuit can be constructed around either of two readilyavailable, low cost crystals. Both crystals are approximately the same cost, depending on source and quantities. These crystals, identified in the table below, may be obtained from Electro Dynamics, 5625 Foxridge Drive, Shawnee Mission, Kansas

66201, by ordering Part No. 333R05-001 ( 3.579 MHz ) or 59672 (4.19 MHz).

The oscillator output frequency is divided by 2 or by 4 to provide any of the frequency options shown in the table. By trading off the slight deviation in frequency from the standard 1 MHz or 2 MHz clock with cost, this approach can reduce the cost of the oscillator circuit to less than \(\$ 2.00\) each in quantity buys.
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{2}{|c|}{ Crystal } & \multicolumn{2}{|c|}{ Output Frequency (MHz) } \\
\hline Primary Use & Frequency & Divided By 2 & Divided By 4 \\
\hline \begin{tabular}{l} 
Color TV \\
P/N 333R05-001 \\
Automotive Clock \\
P/N 59672
\end{tabular} & 3.579545 MHz & 1.7897 & 0.894886 \\
\hline
\end{tabular}

\section*{DESCRIPTION}

The clock input frequency generator shown in the schematic consists of an oscillator circuit requiring one IC and a divide by 2 or by 4 circuit which also requires only one IC. The output of this circuit is applied to the ( \(\varnothing 0\) ) input of the R650X microcomputer clock generator circuit.

The oscillator circuit uses three of the six drivers in a standard 7404 and a crystal to produce an output. The oscillator output is input to a standard 7474 and the frequency is divided by either 2 or 4 depending on the jumper connections ( A or B ), as shown in the schematic.


\section*{R6500/R6532 \\ Timer Interrupt Precautions}

\section*{PURPOSE}

The R6532 is a RAM, I/O, timer (RIOT) combination device. The timer is an on-board count-down circuit and may be programmed to cause interrupts to the R6502 microprocessor. The timer interrupt is enabled by simply addressing the R6532 with the necessary selects and address bits. It is not necessary to load any internal registers to enable the interrupt, only to address the device.

The R6502 (or one of its 28 -pin versions) microprocessor can inadvertently cause addressing of the R6532 (or other devices with a timer) during start-up or RESET operations. When RES is driven low, the R6502 and R6532 are initialized to known internal states. When \(\overline{R E S}\) goes high, however, the start-up procedure is initiated and the first two cycles contain arbitrary or random addresses on the bus. Table 1 illustrates the cycles immediately following \(\overline{\mathrm{RES}}\) going high.

In most cases, this is normally not a problem, since the occurrence of RES causes the R6502 IRQ interrupt to be disabled. However, if the R6532 interrupt output is connected to the \(\overline{\text { NMI }}\) (Non-Maskable Interrupt) input of the R6502 and the R6532 timer interrupt is inadvertently enabled during start-up, a timer interrupt may occur before the processor has executed its system initialization procedure. The possibility of all these things happening is somewhat remote, but can be a potential problem.

\section*{DESCRIPTION}

There are several solutions to this problem:
1. Use the \(\overline{\mathrm{RQ}}\) interrupt input of the R6502, instead of \(\overline{\mathrm{NMI} .}\) In this way, the \(\overline{\mathrm{RQ}}\) interrupt is automatically disabled by \(\overline{\operatorname{RES}}\) and the R6532 timer interrupt cannot occur.
2. Use separate \(\overline{\mathrm{RES}}\) signals for the R6502 and the R6532. In order to avoid the first two cycles of the start-up (wherein the addresses are unpredictable), it is necessary to hold the RES to the 6532 low after the \(\overline{\text { RES }}\) to the R6502 goes high. This is illustrated in Figure 1.


Figure 1. Delayed Reset to R6532

Table 1. Start-Up Cycle
\begin{tabular}{|c|l|l|l|l|}
\hline Cycles & Address Bus & Data Bus & External Operation & Internal Operation \\
\hline 1 & \(?\) & \(?\) & Don't Care & Hold during Reset \\
2 & \(?+1\) & \(?\) & Don't Care & First Start State \\
3 & \(0100+\) SP & \(?\) & Don't Care & Second Start State \\
4 & \(0100+\) SP-1 & \(?\) & Don't Care & Third Start State \\
5 & \(0100+\) SP-2 & \(?\) & Don't Care & Fourth Start State \\
6 & FFFC & Start PCL & Fetch First Vector & \\
7 & FFFD & Start PCH & Fetch Second Vector & Hold PCL \\
8 & PCH PCL & First OP CODE & Load First OP CODE & \\
\hline
\end{tabular}

\section*{Application Note}
3. Gate the R6532 \(\overline{\mathrm{IRQ}}\) output to the R6502 \(\overline{\mathrm{NMI}}\) input with a circuit which is enabled by the initialization routine of the processor. Figure 2 shows a possible configuration, with the gate enabled only when the processor does a write operation with A15 high. Note that this scheme essentially allows disabling of the \(\overline{\mathrm{NMI}}\) in the R6502.

There are likely to be many other solutions to this problem. These ideas are intended to provide some simple ones and to provoke thought for others from the reader.


Figure 2. Scheme for Gating to the NMI Input

\title{
A Dot Matrix Controller System Design Using the 10938/10939 Display Drivers and R6500/1EB Microcomputer
}

\author{
by Terry Christensen and Tal Klaus, \\ Semiconductor Products Division, Newport Beach, California
}

\section*{INTRODUCTION}

The Rockwell 10938 and 10939 Dot Matrix Display Controller is a two-chip MOS/LSI general purpose display controller system designed to interface a host processor to dot matrix displays (vacuum-fluorescent or LED).

This application note describes how this chip set can be used to drive a 40 character \(5 \times 7\) dot matrix vacuum-fluorescent display. For demonstration purposes, a Futaba 40-SD-41Z display is used and a Rockwell R6500/1EB Backpack Emulator serves as the host. With appropriate adjustments to the power supplies, the interfacing technique described is valid for all similar displays and any host processor. Since the display has 40 grids, two 10939s are required.

The two chip set will drive displays containing up to 35 anodes (dots or segments) and 20 grids (characters).

The 10938 controls the anodes. It contains the anode drivers and a PLA-type decoder programmed to generate the \(5 \times 7\) dot patterns for the full 96 character ASCII set. A similar device, the 10941, is programmed to generate the ASCII character set for 16 segment displays as well as bar graph patterns. The anode driver chips may be driven in parallel to generate patterns for more than 35 dots. An example of this is the 10942/10943 anode driver set which is programmed to generate patterns for \(5 \times 12\) dot matrix displays.

The 10939 controls the grids. In addition to 20 grid drivers, it contains a cursor driver, a 20 character display data buffer, logic to control grid timing and display refresh, and the host interface logic. These devices may be cascaded to drive displays with as many as 80 grids. Since the 10939 performs the grid strobing and display refresh functions, the host processor need only define the operating parameters (such as duty cycle and character count) and update the display message.

The hardware section of this document describes the demonstration system and explains the operation of the display controller chip set. The software section describes several methods of controlling the display drivers and the display output.

\section*{DESCRIPTION OF HARDWARE}

The simplicity of the hardware to drive the display is shown in the Figure 1 schematic and is presented in three sections: the host processor, the display drivers and the power supply.

\section*{Host Processor}

The host processor for this application is a Rockwell R6500/1EB Backpack Emulator which is the PROM prototyping version of the masked-ROM R6500/1 Single Chip NMOS Microcomputer. The R6500/1EB is totally upward/downward compatible with all members of the R6500 family. It is designed to accept standard 5 -volt 24-pin PROMs, EPROMs or ROMs directly in a socket on top of the emulator which simplifies program development. A 2 MHz crystal provides the timing reference for the generation of a 1 MHz internal clock. Reset to the emulator is supplied during power on while the RC circuit is charging. The system can be reset at other times by the push button switch.

Data may be transferred from a host processor to the display controller in either a parallel or a serial mode. In this application, parallel data is sent from port \(B\) of the emulator chip to the 10939 data ports. Emulator lines PC0 and PC1 control the load lines of the 10939s. Line PDO on the emulator chip controls the reset circuit that drives the POR lines of the 10939s. This places the reset of the display controllers under software control. A level translator circuit converts the 0 to +5 V TTL levels of the host to the +5 V to -15 V levels of the display controller devices.

\section*{Display Control}

The display driver chip set interfaces directly with the vacuum fluorescent display tube. The selected display tube has a \(5 \times 12\) dot matrix. For this demonstration, rows one through seven are connected to the 10938 anode drivers to serve as a \(5 \times 7\) dot matrix. The dots of row nine are connected together to form a cursor and the anodes of rows \(8,10,11\) and 12 are unused.

The two 10939 devices are connected in daisy-chain fashion. Each 10939 device has its own on-board oscillator and clock generator. However, when more than one 10939 is used in a system, the same clock must be used for all devices. The MASTER pin on the 10939 device which is to supply the system clock must be connected to VDD, but on the other 10939 device, the slave, the MASTER pin is connected to VSS. These connections activate the oscillator on the master 10939 and cause a three-level four-state signal to be output on the CLOCK output. The oscillator on the slave 10939 is deactivated. The internal clock generators on both the master and slave devices use the signal on the CLOCK pin as an input. This minimizes the skew between master and slave devices.

As shown in the schematic, for this application, the master 10939 controls the left half of the display and the slave controls the right half. Strobe 0 (STROO) controls the left most digit (MSB) and strobe 19 (STR19) controls the right most digit (LSB) of
each half of the display. The cursor outputs are diode ORed to prevent ghosting and they are pulled down to VGG to provide a normally off signal to the display.

A two line synchronization port (SOP and SIP) insures that only one 10939 device at a time drives the display. When one 10939 outputs its last character, it emits a pulse on SOP. The next 10939 receives this pulse on its SIP input and starts its display cycle. This sequence continues through all of the 10939's in a
chain. The SOP of the last 10939 is connected back to the SIP of the first 10939 to start another cycle. The limit to the number of 10939's in the chain is determined by: 1) the load on the clock output on the master 10939, and 2) the display refresh requirements. The synchronization signal propagates during the last character time of its own 10939 and thus does not require any extra time before the first character of the next 10939. The duty cycles of all the 10939's in the chain must be the same.


Figure 1. Display System Schematic

Display data and timing is output to the 10938 device via a two line serial port consisting of the SCLKDIS and DATALOAD pins. In order to minimize the number of package pins, these outputs are multiplexed, three-level, four-state drivers.

The SCLKDIS signal is composed of the shift clock which shifts new data into the 10938 device and a disable signal which sets all of the 10938 display output drivers to the display off state. The DATALOAD signal is composed of serial 8 -bit ASCII data and a load signal to transfer the new data from the 10938 input buffer through the PLA to the display driver outputs. The ASCII data is output with the most significant bit first.

10938 Pin Functions
\begin{tabular}{|l|c|l|}
\hline \multicolumn{1}{|c|}{ Signal Name } & Pin No. & \multicolumn{1}{c|}{ Function } \\
\hline\(V_{\text {SS }}\) & 2 & Power and signal reference \\
SGO1-SG35 & \(3-25,27-38\) & Anode driver outputs \\
SCLK-DIS & 39 & Serial data shift \\
DATA-LOAD & 40 & Serial data outputlatch control \\
\(V_{D D}\) & 1 & DC Power \\
\(V_{G G}\) & 26 & Pull down driver voltage \\
\hline
\end{tabular}


10938 Pin Configuration
10939 Pin Functions
\begin{tabular}{|l|c|l|}
\hline \multicolumn{1}{|c|}{ Signal Name } & Pin No. & \multicolumn{1}{|c|}{ Function } \\
\hline V \(_{\text {SS }}\) & 36 & Power and signal reference \\
V \(_{\text {DD }}\) & 37 & DC Power \\
CLOCK & 38 & Synchronization Clock \\
CURSOR & 14 & Cursor drive output \\
MASTER & 39 & Master/Slave Mode control \\
SIP & 3 & Sync Input \\
SOP & 2 & Sync Output \\
DO-D7 & \(6-13\) & Serial or parallel data input \\
LD & 5 & Inputn data strobe \\
POR & 4 & Power-on reset \\
SCLK-DIS & 1 & Serial data shift clock \\
DATA-LOAD & 40 & Serial data outputlatch control \\
STR00-STR19 & \(15-34\) & Grid Drive Outputs \\
V GG & 35 & Pull down driver voltage \\
\hline
\end{tabular}

\section*{Power Supply}

The power for this application is derived from two linear power supplies for VSS ( +5 Vdc ) and VGG ( -35 Vdc ). A third level for VDD ( -15 Vdc ) is obtained from a zener reference between VSS and VGG. Power requirements at room temperature \(\left(25^{\circ} \mathrm{C}\right)\) are as follows:
\[
\begin{array}{ll}
\text { VSS } & +5 \pm 0.5 \mathrm{Vdc} @ 40 \mathrm{ma} \\
\text { VDD } & -15 \pm 1.5 \mathrm{Vdc} @ 12 \mathrm{ma} \\
\text { VGG } & -35 \pm 3.5 \mathrm{Vdc} @ 16 \mathrm{ma}
\end{array}
\]

These levels are for worst case operation, i.e., with all 35 dots ON. For normal alphanumeric display characters, the VGG power to the 10938 is reduced by 50 percent for a total of about 11 ma . At \(0^{\circ} \mathrm{C}\) operation, the power requirement would increase about 20 percent.

In addition to the dc levels for the IC devices, the vacuum-fluorescent display tube also requires an ac filament voltage. The filament power for the Futaba 40-SD-41 display tube is typically 6.3 Vac at 150 ma . This is driven from a center-tapped transformer and biased at 6.8 V above VGG with a zener diode as shown in Figure 2.



Figure 2. Basic Drive Circuit

\section*{DISPLAY OPERATION}

At power on, the 10939 is placed in an internal host mode with reset from the R6500/1EB. This allows the host system to load the control registers and the data buffer without flashing "garbage" on the display. The normal display refresh sequence is started upon receipt of a START REFRESH control code. Only the master 10939 in a multi-chip system will recognize the START REFRESH code. The master will start the slave(s) at the appropriate time by using the SOP signal.

During the initial rise time of VDD at power turn-on, the magnitude of VGG should not exceed the magnitude of VDD.

Data bytes may be loaded into a 10939 in either a serial or a parallel data load mode. At power-on reset, the device is set to serial load mode. The parallel load mode is implemented when any of the six data input lines D2-D7 is raised to VSS (TTL logic " 1 "). After the parallel load mode has been implemented, the chip must be reset to return to serial load mode.

When using serial data load mode exclusively, it is recommended that input lines D2-D7 be externally tied to VDD to prevent inadvertent implementation of the parallel load mode. The data line DO is used for data input, and the serial clock is input on D1. After eight bits of data (with the most significant bit first) have been shifted into the data buffer, a pulse on the LD signal loads the data into an internal buffer and informs the 10939 that a new data word is available. After the LD pulse, a new data word may be shifted in while the 10939 is processing the first word.

In parallel mode, data bytes are loaded into the 10939 by loading the data onto DO-D7, then pulsing the LD input. Before sending data to the chip, implement the parallel load mode by toggling the data lines. This will not be effective unless it is done after POR has gone low.

In this application, the data lines for both 10939s are controlled by emulator port B. The LD lines determine which device accepts the output data.

\section*{SOFTWARE}

The subroutines of this section control the display in the previously described system. Included are examples of display driver initialization, data transfer to the display drivers and display scrolling. The routines are written in 6502 Assembly language and assume 1 MHz operation. With minor modifications, they may be used for a system having a display with a different grid count.

The following definitions are used throughout:
CONSTANTS
\begin{tabular}{lll} 
MRS & \(=\$ 02\) & \\
SLV & \(=\$ 01\) & \\
MASTER 10939 \\
ALL & \(=\$ 03\) & \\
& & BLAVE 10939 \\
DUT & \(=\$ 5 A\) & \\
DT & \(=\$ 06\) & \\
DUTY CYCLE \(=24 / 32\) \\
CC & \(=\$ 94\) & \\
& & CHIGIT TIME \(=32\) \\
& RAM & \\
& \(*=\$ 0\) & \\
HOLD & \(*=\star+1\) & \\
& LOAD LINE SELECT
\end{tabular}

BIT 1 = MASTER 10939 (UPPER \(1 / 2\) OF DISPLAY)
BIT \(0=\) SLAVE 10939 (LOWER \(1 / 2\) OF DISPLAY)
\begin{tabular}{|c|c|c|}
\hline KNTR & * \(=\star+1\) & COUNTER FOR \# OF DIGITS TO OUTPUT \\
\hline KNT2 & * \(=*+1\) & COUNTER FOR DISPLAY ROTATION \\
\hline DATA & \(*=*+1\) & DATA TO BE OUTPUT TO 10939'S \\
\hline SDATA & * \(=*+1\) & TEMP REG FOR SERIAL OUTPUT \\
\hline PNTR & * \(=*+2\) & TABLE POINTER \\
\hline BPNT & * \(=*+2\) & 2ND POINTER FOR DISPLAY ROTATION \\
\hline TEMP & * \(=*+1\) & SCRATCH PAD \\
\hline WAITER & * \(=*+1\) & DELAY LOOP COUNTER \\
\hline
\end{tabular}
\begin{tabular}{cll} 
& \(1 / 0\) & \\
PBIO & \(=\$ 081\) & DISP DATA LINES \\
PCIO & \(=\$ 082\) & DISP LOAD LINES
\end{tabular}

BIT \(0=\) SLAVE (RIGHT OR LOWER)
BIT 1 = MASTER (LEFT OR UPPER)
\begin{tabular}{rlrl} 
PDIO & \(=\$ 083\) & & DISP DRIVER CNTL LINES \\
BIT 0 & \(=\) POR & & \\
LLATCH & \(=\$ 085\) & & LOWER LATCH \\
ULATCH & \(=\$ 088\) & & L U LTCH, XFR 2 CNTR, CLR FLG \\
CR & \(=\$ 08 F\) & & CONTROL REGISTER
\end{tabular}

\section*{DISPLAY DRIVER CONTROL WORDS}

Control Word Assignments
\begin{tabular}{|c|l|}
\hline Hex Value & \multicolumn{1}{|c|}{ Function } \\
\hline 01 & Load 01 into Data Buffer \\
05 & Set digit time to 16 cycles per grid \\
06 & Set digit time to 32 cycles per grid \\
07 & Set digit time to 64 cycles per grid \\
08 & Enable Normal Display Mode (MSB in data \\
& word is used for cursor control only) \\
09 & Enable Blank Mode (data words with MSB = 1 \\
& will be blanked and cursor will be on) \\
\(0 A\) & Enable Inverse Mode (data words with MSB = 1 \\
& will be "inversed" and cursor will be on) \\
\(0 E\) & \begin{tabular}{l} 
Start Display Refresh Cycle (use only once \\
after reset) \\
\(40-7 F\) \\
\(80-9 F\) \\
Load Duty Cycle Register with lower 6 bits (0-63) \\
Co-D3
\end{tabular} \\
\hline
\end{tabular}

Duty Cycle Control Codes
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline & \multicolumn{2}{|l|}{Digit Time \(=16\)} & \multicolumn{2}{|l|}{Digit Time \(=32\)} & \multicolumn{2}{|l|}{Digit Time \(=64\)} \\
\hline Code & On & Off & On & Off & On & Off \\
\hline 40 & - & 16 & - & 32 & - & 64 \\
\hline 41 & - & 16 & - & 32 & - & 64 \\
\hline 42 & - & 16 & - & 32 & - & 64 \\
\hline 43 & 1 & 15 & 1 & 31 & 1 & 63 \\
\hline 44 & 2 & 14 & 2 & 30 & 2 & 62 \\
\hline 45 & 3 & 13 & 3 & 29 & 3 & 61 \\
\hline 46 & 4 & 12 & 4 & 28 & 4 & 60 \\
\hline 47 & 5 & 11 & 5 & 27 & 5 & 59 \\
\hline 48 & 6 & 10 & 6 & 26 & 6 & 58 \\
\hline 49 & 7 & 9 & 7 & 26 & 7 & 57 \\
\hline 4A & 8 & 8 & 8 & 24 & 8 & 56 \\
\hline 4B & 9 & 7 & 9 & 23 & 9 & 55 \\
\hline 4C & 10 & 6 & 10 & 22 & 10 & 54 \\
\hline 4D & 11 & 5 & 11 & 21 & 11 & 53 \\
\hline 4E & 12 & 4 & 12 & 20 & 12 & 52 \\
\hline 4F & 13 & 3 & 13 & 19 & 13 & 51 \\
\hline 50 & 13 & 3 & 14 & 18 & 14 & 50 \\
\hline 51 & 13 & 3 & 15 & 17 & 15 & 49 \\
\hline 52 & 13 & 3 & 16 & 16 & 16 & 48 \\
\hline 53 & 13 & 3 & 17 & 15 & 17 & 47 \\
\hline . & - & - & - & . & - & . \\
\hline . & - & - & . & - & . & . \\
\hline 5 & \(\cdots\) & \(\cdots\) & - & 7 & - & - \\
\hline 5B & 13 & 3 & 25 & 7 & 25 & 39 \\
\hline 5C & 13 & 3 & 26 & 6 & 26 & 38 \\
\hline 5D & 13 & 3 & 27 & 5 & 27 & 37 \\
\hline 5E & 13 & 3 & 28 & 4 & 28 & 36 \\
\hline 5 F & 13 & 3 & 29 & 3 & 29 & 35 \\
\hline 60 & 13 & 3 & 29 & 3 & 30 & 34 \\
\hline 61 & 13 & 3 & 29 & 3 & 31 & 33 \\
\hline 62 & 13 & 3 & 29 & 3 & 32 & 32 \\
\hline . & - & - & - & - & . & . \\
\hline - & - & - & - & - & - & - \\
\hline 7 C & 13 & 3 & 29 & 3 & 58 & 6 \\
\hline 7 C & 13 & 3 & 29 & 3 & 58 & 6 \\
\hline 7D & 13 & 3 & 29 & 3 & 59 & 5 \\
\hline 7E & 13 & 3 & 29 & 3 & 60 & 4 \\
\hline 7F & 13 & 3 & 29 & 3 & 61 & 3 \\
\hline
\end{tabular}

Buffer Pointer Control Codes
\begin{tabular}{|c|c|c|}
\hline \begin{tabular}{c} 
Code \\
Value
\end{tabular} & \begin{tabular}{c} 
Pointer \\
Value
\end{tabular} & \begin{tabular}{c} 
Character \\
Position
\end{tabular} \\
\hline C0 & 00 & 0 \\
C1 & 01 & 1 \\
C2 & 02 & 2 \\
C3 & 03 & 3 \\
C4 & 04 & 4 \\
C5 & 05 & 5 \\
C7 & 06 & 6 \\
C8 & 07 & 7 \\
C9 & 08 & 8 \\
CA & 09 & 9 \\
CB & \(0 A\) & 10 \\
CC & \(0 B\) & 11 \\
CD & \(0 C\) & 12 \\
CE & \(0 D\) & 13 \\
CF & \(0 E\) & 14 \\
D0 & \(0 F\) & 15 \\
D1 & 10 & 16 \\
D2 & 11 & 17 \\
D3 & 12 & 18 \\
\hline
\end{tabular}

Load Digit Counter Codes
\begin{tabular}{|c|c|c|}
\hline Code & \begin{tabular}{c} 
Digit \\
Counter Value
\end{tabular} & \begin{tabular}{c} 
No. of Grids \\
Controlled
\end{tabular} \\
\hline 80 & 00 & 32 \\
81 & 01 & 1 \\
82 & 02 & 2 \\
83 & 03 & 3 \\
84 & 04 & 4 \\
85 & 05 & 5 \\
86 & 06 & 6 \\
87 & 07 & 7 \\
88 & 08 & 8 \\
89 & 09 & 9 \\
\(8 A\) & \(0 A\) & 10 \\
\(8 B\) & \(0 B\) & 11 \\
8 C & 0 C & 12 \\
8 D & 0 D & 13 \\
8 E & 0 E & 14 \\
8 F & 0 F & 15 \\
90 & 10 & 16 \\
91 & 11 & 17 \\
92 & 12 & 18 \\
93 & 13 & 19 \\
94 & 14 & 20 \\
95 & 15 & 21 \\
96 & 16 & 22 \\
97 & 17 & 23 \\
98 & 18 & 24 \\
99 & 19 & 25 \\
9 A & 1 A & 26 \\
\(9 B\) & 1 B & 27 \\
9 C & 1 C & 28 \\
9 D & 1 D & 12 \\
9 E & 1 E & 30 \\
9 F & 1 F & 31 \\
\hline
\end{tabular}

\section*{Application Note}

\section*{Delay Loops}

Delay loops DELAY and WATEO will be frequently referenced. They are used to control the display driver data load cycle time and to set display update and scrolling speed.
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{Y * 50MS DELAY LOOP} & \multicolumn{4}{|c|}{SHORT DELAY LOOP WAIT \((17+10\) * (ACC +1\()\) )US} \\
\hline DELAY & LDY & \#\$03 & WAIT 150 MS (3 * 50MS) & & & & \\
\hline DLAYO & LDA & \#<50000 & LOAD COUNTER WITH 50000 & WATEO & LDA & \#\$00 & WAIT 27US \\
\hline & STA & LLATCH & & WATE & STA & WAITER & STORE LOOP COUNTER \\
\hline DLAY1 & LDA & \#>50000 & TO GET 50 MS DELAY & WATE1 & NOP & & \\
\hline & STA & ULATCH & & & DEC & WAITER & \\
\hline DLAY2 & LDA & CR & & & BPL & WATE1 & \\
\hline & BPL & DLAY2 & & & RTS & & \\
\hline & DEY & & & & & & \\
\hline & BNE & DLAY1 & & & & & \\
\hline & RTS & & & & & & \\
\hline
\end{tabular}

TIMING WAVEFORMS


Parallel Interface Timing Waveforms


\section*{Serial Interface Timing Waveforms}


Flowchart: Serial Data Transfer to Display Controllers

\section*{Output A Character-Serial}

This version of OPUT performs a serial data transfer from the host system to the selected 10939(s). Load line timing is the same for serial data transfer as it is for parallel data transfer. Serial data is shifted into each 10939 most significant bit first. It is not necessary to reload character data between load line pulses so a string of identical characters (when blanking the display for example) may be loaded by successively pulsing the load line.

\section*{OUTPUT A CHARACTER}

SERIAL OUTPUT MSB FIRST
HOLD = LOAD LINE(S)
ACC OR DATA \(=\) DATA
\begin{tabular}{lll} 
OPUT & STA & DATA \\
OUTPUT & WHEN DATA IN ACC \\
& LDA DOP & INIT COUNTER \\
& STA SDATA & FETCH DATA \\
OUTS1 & ROL SDATA & \\
& LDA \(\# \$ 01\) & DATA BIT TO C \\
& &
\end{tabular}

BIT 1 = SERIAL CLOCK LINE
\[
\text { BIT } 0=\text { DATA BIT }
\]

ROL A DATA \& SER CLK IN ACC STA PBIO OUTPUT DATA, TURN ON SER CLK
AND \#01
STA PBIO TURN OFF SER CLK
DEX
BNE OUTS1
OUTPUT NEXT BIT
ROL SDATA RESTORE CARRY
OUTPT LDA HOLD SET LOAD LINE(S) HI
STA PCIO
JSR WATEO
LDA \#00
STA PCIO
LDA \#02
JSR WATE RTS


Flowchart: Parallel Data Transfer to Display Controllers
            SEND 01 TO
        SELECTED 10939(S)
        FETCH CONTROL
        SEND CONTROL
        SEND CONTROL
            WORD TO
            WORD TO
        SELECTED 10939(S)
        SELECTED 10939(S)
            END
            END
            WORD
            WORD

Flowchart: Send a Control Word to
Display Controllers

\section*{Output A Character-Parallel}

This version of subroutine OPUT performs a parallel data transfer from the host system to one or both of the 10939's. Note that this subroutine contains two time delays. These are used to adjust the load line off and load cycle times. Also, it contains two entry points. OPUT is used when the output data is in the accumulator and OUTPUT is used, when the output data has been stored in RAM location DATA.

OUTPUT A CHARACTER
PARALLEL OUTPUT
HOLD = LOAD LINE(S)
ACC OR DATA = DATA
\begin{tabular}{llll} 
OPUT & STA & DATA & WHEN DATA IN ACC \\
OUTPUT & LDA & DATA & FETCH DATA \\
& STA & PBIO & OUTPUT DATA \\
OUTPT & & & \\
& LDA & HOLD & SET LOAD LINE(S) HI \\
& STA & PCIO & \\
& LSR & WATEO & WAIT 20 US \\
& STA & \#OO & PCIO \\
& LDA & \#02 & \\
& JSR & WATE & WAIT 40 US \\
& RTS & &
\end{tabular}

\section*{Send A Control Word}

CMND sends a control word from the host system to the selected 10939(s). The accumulator is loaded with the control word prior to the transfer to this subroutine.
```

SEND A COMMAND
ACC = COMMAND
CMND PHA
LDA \#\$01 PREPARE DISPLAY DRIVER
JSR OPUT FOR CONTROL WORD
PLA
JSR OPUT SEND CNTL WORD
RTS

```

\section*{Initialize Display Drivers}

TRNON is an example of an initialization routine.
SET UP DISPLAY CONTROLLER
\begin{tabular}{rll} 
TRNON LDA & \#\$00 & \\
STA & PDIO & DISABLE 10939'S \\
STA & PCIO & SET LOAD LINES LOW \\
STA & PBIO & SET DATA LINES LOW \\
& & \\
LDY & \#\$01 & WAIT 50 MS \\
JSR & DLAYO & \\
LDA & \#\$01 & RELEASE POR \\
STA & PDIO & \\
& & \\
LDY & \#\$01 & WAIT 50 MS \\
JSR & DLAYO & \\
& & \\
LDA & \#\$FF & * PARALLEL DATA LOAD ONLY \\
STA & PBIO & *PULSE DATA LINES \\
LDA & \#\$00 & * \\
STA & PBIO & *PARALLEL DATA LOAD ONLY \\
& & \\
LDA & \#ALL & SET DISPLAY CONTROLLER PARAMS \\
STA & HOLD & ADDRESS BOTH 10939'S \\
LDA & \#CC & DIGIT COUNT = 20 \\
JSR & CMND & \\
LDA & \#DT & DIGIT TIME = 32 CYC/CHAR \\
JSR & CMND & \\
LDA & \#DUT & DUTY CYCLE = 24/32 \\
JSR & CMND & \\
& & \\
LDA & \#MRS & LOAD MASTER ONLY \\
STA & HOLD & \\
LDA & \#\$0E & START REFRESH CYCLE \\
JMP & CMND & (RETURN VIA CMND)
\end{tabular}


Flowchart: Display Controller Initialization

\section*{BLANK The Display}

BLNK is a routine which fills the display buffers with blanks. By preloading HOLD, DATA and KNTR, then entering the routine at location OUTC, it can be used to display a string of constants.

BLANK DISPLAY
\begin{tabular}{llll} 
BLNK & LDA & \#ALL & ADDRESS BOTH 10939'S \\
& STA & HOLD & \\
& LDA & \#\$CO & SET BUFFER POINTER TO ZERO \\
& JSR & CMND & \\
BLN1 & LDA & \#\$20 & ASCII BLANK \\
BLN11 & STA & DATA & \\
BLN2 & LDA & \#\$14 & OUTPUT 20 DIGITS \\
& STA & KNTR & \\
& BNE & OUTC1 &
\end{tabular}

OUTPUT A CONSTANT
ACC \(=\) DATA
KNTR \(=\#\) DIGITS \((\mathrm{MAX}=20)\)
OUTC STA DATA
OUTC1 JSR OUTPUT DEC KNTR BNE OUTC1 RTS


Flowchart: Blank the Display

\section*{Load A Message}

TOUTO loads the display with data from a table stored in RAM or ROM. Locations PNTR and PNTR+1 contain the address of the first byte of data to be fetched from the table. KNTR is preloaded with the number of characters to load. \$FF is defined as an end of table flag so the execution of the routine can be terminated either by the count down of KNTR or the detection of the end of a table.

\section*{OUTPUT FROM TABLE}

BUFFER POINTER MUST BE PRELOADED WHEN USING ENTRY POINTS BEFORE TOUT5
\begin{tabular}{llll} 
TOUTO & JSR & POINT & SET UP POINTER \\
& & & \\
TOUT & LDA & \#MRS & SELECT MASTER \\
TOUT1 & STA & HOLD & \\
TOUT2 & LDA & \#\$14 & 20 CHARS MAX \\
TOUT3 & STA & KNTR & \\
TOUT4 & JSR & OUTT & SEND IT \\
& & & \\
TOUT5 & LDA & \#\$03 & SELECT THE OTHER 10939 \\
& EOR HOLD & \\
TOUT7 & STA & HOLD & \\
& LDA & \#\$C0 & BUFF PNTR = 0 \\
& JSR CMND & \\
& LDA & \#\$14 & 20 CHARS MAX \\
TOUT8 & STA & KNTR & \\
& JMP & OUTT1 & SEND IT \\
& & & \\
OUTT & LDY & \#\$00 & INITIALIZE COUNTER \\
OUTT1 & LDA & (PNTR), Y & FETCH DATA \\
& CMP & \#\$FF & END OF TABLE ? \\
& BEQ & OUTT2 & YES \\
& JSR & OPUT & NO: SEND IT \\
& INY & & POINT TO NEXT TBL LOCN \\
& DEC & KNTR & COUNT DONE ? \\
& BNE & OUTT1 & NO \\
OUTT2 & RTS & & YES: EXIT
\end{tabular}

LOAD TABLE POINTER
X = OFFSET FOR POINTER TABLE
\begin{tabular}{lll} 
POINT & LDA & MESS, \(X\) \\
& & \begin{tabular}{c} 
FETCH ADDRESS FROM \\
POINTER TABLE
\end{tabular} \\
STA & PNTR & TRANSFER TO POINTER \\
& & REGISTER
\end{tabular}


Flowchart: Display with Table Data

\section*{Message Scroll}

The next three subroutines are used for scrolling messages across the display. SHFI clears the display then shifts in a message. SHFTO shifts a message across the display and ROTR is a loop which repeatedly rotates a message through the display. These routines may be used separately or combined to create various effects.

\section*{Scroll In A Message}

SHFI blanks the display then shifts in a table message. The embedded transfers to delay loops are used to control the shifting speed.

CLEAR DISPLAY
SHIFT IN TABLE MESSAGE RIGHT TO LEFT
EXIT WHEN MSD MASTER HOLDS FIRST
CHARACTER OF TABLE
\begin{tabular}{llll} 
SHFI & JSR & POINT & SET UP TABLE POINTER \\
JSR & BLNK & BLANK DISPLAY \\
JSR & DELAY & WAIT \\
& & \\
LDA & \#SLV & START WITH SLAVE ONLY \\
BNE & SHF2 & \\
SHF1 & LDA & \#MRS & LOAD MASTER \& SLAVE \\
SHF2 & STA & HOLD & \\
& & \\
LDA & \#O1 & START WITH ONE DIGIT \\
STA & KNT2 & SAVE \# OF DIGITS \\
SHF3 & STA & KNTR & \\
& \\
SEC & & SET BUFFER PNTR = 20 - \# \\
& & DIGITS \\
LDA & \#\$14 & \\
SBC & KNT2 & \\
ORA & \#\$C0 & \\
JSR & CMND & \\
LDA & HOLD & HOLD DOUBLES AS A FLAG \\
CMP & \#MRS & \\
BNE & SHF4 & \\
& & \\
JSR & TOUT4 & OUTPT TO MSTR \& SLV \\
JSR & SHFT2 & ADD A SPACE IF END OF TABLE \\
LDA & \#MRS & SET UP FOR NEXT PASS \\
STA & HOLD & \\
JMP & SHF5 & \\
SHF4 & & \\
JSR & OUTT & OUTPT TO SLAVE ONLY \\
JSR & SHFT2 & ADD A SPACE IF END OF TABLE \\
JSR & DELAY & WAIT \\
INC & KNT2 & ADD ANOTHER DIGIT \\
LDA & KNT2 & \\
CMP & \#\$15 & \\
BNE & SHF3 & BUFFER LOADED: WHICH ONE ? \\
CDA & \#SLV & HOLD & \\
BEQ & SHF1 & SLAVE LDED, ADD MSTR \\
RTS & & MSTR \& SLV LOADED: EXIT
\end{tabular}


Flowchart: Display Clear and Message Shift In

\section*{Scroll A Message Across the Display}

SHFTO blanks the display, shifts in a table message then shifts the message out of the display while simultaneously shifting in blanks.

SHIFT TABLE MESSAGE ACROSS DISPLAY
\begin{tabular}{llll} 
SHFTO & JSR & SHFI & BLANK DISPLAY, SHIFT IN MESSAGE \\
SHFTO2 & JSR & SHFTY & SHIFT LEFT 1 DIGIT \\
& JSR & DELAY & WAIT \\
& BCC & SHFTO1 & \\
& RTS & & DONE ON C=1 \\
SHFTO1 & INC & PNTR & ADJ PNTR 4 NEXT SHIFT \\
& BNE & SHFTO2 & \\
& INC & PNTR+1 & \\
& BCC & SHFTO2 &
\end{tabular}

SHIFT TABLE MESSAGE LEFT ONE
DIGIT. OUTPUT A BLANK IF END
OF TABLE IS DETECTED.
\begin{tabular}{llll} 
SHFTY & LDY & \#00 & INITIALIZE POINTER OFFSET \\
& LDA & \#MRS & SELECT MASTER \\
SHFTY1 & JSR & TOUT7 & OUTPUT MESSAGE \\
& LDA & KNTR & END OF TABLE ? \\
& BEQ & SHFT1 & NO \\
& CMP & \#\$14 & YES \\
& CLC & & \\
& BNE & SHFTB & SET C=1 IF END OF TABLE \\
& SEC & & DETECTED AT MSD OF MASTER. \\
& BEQ & SHFTB & OUTPUT A BLANK \\
SHFT1 & LDA & \#SLV & SELECT SLAVE \\
SHFT11 & JSR & TOUT7 & OUTPUT MESSAGE \\
& CLC & & \\
SHFT2 & LDA & KNTR & END OF TABLE ? \\
& BEQ & SHFT3 & NO: EXIT \\
SHFTB & STA & TEMP & YES: SVE XIT CNTR VALUE \\
& LDA & \#01 & FOR ROTR THEN \\
& STA & KNTR & OUTPUT A BLANK \\
& LDA & \#\$20 & \\
SHFT3 & RTS & OUTC &
\end{tabular}


Flowchart: Shift Message Across Display


Flowchart: Shift Message Left One Position

Rotate A Message-Continuous Loop
ROTR rotates a message on the display.
ROTATE A TABLE MESSAGE-CONTINUOUS LOOP MESSAGE MUST BE \(\geqslant 20\) CHARACTERS
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{5}{*}{ROTR} & JSR & SHFI & SHIFT IN MESSAGE \\
\hline & LDA & PNTR & SAVE TBL ADDRSS FOR WRAP \\
\hline & STA & BPNT & AROUND \\
\hline & LDA & PNTR+1 & \\
\hline & STA & BPNT+1 & \\
\hline \multirow[t]{22}{*}{ROTR1} & LDA & \#00 & TEMP IS CNTR VALUE 4 WRAP AROUND \\
\hline & STA & TEMP & TEMP \(\ddagger 0=\) TBL END DETECTED \\
\hline & JSR & SHFTY & SHIFT LEFT ONE DIGIT \\
\hline & BCS & ROTR5 & TBL END IN MSD DISP ? \\
\hline & LDA & \#00 & NO: TABLE END DETECTED ? \\
\hline & CMP & TEMP & \\
\hline & BEQ & ROTR25 & NO \\
\hline & LDA & PNTR & TABLE END: WRAP AROUND \\
\hline & PHA & & SAVE TAIL POINTER ON STACK \\
\hline & LDA & PNTR+1 & \\
\hline & PHA & & \\
\hline & LDA & BPNT & FETCH 1ST BYTE PNTR \\
\hline & STA & PNTR & \\
\hline & LDA & BPNT+1 & \\
\hline & STA & PNTR+1 & \\
\hline & DEC & TEMP & SHFTY ADDED BLNK: ADJ CNTR \\
\hline & BNE & ROTR10 & \\
\hline & LDA & \#MRS & COUNT DONE-WHICH HALF ? \\
\hline & CMP & HOLD & \\
\hline & BNE & ROTR20 & LOWER: SET UP 4 NEXT SHIFT \\
\hline & JSR & SHFT1 & UPPER: DO LOWER \\
\hline & JMP & ROTR20 & SET UP 4 NEXT SHIFT \\
\hline \multirow[t]{5}{*}{ROTR5} & LDA & BPNT & TBL END IN MSD DISP \\
\hline & STA & PNTR & RESET PNTR \\
\hline & LDA & BPNT+1 & \\
\hline & STA & PNTR+1 & \\
\hline & JMP & ROTR26 & DO NEXT SHIFT \\
\hline \multirow[t]{7}{*}{ROTR10} & LDA & TEMP & COUNT NOT DONE \\
\hline & STA & KNTR & RESET COUNTER \\
\hline & LDA & \#MRS & WHICH HALF ? \\
\hline & CMP & HOLD & \\
\hline & BNE & ROTR15 & \\
\hline & JSR & TOUT4 & UP: FINISH UP, DO LOW \\
\hline & JMP & ROTR20 & \\
\hline ROTR15 & JSR & OUTT & LOWER: FINISH LOWER \\
\hline \multirow[t]{4}{*}{ROTR20} & PLA & & RECLAIM TAIL POINTER \\
\hline & STA & PNTR+1 & \\
\hline & PLA & & \\
\hline & STA & PNTR & \\
\hline \multirow[t]{3}{*}{ROTR25} & INC & PNTR & INCREMENT TABLE \\
\hline & BNE & ROTR26 & POINTER FOR \\
\hline & INC & PNTR+1 & NEXT SHIFT \\
\hline ROTR26 & JSR & DELAY & WAIT \\
\hline
\end{tabular}
[ADD EXIT SEQUENCE HERE]
DO NEXT SHIFT


Flowchart: Rotate Message

\section*{Application Note}

For further product information, refer to the following documents:
\begin{tabular}{|c|l|}
\hline Order Number & \multicolumn{1}{|c|}{ Document Title } \\
\hline D96 & \begin{tabular}{l} 
10938 and 10930 Dot Matrix Display \\
Controller Data Sheet
\end{tabular} \\
D60 & R6500/1EB Backpack Emulator Data Sheet \\
D51 & R6500/1 One-Chip Microcomputer Data Sheet \\
D51S & \begin{tabular}{l} 
R6500/1E Emulator Device Data Sheet \\
Supplement
\end{tabular} \\
212 & \begin{tabular}{l} 
R6500/1 One-Chip Microcomputer Product \\
Description \\
Intelligent Display Controller \\
Designer's Notes
\end{tabular} \\
\hline 2175 &
\end{tabular}

\title{
Intelligent Display Controller Designer's Notes
}

\author{
by Terry Christensen and Tal Klaus, \\ Semiconductor Products Division, Newport Beach, California
}

\section*{DESCRIPTION}

The Rockwell Intelligent Display Controller family of products is designed to interface host processors to various types of vacuum fluorescent displays. In addition to providing the display drive signals, these products perform character decoding, grid timing and display refresh functions. Included in the family are a series of single chip display controllers, a series of anode decoder/drivers and a grid controller/driver.

Figure 1 is a block diagram of the single chip display controller. The products of this series contain 18 anode drivers and 16 grid drivers. Commands and data are input through a serial data port. A \(64 \times 16\)-bit mask programmable PLA provides character decoding. A \(16 \times 8\)-bit data buffer holds character data. Commands for brightness control, data buffer control and test mode enable are available.

Two PLA patterns are provided as standard products. One, the 10937 provides ASCII to 16 segment decoding. The other, the 10951 provides 7 segment numeric and 16 segment bargraph decoding. Both of these products feature decimal point and tail
control. Also available is the 10957 which is a 10937 modified to provide greater decimal and tail control.
The block diagram of Figure 2 shows a typical host and display interface for a single chip display controller.
Grid controller/drivers are combined with anode decoder/drivers to create multi-chip display controllers. As shown in the block diagram of Figure 3, the grid controller/driver (10939) accepts commands and data from the host system, sends data and timing information to the anode decoder/driver, and controls a cursor output in addition to controlling the display grids. Commands for brightness control, buffer control, and blank and inverse display modes are available. These commands and the character data may be input to the 10939 through either a serial or a parallel data port. Each 10939 can drive up to 20 grids and store the related character data for automatic refresh. With the synchronization logic provided, as many as four 10939's can be daisy chained together to drive 80 character displays as shown in Figure 4.
The anode decoder/driver can drive up to 35 anodes. Data input from the grid controller/driver are decoded in a 128 character mask


Figure 1. Single Chip Display Controller Block Diagram

Figure 2. 16 Character 16 Segment Display Driven by Single-Chip Display Controller


Figure 3. Multi-Chip Display Controller Block Diagram


Figure 4. Block Diagram of \(\mathbf{8 0}\) Character \(5 \times 12\) Dot Matrix
Display Driven by Multi-Chip Display Controller
programmable PLA to determine which anodes to activate. Several anode drivers may be driven as shown in Figure 4 to produce characters from more than 35 anodes.

Four PLA patterns are produced as standard products. The 10938 provides ASCII to \(5 \times 7\) dot matrix decoding. The 10941 generates 16 segment ASCII and bargraph patterns. The 10942 and 10943 are used together to generate \(5 \times 12\) dot matrix ASCII characters.

Tables 1 and 2 compare the features of the display controlier products.

Typical applications for the intelligent display controller family include: automotive instrument clusters, interactive terminals, typewriters, telecommunications products, industrial automation, appliances, hand-held computers and instrumentation systems.

Although intended for vacuum fluorescent displays, users are finding these intelligent controllers are cost effective for use with gas discharge, LED and incandescent displays even though buffering is required.

By providing a simple interface both with the host computer and the associated display, the intelligent controller family provides significant advantages over other approaches. The benefits of

Rockwell's intelligent display controller approach are: reduction of operating time required of the host computer, less display overhead electronics, simplified system design, less board real estate for the display control function, reduced power and cooling, lower overall installed cost and lower maintenance costs.

This can be seen from the following comparison. Several techniques can be used to drive a 20 character, \(5 \times 7\) dot matrix, vacuum fluorescent display. One way is to use two 10-bit shift register latched drivers to drive the grids and five 8 -bit latched drivers to drive the anodes as shown in Figure 5. This configuration uses 19 outputs from the host system for display control. The host system must perform the grid timing and character to dot conversion. Because of this, the host system must service the display every character cycle.

An efficient alternate method is to use the 10938/10939 chip set as shown in Figure 6. With this configuration, 4 or 10 outputs from the host system and a simple reset circuit are needed to drive the display controller. At initialization, the host loads operating parameters into the display controller. Then the display buffer is loaded with the ASCII code of the characters to be displayed. After that the host accesses the display controller only when display characters or operating parameters need to be changed. The display controller performs the grid timing and ASCII to dot conversion functions.

Table 1. Comparison of Single Chip Display Controller Features
\begin{tabular}{|c|c|c|c|}
\hline Features & 10937 & 10951 & 10957 \\
\hline PLA Size & 64 & 64 & 64 \\
\hline Font & 16 Segment Alphanumeric Decimal Point Comma & 7 Segment Numeric Decimal Point Comma 16 Segment Bargraph & 16 Segment Alphanumeric Decimal Point Comma \\
\hline Anode Drivers & & & \\
\hline Type
Number & \begin{tabular}{l}
Open-Drain \\
18
\end{tabular} & Open-Drain
\[
18
\] & Open-Drain
\[
18
\] \\
\hline Current Limit (mA) & 10 & 10 & 10 \\
\hline Grid Drivers & & & \\
\hline Type
Number & Open-Drain 16 & Open-Drain 16 & Open-Drain 16 \\
\hline Current Limit (mA) & 20 & 20 & 20 \\
\hline Host Interface & Serial & Serial & Serial \\
\hline Control Options & Duty Cycle & Duty Cycle & Duty Cycle \\
\hline & Character Count & Character Count & Character Count \\
\hline & Buffer Pointer & Buffer Pointer & Buffer Pointer \\
\hline & Test Mode & Test Mode & Test Mode \\
\hline Power Supply Limits & & & \\
\hline VDD(V) & \(-15 \pm 1.5\) & \(-15 \pm 1.5\) & \(-15 \pm 1.5\) \\
\hline VGG(V) & to -50 & to -50 & to -50 \\
\hline Package & 40 Pin Dip & 40 Pin Dip & 40 Pin Dip \\
\hline Other & 2 Decimal and Tail Commands & 2 Decimal and Tail Commands & 4 Decimal and Tail Commands \\
\hline
\end{tabular}

Table 2. Comparison of Multi-Chip Display Controller Features



Figure 5. 20 Character \(5 \times 7\) Dot Matrix Display Driven by Latched Drivers


Figure 6. 20 Character \(5 \times 7\) Dot Matrix Display Driven by Multi-Chip Display Controller

\section*{HOST-DISPLAY CONTROLLER INTERFACE}

These devices contain circuitry to protect the inputs against damage due to high static voltages. However, it is advised that normal precautions be taken to avoid application of any voltage beyond the maximum rated limits. All inputs are TTL compatible although pullup (to VSS) resistors may be required in certain applications.

\section*{CONTROL OF SINGLE CHIP DISPLAY CONTROLLERS}

Commands and display data are clocked into the single chip display controller from the host serially with the DATA and SCLK inputs. Input data is shifted in as serial bytes, MSB first. Each bit is latched in on the falling edge of the SCLK pulse. The SCLK signal must remain high from one to \(20 \mu \mathrm{~s}\) and low at least one \(\mu \mathrm{S}\) for each bit. There must be a \(40 \mu \mathrm{~s}\) gap, with SCLK held low, between each byte. It is recommended that the display controller be reset periodically to assure bit synchronization. Figure 7 contains a summary of the data transfer timing requirements and a flow chart of the data transfer procedure.

The MSB of the input byte is called the control bit. The state of this bit determines the function of the input data. If the control bit is a one, the input data is a command or control word. If the control bit is a zero, the input byte is display data.

The single chip display controller recognizes four types of commands which are summarized in Table 3. The Buffer Pointer Control command sets the display data buffer pointer to the desired digit position. This enables easy modification of any individual character. When the command is executed, the buffer pointer is loaded with two less than the value of the controlling strobe line. Thus, to set the buffer pointer to the anode data for the character controlled by AD8, the command \(A 6_{16}\) is sent to the display controller.

The Digit Counter Control command sets the number of strobe lines to be activated on the display controller. It is normally used during initialization to define the number of characters to be controlled. In some cases it may also be used to adjust display brightness. This is discussed in the section describing display control techniques. The four least significant bits of the command byte determine the number of strobes to be activated. A command code of \(\mathrm{CO}_{16}\) enables all 16 strobes. Otherwise, the number in the lower half of the command is the number of active digits.

Display brightness and display on/off are controlled by the Duty Cycle Control command. The internal clock of the display controller runs at \(100 \mathrm{KHz} \pm 50 \%\). 32 clock cycles are allotted each active strobe. One of these 32 cycles is an inter-digit off time.


Figure 7. Data Transfer to Single-Chip Display Controller

The Duty Cycle Control command is used to select the number of the remaining 31 clock cycles a strobe is on. The number of "on" cycles is the five least significant bits of the command byte.

The fourth command type is a Test Mode Enable. When this mode is activated, the digit time is reduced from 32 to 4 clock cycles. After the test mode has been entered, a power-on reset sequence must be performed to resume normal operation.

\section*{CONTROL OF MULTI-CHIP DISPLAY CONTROLLERS}

In systems using the multi-chip display controller, commands and display data are sent from the host to the 10939(s) through the data (DO-D7) and LD lines. Either a parallel or a serial data input mode may be used.

The parallel data input mode is implemented by toggling any of data lines D2-D7 after POR has gone low. Once the parallel data load mode has been implemented, a power-on reset procedure must be performed to return to serial data load mode. Parallel data transfer is accomplished, as shown in Figure 8, by putting the
command or display data on the data lines, then pulsing the LD line. The load cycle time must be at least \(60 \mu \mathrm{~s}\) with the LD line set high for at least one \(\mu \mathrm{s}\) and held low for at least \(40 \mu \mathrm{~s}\).

The serial data input mode is implemented during the power-on reset procedure. In those systems using serial mode, ports D2-D7 should be tied low to prevent the inadvertent implementation of the parallel load mode. Serial data bytes are shifted into a data buffer MSB first on line D0 using line D1 as the serial clock. The last eight bits clocked in are latched into the display controller by a pulse on the LD line. As shown in Figure 9, the cycle time for each data bit is \(2 \mu \mathrm{~s}\) and the load time for each byte is \(60 \mu \mathrm{~S}\).

The 10939's may be cascaded together to drive displays having more than 20 characters. As many as four 10939's can be daisy chained as shown in Figures 4 and 14 to control up to 80 characters.

Each 10939 has its own on-chip oscillator and a clock generator operating at approximately 100 kHz . When more than one 10939 is used in a system, the same clock must be used for all the

Table 3. Single Chip Command Summary

devices. To do this, one 10939 is designated the master by connecting its MASTER pin to VDD. This activates the oscillator on that device and causes a three-level four-state signal to be output on the CLOCK pin. The MASTER pin on the remaining, i.e., slave, devices is connected to VSS. This deactivates the oscillators on these devices so that the master's CLOCK output can be input on the slaves' CLOCK pins.

A two line synchronization port (SOP and SIP) ensures that only one 10939 device at a time drives the display. When one 10939 outputs its last character, it emits a pulse on its SOP. The next

10939 receives this pulse on its SIP input and starts its display cycle. This sequence continues through all of the 10939's in a chain. The SOP of the last 10939 is connected back to the SIP of the first 10939 to start another cycle. The limit to the number of 10939's in the chain is determined by: 1) the load on the clock output of the master 10939, and 2) the display refresh requirements. The synchronization signal propagates during the last character time of its own 10939 and thus does not require any extra time before the first character of the next 10939. The duty cycles of all the 10939's in the chain must be the same.


PARALLEL INTERFACE TIMING WAVEFORMS

*FOR INDUSTRIAL RATED PARTS SUBSTITUTE 44.5 FOR 40 66.7 FOR 60

Figure 8. Parallel Data Transfer to 10939


Figure 9. Serial Data Transfer to 10939

The data pattern \(01_{16}\) is a control prefix byte. When this byte is transmitted to a 10939, it indicates that the next byte is a command. Several command types, listed in Table 4 are recognized by the 10939 .

One of these, the Digit Time Select, determines the amount of time allotted to each character during the refresh cycle. Three options are available. These are 16, 32 or 64 half clock cycles per character. A clock cycle is one cycle of the internal clock of the master 10939 of the system.

The Duty Cycle Select is another command type. This determines the number of clock cycles a digit driver is on during its character time. Three half clock cycles of each character time are used as an inter-digit off time so the selectable duty cycle range is zero to digit time minus three.

A third command type is the Digit Count Select. This determines the number of character positions to be controlled. Note that a digit count greater than the actual number of characters can be selected. This is a feature that can be used to extend the display cycle time and thus expand the range of brightness control since adding phantom characters causes a proportionate reduction of display brightness.

The 10939 contains a 20 character data buffer which holds the anode data for each digit. A buffer pointer, which can be set on command, allows direct access to the data for each character.

The multi-chip display controllers may be operated in three command selectable display modes. These are the normal, inverse and blank modes. When the inverse mode is enabled, selected characters will be inverted. The anodes that would be enabled in normal mode are disabled and the anodes that would be disabled in normal mode are enabled. When the blank mode is enabled, selected characters will be blanked.

The MSB of the data byte is a control bit which determines which characters are selected for a particular display mode. Characters for which this bit is a zero will be displayed in the normal mode.

The data byte control bit also controls the cursor output. The cursor output will be enabled on all characters with the MSB equal to one. So when normal mode is enabled and the MSB of the data byte is set, the normal character will be displayed with the cursor on. When blank mode is enabled and the MSB equals one, the character will be blanked and the cursor will be on.

Two commands remain. One is the Start Refresh Command. At power on, 10939s are placed in an internal halt mode. The normal display refresh sequence starts when a master 10939 receives this start refresh command.

The final command is the command to load \(01_{16}\) into the data buffer. This byte signifies that a command follows. When the command is also \(01_{16}\), it means that \(01_{16}\) is data.

Display data and timing (Figure 10) are output to the anode decoder/driver via a two line serial port consisting of the SCLK-DIS and DATA-LOAD PINS. In order to minimize the number of package pins, these outputs are multiplexed, three-level, four-state drivers.

The SCLK-DIS signal is composed of the shift clock which shifts new data into the anode decoder/driver and a disable signal which sets all of the anode drivers to the display off state. The DATALOAD signal is composed of serial 8 -bit data and a load signal to transfer the new data from the 10938 input buffer through the PLA to the display driver outputs. The data is output with the most significant bit first.

The anode decoder/driver devices can drive a maximum of 35 anodes. For displays having more than 35 anodes per character, such as the \(5 \times 12\) dot matrix example of Figure 4, two or more anode decoder/drivers may be connected in parallel.

\section*{POWER-ON RESET AND INITIALIZATION}

The power-on reset (POR) input controls the initialization of the internal circuits of the display controllers. Chip reset is achieved by setting the POR input high (VSS), waiting a minimum of \(100 \mu \mathrm{~S}\) then setting the POR input low. After another delay of at least \(100 \mu \mathrm{~s}\), commands and data may be sent to the display controllers. On a cold start, POR should be held high for at least \(100 \mu \mathrm{~s}\) after VDD stabilizes. Figure 11 contains examples of circuits that can be used to control this input while Figure 12 contains cold start timing diagrams.

A power-on reset establishes the following default conditions on the single chip display controllers:
a. The grid drivers (ADXX) are off (floating).
b. The anode drivers (SGX, PNT, TAIL) are off (floating).
c. Duty cycle is set to zero.
d. Digit Count is set to 16.
e. The buffer pointer selects the character controlled by AD1.
f. The display data buffer is filled with zeros.

When performing chip initialization it is recommended that a sequence such as that of Figure 13 be followed. In this sequence, the digit count is adjusted and the display data buffer is loaded before the duty cycle is set. This prevents the flashing of random data on the display.

A power-on reset establishes the following default conditions on the multi-chip display controller.
a. The Grid Drivers (STRXX) are off.
b. Duty Cycle is set to zero.
c. Digit Count is set to 32 .
d. The Buffer Pointer is set to zero.
e. Digit Time is set to 64 cycles per character.
f. Normal display mode is selected.
g. The DATA-LOAD output is set to the high impedance state.
h. SCLK-DIS is set to Vol to disable the anode drivers.

When the POR signal is removed, SCLK-DIS is set to the high impedance state.
i. SOP is set to Vol to disable the synchronization pulse.
j. The 10939(s) is (are) placed in an internal halt mode. This allows the host system to load the control registers and the data buffer without flashing "garbage" on the display. The normal display refresh sequence is started upon receipt of a START REFRESH control code. Only the master 10939 in a multi-chip system will recognize the START REFRESH code. The slave(s) will be started by the master at the appropriate time, using the SOP signal.

Table 4. Multi-Chip Command Summary
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline \multicolumn{7}{|c|}{Control Word Assignments} & \multicolumn{3}{|c|}{Digit Counter Control Codes} \\
\hline Hex Code & & & & ion & & & Hex Code & Digit Counter Value & No. of Grids Controlled \\
\hline 01 & \multicolumn{6}{|l|}{\multirow[t]{15}{*}{\begin{tabular}{l}
Load 01 into Data Buffer \\
Set digit time to 16 cycles per grid \\
Set digit time to 32 cycles per grid \\
Set digit time to 64 cycles per grid \\
Enable Normal Display Mode (MSB in data words \\
is ignored) \\
Enable Blank Mode (data words with MSB = 1 will be blanked) \\
Enable Inverse Mode (data words with MSB = 1 will be "inversed") \\
Start Display Refresh Cycle (use only once after reset) \\
Load Duty Cycle Register with lower 6 bits (0-63) \\
Load Digit Counter ( \(80=32,81=1,82=2\), etc.) \\
Load Buffer Pointer Register with lower 5 bits
\end{tabular}}} & 80 & 00 & 32 \\
\hline 05 & & & & & & & 81 & 01 & 1 \\
\hline 06 & & & & & & & 82 & 02 & 2 \\
\hline 07 & & & & & & & 83 & 03 & 3 \\
\hline 08 & & & & & & & 84 & 04 & 4 \\
\hline & & & & & & & 85 & 05 & 5 \\
\hline 09 & & & & & & & 86 & 06 & 6 \\
\hline & & & & & & & 87 & 07 & 7 \\
\hline OA & & & & & & & 88 & 08 & 8 \\
\hline & & & & & & & 89 & 09 & 9 \\
\hline OE & & & & & & & 8A & OA & 10 \\
\hline & & & & & & & 8B & OB & 11 \\
\hline 40-7F & & & & & & & 8 C & OC & 12 \\
\hline 80-9F & & & & & & & 8D & OD & 13 \\
\hline CO-DF & & & & & & & 8 E & OE & 14 \\
\hline & & & & & & & 8F & OF & 15 \\
\hline \multicolumn{7}{|c|}{\multirow[b]{3}{*}{Duty Cycle Control Codes}} & 90 & 10 & 16 \\
\hline & & & & & & & 91 & 11 & 17 \\
\hline & & & & & & & 92 & 12 & 18 \\
\hline \multirow[t]{2}{*}{Hex Code} & \multicolumn{2}{|l|}{Digit Time \(=16\)} & \multicolumn{2}{|l|}{Digit Time \(=32\)} & \multicolumn{2}{|l|}{Digit Time \(=64\)} & 93
94 & 13
14 & 19 \\
\hline & On & Off & On & Off & On & Off & 95 & 15 & 21 \\
\hline 40 & - & 16 & - & 32 & - & 64 & 96 & 16 & 22 \\
\hline 41 & - & 16 & - & 32 & - & 64 & 97 & 17 & 23 \\
\hline 42 & - & 16 & - & 32 & - & 64 & 98 & 18 & 24 \\
\hline \multirow[t]{2}{*}{43} & 1 & 15 & 1 & 31 & 1 & 63 & 99 & 19 & 25 \\
\hline & 2 & 14 & 2 & 30 & 2 & 62 & 9A & 1A & 26 \\
\hline 44 & 3 & 13 & 3 & 29 & 3 & 61 & 9 B & 1 B & 27 \\
\hline 46 & 4 & 12 & 4 & 28 & 4 & 60 & 9 C & 1 C & 28 \\
\hline 47 & 5 & 11 & 5 & 27 & 5 & 59 & 9 D & 1D & 29 \\
\hline 48 & 6 & 10 & 6 & 26 & 6 & 58 & 9E & 1E & 30 \\
\hline 49 & 7 & 9 & 7 & 25 & 7 & 57 & 9 F & 1F & 31 \\
\hline 4A & 8 & 8 & 8 & 24 & 8 & 56 & & & \\
\hline 4B & 9 & 7 & 9 & 23 & 9 & 55 & & & \\
\hline 4 C & 10 & 6 & 10 & 22 & 10 & 54 & \multicolumn{3}{|c|}{\multirow[b]{2}{*}{Buffer Pointer Control Codes}} \\
\hline 4D & 11 & 5 & 11 & 21 & 11 & 53 & & & \\
\hline \multirow[t]{2}{*}{4E} & 12 & 4
3 & 12 & 20 & 12 & 52 & Hex Code & Pointer Value & Character Controlled By \\
\hline & 13 & 3
3 & 13 & 19
18 & 13 & 51
50 & C0 & 00 & STR00 \\
\hline 50 & 13 & \({ }^{\prime \prime}\) & 14 15 & 18
17 & 14 15 & 49 & C1 & 01 & STR01 \\
\hline 51 & & , & 15 & 17 & 15 & 49 & C2 & 02 & STR02 \\
\hline & & & & & & & C3 & 03 & STR03 \\
\hline . & . & . & . & & & & C4 & 04 & STR04 \\
\hline 5D & " & " & 27 & 5 & 27 & 37 & C5 & 05 & STR05 \\
\hline 5 E & " & " & 28 & 4 & 28 & 36 & C6 & 06 & STR06 \\
\hline \multirow[t]{2}{*}{5F} & " & " & 29 & 3 & 29 & 35 & C7 & 07 & STR07 \\
\hline & " & " & 29 & 3 & 30 & 34 & C8 & 08 & STR08 \\
\hline 60 & " & " & \(\prime\) & " & 31 & 33 & C9 & 09 & STR09 \\
\hline 61 & . & . & & & , & & CA & OA & STR10 \\
\hline \multirow[t]{2}{*}{\(\stackrel{.}{ }\)} & . & . & . & . & & & CB & OB & STR11 \\
\hline & . & . & . & . & . & . & CC & OC & STR12 \\
\hline 7 C & " & " & " & " & 58 & 6 & CD & OD & STR13 \\
\hline 7 C & " & " & " & " & 59 & 5 & CE & OE & STR14 \\
\hline 7E & " & " & " & " & 60 & 4 & CF & OF & STR15 \\
\hline \multirow[t]{2}{*}{7F} & \multirow[t]{2}{*}{"} & \multirow[t]{2}{*}{"} & \multirow[t]{2}{*}{"} & \multirow[t]{2}{*}{"} & \multirow[t]{2}{*}{61} & \multirow[t]{2}{*}{3} & D0 & 10 & STR16 \\
\hline & & & & & & & D1 & 11 & STR17 \\
\hline & & & & & & & D2 & 12 & STR18 \\
\hline & & & & & & & D3 & 13 & STR19 \\
\hline
\end{tabular}



Figure 11. Power On/Reset Control Circuits


6

Figure 12. Power On/Reset Timing


Figure 13. Single Chip Display Controller Initialization

Figure 14 is an example of an initialization sequence for the multichip display controller. In systems using parallel data loading, one or more of data lines D2 through D7 should be toggled before sending data to the 10939. Digit time should be set before the duty cycle is selected. To prevent the flashing of random data on the display, the display data buffer should be loaded before the start refresh cycle command is given.


Figure 14. Multi-Chip Display Controller Initialization

\section*{CONTROLLER DISPLAY INTERFACE \\ display interface of single chip DISPLAY CONTROLLER}

The single chip display controllers can drive up to 16 digits and 18 segments. These are open drain drivers so external pull down resistors must be supplied. The total capacitance on an output and the display duty cycle determine the resistor values to use. To prevent ghosting, the RC time constant of an output must be less than the interdigit off time. However, the resistor value should be as large as possible to maximize the portion of the driver current going to the display. Thus \(R \leq T_{\text {off }} / C_{\text {eff }}\), where \(T_{\text {off }}\) is the interdigit off time and \(\mathrm{C}_{\text {eff }}\) is the total capacitance on the driver. For VF displays, this value is usually between \(30 \mathrm{k} \Omega\) and \(50 \mathrm{k} \Omega\).

Each segment driver can source up to 10 mA and each digit driver can source up to 20 mA . Operating the chips beyond these limits can reduce chip life time. Both 40 and 50 volt versions of the single chip display controller are available as standard products.

Two PLA patterns are offered as standard products. One of them, part number 10937, displays 16 segment upper case ASCII characters plus decimal and tail. It can also be used for 14 segment ASCII and 7 segment numeric displays. The 14 and 16 segment driver assignments and character patterns are listed in Tables 5 and 6. Part number 10951 generates 7 segment numeric and 16 segment bargraph codes. Tables 7 and 8 contain the segment assignments and patterns generated by this device.

Table 5. 16 Segment PLA Patterns


10937 Driver Assignments

\footnotetext{
Bit 7 of the data byte is a don't care
}

Table input data is for bit 7 equal to zero

Table 6. 14 Segment PLA Patterns


Table 7. 7 Segment PLA Patterns



10951 Driver Assignments

Bit 7 of the data byte is a don't care Table input data is for bit 7 equal to zero
\({ }^{1}\) Segment drivers SGH, SGI, SGJ, SGK, SGL are enabled when these codes are used.
\({ }^{2}\) Segment drivers SGM, SGN, SGO, SGP are enabled when these codes are used.

Table 8． 16 Segment Bargraph Patterns
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline  &  &  &  &  &  &  &  \\
\hline 00 & － & 08 & & 10 & － & 18 & \(\underline{\underline{\underline{\underline{\underline{\underline{\underline{\underline{\prime}}}}}}}}\) \\
\hline 01 & － & 09 & － & 11 & \(\underline{=}\) & 19 & 金 \\
\hline 02 & － & OA & － & 12 & ＝ & 1A & 金 \\
\hline 03 & － & OB & － & 13 & 三 & 1B & \(\underline{\underline{\underline{\underline{\underline{\underline{\underline{\underline{\underline{\prime}}}}}}}}}\) \\
\hline 04 & － & OC & － & 14 & 三 & 1 C & 金 \\
\hline 05 & － & OD & & 15 & 三㕩 & 1 D &  \\
\hline 06 & － & OE & － & 16 & 金 & 1 E & 金 \\
\hline 07 & － & OF & & 17 & 金 & 1 F & 金 \\
\hline
\end{tabular}
\begin{tabular}{|c|}
\hline SGP \\
\hline SGO \\
\hline SGN \\
\hline SGI \\
\hline SGL \\
\hline SGK \\
\hline SGJ \\
\hline SGI \\
\hline SGH \\
\hline SGG \\
\hline SGF \\
\hline SGE \\
\hline SGD \\
\hline SGC \\
\hline SGB \\
\hline SGA \\
\hline
\end{tabular}

Bit 7 of the data byte is a don＇t care
Table input data is for bit 7 equal to zero

A modified version of the 10937, part number 10957, offers expanded decimal and comma control. To provide this, two of the 10937 data codes have been redefined. Table 9 lists the unique 10957 codes and compares the 10957 with the 10937.

The single chip display controllers were not designed for paralleled or cascaded operation. The multi-chip display controller should be used for displays having more than 16 digits or more than 18 segments per character.

Table 9. Comparison of 10957 with 10937
\begin{tabular}{|c|c|c|}
\hline \begin{tabular}{c} 
Input \\
Data
\end{tabular} & \begin{tabular}{c}
10937 \\
Character
\end{tabular} & \begin{tabular}{c}
10957 \\
Character
\end{tabular} \\
\hline 2 C & \(;\) & \(;\) \\
\hline 2 E & \(\cdot\) & \(\cdot\) \\
\hline 6 C & \(;\) &, \\
\hline 6 E & \(\cdot\) & \\
\hline
\end{tabular}

\section*{DISPLAY INTERFACE OF MULTI-CHIP DISPLAY CONTROLLERS}

Multi-chip display controllers are constructed from various combinations of anode decoder/drivers and grid controller/drivers.

The anode decoder/drivers can each drive a maximum of 35 dots or segments. Each driver can carry a 2 mA load and no external pull downs are required. The devices may be driven in parallel to generate patterns of more than 35 dots. An example of this is the \(5 \times 12\) dot matrix block diagram of Figure 4.

Display data codes and timing information are sent from a 10939 or other source to the anode decoder/drivers serially on the DATALOAD and SCLK-DIS lines. An on-board 128 character PLA decodes the data bytes to determine which drivers to enable. Standard PLA patterns are available for three character fonts. The 10938, listed in Table 10, generates \(5 \times 7\) dot matrix patterns. The 10941, listed in Tables 11 and 12, generates 16 segment and bargraph patterns. It also features separate decimal and comma drivers. This PLA may also be used for 14 segment and 7 segment displays. The 10942 and 10943 are combined to produce the \(5 \times 12\) dot matrix patterns shown in Table 13.

Each grid controller/driver, i.e. 10939, can drive 20 digits and a cursor. These are push-pull drivers which can source 10 mA each. The 10939s may be cascaded, as shown in Figure 4, to drive displays of more than 20 characters. They may be connected in parallel, as shown in Figure 15, to drive multi-line displays having shared grids. In this configuration, the grid drivers may be wired ORed if additional grid current is required. However, when this is done, diodes and pull down resistors must be used as they are used with the cursor outputs. Alternatively, external drivers may be added. The total number of 10939 s that may be connected together is limited by the duty cycle requirements of the display and the load on the master 10939 clock output. Typically, this limit is four 10939s but more may be added if the clock output load is kept below 50 pF .

In addition to the grid drivers, each 10939 contains a cursor output to drive the cursor segment present on some displays. This output is activated when the MSB of the data byte for a particular digit is a one.

\section*{USE OF EXTERNAL DRIVERS WITH INTELLIGENT DISPLAY CONTROLLERS}

If external drivers are added, the devices of the Intelligent Display Controller product line can be used to control displays which operate beyond the range of the display controllers' internal drivers. This applies to LED, Gas Discharge and certain VF displays.

An example of this is shown in Figure 16. Here the 10941/10939 chip set is used to control a 16 segment LED display. The display consists of two Hewlett Packard HDSP-6508s. These are 16 segment GaAsP red LEDs. They are common cathode configured and mounted in an 8 -character package. The 10939 strobe outputs are connected to 600 mA inverting drivers which control the cathodes. The 10941 segment outputs are connected to 500 mA sourcing drivers which control the anodes. A \(47 \Omega\) current limiting resistor is also supplied to each anode.

\section*{DISPLAY CONTROL TECHNIQUES}

\section*{DIGIT STROBING}

The display controller strobe lines are activated sequentially starting with STR00 (AD1 on single chip controllers) and ending with the highest strobe enabled by the character count select commands. After the last strobe in the chain has completed its cycle, the process repeats. The strobe drivers may be connected to strobe a display from right to left, or from left to right, depending on the system requirements. In most cases this will be determined by board layout or software constraints.

\section*{BRIGHTNESS CONTROL}

In certain applications, particularly in situations where the environmental light level varies, the display brightness must be varied from time to time. This can be done by varying the duty cycle and by adding and deleting fictitious digits.

For example, suppose a 10937 is used to control a 7-digit alphanumeric display. Assume that the maximum progammable duty cycle, i.e. each strobe ON 31 clock cycles, is used when ambient light levels are high. Then the display brightness can be decreased by decreasing the duty cycle. Display dimming from maximum to minimum brightness will be achieved in 31 steps with a 3.22 percent decrease from full brightness at each step.

At lower light levels it may be desirable to decrease the display brightness in smaller steps. This can be done by using fictitious digits. In this example, after the display has been dimmed to approximately 20 percent of full brightness, i.e. duty cycle value as been decreased from 31 to 7 , the character count is increased from 7 to 16. At the same time, the duty cycle number is changed from 7 to 14 . Display dimming then proceeds by successively reducing the duty cycle. However, now the brightness is reduced about 1.4 percent with each step.

Table 10. \(5 \times 7\) Dot Matrix PLA Patterns


Table 11. 16 Segment PLA Patterns
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline  &  &  &  &  &  &  &  &  &  &  &  &  &  &  &  \\
\hline 00 & & 01 & & 02 & \[
\left|\begin{array}{ll}
1 & -1 \\
1 & 1 \\
I & -1
\end{array}\right|
\] & 03 &  & & \[
\left|\begin{array}{l}
- \\
-1 \\
- \\
-
\end{array}\right|
\] & 05 & \[
\begin{aligned}
& --1 \\
& --1 \\
& -\quad-1
\end{aligned}
\] & 06 & \(|1-1|\) & 07 & \[
\left|\begin{array}{ll}
-1 & - \\
- & - \\
- & -1
\end{array}\right|
\] \\
\hline 08 &  & 09 &  & OA & \[
\left|\begin{array}{ll}
- & - \\
- & -1 \\
- & -
\end{array}\right|
\] & OB & \[
\left[\left.\begin{array}{l}
- \\
- \\
- \\
-
\end{array} \right\rvert\,\right.
\] & OC & \[
\left|\begin{array}{ll}
1 & 1 \\
1 / & \mid
\end{array}\right|
\] & OD & \[
1
\] & OE &  & OF & \[
\left.\begin{array}{ll|}
- & -1 \\
- & -1 \\
- & -1
\end{array} \right\rvert\,
\] \\
\hline 10 & \(|1-1|\) & 11 & \[
\left.\left|\begin{array}{ll}
- & - \\
- & - \\
- & -
\end{array}\right| \cdot \right\rvert\,
\] & 12 & \[
\left|\begin{array}{l}
- \\
-1 \\
- \\
-\quad-1
\end{array}\right|
\] & 13 &  & 14 & \[
\left|\begin{array}{ll}
- & - \\
- & - \\
- & -
\end{array}\right|
\] & 15 & \[
\left|\begin{array}{l}
-- \\
-- \\
-
\end{array}\right|
\] & 16 & \[
\left|\begin{array}{ll}
-1 & 1 \\
1 & 1 \\
I & -1
\end{array}\right|
\] & 17 &  \\
\hline 18 &  & 19 & \[
\left.\begin{aligned}
& --1 \\
& -- \\
& --10
\end{aligned} \right\rvert\,
\] & 1A &  & 1B & \[
\left[\left.\begin{array}{l}
- \\
- \\
- \\
-
\end{array} \right\rvert\,\right.
\] & 1C &  & 1D & \[
-1
\] & 1 E &  & 1 F & \[
\left|\begin{array}{l}
-1 \\
- \\
- \\
- \\
-
\end{array}\right|
\] \\
\hline 20 & & 21 & \[
\bar{\searrow}
\] & 22 & & 23 &  & 24 &  & 25 &  & 26 & \[
\begin{aligned}
& -1 \\
& -\triangle
\end{aligned}
\] & 27 & / \\
\hline 28 & 1 & 29 & \[
1
\] & 2A & \[
\frac{1 /}{/ \pi}
\] & 2 B & -1- & 2 C & / & 2D & - - & 2E & - & 2F & \(1 /\) \\
\hline 30 &  & 31 & , & 32 & \[
\left|\begin{array}{c}
--1 \\
-- \\
--
\end{array}\right|
\] & 33 & \[
\begin{aligned}
& -- \\
& --1 \\
& --
\end{aligned}
\] & 34 &  & 35 & \[
\left|\begin{array}{l}
-- \\
-- \\
-\quad-1
\end{array}\right|
\] & 36 & \[
\left|\begin{array}{l}
- \\
-\infty \\
- \\
-\infty
\end{array}\right|
\] & 37 & \(--1\) \\
\hline 38 & \[
\left\lvert\, \begin{aligned}
& -- \\
& -- \\
& -\infty
\end{aligned}\right.
\] & 39 & \[
\left|\begin{array}{l}
--1 \\
-- \\
--1
\end{array}\right|
\] & 3A &  & 3B &  & 3 C & \(1 /\) & 3D &  & 3E &  & 3F & --1 \\
\hline 40 &  & 41 & \(\mid--1\) & 42 &  & 43 &  & 44 & \[
\left.\begin{gathered}
-1 \\
-1 \\
-1 \\
1
\end{gathered} \right\rvert\,
\] & 45 &  & 46 & \(11^{-}\) & 47 &  \\
\hline 48 &  & 49 &  & 4A & \[
-1
\] & 4B & \(1-1\) & 4C & \[
\left.\right|_{-}
\] & 4D &  & 4E & \[
\left\lvert\, \begin{array}{ll}
1 \\
\mid & 1
\end{array}\right.
\] & 4F &  \\
\hline 50 & \(\left|-\frac{1}{--}\right|\) & 51 &  & 52 & \[
\left|\begin{array}{l}
--1 \\
-\frac{1}{-}
\end{array}\right|=
\] & 53 & \[
\left\lvert\, \begin{aligned}
& -\infty \\
& -- \\
& -\infty
\end{aligned}\right.
\] & 54 &  & 55 &  & 56 & \(1 / 1\) & 57 &  \\
\hline 58 & \[
1 /
\] & 59 &  & 5A & \[
\begin{aligned}
& -1 \\
& 1 \\
& 1
\end{aligned}
\] & 58 & \[
\left.\right|_{1} ^{-}
\] & 5C & \[
\searrow
\] & 5D & \[
-1
\] & 5E & / & 5F & - \\
\hline
\end{tabular}


10941 Driver Assignments

Table 12． 16 Segment Bargraph Patterns
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline \[
\begin{array}{|l|}
\hline \frac{\mathrm{m}}{0} \\
\underline{0} \\
\vdots \\
\underline{a} \\
\hline
\end{array}
\] &  &  &  &  &  & \[
\begin{array}{|l|l}
\hline \stackrel{y}{0} \\
\underline{0} \\
\vdots \\
\underline{a} \\
\underline{a}
\end{array}
\] &  &  &  &  &  &  &  &  &  \\
\hline 60 & & 61 & & 62 & － & 63 & － & 64 & － & 65 & － & 66 & － & 67 & － \\
\hline 68 & － & 69 & － & 6A & － & 6B & － & 6 C & － & 6D & － & 6E & & 6 F & \\
\hline 70 & － & 71 & ＝ & 72 & \(\equiv\) & 73 & 三 & 74 & 三 & 75 & 墙 & 76 & 金 & 77 & 暙 \\
\hline 78 & 金 & 79 & 金 & 7A & & 78 & 誊 & 7 C & 金 & 7D & 金 & 7E & 金 & 7 F & 金 \\
\hline
\end{tabular}


10941 Driver Assignments

Table 13. \(5 \times 12\) Dot Matrix PLA Patterns



Figure 15. Driving a Two Line Display with a 10938 and a 10939


Figure 16. Driving an LED Display with a 10941 and a 10939

\section*{DISPLAY BLANKING}

The intelligent display controllers may use several methods to blank displays. One method is to load the display buffer with blanks. A second method is to set the duty cycle to zero.

A third method of display blanking is available on multi-chip display controllers. This is the use of blank mode. When this mode is to be used, the display data buffer is loaded with data having the most significant bit set to a one. Then the display is blanked by enabling the blank mode. This feature is especially useful when only selected characters are to be blanked.

\section*{POWER REQUIREMENTS}

\section*{INTRODUCTION}

This section discusses some of the factors involved in determining power requirements of typical vacuum fluorescent display systems. It discusses the display tube construction and operation, the controller types and power requirements, and the factors which affect power dissipation. Examples of power calculations are given for several display configurations.

\section*{DISPLAY TUBE OPERATION}

To be able to determine the power requirements for a display system it would be helpful to have a basic understanding of how a vacuum fluorescent tube is constructed and operates.

\section*{Construction}

The vacuum fluorescent display tube contains three basic elements in an evacuated tube. These are the filament cathode, control grid and anode. The directly heated cathode, nearest the glass viewing surface, is a metal filament covered with an oxide coating and is thin enough not to cause viewing interference. The control grid is a wire mesh also thin enough not to cause viewing interference. The anodes are formed of a fluorescent material coating on insulating bases to form alpha-numeric, bargraph or dot matrix segments.

\section*{Operation}

Thermionic emission by the cathode results at the relatively low temperatures of \(650^{\circ} \mathrm{C}\) to \(700^{\circ} \mathrm{C}\). When positive voltages (with respect to the cathode) are applied to the grid (Ec) and anode (Eb), the electrons are accelerated toward them. The fine mesh construction of the grid allows most of the electrons to pass through it to the phosphor on the positive anodes. The collision of electrons on the phosphor causes light to be emitted in the blue-green spectrum.

When no voltage is applied to the grid (same potential as the cathode) some of the electrons still get through to the positive anode. To cut off all electron flow to the anode, a negative voltage
with respect to the cathode is applied to the grid. This is called the grid cutoff voltage (Ecco). When the anode voltage is open or lower than the cathode voltage almost no electrons reach the phosphor and those few that do have insufficient energy to cause light emission. This is known as the plate (anode) cutoff voltage (Ebco). The negative potential cutoff voltages are normally both the same level and are generated by providing a positive cathode bias (EK).

The basic principle of operation is shown in Figure 17. Three anode segments are shown in the vacuum tube. If anode voltage Eb is applied through switches \(\mathrm{S}_{1}\) and \(\mathrm{S}_{3}\) with \(\mathrm{S}_{2}\) open, for example, currents la1 and la3 flow to their respective anodes to cause light emission.

By increasing the number of anode segments to seven and arranging them to form numerals, digits from 0 to 9 can be indicated. More anode segments are added to provide the popular 14 or 16 segment alpha-numeric characters. Dot matrix configurations lend themselves to more versatile character generation and are generally a matrix of \(5 \times 7\) dots ( 35 anodes) or \(5 \times 12\) dots ( 60 anodes) as shown in Figure 18.

Providing the same pattern of anodes (character) behind multiple grids and time multiplexing the "ON" signal to each grid allows multi-character displays to be constructed in a single tube as shown in Figure 19. As each grid in a multi-character display tube is turned on (positive pulse applied) the appropriate anodes are also driven positive to form the desired character at that position.

\section*{Electrical Considerations}

A major feature of any display device is the readability of the characters and this relates directly to luminance or brightness of the device. Luminance is affected by factors such as filament, grid and anode voltages, as well as duty cycle, phosphor response and temperature.

The filament voltage (Ef) is selected carefully to produce a filament temperature near \(700^{\circ} \mathrm{C}\). Thermionic emission increases rapidly with filament temperature up to about \(600^{\circ} \mathrm{C}\) where it levels off. The filament voltage is selected by the tube manufacturer to work in this saturation region of about \(650^{\circ} \mathrm{C}\) to \(700^{\circ} \mathrm{C}\). If the filament temperature is too high (high Ef), the overheating causes a brightness slump due to evaporation of the oxide. A too low filament temperature operates on the steep part of the emission curve and brightness variation becomes large and unstable with slight voltage variations. The filament voltage should not be used to vary luminance.

Another factor of filament voltage affects the brightness in multicharacter displays. Using dc voltage for the filament produces a linearly distributed bias voltage across the filament element resulting in a non-uniform display brightness. The filament voltage is specified therefore by the manufacturer as ac; either 60 Hz or a higher frequency pulse from a dc-to-ac converter. The filament bias voltage is normally applied to the center tap of the filament transformer as discussed later.


Figure 17. Basic Operation


Figure 18. Characters


Figure 19. Basic Dynamic Drive Circuit

Brightness is also affected by the level of the grid and anode voltage (currents). To obtain an acceptable brightness level using a dc voltage on the grid or anode takes far less voltage than when the element is pulsed as shown in the graph of Figure 20. However, by multiplexing this pulse to many characters (grids) a large power savings is realized. The relationship of luminance to grid and anode voltage is given by the expression:
\[
\mathrm{L}=\mathrm{K} *(\mathrm{ebc})^{2.5} *\left(\frac{\mathrm{p}}{\mathrm{Tr}}\right)
\]
where: \(\quad \mathrm{L}=\) Luminance
\(\mathrm{K}=\mathrm{a}\) constant depending on tube type
\(\mathrm{ebc}=\) grid and anode voltage, where \(\mathrm{eb}=\mathrm{ec}\) \(\mathrm{tp} / \mathrm{Tr}=\) pulse duty cycle

From the above equation it can be seen that the duty cycle of the pulse has a bearing on the brightness of the display. When a pulse voltage is applied to the device a time lag is seen between the pulse application and the brightness response of the fluorescent material due to the internal impedance of the tube itself. Figure 21 indicates that this time lag is about \(8 \mu\) s in both rise time and fall time. It is recommended by display manufacturers that blanking (no positive voltage to any grid) of about \(20 \mu \mathrm{~s}\) be provided


Figure 20. Anode Grid Voltage-Brightness Characteristics (DC and Pulse)


Figure 21. Pulse Response of Phosphor
between the multiplexed digit pulses to assure that the response time lag and extraneous noise does not cause undesirable character illumination. Note that brightness will be constant when duty factor is constant regardless of pulse width except that brightness will deteriorate when the pulse width nears \(8 \mu \mathrm{~s}\) or less. Figure 22 shows the relationship of adjacent multiplexed grid pulses with the blanking separation.

Because the fluorescent material has semiconductor properties the luminance is also affected by ambient temperature as shown in Figure 23. Most display tube manufacturers recommend operation between \(-10^{\circ} \mathrm{C}\) to \(+55^{\circ} \mathrm{C}\).

\section*{Controller Power Requirements}

As shown previously, the Rockwell display controllers are of three types: grid/anode controllers with open drain drivers, and grid controllers and anode controllers with push-pull drivers. The power requirements for these controllers will be covered in this section. The factors which affect the power dissipation will also be discussed: these include voltage variations, temperature affects, and the display load requirements such as tube type and characters being driven.


Figure 23. Ambient Temperature Effect


Figure 22. Relationship of Adjacent Multiplexed Grid Pulses with Blanking Separation


\section*{Device Power Requirements}

Figure 24 shows the three basic types of Rockwell display controller devices. They have open-drain or push-pull drivers which are shown schematically in Figure 25.

Vdd power is used in all three device types for the logic section. Worst case dissipation is at Vdd max ( -16.5 Vdc for the open-drain device and -22 Vdc for the push-pull devices) and at the lowest temperature \(\left(0^{\circ} \mathrm{C}\right.\) for the commercial range and \(-40^{\circ} \mathrm{C}\) for the industrial range). Idd varies as a function of applied voltage and temperature.

Vgg power is dissipated in the push-pull driver devices when an output grid or anode driver is ON (pulled to Vss). Most of the dissipation is in the logic pre-drivers but a small amount is also used in the driver itself. At worst case, with Vgg at -50 Vdc and a temperature of \(40^{\circ} \mathrm{C}\), the maximum drain for each ON grid driver is 25 mW or \(0.5 \mathrm{~mA} / \mathrm{driver}\). As an example, since only one grid driver and the cursor driver can be ON at the same time, the maximum Igg load of the 10939 device is 1.0 mA . The maximum drain for each ON anode driver is 16 mW or .32 mA per driver, so the maximum Igg load of the anode controller with all 35 anode drivers ON would be 11.2 mA . Igg varies not only as a function of the number of drivers ON, but also as a function of applied voltage and temperature.

\section*{Effects of Voltage Variations}

The effects of supply voltage variations on current drains are shown in Figure 26. As Vdd supply voltage increases the current also increases at rates from approximately \(0.015 \mathrm{~mA} / \mathrm{Vdc}\) to almost \(0.06 \mathrm{~mA} / \mathrm{Vdc}\) depending on device type. Igg also increases as Vgg increases for the push-pull driver devices as shown for the 1094X anode driver devices.

\section*{Effects of Temperature Variation}

As previously stated, the worst case supply current is at the lowest temperature extremes. The power dissipation in the controller device for both Vdd and Vgg generally follow the curve shown in Figure 27. The curve is defined by the equation below and is normalized to \(+25^{\circ} \mathrm{C}\) :
\[
\frac{\mathrm{K}^{\prime}}{\mathrm{Ko}^{\prime}}=\left(\frac{\mathrm{T}}{\mathrm{~T}_{\mathrm{o}}}\right)^{\mathrm{m}}
\]
\[
\text { Where } \begin{aligned}
\mathrm{K}^{\prime} & =\mathrm{K} \text { factor at new temperature, } \mathrm{T} \\
\mathrm{Ko} & =\mathrm{K} \text { factor at } \mathrm{To}\left(25^{\circ} \mathrm{C}\right) \\
\mathrm{T} & =\text { New temperature, in Kelvin } \\
\mathrm{To} & =\text { Initial temperature }\left(25^{\circ} \mathrm{C}=298^{\circ} \mathrm{K}\right) \\
\mathrm{m} & =\text { Exponent, dependent on device materials }
\end{aligned}
\]

\section*{Display Load Variations}

Current is drawn from the Vgg supply due to the display grid or anode load itself. This load is a function of the display tube and may be any load up to the maximum allowed by the device driver. \(I_{\text {load }}\) (max) for the grid, cursor, point and tail drivers is 20 mA for the single chip controllers and 10 mA for the grid controller drivers. The maximum load on the segment drivers of the single chip controllers is 10 mA and the maximum load of the anode drivers is

2 mA each. Each tube type is different and actual current requirements must be taken from the manufacturers display tube specifications. This power is dissipated in the display tube rather than in the controller device and is also dependent on the number of grids or anodes that are driven ON.

\section*{Character Load Variations}

The total device power required is dependent on the number of grids or anodes being driven ON at any particular moment. The grids are driven ON sequentially in a multiplexed fashion so that only one grid is ever enabled at any time. The anodes are driven individually to form different characters in both the segmented and dot matrix displays. The anode driver devices are designed with up to 35 output drivers available as shown in Table 14. However, not every driver is used to form characters in each application.

Table 14 shows the dot patterns of the 128 character font for the 10938 anode driver device. Except for the inverse mode in which all the dot patterns are reversed, and character 7F which has all anodes ON; the worst case dot pattern is letter " \(B\) " which has 20 anodes ON. If, for example, a particular application requires only alpha-numeric characters displayed, the peak drive current required for the load would be only 57 percent of the worst case load. With a display tube requiring a maximum load of 2 mA for each dot anode, the total Igg current required would be ( \(35 \times 2 \mathrm{~mA} \times 0.57\) ) 39.9 mA for the display tube and ( \(35 \times 0.32 \mathrm{~mA} \times 0.57\) ) 6.4 mA for the 10938 drivers. The average current would be \((35 \times 2 \mathrm{~mA} \times 0.384) 27 \mathrm{~mA}\) for the display tube and \((35 \times 0.32 \times 0.384) 4.3 \mathrm{~mA}\) for the 10938 drivers. Note, however, that the actual predominance or frequency of use of each character has to be considered to obtain a realistic average current over a given time period. Table 15 lists the average ratios of anodes ON per total anodes for the various anode driver devices.

\section*{DISPLAY SYSTEM POWER CONSIDERATIONS}

The controller device power is not the only power that has to be considered in deriving display system power requirements. Also to be considered are the power for the host microprocessor and the display tube load.

\section*{Typical Power Flow}

The microprocessor is normally a bipolar or MOS device requiring +5 vdc for its power source. In such a display system the Vss return for the control devices is returned to the +5 vdc Vcc as shown in Figure 28. Vdd is a negative supply, referenced to Vss, to supply the logic sections of the controller device. Vgg is a negative voltage to supply anode and grid current through the controller output switches to the display, tube. Ek is a positive level voltage referenced to Vgg for cathode bias (to the center tap of the filament transformer). The filament voltage is an ac 60 cycle voltage supplied through a step down transformer or a dc-dc converter output which supplies a chopped high frequency square wave.


Figure 25. Controller Drive Circuits


Figure 26. Effects of Voltage Variation, \(\Delta \mathrm{ldd} / \Delta \mathrm{Vdd}\left(\right.\) at \(25^{\circ} \mathrm{C}\) )

\section*{Application Note}


Figure 27. Effects of Temperature Variations

Table 14. 10938 Dot Patterns
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline  &  &  &  &  &  &  &  & \[
\begin{array}{|l|}
\hline z \\
0 \\
0 \\
0 \\
0 \\
0 \\
\frac{1}{4} \\
\hline
\end{array}
\] &  &  &  & \[
\begin{array}{|l|}
\hline z \\
0 \\
0 \\
0 \\
0 \\
0 \\
\vdots \\
\hline
\end{array}
\] &  &  &  & & & \\
\hline 0 & & 17 &  & 18 &  & 7 & \(\stackrel{\bullet}{\square}\) & 14 &  & 12 &  & 16 &  & 15 & \(\cdots\) & & & \\
\hline 14 & - & 13 & ¢ \({ }^{\bullet}\) ! & 18 & \(\cdots \cdots\) & 9 & \(\stackrel{\bullet}{\bullet}\) & 11 & \(\because\) & 8 & \(\square^{\bullet \bullet}\) : & 16 &  & 5 & ! & & & \\
\hline 17 &  & 17 &  & 17 &  & 18 &  & 16 &  & 17 &  & 16 &  & 15 & •
\(\cdots\)
\(\cdots\) & & & \\
\hline 10 & - & 11 & ! & 17 & \(\cdots\) & 9 & \(:^{\bullet \cdot}\) & 7 & ! & 9 &  & 7 & \(\cdots\) & 15 &  & & & \\
\hline 0 & & 5 &  & 6 & : : & 18 & ! ! & 15 & \(\cdots\) & 13 &  & 16 &  & 3 & : & & & \\
\hline 9 & & 9 & \[
\begin{aligned}
& \bullet \\
& \\
& \\
& \hline
\end{aligned}
\] & 11 & \(\because \because \cdot\) & 9 & - : & 3 & : & 5 & -•••• & 2 & : & 5 &  & & \# & \% \\
\hline 16 & & 10 & \(\because\) & 14 & -**: & 15 &  & 14 & . \(-:\) & 17 & :.... & 16 & ! \({ }^{\circ}\) & 11 & \(\cdots\) ••• & Character(s) & ON & ON \\
\hline & & & & & - .... & & & & -..! & 17 & & & & 11 & & \begin{tabular}{l}
1 Letter "B" \\
2 Avg of all Numeric
\end{tabular} & 20.0
14.1 & \[
\begin{aligned}
& 57.1 \\
& 40.0
\end{aligned}
\] \\
\hline 17 & \({ }^{\bullet \cdots}\) & 16 & \(\because\) & 2 & - & 4 & - & 7 & \(\because \bullet^{\bullet}\) & 10 & \(\cdots\) & 7 &  & 9 & \(\stackrel{\bullet \bullet}{ } \stackrel{\bullet}{ }\) & \begin{tabular}{l}
3 Avg of all Alpha Caps \\
4 Avg of all Alpha Lowercase
\end{tabular} & 14.9
11.7 & \[
\begin{aligned}
& 42.6 \\
& 33.4
\end{aligned}
\] \\
\hline 18 & & 18 & ! \({ }_{\text {- }}\) & 20 &  & 13 & \(\square^{\bullet \bullet}\) & 18 &  & 17 & :
\(\vdots \cdots\)
\(\vdots . .\). & 13 &  & 16 &  & \begin{tabular}{l}
5 Avg of items 2 \& 3 \\
6 Avg of items 2 thru 4
\end{tabular} & 14.7
13.4 & \[
41.9
\]
\[
38.4
\] \\
\hline 17 & ! & 11 & \(\because \because\)
\(\vdots\)
\(\vdots\)
\(\square\) & 9 &  & 14 & \(\begin{array}{ll}\vdots \\ \vdots & \bullet \\ \\ \vdots\end{array}\) & 11 & \begin{tabular}{l} 
! \\
\(\vdots\) \\
\(\vdots\) \\
\hline....
\end{tabular} & 17 &  & 17 &  & 16 & ! \({ }^{\bullet \bullet}\) & 7 Avg of all characters & 13.4
12.4 & \[
35.4
\] \\
\hline 15 & ! \({ }_{\text {- }}\) & 17 &  & 18 &  & 15 & :.... & 11 & -•••• & 15 & ! \(\quad \vdots\) & 13 &  & 18 & ! \(\quad \begin{array}{r}\text { \% } \\ \vdots \\ \vdots \\ \vdots\end{array}\) & & & \\
\hline 13 &  & 10 &  & 15 &  & 13 & !...
\(\vdots\)
\(\vdots\) & 5 &  & 13 &  & 11 & - \(\because \bullet \cdot\) & 11 & ! & & & \\
\hline 3 & & 14 & \(\cdots\) & 14 &  & 11 & \[
: \text { •••• }
\] & 14 &  & 15 &  & 11 &  & 17 & -••! & & & \\
\hline 12 & \(!\) & 8 & - & 8 & \(\because\) & 11 & \(\vdots\) ! & 9 & \[
\begin{gathered}
\because \\
\vdots \\
\hdashline
\end{gathered}
\] & 16 & \(\because \because: ~\) & 12 &  & 12 & ! \({ }^{\bullet \ldots}\) & & & \\
\hline 14 & ! \({ }_{\text {! }}\) & 14 &  & 8 &  & 12 & \(\cdots \cdots\) & 10 & \(\because\) & 12 & ! \(\quad \begin{array}{r}\text { a } \\ \\ \hline\end{array}\) & 9 & ! \(\quad:\) & 12 & \(\vdots!\) & & & \\
\hline 9 & \(\stackrel{\bullet}{\bullet}\) & 10 & \(\because \bullet^{\circ}\) & 13 & \(\cdots{ }^{\bullet \bullet}\) & 15 & \begin{tabular}{l}
\(\because \bullet \cdot\) \\
\hdashline\(\because\) \\
\(\bullet .\).
\end{tabular} & 13 &  & 14 &  & 5 & -•••• & 35 &  & & & \\
\hline
\end{tabular}

Table 15. Character Anodes ON Summary
\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Character(s) Display Type} & \multicolumn{4}{|c|}{\% Anodes On} \\
\hline & 10937, 10957 & 10938 & 10941** & 10942/43 \\
\hline - Total Anodes & 16 & 35 & 16 & 46 \\
\hline - Worst Case Digit(s)* & \$,\%,0 & B & \$,\%,0,8 & B \\
\hline Anodes ON & 10 & 20 & 10 & 20 \\
\hline \% Anodes ON & 63.0 & 57.1 & 62.5 & 43.5 \\
\hline - Numeric (Avg, \%) & 46.0 & 40.0 & 46.3 & 31.1 \\
\hline - Alpha all caps (Avg, \%) & 39.0 & 42.6 & 38.9 & 32.4 \\
\hline - Alpha lower case (Avg, \%) & - & 33.4 & - & 26.9 \\
\hline - Alpha Caps - Numeric (Avg, \%) & 41.0 & 41.9 & 41.0 & 32.1 \\
\hline - Alpha - Numeric (Avg, \%) & 41.0 & 38.4 & 41.0 & 29.9 \\
\hline - All Characters (Avg, \%) & 24 & 35.4 & 37.0 & 27.2 \\
\hline \begin{tabular}{l}
*Excluding inverse and all dots ON pattern. \\
**Excluding bargraph
\end{tabular} & & & & \\
\hline
\end{tabular}


Figure 28. Typical Display System Power Flow

\section*{Example 1: 20-Character Display}

Figure 29 shows a \(5 \times 7\) dot matrix 20 -character display tube being driven by a 10938 anode driver and a 10939 grid driver and controlled by an R6500/1 microprocessor. Five voltage levels are required including the ac filament voltage of \(6 \mathrm{Vac} @ 23 \mathrm{~mA}\) typically.

The other voltages are:
Vcc of +5 Vdc referenced to Gnd for the microprocessor Vdd of -20 Vdc referenced to Vss for the driver devices Vgg of -33 Vdc referenced to Vss for the driver devices Ek of +6 Vdc referenced to Vgg for the display tube cathode

As discussed before, Vgg is determined by the sum of eb/ec and Ek. Ek bias above Vgg is normally provided by a zener diode reference. The ac filament voltage, Ek and eb/ec are specified by the display tube manufacturer.

The Vcc current requirement is typically 100 mA at \(+25^{\circ} \mathrm{C}\). The Vdd current requirements from Figure 24 are 6 mA for the 10939 grid driver and 3.2 mA for the 10938 anode driver. Vgg current from Figure 24 is .25 mA for the 10939 and 8 mA for the 10938 , however, this is at a Vgg of -50 Vdc . At -33 Vdc the 10938 current reduces at a rate of \(0.15 \mathrm{~mA} / \mathrm{Ndc}\) for a totàl of [8-(0.15)(17)] 5.5 mA . Other \(\operatorname{lgg}\) components from the display tube characteristics include the anode drive of \(2.7 \mathrm{~mA} /\) all dots ON , and the grid drive of 2.9 mA . This total Igg current of 11.3 mA is representative of all 35 dots on continuously.


Figure 29. 20 Character Display Example

For display operation of alphanumerics only, with an average of 38.4 percent of the dots ON as shown in Table 15, anode drive currents reduce to a total \(\operatorname{lgg}\) of 6.3 mA . Peak \(\operatorname{Igg}\) for the letter " \(B\) " increases anode drive current to 57 percent of all dots for a total of 7.7 mA .

Worst case power dissipation is also shown in Figure 29. This is at maximum voltage excursions and a temperature of \(-40^{\circ} \mathrm{C}\). (Keep in mind, however, that most VF display tubes are recommended for operation down to only about \(-10^{\circ} \mathrm{C}\) to \(-20^{\circ} \mathrm{C}\).) Idd at -22 Vdc increases by 0.03 mA for the 10938 (as shown in Figure 24) to 3.23 mA . Figure 27 shows that a factor of 1.38 is used to determine Idd or \(\operatorname{Igg}\) at \(-40^{\circ} \mathrm{C}\) so that the total Idd becomes \((3.23 * 1.38) 4.5 \mathrm{~mA}\). Igg for the 10938 becomes \([(5.5 \mathrm{~mA}+0.15 \mathrm{~mA} / \mathrm{Vdc} * 3 \mathrm{Vdc}) 1.38] 8.2 \mathrm{~mA}\). The same procedure is used to determine the grid driver current requirements. Igg is assumed to increase by 50 percent worst case. The tube currents ib and ic are assumed to increase by 20 percent as temperature decreases from \(+25^{\circ} \mathrm{C}\) to \(-20^{\circ} \mathrm{C}\) and voltage increases to maximum which is worst case for VF display tubes.

Note in these examples that the cursor drive requirements for the 10939 and display tube have not been included and would have to be added to the totals when used.

\section*{Example 2: 40-Character Display}

Figure 30 shows how the 10939 controller devices are cascaded to control the 40-character display tube. The 10942/43 devices are used in parallel to provide an expanded font capability for a \(5 \times 12\) dot matrix.

The current requirements for this system are determined in the same way as in Example 1. Note that when two 10939s are used, the logic current (Idd) is the sum of a master and one slave but the grid drive current (lgg) remains the same. This is because in a master-slave configuration only one grid is enabled at any given moment giving a constant Igg and ic load of a single grid.

For this example Vgg is \(\mathbf{- 5 0} \mathrm{Vdc}\) (eb/ec of 41 Vdc and Ek of 9 Vdc ) for an lgg of . 25 mA for the grid drivers. However, only 23 of the 35 drivers are used in the anode driver bringing the total to \(5.25 \mathrm{~mA} /\) device. For totally alphanumeric applications the anode currents reduce to 30 percent of all dots ON and the peak currents for letter " \(B\) " reduce to 43.5 percent of full ON.

The worst case power dissipation at voltage and temperature extremes are calculated in the same way as in Example 1.

\section*{Example 3: Two-line by 40-Character Display}

Figure 31 is an example of a more advanced display system. The major difference between this example and Example 2 is that two grids are enabled at the same time (one in each line) and therefore the grid drive current and ic are doubled.

\section*{Power Source}

The power source for the display systems can be derived from standard power supplies, custom designs, or DC-DC converters.

Four separate standard supplies could be used to furnish the four dc voltages required for Example 1 as shown in Figure 32. This is expensive, however, and the proper voltage levels are not really "standard" in most cases, and therefore not readily available. Tracking of the power supplies upon power turn-on and turn-off could also be a problem. The structure of the PMOS display driver devices is such that Vgg should not be more negative than Vdd unless Vdd is at -10 Vdc or greater; otherwise, damage to the output drivers is possible. If the 40 Vdc Vgg supply has much faster response than the 20 Vdc Vdd supply in Figure 32, this problem could exist.

Figure 33 shows how the voltages could be derived using only two standard supplies and zener diodes for the other levels. Using a zener diode to generate Vdd from the Vgg supply level assures that the Vdd and Vgg levels "track" all the way to Vdd. This is also shown in Figure 33. Another zener is used to generate the Ek bias voltage above Vgg for the filament transformer center tap.

DC-DC converters are also available that have been designed specifically to provide the power requirements for particular display tube types available in the marketplace. As shown in Figure 34, these converters normally oscillate the low voltage dc input through a step-up transformer and then rectify and filter the high frequency square wave to provide the desired output voltage. A dc feedback is applied to the input oscillator transistor to adjust the oscillation duty cycle and thus provide a constant voltage output. To provide multiple dc output levels (such as for Vdd and Vgg) multi-turn secondary transformer taps and rectifier filter sections are included in the design. See Reference 3 for addresses of DCDC converter vendors.

\section*{FOOTPRINTS}

Figure 35 contains the pin configurations of all the products of the Intelligent Display Controller family.


Figure 30. 40 Character Display Example

(SEE FIGURE 15 FOR TYPICAL INTERCONNECTIONS.)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{} & \multicolumn{2}{|l|}{\multirow[t]{2}{*}{(4) 10939 GRID DRIVE}} & \multirow[t]{2}{*}{(2) 10938 ANODE DRIVE} & \multicolumn{2}{|l|}{DISPLAY TUBE} & \multirow[t]{2}{*}{TOTAL (mA)} \\
\hline & & & & ib & ic & \\
\hline AT \(25^{\circ} \mathrm{C}\), TYPICAL & M & (3) S & & & & \\
\hline - Idd (AT -20 VDC) & 6.0 & 12.0 & 6.4 & - & - & 22.4 \\
\hline - \(\operatorname{lgg}\) (AT -50 VDC) & & & & & & \\
\hline ALL DOTS "ON" & & 0.5 & 16.0 & 15.0 & 30.0 & 61.5 \\
\hline ALPHA NUMERIC ONLY & & 0.5 & 6.2 & 5.8 & 30.0 & 42.5 \\
\hline PEAK, LETTER "B"' & & 0.5 & 9.2 & 8.6 & 30.0 & 48.3 \\
\hline AT \(-40^{\circ} \mathrm{C}\) W.C. & & & & & & \\
\hline - Idd (AT -22 VDC) & 13.6 & 27.3 & 9.0 & - & - & 49.9 \\
\hline - lgg (AT -55 VDC) & & & & & & \\
\hline ALL DOTS "ON" & & 1.0 & 22.4 & 18.0 & 36.0 & 77.4 \\
\hline
\end{tabular}
'PULLUPS REQUIRED ON
ALL INPUTS FROM
TTL SOURCES

Figure 31. Advanced Display System Example


Figure 32. Standard Power Supply Source


Figure 33. Modified Power Supply Source


Figure 34. DC-DC Converter Power Source


Figure 35. Pin Configurations of Intelligent Display Controllers

\section*{REFERENCES}
1. Application Notes
- A Dot Matrix Controller System Design using the 10938/10939 Display Drivers and R6500/1EB Microcomputer,' Rockwell International, APP Note Order No. 2163, P.O. Box C, Newport Beach, CA 92660.
- "Vacuum Fluorescent Display," Application Notes AP-01 through AP-05. Noritake Electronics (See Reference 2.)
2. Vacuum Fluorescent Display Tubes
- Futaba Corporation 555 West Victoria Street Compton, CA 90220
(213) 537-9610

142 Crossen
Elk Grove Village, IL 60007 (312) 364-7204
- Noritake Electronics, Inc. 22410 Hawthorne Boulevard, Suite \#6 Torrance, CA 90505
(213) 373-6704

1822 Brummel Drive Elk Grove Village, IL 60007 (312) 439-9020

\section*{3. DC-DC Converters}
- FUJI Electrochemical Co., Ltd. 16921 South Western Avenue Gardena, CA 90247
(213) 323-1134
- TDK Corp. of America 3102 Kashiwa Street Torrance, CA 90505 (213) 539-6631 4711 West Golf Road, Suite 300 Skokie, IL 60076 (312) 679-8200

\section*{ROCKWELL SEMICONDUCTOR PRODUCTS SALES OFFICES}

\section*{REGIONAL SALES OFFICES/ROCKWELL SEMICONDUCTOR PRODUCTS}
\begin{tabular}{|c|c|c|c|}
\hline HEADQUARTERS & 0102 & FAR EAST & 0210 \\
\hline 0104 & Semiconductor Products Division & 0240 & Semiconductor Products Div. GmbH \\
\hline Semiconductor Products Division & Rockwell International & Semiconductor Products Division & Rockwell International \\
\hline Rockwell International & 10700 West Higgins Rd. & Rockwell International & Isafjordsgatan 11 \\
\hline 4311 Jamboree Road & Suite 102 ( & Overseas Corp. & 16340 Spanga \\
\hline P.O. Box C, MS 501-300 & Rosemont, Illinois 60018 & Dai-ichi Hirakawa-cho Bldg. & \\
\hline Newport Beach, California 92660-3095
(714) \(833-4700\) & (312) 297-8862 & 7-6, 2-chome, Hirakawa-cho & \[
\begin{aligned}
& (46-8) 751-5000 \\
& \text { TLX: } 122442
\end{aligned}
\] \\
\hline  & FAX: (312) 297-3230 & Chiyoda-ku, Tokyo 102, Japan (81-3) 265-8808 & \\
\hline & 0103 & TLX:J22198
\[
\text { FAX: }(81-3) 263-0639
\] & Semiconductor Products Rockwell-Collins Italiana S.P.A. \\
\hline UNITED STATES/CANADA & Semiconductor Products Division & & Via Boccaccio, 23 2, \\
\hline Semiconductor Products' Division & Rockwell International & 0263 & 20123 Milano, Italy \\
\hline Semiconductor Products Division & 5001B Greentree & Rockwell International Ltd. & FAX: (39-2) 498-1450 \\
\hline 4311 Jamboree Road & Executive Campus, Rt. 73 & 904 World Wide House & TLX: 316562 RCIMIL 1 \\
\hline Newport Beach, California 92660-3095 (714) 833-4655 & Marlton, New Jersey 08053 (609) 596-0090 & 19 Des Voeux Road Central Hong Kong & \begin{tabular}{l}
0278 \\
Semiconductor Products Division
\end{tabular} \\
\hline TWX: 910 591-1698 & \begin{tabular}{l}
MCI: 6502229511 \\
FAX: (609) 596-5681
\end{tabular} & \[
(852-5) 246-033
\]
TLX: HX74071 & Rockwell International Immeuble Bureaux Evry 2 \\
\hline 0106 minder Products Division & & & 523, Place des Terrasses \\
\hline Semiconductor Products Division & 0107 & EUROPE & 91034 Evry Cedex, France \\
\hline Rockwell International 3375 Scott Blvd., Suite 410 & Semiconductor Products Division & 0201 & (33-16) 497-2828 \\
\hline Santa Clara, California 95054 & Rockwell International & Semiconductor Products Division & TLX: 690-328 \\
\hline (408) 980-1900 & 2 Burlington Woods Drive & Rockwell International GmbH & FAX: (33-16) 078-2888 \\
\hline TWX: \(650260-6750\) & Burlington, Massachusetts 01803 & Fraunhoferstrasse 11 & SOUTH AMERICA \\
\hline FAX: (408) 980-0744 & (617) 272-5645 & D-8033 Munchen-Martinsried & \\
\hline 0109 & MCI: 6502512464 & (49-89) \(857-601\) & Semiconductor Products Division \\
\hline Semiconductor Products Division & FAX: (617) 273-2399 & TLX: 521-2650 rimd d & Rockwell International \\
\hline Rockwell International & & FAX: (089) 8.57.57.93 & Santa Clara, CA 95054 \\
\hline 3081 Holcomb Bridge Rd., Suite A & 0111 & & (408) 980-1900 \\
\hline Norcross, Georgia 30071
(404) 446.7414 & Semiconductor Products Division & 0202 & TWX: \(650260-6750\) \\
\hline (404) 446-7414
FAX: & 55 Town Center Court
Suite 700 & Semiconductor Products Division Rockwell International Limited & CENTRAL AMERICA/MEXICO \\
\hline 0101 & Scarborough, Ontario & Central House & 0110 \\
\hline Semiconductor Products Division & Canada M1P 4X4 & 3, Lam & Semiconductor Products Division \\
\hline Rockwell International & (416) 296-1644/1645 & Hounslow, Middlese & Rockwell International \\
\hline 2001 N. Collins Blvd., Suite 103 & TLX: 06525235 & TW3 1 HY England & 4311 Jamboree Rd. \\
\hline Richardson, Texas 75080 & FAX: (416) 296-1259 & (44-1) 577-2800 -or- & P.O. Box C, M S 501-301 \\
\hline (214) 996-6500 & & (44-1) 577-1034 & Newport Beach, CA 92658-8902 \\
\hline TLX: \(650227-9516\) & & TLX: \(265871{ }^{-}\) & (714) \(833-4655\) \\
\hline FAX: (214) 996-7812 & & MONREF G REF. DUC001 & TWX: 910 591-1698 \\
\hline
\end{tabular}

For applications assistance, price quotations or technical literature on Rockwell modem, controller and high speed telecommunication products, call your local Rockwell Semiconductor and Products Division sales office.

\section*{ALABAMA}

2000
Robert O. Whitesell \& Associates Braham Springs Professional Village 2227 Drake Ave., S.W., Ste. 10-F P.O. Box 1797

Huntsville, AL 35807
(205) 883-5110

FAX: 205 882-9626

ARKANSAS
2026
Norcom inc.
2227 S. Garnett Rd., Ste. 109A
(Tulsa, Oklahoma 74129)
(918) 832-7747

TWX: 910 845-2298

\section*{CALIFORNIA}

2033
Centaur Corporation
18006 Skypark Circle, Ste. 106
Irvine, CA 92714
(714) 261-2123

TWX: 910 595-2887
FAX: (714) 261-2905
2037
23901 Calabasas Rd., Ste. 1063
Calabasas, CA 91302
(818) 704-1655

2045
Centaur Corporation
9420 Farnham, Suite 201A
San Diego, CA 92123
619) 278-4950

FAX: (619) 278-0649

SALES REPRESENTATIVES - UNITED STATES/CANADA

2060
Criterion Sales Inc.
3350 Scott Blvd., Bldg. \#44
Santa Clara, CA 95054-3126
(408) 988-6300

FAX: (408) 986-9039
COLORADO
2072
Quorum 3
8000 E. Girard Ave., Suite 302
Denver, CO 80231
303) 696-8480

WX: 910 997-8013
FAX: (303) 696-8579

\section*{CONNECTICUT}

2004
Kitchen \& Kutchin
23 Peck Street
North Haven, CT 06473
(203) 239-0212

TWX: 910 474-0011
DELAWARE
2003
Beacon North
103-F Carpenter Dr.
Sterling, VA 22170 )
(703) 478-2480

\section*{FLORIDA}

2005
Currie, Peak \& Frazier, Inc
7335 Lake Ellenor Dr.
Orlando Central Park, FL 32809
(305) 855-0843

TWX: 810 850-0106
FAX: (305) 855-5619

GEORGIA
2002
Currie, Peak and Frazier, Inc.
5664 Peachtree Parkway, Ste. J
Norcross, GA 30092
(404) 449-7662

\section*{IDAHO}

Westerberg Associates
(See Bellevue, Washington)

ILLINOIS
2006
LTD Technologies Inc.
810 Arlington Heights Rd.
Itasca, IL 60143
(312) 773-2900

TWX: 332415
FAX: (312) 773-0358

\section*{INDIANA}

2007
Robert O. Whitesell \& Associates
3426 Taylor St
Fort Wayne, IN 46804
(219) 432-5591

TWX: 810 332-1416
2008
Robert O. Whitesell \& Associates
6691 E. Washington St.
P.O. Box 19904

Indianapolis, IN 46219-0904
(317) 359-9283

TWX: 810 341-3320
FAX: (317) 359-2091

2009
Robert O. Whitesell \& Associates
1825 S. Plate, Suite A
Kokomo, IN 4690
(317) 457-9127

TWX: 810 269-1917

\section*{OWA}

Dy-Tronix Inc
23 Twixt Town Rd. N.E., Ste. 201
Cedar Rapids, IA 52402-3297
(319) 377-8275

FAX: (319) 377-9163

\section*{KANSAS}

2081
Dy-Tronix Inc.
1999 Amidon, Suite 322
Wichita, KS 67203-2124
(316) 838-0884

KENTUCKY
2082
Robert O. Whitesell \& Assoclates
313 Lagrange Rd., Suite 201
P.O. Box 797

Pewee Valley, KY 40056-9998
(502) 241-8977

LOUISIANA
Robert O. Whitesell \& Associates
(See Huntsville, Alabama)

\section*{MAINE}

Kitchen \& Kutchin, Inc (See Burlington, Massachusetts)

\section*{SALES REPRESENTATIVES - UNITED STATES/CANADA (cont'd)}
\begin{tabular}{|c|c|c|c|}
\hline MARYLAND & NEW HAMPSHIRE & \multirow[b]{4}{*}{\begin{tabular}{l}
Robert O. Whitesell \& Associates 4133 South Dixie Ave. \\
Dayton, OH 45439 \\
(513) 298-9546
\end{tabular}} & \multirow[t]{4}{*}{\begin{tabular}{l}
VIRGINIA \\
2034 Beacon North, Inc. 103-F Carpenter Dr. Sterling, VA 22170
\end{tabular}} \\
\hline Beacon North & \multirow[t]{3}{*}{\begin{tabular}{l}
Kitchen \& Kutchin, Inc. \\
(See Burlington, Massachusetts)
\end{tabular}} & & \\
\hline (See Sterling, Virginia) & & & \\
\hline & & & \\
\hline \multirow[t]{2}{*}{MASSACHUSETTS} & NEW JERSEY & \multirow[t]{2}{*}{TWX:510601-2416} & (703) 478 -2480 \\
\hline & \multirow[b]{2}{*}{2043} & & TLX: 510 600-8363 \\
\hline Kitchen \& Kutchin, Inc. & & \multicolumn{2}{|l|}{\multirow[t]{2}{*}{OREGON}} \\
\hline 87 Cambridge St. & 508 Main St. & & \\
\hline \multirow[t]{2}{*}{Burlington, MA 01803
(617) 229-2660} & Boonton, NJ 07005 & 2079 & WASHINGTON \\
\hline & \multirow[t]{2}{*}{(201) 335-0680} & \multirow[t]{2}{*}{Westerberg Assoc., Inc. 7165 S.W. Fir Loop} & 2078 \\
\hline \multirow[t]{2}{*}{FAX: (617) 273-5895} & & & \multirow[t]{2}{*}{Westerberg Assoc., Inc. 12505 N.E. Bel-Red Rd., Ste. 112} \\
\hline & 2017 & Portland, OR 97223 & \\
\hline MICHIGAN & Naudain Associates
The Pavilions at Greent & \multirow[t]{2}{*}{(503) 620-1931} & Bellevue, WA 98005 (206) 453-8881 \\
\hline \multirow[t]{5}{*}{\begin{tabular}{l}
2011 \\
R.O. Whitesell \& Associates 8332 Office Park Dr., Ste. A Grand Blanc, MI 48439-2035 (313) 695-0770 \\
TWX: 810 224-4939
\end{tabular}} & \multirow[t]{2}{*}{Route 73, Ste. 307
Marlton, NJ 08053} & & \multirow[t]{3}{*}{TWX: 910 240-1599} \\
\hline & & PENNSYLVANIA & \\
\hline & \multirow[t]{2}{*}{\[
\begin{aligned}
& (609) 983-5300 \\
& \text { FAX: }(609) 596-5367
\end{aligned}
\]} & \multirow[t]{2}{*}{Naudain Associates (See Marlton, New Jersey)} & \\
\hline & & & WASHINGTON, D.C. \\
\hline & & \multirow{6}{*}{\begin{tabular}{l}
2028 \\
Robert O. Whitesell \& Associates 1360 Old Freeport Rd., Ste. 1-B Pittsburgh, PA 15238
\[
\text { (412) } 963-6161
\]
\end{tabular}} & 2076 \\
\hline \multirow[t]{5}{*}{\begin{tabular}{l}
2013 \\
Robert O. Whitesell \& Associates 688 Cascade West Parkway S.E. \\
Grand Rapids, MI 49506 \\
(616) 942-5420
\end{tabular}} & NEW MEXICO & & \multirow[t]{4}{*}{\begin{tabular}{l}
Beacon North \\
103-F Carpenter Dr. \\
(Sterling, VA 22170) \\
(703) 478-2480
\end{tabular}} \\
\hline & 2018 & & \\
\hline & \multirow[t]{4}{*}{Rep New Tec 9219 Lagrima De Oro Rd., N.E. Albuquerque, NM 87111 (505) 293-2582} & & \\
\hline & & & \\
\hline & & & \multirow[t]{3}{*}{\begin{tabular}{l}
WEST VIRGINIA \\
Robert O. Whitesell \& Associates (See Cincinnati, Ohio)
\end{tabular}} \\
\hline \begin{tabular}{l}
2014 \\
Robert O. Whitesell \& Associates
\end{tabular} & & \multirow[t]{4}{*}{\begin{tabular}{l}
RHODE ISLAND \\
Kitchen \& Kutchin, Inc. (See Burlington, Massachusetts)
\end{tabular}} & \\
\hline 18444 W. 10 Mile Rd. & \multirow[t]{2}{*}{NEW YORK} & & \\
\hline Southfield, M1 48075 & & & WISCONSIN \\
\hline \multirow[t]{2}{*}{TWX: 510 601-2458} & \multirow[t]{2}{*}{\begin{tabular}{l}
2048 \\
Ossmann Component Sales Corp. \\
6666 Old Collamer Rd.
\end{tabular}} & & \multirow[t]{2}{*}{\begin{tabular}{l}
2058 \\
Larsen Associates Inc.
\end{tabular}} \\
\hline & & \multirow[t]{4}{*}{SOUTH DAKOTA Rockwell International (See Rosemont, Illinois)} & \\
\hline \multirow[t]{2}{*}{\begin{tabular}{l}
\[
2015
\] \\
R.O. Whitesell \& Associates
\end{tabular}} & \multirow[t]{2}{*}{East Syracuse, NY 13057 (315) 437-7052} & & 10855 W. Potter Rd. Wauwatosa, WI 53226 \\
\hline & & & (414) 258-0529 \\
\hline \multirow[t]{4}{*}{\begin{tabular}{l}
1822 Hilltop Rd. \\
St. Joseph, MI 49085 \\
(616) 983-7337
\end{tabular}} & FAX: (315) 437-2332 & & FAX: (414) 258-9655 \\
\hline & 2049 & \multirow[t]{2}{*}{TENNESSEE} & \\
\hline & Ossmann Component Sales Corp. & & \multirow[t]{2}{*}{WYOMING} \\
\hline & \multirow[t]{2}{*}{280 Metro Park} & 2029 Robert O. Whitesell \& Associates & \\
\hline MINNESOTA & & Robert O. Whitesell \& Associates & \multirow[t]{3}{*}{(See Denver, Colorado)} \\
\hline 2077 & \multirow[b]{2}{*}{TWX: 310 493-7053} & \multirow[t]{3}{*}{\begin{tabular}{l}
Knoxville, TN 37923 \\
(615) 694-9476
\end{tabular}} & \\
\hline Electronic Innovators, Inc. & & & \\
\hline 9727 Valley View Rd. & \multirow[t]{2}{*}{FAX: (716) 427-2861 2020} & & \multirow[t]{2}{*}{\[
\begin{gathered}
\text { CANADA } \\
2036
\end{gathered}
\]} \\
\hline Eden Prairie, MN 55344 & & & \\
\hline (612) 941-0830 & PAF Associates & TEXAS & Renmark Electronics Limited \\
\hline FAX: (612) 941 -6193 & 120 W. Main St. & 2031 & Richmond Hill, Ontario \\
\hline & Smithtown, LI, NY 11787 & Norco & Canada L4B 1J9 \\
\hline & (516) 360-0940 & & (416) 881-8844 \\
\hline MISSISSIPPI & \multirow[t]{3}{*}{MCI: 6502811354} & \multirow[t]{3}{*}{\begin{tabular}{l}
Austin, TX 78758 \\
(512) 451-2757 \\
TWX: 910 874-1383
\end{tabular}} & \multirow[t]{2}{*}{FAX: (416) 881-8848} \\
\hline \multirow[t]{2}{*}{Robert O. Whitesell \& Associates (See Huntsville, Alabama)} & & & \\
\hline & & & Renmark Electronics Limited \\
\hline \multirow[b]{2}{*}{MISSOURI} & & 2030 & 1445 Woodruffe Ave. \\
\hline & \multirow[b]{2}{*}{Currie, Peak and Frazier, Inc. 1212 Grove St.} & Norcom, Inc. & \multirow[t]{5}{*}{\begin{tabular}{l}
Ottawa, Ontario \\
Canada K2G 1W1 \\
(613) 727-0320 \\
FAX: (613) 727-5527
\end{tabular}} \\
\hline 2068 & & 4450 Sigma Rd. & \\
\hline Dy-Tronix Inc. & P.O. Box 5588 & Suite 135 & \\
\hline 3407 Bridgeland Drive & Greensboro, NC 27403 & Dallas, TX 75234 & \\
\hline \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { Bridgeton, MO } 63044 \\
& \text { (314) 291-4777 }
\end{aligned}
\]} & \multirow[t]{2}{*}{(919) 373-0380} & (214) 386-4888 & \\
\hline & & FAX: (214) 386-4907 & AUSTRALIA \\
\hline \multirow[b]{2}{*}{2069} & \multirow{5}{*}{NORTH DAKOTA Rockwell International (See Rosemont, Mlinois)} & & \multirow[t]{2}{*}{\({ }^{2046}\) VSI Electronics Pty. Limited} \\
\hline & & Norcom, Inc. & \\
\hline \multirow[t]{2}{*}{Dy-Tronix Inc.
8801 E. 63 rd St., Ste. 108} & & 8502 Tybor, Suite 115 & 16 Dickson Ave. Artarmon, NSW \\
\hline & & Houston, TX 77074 & \multirow[t]{2}{*}{\begin{tabular}{l}
2064 Australia \\
(02) 439-4655
\end{tabular}} \\
\hline 8801 E. 63rd St., Ste. 108
Raytown, MO 64133-4865 & & (713) 778-0392 & \\
\hline \multirow[t]{2}{*}{(816) 356-6340} & OHIO & \multirow[t]{2}{*}{TWX: 910 881-1056} & \multirow[t]{2}{*}{\begin{tabular}{l}
TLX: AA22846 \\
FAX: (02) 439-6435
\end{tabular}} \\
\hline & Orio & & \\
\hline MONTANA & \begin{tabular}{l}
\[
2022
\] \\
Robert O. Whitesell \& Associates
\end{tabular} & \multicolumn{2}{|l|}{Norcom, Inc.} \\
\hline \multirow[t]{2}{*}{2067} & \multirow[t]{2}{*}{Robert O. Whitesell \& Associates 1172 West Galbraith Cincinnati, OH 45231} & 7110 Mountain Grove & BRAZIL \\
\hline & & \multirow[t]{2}{*}{San Antonio, TX 78250
(512) \(680-4513\)} & \multirow[t]{2}{*}{\[
2070
\]} \\
\hline Rockwell International
10700 W. Higgins, Ste. 102 & \multirow[t]{2}{*}{Cincinnati, OH 45231 (513) 521-2290} & & \\
\hline (Rosemont, IL 60018) & & & 478 West 650 South \\
\hline (312) 297-8862 & 2023 & & Orem, UT 84058 \\
\hline TWX: 910 233-0179 & Robert O. Whitesell \& Associates & UTAH & (801) 224-5773 \\
\hline & 6000 West Creek Rd., Suite 21 & 2073 & FAX: (801) 375-6880 \\
\hline NEBRASKA & \begin{tabular}{l}
Cleveland, OH 44131 \\
(216) 447-9020
\end{tabular} & \multicolumn{2}{|l|}{Quorum 3} \\
\hline \multirow[t]{4}{*}{\begin{tabular}{l}
Dy-Tronix Inc. \\
(See Cedar Rapids, Iowa) (See Bridgeton, Missouri)
\end{tabular}} & \multirow[t]{2}{*}{TWX: 810 427-2211} & & \multirow[t]{2}{*}{NEW ZEALAND
\[
2050
\]} \\
\hline & & \multirow[t]{3}{*}{Salt Lake City, UT 84121 (801) 943-9227} & \\
\hline & \multirow[t]{3}{*}{Robert O. Whitesell \& Associates 6161 Busch Blvd., Ste. 108} & & VSI Electronics, (N.Z.) Ltd. \\
\hline & & & Private Bag, Newmarket \\
\hline \multirow[t]{3}{*}{NEVADA Criterion Sales Inc. (See Santa Clara, California)} & & \multirow[t]{3}{*}{\begin{tabular}{l}
VERMONT \\
Kitchen \& Kutchin, Inc. (See Burlington, Massachusetts)
\end{tabular}} & Auckland, New Zealand (9) 599150 \\
\hline & \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { Columbus, OH } 43229 \\
& (614) 888-9396 \\
& \text { TWX: } 801337-2076
\end{aligned}
\]} & & TLX: NZ60340 \\
\hline & & & FAX: (9) 593694 \\
\hline
\end{tabular}

INDUSTRIAL DISTRIBUTORS - UNITED STATES/CANADA
The following Distributors stock Rockwell modem, controller and high speed telecommunication products. If there is no distributor location close to you, call the nearest Rockwell Semiconductor Products Division sales representative.
\begin{tabular}{|c|c|c|c|}
\hline ALABAMA & 1194 & 1182 & 1174 \\
\hline 1000 & Marshall Industries & Marshall Industries & Quality Components \\
\hline Hamilton/Avnet Electronics & 336 Los Coches St. & 20 Sterling Dr. & 6145 Northbelt Pkwy., Ste. B \\
\hline 4940 Research Dr. N.W. & Milpitas, CA 95035 & Barnes Ind. Park, N. & Norcross, GA 30071
(404) 449-9508 \\
\hline Huntsville, AL 35805 (205) 837-7210 & (408) \(942-4600\) & \begin{tabular}{l}
Post Office Box 200 \\
Wallingford, CT 06492
\end{tabular} & \[
\begin{aligned}
& \text { (404) 449-9508 } \\
& \text { FAX: (404) } 449-0275
\end{aligned}
\] \\
\hline TWX: 810 726-2162 & \begin{tabular}{l}
\[
1196
\] \\
Hamilton/Avnet Electronics
\end{tabular} & (203) 265-3822 & \\
\hline 1001 & 3002 East G. Street & 1008 & ILLINOIS \\
\hline Quality Components & Ontario, CA 91764 & Almo Electronics & 1016 \\
\hline 4900 University Sq., Ste. 20 & (714) 989-4602 & 31 Village Street & Advent Electronics \\
\hline Huntsville, AL 35816 (205) 830-1881 & \begin{tabular}{l}
1172 \\
Marshall Industries \\
3039 Kilgore
\end{tabular} & Wallingford, CT 06492 (203) 269-6801 & 7110-16 N. Lyndon St. Rosemont, IL 60018 (312) 298-42 10 \\
\hline \begin{tabular}{l}
\[
1188
\] \\
Marshall Industries
\end{tabular} & Rancho Cordova, CA 95670 & FLORIDA & 1017 \\
\hline 3313 Memorial Parkway South & (916) 635-9700 & 1013 & Hamilton/Avnet Electronics \\
\hline Huntsville, AL 35801 & 1092 & Hamilton/Avnet Electronics & 1130 Thorndale Ave.
Bensenville, IL 60106 \\
\hline (205) 881-9235 & Hamilton/Avnet Electronics 4103 Northgate Blyd & \begin{tabular}{l}
6801 N.W. 15th Way \\
Fort Lauderdale, FL 33309
\end{tabular} & Bensenville, IL 60106 (312) 860-8522 \\
\hline ARIZONA & Sacramento, CA 95834 & (305) 971-2900 TWX: 510 956-3097 & TWX:910 227-0060 \\
\hline 1002 & & & 1180 \\
\hline Hamilton/Avnet Electronics & 1007 & 1186 & Marshall Industries \\
\hline 505 So. Madison Dr. & Hamilton/Avnet Electronics & Marshall Industries & 1261 Wiley Road, \#F \\
\hline Tompe, AZ 85281 & 4545 Viewridge Ave. & 2700 W. Cypress Creek & Schaumburg, IL 60195 \\
\hline \[
\begin{aligned}
& \text { (602) } 231-5100 \\
& \text { TWX: } 910950-0077
\end{aligned}
\] & San Diego, CA 92123
(619) \(571-7510\) & Ft. Lauderdale, FL 33309 & (312) 490-0155 \\
\hline & TWX: 910 335-1216 & (305) 977-4880 & \\
\hline 1167 & & & INDIANA \\
\hline Marshall Industries & 1173 & Reptron & 1036 \\
\hline 9830 So. 51 st Street & Marshall Industries & 3320 N.W. 53rd Street & Hamilton/Avnet Electronics \\
\hline Suite B121 & 10105 Carroll Canyon Rd. & Ft. Lauderdale, FL 33309 & 485 Gradle Dr. \\
\hline Phoenix, AZ 85044 (602) 496-0290 & \[
\begin{aligned}
& \text { San Diego, CA } 92131 \\
& \text { (619) 578-9600 }
\end{aligned}
\] & \[
\begin{aligned}
& \text { (305) 735-1112 } \\
& \text { FAX: (305) } 735-1121
\end{aligned}
\] & Carmel, IN 46032 (317) 844-9333 \\
\hline & 1174 & & TWX: 810 260-3966 \\
\hline CALIFORNIA & Zeus & Marshall Industries & \\
\hline & 1580 Old Oakland Rd., Ste. 205 & 4205 34th Street, S.W. & Advent \\
\hline Zeus West Anaheim & San Jose, CA 95131 & Orlando, FL 32811 & 8446 Moller Rd. \\
\hline 1130 Hawk Circle & (408) 998-5121 & (305) 841 -1878 & Indianapolis, IN 46268 \\
\hline \begin{tabular}{l}
Anaheim, CA 92807 \\
(714) 632-6880
\end{tabular} & 1178 Microtechnology Inc. & 1066 & (317) 872-4910 \\
\hline & Western Microtechnology Inc. & Zeus & 1189 \\
\hline 1158 & 12900 Saratoga Avenue & 1750 West Broadway & Marshall Industries \\
\hline Marshall Industries 9710 De Soto Avenue & (408) 725-1660 & \begin{tabular}{l}
Suite 114 \\
Ovievo, FL 32765
\end{tabular} & 6990 Corporate Dr. \\
\hline Chatsworth, CA 91311 & FAX: (408) 255-6491 & (305) 365-3000 & Indianapolis, iN 46278 \\
\hline (818) 407-4100 & TWX:910338-0013 & & \\
\hline & 1008 & Hamilton/Avnet Electronics & IOWA \\
\hline Hamilton/Avnet & Hamilton/Avnet El & 3197 Tech Dr. North & \\
\hline 9650 De Soto Ave. & 1175 Bordeaux Dr. & St. Petersburg, FL 33702 & 1086 Advent Electronics \\
\hline Chatsworth, CA 91311 & Sunnyvale, CA 94086 & (813) 229-7010 & Advent Electronics \\
\hline (818) 700-6500 & TWX: 910 339-9332 & TWX: 810 863-0374 & Cedar Rapids, IA 52404 \\
\hline 1004 & 1152 & 1018 & (319) 363-0221 \\
\hline Avnet Electronics & Image Electronics & Marshall Industries & \\
\hline 350 McCormick & 1342 Bell Ave. & 2840 Scherer Dr. & Hamilton/Avnet \\
\hline Costa Mesa, CA 92626 & Tustin, CA 92680 & Suite 410 & 915 33rd Ave., S.W. \\
\hline TWX:910 595-2638 & (714) 259-0900 & (813) 576 -1399 & Cedar Rapids, IA 52404 (319) 362-4757 \\
\hline 1005 & COLORADO & 1019 & \\
\hline Hamilton Electro Sales & 1185 & Reptron & KANSAS \\
\hline 3170 Pullman St. & Marshall Industries & 14501 McCormick Dr. & \\
\hline Costa Mesa, CA 92626 & 12351 N. Grant & Tampa, FL 33625 & 1191 \\
\hline (714) 641-4100 & Thornton, CO 80241 & (813) 855-4656 & 8321 Melrose Dr. \\
\hline 1003 Hamilton Electro Sales & FAX: (303) 457-2899 & \[
1146
\] & Lenexa, KS 66214 (913) \(492-3121\) \\
\hline ales & & 6947 University Blvd. & \\
\hline Culver City, CA 90230 & Hamilton/Avnet Electronics & Winter Park, FL 32792 & 1037 Hamilton/Avnet Electronics \\
\hline (213) 558-2000 & 8765 E. Orchard Rd., Ste. 708 & (305) 628-3888 & 9219 Quivira Rd. \\
\hline (213) 558-2441 (Int' \({ }^{\text {Group) }}\) & Englewood, CO 80111 & Quality Components & Overland, KS 66215 \\
\hline \begin{tabular}{l}
1159 \\
Marshall Industries
\end{tabular} & TWX: 910 935-0787 & (800) 241 -0037 & \[
\begin{aligned}
& \text { (913): 888-8900 } \\
& \text { TWX: } 910743-0005
\end{aligned}
\] \\
\hline 9674 Telstar Avenue & CONNECTICUT & GEORGIA & \\
\hline (818) 459-5500 & 1011 & 1015 & MARYLAND \\
\hline & Hamilton/Avnet Electronics & Hamilton/Avnet Electronics & 1039 \\
\hline 1155 & Commerce Industrial Park & 5825D Peachtree Corner E. & Hamilton/Avnet Electronics \\
\hline Hamilton Electro Sales & Commerce Dr. & Norcross, GA 300 & 6822 Oak Hall Ln. \\
\hline 1361-B West 190th St. & Danbury, CT 06810 & TWX: 810 (404760-0432 & Columbia, MD 21045 \\
\hline (213) 217-6748 & TWX: 710456 -9974 & & TWX: 710 862-1861 \\
\hline & & 1176 & \\
\hline \begin{tabular}{l}
\[
1190
\] \\
Marshall Industries
\end{tabular} & \begin{tabular}{l}
\[
1012
\] \\
J.V. Electronics
\end{tabular} & Marshall Industries
\(4350-J\) International Blvd. & 1040 \\
\hline 1 Morgan Avenue & 690 Main St. & Norcross, GA 30093 & 8930 A Rt. 108 \\
\hline Irvine, CA 92710 & East Haven, CT 06512 & (404) 923-5750 & Columbia, MD 20145 \\
\hline (714) 859-5050 & (203) 469-2321 & FAX: (404) 923-2743 & (301) 997-1118 \\
\hline
\end{tabular}

1161
8445 Helgerman
Gaithersburg, MD 20877
(301) 840-9450

1075
Almo Electronics Corp.
8502 Dakota Dr
Gaithersburg, MD 20877
(301) 670-0090

\section*{MASSACHUSETTS}

1109
Almo Electronics
60 Shawmut Rd.
Canton, MA 02021-1410
(617) 821-1420

Zeus
420 Marrett Road
Lexington, MA 02173
(617) 863-8800

1115
Hamilton/Avnet
10-D Centennial Dr
Peabody, MA 01960
(617) 531-7430

1084
Future Electronics
133 Flanders Rd
Westboro, MA 01581
(617) 366-2400

1116
Marshall Industries
33 Upton Dr.
Wilmington, MA 01887
(617) 658-0810

\section*{MICHIGAN}

1043
Advent Electronics
24713 Crestview Ct.
Farmington Hills, MI 48018
(313) 477-1650

1077
Hamilton/Avnet Electronics
2215 29th St., S.E. A-5
Grand Rapids, MI 49508
(616) 243-8805

TWX: 810 273-6921
1044
Hamilton/Avnet Electronics
32487 Schoolcraft Rd.
Livonia, MI 48150
(313) 522-4700

TWX: 810 242-8775
1162
Marshall Industries
31067 Schoolcraft
Livonia, MI 48150
(313) 525-5850

1021
Reptron
34403 Glendale Rd.
Post Office Box 2768
Livonia, MI 4815
(313) 525-2700

\section*{MINNESOTA}

\section*{1127}

Voyager Electronics Corp.
7163 Commerce Circle West
Fridley, MN 55432
(612) 571-7766

1047
Hamilton/Avnet Electronics
10300 Bren Rd. E
Minnetonka, MN 55343
(612) 932-0600

TWX: 910 576-2720
1163
Marshall Industries
3800 Annapolis Ln.
Plymouth, MN 55441
(612) 559-2211

MISSOURI
1048
Hamilton/Avnet Electronics
13743 Shoreline Ct.
Earth City, MO 63045
(314) 344-1200

TWX: 910 762-0684

\section*{NEW HAMPSHIRE}

1049
Hamilton/Avnet Electronics
444 E. Industrial Park Dr
Manchester, NH 03103
(603) 624-9400

NEW JERSEY
1156
Pan American Electronics Inc.
59 Main Street
Bloomingdale, NH 07403
(201) 839-0077

1020
Hamilton/Avnet Electronics
1 Keystone Ave., Bldg. 36
Cherry Hill, NJ 08003
(609) 424-01 10

TWX: 710 940-0262
1078
Hamilton/Avnet Electronics
10 Industrial Rd.
Fairfield, NJ 07006
(201) 575-3390

TWX: 710 734-4388
1164
Marshall Industries
101 Fairfield Rd
Fairfield, NJ 07006
(201) 882-0320

1166
Marshalf Industries
158 Gaither Dr.
Mt. Laurel, NJ 08054
(609) 234-9100

1126
General Components Inc.
245-D Clifton Ave.
West Berlin, NJ 08091
(609) 768-6767

\section*{NEW MEXICO}

1022
Hamilton/Avnet Electronics
2524 Baylor Dr. S.E.
Albuquerque, NM 87106
(505) 765-1500

TWX: 910 989-0614

\section*{NEW YORK}

1114
Semispecialists of America
105 Baylis Road
Melville, NY 11747
(516) 293-2710

FAX: (516) 293-2707
1025
Hamilton/Avnet Electronics
933 Motor Parkway
Hauppauge, LI, NY 11787
(516) 231-9800

TWX: 510 224-6166
1192
Marshall Industries
275 Oser Ave
Hauppauge, LI, NY 11788
(516) 273-2424

1193
Marshall Industries
129 Brown St.
Johnson City, NY 13790
(607) 798-1611

024
Hamilton/Avnet Electronics
333 Metro Park
Rochester, NY 14623
716) 475-9140

TWX: 510 253-5470
1022
Future Electronics
7453 Morgan
Liverpool, NY 13088
(315) 451-2371

1021
eu
100 Midland Avenue
Port Chester, NY 10573
914) 937-7400

FAX: (914) 937-2553
117
Marshall Industries
1280 Scottsville Rd.
Rochester, NY 14624
(716) 235-7620

1023
Hamilton/Avnet Electronics
03 Twin Oaks Dr.
yracuse, NY 13206
(315) 437-2641

NORTH CAROLINA
1027
Hamilton/Avnet Electronics
3510 Spring Forest Rd
Raleigh, NC 27604
Raleigh, \(\mathbf{~} \mathbf{8 7 8}-0810\)
TWX: 510-928-1836
1170
Marshall Industries
5221 North Blvd.
Raleigh, NC 27604
(919) 878-9882

1173
Quality Components
2940-15 Trawick Rd.
Raleigh, NC 27604
(919) \(876-7767\)

\section*{OHIO}

1028
Hamilton/Avnet Electronics
4588 Emery Industrial Parkway
Cleveland, OH 44128
(216) 831-3500

TWX: 810 427-9452
1029
Hamilton/Avnet Electronics
954 Senate Dr
P.O. Box 610

Dayton, OH 45459
513) 439-6700

TWX: 810 450-2531
1184
Marshall Industries
6212 Executive Blvd
Dayton, OH 45424
(513) 236-8088

1181
Marshall Industries
30700 Bainbridge Rd
Unit A
Solon, OH 44139
(216) 248-1788

133
Hamilton/Avnet Electronics
777 Brooksedge Blvd.
Westerville, OH 43081
614) 882-7004

OKLAHOMA
1117
Hamilton/Avnet Electronics
12121 E. 51st Street
Suite. 102A
Tulsa, OK 74146
(918) 252-7297

1113
Quality Components, Inc.
3158 So. 108th East Avenue
3158 So.
Suite 274
Tulsa, OK 74146
(918) \(664-8812\)

\section*{OREGON}

1150
Western Micro Technology Inc.
13770 S.W. 24th
Beaverton, OR 97005
(503) 629-2082

1169
Marshall Industries
8333 S.W. Cirrus Drive
Beaverton, OR 97005
(503) 644-5050

1032
Hamilton/Avnet Electronics
6024 S.W. Jean Rd.
Bldg. C, Suite 10
Lake Oswego, OR 97034
(503) 635-8157

TWX: 910 455-8179

PENNSYLVANIA
1034
Almo Electronics
9815 Roosevelt Blvd
Philadelphia, PA 19114
(215) 698-4000

1037
Hamilton/Avnet
2800 Liberty Ave., Bidg. E
Pittsburgh, PA 15222
(412) \(281-4150\)

1168
Marshall Industries
701 Alpha Drive
Suite 240
Pittsburgh, PA 15238
(412) 963-0441

TEXAS
1110
Quality Components, Inc.
4257 Kellway Circle
Addison, TX 75001
(214) 733-4300

TWX: 910 860-5459
1050
Hamilton/Avnet Electronics
1807-A W. Braker Lane
Austin, TX 78758
(512) 837-8911

TWX: 910 874-1319
1177
Marshall Industries
8504 Cross Park Dr.
Austin, TX 78754
(512) 837-1991

1112
Quality Components, Inc.
2120-M Baker Ln.
Austin, TX 78758
(512) 835-0220

TLX: 324930
1183
Marshall Industries
2045 Chenault
Carrollton, TX 75006
(214) 233-5200

1187
Marshall Industries
7250 Langtry
Houston, TX 77040
(713) 895-9200

1052
Hamilton/Avnet Electronics
2111 W. Walnut Hill Ln.
Irving (Dallas), TX 75062
(214) \(550-7755\)

TWX: 910 860-5929

1051
1800 N. Glenville Dr.
Suite 120
Richardson, TX 75081
(214) \(783-7010\)

1053
Hamilton/Avnet Electronic
4850 Wright Rd.
Stafford, TX 77477
(713) 240-7898

1111
Quality Components, Inc
1005 Industrial Blvd.
Sugarland, TX 77478
(713) \(240-2255\)

\section*{UTAH \\ 1059}

Hamilton/Avnet Electronics
1585 West 2100 South
Salt Lake City, UT 84119
801) 972-2800

TWX: 910 925-4017
1058
Marshall Industries
466 Lawndale Dr., Ste. C
Salt Lake City, UT 84115 (801)485-1551

WASHINGTON
1060
Hamilton/Avnet Electronics
14212 N.E. 21st St
Bellevue, WA 98007
(206) 643-3950

TWX: 910443 -2469
1175
Marshall Industries
14102 N.E. 21 st Street
Bellevue, WA 98007
(206) 747-9100

1149
Nestern Micro Technology Inc
14636 N.E. 95th Street
Redmond WA 98052
(206) \(881-6737\)

WISCONSIN
1061
Hamilton/Avnet Electronics
2975 Marrland Rd.
New Berlin, WI 53151
(414) 784-4510

TWX: 910 262-1182
1062
Marshall Industries
235 N. Executive Dr., \#305
Brookfield, WI 53005
(414) \(797-8400\)
(800) \(472 \cdot 2420\)

\section*{CANADA}

1091
Hamilton/Avnet Electronics
281621 st St. N.E.
Calgary, Alberta
Canada T2E 6Z2
(403) 250-3586

TWX: 03-827642
1092
ITT Multicomponents
11680170 St.
Edmonton, Alberta
Canada T5S 1J7
(403) \(451-4001\)

1093
ITT Multicomponents
3455 Gardner Court
Burnaby, British Columbia
Vancouver, Canada V5G 4J7
(604) 291-8866

TLW: 04-356533

1072
Future Electronics, Inc.
1695 Boundary Rd.
Vancouver, British Columbia
Canada V5K 4X7
(604) 294-1166

TLX: 04-354744
FAX: (604) 294-1206

1073
TT Multicomponents
760 Century St.
Winnipeg, Manitoba
Winnipeg, Manitob
(204) 786-8401

1074
TT Multicomponents
15 Mount Royal Blvd.
P.O. Box 821

Moncton, New Brunswick
Canada E1C 8N6
(506) \(857-8001\)

1075
ITT Multicomponents
\#103-11 Morris Dr.
Burnside Industrial Park
Dartmouth, Nova Scotia
Dartmouth, Nova Scotia
Canada B3B 1 M
1076
TTT Multicomponents
300 N. Rivermede Rd.
Concord, Ontario
Canada L4K 2 Z4
(416) 736-1144

TLX:06-964814
FAX: (416) 736-4831
1081
Future Electronics Inc.
82 Saint Regis Crescent North
Downsview, Ontario
Canada M3J \(1 \mathrm{Z3}\)
Canada M3J 12
TWX: 610 491-1470
FAX: (416) 638-2936
1063
Hamilton/Avnet Electronics
6845 Rexwood Rd., Units 3-5
Mississauga, Ontario
Canada L4V 1R2
(416) 677-7432

1064
Hamilton/Avnet Electronics
190 Colonnade Rd
Nepean, Ontario
Canada K2E 7J5
Canada K2E 7 J
TWX:053-4971

1070
Future Electronics Inc
Baxter Center
1050 Baxter Rd
Ottawa, Ontario
Canada K2C 3P2
(613) 820-8313

TWX: 610 563-1697
FAX: (613) 820-3271
1080
Future Electronics Inc.
237 Hymus Blvd.
Pointe Claire, Quebec
Canada H9R 5C7
(514) 694-7710

FAX: (514) 695-3707
TLX: 05-823554
1065
Hamilton/Avnet Electronics
2795 Halpern
St. Laurent
Montreal, Quebec
CanadaH4S 1 P8
(514) 335-1000

1067
ITT Multicomponents
2295 Halpern St.
Ville St. Laurent, Quebec
Canada H4S 1S3
(514) 335-7697

TLX: 05-824138
FAX: (514) 335-9330
1068
ITT Multicomponents
3521 8th Street E., \#209
Saskatoon, Saskatchewan
Canada S7H ON5
(306) 933-2888

ROCKWELL SEMICONDUCTOR PRODUCTS SALES OFFICES - INTERNATIONAL
You can obtain expert applications assistance, price quotations and delivery data from the Distributors and Sales Representatives listed below for Rockwell semiconductor and telecommunication products. If there is no Rockwell distributor convenient to your country, please consider Hamilton/Avnet International listed below.
\begin{tabular}{|c|c|c|c|}
\hline & INDIA & WEST GERMANY & 0266 \\
\hline AFRICA & 4066 & 0250 & Marubeni-Hytech Co. Ltd. \\
\hline South Continental Devices & Semiconductor Complex Limited & Bitronic GmBH & 1-1, Higashi lkebukuro \\
\hline  & Phase VIII, S.A.S. NAGAR-160059 & Dingolfingerstr. 6 & Chome, Toshimaku \\
\hline \[
\text { P.O. Box } 56420
\] & Punjab, India & D-8000 Muenchen 80, Germany & Tokyo, Japan (81-3) 989-7813 \\
\hline Pinegowkig 2123, South Africa & TLX: 395270 LSI & TLX: 5212931 bit d & TLX: NTT 2722648 HYTEC J \\
\hline & & 0245 & 0206 \\
\hline AUSTRIA & ISRAEL & Unitronic GmBH & Matsushita Electric Trading Co. \\
\hline 0226 & 0255 & Munsterstr. 338 & P.O. Box 18 \\
\hline W. Moor GESMBH & Bynet Data Communications & P.O. Box 330429 & Trade Center, 32 nd Floor \\
\hline Storchengasse 1/1/1 & 8-Hanechoshet St. & 4000 Dusseldorf 30 & World Trade Center Bldg. \\
\hline A-1150 Wien & Ramat-Hachayal & W. Germany & 4-1 Hamamatsu-cho 2-chome \\
\hline Austria & Tel-Aviv 69710, Israel & (49-211) 626364-67 & Minato-ku \\
\hline 43 (222) 858-646 & TLX: 342132 & TLX: 8586434 unid d & Tokyo 105, Japan \\
\hline TLX: 047-135701 moor a FAX: (43-222) 615537151 & FAX: (972) 3-475933 & 0237 & \begin{tabular}{l}
(81-3) 435-4552 \\
TLX: 522-8771 METOSK J
\end{tabular} \\
\hline FAX: (43-222) 615537151 & & Astronic GmBH & TLX: 522-8771 METOSK J \\
\hline & ITALY & Winzererstr. 47d. & 0207 \\
\hline BELGIUM & 0260 & 8000 Munchen 40 & Matsushita Electric Trading Co. \\
\hline 0272 & Murata Elettronica & Munich, West Germany & Twin 21 National Tower, 32nd. Flr. \\
\hline Microtron & Via Melchiorre Gioia, 66 & (49-89) 309031 a & 1-61, Shiromi 2-chome \\
\hline Generaal Dewittelaan 7,
2800 Mechelen & T-20125 Milano, Italy & TLX: 5216187 a strd & Higashi-ku \\
\hline 2800 Mechelen & (39-2) 607-3786 & & (06) 946-4841 \\
\hline TLX: 846-22606 mitron b & TW9-2)
TW38-4833 & AUSTRALIA/NEW ZEALAND & TLX: 522-8771 METOSKJ \\
\hline & & 4054 & \\
\hline BRAZIL & NORWAY & VSI Electronics & KOREA \\
\hline Round Valley Services & 0271 & (Australia) Pty. Ltd. & 0242 \\
\hline R. Vitorino Carmilo, 672 & Satt Electronics & 16 Dickson Avenue \({ }^{\text {Artarmon, NSW } 2064 \text { Australia }}\) & Unistandard Corp. \\
\hline CEP 01153-Barrafunda SP & O.H. Bangs Vei 17 & \[
\text { FAX: (02) } 439-6435
\] & 757-1 Bang Bae-Dong \\
\hline (011) 825-3111 & Postboks 70 & TLX: AA-22846 & Kang-Nam Ku \\
\hline TLX: (011) 53612 & 1322 Hovik, Norway & TLX: AA-22846 & Seoul, Korea \\
\hline Phone U.S.A.: (801) 224-5773 & \[
\begin{aligned}
& \text { (47-02) } 123600 \\
& \text { TLX: } 72559 \text { SATT N }
\end{aligned}
\] & VSI Electronics Pty. Ltd. P.O. Box 578 & TLX: K22116 "UNIST"
(82-2) 532-6815 \\
\hline DENMARK & & Crows Nest, NSW 2065 & \\
\hline \[
0244
\] & SPAIN & Artarmon, Australia (02) 439-4655 & SINGAPORE \\
\hline Micronor APS & 0239 & FAX: (02) 439-4655 & 0262 \\
\hline Torvet 1 & Comelta SA. & TLX: AA-22846 & Dynamar International Ltd. \\
\hline 8600 Silkeborg & Emilio Munoz 41 & TLX:AA-22846 & 12, Lorong Bakar Batu \\
\hline Denmark & ESC 1, Planta 1, Nave 1-1-2 & HONG KONG & Kolam Ayer, Suite 05-11 \\
\hline (45-6) 816522 & Madrid 17, Spain & 2086 & Singapore RE 1334 \\
\hline TLX: 63245 MICRONOR DK & (34-1) 754-3001 & Tekcomp Electronics Ltd. & 7476188 \\
\hline & TLX: 42007 CETA E & 1702 Bank Centre & TLX: 26283 \\
\hline FINLAND & FAX: (341) 754-2151 & 636 Nathan Rd. & \\
\hline 0252 & & Kowloon, Hong Kong & TAIWAN \\
\hline Satt Electronics & SWEDEN & (852-3) 880629 & 0213 \\
\hline oy Hitsaajakatu 8, & Betoma Component AB & TLX: 38513 TEKHL & Sertek International Inc. \\
\hline P.O. Box 68 & Box 3005 & FAX: (852) 123-40746 & 3-9, 11-12 Fir. \\
\hline 00811 , Helsinki & Dalvaegen 12 & JAPAN & 135-137 Sec. 2 Chien Kuo N. Road \\
\hline Finland & 17128 Solna, Sweden & 0268 & Taipei, 10479 Taiwan, ROC (86-2) 501-0055 \\
\hline (358) 0-7555133 & (46-8) \(734-8300\)
TLX: 8126331 BETOM & KS Semiconductor, Inc. & TLX:13579 \\
\hline TLX. 124870 ELDYN SF & TLX: 8126331 BETOM & 3-6-31-1 F Osaki Shinasgawaku & FAX: 025012521 \\
\hline FRANCE & SWITZERLAND & T141 Tokyo, Japan (81-3) 490-0762 & \\
\hline 0222 & 0227 & TLX: 2466528 AIS-J & THAILAND \\
\hline System Contact & Aumann \& Co. AG & FAX: (81-3) 495-5565 & 0263 \\
\hline 88, Avenue du General de Gaulle & Foerrlibuckstr. 150 & 0269 & Loxley (Bangkok) Ltd. \\
\hline 67200 Eckbolsheim & CH-8037 Zurich & Kanematsu Semiconductor Corp. & GPO Box 214 \#304 \\
\hline France & Switzerland & 6-1 Shintomi 1 chome & Suapah Road \\
\hline Phone: (33-88) 782089 & (41-1) 443-300 & Chuo-Ku, Tokyo 104, Japan & Bangkok, 10501 \\
\hline (33) 88782089 & TLX: 822966 & (81-3) 551-7791 & Thailand \\
\hline TLX: 890266 SYSCO & & TLX: 2523798 KSC J & \[
221-9156-60
\] \\
\hline 0259 & UNITED KINGDOM & 0203 & 223-9066-8 \\
\hline ERN & 0258 & Kyokuto Boeki Kaisha, Ltd. & TLX: LOXLEY TH81188 \\
\hline 237 rue de Fourny & R.C.S. Microsystems Ltd. & 7th Floor, New Otemachi Bldg. & \\
\hline 78530 BUC France & The Kings Arms & 1-1, 2-chome, Otemachi, Chiyoda-ku & \\
\hline (33-1) 3956-0011 & 141 Uxbridge Rd. & Tokyo, Japan & \\
\hline TLX: 698627 ERN BUC & Hampton Hill, Middlesex & (81-3) 244-3803 & OTHER COUNTRIES \\
\hline & RW12 1BL, England & TLX: J22440 & \\
\hline HOLLAND & (01) 979-2204 & FAX: (81-3) 246-1846 & Hamilton/Avnet Electronics \\
\hline 2087 & TLX: 8951470 RCS MIC & 0204 & International Group \\
\hline Alcom Electronics BV & 0280 & Kyokuto Boeki Kaisha, Ltd. & 10950 Washington Blvd. \\
\hline Esse Baan 1 & Abacus Electronics PLC & Rm. 606 & Culver City, CA 90230 \\
\hline Postbus 358, 2908 AJ & Abacus House & Mainichi Osaka Kaikan Kitakan & (213) 558-2441 \\
\hline Capelle A/D Ijssel & Bone Lane, Newbury & 6-16 Dojima 1-chome, Kita-ku & \\
\hline Holland & Berkshire, RG14 5SF, England & Osaka, Japan & \\
\hline (31-10) 4519-533 & (0635) 30680 & (06) 344-1121 & \\
\hline TLX: 26160 & TLX: 849343 & TLX: c/o KBK's Tokyo Office & \\
\hline
\end{tabular}

\section*{NOTES}```


[^0]:    *These addressing modes are not available to the NMOS CPU family (e.g., the R6502).

[^1]:    NOTE: Timing measurements are referenced to and from a low voltage of 0.8 Vdc and a high voltage of 2.0 Vdc .

[^2]:    MC
    7 UM(T)—Update/Read Mode (Transparent Mode) Update occurs during horizontal and vertical blanking times with update strobe.
    1 Update interleaves during $\emptyset 2$ portion of cycle.

    | MC |  |
    | :---: | :---: |
    | 6 | US(T) -Update Strobe (Transparent Mod |
    | 0 | Pin 34 functions as memory address (RA4). |
    | 1 | Pin 34 functions as update strobe (STB). |
    | MC |  |
    | 5 | CSK - Cursor Skew |
    | 0 | No delay. |
    | 1 | Delays Cursor one character time. |
    | MC |  |
    | 4 | DES - Display Enable Skew |
    | 0 | No delay. |
    | 1 | Display Enable delays one character time. |

    MC

    | 3 | RRA —Refresh RAM Access |
    | :---: | :---: |
    | 0 | Shared memory access |
    | 1 | Transparent memory access |

    MC
    2 RAD -Refresh RAM Addressing Mode
    0 Straight binary addressing
    1 Row/column addressing
    MC1-MCO IMC -Interlace Mode Control
    MC MC
    $\begin{array}{lll}\frac{1}{X} & 0 & \text { Operation } \\ \text { Non-interlace }\end{array}$
    01 Interlace SYNC raster scan
    11 Interlace SYNC and video raster scan

    ## R9-ROW SCAN LINES

    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    | - | - | - | SCAN LINES -1 |  |  |  |  |

    This 5 -bit write-only register contains the number of scan lines, minus one, per character row, including spacing.

    ## R10-CURSOR START LINE

    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    | - | $\mathrm{B}_{1}$ | $\mathrm{~B}_{0}$ | START SCAN LINE |  |  |  |  |

    ## R11-CURSOR END LINE

    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    | - | - | - | END SCAN LINE |  |  |  |  |

    These 5 -bit write-only registers select the starting and ending scan lines for the cursor. In addition, bits 5 and 6 of R10 are used to select the cursor blink mode, as follows:

    | $\mathbf{B}_{\mathbf{1}}$ | $\mathbf{B}_{\mathbf{0}}$ | Cursor Operating Mode |
    | :---: | :---: | :--- |
    | 0 | 0 | Display Cursor Continuously |
    | 0 | 1 | Blank Cursor |
    | 1 | 0 | Blink cursor at 1/16 Field Rate |
    | 1 | 1 | Blink Cursor at 1/32 Field Rate |

    A one character wide cursor can be controlled by storing values into the Cursor Start Line (R10) and Cursor End Line (R11) registers and into the Cursor Position Address High (R14) and Cursor Position Low (R15) registers.

    R12-DISPLAY START ADDRESS HIGH

    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    | - | - | DISPLAY START ADDRESS HIGH |  |  |  |  |  |

    R13-DISPLAY START ADDRESS LOW

    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
    | :--- | :--- | :--- | :---: | :---: | :---: | :---: | :---: |
    | DISPLAY START ADDRESS LOW |  |  |  |  |  |  |  |

    These registers together form a 14-bit register whose contents are the memory address of the first character to be displayed (the character on the top left of the video display, as in Figure 4). Subsequent memory addresses are generated by the R6545 as a result of CCLK input pulses. Scrolling of the display is accomplished by changing R12 and R13 to the memory address of the first character of the first line of text to be displayed. Entire pages of text may be scrolled or changed as well via R12 and R13.

    ## R14-CURSOR POSITION HIGH

    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    | - | - | CURSOR POSITION HIGH |  |  |  |  |  |

    ## R15-CURSOR POSITION LOW

    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
    | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
    | CURSOR POSITION LOW |  |  |  |  |  |  |  |

    These registers together form a 14-bit register whose contents are the memory address of the current cursor position. When the video display scan counter (MA lines) matches the contents of this register, and when the scan line counter (RA lines) falls within the bounds set by R10 and R11, then the CURSOR output becomes active. Bit 5 of the Mode Control Register (R8) may be used to delay the CURSOR output by a full CCLK time to accommodate slow access memories.

    The cursor is positioned on the screen by loading the Cursor Position Address High (R14) and Cursor Position Address Low (R15) registers with the desired refresh RAM address. The cursor can be positioned in any of the 16K character positions. Hardware paging and data scrolling is thus allowed without loss of cursor position. Figure 3 is an example of several cursor options.
    

    Figure 3. Cursor Display Scan Line Control Examples

    ## R16-LIGHT PEN HIGH

    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    | - | - | LPEN HIGH |  |  |  |  |  |

    ## R17-LIGHT PEN LOW

    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    | LPEN LOW |  |  |  |  |  |  |  |

    These registers together form a 14-bit register whose contents are the light pen strobe position, in terms of the video display address at which the strobe occurred. When the LPEN input changes from low to high, then, on the next negative-going edge of CCLK, the contents of the internal scan counter is stored in registers R16 and R17.

    ## R18-UPDATE ADDRESS HIGH

    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    | - | - | UPDATE ADDRESS HIGH |  |  |  |  |  |

    ## R19—UPDATE ADDRESS LOW

    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
    | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
    | UPDATE ADDRESS LOW |  |  |  |  |  |  |  |

    These registers together comprise a 14-bit register whose contents are the memory address at which the next read or update will occur (for transparent address mode only). Whenever a read/update occurs, the update location automatically increments to allow for fast updates or readouts of consecutive character locations. The section on REFRESH RAM ADDRESSING describes this more fully.

    R31-DUMMY LOCATION

    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    | - | - | - | - | - | - | - | - |

    This register does not store any data, but is required to detect transparent addressing updates. This is necessary to increment the Update Address Register and to set the Update Ready bit in the status register.

    ## REGISTER FORMATS

    Register pairs R12/R13, R14/R15, R16/R17, and R18/R19 are formatted in one of two ways:
    (1) Straight binary, if register R8, bit $2=0$
    (2) Row/Column, if register R8, bit $2=1$. In this case the low byte is the Character Column and the high byte is the Character Row.
    

    Figure 4. Video Display Format

    ## DESCRIPTION OF OPERATION

    ## VIDEO DISPLAY

    Figure 4 indicates the relationship of the various program registers in the R6545 and the resulant video display.

    Non-displayed areas of the Video Display are for horizontal and vertical retrace functions of the CRT monitor. The horizontal and vertical sync signals, HSYNC and VSYNC, are programmed to occur during these intervals and trigger the retrace in the CRT monitor. The pulse widths are constrained by the monitor requirements. The time position of the pulses may be adjusted to vary the display margins (left, right, top, and bottom).

    ## REFRESH RAM ADDRESSING

    There are two modes of addressing for the video display memory:

    ## Shared Memory Mode (R8, BIT $3=0$ )

    In this mode, the Refresh RAM address lines (MA0-MA13) directly reflect the contents of the internal refresh scan character counter. Multiplex control, to permit addressing and selection of the RAM by both the CPU and the CRTC, must be provided externally to the CRTC. In the Row/Column address mode, lines MAO-MA7 become character column addresses (CC0-CC7) and MA8-MA13 become character row addresses (CR0-CR5). Figure 5 illustrates the system configuration.

    Transparent Memory Addressing (R8, BIT $3=1$ )
    For this mode, the display RAM is not directly accessible by the CPU, but is controlled entirely by the R6545. All CPU accesses are made via the R6545 and a small amount of external circuitry. Figure 6 shows the system configuration for this approach.
    

    Figure 5. Shared Memory System Configuration
    

    Figure 6. Transparent Memory Addressing System Configuration
    (Data Hold Latch Needed for Horizontal/Vertical Blanking Updates, Only).

    ## ADDRESSING MODES

    Figure 7 illustrates the address sequence for both modes of the Refresh RAM address.

    ## Row/Column

    In this mode, the CRTC address lines (MA0-MA13) generate 8 column (MA0-MA7) and 6 row (MA8-MA13) addresses. Extra hardware is needed to compress this addressing into a straight binary sequence in order to conserve memory in the refresh RAM (register R8, bit 2 is a 1 ).

    ## Binary

    In this mode, the CRTC address lines are straight binary and no compression circuits are needed. However, software complexity increases since the CRT characters cannot be stored in terms of their row and column locations, but must be sequential (register R8, bit 2 is a 0 ).

    ## USE OF DYNAMIC RAM FOR REFRESH MEMORY

    The R6545 permits use of dynamic RAMS as storage devices for the Refresh RAM by continuing to increment memory addresses in the non-display intervals of the scan. This is a
    viable technique, since the Display Enable signal controls the actual video display blanking. Figure 7 illustrates Refresh RAM addressing for both row/column and binary addressing for 80 columns and 24 rows with 10 non-displayed columns and 10 non-displayed rows.

    Note that the straight-binary mode has the advantage that all display memory addresses are stored in a continuous memory block, starting with address 0 and ending at 1919. The disadvantage with this method is that, if it is desired to change a displayed character location, the row and column identity of the location must be converted to its binary address before the memory may be written. The row/column mode, on the other hand, does not need to undergo this conversion. However, memory is not used as efficiently, since the memory addresses are not continuous, gaps exist. This requires that the system be equipped with more memory than actually used and this extra memory is wasted. Alternatively, address compression logic may be employed to translate the row/column format into a continuous address block.

    The user selects whichever mode is best for the given application. The trade-offs between the modes are software versus hardware. Straight-binary mode minimizes hardware requirements and row/column minimizes software requirements.
    

    STRAIGHT BINARY ADDRESSING SEQUENCE
    

    ROW/COLUMN ADDRESSING SEQUENCE

    Figure 7. Display Address Sequences (with Start Address $=0$ ) for $80 \times 24$ Example

    ## MEMORY CONYENTION SCHEMES FOR SHARED MEMORY ADDRESSING

    From the diagram of Figure 5, it is clear that both the R6545 and the system CPU must address the video display memory. The R6545 repetitively fetches character information to generate the video signals in order to keep the screen display active. The CPU occasionally accesses the memory to change the displayed information or to read out current data characters. Three ways of resolving this dual-contention requirement are apparent:

    - CPU Priority

    In this technique, the address lines to the video display memory are normally driven by the R6545 unless the CPU needs access, in which case the CPU addresses immediately override those from the R6545 giving the CPU immediate access.

    - $\emptyset 1$ and $\emptyset 2$ Memory Interleaving

    This method permits both the R6545 and the CPU to access the video display memory by time-sharing. During the $\emptyset 1$ portion of each cycle (the time when $\emptyset 2$ is low), the R6545 address outputs are gated to the video display memory. During $\emptyset 2$ time, the CPU address lines are switched in. This way, both the R6545 and the CPU have unimpeded access to the memory. Figure 8 illustrates these timings.
    

    Figure 8. $\$ 1$ and $\$ 2$ Interleaving

    ## - Vertical Blanking

    With this approach, the address circuitry is identical to the case for CPU Priority updates. The only difference is that the Vertical Retrace status bit (bit 5 of the Status Register) is used by the CPU so that access to the video display memory is only made during vertical blanking time (when bit 5 is a 1 ). In this way, no visible screen perturbations result. See Figure 10 for details.

    ## TRANSPARENT MEMORY ADDRESSING

    In this mode of operation, the video display memory address lines are not switched by contention circuits, but are generated by the R6545. In effect, the contention is handled by the R6545. As a result, the schemes for accomplishing CPU memory access are different:

    ## - $\$ 1$ and $\emptyset 2$ Interleaving

    This mode is similar to the Interleave mode used with shared memory. In this case, however, the $\emptyset 2$ address is generated from the Update Address Register (R18 and R19) in the R6545. The CPU loads the address to be accessed into R18/R19. This address is then gated onto the MA lines during $\emptyset 2$. Figure 9 shows the timing.
    

    Figure 9. $\$ 1$ and 02 Transparent Interleaving

    ## - Horizontal/Vertical Blanking

    In this mode, the CPU loads the Update Address into R18 and R19. This address is gated onto the MA lines during horizontal or vertical blank times, so memory accesses do not interfere with the display appearance. Pin 34 can be programmed, by R8 bit 6 , to function as an update strobe which signals the presence of an update address on the MA lines. Data hold latches are necessary to temporarily retain the character to be stored until the retrace time occurs. In this way, the system CPU is not halted waiting for the blanking time to arrive. Figure 11 illustrates the address and strobe timing for this mode.

    ## CURSOR AND DISPLAY ENABLE SKEW CONTROL

    Bits 4 and 5 of the Mode Control register (R8) are used to delay the Display Enable and Cursor outputs, respectively. Figure 12 illustrates the effect of the delays.
    

    Figure 10. Operation of Vertical Blanking Status Bit
    

    Figure 11. Retrace Update Timing
    

    Figure 12. Cursor and Display Enable Skew

    BUS WRITE TIMING CHARACTERISTICS ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{A}=\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$, unless otherwise noted)

    | Symbol | Characteristic | 1 MHz |  | 2 MHz |  | Unit |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    |  |  | Min. | Max. | Min. | Max. |  |
    | $\mathrm{t}_{\mathrm{CYC}}$ | Cycle Time | 1.0 | - | 0.5 | - | $\mu \mathrm{S}$ |
    | $\mathrm{t}_{\mathrm{CH}}$ | ¢2 Pulse Width High | 440 | - | 200 | - | ns |
    | $\mathrm{t}_{\mathrm{CL}}$ | $\emptyset 2$ Pulse Width Low | 420 | - | 190 | - | ns |
    | $\mathrm{t}_{\text {ACW }}$ | Address Set-Up Time | 80 | - | 40 | - | ns |
    | $\mathrm{t}_{\text {CAH }}$ | Address Hold Time | 0 | - | 0 | - | ns |
    | $t_{\text {wCW }}$ | R $\bar{W}$ Set-Up Time | 80 | - | 40 | - | ns |
    | $\mathrm{t}_{\text {CWH }}$ | R $\bar{W}$ Hold Time | 0 | - | 0 | - | ns |
    | $t_{\text {bcw }}$ | Data Bus Set-Up Time | 165 | - | 60 | - | ns |
    | $t_{\text {HW }}$ | Data Bus Hold Time | 10 | - | 10 | - | ns |
    | ( $\mathrm{t}_{\mathrm{R}}$ and $\mathrm{t}_{\mathrm{F}}=10$ to 30 ns ) |  |  |  |  |  |  |

    BUS READ TIMING CHARACTERISTICS $\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=T_{L}\right.$ to $T_{H}$, unless otherwise noted)

    |  | Characteristic | 1 MHz |  | 2 MHz |  | Unit |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    | Symbol |  | Min. | Max. | Min. | Max. |  |
    | $t_{\text {cyC }}$ | Cycle Time | 1.0 | - | 0.5 | - | $\mu \mathrm{S}$ |
    | $\mathrm{t}_{\mathrm{CH}}$ | $\emptyset 2$ Pulse Width | 440 | - | 200 | - | ns |
    | $\mathrm{t}_{\mathrm{CL}}$ | $\emptyset 2$ Pulse Width Low | 420 | - | 190 | - | ns |
    | $\mathrm{t}_{\text {ACR }}$ | Address Set-Up Time | 80 | - | 40 | - | ns |
    | $\mathrm{t}_{\text {CAR }}$ | Address Hold Time | 0 | - | 0 | - | ns |
    | $t_{\text {WCR }}$ | R/̄W Set-Up Time | 80 | - | 40 | - | ns |
    | $\mathrm{t}_{\text {CDR }}$ | Read Access Time (Valid Data) | - | 290 | - | 150 | ns |
    | $t_{\text {HR }}$ | Read Hold Time | 10 | - | 10 | - | ns |
    | $\mathrm{t}_{\text {CDA }}$ | Data Bus Active Time (Invalid Data) | 40 | - | 40 | - | ns |
    | ( $\mathrm{t}_{\mathrm{R}}$ and $\mathrm{t}_{\mathrm{F}}=10$ to 30 ns ) |  |  |  |  |  |  |

    

    ## BUS READ TIMING WAVEFORMS

    

    ## MEMORY AND VIDEO INTERFACE CHARACTERISTICS

    ( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$, unless otherwise noted)

    | Symbol | Parameter | R6545 |  |  | R6545E |  |  | Units |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    |  |  | Min. | Typ. | Max. | Min. | Typ. | Max. |  |
    | $\mathrm{t}_{\mathrm{CCH}}$ | Minimum Clock Pulse Width, High | 200 |  |  | 130 |  |  | ns |
    | $\mathrm{t}_{\mathrm{CCY}}$ | Clock Frequency |  |  | 2.5 |  |  | 3.7 | MHz |
    | $t_{R}, t_{F}$ | Rise and Fall Time for Clock Input |  |  | 20 |  |  | 20 | ns |
    | $t_{\text {MAD }}$ | Memory Address Delay Time |  | 180 | 300 |  | 100 | 160 | ns |
    | $t_{\text {RAD }}$ | Raster Address Delay Time |  | 180 | 300 |  | 100 | 160 | ns |
    | totD | Display Timing Delay Time |  | 240 | 450 |  | 160 | 300 | ns |
    | $\mathrm{t}_{\text {HSD }}$ | Horizontal Sync Delay Time |  | 240 | 450 |  | 160 | 300 | ns |
    | $t_{V S D}$ | Vertical Sync Delay Time |  | 240 | 450 |  | 160 | 300 | ns |
    | $\mathrm{t}_{\text {CDD }}$ | Cursor Display Timing Delay Time |  | 240 | 450 |  | 160 | 300 | ns |

    ## MEMORY AND VIDEO INTERFACE WAVEFORMS

    

    LIGHT PEN STROBE TIMING CHARACTERISTICS (For Reference Only)

    | Symbol | Characteristic | R6545 |  | R6545A |  | Unit |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    |  |  | Min. | Max. | Min. | Max. |  |
    | $\mathrm{t}_{\text {LPH }}$ | LPEN Hold Time | 150 | - | 100 | - | ns |
    | $\mathrm{t}_{\text {LP1 }}$ | LPEN Setup Time | - | 120 | - | 120 | ns |
    | $\mathrm{t}_{\text {LP2 }}$ | CCLK to LPEN Delay | - | 0 | - | 0 | ns |
    | Note: $\mathrm{t}_{\mathrm{R}}, \mathrm{t}_{\mathrm{F}}=20 \mathrm{~ns}(\mathrm{max})$ |  |  |  |  |  |  |

    LIGHT PEN STROBE TIMING WAVEFORMS
    

    MAO-MA13
    

    NOTE: "Safe" time position for LPEN positive edge to cause address $n+2$ to load into Light Pen Register.
    $t_{L P 2}$ and $t_{L P 1}$ are time positions causing uncertain results.

    TEST LOAD
    

    $$
    \begin{aligned}
    \mathrm{R} & =11 \mathrm{~K} \Omega \text { FOR DO-D7 } \\
    & =24 \mathrm{~K} \Omega \text { FOR ALL OTHER OUTPUTS } \\
    \mathrm{C} & =130 \mathrm{pF} \text { TOTAL FOR DO-D7 } \\
    & =30 \mathrm{pF} \text { ALL OTHER OUTPUTS }
    \end{aligned}
    $$

    CRTC Register Comparison

    | GENERAL FUNCTIONS |  |  |  |  |
    | :---: | :---: | :---: | :---: | :---: |
    | REGISTER | MC6845R HD6845R | HD6845S | R6545-1 | R6545/R6545E |
    | RO HORIZONTAL TOT | TOT-1 | TOT-1 | TOT-1 | TOT-1 |
    | R1 HORIZONAL DISP | ATUAL | ACTUAL | ACTUAL | ACTUAL |
    | R2 HORIZONTAL SYNC | ACTUAL | ACTUAL | ACTUAL | ACTUAL |
    | R3 HORIZ AND VERT SYNC WIDTH | HORIZONTAL | HORIZONTAL AND VERTICAL | HORIZONTAL AND VERTICAL | HORIZONTAL AND VERTICAL |
    | R4 VERTICAL TOT | TOT-1 | TOT-1 | TOT-1 | TOT-1 |
    | R5 VERTICAL TOT ADJ | ANY VALUE | ANY VALUE | any value <br> EXCEPT <br> $R 5=\mathrm{R9H} \cdot \mathrm{X}$ | ANY VALUE |
    | R6 VERTICAL DISP | $\begin{aligned} & \text { ANY VALUE } \\ & <\mathrm{R} 4 \end{aligned}$ | $\begin{aligned} & \text { ANY VALUE } \\ & <\mathrm{R} 4 \end{aligned}$ | $\begin{aligned} & \text { ANY VALUE } \\ & <\mathrm{R} 4 \end{aligned}$ | $\begin{aligned} & \text { ANY VALUE } \\ & <\text { R4 } \end{aligned}$ |
    | R7 VERTICAL SYNC POS | ACTUAL | ACTUAL | ACTUAL | ACTUAL |
    | R8 MODE REG BITS 0 and 1 | INTERLACE MODE SELECT | INTERLACE MODE SELECT | - | INTERLACE MODE SELECT |
    | BITS 2 | - | - | ROWICOLUMN OR STRAIGHT BINARY ADDRESSING | ROW/COLUMN OR STRAIGHT BINARY ADDRESSING |
    | BITS 3 | - | - | SHARED OR TRANSPARENT ADDR | SHARED OR TRANSPARENT ADDR |
    | BITS 4 | - | DISPEN SKEW | DISPEN SKEW | DISPEN SKEW |
    | BITS 5 | - | DISPEN SKEW | CURSOR SKEW | CURSOR SKEW |
    | BITS 6 | - | CURSOR SKEW | RA4/UPSTB | RA4/UPSTB |
    | BITS 7 | - | CURSOR SKEW | TRANSPARENT MODE SELECT | TRANSPARENT MODE SELECT |
    | R9 SCAN LINES | TOT-1 | TOT-1 | TOT-1 | TOT-1 |
    | R10 CURSOR START | ACTUAL | ACTUAL | ACTUAL | ACTUAL |
    | R11 CURSOR END | ACTUAL | ACTUAL | ACTUAL | ACTUAL |
    | R12/R13 DISP ADDR | WRITE ONLY | READ/WRITE | WRITE ONLY | WRITE ONLY |
    | R14/R15 CURSOR POS | WRITE ONLY | READ/WRITE | READ/WRITE | READ/WRITE |
    | R16/R17 LPEN REG | READ ONLY | READ ONLY | READ ONLY | READ ONLY |
    | R18/R19 UPDATE ADDR REG | N/A | N/A | TRANSPARENT MODE ONLY | TRANSPARENT MODE ONLY |
    | R31 DUMMY REG | N/A | N/A | TRANSPARENT MODE ONLY | TRANSPARENT MODE ONLY |
    | STATUS REG | NO | NO | YES | YES |
    | INTERLACE SYNC |  |  |  |  |
    | Ro | TOT-1 = ODD | TOT-1 = ODD | - | TOT-1 = ODD OR EVEN |
    | R4 VERTICAL | TOT-1 | TOT-2 | - | TOT-1 |
    | R6 VERT DISP | TOT/2 | TOT | - | TOT |
    | R7 VERT SYNC | ACTUAL | ACTUAL | - | ACTUAL |
    | R9 SCAN LINES | TOT-1 <br> EVEN ONLY | TOT-2 ODD/EVEN | TOT-1 ODDIEVEN | TOT-1 ODD/EVEN |
    | R10 CURSOR START R11 CURSOR END | BOTH ODD OR BOTH EVEN | ODD/EVEN ODDIEVEN | - | ODD/EVEN ODD/EVEN |
    | CHARACTER CLOCK FREQUENCY |  |  |  |  |
    | CCLK | 2.5 MHz | 3.7 MHz | 2.5 MHz | $3.7 \mathrm{MHz}^{*}$ |
    | Notes: $-=$ Does not apply $\quad$ * R6545 $=2.5 \mathrm{MHz} \quad$ R6545E $=3.7 \mathrm{MHz}$ |  |  |  |  |

    ## ABSOLUTE MAXIMUM RATINGS*

    | Parameter | Symbol | Value | Unit |
    | :--- | :---: | :---: | :---: |
    | Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | V |
    | Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | -0.3 to +7.0 | V |
    | Operating Temperature Range <br> Commercial <br> Industrial | $\mathrm{T}_{\mathrm{A}}$ | 0 to +70 <br> -40 to +85 | ${ }^{\circ} \mathrm{C}$ |
    | Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

    DC CHARACTERISTICS
    $\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}\right.$ to $\mathrm{T}_{\mathrm{H}}$, unless otherwise noted)
    *NOTE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

    | Parameter | Symbol | Min. | Typ. | Max. | Unit | Test Conditions |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    | Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
    | Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ | -0.3 |  | 0.8 | V |  |
    | Input Leakage $\emptyset 2, R / \bar{W}, \overline{R E S}, \overline{C S}, R S, ~ L P E N, ~ C C L K$ | $\mathrm{I}_{\mathrm{N}}$ | - |  | 2.5 | $\mu \mathrm{A}$ |  |
    | Three-State Input Leakage D0-D7 | $\mathrm{I}_{\text {TSI }}$ | - |  | $\pm 10.0$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ to 2.4 V |
    | Output High Voltage D0-D7 <br> All other outputs | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 |  | - | V | $\begin{aligned} & \mathrm{I}_{\text {LOAD }}=205 \mu \mathrm{~A} \\ & \mathrm{I}_{\text {LOAD }}=100 \mu \mathrm{~A} \\ & \hline \end{aligned}$ |
    | Output Low Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - |  | 0.4 | V | $\mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA}$ |
    | ```Input Capacitance \emptyset2, R/\overline{W},\overline{RES},\overline{CS},RS, LPEN, CCLK D0-D7``` | $\mathrm{C}_{\mathrm{IN}}$ | - |  | $\begin{aligned} & 10.0 \\ & 12.5 \\ & \hline \end{aligned}$ | pF | $\begin{aligned} & V_{I N}=0 V \\ & T_{A}=25^{\circ} \mathrm{C} \end{aligned}$ |
    | Output Capacitance | $\mathrm{C}_{\text {OUt }}$ | - |  | 10.0 | pF | $f=1 \mathrm{MHz}$ |
    | Power Dissipation Commercial Industrial | $P_{\text {D }}$ | - | $\begin{aligned} & 350 \\ & 350 \end{aligned}$ | $\begin{aligned} & 700 \\ & 800 \end{aligned}$ | mW | $\mathrm{V}_{C C}=5.25 \mathrm{~V}$ |

    ## PACKAGE DIMENSIONS

    ## 40-PIN PLASTIC DIP

    

    | DIM | MILLIMETERS |  | INCHES |  |  |  |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    |  | MIN | MAX | MIN | MAX |  |  |
    | A | 51.28 | 52.32 | 2.040 | 2.060 |  |  |
    | B | 13.72 | 14.22 | 0.540 | 0.560 |  |  |
    | C | 3.55 | 5.06 | 0.140 | 0.200 |  |  |
    | D | 0.36 | 0.51 | 0.014 | 0.020 |  |  |
    | F | 1.02 | 1.52 | 0.040 | 0.060 |  |  |
    | G | 2.54 |  | BSC | 0.100 |  | BSC |
    | H | 1.65 |  | 2.16 | 0.065 |  |  |
    | J | 0.20 | 0.30 | 0.085 |  |  |  |
    | K | 3.30 | 4.32 | 0.130 |  |  |  |
    | L | 15.24 |  | BSC | 0.600 |  | 0.170 |
    | M | $7^{\circ}$ |  | $10^{\circ}$ | $7^{\circ}$ |  | $10^{\circ}$ |
    | N | 0.51 |  | 1.02 | 0.020 |  | 0.040 |

    44-PIN PLASTIC LEADED CHIP CARRIER (PLCC)
    

    TOP VIEW
    
    

    SIDE VIEW
    

    SECTION A-A TYP FOR BOTH AXIS (EXCEPT FOR BEVELED EDGE)

    CHAM. 11 PINS
    $h \times 45^{\circ}$ PER
    $3 \times 45$
    PER SIDE
    EQUALLY
    SPACES
    BOTTOM VIEW

    | DIM | MILLIMETERS |  | INCHES |  |
    | :---: | :---: | :---: | :---: | :---: |
    |  | MIN | MAX | MIN | MAX |
    | A | 4.14 | 4.39 | 0.163 | 0.173 |
    | A1 | 1.37 | 1.47 | 0.054 | 0.058 |
    | A2 | 2.31 | 2.46 | 0.091 | 0.097 |
    | b | 0.457 TYP |  | 0.018 TYP |  |
    | D | 17.45 | 17.60 | 0.687 | 0.693 |
    | D1 | 16.46 | 16.56 | 0.648 | 0.652 |
    | D2 | 12.62 | 12.78 | 0.497 | 0.503 |
    | D3 | 15.75 REF |  | 0.620 REF |  |
    | e | 1.27 | BSC | 0.050 BSC |  |
    | h | 1.15 TYP |  | 0.045 TYP |  |
    | J | 0.25 TYP |  | 0.010 TYP |  |
    | $\alpha$ | $45^{\circ}$ TYP | $45^{\circ}$ TYP |  |  |
    | R | 0.89 TYP |  | 0.035 TYP |  |
    | R1 | 0.25 TYP |  | 0.010 TYP |  |

    EJECTOR PIN MARKS
    4 PLCS BOTTOM OF
    PACKAGE ONLY
    (TYPICAL)

    # R6549 <br> Color Video Display Generator (CVDG) 

    ## PRELIMINARY

    ## DESCRIPTION

    The Rockwell R6549 Color Video Display Generator (CVDG) integrates video raster control; color lookup table (LUT) update and access; color generation and display refresh; teletext data DMA addressing, data routing and handshake; dynamic RAM (DRAM) control and refresh; and MPU/CVDG/DMA access to DRAM into a single device. Internal horizontal and vertical state machines generate video synchronization signals and control access of video color data from DRAM. A 16-entry color lookup table (LUT) supports 4 -bit encoded color levels for red, green and blue (RGB) colors allowing 4096 color combinations to be generated. Each color code is converted to a 16 -level analog signal by a dedicated DAC, combined with a blanking signal, and output in sync with a pixel clock.
    Control registers allow MPU selection of CVDG operating mode and options while data registers allow MPU update of LUT data, current drawing pointer (CDP) graphics, Y scroll pointer and teletext pointer. The data registers can also be monitored by the MPU as can mode and raster scan status.
    The R6549 is the first display generator to be designed exclusively in support of North American Presentation Level Protocol Syntax (NAPLPS) videotex (VTX) and teletext (TTX).
    Replacing over 30 conventional MSI/LSI devices, the R6549 simplifies system design and layout, reduces printed circuit size, and minimizes required support circuits to speed system prototyping and greatly reduce both development and production costs.
    

    R6549 CVDG Pin Assignments

    ## FEATURES

    - High performance video generator
    - 2:1 or 1:1 interlace
    - Analog red, green, blue (RGB) outputs
    - 16 levels per color plus blanking
    - 4096 color combinations
    -RS-170 sync and color subcarrier generation
    - 16 entry color look-up table (LUT)
    - RS-170 composite sync output with equalization and serration pulses
    - Internal/external video synchronization
    - Color subcarrier generation with line, field and pixel phase lock
    - Compatible with MC1377 color encoder
    - Videotex (VTX)/Teletext (TTX) graphics
    $-256 \times 210 \times 4$ bit-mapped video image buffer
    - Programmable border color
    - Transparent video overlay signal
    - Fast XCDP and Y CDP nibble or byte graphics I/O
    - NAPLPS $X-Y$ origin with smooth $Y$ vertical scroll
    - Fast horizontal drawing support with $X$ auto increment byte write
    - Dynamic RAM interface
    - Direct 48k-byte DRAM support, with auto inherent refresh for interfacing to six $16 \mathrm{k} \times 4$ DRAMS (4416-150 ns)
    - Supports three methods of DRAM access:
    - Video refresh 26.9k-byte DRAM—port or address mapped
    - Teletext/program 5.9k-byte DRAM—port or address mapped
    - Optional program 16k-byte DRAM extension-address mapped
    - Interleaving of MPU and CVDG DRAM access for uninterrupted read/write memory access without memory contention
    - On-chip refresh timing and control
    - MPU Interface
    - Direct timing and cycle stealing for $1.4 \mathrm{MHz} 68 \mathrm{A09E}$ MPU
    - Direct interface to R6512 CPU
    - Teletext support
    - DMA interface and handshake to external NABTS teletext prefix processor
    -5.72 Mbps effective data rate
    - 8k-byte teletext buffer DRAM interface

    ORDERING INFORMATION

    | Part Number | Temperature Range |
    | :---: | :---: |
    | R6549_ | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
    | Package: $\mathrm{P}=$ Plastic |  |

    

    Figure 1. R6549 CVDG Interface Signals

    ## PIN DESCRIPTION

    Throughout this document signals are described logically using the terms active (or asserted) representing the true state, or inactive (or negated) representing the false state, regardless of whether the signal is active at a high or low voltage level.

    The R6549 CVDG signals can be categorized into several different functional interfaces: MPU control and address bus, address/data (A/D) bus, DRAM control, color video output, teletext prefix processor and system clock input. Figure 1 identifies the signals within each group.

    ## DMAC INTERFACE

    TTXREQ-Teletext DMA Request. An asynchronous falling edge-triggered request for direct memory access (DMA) transfer of data from a teletext prefix processor connected to the address/data (A/D) bus to DRAM. This TTL compatible input
    causes the CVDG to stop generating the E and Q clocks for one A/D bus cycle, output a 13 -bit address ( $A 0-A 12$ ) to the DRAM during the processor portion of the $A / D$ bus cycle, assert the $\overline{T T X O E}$ signal, and assert the $\bar{W}$ output to enable writing the data into DRAM.

    TTXOE-Teletext DMA Output Enable. An active LOW TTL compatible output pulse asserted within one A/D bus cycle after TTXREQ is asserted to acknowledge TTXREQ receipt and to enable data transfer from the teletext prefix processor onto the A/D bus (AD0 - AD7).

    ## MPU CONTROL AND ADDRESS BUS

    E-E Clock. A TTL compatible 1.43 MHz output clock that synchronizes data transfers over the MPU bus. This output drives the E clock input to the 6809E MPU. The E clock has special $\mathrm{V}_{\mathrm{OH}}$ and $\mathrm{V}_{\mathrm{OL}}$ output levels, $\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{SS}}+0.3 \mathrm{~V}$, respectively.

    Q-Q Clock. A TTL compatible 1.43 MHz output clock that leads the E clock output for use by the 6809 E .

    R/W-Read/Write. The TTL compatible Read/Write input controls the direction of data transfer between the MPU and the CVDG (HIGH = read from the CVDG; LOW = write to the CVDG). The R $\bar{W}$ line should be connected to external data bus transceivers to also control the data direction between the MPU bus and the A/D bus.

    A0, A1-MPU Address Line AO and A1 Inputs. When $\overline{O C S}$ is active, the encoded $A 0$ and $A 1$ inputs select the register in the CVDG to be accessed during a read or write operation (see Table 1). An exception is when AO and A1 are both high during Mode 0 , in which case DRAM is CDP accessed directly by the MPU at addresses generated by the CVDG.

    When $\overline{\text { DRCS }}$ is active and program DRAM is selected ( $P=1$ in the DRAM Page Register), AO is passed through the CVDG to drive the AD6 output during DRAM column address generation in the processor portion of the A/D bus cycle (see MPU DRAM Access Description).

    A13-MPU Address Line A13 Input. When $\overline{\mathrm{DRCS}}$ is active, A 13 input HIGH causes program DRAM to be accessed (CASP asserted) during the processor portion of the A/D bus cycle independent of the P bit value in the DRAM Page Register. When program DRAM is selected in the DRAM Page Register $(P=1)$ or when $A 13=1, A 13$ is passed through the CVDG to drive the AD5 output during DRAM column address generation in the processor portion of the AID bus cycle (see MPU DRAM Access Description).
    $\overline{\text { OCS }}-1 / O$ Chip Select. The active LOW, TTL compatible, IOCS input selects CVDG I/O port operation. The CVDG internal registers addressed by the AO and A1 inputs are accessed as enabled by the mode selected in the Mode Register. Data direction is controlled by the R/ $\bar{W}$ input as appropriate for each register and mode.

    Table 1. CVDG Register Select Logic ( $\overline{\mathbf{1 O C S}}=$ LOW $)$

    | A1 | AO | Mode | Read (R/ $\bar{W}=H$ ) | Write (R/ $\overline{\mathbf{W}}=\mathrm{L})$ |
    | :---: | :---: | :---: | :--- | :--- |
    | L | L | - | Status Register | Mode Register |
    | L | H | 0 | X CDP Register | X CDP Register |
    | H | L | 0 | Y CDP Register | Y CDP Register |
    | H | H | 0 | DRAM $^{2}$ | DRAM |
    | H | H | 1 | - | LUT Address Register |
    | H | H | 2 | LUT3 | LUT Data Register |
    | H | H | 3 | - | Switch Register |
    | H | H | 4 | - | Y Scroll Register |
    | H | L | 5 | TTX Pointer Register | TTX Pointer Register |
    | H | H | 6 | - | DRAM Page Register |

    Notes:

    1. The mode is selected in Mode Register.
    2. DRAM is accessed directly by the MPU at DRAM addresses determined by the CVDG X CDP and Y CDP register contents.
    3. The LUT is accessed as enabled and addressed in the LUT Address Register

    DRCS-DRAM Chip Select. $\overline{\text { DRCS }}$ is a TTL compatible, active LOW, input that enables MPU access to the DRAM. CTIME, $\overline{\text { RTIME }}$ and $\overline{\text { DTIME outputs are asserted by the CVDG at the }}$ proper times to enable external buffers which drive the MPU generated address onto the A/D bus and drive data between the MPU bus data lines and the A/D bus in the direction controlled by R $\bar{W}$ (HIGH = read from DRAM; LOW = write to DRAM). Note that DRCS configurations are advanced and optional for many configurations.

    ## ADDRESS/DATA BUS

    ADO-AD7-Address/Data Lines. Eight TTL compatible, bidirectional, multiplexed address/data lines (ADO - AD7) interface the CVDG directly to the video/program DRAM, through external buffers to the MPU address bus (A1-A12), and through external transceivers to the MPU data bus (D0 - D7). These lines transfer both address and data between the DRAM and the CVDG and between the MPU bus and the CVDG/DRAM during one 698 ns A/D bus cycle.

    RASL, $\overline{\text { RASH }}$-Row Address Strobe Low and High. TTL compatible outputs strobe the upper eight bits of the address on A/D bus lines AD0-AD7 into DRAM (as DRAM addresses A6-A13) on the falling edge. RASL strobes the address into the DRAM containing the lower four data bits (DO-D3) and $\overline{\text { RASH }}$ strobes the address into the DRAM containing the upper four data bits (D4-D7).

    CAS1, CAS2, $\overline{\text { CASP-Column Address Strobes 1, } 2 \text { and P. }}$ The TTL compatible CAS outputs strobe the six lower bits of the address on A/D bus lines (AD1-AD6) into DRAM (as DRAM addresses A0-A5) on the falling edge. CAS1 and CAS2 connect to the video DRAM containing the LUT addresses. Four 4-bit LUT addresses packed into two bytes are accessed during the video portion of each A/D bus cycle. CAS1 strobes the DRAM containing the LUT addresses for the first two pixel positions while CAS2 strobes the DRAM devices containing the LUT addresses for the second two pixel positions. $\overline{\text { CASP }}$ connects to the program DRAM containing the program instructions/data.
    $\overline{\mathrm{OE}}, \overline{\mathrm{OE}}$-DRAM Output Enable. These active LOW, TTL compatible, outputs enable DRAM device data output lines during a read. $\overline{\mathrm{OE}}$ connects to the two video DRAM devices containing byte 1 (LUT addresses for pixels 1 and 2) and is asserted first during a video refresh cycle. $\overline{\mathrm{OE} 2}$ connects to the two DRAM devices containing byte 2 (LUT addresses for pixels 3 and 4) and is asserted following $\overline{O E 1}$. $\overline{O E 2}$ is also connected to the program DRAM devices and enables their data outputs during the processor portion of the A/D bus cycle.
    $\bar{W}$-DRAM Write Enable. The TTL compatible, active LOW, $\bar{W}$ output strobes data from the A/D bus into DRAM during a write in the processor portion of the A/D bus cycle. $\bar{W}$ is held HIGH during a read from DRAM.

    RTIME-Row Address Time. The active LOW, TTL compatible, RTIME output enables DRAM row address lines from the MPU onto the A/D bus through external buffers when DRCS is active. (Required for DRCS configurations only.)

    CTIME-Column Address Time. The active LOW, TTL compatible, CTIME output enables DRAM column address lines from the MPU onto the A/D bus through external buffers when $\overline{\text { DRCS }}$ is active. (Required for $\overline{\text { DRCS }}$ configurations only.)
     output enables data transfer between the MPU data bus and the A/D bus through external transceivers when DRCS or $\overline{\text { IOCS }}$ is active.

    ## SYSTEM CLOCK

    SYSCLK-System Clock. A clock input with a duty cycle of $40 / 60$ to $50 / 50$. The clock frequency should be 28.63636 MHz $\pm 80 \mathrm{~Hz}$ for proper operation of the colorburst frequency. This input clock may be stopped in either state for up to $1 \mu \mathrm{~s}$ to allow for external digital phase lock techniques.

    ## VIDEO/COLOR OUTPUTS

    CSUBC-Color Subcarrier Clock Output. A TTL compatible $3.579545 \mathrm{MHz} \pm 10 \%$ color subcarrier clock. The clock rate complies with the North American Color Burst Clock Output Standard. The rate is the SYSCLK divided by eight and is phase keyed to the horizontal sync ( $\overline{\mathrm{HSYNC}}$ ) output on C/HSYNC (as either a component of CSYNC or pure HSYNC). Vertical blanking interval (VBI) color gating by VSYNC must be done externally (since some modems require an uninterrupted 3.579 MHz clock).

    When the color outputs are connected to an MC1377 color encoder, the CSUBC output can be connected to the MC1377 CLK input, typically through a 500 pF capacitor $/ 150 \mu \mathrm{H}$ inductor filter network.

    C/HSYNC-Composite/Horizontal Sync Output. Either a composite sync ( $\overline{\mathrm{CSYNC}}$ ) or a horizontal sync ( $\overline{\mathrm{HSYNC}}$ ) output at TTL levels, asserted "tips down", is selected by the External Sync (EXT) bit in the Switch Register.

    In internal sync (EXT = 0), an RS-170 composite sync with full serration and equalization is output in either 2:1 or 1:1 interlace as selected by the 2:1 Interlace Select (S21) bit in the Switch Register (S21 = 1 for 2:1; S21 = 0 for 1:1).

    In external sync (EXT $=1$ ), a pure $\overline{\text { HSYNC }}$ is output in either normal or early timing as selected by the Normal Horizontal Sync (NHS) bit in the Switch Register. In normal timing (NHS = 1), a 15.7 kHz signal is output; in advance timing ( $\mathrm{NHS}=0$ ), a 15.9 kHz stop clock signal is output.

    When the color outputs are connected to an MC1377 color encoder, the C/HSYNC output can be connected directly to the MC1377 SYNC input pin.
    $\overline{\text { VSYNC-Vertical Sync Input/Output. A TTL compa:ible }}$ vertical sync ( $\overline{\mathrm{VSYNC}}$ ) input or output signal depending on the state of the External Sync (EXT) bit in the Switch Register (see Mode 3). VSYNC is an externally generated input at power up or when EXT $=1$. $\overline{\text { VSYNC }}$ is an internally generated output when $E X T=0$.

    The VSYNC output can be used to disable the color subcarrier at the chroma modulator during VBI. Videotex decoders can also use VSYNC to interrupt the MPU at a 60 Hz rate for blink, task and timekeeping operations.

    PIXCLK-Pixel Clock Output. A 5.7272 MHz pixel output clock running synchronously with the RGB color outputs.

    R, G, B-Red, Green and Blue Color Outputs. Three separate color analog output voltages. Each output provides a 1.0 Vpp video signal at high impedance with a 1.8 Vdc offset. Each color level is controlled by a 4-bit color code accessed from the LUT for each pixel position. A digital-to-analog converter (DAC) converts the 4 -bit code to one of 16 output voltage levels (black level $=1.875 \mathrm{Vdc}$; white level $=2.800 \mathrm{Vdc}$ ). The three outputs allow 4096 color level combinations. A composite blanking signal $(1.800 \mathrm{Vdc})$ is included in each output.

    The output signals include high frequency clock components which may require low pass filtering in some applications. The outputs can be connected to the RIN, G IN, and B IN inputs to a MC1377 color encoder through $15 \mu \mathrm{~F}$ (typical) AC coupling capacitors.

    The color outputs, through external buffers, can also drive 75 ohm loads, e.g., the inputs to an RGB color monitor/TV.

    XPAR-Transparent Output. A TTL compatible, active HIGH, output controlled by one bit in a 4-bit code (three bits are don't care) in the LUT. A LUT value of 1XXX in DRAM asserts XPAR (HIGH); LUT value of OXXX in DRAM negates XPAR (LOW). This output can be used to indicate which video source to select. When XPAR output is HIGH, external video signals should be selected to display background video; when XPAR output is LOW, CVDG outputs should be selected to display graphics. The XPAR output is always HIGH during composite blanking to pass external vertical blanking interval (VBI) signals, external sync, color burst, etc.

    ## POWER/GROUND

    VCC-Primary Power. 5.0 Vdc.
    VSS-Ground. Power and signal ground.

    ## FUNCTIONAL DESCRIPTION

    The R6549 CVDG operation is controlled by three free-running synchronous state machines with the following cycle rates:

    $$
    \begin{array}{ll}
    \text { Address/Data (A/D) Bus Cycle } & 698 \mathrm{~ns} / \text { cycle }(1.43 \mathrm{MHz}) \\
    \text { Horizontal Raster Line Cycle } & 63.5 \mathrm{\mu s} / \text { cycle }(15.74 \mathrm{kHz})^{*} \\
    \text { Vertical Raster Frame Cycle } & 33.3 \mathrm{~ms} / \mathrm{cycle}(30 \mathrm{~Hz})
    \end{array}
    $$

    The CVDG also includes timing shift registers and sample flipflops to generate internal and external timing signals; programmed logic arrays (PLAs) to perform I/O decoding, generate DRAM control signals and determine state machine outputs; registers to hold command/status and data; an internal 16-bit row/column bus in display X-Y coordinates; internal input and output 8 -bit data busses; and input/output buffers to isolate internal circuits from external interfaces and to drive outputs. Figure 2 illustrates the main CVDG components.


    

    ## R6549

    ## SYSTEM TIMING

    ## System Clock

    Internal and output timing signals are derived from the 28.636363 MHz crystal frequency on the SYSCLK input pin. A two-phase non-overlapping 14.318181 MHz (SYSCLK/2) clock is generated to sequence high speed data transfer within the CVDG.

    ## Timing Shift Register

    The Timing Shift Register generates internal timing pulses as internal timing references at frequencies from 14.318 MHz down to 13.98 kHz . Flip-flops sample the various timing pulses to generate derivative timing reference signals for use by other CVDG circuits.

    A two-phase non-overlapping 1.431818 MHz (SYSCLK/20) clock is generated for low speed sequencing within the CVDG and is also the external microprocessor bus and A/D bus timing reference. One phase of the 1.43 MHz clock drives the E clock output pin. A quadrature 1.431818 MHz clock leading the E clock is output on the $Q$ output pin.

    ## Pixel Clock

    A 5.72 MHz pixel clock is output on the PIXCK output pin. Four pixel output clocks occur each 698 ns (one clock pulse coincident with each of the red, green and blue color level outputs and the transparent bit output for each pixel location).

    ## VIDEO RASTER CONTROL

    ## Horizontal Raster Line Cycle

    An internal horizontal state machine (HSM) controls the horizontal raster line cycle. The HSM is incremented at the E clock rate, nominally every 698 ns . When normal horizontal sync timing is selected in the Switch Register ( $\mathrm{NHS}=1$ ), 91 horizontal counts (HSO - HS90), or states, comprise the $63.56 \mu \mathrm{~s}$ line raster. When early horizontal sync timing is selected (NHS $=0$ ), typically to support external synchronization, 90 horizontal counts (HSO - HS89) provide a $62.86 \mu$ s line raster. The first 64 counts clock the 256 displayed pixels (at four pixels per count). Figure 3 illustrates the horizontal and vertical raster count reference.

    The HSM generates the horizontal raster timing pulses for internal logic and/or external output. These signals are the horizontal sync (ㅆSYNC), horizontal border and blanking, horizontal blanking, serration and equalization timing pulses.

    The horizontal border and blanking pulse identifies the time that a border color is output (see LUT Data Register description) outside of the 256 pixel locations except during actual horizontal blanking. This signal is reported in bit $6(\overline{\mathrm{HB}})$ of the Status Register.

    An increment vertical count signal is also generated to increment the vertical state machine.

    ## Vertical Raster Frame Cycle

    An internal vertical state machine (VSM) controls the 33.3 ms vertical raster frame cycle. The VSM is incremented twice each horizontal raster line cycle. The VSM count (VSO - VS523 or VSO - VS524), or state, supports two frames per 30 ms vertical raster cycle. The upper count depends on the interlace mode (S21) switch position selected in the Switch Register. When 2:1 interlace mode is selected ( $\mathrm{S} 21=1$ ), the upper VSM count supports a $2621 / 2$ line frame. When $1: 1$ interlace is selected ( $\mathrm{S} 21=0$ ), the upper VSM count supports a 262 line frame.

    A VSM clear sign is normally generated when the VSM upper count is reached to restart the VSM at 0 ; however, when external sync is selected (EXT $=1$ ) the VSM clear signal is generated from the external sync signal input on the VSYNC pin. Internal vertical state timing signals are generated for internal logic and/or external output. These signals include vertical sync ( $\overline{\mathrm{VSYNC}}$ ), vertical border and blanking, vertical blanking, and equalization enable pulses and the load $Y$ scroll pointer time.

    An internal vertical sync pulse, a vertical blanking pulse, and an equalization pulse are generated for combining with the HSYNC serration and equalization pulses when internal sync is selected $(E X T=0)$ to output composite sync on the $\overline{C / H S Y N C}$ pin.

    The vertical blanking pulse is also buffered and output on the VSYNC pin when' internal sync is selected in the Switch Register ( $E X T=0$ ).

    The internal vertical border and blanking pulse is generated and reported in bit $7(\overline{\mathrm{VB}})$ of the Status Register. The pulse width is 3.302 ms for $2: 1$ interlace ( $\mathrm{S} 21=1$ ) or 3.333 ms for $1: 1$ interlace ( $\mathrm{S} 21=0$ ). This duration identifies the time the border color determined from the LUT Data Register is output, except during actual vertical blanking.

    An internal load $Y$ offset pointer signal is generated and routed to the $Y$ Scroll Counter to cause the $Y$ offset to load during the non-visible portion of the display raster.

    ## Composite Sync and Color Subcarrier Clock Generation

    HSYNC is output in one of two forms on the C/HSYNC pin depending upon the EXT bit state in the Switch Register. If internal sync is selected ( $E X T=0$ ), $\overline{\text { HSYNC }}$ is combined with horizontal blanking serration, equalization and vertical sync ( $\overline{\mathrm{VSYNC}}$ ) pulses to output as composite sync ( $\overline{\text { CSYNC }}$ ). If external sync is selected (EXT = 1), the HSYNC signal is output on C/HSYNC.

    A 3.58 MHz color subcarrier clock (SYSCLK/8 and phase keyed to horizontal sync) is generated from composite sync and horizontal sync signals then is output on the CSUBC pin.
    

    Figure 3. CVDG Video Raster Count Reference

    ## ADDRESS/DATA BUS CONTROL

    The Address/Data Bus state machine controls the operation of the 698 ns A/D bus cycle. The A/D bus cycle contains a 2-byte video data access cycle and a 1-byte I/O data access cycle (Figure 4). The addresses and data transferred on the A/D bus depend on the phase of the AND bus cycle (i.e., the E clock level) and the type of operation in the I/O data access cycle. Table 2 identifies the source of the addresses for each type of DRAM access.

    ## Video Data Access Cycle

    The video data access cycle (also referred to as the video portion of the A/D bus cycle) occurs during the first half of the A/D bus cycle (when the E clock is LOW). Two bytes of video data (containing four LUT addresses corresponding to four pixel locations on the display) are read each cycle from DRAM at the DRAM address generated by the CVDG. The DRAM address is generated corresponding to the first of four pixel column locations in the horizontal raster and the pixel row location in the vertical raster. The video column $(X)$ address of 0 to 64 is controlled by the horizontal state machine. The video row $(Y)$ address of 209 to 0 is controlled by the $Y$ Address Counter, which is in turn controlled by the vertical state machine and the Y Scroll Register. The two data bytes are loaded into the CVDG Video Data Register for subsequent serialization and LUT access (see the Pixel Color Generation description).

    Up to 48k-bytes of Dynamic RAM (DRAM) can be connected to the AVD bus to store video data (LUT addresses) for video refresh, program instructions/data and received teletext data. The DRAM is segmented into six $8 k$-byte blocks with page selection of one block at a time during access (Figure 5). Four pages are required for video refresh (V00 - V11); three pages (V00, V01 and V10) hold video data exclusively, and one page (V11) holds video and program/teletext data. Two other pages hold program data. During the video data access cycle, and some modes of the I/O data access cycle, paging is handled automatically by the CVDG. The $A 13$ and A0 input lines and the P, V1 and VO bits in the CVDG DRAM Page Register select the page for MPU DRAM access during the I/O data access cycle (see MPU DRAM Access description).

    ## I/O Data Access Cycle

    The I/O data access cycle (also referred to as the processor portion of the A/D bus cycle) occurs during the second half of the A/D bus cycle (when E clock is HIGH). A/D bus address source and data source/destination depends upon CVDG chip select ( $\overline{\mathrm{OCS}}$ and $\overline{\mathrm{DRCS}}$ ) and Teletext Request (TTXREQ) input levels, the selected CVDG mode, and the register select (AO and A1) input levels. Refer to the description of each I/O access cycle function for details.

    ## A/D Bus Control Line Buffers and Logic

    The A/D Bus Control Line Buffers and Logic condition input and output A/D Bus control signals. Six input signals (R $\bar{W}, A 0, A 1$, $A 13, \overline{1 O C S}$ and $\overline{D R C S})$ are buffered and routed to the DRAM Control PLA.

    The E and Q output clocks are suppressed during a teletext DMA transfer. When TTXRE $\bar{Q}$ input goes LOW, the Q and E clock outputs are held LOW to disable the clocks for one MPU bus cycle. In addition, the increment TTX address count goes HIGH to increment the modulo 32 TTX Counter. When TTXREQ goes HIGH at the completion of the DMA data transfer, the E and Q output clocks are enabled, the $\overline{\mathrm{TTXOE}}$ output is negated (reset HIGH), and the increment TTX address count signal is reset.

    Internal reset and initialization signals are generated when both $\overline{\mathrm{IOCS}}$ and $\overline{\mathrm{DRCS}}$ inputs are LOW for test purposes.

    ## A/D Bus Control PLA

    The A/D Bus Control PLA decodes CVDG and A/D Bus operation commands from buffered A/D bus control input signals and encoded mode bits in the Mode Register. Outputs from the PLA are buffered and routed to other circuits in the CVDG as internal enable signals.

    ## A/D Bus Input/Output Buffers

    The A/D Bus Input/Output Buffers isolate the internal CVDG data bus lines from the external ADD bus lines (ADO - AD7). Input buffers continuously copy AD0 - AD7 onto the internal input data bus. Output buffers drive the states of the internal output data bus lines onto ADO - AD7 when enabled by a CVDG output function and clocked by the 14.3 MHz internal clock. Two of these output buffers drive AD5 and AD6 during MPU DRAM access ( $\overline{\mathrm{DRCS}}=\mathrm{L}$ ) with the DRAM page signals, i.e., VO and V1, respectively, or A13 and A0 inputs, respectively, depending on the state of the A13 input and the $P$ bit in the DRAM Page Register.

    ## A/D Bus Output Control Logic

    The AID Bus Output Control Logic drives data onto the internal output bus from the internal row and column bus lines, from the LUT, and from other internal CVDG circuits when enabled by outputs from the A/D Bus Control PLA.

    ## DRAM Control PLA and Buffers

    The DRAM Control PLA and Buffers generate and drive control and timing output signals to the DRAM; the row, column and data time output control signals for use by external line buffers and data line transceivers; and internal signals to control input/output data direction and to enable the internal row and column bus.

    Timing pulses from the Timing Shift Registers; control signals from the Mode and Page registers, A/D Bus Control Buffers and Logic, and A/D Bus Control PLA; and control signals generated and derived from other sections of the CVDG are input to the PLA.

    Output control states from the PLA are buffered and routed to external DRAM control signal pins ( $\overline{\mathrm{RASL}}, \overline{\mathrm{RASH}}, \overline{\mathrm{CAS}}, \overline{\mathrm{CAS} 2}$, $\overline{\mathrm{CASP}}, \overline{\mathrm{OE}}, \overline{\mathrm{OE} 2}$, and $\bar{W})$ and to external $A / D$ bus control signal pins ( $\overline{\mathrm{CTIME}}, \overline{\mathrm{RTIME}}$ and $\overline{\mathrm{DTIME}})$. Other output signals are inverted and routed to internal logic.
    

    Figure 4. DRAM Address/Data (A/D) Bus Cycle

    Table 2. Address/Data Bus Address Sources

    | DRAM Row/Column | - | CA5 | CA4 | CA3 | CA2 | CA1 | CAO | - | RA7 | RA6 | RA5 | RA4 | RA3 | RA2 | RA1 | RAO |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    | CVDG Display Row/Column Bus | C7 | C6 | C5 | C4 | C3 | C2 | C1 | C0 | R7 | R6 | R5 | R4 | R3 | R2 | R1 | RO |
    | A/D Bus | AD7 | AD6 | AD5 | AD4 | AD3 | AD2 | AD1 | ADO | AD7 | AD6 | AD5 | AD4 | AD3 | AD2 | AD1 | ADO |
    | Video Cycle ${ }^{1}$ | 0 | V7 | V6 | V5 | V4 | V3 | V2 | 0 | V1 | V0 | H6 | H5 | H4 | H3 | H2 | H1 |
    | Processor Cycle <br> CDP Graphics ${ }^{2}$ $(\overline{\mathrm{IOCS}}=\mathrm{L}, \text { Mode } 0)$ | $X 1^{3}$ | Y7 | Y6 | Y5 | Y4 | Y3 | Y2 | X04 | Y1 | YO | X7 | X6 | X5 | X4 | X3 | X2 |
    | MPU Video DRAM Access ${ }^{5}$ $(\overline{\mathrm{DRCS}}=\mathrm{L}, \mathrm{P}=0)$ | $A 0^{6}$ | $V_{17}{ }^{7}$ | V02 | A12 | A11 | A10 | A9 | 0 | A8 | A7 | A6 | A5 | A4 | A3 | A2 | A1 |
    | MPU Program DRAM Access ${ }^{8}$ $(\overline{\mathrm{DRCS}}=\mathrm{L}, \mathrm{P}=1)$ | 0 | $A^{\prime}{ }^{9}$ | A139 | A12 | A11 | A10 | A9 | 0 | A8 | A7 | A6 | A5 | A4 | A3 | A2 | A1 |
    | Teletext DMA Access ${ }^{10}$ $(\overline{\text { TTXREQ }}=\mathrm{L})$ | TO | 111 | 111 | T12 | T11 | T10 | T9 | 0 | T8 | T7 | T6 | T5 | T4 | T3 | T2 | T1 |

    ## Notes:

    1. Video Cycle:

    H1 - H6 = HSM Output = 0 to $64(=0$ to 255 pixel LUT addresses @ 4 addresses per access $)$;
    V0-V7 $=\mathrm{Y}$ Scroll Counter Output $=209$ to 0
    2. CDP Graphics:
    $X 0-X 7=X$ CDP Register/Counter contents $=0$ to 255;
    $\mathrm{YO}-\mathrm{Y} 7=\mathrm{Y}$ CDP Register contents $=0$ to 255 ( 0 to 209 for displayable data)
    3. X 1 controls the $\overline{\mathrm{CAS} 1}$ and $\overline{\mathrm{CAS} 2}$ outputs:
    $0=$ Assert CAS1
    $1=$ Assert CAS2
    4. X0 controls the $\overline{\text { RASL }}$ and $\overline{\text { RASH }}$ outputs:
    $0=$ Assert $\overline{\text { RASL }}$
    $1=$ Assert $\overline{\text { RASH }}$
    5. MPU Video DRAM Access: $A 0-A 12=$ MPU Address $=0$ to 4096.
    6. A0 input controls the $\overline{\mathrm{CAS} 1}$ and $\overline{\mathrm{CAS2}}$ outputs:
    $L=$ Assert $\overline{\text { CAS1 }}$
    $H=$ Assert CAS2
    7. V0 and V1 bits in the DRAM Page Register control assertion of AD6 and AD5 outputs, respectively:
    $0=$ Negate output
    $1=$ Assert output
    8. MPU Program DRAM Access: $A 0-A 13=$ MPU Address $=0$ to 8192
    9. A0 and A13 inputs control the AD6 and AD5 outputs, respectively:
    $L=$ Negate output
    $H=$ Assert output
    10. Teletext Access:

    T1-T4 $=$ Modulo 32 counter incremented by each DMA byte transfer
    T5-T12 = Teletext Pointer Register contents incremented by T1-T4 overfiow
    11. AD6 and AD5 asserted to select program DRAM.
    

    ## Notes:

    1. 26,880 bytes of video memory are required to support video refresh, i.e., to supply 53,7604 -bit LUT addresses in support of the $210 \times 256$ pixel display area. With 32,768 bytes supplied in four 4416 DRAM devices, 5888 bytes are available for general program/TTX message use in the upper part of video memory page 3 (V11).
    2. Nibbles shown correspond to beginning and ending data for $210 \times 256$ pixel display area in $X$ (column), $Y($ row $)$ coordinates.

    Figure 5. DRAM Memory Map

    ## PIXEL COLOR GENERATION

    ## LUT Address Generation

    The 16 -bit Video Data Register latches the four LUT addresses contained in the two data bytes acquired during the video data access cycle. Two 4-bit color lookup table (LUT) addresses are packed into each byte. The Video Shift Register serializes the four LUT addresses and transfers them one byte at a time to the LUT Address Generator. The LUT Address Generator latches the 4-bit coded LUT addresses from the Video Shift Register, converts the coded address to 16 binary signals and latches the binary address $(0-15)$ for routing to the LUT.

    ## LUT Operation

    The color look-up table (LUT) is a $16 \times 13$ bit memory holding 16 entries of $R, G$ and $B$ color codes and corresponding trans-
    parent state (see Table 3). Each entry holds three 4-bit encoded color levels ( $0000=$ lowest voltage level, $1111=$ highest voltage level) and a 1-bit transparent state ( $0=0$ ff, $1=0$ ) . For each pixel location the three color level codes (R, G and B) are sampled from the LUT, latched and routed through three separate digital-to-analog converters. The transparent bit corresponding to each pixel location is also accessed from the LUT, latched, buffered and output on the XPAR pin.

    ## Digital-To-Analog Conversion (DACs)

    The 4-bit color code for each color ( $\mathrm{R}, \mathrm{G}$ and B ) at a pixel position is converted to a corresponding analog voltage through a 16 -level digital-to-analog converter (DAC). Four lines from the four color code lines and their four complements are decoded to one of 16 levels, sampled and latched. The latched outputs are in turn connected to the color output pin ( $\mathrm{R}, \mathrm{G}$ and B ) through a voltage divider ladder network.

    Table 3. LUT Structure
    

    ## I/O DATA ACCESS CYCLE FUNCTIONS

    The I/O access cycle operates in one of five ways:

    1. CVDG Mode/Status Register Access (enabled by $\overline{\mathrm{OCS}}$ LOW)
    2. CVDG Graphics Access (enabled by $\overline{\mathrm{OCS}}$ LOW)
    3. CVDG Parameter I/O Access (enabled by $\overline{\text { IOCS }}$ LOW)
    4. MPU DRAM I/O Access (enabled by $\overline{\text { DRCS }}$ LOW)
    5. Teletext Byte DMA (enabled by TTXREQ LOW)

    The basic type of I/O access cycle is determined by the chip select ( $\overline{\mathrm{IOCS}}$ or $\overline{\mathrm{DRCS}}$ ) and Teletext Request ( $\overline{\mathrm{TTXREQ}}$ ) inputs. When neither of the chip select inputs are LOW, nor has a TTX DMA transfer been initiated by TTXREQ LOW, the I/O access cycle is idle with no data transfer occurring during the processor portion of the A/D bus cycle.

    When $\overline{\mathrm{OCS}}$ is LOW, the register address inputs ( AO and A 1 ) and the mode selected in the CVDG Mode Register define the specific CVDG I/O operation, i.e., Mode/Status Register Access, CVDG Graphics Access (Mode 0 ), or one of the six CVDG Parameter Access modes (Modes 1-6). Table 4 shows the CVDG registers accessible during the I/O access cycle and the bit assignments. When A1 and AO are both HIGH, the register bits are defined with reference to a pseudo Data Register (DR). The actual internal CVDG register accessed depends on the selected mode (see Table 4). The bits are defined in the following text.

    ## CVDG Mode/Status Register Access

    When $\overline{\mathrm{OCS}}$ is LOW and the register address is zero (AO and A1 inputs are both LOW), the Mode Register (MR) or the Status Register (SR) is accessed depending upon the $\mathrm{R} / \overline{\mathrm{W}}$ input level. When $\mathrm{R} \bar{W}$ is LOW, the Mode Register is written; when $\mathrm{R} \overline{\mathrm{W}}$ is HIGH, the Status Register is read.

    Table 4. CVDG Register Summary

    | Internal CVDG Register | Mode | Register Select Lines |  | R/W ${ }^{4}$ | Register Bit No. |  |  |  |  |  |  |  | Reset ${ }^{3}$ |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    |  |  | A1 | AO |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
    | Mode Register | - | 0 | 0 | W | - | - | - | - | S | M2 | M1 | MO | OF |
    | Status Register | - | 0 | 0 | R | $\overline{\mathrm{VB}}$ | $\overline{H B}$ | M2 | M1 | MO | P | V1 | V0 | - - |
    | X CDP Register | 0 | 0 | 1 | R/W | X7 | X6 | X5 | X4 | X3 | X2 | X 1 | X0 | 00 |
    | Y CDP Register | 0 | 1 | 0 | R/W | Y7 | Y6 | Y5 | Y4 | Y3 | Y2 | Y1 | YO | 00 |
    | DRAM ${ }^{1}$ | 0 | 1 | 1 | R/W | P3 | P2 | P1 | PO | Q3 | Q2 | Q1 | Q0 | -- |
    | LUT Address Register | 1 | 1 | 1 | W | XPE | RE | GE | BE | A3 | A2 | A1 | AO | 00 |
    | LUT ${ }^{2}$ | 2 | 1 | 1 | R | - | - | - | - | D3 | D2 | D1 | D0 | - - |
    | LUT Data Register | 2 | 1 | 1 | W | - | - | - | - | D3 | D2 | D1 | D0 | - - |
    | Switch Register | 3 | 1 | 1 | W | NHS | S21 | EXT | LS | TST | - | - | - | F8 |
    | Y Scroll Register | 4 | 1 | 1 | W | Y7 | Y6 | Y5 | Y4 | Y3 | Y2 | Y1 | Y0 | 00 |
    | TTX Pointer Register | 5 | 1 | 0 | RNW | A12 | A11 | A10 | A9 | A8 | A7 | A6 | A5 | 00 |
    | DRAM Page Register | 6 | 1 | 1 | W | - | - | - | - | - | $P$ | V1 | V0 | 07 |
    | Notes: <br> 1. The DRAM is directly accessed and not the CVDG. <br> 2. Data is transferred from the LUT onto the AID bus without going through the LUT Data Register. <br> 3. Reset state upon power up. <br> 4. $R / W=$ Read/write $(R=$ read only; $W=$ write only; $R / W=$ read or write $)$. |  |  |  |  |  |  |  |  |  |  |  |  |  |

    ## Mode Register

    The write-only Mode Register selects the CVDG mode for next read from, or write to, the CVDG. In addition, the Mode Register contains a submode flag applicable only to Mode 0 . The Mode Register may be written at any time regardless of the current CVDG mode. The mode and submode bits are initialized to ones upon power up.

    |  |  |  |  |  |  |  |  |  |  |  |  |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    | Register | A1 | AO | R/W | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
    | Mode | 0 | 0 | W | - | - | - | - | S | M 2 | M 1 | M 0 |

    ## MR7-MR4 Not used (no effect)

    ## MR3 CDP Submode Flag (S) - (Mode 0 only-see Mode 0 description)

    0 Enable CDP Nibble Submode. Allows read/write of a single 4-bit pixel nibble in a byte.
    1 Enable CDP Byte Submode. Allows read/write of two 4-bit pixel nibbles in a byte with automatic increment of the X CDP for faster storage of LUT addresses in DRAM.

    | MR2-MRO |  | (M0) | CVDG Mode (M2-M0) |
    | :---: | :---: | :---: | :---: |
    | (M2) | (M1) |  |  |
    | 0 | 0 | 0 | Mode 0 - Port CDP Graphics |
    | 0 | 0 | 1 | Mode 1 - LUT Address |
    | 0 | 1 | 0 | Mode 2 - LUT Data |
    | 0 | 1 | 1 | Mode 3 - Switch Register |
    | 1 | 0 | 0 | Mode 4 - Y Scroll Offset Register |
    | 1 | 0 | 1 | Mode 5 - Teletext DMA Pointer |
    | 1 | 1 | 0 | Mode 6 - Set DRAM Page |
    | 1 | 1 | 1 | Not used - no effect |

    Note that the mode must be written into the Mode Register before the desired mode can be executed.

    ## Status Register

    The read-only Status Register reports the selected CVDG mode, the selected DRAM page and the status of the horizontal and vertical raster blanking signals. The Status Register may be read at anytime regardless of the CVDG mode.

    The horizontal blanking $(\overline{\mathrm{HB}})$ and vertical blanking ( $(\overline{\mathrm{VB}})$ signals report the state of the video raster at the time of access. The states of these two signals can be used for 15 kHz poll-driven timing, vertical blanking interval (VBI) identification, LUT loading, etc. These blanking times reflect the non-pixel display time including the time actual horizontal and vertical blanking signals are generated (for inclusion in composite sync output).

    | Register | A1 | A0 | R/W | Bit Position |  |  |  |  |  |  |  |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    |  |  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
    | Status | 0 | 0 | R | $\overline{\mathrm{VB}}$ | $\overline{\mathrm{HB}}$ | M2 | M1 | MO | P | V1 | Vo |

    ## SR7 Vertical Blanking ( $\overline{\mathrm{VB}}$ )

    0 Vertical blanking is asserted.
    1 Vertical blanking is not asserted.

    ## SR6 Horizontal Blanking ( $\overline{\mathrm{HB}}$ )

    0 Horizontal blanking is asserted.
    1 Horizontal blanking is not asserted.

    ## SR5-SR3 Mode Selected (M2-M0)

    Reports the current CVDG mode as selected in bits 2-0 of the Mode Register.

    ```
    SR5 SR4 SR3
    ```

    (M2) (M1) (M0)

    | 0 | 0 | 0 | Mode 0- Port CDP Graphics |
    | :--- | :--- | :--- | :--- |
    | 0 | 0 | 1 | Mode 1-LUT Address |
    | 0 | 1 | 0 | Mode 2-LUT Data |
    | 0 | 1 | 1 | Mode 3- Switch Register |
    | 1 | 0 | 0 | Mode 4-Y Scroll Offset Register |
    | 1 | 0 | 1 | Mode 5- Teletext DMA Pointer |
    | 1 | 1 | 0 | Mode 6- DRAM Page |
    | 1 | 1 | 1 | Not used - no effect |

    ## SR2-SRO DRAM Page Selected (P, V1, V0)

    Reports the current DRAM Page selected in bits 2-0 of the Page Register (see Mode 6 - Write DRAM Page). $P$ is the program RAM page indicator. V0 and V1 are the video page indicators.

    | SR2 <br> (P) | SR1 <br> (V1) | SR0 <br> (V0) | Selected DRAM Page |
    | :---: | :---: | :---: | :--- |
    | 0 | 0 | 0 | Video Page 0: 8k-byte video RAM <br> 0 |
    | 0 |  | 1 | Video Page 1: 8k-byte video RAM |
    | 0 | 1 | 0 | Video Page 2: 8k-byte video RAM <br> 0 |
    | 1 | 1 | Video Page 3: 2.3k-byte video RAM; <br> 1 | 0 |

    ## Mode 0 - Port CDP Graphics

    When $\overline{O C S}$ is LOW and Mode 0 is selected in the Mode Register, the Port Current Drawing Pointer (CDP) Mode is active. In this mode display column and row addresses can be written to the CVDG Current Drawing Pointer (CDP) $X$ and $Y$ registers, respectively, and pixel data accessed in DRAM. This mode is primarily used to update LUT addresses (i.e., the CDPs) in the video pages of DRAM. These LUT addresses are the video data read from the DRAM by the CVDG during the video portion of the $A / D$ bus cycle.

    This mode can be used to write or read data in any of the four $8 k$-byte video pages of DRAM defined by the V0 and V1 bits in the CVDG DRAM Page Register. The first three pages (V00, V01 and V10) are used exclusively for video data. 2304 bytes (addresses 0-8FF) of the fourth page (V11) are used for video data while the rest of the DRAM can be used for program or teletext message storage.

    In mode 0, the MPU writes the address of the data in display coordinates into the CVDG X CDP and Y CDP registers. The $X$ CDP contains the pixel position in the horizontal axis (i.e., the display column number) and varies from 0 to 255 (hex FF). Each pixel data nibble corresponds to a location (0 to 15) in the color look-up table (LUT) from which the corresponding R, G and B color levels and transparent bit data are retrieved for color generation. The Y CDP contains the pixel position in the vertical axis (i.e., the display row number) and varies from 0 to 255 (hex FF). Only values of 0 to 209 are used by the CVDG during the video portion of the A/D bus cycle to access video data. Y addresses 210-255 identify DRAM address on video DRAM page V11 that can contain non-displayable data, i.e., program or teletext data.

    The registers accessible (besides in Mode and Status registers) in this mode are:

    | Register | A1 | AO | R/W | Bit Position |  |  |  |  |  |  |  |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    |  |  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
    | X CDP | 0 | 1 | R/W | X7 | X6 | X5 | X4 | X3 | X2 | X1 | x0 |
    | Y CDP | 1 | 0 | RNW | Y7 | Y6 | Y5 | Y4 | Y3 | Y2 | Y1 | Yo |
    | DRAM* | 1 | 1 | RW | P3 | P2 | P1 | PO | Q3 | Q2 | Q1 | 00 |
    | *Not CVDG Access |  |  |  |  |  |  |  |  |  |  |  |

    The X CDP Register is accessed at register address $1(\mathrm{~A} 1=0$ and $A O=1$ ) and the $Y$ CDP Register is accessed at register address $2(A 1=1$ and $A 0=0)$. When register address $3(A 1=1$ and $A O=1$ ) is detected, the CVDG generates DRAM row and column addresses corresponding to the display coordinates loaded in the X CDP and Y CDP registers. Data is then written from the A/D bus to the DRAM ( $\operatorname{R} \bar{W}=$ low) or read from the DRAM to the A/D bus ( $R \bar{W}=$ high).

    There are two submodes in Mode 0 that allow accessing of DRAM data at either the nibble (4-bit) or byte ( 8 -bit) level. The submode is selected by the $S$ bit (bit 3 ) in the Mode Register:

    $$
    \begin{array}{ll}
    S=0 & \text { CDP Nibble Submode } \\
    S=1 & \text { CDP Byte Submode }
    \end{array}
    $$

    ## CDP Nibble Submode

    The CDP Nibble Submode ( $S=0$ ) reads or writes DRAM data one nibble at a time. Eight bits of data corresponding to two 4-bit LUT addresses ( $\mathrm{P} 3-\mathrm{PO}$ and Q3-Q0) are on the A/D data bus, but only one nibble is read or written during each access.

    When writing the data, the $Q$ nibble should contain the same pixel data as the $P$ nibble. Only one of the nibble values is strobed into DRAM according to the XO value in the X CDP Register which enables the RASL or RASH signal to DRAM during the write. If $\mathrm{XO}=0$, the Q nibble (data bits 3-0) is written
    into the DRAM (row address strobed by $\overline{\operatorname{RASL}}$ ); if $X 0=1$, the P nibble (data bits 7-4) is written into the DRAM (row address strobed by $\overline{\mathrm{RASH}})$.

    When reading the data, only one nibble is read depending on the state of $X O$ in the $X$ CDP. If $X O=0$, the $Q$ nibble is read (row address strobed by $\overline{\text { RASL }}$ ); if $X 0=1$, the $P$ nibble is read (row address strobed by $\overline{\text { RASH }}$ ).

    Reading or writing the data in this submode has no effect on the $X$ CDP or Y CDP register values.

    ## CDP Byte Access Submode

    The CDP Byte Submode $(S=1$ ) reads or writes two 4-bit LUT addresses at a time (in one byte) with an automatic increment of the X CDP value in the X CDP Register during write. Each write of the DRAM data writes the eight data bits on ADO-AD7 into DRAM and increments the X CDP by two upon the completion of the write cycle. (The new X CDP count can be read from the X CDP Register at any time.) As writing of the data continues, the X CDP value eventually wraps around to zero and continues incrementing. The Y CDP Register value must be incremented by writing a new Y CDP value. The automatic increment of $X$ CDP value allows fast horizontal drawing for filling of polygon and rectangle type shapes (i.e., no intervening X CDP update is required). Note that the filled boundaries must be addressed by the horizontal line software since the XO value has no effect in this submode.

    This feature is useful for fast non-modulo 210 Y scrolling with quick reads/writes interleaved by old/new Y address updates. Note that when $S=1$ in the Mode Register, the XO value has no effect (the P nibble corresponds to $\mathrm{XO}=1$ and the Q nibble corresponds to $\mathrm{XO}=0$ ).

    Reading of the DRAM data in this submode does not effect the $X$ CDP count.

    ## CVDG PARAMETER I/O ACCESS

    Six CVDG Parameter Access modes allow the MPU to load control parameters into CVDG internal registers. Two of the modes also allow the MPU to read the parameter values from registers. The exact mode and access is controlled by the selected mode in the Mode Register and the register select input lines (A1 and AO ).

    ## Mode 1 - LUT Address

    In Mode 1, data written to register address 3 ( $\mathrm{A} 1=1$ and AO $=1$ ) is loaded into the LUT Address Register. Four bits control LUT write and read and the other four bits contain the actual LUT address. Bits 7-4 (XPE, RE, GE and BE) enable writing into, or reading from, corresponding sections of the LUT (i.e., XPAR, R, G and B) during Mode 2 access. Bits $3-0$ in the register contain the LUT address ( $0-15$ ) accessed during Mode 2.

    | Register | A1 | AO | R/W | Bit Position |  |  |  |  |  |  |  |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    |  |  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
    | LUT Address | 1 | 1 | W | XPE | RE | GE | ':E | A3 | A2 | A1 | AO |

    

    The LUT address in the LUT Address Register, rather than the LUT addresses read from DRAM, is also used to lookup the color level code in the LUT during the active display time (border and/or pixel) in two circumstances:

    1. Outside the $256 \times 210$ graphics area, i.e., to generate the border color. Note that programs loading the LUT during the vertical blanking interval (VBI) must restore the address of the border color in the LUT into the LUT Address Register prior to unblanking.
    2. Within the $256 \times 210$ graphics area when the LS bit $=0$ in the Switch Register.

    ## Mode 2 - LUT Data

    In Mode 2, LUT data (i.e., color levels and transparent state) written to, or read from, register address 3 ( $\mathrm{A} 1=1, A 0=1$ ) is loaded into, or read from the LUT at the LUT address contained in the LUT Address Register. Only the section (R, G, B and/or XPAR codes) of the LUT entry enabled by bits 7-4 in the LUT Address Register are accessed. Normally only one enable bit at a time is set to a 1 . During a write, data will be written into each LUT section enabled. During a read, ambiguous data will be accessed if more than one enable bit is set.

    The transparent state (XPAR) is only one bit (D3). The other three data bits (D2-DO) are don't care.

    During a write, the data on the A/D bus is written into the CVDG LUT Data Register. The LUT Address Generator latches the 4-bit LUT address from the LUT Data Register rather than from the Video Shift Register. The LUT Address Generator then generates the 16 -bit binary address for routing to the LUT. The LUT is loaded in a similar manner as described for pixel color generation.

    During a read, data is transferred from the LUT directly to the A/D bus without going through the LUT Data Register. XPAR is not availabe for readback.

    |  |  |  | Bit Position |  |  |  |  |  |  |  |  |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    | Register | A1 | AO | R/W | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
    | LUT Data* | 1 | 1 | R/W | - | - | - | - | D3 | D2 | D1 | DO |

    *During a read, data is transferred directly from LUT to AID bus without going through LUT Data Register.

    ## DR7-DR4 Not used (no effect)

    ## DR3-DRO Color Level Code or Transparent Bit State

    | D3 | D2 | D1 | DO | R, G or B Color Output Level |
    | :---: | :---: | :---: | :---: | :---: |
    | 0 | 0 | 0 | 0 | Color output level 0 |
    | 0 | 0 | 0 | 1 | Color output level 1 |
    |  |  |  |  |  |
    | 1 | 1 | 1 |  | Color output level 15 |
    | D3 | D2 | D1 | DO | XPAR Output Level |
    | 0 | X | X | X | XPAR output LOW |
    | 1 | X | X | X | XPAR output HIGH ( $\mathrm{X}=$ no effect) |

    ## Mode 3 - Switch Register

    In Mode 3, switch position data (represented by bit states) written to register address 3 ( $A 1=1, A 0=1$ ) is loaded into the CVDG Switch Register. Three bits control video raster operation, one bit controls the LUT address access source, and one bit enables the CVDG test mode. All five bits are set to a 1 by power up.

    | Register | A1 | AO | R/W | Bit Position |  |  |  |  |  |  |  |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    |  |  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
    | Switch | 1 | 1 | W | NHS | S21 | EXT | LS | TST | - | - | - |


    ## Mode 4 - Y Scroll Register

    In Mode 4, a $Y$ scroll offset value written to register address 3 ( $A 1=1, A 0=1$ ) is loaded into the $Y$ Scroll Register. The Y scroll offset may vary from 0 to 209 (decimal). The value written defines the first horizontal row to be displayed at the top of the $256 \times 210$ graphics image area.

    | Register | A1 | AO | R/W | Bit Position |  |  |  |  |  |  |  |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    |  |  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
    | Y Scroll | 1 | 1 | W | Y7 | Y6 | Y5 | Y4 | Y3 | Y2 | Y1 | YO |

    

    ## Mode 5 - Teletext DMA Pointer

    In Mode 5, an 8-bit Teletext pointer written to register address 2 ( $A 1=1, A 0=0$ ) is loaded into the TTX Pointer Register and Counter. The pointer, consisting of address bits A12-A5 specifies the starting address on a 32-byte boundary for the DMA transfer of teletext data into video page 3 of DRAM. During a teletext DMA data transfer, the Modulo 32 Teletext Counter is incremented by one upon each DMA byte transfer. The TTX Pointer Register is incremented by one every 32 bytes. The value of the Teletext Pointer can be read at any time in Mode 5.

    | Register | A1 | AO | R/W | Bit Position |  |  |  |  |  |  |  |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    |  |  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
    | Teletext Pointer | 1 | 0 | R/W | A12 | A11 | A10 | A9 | A8 | A7 | A6 | A5 |

    The status of the $\mathrm{P}, \mathrm{V} 1$ and V 0 in the Mode/Status Register are unchanged during a Teletext DMA data transfer.

    ## Mode 6 - Set DRAM Page

    In Mode 6, data written to register address 3 ( $\mathrm{A} 1=1, \mathrm{AO}=1$ ) is loaded into the DRAM Page Register. The data contains a 3 -bit DRAM page select code and five unused bits (don't care). These DRAM page select bits specify the 8 k -byte DRAM page accessed during a MPU DRAM access ( $\overline{\text { DRCS }}=$ low) when A13 input is LOW. The DRAM page bits can be read from the Status Register at any time.

    |  |  |  |  | Bit Position |  |  |  |  |  |  |  |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    |  | Register | A1 | A0 | R/W | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ |
    |  | 0 |  |  |  |  |  |  |  |  |  |  |
    | DRAM Page | 1 | 1 | W | - | - | - | - | - | $P$ | $V_{1}$ | V0 |

    ## DR7-DR3 Not Used (no effect)

    | DR2-DRO | Selected DRAM Page |  |
    | :--- | :--- | :--- |
    | DR2 | DR1 | DR0 |
    | (P) | (V1) | (V0) |


    | 0 | 0 | 0 | Video Page 0: 8k-byte video RAM |
    | :--- | :--- | :--- | :--- |
    | 0 | 0 | 1 | Video Page 1: 8k-byte video RAM |
    | 0 | 1 | 0 | Video Page 2: 8k-byte video RAM <br> 0 |
    | 1 | 1 | Video Page 3: 2.3k-byte video RAM; <br> 5.9k-byte program RAM |  |
    | 1 | 0 | 0 | Program Page 0: 16 k -byte optional program <br> RAM accessed via DRCS (additionally paged <br> by A13 and A0 inputs) |

    ## MPU DRAM I/O ACCESS

    When DRCS is LOW, the MPU directly accesses the DRAM in an address map manner. The MPU generates the DRAM row and column addresses (except for two column address lines which are driven by the CVDG). The CVDG drives the AD5 and AD6 lines during DRAM column address time and also outputs control signals ( $\overline{\text { RTIME }}$, CTIME and $\overline{\text { DTIME }}$ ) to enable external A/D bus buffers. MPU address line A1-A8 are enabled onto A/D bus lines ADO-AD7, respectively, by $\overline{R T I M E}$ to drive the DRAM row address. MPU address line A9-A12 are enabled onto A/D bus lines AD1-AD4, respectively, by CTIME to drive the DRAM column address. The CVDG drives AD5 and AD6 with one of two sets of signals during CTIME. External bidirectional data line buffers are enabled by DTIME in the direction controlled by the MPU R $\bar{W}$ output to transfer data between the MPU data bus lines DO-D7 and A/D bus lines AD0-AD7.

    A13 input high causes program DRAM to be accessed during the processor portion of the A/D bus independent of the $P$ bit value in the DRAM Page Register. $\overline{\text { CASP }}$ is asserted in response to the A13 HIGH to strobe the column address lines into program DRAM.

    When A13 input is LOW, the section of DRAM accessed depends on the $P$ bit value in the DRAM Page Register and the A0 input. If $P=0$, video DRAM is accessed; $\overline{C A S 1}$ is generated when $A 0$ is LOW and CAS2 is generated when AO is HIGH. If $P=1$, program DRAM is accessed since $\overline{\text { CASP }}$ is generated instead of $\overline{C A S 1}$ or $\overline{\text { CAS2 }}$ to strobe the DRAM column address.

    The AD5 and AD6 outputs are driven by the CVDG during DRAM column address generation in the processor portion of the A/D bus cycle as controlled by the P bit in the DRAM Page Register. If video DRAM is selected $(P=0)$, the V0 and V1 bits in the DRAM Page Register are output on AD5 and AD6, respectively. If program DRAM is selected $(P=1)$, the A0 and A13 inputs are output on AD5 and AD6, respectively.

    Note that the DRAM requires assertion of all three control signals for a valid access (i.e., $\overline{\text { RAS }}, \overline{\mathrm{CAS}}$ and $\overline{\mathrm{OE}}$ for a read and $\overline{\text { RAS }}$, $\overline{\text { CAS }}$ and $\bar{W}$ for a write). The CVDG sometimes outputs one or two of these signals but not all three control signals in "no access" situations.

    ## TELETEXT DMA I/O ACCESS

    Teletext data can be DMA transferred from a teletext prefix processor connected to the A/D bus to DRAM locations addressed by the CVDG. A 13-bit TTX Latch/Counter determines the DRAM address. The upper 8 -bits of the TTX Counter is a latch. The value of the latch is defined by the TTX Pointer Register which can be loaded in Mode 5 by writing to register address $2(A 1=1$ and $A 0=0)$. The TTX Pointer Register value therefore defines the TTX DMA starting address on a 32-byte boundary. The lower 5 -bits of the TTX Latch/Counter is a modulo 32 counter. This counter increments by one after each TTX byte transfer. When the counter overfiows (i.e., from 31 to 0 )
    the upper count is incremented by one to increment the total address. The address is reset to zero during horizontal blanking. The upper count may be read from the TTX Pointer Register at any time in Mode 5.
    TTX DMA transfer is initiated by asserting $\overline{\text { TTXREQ }}$ to the CVDG. The CVDG asserts TTX Output Enable (TTXOE) to acknowledge TTXREQ receipt, suspends outputting the $E$ and Q clocks for one cycle, outputs the 13 -bit DRAM address and asserts DRAM Write Enable ( $\bar{W}$ ) to enable writing into DRAM.

    Note that DMA must be used only when the horizontal sync is genlocked to the external teletext raster.
    

    Figure 6. CVDG Connection to A/D Bus and DRAM
    
    
    

    ## AC CHARACTERISTICS

    $\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{S S}=0\right)$
    MPU CLOCK AND CONTROL LINE TIMING
    
    

    Figure 8. CVDG-MPU A/D Bus Timing Waveforms

    DRAM TIMING - VIDEO ACCESS CYCLE

    | Ref. Fig. 9 No. | Symbol | Parameter | Min. | Typ. | Max. | Unit | Notes |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    | 1 | $t_{\text {RLRTL }}$ | $\overline{\text { RAS }}$ Low to $\overline{\text { RTIME Low (Delay) }}$ |  | 315 |  | ns |  |
    | 2 | thtLRTH | RTIME Low to $\overline{\text { RTIME }}$ High |  | 70 |  | ns |  |
    | 3 | $t_{\text {RLCTL }}$ | $\overline{\text { RAS Low to CTIME Low (Delay) }}$ |  | 35 |  | ns |  |
    | 4 | ${ }_{\text {t cticth }}$ | $\overline{\text { CTIME Low to CTIME High }}$ |  | 87 |  | ns |  |
    | 5 | $\mathrm{t}_{\text {RLOTL }}$ | $\overline{\text { RAS Low to DTIME Low (Delay) }}$ |  | 122 |  | ns |  |
    | 6 | t DTLDTH | $\overline{\text { DTIME }}$ Low to DTIME High |  | 157 |  | ns |  |
    | 7 | $\mathrm{t}_{\mathrm{RC}}$ | RAM Read/Write Cycle |  | 350 |  | ns |  |
    | 8 | $t_{\text {R }}$ | $\overline{\text { RAS }}$ High Width |  | 105 |  | ns |  |
    | 9 | $t_{\text {RAS }}$ | RAS Low Width |  | 245 |  | ns |  |
    | 10 | $t_{\text {RCD }}$ | $\overline{\text { RAS }}$ Low to $\overline{\text { CAS }}$ Low (Delay) |  | 70 |  | ns |  |
    | 11 | ${ }^{\text {t CaS }}$ | $\overline{\text { CAS }}$ Low Width |  | 245 |  | ns |  |
    | 12 | ${ }^{\text {t }}$ CSH | $\overline{\text { RAS }}$ Low to $\overline{\text { CAS }}$ Rising (Delay) |  | 315 |  | ns |  |
    | 13 | $t_{\text {RSH }}$ | $\overline{\text { CAS }}$ Low to $\overline{\text { RAS }}$ Rising (Delay) |  | 175 |  | ns |  |
    | 14 | ${ }^{\text {t }}$ CPN | $\overline{\text { CAS }}$ High Width |  | 105 |  | ns |  |
    | 15 | ${ }^{\text {t CRP }}$ | $\overline{\text { CAS }}$ High to $\overline{\text { RAS }}$ Falling (Delay) |  | 35 |  | ns |  |
    | 16 | $t_{1}$ | $\overline{\text { RAS }}$ and $\overline{\text { CAS }}$ Transition Times |  | 5 |  | ns |  |
    | 17 | $t_{\text {RCS }}$ | Read Command Setup |  | 105 |  | ns |  |
    | 18 | $t_{\text {ASR }}$ | Row Address Setup |  | 35 |  | ns |  |
    | 19 | $t_{\text {RAH }}$ | Row Address Hold |  | 35 |  | ns |  |
    | 20 | ${ }^{\text {t }}$ ASC | Column Address Setup |  | 35 |  | ns |  |
    | 21 | ${ }^{\text {t }}$ CAH | Column Address Hold |  | 70 |  | ns |  |
    | 22 | $t_{\text {AR }}$ | $\overline{\text { RAS }}$ Low to Column Hold |  | 140 |  | ns |  |
    | 23 | $t_{\text {RAC }}$ | $\overline{\text { RAS }}$ Low to Data Valid (Setup) |  |  | 150 | ns |  |
    | 24 | ${ }^{\text {t }}$ CAC | $\overline{\mathrm{CAS}}$ Low to Data Valid (Setup) |  |  | 80 | ns |  |
    | 25 | $t_{\text {RLGIL }}$ | $\overline{\text { RAS }}$ Low to $\overline{\mathrm{OE} 1}$ Low (Delay) |  | 140 |  | ns |  |
    | 26 | $\mathrm{t}_{\text {GLGHr }}$ | $\overline{\mathrm{OE}}$ Low to $\overline{\mathrm{OE}}$ High |  | 70 |  | ns |  |
    | 27 | toea | $\overline{\mathrm{OE}}$ Low to Data Valid (Setup) | 0 |  | 40 | ns |  |
    | 28 | toez | $\overline{\mathrm{OE}}$ High to Output High Z (Hold) | 0 |  | 35 | ns |  |
    | 29 | $\mathrm{t}_{\text {RLG2L }}$ | RAS Low to OE2 Low (Delay) |  | 210 |  | ns |  |

    DRAM TIMING - MPU DRAM.ACCESS CYCLE

    | Ref. Fig. 9 No. | Symbol | Parameter | Min. | Typ. | Max. | Unit | Notes |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    | 30 | $t_{\text {RRH }}$ | Read Command Hold After $\overline{\text { RAS }}$ High |  | 280 |  | ns |  |
    | 31 | $t_{\text {RCH }}$ | Read Command Hold After $\overline{\text { CAS }}$ High |  | 210 |  | ns |  |
    | 33 | $t_{\text {GLGH }}$ | $\overline{\mathrm{OE} 1}, \overline{\mathrm{OE} 2}$ Low to $\overline{\mathrm{OE} 1}, \overline{\mathrm{OE} 2} \mathrm{High}$ |  | 140 |  | ns |  |
    | 36 | $\mathrm{t}_{\mathrm{DS}}$ | Data Setup |  | 12 |  | ns |  |
    | 37 | $t_{\text {w }}$ | $\bar{W}$ Low to $\bar{W}$ High |  | 140 |  | ns |  |
    | 38 | $t_{\text {DH }}$ | Data Hold After $\bar{W}$ Low |  | 70 |  | ns |  |
    | 39 | ${ }^{\text {t }}$ DHC | Data Hold After CAS Low |  | 175 |  | ns |  |
    | 40 | ${ }^{\text {t }}$ DHR | . Data Hold After RAS Low |  | 245 |  | ns |  |
    | 41 | $t_{\text {WCR }}$ | Write Command Hold After $\overline{\text { RAS }}$ Low |  | 315 |  | ns |  |
    | 42 | ${ }^{\text {t }}$ WCH | Write Command Hold After CASP Low |  | 245 |  | ns |  |
    | 43 | $t_{\text {RWL }}$ | Write Command Setup before $\overline{\text { RAS }}$ Rising |  | 70 |  | ns |  |
    | 44 | ${ }^{\text {t }} \mathrm{CWL}$ | Write Command Setup before $\overline{\mathrm{CAS}}$ Rising |  | 140 |  | ns |  |

    

    Figure 9. CVDG-DRAM A/D Bus Timing Waveforms

    ## TELETEXT DMA CYCLE TIMING

    | Ref. Fig. 10 No. | Symbol | Parameter | Min. | Typ. | Max. | Unit | Notes |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    | 1 | $t_{\text {RLEL }}$ | TTXREQ Low to E Low (Setup) |  | 80 |  | ns |  |
    | 2 | telre | E Low to TTXREQ High (Hold) |  | 10 |  | ns |  |
    | 3 | telgl | E Low to TTXOE Low |  | 595 |  | ns |  |
    | 4 | $t_{\text {GLGH }}$ | TTXOE Low to TTXOE High |  | 140 |  | ns |  |

    

    Figure 10. Teletext Prefix Processor - CVDG Timing Waveforms
    horizontal video timing

    | Ref. Fig. 11 No. | Symbol | Parameter | Min. | Typ. | Max. | Unit | Notes |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    | 1 |  | H Sync to Setup | 9.3 | 9.4 | 9.5 | $\mu \mathrm{S}$ | 1 |
    | 2 |  | H Front Porch | 1.4 | 1.5 | 1.6 | $\mu \mathrm{S}$ | 1 |
    | 3 |  | H Sync to XPAR | - | 10.16 | - | $\mu \mathrm{S}$ | 2 |
    | 4 |  | XPAR Front Porch | - | 2.79 | - | $\mu \mathrm{S}$ | 2 |
    | 5 |  | H Sync to Border 1 | - | 8.38 | - | $\mu \mathrm{S}$ | 2 |
    | 6 |  | H Sync to Graphics | - | 12.57 | - | $\mu \mathrm{S}$ | 2 |
    | 7 |  | H Sync to Border 2 | - | 57.27 | - | $\mu \mathrm{S}$ | 2 |
    | 8 |  | Border Front Porch | - | 2.79 | - | $\mu \mathrm{S}$ | 2 |
    | 9 |  | H Sync Tip | - | 4.81 | - | $\mu \mathrm{S}$ | 2 |
    | 10 |  | H Period (Normal) | - | 63.556 | - | $\mu \mathrm{S}$ | 2 |
    | 11 |  | H Period (Early) | - | 62.857 | - | $\mu \mathrm{S}$ | 2 |

    Notes: 1. RS-170A Specification (shown for reference only).
    2. $\pm 0.1 \mu \mathrm{~s}$; based on 28.636363 MHz SYSCLK input.
    

    Figure 11. Horizontal Video Output Timing Waveforms

    Vertical Cycle Timing

    | Ref. Fig. 12 No. | Symbol | Parameter | Min. | Typ. | Max. | Unit | Notes |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    | 1 | $\mathrm{V}_{\text {SU }}$ | $\overline{\text { VSYNC }}$ Low Input to First Serration Setup | 20 | - | - | ns | 3 |
    | 2 | $V_{H}$ | VSYNC Low Input Pulse Duration | 63.5 | - | - | $\mu \mathrm{S}$ | 3 |
    | - |  | VSYNC Low Output Pulse Duration (Burst Blank) | 19 | - | - | H | 1 |
    | - |  | $\checkmark$ Blank Duration | 52 | - | - | H | 1 |
    | - |  | $V$ Unblank to Graphics Duration (Top Border) | 21 | - | - | H | 1 |
    | - |  | Graphics to V Blank Duration (Bottom Border) | 31 | - | - | H | 1. 2 |

    Notes: 1. $\mathrm{H}=\overline{\mathrm{HSYNC}}$ pulse width $(63.5 \mu \mathrm{~s})$
    2. $2: 1$ interlace mode.
    3. Shown for reference only-not an R6549 requirement.
    

    Figure 12. Vertical Cycle Waveforms-2:1 Interlace

    ## TELETEXT DMA CYCLE TIMING

    | Ref. Fig. 13 No. | Symbol | Parameter |  | Min. | Typ. | Max. | Unit | Notes |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    | 1 | $t_{\text {ELPL }}$ | E Low to PIXCK High |  |  | 0 |  | ns |  |
    | 2 | $\mathrm{t}_{\text {PHPL }}$ | PIXCK High to PIXCK Low |  |  | 70 |  | ns |  |
    | 3 | tplph | PIXCK Low to PIXCK High |  |  | 105 |  | ns |  |
    | 4 | $\mathrm{t}_{\mathrm{PCrC}}$ | PIXCK Cycle | , |  | 175 |  | ns |  |

    

    Figure 13. Video Output Waveforms

    ## DC CHARACTERISTICS

    $\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}$, unless otherwise noted)

    \begin{tabular}{|c|c|c|c|c|c|c|}
    \hline Parameter \& Symbol \& Min. \& Typ. \& Max. \& Unit \& Test Conditions \\
    \hline \begin{tabular}{l}
    Input High Voltage \\
    SYSCLK \\
    \(\overline{\text { IOCS }}, \overline{D R C S}, \overline{T T X R E Q}, A 0, A 1, A 13, R \bar{W}\). \\
    VSYNC, ADO-AD7
    \end{tabular} \& \[
    \begin{aligned}
    \& \mathrm{V}_{\mathrm{IHC}} \\
    \& \mathrm{~V}_{\mathrm{H}}
    \end{aligned}
    \] \& \[
    \begin{aligned}
    \& v_{\mathrm{CC}}-0.75 \\
    \& \mathrm{v}_{\mathrm{SS}}+2.0
    \end{aligned}
    \] \& - \& \[
    \begin{aligned}
    \& \mathrm{v}_{\mathrm{cc}} \\
    \& \mathrm{v}_{\mathrm{cc}}
    \end{aligned}
    \] \& v \& \\
    \hline \begin{tabular}{l}
    Input Low Voltage SYSCLK \\
    \(\overline{\text { IOCS }}, \overline{\text { DRCS }}, \overline{T T X R E Q}, ~ A 0, ~ A 1, ~ A 13, ~ R / \bar{W}\) VSYNC, ADO-AD7
    \end{tabular} \& \[
    \begin{aligned}
    \& \mathrm{v}_{\mathrm{ILC}} \\
    \& \mathrm{v}_{\mathrm{LL}}
    \end{aligned}
    \] \& \[
    \begin{aligned}
    \& v_{S S}-0.3 \\
    \& v_{S S}-0.3
    \end{aligned}
    \] \& - \& \[
    \begin{aligned}
    \& V_{S S}+0.4 \\
    \& v_{S S}+0.8
    \end{aligned}
    \] \& v \& \\
    \hline Input Leakage Current \& \(1 / 2\) \& - \& - \& \(\pm 10\) \& \(\mu \mathrm{A}\) \& \[
    \begin{aligned}
    \& V_{\text {IN }}=0 \mathrm{~V} \text { to } 5.25 \mathrm{~V} \\
    \& V_{C C}=0
    \end{aligned}
    \] \\
    \hline \begin{tabular}{l}
    Output High Voltage \\
    E \\
    Q, \(\overline{\text { RTIME }}\) CTIME, \(\overline{\text { DTIME }}\) \\
    \(\overline{\text { RASL }}, \overline{\text { RASH }}, \bar{W}\) \\
    \(\overline{\text { CAS1 }}, \overline{\text { CAS } 2}, \overline{\text { CASP }}, \overline{\mathrm{OE} 1}, \overline{\mathrm{OE} 2}, \overline{T T X O E}\), C/HSYNC, VSYNC, CSUBC, PIXCK, XPAR ADO-AD7
    \end{tabular} \& \(\mathrm{V}_{\mathrm{OH}}\) \& \[
    \begin{aligned}
    \& v_{C C}-0.75 \\
    \& v_{S S}+2.4
    \end{aligned}
    \]
    \[
    \mathrm{V}_{\mathrm{ss}}+2.4
    \] \&  \& - \& V \& \[
    \begin{aligned}
    \& \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\
    \& \mathrm{I}_{\text {OH }}=-0.14 \mathrm{~mA} \\
    \& \text { Note } 1 \\
    \& \mathrm{I}_{\text {OH }}=-80 \mu \mathrm{~A} \\
    \& \text { Note } 2 \\
    \& \mathrm{I}_{\text {OH }}=-170 \mu \mathrm{~A} \\
    \& \text { Note } 3
    \end{aligned}
    \] \\
    \hline \begin{tabular}{l}
    Output Low Voltage \\
    E \\
    Q, हिTIME, CTIME, DTIME, \\
    \(\overline{\text { RASL }}, \overline{\text { RASH }}, \bar{W}\), \\
    CAS1, \(\overline{\mathrm{CAS} 2}, \overline{\mathrm{CASP}}, \overline{\mathrm{OE} 1}, \overline{\mathrm{OE} 2}, \overline{\mathrm{TTXOE}}\), C/HSYNC, VSYNC, CSUBC, PIXCK, XPAR AD0-AD7
    \end{tabular} \& \(\mathrm{V}_{\text {OL }}\) \&  \& - \& \[
    \begin{aligned}
    \& v_{S S}+0.4 \\
    \& v_{S S}+0.4 \\
    \& v_{S S}+0.4
    \end{aligned}
    \] \& v \& \begin{tabular}{l}
    \[
    \begin{aligned}
    \& \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\
    \& \mathrm{I}_{\mathrm{OL}}=1.7 \mathrm{~mA}
    \end{aligned}
    \] \\
    Note 1
    \[
    \mathrm{lol}=1.6 \mathrm{~mA}
    \] \\
    Note 2
    \[
    \mathrm{I}_{\mathrm{OL}}=3.0 \mathrm{~mA}
    \] \\
    Note 3
    \end{tabular} \\
    \hline Output Leakage Current (Off-State)
    ADO-AD7 \& loff \& - \& - \& \(\pm 20\) \& \(\mu \mathrm{A}\) \& \(\mathrm{V}_{\mathrm{IN}}=0\) to 5.25 V \\
    \hline Output High Voltage R, G, B \& \(\mathrm{V}_{\mathrm{VH}}\) \& - \& +2.800 \& - \& v \& \[
    \begin{aligned}
    \& \mathrm{C}_{\mathrm{L}}=30 \mathrm{pF} \\
    \& \mathrm{R}_{\mathrm{L}}=10 \mathrm{~K} \mathrm{Ohms} \\
    \& \mathrm{t}_{\mathrm{r}} / \mathrm{t}_{\mathrm{t}}=50 \mathrm{~ns}
    \end{aligned}
    \] \\
    \hline Output Low Voltage
    R, G, B \& \(\mathrm{V}_{\mathrm{VL}}\) \& - \& +1.875 \& - \& v \& \\
    \hline Output Blanking Voltage R, G, B \& \(\mathrm{v}_{\text {ve }}\) \& - \& +1.800 \& - \& v \& \\
    \hline ```
    Input Capacitance 

